Spaces:
Running
Running
var __create = Object.create; | |
var __defProp = Object.defineProperty; | |
var __getOwnPropDesc = Object.getOwnPropertyDescriptor; | |
var __getOwnPropNames = Object.getOwnPropertyNames; | |
var __getProtoOf = Object.getPrototypeOf; | |
var __hasOwnProp = Object.prototype.hasOwnProperty; | |
var __commonJS = (cb, mod) => function __require() { | |
return mod || (0, cb[__getOwnPropNames(cb)[0]])((mod = { exports: {} }).exports, mod), mod.exports; | |
}; | |
var __copyProps = (to, from, except, desc) => { | |
if (from && typeof from === "object" || typeof from === "function") { | |
for (let key of __getOwnPropNames(from)) | |
if (!__hasOwnProp.call(to, key) && key !== except) | |
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable }); | |
} | |
return to; | |
}; | |
var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps( | |
// If the importer is in node compatibility mode or this is not an ESM | |
// file that has been converted to a CommonJS file using a Babel- | |
// compatible transform (i.e. "__esModule" has not been set), then set | |
// "default" to the CommonJS "module.exports" for node compatibility. | |
isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target, | |
mod | |
)); | |
// node_modules/set-cookie-parser/lib/set-cookie.js | |
var require_set_cookie = __commonJS({ | |
"node_modules/set-cookie-parser/lib/set-cookie.js"(exports, module) { | |
"use strict"; | |
var defaultParseOptions = { | |
decodeValues: true, | |
map: false, | |
silent: false | |
}; | |
function isNonEmptyString(str) { | |
return typeof str === "string" && !!str.trim(); | |
} | |
function parseString(setCookieValue, options) { | |
var parts = setCookieValue.split(";").filter(isNonEmptyString); | |
var nameValuePairStr = parts.shift(); | |
var parsed = parseNameValuePair(nameValuePairStr); | |
var name = parsed.name; | |
var value = parsed.value; | |
options = options ? Object.assign({}, defaultParseOptions, options) : defaultParseOptions; | |
try { | |
value = options.decodeValues ? decodeURIComponent(value) : value; | |
} catch (e) { | |
console.error( | |
"set-cookie-parser encountered an error while decoding a cookie with value '" + value + "'. Set options.decodeValues to false to disable this feature.", | |
e | |
); | |
} | |
var cookie = { | |
name, | |
value | |
}; | |
parts.forEach(function(part) { | |
var sides = part.split("="); | |
var key = sides.shift().trimLeft().toLowerCase(); | |
var value2 = sides.join("="); | |
if (key === "expires") { | |
cookie.expires = new Date(value2); | |
} else if (key === "max-age") { | |
cookie.maxAge = parseInt(value2, 10); | |
} else if (key === "secure") { | |
cookie.secure = true; | |
} else if (key === "httponly") { | |
cookie.httpOnly = true; | |
} else if (key === "samesite") { | |
cookie.sameSite = value2; | |
} else { | |
cookie[key] = value2; | |
} | |
}); | |
return cookie; | |
} | |
function parseNameValuePair(nameValuePairStr) { | |
var name = ""; | |
var value = ""; | |
var nameValueArr = nameValuePairStr.split("="); | |
if (nameValueArr.length > 1) { | |
name = nameValueArr.shift(); | |
value = nameValueArr.join("="); | |
} else { | |
value = nameValuePairStr; | |
} | |
return { name, value }; | |
} | |
function parse(input, options) { | |
options = options ? Object.assign({}, defaultParseOptions, options) : defaultParseOptions; | |
if (!input) { | |
if (!options.map) { | |
return []; | |
} else { | |
return {}; | |
} | |
} | |
if (input.headers) { | |
if (typeof input.headers.getSetCookie === "function") { | |
input = input.headers.getSetCookie(); | |
} else if (input.headers["set-cookie"]) { | |
input = input.headers["set-cookie"]; | |
} else { | |
var sch = input.headers[Object.keys(input.headers).find(function(key) { | |
return key.toLowerCase() === "set-cookie"; | |
})]; | |
if (!sch && input.headers.cookie && !options.silent) { | |
console.warn( | |
"Warning: set-cookie-parser appears to have been called on a request object. It is designed to parse Set-Cookie headers from responses, not Cookie headers from requests. Set the option {silent: true} to suppress this warning." | |
); | |
} | |
input = sch; | |
} | |
} | |
if (!Array.isArray(input)) { | |
input = [input]; | |
} | |
options = options ? Object.assign({}, defaultParseOptions, options) : defaultParseOptions; | |
if (!options.map) { | |
return input.filter(isNonEmptyString).map(function(str) { | |
return parseString(str, options); | |
}); | |
} else { | |
var cookies = {}; | |
return input.filter(isNonEmptyString).reduce(function(cookies2, str) { | |
var cookie = parseString(str, options); | |
cookies2[cookie.name] = cookie; | |
return cookies2; | |
}, cookies); | |
} | |
} | |
function splitCookiesString2(cookiesString) { | |
if (Array.isArray(cookiesString)) { | |
return cookiesString; | |
} | |
if (typeof cookiesString !== "string") { | |
return []; | |
} | |
var cookiesStrings = []; | |
var pos = 0; | |
var start; | |
var ch; | |
var lastComma; | |
var nextStart; | |
var cookiesSeparatorFound; | |
function skipWhitespace() { | |
while (pos < cookiesString.length && /\s/.test(cookiesString.charAt(pos))) { | |
pos += 1; | |
} | |
return pos < cookiesString.length; | |
} | |
function notSpecialChar() { | |
ch = cookiesString.charAt(pos); | |
return ch !== "=" && ch !== ";" && ch !== ","; | |
} | |
while (pos < cookiesString.length) { | |
start = pos; | |
cookiesSeparatorFound = false; | |
while (skipWhitespace()) { | |
ch = cookiesString.charAt(pos); | |
if (ch === ",") { | |
lastComma = pos; | |
pos += 1; | |
skipWhitespace(); | |
nextStart = pos; | |
while (pos < cookiesString.length && notSpecialChar()) { | |
pos += 1; | |
} | |
if (pos < cookiesString.length && cookiesString.charAt(pos) === "=") { | |
cookiesSeparatorFound = true; | |
pos = nextStart; | |
cookiesStrings.push(cookiesString.substring(start, lastComma)); | |
start = pos; | |
} else { | |
pos = lastComma + 1; | |
} | |
} else { | |
pos += 1; | |
} | |
} | |
if (!cookiesSeparatorFound || pos >= cookiesString.length) { | |
cookiesStrings.push(cookiesString.substring(start, cookiesString.length)); | |
} | |
} | |
return cookiesStrings; | |
} | |
module.exports = parse; | |
module.exports.parse = parse; | |
module.exports.parseString = parseString; | |
module.exports.splitCookiesString = splitCookiesString2; | |
} | |
}); | |
// src/Headers.ts | |
var import_set_cookie_parser = __toESM(require_set_cookie()); | |
// src/utils/normalizeHeaderName.ts | |
var HEADERS_INVALID_CHARACTERS = /[^a-z0-9\-#$%&'*+.^_`|~]/i; | |
function normalizeHeaderName(name) { | |
if (HEADERS_INVALID_CHARACTERS.test(name) || name.trim() === "") { | |
throw new TypeError("Invalid character in header field name"); | |
} | |
return name.trim().toLowerCase(); | |
} | |
// src/utils/normalizeHeaderValue.ts | |
var charCodesToRemove = [ | |
String.fromCharCode(10), | |
String.fromCharCode(13), | |
String.fromCharCode(9), | |
String.fromCharCode(32) | |
]; | |
var HEADER_VALUE_REMOVE_REGEXP = new RegExp( | |
`(^[${charCodesToRemove.join("")}]|$[${charCodesToRemove.join("")}])`, | |
"g" | |
); | |
function normalizeHeaderValue(value) { | |
const nextValue = value.replace(HEADER_VALUE_REMOVE_REGEXP, ""); | |
return nextValue; | |
} | |
// src/utils/isValidHeaderName.ts | |
function isValidHeaderName(value) { | |
if (typeof value !== "string") { | |
return false; | |
} | |
if (value.length === 0) { | |
return false; | |
} | |
for (let i = 0; i < value.length; i++) { | |
const character = value.charCodeAt(i); | |
if (character > 127 || !isToken(character)) { | |
return false; | |
} | |
} | |
return true; | |
} | |
function isToken(value) { | |
return ![ | |
127, | |
32, | |
"(", | |
")", | |
"<", | |
">", | |
"@", | |
",", | |
";", | |
":", | |
"\\", | |
'"', | |
"/", | |
"[", | |
"]", | |
"?", | |
"=", | |
"{", | |
"}" | |
].includes(value); | |
} | |
// src/utils/isValidHeaderValue.ts | |
function isValidHeaderValue(value) { | |
if (typeof value !== "string") { | |
return false; | |
} | |
if (value.trim() !== value) { | |
return false; | |
} | |
for (let i = 0; i < value.length; i++) { | |
const character = value.charCodeAt(i); | |
if ( | |
// NUL. | |
character === 0 || // HTTP newline bytes. | |
character === 10 || character === 13 | |
) { | |
return false; | |
} | |
} | |
return true; | |
} | |
// src/Headers.ts | |
var NORMALIZED_HEADERS = Symbol("normalizedHeaders"); | |
var RAW_HEADER_NAMES = Symbol("rawHeaderNames"); | |
var HEADER_VALUE_DELIMITER = ", "; | |
var _a, _b, _c; | |
var Headers = class _Headers { | |
constructor(init) { | |
// Normalized header {"name":"a, b"} storage. | |
this[_a] = {}; | |
// Keeps the mapping between the raw header name | |
// and the normalized header name to ease the lookup. | |
this[_b] = /* @__PURE__ */ new Map(); | |
this[_c] = "Headers"; | |
if (["Headers", "HeadersPolyfill"].includes(init?.constructor.name) || init instanceof _Headers || typeof globalThis.Headers !== "undefined" && init instanceof globalThis.Headers) { | |
const initialHeaders = init; | |
initialHeaders.forEach((value, name) => { | |
this.append(name, value); | |
}, this); | |
} else if (Array.isArray(init)) { | |
init.forEach(([name, value]) => { | |
this.append( | |
name, | |
Array.isArray(value) ? value.join(HEADER_VALUE_DELIMITER) : value | |
); | |
}); | |
} else if (init) { | |
Object.getOwnPropertyNames(init).forEach((name) => { | |
const value = init[name]; | |
this.append( | |
name, | |
Array.isArray(value) ? value.join(HEADER_VALUE_DELIMITER) : value | |
); | |
}); | |
} | |
} | |
[(_a = NORMALIZED_HEADERS, _b = RAW_HEADER_NAMES, _c = Symbol.toStringTag, Symbol.iterator)]() { | |
return this.entries(); | |
} | |
*keys() { | |
for (const [name] of this.entries()) { | |
yield name; | |
} | |
} | |
*values() { | |
for (const [, value] of this.entries()) { | |
yield value; | |
} | |
} | |
*entries() { | |
let sortedKeys = Object.keys(this[NORMALIZED_HEADERS]).sort( | |
(a, b) => a.localeCompare(b) | |
); | |
for (const name of sortedKeys) { | |
if (name === "set-cookie") { | |
for (const value of this.getSetCookie()) { | |
yield [name, value]; | |
} | |
} else { | |
yield [name, this.get(name)]; | |
} | |
} | |
} | |
/** | |
* Returns a boolean stating whether a `Headers` object contains a certain header. | |
*/ | |
has(name) { | |
if (!isValidHeaderName(name)) { | |
throw new TypeError(`Invalid header name "${name}"`); | |
} | |
return this[NORMALIZED_HEADERS].hasOwnProperty(normalizeHeaderName(name)); | |
} | |
/** | |
* Returns a `ByteString` sequence of all the values of a header with a given name. | |
*/ | |
get(name) { | |
if (!isValidHeaderName(name)) { | |
throw TypeError(`Invalid header name "${name}"`); | |
} | |
return this[NORMALIZED_HEADERS][normalizeHeaderName(name)] ?? null; | |
} | |
/** | |
* Sets a new value for an existing header inside a `Headers` object, or adds the header if it does not already exist. | |
*/ | |
set(name, value) { | |
if (!isValidHeaderName(name) || !isValidHeaderValue(value)) { | |
return; | |
} | |
const normalizedName = normalizeHeaderName(name); | |
const normalizedValue = normalizeHeaderValue(value); | |
this[NORMALIZED_HEADERS][normalizedName] = normalizeHeaderValue(normalizedValue); | |
this[RAW_HEADER_NAMES].set(normalizedName, name); | |
} | |
/** | |
* Appends a new value onto an existing header inside a `Headers` object, or adds the header if it does not already exist. | |
*/ | |
append(name, value) { | |
if (!isValidHeaderName(name) || !isValidHeaderValue(value)) { | |
return; | |
} | |
const normalizedName = normalizeHeaderName(name); | |
const normalizedValue = normalizeHeaderValue(value); | |
let resolvedValue = this.has(normalizedName) ? `${this.get(normalizedName)}, ${normalizedValue}` : normalizedValue; | |
this.set(name, resolvedValue); | |
} | |
/** | |
* Deletes a header from the `Headers` object. | |
*/ | |
delete(name) { | |
if (!isValidHeaderName(name)) { | |
return; | |
} | |
if (!this.has(name)) { | |
return; | |
} | |
const normalizedName = normalizeHeaderName(name); | |
delete this[NORMALIZED_HEADERS][normalizedName]; | |
this[RAW_HEADER_NAMES].delete(normalizedName); | |
} | |
/** | |
* Traverses the `Headers` object, | |
* calling the given callback for each header. | |
*/ | |
forEach(callback, thisArg) { | |
for (const [name, value] of this.entries()) { | |
callback.call(thisArg, value, name, this); | |
} | |
} | |
/** | |
* Returns an array containing the values | |
* of all Set-Cookie headers associated | |
* with a response | |
*/ | |
getSetCookie() { | |
const setCookieHeader = this.get("set-cookie"); | |
if (setCookieHeader === null) { | |
return []; | |
} | |
if (setCookieHeader === "") { | |
return [""]; | |
} | |
return (0, import_set_cookie_parser.splitCookiesString)(setCookieHeader); | |
} | |
}; | |
// src/getRawHeaders.ts | |
function getRawHeaders(headers) { | |
const rawHeaders = {}; | |
for (const [name, value] of headers.entries()) { | |
rawHeaders[headers[RAW_HEADER_NAMES].get(name)] = value; | |
} | |
return rawHeaders; | |
} | |
// src/transformers/headersToList.ts | |
function headersToList(headers) { | |
const headersList = []; | |
headers.forEach((value, name) => { | |
const resolvedValue = value.includes(",") ? value.split(",").map((value2) => value2.trim()) : value; | |
headersList.push([name, resolvedValue]); | |
}); | |
return headersList; | |
} | |
// src/transformers/headersToString.ts | |
function headersToString(headers) { | |
const list = headersToList(headers); | |
const lines = list.map(([name, value]) => { | |
const values = [].concat(value); | |
return `${name}: ${values.join(", ")}`; | |
}); | |
return lines.join("\r\n"); | |
} | |
// src/transformers/headersToObject.ts | |
var singleValueHeaders = ["user-agent"]; | |
function headersToObject(headers) { | |
const headersObject = {}; | |
headers.forEach((value, name) => { | |
const isMultiValue = !singleValueHeaders.includes(name.toLowerCase()) && value.includes(","); | |
headersObject[name] = isMultiValue ? value.split(",").map((s) => s.trim()) : value; | |
}); | |
return headersObject; | |
} | |
// src/transformers/stringToHeaders.ts | |
function stringToHeaders(str) { | |
const lines = str.trim().split(/[\r\n]+/); | |
return lines.reduce((headers, line) => { | |
if (line.trim() === "") { | |
return headers; | |
} | |
const parts = line.split(": "); | |
const name = parts.shift(); | |
const value = parts.join(": "); | |
headers.append(name, value); | |
return headers; | |
}, new Headers()); | |
} | |
// src/transformers/listToHeaders.ts | |
function listToHeaders(list) { | |
const headers = new Headers(); | |
list.forEach(([name, value]) => { | |
const values = [].concat(value); | |
values.forEach((value2) => { | |
headers.append(name, value2); | |
}); | |
}); | |
return headers; | |
} | |
// src/transformers/reduceHeadersObject.ts | |
function reduceHeadersObject(headers, reducer, initialState) { | |
return Object.keys(headers).reduce((nextHeaders, name) => { | |
return reducer(nextHeaders, name, headers[name]); | |
}, initialState); | |
} | |
// src/transformers/objectToHeaders.ts | |
function objectToHeaders(headersObject) { | |
return reduceHeadersObject( | |
headersObject, | |
(headers, name, value) => { | |
const values = [].concat(value).filter(Boolean); | |
values.forEach((value2) => { | |
headers.append(name, value2); | |
}); | |
return headers; | |
}, | |
new Headers() | |
); | |
} | |
// src/transformers/flattenHeadersList.ts | |
function flattenHeadersList(list) { | |
return list.map(([name, values]) => { | |
return [name, [].concat(values).join(", ")]; | |
}); | |
} | |
// src/transformers/flattenHeadersObject.ts | |
function flattenHeadersObject(headersObject) { | |
return reduceHeadersObject( | |
headersObject, | |
(headers, name, value) => { | |
headers[name] = [].concat(value).join(", "); | |
return headers; | |
}, | |
{} | |
); | |
} | |
export { | |
Headers, | |
flattenHeadersList, | |
flattenHeadersObject, | |
getRawHeaders, | |
headersToList, | |
headersToObject, | |
headersToString, | |
listToHeaders, | |
objectToHeaders, | |
reduceHeadersObject, | |
stringToHeaders | |
}; | |
//# sourceMappingURL=index.mjs.map |