Files
Dramlog-Prod/.next/server/vendor-chunks/set-cookie-parser.js
2025-12-17 23:12:53 +01:00

45 lines
74 KiB
JavaScript

"use strict";
/*
* ATTENTION: An "eval-source-map" devtool has been used.
* This devtool is neither made for production nor for readable output files.
* It uses "eval()" calls to create a separate source file with attached SourceMaps in the browser devtools.
* If you are trying to read the output file, select a different devtool (https://webpack.js.org/configuration/devtool/)
* or disable the default devtool with "devtool: false".
* If you are looking for production-ready output files, see mode: "production" (https://webpack.js.org/configuration/mode/).
*/
exports.id = "vendor-chunks/set-cookie-parser";
exports.ids = ["vendor-chunks/set-cookie-parser"];
exports.modules = {
/***/ "(ssr)/./node_modules/set-cookie-parser/lib/set-cookie.js":
/*!**********************************************************!*\
!*** ./node_modules/set-cookie-parser/lib/set-cookie.js ***!
\**********************************************************/
/***/ ((module) => {
eval("\nvar defaultParseOptions = {\n decodeValues: true,\n map: false,\n silent: false\n};\nfunction isForbiddenKey(key) {\n return typeof key !== \"string\" || key in {};\n}\nfunction createNullObj() {\n return Object.create(null);\n}\nfunction isNonEmptyString(str) {\n return typeof str === \"string\" && !!str.trim();\n}\nfunction parseString(setCookieValue, options) {\n var parts = setCookieValue.split(\";\").filter(isNonEmptyString);\n var nameValuePairStr = parts.shift();\n var parsed = parseNameValuePair(nameValuePairStr);\n var name = parsed.name;\n var value = parsed.value;\n options = options ? Object.assign({}, defaultParseOptions, options) : defaultParseOptions;\n if (isForbiddenKey(name)) {\n return null;\n }\n try {\n value = options.decodeValues ? decodeURIComponent(value) : value; // decode cookie value\n } catch (e) {\n console.error(\"set-cookie-parser: failed to decode cookie value. Set options.decodeValues=false to disable decoding.\", e);\n }\n var cookie = createNullObj();\n cookie.name = name;\n cookie.value = value;\n parts.forEach(function(part) {\n var sides = part.split(\"=\");\n var key = sides.shift().trimLeft().toLowerCase();\n if (isForbiddenKey(key)) {\n return;\n }\n var value = sides.join(\"=\");\n if (key === \"expires\") {\n cookie.expires = new Date(value);\n } else if (key === \"max-age\") {\n var n = parseInt(value, 10);\n if (!Number.isNaN(n)) cookie.maxAge = n;\n } else if (key === \"secure\") {\n cookie.secure = true;\n } else if (key === \"httponly\") {\n cookie.httpOnly = true;\n } else if (key === \"samesite\") {\n cookie.sameSite = value;\n } else if (key === \"partitioned\") {\n cookie.partitioned = true;\n } else if (key) {\n cookie[key] = value;\n }\n });\n return cookie;\n}\nfunction parseNameValuePair(nameValuePairStr) {\n // Parses name-value-pair according to rfc6265bis draft\n var name = \"\";\n var value = \"\";\n var nameValueArr = nameValuePairStr.split(\"=\");\n if (nameValueArr.length > 1) {\n name = nameValueArr.shift();\n value = nameValueArr.join(\"=\"); // everything after the first =, joined by a \"=\" if there was more than one part\n } else {\n value = nameValuePairStr;\n }\n return {\n name: name,\n value: value\n };\n}\nfunction parse(input, options) {\n options = options ? Object.assign({}, defaultParseOptions, options) : defaultParseOptions;\n if (!input) {\n if (!options.map) {\n return [];\n } else {\n return createNullObj();\n }\n }\n if (input.headers) {\n if (typeof input.headers.getSetCookie === \"function\") {\n // for fetch responses - they combine headers of the same type in the headers array,\n // but getSetCookie returns an uncombined array\n input = input.headers.getSetCookie();\n } else if (input.headers[\"set-cookie\"]) {\n // fast-path for node.js (which automatically normalizes header names to lower-case)\n input = input.headers[\"set-cookie\"];\n } else {\n // slow-path for other environments - see #25\n var sch = input.headers[Object.keys(input.headers).find(function(key) {\n return key.toLowerCase() === \"set-cookie\";\n })];\n // warn if called on a request-like object with a cookie header rather than a set-cookie header - see #34, 36\n if (!sch && input.headers.cookie && !options.silent) {\n 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.\");\n }\n input = sch;\n }\n }\n if (!Array.isArray(input)) {\n input = [\n input\n ];\n }\n if (!options.map) {\n return input.filter(isNonEmptyString).map(function(str) {\n return parseString(str, options);\n }).filter(Boolean);\n } else {\n var cookies = createNullObj();\n return input.filter(isNonEmptyString).reduce(function(cookies, str) {\n var cookie = parseString(str, options);\n if (cookie && !isForbiddenKey(cookie.name)) {\n cookies[cookie.name] = cookie;\n }\n return cookies;\n }, cookies);\n }\n}\n/*\n Set-Cookie header field-values are sometimes comma joined in one string. This splits them without choking on commas\n that are within a single set-cookie field-value, such as in the Expires portion.\n\n This is uncommon, but explicitly allowed - see https://tools.ietf.org/html/rfc2616#section-4.2\n Node.js does this for every header *except* set-cookie - see https://github.com/nodejs/node/blob/d5e363b77ebaf1caf67cd7528224b651c86815c1/lib/_http_incoming.js#L128\n React Native's fetch does this for *every* header, including set-cookie.\n\n Based on: https://github.com/google/j2objc/commit/16820fdbc8f76ca0c33472810ce0cb03d20efe25\n Credits to: https://github.com/tomball for original and https://github.com/chrusart for JavaScript implementation\n*/ function splitCookiesString(cookiesString) {\n if (Array.isArray(cookiesString)) {\n return cookiesString;\n }\n if (typeof cookiesString !== \"string\") {\n return [];\n }\n var cookiesStrings = [];\n var pos = 0;\n var start;\n var ch;\n var lastComma;\n var nextStart;\n var cookiesSeparatorFound;\n function skipWhitespace() {\n while(pos < cookiesString.length && /\\s/.test(cookiesString.charAt(pos))){\n pos += 1;\n }\n return pos < cookiesString.length;\n }\n function notSpecialChar() {\n ch = cookiesString.charAt(pos);\n return ch !== \"=\" && ch !== \";\" && ch !== \",\";\n }\n while(pos < cookiesString.length){\n start = pos;\n cookiesSeparatorFound = false;\n while(skipWhitespace()){\n ch = cookiesString.charAt(pos);\n if (ch === \",\") {\n // ',' is a cookie separator if we have later first '=', not ';' or ','\n lastComma = pos;\n pos += 1;\n skipWhitespace();\n nextStart = pos;\n while(pos < cookiesString.length && notSpecialChar()){\n pos += 1;\n }\n // currently special character\n if (pos < cookiesString.length && cookiesString.charAt(pos) === \"=\") {\n // we found cookies separator\n cookiesSeparatorFound = true;\n // pos is inside the next cookie, so back up and return it.\n pos = nextStart;\n cookiesStrings.push(cookiesString.substring(start, lastComma));\n start = pos;\n } else {\n // in param ',' or param separator ';',\n // we continue from that comma\n pos = lastComma + 1;\n }\n } else {\n pos += 1;\n }\n }\n if (!cookiesSeparatorFound || pos >= cookiesString.length) {\n cookiesStrings.push(cookiesString.substring(start, cookiesString.length));\n }\n }\n return cookiesStrings;\n}\nmodule.exports = parse;\nmodule.exports.parse = parse;\nmodule.exports.parseString = parseString;\nmodule.exports.splitCookiesString = splitCookiesString;\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"(ssr)/./node_modules/set-cookie-parser/lib/set-cookie.js","mappings":"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","sources":["webpack://whisky-vault/./node_modules/set-cookie-parser/lib/set-cookie.js?3313"],"sourcesContent":["\"use strict\";\n\nvar defaultParseOptions = {\n  decodeValues: true,\n  map: false,\n  silent: false,\n};\n\nfunction isForbiddenKey(key) {\n  return typeof key !== \"string\" || key in {};\n}\n\nfunction createNullObj() {\n  return Object.create(null);\n}\n\nfunction isNonEmptyString(str) {\n  return typeof str === \"string\" && !!str.trim();\n}\n\nfunction parseString(setCookieValue, options) {\n  var parts = setCookieValue.split(\";\").filter(isNonEmptyString);\n\n  var nameValuePairStr = parts.shift();\n  var parsed = parseNameValuePair(nameValuePairStr);\n  var name = parsed.name;\n  var value = parsed.value;\n\n  options = options\n    ? Object.assign({}, defaultParseOptions, options)\n    : defaultParseOptions;\n\n  if (isForbiddenKey(name)) {\n    return null;\n  }\n\n  try {\n    value = options.decodeValues ? decodeURIComponent(value) : value; // decode cookie value\n  } catch (e) {\n    console.error(\n      \"set-cookie-parser: failed to decode cookie value. Set options.decodeValues=false to disable decoding.\",\n      e\n    );\n  }\n\n  var cookie = createNullObj();\n  cookie.name = name;\n  cookie.value = value;\n\n  parts.forEach(function (part) {\n    var sides = part.split(\"=\");\n    var key = sides.shift().trimLeft().toLowerCase();\n    if (isForbiddenKey(key)) {\n      return;\n    }\n    var value = sides.join(\"=\");\n    if (key === \"expires\") {\n      cookie.expires = new Date(value);\n    } else if (key === \"max-age\") {\n      var n = parseInt(value, 10);\n      if (!Number.isNaN(n)) cookie.maxAge = n;\n    } else if (key === \"secure\") {\n      cookie.secure = true;\n    } else if (key === \"httponly\") {\n      cookie.httpOnly = true;\n    } else if (key === \"samesite\") {\n      cookie.sameSite = value;\n    } else if (key === \"partitioned\") {\n      cookie.partitioned = true;\n    } else if (key) {\n      cookie[key] = value;\n    }\n  });\n\n  return cookie;\n}\n\nfunction parseNameValuePair(nameValuePairStr) {\n  // Parses name-value-pair according to rfc6265bis draft\n\n  var name = \"\";\n  var value = \"\";\n  var nameValueArr = nameValuePairStr.split(\"=\");\n  if (nameValueArr.length > 1) {\n    name = nameValueArr.shift();\n    value = nameValueArr.join(\"=\"); // everything after the first =, joined by a \"=\" if there was more than one part\n  } else {\n    value = nameValuePairStr;\n  }\n\n  return { name: name, value: value };\n}\n\nfunction parse(input, options) {\n  options = options\n    ? Object.assign({}, defaultParseOptions, options)\n    : defaultParseOptions;\n\n  if (!input) {\n    if (!options.map) {\n      return [];\n    } else {\n      return createNullObj();\n    }\n  }\n\n  if (input.headers) {\n    if (typeof input.headers.getSetCookie === \"function\") {\n      // for fetch responses - they combine headers of the same type in the headers array,\n      // but getSetCookie returns an uncombined array\n      input = input.headers.getSetCookie();\n    } else if (input.headers[\"set-cookie\"]) {\n      // fast-path for node.js (which automatically normalizes header names to lower-case)\n      input = input.headers[\"set-cookie\"];\n    } else {\n      // slow-path for other environments - see #25\n      var sch =\n        input.headers[\n          Object.keys(input.headers).find(function (key) {\n            return key.toLowerCase() === \"set-cookie\";\n          })\n        ];\n      // warn if called on a request-like object with a cookie header rather than a set-cookie header - see #34, 36\n      if (!sch && input.headers.cookie && !options.silent) {\n        console.warn(\n          \"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.\"\n        );\n      }\n      input = sch;\n    }\n  }\n  if (!Array.isArray(input)) {\n    input = [input];\n  }\n\n  if (!options.map) {\n    return input\n      .filter(isNonEmptyString)\n      .map(function (str) {\n        return parseString(str, options);\n      })\n      .filter(Boolean);\n  } else {\n    var cookies = createNullObj();\n    return input.filter(isNonEmptyString).reduce(function (cookies, str) {\n      var cookie = parseString(str, options);\n      if (cookie && !isForbiddenKey(cookie.name)) {\n        cookies[cookie.name] = cookie;\n      }\n      return cookies;\n    }, cookies);\n  }\n}\n\n/*\n  Set-Cookie header field-values are sometimes comma joined in one string. This splits them without choking on commas\n  that are within a single set-cookie field-value, such as in the Expires portion.\n\n  This is uncommon, but explicitly allowed - see https://tools.ietf.org/html/rfc2616#section-4.2\n  Node.js does this for every header *except* set-cookie - see https://github.com/nodejs/node/blob/d5e363b77ebaf1caf67cd7528224b651c86815c1/lib/_http_incoming.js#L128\n  React Native's fetch does this for *every* header, including set-cookie.\n\n  Based on: https://github.com/google/j2objc/commit/16820fdbc8f76ca0c33472810ce0cb03d20efe25\n  Credits to: https://github.com/tomball for original and https://github.com/chrusart for JavaScript implementation\n*/\nfunction splitCookiesString(cookiesString) {\n  if (Array.isArray(cookiesString)) {\n    return cookiesString;\n  }\n  if (typeof cookiesString !== \"string\") {\n    return [];\n  }\n\n  var cookiesStrings = [];\n  var pos = 0;\n  var start;\n  var ch;\n  var lastComma;\n  var nextStart;\n  var cookiesSeparatorFound;\n\n  function skipWhitespace() {\n    while (pos < cookiesString.length && /\\s/.test(cookiesString.charAt(pos))) {\n      pos += 1;\n    }\n    return pos < cookiesString.length;\n  }\n\n  function notSpecialChar() {\n    ch = cookiesString.charAt(pos);\n\n    return ch !== \"=\" && ch !== \";\" && ch !== \",\";\n  }\n\n  while (pos < cookiesString.length) {\n    start = pos;\n    cookiesSeparatorFound = false;\n\n    while (skipWhitespace()) {\n      ch = cookiesString.charAt(pos);\n      if (ch === \",\") {\n        // ',' is a cookie separator if we have later first '=', not ';' or ','\n        lastComma = pos;\n        pos += 1;\n\n        skipWhitespace();\n        nextStart = pos;\n\n        while (pos < cookiesString.length && notSpecialChar()) {\n          pos += 1;\n        }\n\n        // currently special character\n        if (pos < cookiesString.length && cookiesString.charAt(pos) === \"=\") {\n          // we found cookies separator\n          cookiesSeparatorFound = true;\n          // pos is inside the next cookie, so back up and return it.\n          pos = nextStart;\n          cookiesStrings.push(cookiesString.substring(start, lastComma));\n          start = pos;\n        } else {\n          // in param ',' or param separator ';',\n          // we continue from that comma\n          pos = lastComma + 1;\n        }\n      } else {\n        pos += 1;\n      }\n    }\n\n    if (!cookiesSeparatorFound || pos >= cookiesString.length) {\n      cookiesStrings.push(cookiesString.substring(start, cookiesString.length));\n    }\n  }\n\n  return cookiesStrings;\n}\n\nmodule.exports = parse;\nmodule.exports.parse = parse;\nmodule.exports.parseString = parseString;\nmodule.exports.splitCookiesString = splitCookiesString;\n"],"names":["defaultParseOptions","decodeValues","map","silent","isForbiddenKey","key","createNullObj","Object","create","isNonEmptyString","str","trim","parseString","setCookieValue","options","parts","split","filter","nameValuePairStr","shift","parsed","parseNameValuePair","name","value","assign","decodeURIComponent","e","console","error","cookie","forEach","part","sides","trimLeft","toLowerCase","join","expires","Date","n","parseInt","Number","isNaN","maxAge","secure","httpOnly","sameSite","partitioned","nameValueArr","length","parse","input","headers","getSetCookie","sch","keys","find","warn","Array","isArray","Boolean","cookies","reduce","splitCookiesString","cookiesString","cookiesStrings","pos","start","ch","lastComma","nextStart","cookiesSeparatorFound","skipWhitespace","test","charAt","notSpecialChar","push","substring","module","exports"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/set-cookie-parser/lib/set-cookie.js\n");
/***/ }),
/***/ "(action-browser)/./node_modules/set-cookie-parser/lib/set-cookie.js":
/*!**********************************************************!*\
!*** ./node_modules/set-cookie-parser/lib/set-cookie.js ***!
\**********************************************************/
/***/ ((module) => {
eval("\nvar defaultParseOptions = {\n decodeValues: true,\n map: false,\n silent: false\n};\nfunction isForbiddenKey(key) {\n return typeof key !== \"string\" || key in {};\n}\nfunction createNullObj() {\n return Object.create(null);\n}\nfunction isNonEmptyString(str) {\n return typeof str === \"string\" && !!str.trim();\n}\nfunction parseString(setCookieValue, options) {\n var parts = setCookieValue.split(\";\").filter(isNonEmptyString);\n var nameValuePairStr = parts.shift();\n var parsed = parseNameValuePair(nameValuePairStr);\n var name = parsed.name;\n var value = parsed.value;\n options = options ? Object.assign({}, defaultParseOptions, options) : defaultParseOptions;\n if (isForbiddenKey(name)) {\n return null;\n }\n try {\n value = options.decodeValues ? decodeURIComponent(value) : value; // decode cookie value\n } catch (e) {\n console.error(\"set-cookie-parser: failed to decode cookie value. Set options.decodeValues=false to disable decoding.\", e);\n }\n var cookie = createNullObj();\n cookie.name = name;\n cookie.value = value;\n parts.forEach(function(part) {\n var sides = part.split(\"=\");\n var key = sides.shift().trimLeft().toLowerCase();\n if (isForbiddenKey(key)) {\n return;\n }\n var value = sides.join(\"=\");\n if (key === \"expires\") {\n cookie.expires = new Date(value);\n } else if (key === \"max-age\") {\n var n = parseInt(value, 10);\n if (!Number.isNaN(n)) cookie.maxAge = n;\n } else if (key === \"secure\") {\n cookie.secure = true;\n } else if (key === \"httponly\") {\n cookie.httpOnly = true;\n } else if (key === \"samesite\") {\n cookie.sameSite = value;\n } else if (key === \"partitioned\") {\n cookie.partitioned = true;\n } else if (key) {\n cookie[key] = value;\n }\n });\n return cookie;\n}\nfunction parseNameValuePair(nameValuePairStr) {\n // Parses name-value-pair according to rfc6265bis draft\n var name = \"\";\n var value = \"\";\n var nameValueArr = nameValuePairStr.split(\"=\");\n if (nameValueArr.length > 1) {\n name = nameValueArr.shift();\n value = nameValueArr.join(\"=\"); // everything after the first =, joined by a \"=\" if there was more than one part\n } else {\n value = nameValuePairStr;\n }\n return {\n name: name,\n value: value\n };\n}\nfunction parse(input, options) {\n options = options ? Object.assign({}, defaultParseOptions, options) : defaultParseOptions;\n if (!input) {\n if (!options.map) {\n return [];\n } else {\n return createNullObj();\n }\n }\n if (input.headers) {\n if (typeof input.headers.getSetCookie === \"function\") {\n // for fetch responses - they combine headers of the same type in the headers array,\n // but getSetCookie returns an uncombined array\n input = input.headers.getSetCookie();\n } else if (input.headers[\"set-cookie\"]) {\n // fast-path for node.js (which automatically normalizes header names to lower-case)\n input = input.headers[\"set-cookie\"];\n } else {\n // slow-path for other environments - see #25\n var sch = input.headers[Object.keys(input.headers).find(function(key) {\n return key.toLowerCase() === \"set-cookie\";\n })];\n // warn if called on a request-like object with a cookie header rather than a set-cookie header - see #34, 36\n if (!sch && input.headers.cookie && !options.silent) {\n 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.\");\n }\n input = sch;\n }\n }\n if (!Array.isArray(input)) {\n input = [\n input\n ];\n }\n if (!options.map) {\n return input.filter(isNonEmptyString).map(function(str) {\n return parseString(str, options);\n }).filter(Boolean);\n } else {\n var cookies = createNullObj();\n return input.filter(isNonEmptyString).reduce(function(cookies, str) {\n var cookie = parseString(str, options);\n if (cookie && !isForbiddenKey(cookie.name)) {\n cookies[cookie.name] = cookie;\n }\n return cookies;\n }, cookies);\n }\n}\n/*\n Set-Cookie header field-values are sometimes comma joined in one string. This splits them without choking on commas\n that are within a single set-cookie field-value, such as in the Expires portion.\n\n This is uncommon, but explicitly allowed - see https://tools.ietf.org/html/rfc2616#section-4.2\n Node.js does this for every header *except* set-cookie - see https://github.com/nodejs/node/blob/d5e363b77ebaf1caf67cd7528224b651c86815c1/lib/_http_incoming.js#L128\n React Native's fetch does this for *every* header, including set-cookie.\n\n Based on: https://github.com/google/j2objc/commit/16820fdbc8f76ca0c33472810ce0cb03d20efe25\n Credits to: https://github.com/tomball for original and https://github.com/chrusart for JavaScript implementation\n*/ function splitCookiesString(cookiesString) {\n if (Array.isArray(cookiesString)) {\n return cookiesString;\n }\n if (typeof cookiesString !== \"string\") {\n return [];\n }\n var cookiesStrings = [];\n var pos = 0;\n var start;\n var ch;\n var lastComma;\n var nextStart;\n var cookiesSeparatorFound;\n function skipWhitespace() {\n while(pos < cookiesString.length && /\\s/.test(cookiesString.charAt(pos))){\n pos += 1;\n }\n return pos < cookiesString.length;\n }\n function notSpecialChar() {\n ch = cookiesString.charAt(pos);\n return ch !== \"=\" && ch !== \";\" && ch !== \",\";\n }\n while(pos < cookiesString.length){\n start = pos;\n cookiesSeparatorFound = false;\n while(skipWhitespace()){\n ch = cookiesString.charAt(pos);\n if (ch === \",\") {\n // ',' is a cookie separator if we have later first '=', not ';' or ','\n lastComma = pos;\n pos += 1;\n skipWhitespace();\n nextStart = pos;\n while(pos < cookiesString.length && notSpecialChar()){\n pos += 1;\n }\n // currently special character\n if (pos < cookiesString.length && cookiesString.charAt(pos) === \"=\") {\n // we found cookies separator\n cookiesSeparatorFound = true;\n // pos is inside the next cookie, so back up and return it.\n pos = nextStart;\n cookiesStrings.push(cookiesString.substring(start, lastComma));\n start = pos;\n } else {\n // in param ',' or param separator ';',\n // we continue from that comma\n pos = lastComma + 1;\n }\n } else {\n pos += 1;\n }\n }\n if (!cookiesSeparatorFound || pos >= cookiesString.length) {\n cookiesStrings.push(cookiesString.substring(start, cookiesString.length));\n }\n }\n return cookiesStrings;\n}\nmodule.exports = parse;\nmodule.exports.parse = parse;\nmodule.exports.parseString = parseString;\nmodule.exports.splitCookiesString = splitCookiesString;\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"(action-browser)/./node_modules/set-cookie-parser/lib/set-cookie.js","mappings":"AAAa;AAEb,IAAIA,sBAAsB;IACxBC,cAAc;IACdC,KAAK;IACLC,QAAQ;AACV;AAEA,SAASC,eAAeC,GAAG;IACzB,OAAO,OAAOA,QAAQ,YAAYA,OAAO,CAAC;AAC5C;AAEA,SAASC;IACP,OAAOC,OAAOC,MAAM,CAAC;AACvB;AAEA,SAASC,iBAAiBC,GAAG;IAC3B,OAAO,OAAOA,QAAQ,YAAY,CAAC,CAACA,IAAIC,IAAI;AAC9C;AAEA,SAASC,YAAYC,cAAc,EAAEC,OAAO;IAC1C,IAAIC,QAAQF,eAAeG,KAAK,CAAC,KAAKC,MAAM,CAACR;IAE7C,IAAIS,mBAAmBH,MAAMI,KAAK;IAClC,IAAIC,SAASC,mBAAmBH;IAChC,IAAII,OAAOF,OAAOE,IAAI;IACtB,IAAIC,QAAQH,OAAOG,KAAK;IAExBT,UAAUA,UACNP,OAAOiB,MAAM,CAAC,CAAC,GAAGxB,qBAAqBc,WACvCd;IAEJ,IAAII,eAAekB,OAAO;QACxB,OAAO;IACT;IAEA,IAAI;QACFC,QAAQT,QAAQb,YAAY,GAAGwB,mBAAmBF,SAASA,OAAO,sBAAsB;IAC1F,EAAE,OAAOG,GAAG;QACVC,QAAQC,KAAK,CACX,yGACAF;IAEJ;IAEA,IAAIG,SAASvB;IACbuB,OAAOP,IAAI,GAAGA;IACdO,OAAON,KAAK,GAAGA;IAEfR,MAAMe,OAAO,CAAC,SAAUC,IAAI;QAC1B,IAAIC,QAAQD,KAAKf,KAAK,CAAC;QACvB,IAAIX,MAAM2B,MAAMb,KAAK,GAAGc,QAAQ,GAAGC,WAAW;QAC9C,IAAI9B,eAAeC,MAAM;YACvB;QACF;QACA,IAAIkB,QAAQS,MAAMG,IAAI,CAAC;QACvB,IAAI9B,QAAQ,WAAW;YACrBwB,OAAOO,OAAO,GAAG,IAAIC,KAAKd;QAC5B,OAAO,IAAIlB,QAAQ,WAAW;YAC5B,IAAIiC,IAAIC,SAAShB,OAAO;YACxB,IAAI,CAACiB,OAAOC,KAAK,CAACH,IAAIT,OAAOa,MAAM,GAAGJ;QACxC,OAAO,IAAIjC,QAAQ,UAAU;YAC3BwB,OAAOc,MAAM,GAAG;QAClB,OAAO,IAAItC,QAAQ,YAAY;YAC7BwB,OAAOe,QAAQ,GAAG;QACpB,OAAO,IAAIvC,QAAQ,YAAY;YAC7BwB,OAAOgB,QAAQ,GAAGtB;QACpB,OAAO,IAAIlB,QAAQ,eAAe;YAChCwB,OAAOiB,WAAW,GAAG;QACvB,OAAO,IAAIzC,KAAK;YACdwB,MAAM,CAACxB,IAAI,GAAGkB;QAChB;IACF;IAEA,OAAOM;AACT;AAEA,SAASR,mBAAmBH,gBAAgB;IAC1C,uDAAuD;IAEvD,IAAII,OAAO;IACX,IAAIC,QAAQ;IACZ,IAAIwB,eAAe7B,iBAAiBF,KAAK,CAAC;IAC1C,IAAI+B,aAAaC,MAAM,GAAG,GAAG;QAC3B1B,OAAOyB,aAAa5B,KAAK;QACzBI,QAAQwB,aAAaZ,IAAI,CAAC,MAAM,gFAAgF;IAClH,OAAO;QACLZ,QAAQL;IACV;IAEA,OAAO;QAAEI,MAAMA;QAAMC,OAAOA;IAAM;AACpC;AAEA,SAAS0B,MAAMC,KAAK,EAAEpC,OAAO;IAC3BA,UAAUA,UACNP,OAAOiB,MAAM,CAAC,CAAC,GAAGxB,qBAAqBc,WACvCd;IAEJ,IAAI,CAACkD,OAAO;QACV,IAAI,CAACpC,QAAQZ,GAAG,EAAE;YAChB,OAAO,EAAE;QACX,OAAO;YACL,OAAOI;QACT;IACF;IAEA,IAAI4C,MAAMC,OAAO,EAAE;QACjB,IAAI,OAAOD,MAAMC,OAAO,CAACC,YAAY,KAAK,YAAY;YACpD,oFAAoF;YACpF,+CAA+C;YAC/CF,QAAQA,MAAMC,OAAO,CAACC,YAAY;QACpC,OAAO,IAAIF,MAAMC,OAAO,CAAC,aAAa,EAAE;YACtC,oFAAoF;YACpFD,QAAQA,MAAMC,OAAO,CAAC,aAAa;QACrC,OAAO;YACL,6CAA6C;YAC7C,IAAIE,MACFH,MAAMC,OAAO,CACX5C,OAAO+C,IAAI,CAACJ,MAAMC,OAAO,EAAEI,IAAI,CAAC,SAAUlD,GAAG;gBAC3C,OAAOA,IAAI6B,WAAW,OAAO;YAC/B,GACD;YACH,6GAA6G;YAC7G,IAAI,CAACmB,OAAOH,MAAMC,OAAO,CAACtB,MAAM,IAAI,CAACf,QAAQX,MAAM,EAAE;gBACnDwB,QAAQ6B,IAAI,CACV;YAEJ;YACAN,QAAQG;QACV;IACF;IACA,IAAI,CAACI,MAAMC,OAAO,CAACR,QAAQ;QACzBA,QAAQ;YAACA;SAAM;IACjB;IAEA,IAAI,CAACpC,QAAQZ,GAAG,EAAE;QAChB,OAAOgD,MACJjC,MAAM,CAACR,kBACPP,GAAG,CAAC,SAAUQ,GAAG;YAChB,OAAOE,YAAYF,KAAKI;QAC1B,GACCG,MAAM,CAAC0C;IACZ,OAAO;QACL,IAAIC,UAAUtD;QACd,OAAO4C,MAAMjC,MAAM,CAACR,kBAAkBoD,MAAM,CAAC,SAAUD,OAAO,EAAElD,GAAG;YACjE,IAAImB,SAASjB,YAAYF,KAAKI;YAC9B,IAAIe,UAAU,CAACzB,eAAeyB,OAAOP,IAAI,GAAG;gBAC1CsC,OAAO,CAAC/B,OAAOP,IAAI,CAAC,GAAGO;YACzB;YACA,OAAO+B;QACT,GAAGA;IACL;AACF;AAEA;;;;;;;;;;AAUA,GACA,SAASE,mBAAmBC,aAAa;IACvC,IAAIN,MAAMC,OAAO,CAACK,gBAAgB;QAChC,OAAOA;IACT;IACA,IAAI,OAAOA,kBAAkB,UAAU;QACrC,OAAO,EAAE;IACX;IAEA,IAAIC,iBAAiB,EAAE;IACvB,IAAIC,MAAM;IACV,IAAIC;IACJ,IAAIC;IACJ,IAAIC;IACJ,IAAIC;IACJ,IAAIC;IAEJ,SAASC;QACP,MAAON,MAAMF,cAAcf,MAAM,IAAI,KAAKwB,IAAI,CAACT,cAAcU,MAAM,CAACR,MAAO;YACzEA,OAAO;QACT;QACA,OAAOA,MAAMF,cAAcf,MAAM;IACnC;IAEA,SAAS0B;QACPP,KAAKJ,cAAcU,MAAM,CAACR;QAE1B,OAAOE,OAAO,OAAOA,OAAO,OAAOA,OAAO;IAC5C;IAEA,MAAOF,MAAMF,cAAcf,MAAM,CAAE;QACjCkB,QAAQD;QACRK,wBAAwB;QAExB,MAAOC,iBAAkB;YACvBJ,KAAKJ,cAAcU,MAAM,CAACR;YAC1B,IAAIE,OAAO,KAAK;gBACd,uEAAuE;gBACvEC,YAAYH;gBACZA,OAAO;gBAEPM;gBACAF,YAAYJ;gBAEZ,MAAOA,MAAMF,cAAcf,MAAM,IAAI0B,iBAAkB;oBACrDT,OAAO;gBACT;gBAEA,8BAA8B;gBAC9B,IAAIA,MAAMF,cAAcf,MAAM,IAAIe,cAAcU,MAAM,CAACR,SAAS,KAAK;oBACnE,6BAA6B;oBAC7BK,wBAAwB;oBACxB,2DAA2D;oBAC3DL,MAAMI;oBACNL,eAAeW,IAAI,CAACZ,cAAca,SAAS,CAACV,OAAOE;oBACnDF,QAAQD;gBACV,OAAO;oBACL,uCAAuC;oBACvC,8BAA8B;oBAC9BA,MAAMG,YAAY;gBACpB;YACF,OAAO;gBACLH,OAAO;YACT;QACF;QAEA,IAAI,CAACK,yBAAyBL,OAAOF,cAAcf,MAAM,EAAE;YACzDgB,eAAeW,IAAI,CAACZ,cAAca,SAAS,CAACV,OAAOH,cAAcf,MAAM;QACzE;IACF;IAEA,OAAOgB;AACT;AAEAa,OAAOC,OAAO,GAAG7B;AACjB4B,oBAAoB,GAAG5B;AACvB4B,0BAA0B,GAAGjE;AAC7BiE,iCAAiC,GAAGf","sources":["webpack://whisky-vault/./node_modules/set-cookie-parser/lib/set-cookie.js?3313"],"sourcesContent":["\"use strict\";\n\nvar defaultParseOptions = {\n  decodeValues: true,\n  map: false,\n  silent: false,\n};\n\nfunction isForbiddenKey(key) {\n  return typeof key !== \"string\" || key in {};\n}\n\nfunction createNullObj() {\n  return Object.create(null);\n}\n\nfunction isNonEmptyString(str) {\n  return typeof str === \"string\" && !!str.trim();\n}\n\nfunction parseString(setCookieValue, options) {\n  var parts = setCookieValue.split(\";\").filter(isNonEmptyString);\n\n  var nameValuePairStr = parts.shift();\n  var parsed = parseNameValuePair(nameValuePairStr);\n  var name = parsed.name;\n  var value = parsed.value;\n\n  options = options\n    ? Object.assign({}, defaultParseOptions, options)\n    : defaultParseOptions;\n\n  if (isForbiddenKey(name)) {\n    return null;\n  }\n\n  try {\n    value = options.decodeValues ? decodeURIComponent(value) : value; // decode cookie value\n  } catch (e) {\n    console.error(\n      \"set-cookie-parser: failed to decode cookie value. Set options.decodeValues=false to disable decoding.\",\n      e\n    );\n  }\n\n  var cookie = createNullObj();\n  cookie.name = name;\n  cookie.value = value;\n\n  parts.forEach(function (part) {\n    var sides = part.split(\"=\");\n    var key = sides.shift().trimLeft().toLowerCase();\n    if (isForbiddenKey(key)) {\n      return;\n    }\n    var value = sides.join(\"=\");\n    if (key === \"expires\") {\n      cookie.expires = new Date(value);\n    } else if (key === \"max-age\") {\n      var n = parseInt(value, 10);\n      if (!Number.isNaN(n)) cookie.maxAge = n;\n    } else if (key === \"secure\") {\n      cookie.secure = true;\n    } else if (key === \"httponly\") {\n      cookie.httpOnly = true;\n    } else if (key === \"samesite\") {\n      cookie.sameSite = value;\n    } else if (key === \"partitioned\") {\n      cookie.partitioned = true;\n    } else if (key) {\n      cookie[key] = value;\n    }\n  });\n\n  return cookie;\n}\n\nfunction parseNameValuePair(nameValuePairStr) {\n  // Parses name-value-pair according to rfc6265bis draft\n\n  var name = \"\";\n  var value = \"\";\n  var nameValueArr = nameValuePairStr.split(\"=\");\n  if (nameValueArr.length > 1) {\n    name = nameValueArr.shift();\n    value = nameValueArr.join(\"=\"); // everything after the first =, joined by a \"=\" if there was more than one part\n  } else {\n    value = nameValuePairStr;\n  }\n\n  return { name: name, value: value };\n}\n\nfunction parse(input, options) {\n  options = options\n    ? Object.assign({}, defaultParseOptions, options)\n    : defaultParseOptions;\n\n  if (!input) {\n    if (!options.map) {\n      return [];\n    } else {\n      return createNullObj();\n    }\n  }\n\n  if (input.headers) {\n    if (typeof input.headers.getSetCookie === \"function\") {\n      // for fetch responses - they combine headers of the same type in the headers array,\n      // but getSetCookie returns an uncombined array\n      input = input.headers.getSetCookie();\n    } else if (input.headers[\"set-cookie\"]) {\n      // fast-path for node.js (which automatically normalizes header names to lower-case)\n      input = input.headers[\"set-cookie\"];\n    } else {\n      // slow-path for other environments - see #25\n      var sch =\n        input.headers[\n          Object.keys(input.headers).find(function (key) {\n            return key.toLowerCase() === \"set-cookie\";\n          })\n        ];\n      // warn if called on a request-like object with a cookie header rather than a set-cookie header - see #34, 36\n      if (!sch && input.headers.cookie && !options.silent) {\n        console.warn(\n          \"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.\"\n        );\n      }\n      input = sch;\n    }\n  }\n  if (!Array.isArray(input)) {\n    input = [input];\n  }\n\n  if (!options.map) {\n    return input\n      .filter(isNonEmptyString)\n      .map(function (str) {\n        return parseString(str, options);\n      })\n      .filter(Boolean);\n  } else {\n    var cookies = createNullObj();\n    return input.filter(isNonEmptyString).reduce(function (cookies, str) {\n      var cookie = parseString(str, options);\n      if (cookie && !isForbiddenKey(cookie.name)) {\n        cookies[cookie.name] = cookie;\n      }\n      return cookies;\n    }, cookies);\n  }\n}\n\n/*\n  Set-Cookie header field-values are sometimes comma joined in one string. This splits them without choking on commas\n  that are within a single set-cookie field-value, such as in the Expires portion.\n\n  This is uncommon, but explicitly allowed - see https://tools.ietf.org/html/rfc2616#section-4.2\n  Node.js does this for every header *except* set-cookie - see https://github.com/nodejs/node/blob/d5e363b77ebaf1caf67cd7528224b651c86815c1/lib/_http_incoming.js#L128\n  React Native's fetch does this for *every* header, including set-cookie.\n\n  Based on: https://github.com/google/j2objc/commit/16820fdbc8f76ca0c33472810ce0cb03d20efe25\n  Credits to: https://github.com/tomball for original and https://github.com/chrusart for JavaScript implementation\n*/\nfunction splitCookiesString(cookiesString) {\n  if (Array.isArray(cookiesString)) {\n    return cookiesString;\n  }\n  if (typeof cookiesString !== \"string\") {\n    return [];\n  }\n\n  var cookiesStrings = [];\n  var pos = 0;\n  var start;\n  var ch;\n  var lastComma;\n  var nextStart;\n  var cookiesSeparatorFound;\n\n  function skipWhitespace() {\n    while (pos < cookiesString.length && /\\s/.test(cookiesString.charAt(pos))) {\n      pos += 1;\n    }\n    return pos < cookiesString.length;\n  }\n\n  function notSpecialChar() {\n    ch = cookiesString.charAt(pos);\n\n    return ch !== \"=\" && ch !== \";\" && ch !== \",\";\n  }\n\n  while (pos < cookiesString.length) {\n    start = pos;\n    cookiesSeparatorFound = false;\n\n    while (skipWhitespace()) {\n      ch = cookiesString.charAt(pos);\n      if (ch === \",\") {\n        // ',' is a cookie separator if we have later first '=', not ';' or ','\n        lastComma = pos;\n        pos += 1;\n\n        skipWhitespace();\n        nextStart = pos;\n\n        while (pos < cookiesString.length && notSpecialChar()) {\n          pos += 1;\n        }\n\n        // currently special character\n        if (pos < cookiesString.length && cookiesString.charAt(pos) === \"=\") {\n          // we found cookies separator\n          cookiesSeparatorFound = true;\n          // pos is inside the next cookie, so back up and return it.\n          pos = nextStart;\n          cookiesStrings.push(cookiesString.substring(start, lastComma));\n          start = pos;\n        } else {\n          // in param ',' or param separator ';',\n          // we continue from that comma\n          pos = lastComma + 1;\n        }\n      } else {\n        pos += 1;\n      }\n    }\n\n    if (!cookiesSeparatorFound || pos >= cookiesString.length) {\n      cookiesStrings.push(cookiesString.substring(start, cookiesString.length));\n    }\n  }\n\n  return cookiesStrings;\n}\n\nmodule.exports = parse;\nmodule.exports.parse = parse;\nmodule.exports.parseString = parseString;\nmodule.exports.splitCookiesString = splitCookiesString;\n"],"names":["defaultParseOptions","decodeValues","map","silent","isForbiddenKey","key","createNullObj","Object","create","isNonEmptyString","str","trim","parseString","setCookieValue","options","parts","split","filter","nameValuePairStr","shift","parsed","parseNameValuePair","name","value","assign","decodeURIComponent","e","console","error","cookie","forEach","part","sides","trimLeft","toLowerCase","join","expires","Date","n","parseInt","Number","isNaN","maxAge","secure","httpOnly","sameSite","partitioned","nameValueArr","length","parse","input","headers","getSetCookie","sch","keys","find","warn","Array","isArray","Boolean","cookies","reduce","splitCookiesString","cookiesString","cookiesStrings","pos","start","ch","lastComma","nextStart","cookiesSeparatorFound","skipWhitespace","test","charAt","notSpecialChar","push","substring","module","exports"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///(action-browser)/./node_modules/set-cookie-parser/lib/set-cookie.js\n");
/***/ }),
/***/ "(rsc)/./node_modules/set-cookie-parser/lib/set-cookie.js":
/*!**********************************************************!*\
!*** ./node_modules/set-cookie-parser/lib/set-cookie.js ***!
\**********************************************************/
/***/ ((module) => {
eval("\nvar defaultParseOptions = {\n decodeValues: true,\n map: false,\n silent: false\n};\nfunction isForbiddenKey(key) {\n return typeof key !== \"string\" || key in {};\n}\nfunction createNullObj() {\n return Object.create(null);\n}\nfunction isNonEmptyString(str) {\n return typeof str === \"string\" && !!str.trim();\n}\nfunction parseString(setCookieValue, options) {\n var parts = setCookieValue.split(\";\").filter(isNonEmptyString);\n var nameValuePairStr = parts.shift();\n var parsed = parseNameValuePair(nameValuePairStr);\n var name = parsed.name;\n var value = parsed.value;\n options = options ? Object.assign({}, defaultParseOptions, options) : defaultParseOptions;\n if (isForbiddenKey(name)) {\n return null;\n }\n try {\n value = options.decodeValues ? decodeURIComponent(value) : value; // decode cookie value\n } catch (e) {\n console.error(\"set-cookie-parser: failed to decode cookie value. Set options.decodeValues=false to disable decoding.\", e);\n }\n var cookie = createNullObj();\n cookie.name = name;\n cookie.value = value;\n parts.forEach(function(part) {\n var sides = part.split(\"=\");\n var key = sides.shift().trimLeft().toLowerCase();\n if (isForbiddenKey(key)) {\n return;\n }\n var value = sides.join(\"=\");\n if (key === \"expires\") {\n cookie.expires = new Date(value);\n } else if (key === \"max-age\") {\n var n = parseInt(value, 10);\n if (!Number.isNaN(n)) cookie.maxAge = n;\n } else if (key === \"secure\") {\n cookie.secure = true;\n } else if (key === \"httponly\") {\n cookie.httpOnly = true;\n } else if (key === \"samesite\") {\n cookie.sameSite = value;\n } else if (key === \"partitioned\") {\n cookie.partitioned = true;\n } else if (key) {\n cookie[key] = value;\n }\n });\n return cookie;\n}\nfunction parseNameValuePair(nameValuePairStr) {\n // Parses name-value-pair according to rfc6265bis draft\n var name = \"\";\n var value = \"\";\n var nameValueArr = nameValuePairStr.split(\"=\");\n if (nameValueArr.length > 1) {\n name = nameValueArr.shift();\n value = nameValueArr.join(\"=\"); // everything after the first =, joined by a \"=\" if there was more than one part\n } else {\n value = nameValuePairStr;\n }\n return {\n name: name,\n value: value\n };\n}\nfunction parse(input, options) {\n options = options ? Object.assign({}, defaultParseOptions, options) : defaultParseOptions;\n if (!input) {\n if (!options.map) {\n return [];\n } else {\n return createNullObj();\n }\n }\n if (input.headers) {\n if (typeof input.headers.getSetCookie === \"function\") {\n // for fetch responses - they combine headers of the same type in the headers array,\n // but getSetCookie returns an uncombined array\n input = input.headers.getSetCookie();\n } else if (input.headers[\"set-cookie\"]) {\n // fast-path for node.js (which automatically normalizes header names to lower-case)\n input = input.headers[\"set-cookie\"];\n } else {\n // slow-path for other environments - see #25\n var sch = input.headers[Object.keys(input.headers).find(function(key) {\n return key.toLowerCase() === \"set-cookie\";\n })];\n // warn if called on a request-like object with a cookie header rather than a set-cookie header - see #34, 36\n if (!sch && input.headers.cookie && !options.silent) {\n 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.\");\n }\n input = sch;\n }\n }\n if (!Array.isArray(input)) {\n input = [\n input\n ];\n }\n if (!options.map) {\n return input.filter(isNonEmptyString).map(function(str) {\n return parseString(str, options);\n }).filter(Boolean);\n } else {\n var cookies = createNullObj();\n return input.filter(isNonEmptyString).reduce(function(cookies, str) {\n var cookie = parseString(str, options);\n if (cookie && !isForbiddenKey(cookie.name)) {\n cookies[cookie.name] = cookie;\n }\n return cookies;\n }, cookies);\n }\n}\n/*\n Set-Cookie header field-values are sometimes comma joined in one string. This splits them without choking on commas\n that are within a single set-cookie field-value, such as in the Expires portion.\n\n This is uncommon, but explicitly allowed - see https://tools.ietf.org/html/rfc2616#section-4.2\n Node.js does this for every header *except* set-cookie - see https://github.com/nodejs/node/blob/d5e363b77ebaf1caf67cd7528224b651c86815c1/lib/_http_incoming.js#L128\n React Native's fetch does this for *every* header, including set-cookie.\n\n Based on: https://github.com/google/j2objc/commit/16820fdbc8f76ca0c33472810ce0cb03d20efe25\n Credits to: https://github.com/tomball for original and https://github.com/chrusart for JavaScript implementation\n*/ function splitCookiesString(cookiesString) {\n if (Array.isArray(cookiesString)) {\n return cookiesString;\n }\n if (typeof cookiesString !== \"string\") {\n return [];\n }\n var cookiesStrings = [];\n var pos = 0;\n var start;\n var ch;\n var lastComma;\n var nextStart;\n var cookiesSeparatorFound;\n function skipWhitespace() {\n while(pos < cookiesString.length && /\\s/.test(cookiesString.charAt(pos))){\n pos += 1;\n }\n return pos < cookiesString.length;\n }\n function notSpecialChar() {\n ch = cookiesString.charAt(pos);\n return ch !== \"=\" && ch !== \";\" && ch !== \",\";\n }\n while(pos < cookiesString.length){\n start = pos;\n cookiesSeparatorFound = false;\n while(skipWhitespace()){\n ch = cookiesString.charAt(pos);\n if (ch === \",\") {\n // ',' is a cookie separator if we have later first '=', not ';' or ','\n lastComma = pos;\n pos += 1;\n skipWhitespace();\n nextStart = pos;\n while(pos < cookiesString.length && notSpecialChar()){\n pos += 1;\n }\n // currently special character\n if (pos < cookiesString.length && cookiesString.charAt(pos) === \"=\") {\n // we found cookies separator\n cookiesSeparatorFound = true;\n // pos is inside the next cookie, so back up and return it.\n pos = nextStart;\n cookiesStrings.push(cookiesString.substring(start, lastComma));\n start = pos;\n } else {\n // in param ',' or param separator ';',\n // we continue from that comma\n pos = lastComma + 1;\n }\n } else {\n pos += 1;\n }\n }\n if (!cookiesSeparatorFound || pos >= cookiesString.length) {\n cookiesStrings.push(cookiesString.substring(start, cookiesString.length));\n }\n }\n return cookiesStrings;\n}\nmodule.exports = parse;\nmodule.exports.parse = parse;\nmodule.exports.parseString = parseString;\nmodule.exports.splitCookiesString = splitCookiesString;\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"(rsc)/./node_modules/set-cookie-parser/lib/set-cookie.js","mappings":"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","sources":["webpack://whisky-vault/./node_modules/set-cookie-parser/lib/set-cookie.js?3313"],"sourcesContent":["\"use strict\";\n\nvar defaultParseOptions = {\n  decodeValues: true,\n  map: false,\n  silent: false,\n};\n\nfunction isForbiddenKey(key) {\n  return typeof key !== \"string\" || key in {};\n}\n\nfunction createNullObj() {\n  return Object.create(null);\n}\n\nfunction isNonEmptyString(str) {\n  return typeof str === \"string\" && !!str.trim();\n}\n\nfunction parseString(setCookieValue, options) {\n  var parts = setCookieValue.split(\";\").filter(isNonEmptyString);\n\n  var nameValuePairStr = parts.shift();\n  var parsed = parseNameValuePair(nameValuePairStr);\n  var name = parsed.name;\n  var value = parsed.value;\n\n  options = options\n    ? Object.assign({}, defaultParseOptions, options)\n    : defaultParseOptions;\n\n  if (isForbiddenKey(name)) {\n    return null;\n  }\n\n  try {\n    value = options.decodeValues ? decodeURIComponent(value) : value; // decode cookie value\n  } catch (e) {\n    console.error(\n      \"set-cookie-parser: failed to decode cookie value. Set options.decodeValues=false to disable decoding.\",\n      e\n    );\n  }\n\n  var cookie = createNullObj();\n  cookie.name = name;\n  cookie.value = value;\n\n  parts.forEach(function (part) {\n    var sides = part.split(\"=\");\n    var key = sides.shift().trimLeft().toLowerCase();\n    if (isForbiddenKey(key)) {\n      return;\n    }\n    var value = sides.join(\"=\");\n    if (key === \"expires\") {\n      cookie.expires = new Date(value);\n    } else if (key === \"max-age\") {\n      var n = parseInt(value, 10);\n      if (!Number.isNaN(n)) cookie.maxAge = n;\n    } else if (key === \"secure\") {\n      cookie.secure = true;\n    } else if (key === \"httponly\") {\n      cookie.httpOnly = true;\n    } else if (key === \"samesite\") {\n      cookie.sameSite = value;\n    } else if (key === \"partitioned\") {\n      cookie.partitioned = true;\n    } else if (key) {\n      cookie[key] = value;\n    }\n  });\n\n  return cookie;\n}\n\nfunction parseNameValuePair(nameValuePairStr) {\n  // Parses name-value-pair according to rfc6265bis draft\n\n  var name = \"\";\n  var value = \"\";\n  var nameValueArr = nameValuePairStr.split(\"=\");\n  if (nameValueArr.length > 1) {\n    name = nameValueArr.shift();\n    value = nameValueArr.join(\"=\"); // everything after the first =, joined by a \"=\" if there was more than one part\n  } else {\n    value = nameValuePairStr;\n  }\n\n  return { name: name, value: value };\n}\n\nfunction parse(input, options) {\n  options = options\n    ? Object.assign({}, defaultParseOptions, options)\n    : defaultParseOptions;\n\n  if (!input) {\n    if (!options.map) {\n      return [];\n    } else {\n      return createNullObj();\n    }\n  }\n\n  if (input.headers) {\n    if (typeof input.headers.getSetCookie === \"function\") {\n      // for fetch responses - they combine headers of the same type in the headers array,\n      // but getSetCookie returns an uncombined array\n      input = input.headers.getSetCookie();\n    } else if (input.headers[\"set-cookie\"]) {\n      // fast-path for node.js (which automatically normalizes header names to lower-case)\n      input = input.headers[\"set-cookie\"];\n    } else {\n      // slow-path for other environments - see #25\n      var sch =\n        input.headers[\n          Object.keys(input.headers).find(function (key) {\n            return key.toLowerCase() === \"set-cookie\";\n          })\n        ];\n      // warn if called on a request-like object with a cookie header rather than a set-cookie header - see #34, 36\n      if (!sch && input.headers.cookie && !options.silent) {\n        console.warn(\n          \"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.\"\n        );\n      }\n      input = sch;\n    }\n  }\n  if (!Array.isArray(input)) {\n    input = [input];\n  }\n\n  if (!options.map) {\n    return input\n      .filter(isNonEmptyString)\n      .map(function (str) {\n        return parseString(str, options);\n      })\n      .filter(Boolean);\n  } else {\n    var cookies = createNullObj();\n    return input.filter(isNonEmptyString).reduce(function (cookies, str) {\n      var cookie = parseString(str, options);\n      if (cookie && !isForbiddenKey(cookie.name)) {\n        cookies[cookie.name] = cookie;\n      }\n      return cookies;\n    }, cookies);\n  }\n}\n\n/*\n  Set-Cookie header field-values are sometimes comma joined in one string. This splits them without choking on commas\n  that are within a single set-cookie field-value, such as in the Expires portion.\n\n  This is uncommon, but explicitly allowed - see https://tools.ietf.org/html/rfc2616#section-4.2\n  Node.js does this for every header *except* set-cookie - see https://github.com/nodejs/node/blob/d5e363b77ebaf1caf67cd7528224b651c86815c1/lib/_http_incoming.js#L128\n  React Native's fetch does this for *every* header, including set-cookie.\n\n  Based on: https://github.com/google/j2objc/commit/16820fdbc8f76ca0c33472810ce0cb03d20efe25\n  Credits to: https://github.com/tomball for original and https://github.com/chrusart for JavaScript implementation\n*/\nfunction splitCookiesString(cookiesString) {\n  if (Array.isArray(cookiesString)) {\n    return cookiesString;\n  }\n  if (typeof cookiesString !== \"string\") {\n    return [];\n  }\n\n  var cookiesStrings = [];\n  var pos = 0;\n  var start;\n  var ch;\n  var lastComma;\n  var nextStart;\n  var cookiesSeparatorFound;\n\n  function skipWhitespace() {\n    while (pos < cookiesString.length && /\\s/.test(cookiesString.charAt(pos))) {\n      pos += 1;\n    }\n    return pos < cookiesString.length;\n  }\n\n  function notSpecialChar() {\n    ch = cookiesString.charAt(pos);\n\n    return ch !== \"=\" && ch !== \";\" && ch !== \",\";\n  }\n\n  while (pos < cookiesString.length) {\n    start = pos;\n    cookiesSeparatorFound = false;\n\n    while (skipWhitespace()) {\n      ch = cookiesString.charAt(pos);\n      if (ch === \",\") {\n        // ',' is a cookie separator if we have later first '=', not ';' or ','\n        lastComma = pos;\n        pos += 1;\n\n        skipWhitespace();\n        nextStart = pos;\n\n        while (pos < cookiesString.length && notSpecialChar()) {\n          pos += 1;\n        }\n\n        // currently special character\n        if (pos < cookiesString.length && cookiesString.charAt(pos) === \"=\") {\n          // we found cookies separator\n          cookiesSeparatorFound = true;\n          // pos is inside the next cookie, so back up and return it.\n          pos = nextStart;\n          cookiesStrings.push(cookiesString.substring(start, lastComma));\n          start = pos;\n        } else {\n          // in param ',' or param separator ';',\n          // we continue from that comma\n          pos = lastComma + 1;\n        }\n      } else {\n        pos += 1;\n      }\n    }\n\n    if (!cookiesSeparatorFound || pos >= cookiesString.length) {\n      cookiesStrings.push(cookiesString.substring(start, cookiesString.length));\n    }\n  }\n\n  return cookiesStrings;\n}\n\nmodule.exports = parse;\nmodule.exports.parse = parse;\nmodule.exports.parseString = parseString;\nmodule.exports.splitCookiesString = splitCookiesString;\n"],"names":["defaultParseOptions","decodeValues","map","silent","isForbiddenKey","key","createNullObj","Object","create","isNonEmptyString","str","trim","parseString","setCookieValue","options","parts","split","filter","nameValuePairStr","shift","parsed","parseNameValuePair","name","value","assign","decodeURIComponent","e","console","error","cookie","forEach","part","sides","trimLeft","toLowerCase","join","expires","Date","n","parseInt","Number","isNaN","maxAge","secure","httpOnly","sameSite","partitioned","nameValueArr","length","parse","input","headers","getSetCookie","sch","keys","find","warn","Array","isArray","Boolean","cookies","reduce","splitCookiesString","cookiesString","cookiesStrings","pos","start","ch","lastComma","nextStart","cookiesSeparatorFound","skipWhitespace","test","charAt","notSpecialChar","push","substring","module","exports"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/set-cookie-parser/lib/set-cookie.js\n");
/***/ })
};
;