mirror of
https://github.com/logos-messaging/lab.waku.org.git
synced 2026-01-10 09:43:08 +00:00
115 lines
282 KiB
JavaScript
115 lines
282 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/@leichtgewicht";
|
|
exports.ids = ["vendor-chunks/@leichtgewicht"];
|
|
exports.modules = {
|
|
|
|
/***/ "(ssr)/./node_modules/@leichtgewicht/base64-codec/index.mjs":
|
|
/*!************************************************************!*\
|
|
!*** ./node_modules/@leichtgewicht/base64-codec/index.mjs ***!
|
|
\************************************************************/
|
|
/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => {
|
|
|
|
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ PREFERS_NO_PADDING: () => (/* binding */ PREFERS_NO_PADDING),\n/* harmony export */ PREFERS_PADDING: () => (/* binding */ PREFERS_PADDING),\n/* harmony export */ base64: () => (/* binding */ base64),\n/* harmony export */ base64URL: () => (/* binding */ base64URL),\n/* harmony export */ make: () => (/* binding */ make)\n/* harmony export */ });\nconst PREFERS_PADDING = 1;\nconst PREFERS_NO_PADDING = 2;\nfunction make(name, charset, padding, paddingMode) {\n if (charset.length !== 64) {\n throw new Error(`Charset needs to be 64 characters long! (${charset.length})`);\n }\n const byCharCode = new Uint8Array(256);\n const byNum = new Uint8Array(64);\n for(let i = 0; i < 64; i += 1){\n const code = charset.charCodeAt(i);\n if (code > 255) {\n throw new Error(`Character #${i} in charset [code=${code}, char=${charset.charAt(i)}] is too high! (max=255)`);\n }\n if (byCharCode[code] !== 0) {\n throw new Error(`Character [code=${code}, char=${charset.charAt(i)}] is more than once in the charset!`);\n }\n byCharCode[code] = i;\n byNum[i] = code;\n }\n const padCode = padding.charCodeAt(0);\n const codec = {\n name,\n encodingLength (str) {\n const strLen = str.length;\n const len = strLen * 0.75 | 0;\n if (str.charCodeAt(strLen - 1) === padCode) {\n if (str.charCodeAt(strLen - 2) === padCode) {\n return len - 2;\n }\n return len - 1;\n }\n return len;\n },\n encode (str, buffer, offset) {\n if (buffer === null || buffer === undefined) {\n buffer = new Uint8Array(codec.encodingLength(str));\n }\n if (offset === null || offset === undefined) {\n offset = 0;\n }\n let strLen = str.length;\n if (str.charCodeAt(strLen - 1) === padCode) {\n if (str.charCodeAt(strLen - 2) === padCode) {\n strLen -= 2;\n } else {\n strLen -= 1;\n }\n }\n const padding = strLen % 4;\n const safeLen = strLen - padding;\n let off = offset;\n let i = 0;\n while(i < safeLen){\n const code = byCharCode[str.charCodeAt(i)] << 18 | byCharCode[str.charCodeAt(i + 1)] << 12 | byCharCode[str.charCodeAt(i + 2)] << 6 | byCharCode[str.charCodeAt(i + 3)];\n buffer[off++] = code >> 16;\n buffer[off++] = code >> 8;\n buffer[off++] = code;\n i += 4;\n }\n if (padding === 3) {\n const code = byCharCode[str.charCodeAt(i)] << 10 | byCharCode[str.charCodeAt(i + 1)] << 4 | byCharCode[str.charCodeAt(i + 2)] >> 2;\n buffer[off++] = code >> 8;\n buffer[off++] = code;\n } else if (padding === 2) {\n buffer[off++] = byCharCode[str.charCodeAt(i)] << 2 | byCharCode[str.charCodeAt(i + 1)] >> 4;\n }\n codec.encode.bytes = off - offset;\n return buffer;\n },\n decode (buffer, start, end) {\n if (start === null || start === undefined) {\n start = 0;\n }\n if (end === null || end === undefined) {\n end = buffer.length;\n }\n const length = end - start;\n const pad = length % 3;\n const safeEnd = start + length - pad;\n const codes = [];\n for(let off = start; off < safeEnd; off += 3){\n const num = buffer[off] << 16 | buffer[off + 1] << 8 | buffer[off + 2];\n codes.push(byNum[num >> 18 & 0x3F], byNum[num >> 12 & 0x3F], byNum[num >> 6 & 0x3F], byNum[num & 0x3F]);\n }\n if (pad === 2) {\n const num = (buffer[end - 2] << 8) + buffer[end - 1];\n codes.push(byNum[num >> 10], byNum[num >> 4 & 0x3F], byNum[num << 2 & 0x3F]);\n if (paddingMode === PREFERS_PADDING) {\n codes.push(padCode);\n }\n } else if (pad === 1) {\n const num = buffer[end - 1];\n codes.push(byNum[num >> 2], byNum[num << 4 & 0x3F]);\n if (paddingMode === PREFERS_PADDING) {\n codes.push(padCode, padCode);\n }\n }\n codec.decode.bytes = length;\n return String.fromCharCode.apply(String, codes);\n }\n };\n return codec;\n}\nconst base64 = make(\"base64\", \"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/\", \"=\", PREFERS_PADDING);\n// https://datatracker.ietf.org/doc/html/rfc4648#section-5\nconst base64URL = make(\"base64-url\", \"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_\", \"=\", PREFERS_NO_PADDING);\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"(ssr)/./node_modules/@leichtgewicht/base64-codec/index.mjs","mappings":"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","sources":["webpack://flush-notes/./node_modules/@leichtgewicht/base64-codec/index.mjs?5dc1"],"sourcesContent":["export const PREFERS_PADDING = 1\nexport const PREFERS_NO_PADDING = 2\n\nexport function make (name, charset, padding, paddingMode) {\n  if (charset.length !== 64) {\n    throw new Error(`Charset needs to be 64 characters long! (${charset.length})`)\n  }\n  const byCharCode = new Uint8Array(256)\n  const byNum = new Uint8Array(64)\n  for (let i = 0; i < 64; i += 1) {\n    const code = charset.charCodeAt(i)\n    if (code > 255) {\n      throw new Error(`Character #${i} in charset [code=${code}, char=${charset.charAt(i)}] is too high! (max=255)`)\n    }\n    if (byCharCode[code] !== 0) {\n      throw new Error(`Character [code=${code}, char=${charset.charAt(i)}] is more than once in the charset!`)\n    }\n    byCharCode[code] = i\n    byNum[i] = code\n  }\n  const padCode = padding.charCodeAt(0)\n  const codec = {\n    name,\n    encodingLength (str) {\n      const strLen = str.length\n      const len = strLen * 0.75 | 0\n      if (str.charCodeAt(strLen - 1) === padCode) {\n        if (str.charCodeAt(strLen - 2) === padCode) {\n          return len - 2\n        }\n        return len - 1\n      }\n      return len\n    },\n    encode (str, buffer, offset) {\n      if (buffer === null || buffer === undefined) {\n        buffer = new Uint8Array(codec.encodingLength(str))\n      }\n      if (offset === null || offset === undefined) {\n        offset = 0\n      }\n\n      let strLen = str.length\n      if (str.charCodeAt(strLen - 1) === padCode) {\n        if (str.charCodeAt(strLen - 2) === padCode) {\n          strLen -= 2\n        } else {\n          strLen -= 1\n        }\n      }\n\n      const padding = strLen % 4\n      const safeLen = strLen - padding\n\n      let off = offset\n      let i = 0\n      while (i < safeLen) {\n        const code =\n          (byCharCode[str.charCodeAt(i)] << 18) |\n          (byCharCode[str.charCodeAt(i + 1)] << 12) |\n          (byCharCode[str.charCodeAt(i + 2)] << 6) |\n          byCharCode[str.charCodeAt(i + 3)]\n        buffer[off++] = code >> 16\n        buffer[off++] = code >> 8\n        buffer[off++] = code\n        i += 4\n      }\n\n      if (padding === 3) {\n        const code =\n          (byCharCode[str.charCodeAt(i)] << 10) |\n          (byCharCode[str.charCodeAt(i + 1)] << 4) |\n          (byCharCode[str.charCodeAt(i + 2)] >> 2)\n        buffer[off++] = code >> 8\n        buffer[off++] = code\n      } else if (padding === 2) {\n        buffer[off++] = (byCharCode[str.charCodeAt(i)] << 2) |\n          (byCharCode[str.charCodeAt(i + 1)] >> 4)\n      }\n\n      codec.encode.bytes = off - offset\n      return buffer\n    },\n    decode (buffer, start, end) {\n      if (start === null || start === undefined) {\n        start = 0\n      }\n      if (end === null || end === undefined) {\n        end = buffer.length\n      }\n\n      const length = end - start\n      const pad = length % 3\n      const safeEnd = start + length - pad\n      const codes = []\n      for (let off = start; off < safeEnd; off += 3) {\n        const num = (buffer[off] << 16) | ((buffer[off + 1] << 8)) | buffer[off + 2]\n        codes.push(\n          byNum[num >> 18 & 0x3F],\n          byNum[num >> 12 & 0x3F],\n          byNum[num >> 6 & 0x3F],\n          byNum[num & 0x3F]\n        )\n      }\n\n      if (pad === 2) {\n        const num = (buffer[end - 2] << 8) + buffer[end - 1]\n        codes.push(\n          byNum[num >> 10],\n          byNum[(num >> 4) & 0x3F],\n          byNum[(num << 2) & 0x3F]\n        )\n        if (paddingMode === PREFERS_PADDING) {\n          codes.push(padCode)\n        }\n      } else if (pad === 1) {\n        const num = buffer[end - 1]\n        codes.push(\n          byNum[num >> 2],\n          byNum[(num << 4) & 0x3F]\n        )\n        if (paddingMode === PREFERS_PADDING) {\n          codes.push(padCode, padCode)\n        }\n      }\n\n      codec.decode.bytes = length\n      return String.fromCharCode.apply(String, codes)\n    }\n  }\n  return codec\n}\n\nexport const base64 = make('base64', 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/', '=', PREFERS_PADDING)\n// https://datatracker.ietf.org/doc/html/rfc4648#section-5\nexport const base64URL = make('base64-url', 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_', '=', PREFERS_NO_PADDING)\n"],"names":["PREFERS_PADDING","PREFERS_NO_PADDING","make","name","charset","padding","paddingMode","length","Error","byCharCode","Uint8Array","byNum","i","code","charCodeAt","charAt","padCode","codec","encodingLength","str","strLen","len","encode","buffer","offset","undefined","safeLen","off","bytes","decode","start","end","pad","safeEnd","codes","num","push","String","fromCharCode","apply","base64","base64URL"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/@leichtgewicht/base64-codec/index.mjs\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(ssr)/./node_modules/@leichtgewicht/dns-packet/buffer_utils.mjs":
|
|
/*!*****************************************************************!*\
|
|
!*** ./node_modules/@leichtgewicht/dns-packet/buffer_utils.mjs ***!
|
|
\*****************************************************************/
|
|
/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => {
|
|
|
|
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ bytelength: () => (/* binding */ bytelength),\n/* harmony export */ copy: () => (/* binding */ copy),\n/* harmony export */ from: () => (/* binding */ from),\n/* harmony export */ isU8Arr: () => (/* binding */ isU8Arr),\n/* harmony export */ readUInt16BE: () => (/* binding */ readUInt16BE),\n/* harmony export */ readUInt32BE: () => (/* binding */ readUInt32BE),\n/* harmony export */ toHex: () => (/* binding */ toHex),\n/* harmony export */ write: () => (/* binding */ write),\n/* harmony export */ writeUInt16BE: () => (/* binding */ writeUInt16BE),\n/* harmony export */ writeUInt32BE: () => (/* binding */ writeUInt32BE)\n/* harmony export */ });\n/* harmony import */ var utf8_codec__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! utf8-codec */ \"(ssr)/./node_modules/utf8-codec/index.mjs\");\n\nconst isU8Arr = (input)=>input instanceof Uint8Array;\nfunction bytelength(input) {\n return typeof input === \"string\" ? utf8_codec__WEBPACK_IMPORTED_MODULE_0__.encodingLength(input) : input.byteLength;\n}\nfunction from(input) {\n if (input instanceof Uint8Array) {\n return input;\n }\n if (Array.isArray(input)) {\n return new Uint8Array(input);\n }\n return utf8_codec__WEBPACK_IMPORTED_MODULE_0__.encode(input);\n}\nfunction write(arr, str, start) {\n if (typeof str !== \"string\") {\n throw new Error(\"unknown input type\");\n }\n utf8_codec__WEBPACK_IMPORTED_MODULE_0__.encode(str, arr, start);\n return utf8_codec__WEBPACK_IMPORTED_MODULE_0__.encode.bytes;\n}\nfunction toHex(buf, start, end) {\n let result = \"\";\n for(let offset = start; offset < end;){\n const num = buf[offset++];\n const str = num.toString(16);\n result += str.length === 1 ? \"0\" + str : str;\n }\n return result;\n}\nconst P_24 = Math.pow(2, 24);\nconst P_16 = Math.pow(2, 16);\nconst P_8 = Math.pow(2, 8);\nconst readUInt32BE = (buf, offset)=>buf[offset] * P_24 + buf[offset + 1] * P_16 + buf[offset + 2] * P_8 + buf[offset + 3];\nconst readUInt16BE = (buf, offset)=>buf[offset] << 8 | buf[offset + 1];\nconst writeUInt32BE = (buf, value, offset)=>{\n value = +value;\n buf[offset + 3] = value;\n value = value >>> 8;\n buf[offset + 2] = value;\n value = value >>> 8;\n buf[offset + 1] = value;\n value = value >>> 8;\n buf[offset] = value;\n return offset + 4;\n};\nconst writeUInt16BE = (buf, value, offset)=>{\n buf[offset] = value >> 8;\n buf[offset + 1] = value & 0xFF;\n return offset + 2;\n};\nfunction copy(source, target, targetStart, sourceStart, sourceEnd) {\n if (targetStart < 0) {\n sourceStart -= targetStart;\n targetStart = 0;\n }\n if (sourceStart < 0) {\n sourceStart = 0;\n }\n if (sourceEnd < 0) {\n return new Uint8Array(0);\n }\n if (targetStart >= target.length || sourceStart >= sourceEnd) {\n return 0;\n }\n return _copyActual(source, target, targetStart, sourceStart, sourceEnd);\n}\nfunction _copyActual(source, target, targetStart, sourceStart, sourceEnd) {\n if (sourceEnd - sourceStart > target.length - targetStart) {\n sourceEnd = sourceStart + target.length - targetStart;\n }\n let nb = sourceEnd - sourceStart;\n const sourceLen = source.length - sourceStart;\n if (nb > sourceLen) {\n nb = sourceLen;\n }\n if (sourceStart !== 0 || sourceEnd < source.length) {\n source = new Uint8Array(source.buffer, source.byteOffset + sourceStart, nb);\n }\n target.set(source, targetStart);\n return nb;\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvQGxlaWNodGdld2ljaHQvZG5zLXBhY2tldC9idWZmZXJfdXRpbHMubWpzIiwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7O0FBQWtDO0FBRTNCLE1BQU1DLFVBQVVDLENBQUFBLFFBQVNBLGlCQUFpQkMsV0FBVTtBQUVwRCxTQUFTQyxXQUFZRixLQUFLO0lBQy9CLE9BQU8sT0FBT0EsVUFBVSxXQUFXRixzREFBbUIsQ0FBQ0UsU0FBU0EsTUFBTUksVUFBVTtBQUNsRjtBQUVPLFNBQVNDLEtBQU1MLEtBQUs7SUFDekIsSUFBSUEsaUJBQWlCQyxZQUFZO1FBQy9CLE9BQU9EO0lBQ1Q7SUFDQSxJQUFJTSxNQUFNQyxPQUFPLENBQUNQLFFBQVE7UUFDeEIsT0FBTyxJQUFJQyxXQUFXRDtJQUN4QjtJQUNBLE9BQU9GLDhDQUFXLENBQUNFO0FBQ3JCO0FBRU8sU0FBU1MsTUFBT0MsR0FBRyxFQUFFQyxHQUFHLEVBQUVDLEtBQUs7SUFDcEMsSUFBSSxPQUFPRCxRQUFRLFVBQVU7UUFDM0IsTUFBTSxJQUFJRSxNQUFNO0lBQ2xCO0lBQ0FmLDhDQUFXLENBQUNhLEtBQUtELEtBQUtFO0lBQ3RCLE9BQU9kLDhDQUFXLENBQUNnQixLQUFLO0FBQzFCO0FBRU8sU0FBU0MsTUFBT0MsR0FBRyxFQUFFSixLQUFLLEVBQUVLLEdBQUc7SUFDcEMsSUFBSUMsU0FBUztJQUNiLElBQUssSUFBSUMsU0FBU1AsT0FBT08sU0FBU0YsS0FBTTtRQUN0QyxNQUFNRyxNQUFNSixHQUFHLENBQUNHLFNBQVM7UUFDekIsTUFBTVIsTUFBTVMsSUFBSUMsUUFBUSxDQUFDO1FBQ3pCSCxVQUFVLElBQUtJLE1BQU0sS0FBSyxJQUFLLE1BQU1YLE1BQU1BO0lBQzdDO0lBQ0EsT0FBT087QUFDVDtBQUVBLE1BQU1LLE9BQU9DLEtBQUtDLEdBQUcsQ0FBQyxHQUFHO0FBQ3pCLE1BQU1DLE9BQU9GLEtBQUtDLEdBQUcsQ0FBQyxHQUFHO0FBQ3pCLE1BQU1FLE1BQU1ILEtBQUtDLEdBQUcsQ0FBQyxHQUFHO0FBQ2pCLE1BQU1HLGVBQWUsQ0FBQ1osS0FBS0csU0FBV0gsR0FBRyxDQUFDRyxPQUFPLEdBQUdJLE9BQ3pEUCxHQUFHLENBQUNHLFNBQVMsRUFBRSxHQUFHTyxPQUNsQlYsR0FBRyxDQUFDRyxTQUFTLEVBQUUsR0FBR1EsTUFDbEJYLEdBQUcsQ0FBQ0csU0FBUyxFQUFFO0FBRVYsTUFBTVUsZUFBZSxDQUFDYixLQUFLRyxTQUFXLEdBQUksQ0FBQ0EsT0FBTyxJQUFJLElBQUtILEdBQUcsQ0FBQ0csU0FBUyxFQUFFO0FBQzFFLE1BQU1XLGdCQUFnQixDQUFDZCxLQUFLZSxPQUFPWjtJQUN4Q1ksUUFBUSxDQUFDQTtJQUNUZixHQUFHLENBQUNHLFNBQVMsRUFBRSxHQUFHWTtJQUNsQkEsUUFBUUEsVUFBVTtJQUNsQmYsR0FBRyxDQUFDRyxTQUFTLEVBQUUsR0FBR1k7SUFDbEJBLFFBQVFBLFVBQVU7SUFDbEJmLEdBQUcsQ0FBQ0csU0FBUyxFQUFFLEdBQUdZO0lBQ2xCQSxRQUFRQSxVQUFVO0lBQ2xCZixHQUFHLENBQUNHLE9BQU8sR0FBR1k7SUFDZCxPQUFPWixTQUFTO0FBQ2xCLEVBQUM7QUFDTSxNQUFNYSxnQkFBZ0IsQ0FBQ2hCLEtBQUtlLE9BQU9aO0lBQ3hDSCxHQUFHLENBQUNHLE9BQU8sR0FBR1ksU0FBUztJQUN2QmYsR0FBRyxDQUFDRyxTQUFTLEVBQUUsR0FBR1ksUUFBUTtJQUMxQixPQUFPWixTQUFTO0FBQ2xCLEVBQUM7QUFFTSxTQUFTYyxLQUFNQyxNQUFNLEVBQUVDLE1BQU0sRUFBRUMsV0FBVyxFQUFFQyxXQUFXLEVBQUVDLFNBQVM7SUFDdkUsSUFBSUYsY0FBYyxHQUFHO1FBQ25CQyxlQUFlRDtRQUNmQSxjQUFjO0lBQ2hCO0lBRUEsSUFBSUMsY0FBYyxHQUFHO1FBQ25CQSxjQUFjO0lBQ2hCO0lBRUEsSUFBSUMsWUFBWSxHQUFHO1FBQ2pCLE9BQU8sSUFBSXJDLFdBQVc7SUFDeEI7SUFFQSxJQUFJbUMsZUFBZUQsT0FBT2IsTUFBTSxJQUFJZSxlQUFlQyxXQUFXO1FBQzVELE9BQU87SUFDVDtJQUVBLE9BQU9DLFlBQVlMLFFBQVFDLFFBQVFDLGFBQWFDLGFBQWFDO0FBQy9EO0FBRUEsU0FBU0MsWUFBYUwsTUFBTSxFQUFFQyxNQUFNLEVBQUVDLFdBQVcsRUFBRUMsV0FBVyxFQUFFQyxTQUFTO0lBQ3ZFLElBQUlBLFlBQVlELGNBQWNGLE9BQU9iLE1BQU0sR0FBR2MsYUFBYTtRQUN6REUsWUFBWUQsY0FBY0YsT0FBT2IsTUFBTSxHQUFHYztJQUM1QztJQUVBLElBQUlJLEtBQUtGLFlBQVlEO0lBQ3JCLE1BQU1JLFlBQVlQLE9BQU9aLE1BQU0sR0FBR2U7SUFDbEMsSUFBSUcsS0FBS0MsV0FBVztRQUNsQkQsS0FBS0M7SUFDUDtJQUVBLElBQUlKLGdCQUFnQixLQUFLQyxZQUFZSixPQUFPWixNQUFNLEVBQUU7UUFDbERZLFNBQVMsSUFBSWpDLFdBQVdpQyxPQUFPUSxNQUFNLEVBQUVSLE9BQU9TLFVBQVUsR0FBR04sYUFBYUc7SUFDMUU7SUFFQUwsT0FBT1MsR0FBRyxDQUFDVixRQUFRRTtJQUVuQixPQUFPSTtBQUNUIiwic291cmNlcyI6WyJ3ZWJwYWNrOi8vZmx1c2gtbm90ZXMvLi9ub2RlX21vZHVsZXMvQGxlaWNodGdld2ljaHQvZG5zLXBhY2tldC9idWZmZXJfdXRpbHMubWpzP2VjOGYiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICogYXMgdXRmOCBmcm9tICd1dGY4LWNvZGVjJ1xuXG5leHBvcnQgY29uc3QgaXNVOEFyciA9IGlucHV0ID0+IGlucHV0IGluc3RhbmNlb2YgVWludDhBcnJheVxuXG5leHBvcnQgZnVuY3Rpb24gYnl0ZWxlbmd0aCAoaW5wdXQpIHtcbiAgcmV0dXJuIHR5cGVvZiBpbnB1dCA9PT0gJ3N0cmluZycgPyB1dGY4LmVuY29kaW5nTGVuZ3RoKGlucHV0KSA6IGlucHV0LmJ5dGVMZW5ndGhcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGZyb20gKGlucHV0KSB7XG4gIGlmIChpbnB1dCBpbnN0YW5jZW9mIFVpbnQ4QXJyYXkpIHtcbiAgICByZXR1cm4gaW5wdXRcbiAgfVxuICBpZiAoQXJyYXkuaXNBcnJheShpbnB1dCkpIHtcbiAgICByZXR1cm4gbmV3IFVpbnQ4QXJyYXkoaW5wdXQpXG4gIH1cbiAgcmV0dXJuIHV0ZjguZW5jb2RlKGlucHV0KVxufVxuXG5leHBvcnQgZnVuY3Rpb24gd3JpdGUgKGFyciwgc3RyLCBzdGFydCkge1xuICBpZiAodHlwZW9mIHN0ciAhPT0gJ3N0cmluZycpIHtcbiAgICB0aHJvdyBuZXcgRXJyb3IoJ3Vua25vd24gaW5wdXQgdHlwZScpXG4gIH1cbiAgdXRmOC5lbmNvZGUoc3RyLCBhcnIsIHN0YXJ0KVxuICByZXR1cm4gdXRmOC5lbmNvZGUuYnl0ZXNcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIHRvSGV4IChidWYsIHN0YXJ0LCBlbmQpIHtcbiAgbGV0IHJlc3VsdCA9ICcnXG4gIGZvciAobGV0IG9mZnNldCA9IHN0YXJ0OyBvZmZzZXQgPCBlbmQ7KSB7XG4gICAgY29uc3QgbnVtID0gYnVmW29mZnNldCsrXVxuICAgIGNvbnN0IHN0ciA9IG51bS50b1N0cmluZygxNilcbiAgICByZXN1bHQgKz0gKHN0ci5sZW5ndGggPT09IDEpID8gJzAnICsgc3RyIDogc3RyXG4gIH1cbiAgcmV0dXJuIHJlc3VsdFxufVxuXG5jb25zdCBQXzI0ID0gTWF0aC5wb3coMiwgMjQpXG5jb25zdCBQXzE2ID0gTWF0aC5wb3coMiwgMTYpXG5jb25zdCBQXzggPSBNYXRoLnBvdygyLCA4KVxuZXhwb3J0IGNvbnN0IHJlYWRVSW50MzJCRSA9IChidWYsIG9mZnNldCkgPT4gYnVmW29mZnNldF0gKiBQXzI0ICtcbiAgYnVmW29mZnNldCArIDFdICogUF8xNiArXG4gIGJ1ZltvZmZzZXQgKyAyXSAqIFBfOCArXG4gIGJ1ZltvZmZzZXQgKyAzXVxuXG5leHBvcnQgY29uc3QgcmVhZFVJbnQxNkJFID0gKGJ1Ziwgb2Zmc2V0KSA9PiAoYnVmW29mZnNldF0gPDwgOCkgfCBidWZbb2Zmc2V0ICsgMV1cbmV4cG9ydCBjb25zdCB3cml0ZVVJbnQzMkJFID0gKGJ1ZiwgdmFsdWUsIG9mZnNldCkgPT4ge1xuICB2YWx1ZSA9ICt2YWx1ZVxuICBidWZbb2Zmc2V0ICsgM10gPSB2YWx1ZVxuICB2YWx1ZSA9IHZhbHVlID4+PiA4XG4gIGJ1ZltvZmZzZXQgKyAyXSA9IHZhbHVlXG4gIHZhbHVlID0gdmFsdWUgPj4+IDhcbiAgYnVmW29mZnNldCArIDFdID0gdmFsdWVcbiAgdmFsdWUgPSB2YWx1ZSA+Pj4gOFxuICBidWZbb2Zmc2V0XSA9IHZhbHVlXG4gIHJldHVybiBvZmZzZXQgKyA0XG59XG5leHBvcnQgY29uc3Qgd3JpdGVVSW50MTZCRSA9IChidWYsIHZhbHVlLCBvZmZzZXQpID0+IHtcbiAgYnVmW29mZnNldF0gPSB2YWx1ZSA+PiA4XG4gIGJ1ZltvZmZzZXQgKyAxXSA9IHZhbHVlICYgMHhGRlxuICByZXR1cm4gb2Zmc2V0ICsgMlxufVxuXG5leHBvcnQgZnVuY3Rpb24gY29weSAoc291cmNlLCB0YXJnZXQsIHRhcmdldFN0YXJ0LCBzb3VyY2VTdGFydCwgc291cmNlRW5kKSB7XG4gIGlmICh0YXJnZXRTdGFydCA8IDApIHtcbiAgICBzb3VyY2VTdGFydCAtPSB0YXJnZXRTdGFydFxuICAgIHRhcmdldFN0YXJ0ID0gMFxuICB9XG5cbiAgaWYgKHNvdXJjZVN0YXJ0IDwgMCkge1xuICAgIHNvdXJjZVN0YXJ0ID0gMFxuICB9XG5cbiAgaWYgKHNvdXJjZUVuZCA8IDApIHtcbiAgICByZXR1cm4gbmV3IFVpbnQ4QXJyYXkoMClcbiAgfVxuXG4gIGlmICh0YXJnZXRTdGFydCA+PSB0YXJnZXQubGVuZ3RoIHx8IHNvdXJjZVN0YXJ0ID49IHNvdXJjZUVuZCkge1xuICAgIHJldHVybiAwXG4gIH1cblxuICByZXR1cm4gX2NvcHlBY3R1YWwoc291cmNlLCB0YXJnZXQsIHRhcmdldFN0YXJ0LCBzb3VyY2VTdGFydCwgc291cmNlRW5kKVxufVxuXG5mdW5jdGlvbiBfY29weUFjdHVhbCAoc291cmNlLCB0YXJnZXQsIHRhcmdldFN0YXJ0LCBzb3VyY2VTdGFydCwgc291cmNlRW5kKSB7XG4gIGlmIChzb3VyY2VFbmQgLSBzb3VyY2VTdGFydCA+IHRhcmdldC5sZW5ndGggLSB0YXJnZXRTdGFydCkge1xuICAgIHNvdXJjZUVuZCA9IHNvdXJjZVN0YXJ0ICsgdGFyZ2V0Lmxlbmd0aCAtIHRhcmdldFN0YXJ0XG4gIH1cblxuICBsZXQgbmIgPSBzb3VyY2VFbmQgLSBzb3VyY2VTdGFydFxuICBjb25zdCBzb3VyY2VMZW4gPSBzb3VyY2UubGVuZ3RoIC0gc291cmNlU3RhcnRcbiAgaWYgKG5iID4gc291cmNlTGVuKSB7XG4gICAgbmIgPSBzb3VyY2VMZW5cbiAgfVxuXG4gIGlmIChzb3VyY2VTdGFydCAhPT0gMCB8fCBzb3VyY2VFbmQgPCBzb3VyY2UubGVuZ3RoKSB7XG4gICAgc291cmNlID0gbmV3IFVpbnQ4QXJyYXkoc291cmNlLmJ1ZmZlciwgc291cmNlLmJ5dGVPZmZzZXQgKyBzb3VyY2VTdGFydCwgbmIpXG4gIH1cblxuICB0YXJnZXQuc2V0KHNvdXJjZSwgdGFyZ2V0U3RhcnQpXG5cbiAgcmV0dXJuIG5iXG59XG4iXSwibmFtZXMiOlsidXRmOCIsImlzVThBcnIiLCJpbnB1dCIsIlVpbnQ4QXJyYXkiLCJieXRlbGVuZ3RoIiwiZW5jb2RpbmdMZW5ndGgiLCJieXRlTGVuZ3RoIiwiZnJvbSIsIkFycmF5IiwiaXNBcnJheSIsImVuY29kZSIsIndyaXRlIiwiYXJyIiwic3RyIiwic3RhcnQiLCJFcnJvciIsImJ5dGVzIiwidG9IZXgiLCJidWYiLCJlbmQiLCJyZXN1bHQiLCJvZmZzZXQiLCJudW0iLCJ0b1N0cmluZyIsImxlbmd0aCIsIlBfMjQiLCJNYXRoIiwicG93IiwiUF8xNiIsIlBfOCIsInJlYWRVSW50MzJCRSIsInJlYWRVSW50MTZCRSIsIndyaXRlVUludDMyQkUiLCJ2YWx1ZSIsIndyaXRlVUludDE2QkUiLCJjb3B5Iiwic291cmNlIiwidGFyZ2V0IiwidGFyZ2V0U3RhcnQiLCJzb3VyY2VTdGFydCIsInNvdXJjZUVuZCIsIl9jb3B5QWN0dWFsIiwibmIiLCJzb3VyY2VMZW4iLCJidWZmZXIiLCJieXRlT2Zmc2V0Iiwic2V0Il0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/@leichtgewicht/dns-packet/buffer_utils.mjs\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(ssr)/./node_modules/@leichtgewicht/dns-packet/classes.mjs":
|
|
/*!************************************************************!*\
|
|
!*** ./node_modules/@leichtgewicht/dns-packet/classes.mjs ***!
|
|
\************************************************************/
|
|
/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => {
|
|
|
|
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ toClass: () => (/* binding */ toClass),\n/* harmony export */ toString: () => (/* binding */ toString)\n/* harmony export */ });\nfunction toString(klass) {\n switch(klass){\n case 1:\n return \"IN\";\n case 2:\n return \"CS\";\n case 3:\n return \"CH\";\n case 4:\n return \"HS\";\n case 255:\n return \"ANY\";\n }\n return \"UNKNOWN_\" + klass;\n}\nfunction toClass(name) {\n switch(name.toUpperCase()){\n case \"IN\":\n return 1;\n case \"CS\":\n return 2;\n case \"CH\":\n return 3;\n case \"HS\":\n return 4;\n case \"ANY\":\n return 255;\n }\n return 0;\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvQGxlaWNodGdld2ljaHQvZG5zLXBhY2tldC9jbGFzc2VzLm1qcyIsIm1hcHBpbmdzIjoiOzs7OztBQUFPLFNBQVNBLFNBQVVDLEtBQUs7SUFDN0IsT0FBUUE7UUFDTixLQUFLO1lBQUcsT0FBTztRQUNmLEtBQUs7WUFBRyxPQUFPO1FBQ2YsS0FBSztZQUFHLE9BQU87UUFDZixLQUFLO1lBQUcsT0FBTztRQUNmLEtBQUs7WUFBSyxPQUFPO0lBQ25CO0lBQ0EsT0FBTyxhQUFhQTtBQUN0QjtBQUVPLFNBQVNDLFFBQVNDLElBQUk7SUFDM0IsT0FBUUEsS0FBS0MsV0FBVztRQUN0QixLQUFLO1lBQU0sT0FBTztRQUNsQixLQUFLO1lBQU0sT0FBTztRQUNsQixLQUFLO1lBQU0sT0FBTztRQUNsQixLQUFLO1lBQU0sT0FBTztRQUNsQixLQUFLO1lBQU8sT0FBTztJQUNyQjtJQUNBLE9BQU87QUFDVCIsInNvdXJjZXMiOlsid2VicGFjazovL2ZsdXNoLW5vdGVzLy4vbm9kZV9tb2R1bGVzL0BsZWljaHRnZXdpY2h0L2Rucy1wYWNrZXQvY2xhc3Nlcy5tanM/MGRlMSJdLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgZnVuY3Rpb24gdG9TdHJpbmcgKGtsYXNzKSB7XG4gIHN3aXRjaCAoa2xhc3MpIHtcbiAgICBjYXNlIDE6IHJldHVybiAnSU4nXG4gICAgY2FzZSAyOiByZXR1cm4gJ0NTJ1xuICAgIGNhc2UgMzogcmV0dXJuICdDSCdcbiAgICBjYXNlIDQ6IHJldHVybiAnSFMnXG4gICAgY2FzZSAyNTU6IHJldHVybiAnQU5ZJ1xuICB9XG4gIHJldHVybiAnVU5LTk9XTl8nICsga2xhc3Ncbn1cblxuZXhwb3J0IGZ1bmN0aW9uIHRvQ2xhc3MgKG5hbWUpIHtcbiAgc3dpdGNoIChuYW1lLnRvVXBwZXJDYXNlKCkpIHtcbiAgICBjYXNlICdJTic6IHJldHVybiAxXG4gICAgY2FzZSAnQ1MnOiByZXR1cm4gMlxuICAgIGNhc2UgJ0NIJzogcmV0dXJuIDNcbiAgICBjYXNlICdIUyc6IHJldHVybiA0XG4gICAgY2FzZSAnQU5ZJzogcmV0dXJuIDI1NVxuICB9XG4gIHJldHVybiAwXG59XG4iXSwibmFtZXMiOlsidG9TdHJpbmciLCJrbGFzcyIsInRvQ2xhc3MiLCJuYW1lIiwidG9VcHBlckNhc2UiXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/@leichtgewicht/dns-packet/classes.mjs\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(ssr)/./node_modules/@leichtgewicht/dns-packet/index.mjs":
|
|
/*!**********************************************************!*\
|
|
!*** ./node_modules/@leichtgewicht/dns-packet/index.mjs ***!
|
|
\**********************************************************/
|
|
/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => {
|
|
|
|
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ AUTHENTIC_DATA: () => (/* binding */ AUTHENTIC_DATA),\n/* harmony export */ AUTHORITATIVE_ANSWER: () => (/* binding */ AUTHORITATIVE_ANSWER),\n/* harmony export */ CHECKING_DISABLED: () => (/* binding */ CHECKING_DISABLED),\n/* harmony export */ DNSSEC_OK: () => (/* binding */ DNSSEC_OK),\n/* harmony export */ RECURSION_AVAILABLE: () => (/* binding */ RECURSION_AVAILABLE),\n/* harmony export */ RECURSION_DESIRED: () => (/* binding */ RECURSION_DESIRED),\n/* harmony export */ TRUNCATED_RESPONSE: () => (/* binding */ TRUNCATED_RESPONSE),\n/* harmony export */ a: () => (/* binding */ ra),\n/* harmony export */ aaaa: () => (/* binding */ raaaa),\n/* harmony export */ answer: () => (/* binding */ answer),\n/* harmony export */ caa: () => (/* binding */ rcaa),\n/* harmony export */ cname: () => (/* binding */ rptr),\n/* harmony export */ decode: () => (/* binding */ decode),\n/* harmony export */ decodeList: () => (/* binding */ decodeList),\n/* harmony export */ dname: () => (/* binding */ rptr),\n/* harmony export */ dnskey: () => (/* binding */ rdnskey),\n/* harmony export */ ds: () => (/* binding */ rds),\n/* harmony export */ enc: () => (/* binding */ renc),\n/* harmony export */ encode: () => (/* binding */ encode),\n/* harmony export */ encodeList: () => (/* binding */ encodeList),\n/* harmony export */ encodingLength: () => (/* binding */ encodingLength),\n/* harmony export */ encodingLengthList: () => (/* binding */ encodingLengthList),\n/* harmony export */ hinfo: () => (/* binding */ rhinfo),\n/* harmony export */ mx: () => (/* binding */ rmx),\n/* harmony export */ name: () => (/* binding */ name),\n/* harmony export */ ns: () => (/* binding */ rns),\n/* harmony export */ nsec: () => (/* binding */ rnsec),\n/* harmony export */ nsec3: () => (/* binding */ rnsec3),\n/* harmony export */ \"null\": () => (/* binding */ rnull),\n/* harmony export */ opt: () => (/* binding */ ropt),\n/* harmony export */ option: () => (/* binding */ roption),\n/* harmony export */ packet: () => (/* binding */ packet),\n/* harmony export */ ptr: () => (/* binding */ rptr),\n/* harmony export */ query: () => (/* binding */ query),\n/* harmony export */ question: () => (/* binding */ question),\n/* harmony export */ response: () => (/* binding */ response),\n/* harmony export */ rp: () => (/* binding */ rrp),\n/* harmony export */ rrsig: () => (/* binding */ rrrsig),\n/* harmony export */ soa: () => (/* binding */ rsoa),\n/* harmony export */ srv: () => (/* binding */ rsrv),\n/* harmony export */ streamDecode: () => (/* binding */ streamDecode),\n/* harmony export */ streamEncode: () => (/* binding */ streamEncode),\n/* harmony export */ txt: () => (/* binding */ rtxt),\n/* harmony export */ unknown: () => (/* binding */ runknown)\n/* harmony export */ });\n/* harmony import */ var _leichtgewicht_ip_codec__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @leichtgewicht/ip-codec */ \"(ssr)/./node_modules/@leichtgewicht/ip-codec/index.mjs\");\n/* harmony import */ var _types_mjs__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./types.mjs */ \"(ssr)/./node_modules/@leichtgewicht/dns-packet/types.mjs\");\n/* harmony import */ var _rcodes_mjs__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./rcodes.mjs */ \"(ssr)/./node_modules/@leichtgewicht/dns-packet/rcodes.mjs\");\n/* harmony import */ var _opcodes_mjs__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./opcodes.mjs */ \"(ssr)/./node_modules/@leichtgewicht/dns-packet/opcodes.mjs\");\n/* harmony import */ var _classes_mjs__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./classes.mjs */ \"(ssr)/./node_modules/@leichtgewicht/dns-packet/classes.mjs\");\n/* harmony import */ var _optioncodes_mjs__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./optioncodes.mjs */ \"(ssr)/./node_modules/@leichtgewicht/dns-packet/optioncodes.mjs\");\n/* harmony import */ var _buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ./buffer_utils.mjs */ \"(ssr)/./node_modules/@leichtgewicht/dns-packet/buffer_utils.mjs\");\n/* harmony import */ var utf8_codec__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! utf8-codec */ \"(ssr)/./node_modules/utf8-codec/index.mjs\");\n\n\n\n\n\n\n\n\nconst QUERY_FLAG = 0;\nconst RESPONSE_FLAG = 1 << 15;\nconst FLUSH_MASK = 1 << 15;\nconst NOT_FLUSH_MASK = ~FLUSH_MASK;\nconst QU_MASK = 1 << 15;\nconst NOT_QU_MASK = ~QU_MASK;\nfunction codec({ bytes = 0, encode, decode, encodingLength }) {\n encode.bytes = bytes;\n decode.bytes = bytes;\n return {\n encode,\n decode,\n encodingLength: encodingLength || (()=>bytes)\n };\n}\nconst name = codec({\n encode (str, buf, offset) {\n if (!buf) buf = new Uint8Array(name.encodingLength(str));\n if (!offset) offset = 0;\n const oldOffset = offset;\n // strip leading and trailing .\n const n = str.replace(/^\\.|\\.$/gm, \"\");\n if (n.length) {\n const list = n.split(\".\");\n for(let i = 0; i < list.length; i++){\n const len = _buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.write(buf, list[i], offset + 1);\n buf[offset] = len;\n offset += len + 1;\n }\n }\n buf[offset++] = 0;\n name.encode.bytes = offset - oldOffset;\n return buf;\n },\n decode (buf, offset) {\n if (!offset) offset = 0;\n const list = [];\n let oldOffset = offset;\n let totalLength = 0;\n let consumedBytes = 0;\n let jumped = false;\n while(true){\n if (offset >= buf.length) {\n throw new Error(\"Cannot decode name (buffer overflow)\");\n }\n const len = buf[offset++];\n consumedBytes += jumped ? 0 : 1;\n if (len === 0) {\n break;\n } else if ((len & 0xc0) === 0) {\n if (offset + len > buf.length) {\n throw new Error(\"Cannot decode name (buffer overflow)\");\n }\n totalLength += len + 1;\n if (totalLength > 254) {\n throw new Error(\"Cannot decode name (name too long)\");\n }\n list.push((0,utf8_codec__WEBPACK_IMPORTED_MODULE_7__.decode)(buf, offset, offset + len));\n offset += len;\n consumedBytes += jumped ? 0 : len;\n } else if ((len & 0xc0) === 0xc0) {\n if (offset + 1 > buf.length) {\n throw new Error(\"Cannot decode name (buffer overflow)\");\n }\n const jumpOffset = _buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.readUInt16BE(buf, offset - 1) - 0xc000;\n if (jumpOffset >= oldOffset) {\n // Allow only pointers to prior data. RFC 1035, section 4.1.4 states:\n // \"[...] an entire domain name or a list of labels at the end of a domain name\n // is replaced with a pointer to a prior occurance (sic) of the same name.\"\n throw new Error(\"Cannot decode name (bad pointer)\");\n }\n offset = jumpOffset;\n oldOffset = jumpOffset;\n consumedBytes += jumped ? 0 : 1;\n jumped = true;\n } else {\n throw new Error(\"Cannot decode name (bad label)\");\n }\n }\n name.decode.bytes = consumedBytes;\n return list.length === 0 ? \".\" : list.join(\".\");\n },\n encodingLength (n) {\n if (n === \".\" || n === \"..\") return 1;\n return _buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.bytelength(n.replace(/^\\.|\\.$/gm, \"\")) + 2;\n }\n});\nconst string = codec({\n encode (s, buf, offset) {\n if (!buf) buf = new Uint8Array(string.encodingLength(s));\n if (!offset) offset = 0;\n const len = _buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.write(buf, s, offset + 1);\n buf[offset] = len;\n string.encode.bytes = len + 1;\n return buf;\n },\n decode (buf, offset) {\n if (!offset) offset = 0;\n const len = buf[offset];\n const s = (0,utf8_codec__WEBPACK_IMPORTED_MODULE_7__.decode)(buf, offset + 1, offset + 1 + len);\n string.decode.bytes = len + 1;\n return s;\n },\n encodingLength (s) {\n return _buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.bytelength(s) + 1;\n }\n});\nconst header = codec({\n bytes: 12,\n encode (h, buf, offset) {\n if (!buf) buf = new Uint8Array(header.encodingLength(h));\n if (!offset) offset = 0;\n const flags = (h.flags || 0) & 32767;\n const type = h.type === \"response\" ? RESPONSE_FLAG : QUERY_FLAG;\n _buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.writeUInt16BE(buf, h.id || 0, offset);\n _buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.writeUInt16BE(buf, flags | type, offset + 2);\n _buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.writeUInt16BE(buf, h.questions.length, offset + 4);\n _buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.writeUInt16BE(buf, h.answers.length, offset + 6);\n _buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.writeUInt16BE(buf, h.authorities.length, offset + 8);\n _buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.writeUInt16BE(buf, h.additionals.length, offset + 10);\n return buf;\n },\n decode (buf, offset) {\n if (!offset) offset = 0;\n if (buf.length < 12) throw new Error(\"Header must be 12 bytes\");\n const flags = _buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.readUInt16BE(buf, offset + 2);\n return {\n id: _buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.readUInt16BE(buf, offset),\n type: flags & RESPONSE_FLAG ? \"response\" : \"query\",\n flags: flags & 32767,\n flag_qr: (flags >> 15 & 0x1) === 1,\n opcode: _opcodes_mjs__WEBPACK_IMPORTED_MODULE_3__.toString(flags >> 11 & 0xf),\n flag_aa: (flags >> 10 & 0x1) === 1,\n flag_tc: (flags >> 9 & 0x1) === 1,\n flag_rd: (flags >> 8 & 0x1) === 1,\n flag_ra: (flags >> 7 & 0x1) === 1,\n flag_z: (flags >> 6 & 0x1) === 1,\n flag_ad: (flags >> 5 & 0x1) === 1,\n flag_cd: (flags >> 4 & 0x1) === 1,\n rcode: _rcodes_mjs__WEBPACK_IMPORTED_MODULE_2__.toString(flags & 0xf),\n questions: new Array(_buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.readUInt16BE(buf, offset + 4)),\n answers: new Array(_buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.readUInt16BE(buf, offset + 6)),\n authorities: new Array(_buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.readUInt16BE(buf, offset + 8)),\n additionals: new Array(_buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.readUInt16BE(buf, offset + 10))\n };\n },\n encodingLength () {\n return 12;\n }\n});\nconst runknown = codec({\n encode (data, buf, offset) {\n if (!buf) buf = new Uint8Array(runknown.encodingLength(data));\n if (!offset) offset = 0;\n const dLen = data.length;\n _buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.writeUInt16BE(buf, dLen, offset);\n _buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.copy(data, buf, offset + 2, 0, dLen);\n runknown.encode.bytes = dLen + 2;\n return buf;\n },\n decode (buf, offset) {\n if (!offset) offset = 0;\n const len = _buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.readUInt16BE(buf, offset);\n const data = buf.slice(offset + 2, offset + 2 + len);\n runknown.decode.bytes = len + 2;\n return data;\n },\n encodingLength (data) {\n return data.length + 2;\n }\n});\nconst rns = codec({\n encode (data, buf, offset) {\n if (!buf) buf = new Uint8Array(rns.encodingLength(data));\n if (!offset) offset = 0;\n name.encode(data, buf, offset + 2);\n _buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.writeUInt16BE(buf, name.encode.bytes, offset);\n rns.encode.bytes = name.encode.bytes + 2;\n return buf;\n },\n decode (buf, offset) {\n if (!offset) offset = 0;\n const len = _buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.readUInt16BE(buf, offset);\n const dd = name.decode(buf, offset + 2);\n rns.decode.bytes = len + 2;\n return dd;\n },\n encodingLength (data) {\n return name.encodingLength(data) + 2;\n }\n});\nconst rsoa = codec({\n encode (data, buf, offset) {\n if (!buf) buf = new Uint8Array(rsoa.encodingLength(data));\n if (!offset) offset = 0;\n const oldOffset = offset;\n offset += 2;\n name.encode(data.mname, buf, offset);\n offset += name.encode.bytes;\n name.encode(data.rname, buf, offset);\n offset += name.encode.bytes;\n _buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.writeUInt32BE(buf, data.serial || 0, offset);\n offset += 4;\n _buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.writeUInt32BE(buf, data.refresh || 0, offset);\n offset += 4;\n _buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.writeUInt32BE(buf, data.retry || 0, offset);\n offset += 4;\n _buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.writeUInt32BE(buf, data.expire || 0, offset);\n offset += 4;\n _buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.writeUInt32BE(buf, data.minimum || 0, offset);\n offset += 4;\n _buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.writeUInt16BE(buf, offset - oldOffset - 2, oldOffset);\n rsoa.encode.bytes = offset - oldOffset;\n return buf;\n },\n decode (buf, offset) {\n if (!offset) offset = 0;\n const oldOffset = offset;\n const data = {};\n offset += 2;\n data.mname = name.decode(buf, offset);\n offset += name.decode.bytes;\n data.rname = name.decode(buf, offset);\n offset += name.decode.bytes;\n data.serial = _buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.readUInt32BE(buf, offset);\n offset += 4;\n data.refresh = _buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.readUInt32BE(buf, offset);\n offset += 4;\n data.retry = _buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.readUInt32BE(buf, offset);\n offset += 4;\n data.expire = _buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.readUInt32BE(buf, offset);\n offset += 4;\n data.minimum = _buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.readUInt32BE(buf, offset);\n offset += 4;\n rsoa.decode.bytes = offset - oldOffset;\n return data;\n },\n encodingLength (data) {\n return 22 + name.encodingLength(data.mname) + name.encodingLength(data.rname);\n }\n});\nconst rtxt = codec({\n encode (data, buf, offset) {\n if (!Array.isArray(data)) data = [\n data\n ];\n for(let i = 0; i < data.length; i++){\n if (typeof data[i] === \"string\") {\n data[i] = _buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.from(data[i]);\n }\n if (!_buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.isU8Arr(data[i])) {\n throw new Error(\"Must be a Buffer\");\n }\n }\n if (!buf) buf = new Uint8Array(rtxt.encodingLength(data));\n if (!offset) offset = 0;\n const oldOffset = offset;\n offset += 2;\n data.forEach(function(d) {\n buf[offset++] = d.length;\n _buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.copy(d, buf, offset, 0, d.length);\n offset += d.length;\n });\n _buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.writeUInt16BE(buf, offset - oldOffset - 2, oldOffset);\n rtxt.encode.bytes = offset - oldOffset;\n return buf;\n },\n decode (buf, offset) {\n if (!offset) offset = 0;\n const oldOffset = offset;\n let remaining = _buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.readUInt16BE(buf, offset);\n offset += 2;\n const data = [];\n while(remaining > 0){\n const len = buf[offset++];\n --remaining;\n if (remaining < len) {\n throw new Error(\"Buffer overflow\");\n }\n data.push(buf.slice(offset, offset + len));\n offset += len;\n remaining -= len;\n }\n rtxt.decode.bytes = offset - oldOffset;\n return data;\n },\n encodingLength (data) {\n if (!Array.isArray(data)) data = [\n data\n ];\n let length = 2;\n data.forEach(function(buf) {\n if (typeof buf === \"string\") {\n length += _buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.bytelength(buf) + 1;\n } else {\n length += buf.length + 1;\n }\n });\n return length;\n }\n});\nconst rnull = codec({\n encode (data, buf, offset) {\n if (!buf) buf = new Uint8Array(rnull.encodingLength(data));\n if (!offset) offset = 0;\n if (typeof data === \"string\") data = _buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.from(data);\n if (!data) data = new Uint8Array(0);\n const oldOffset = offset;\n offset += 2;\n const len = data.length;\n _buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.copy(data, buf, offset, 0, len);\n offset += len;\n _buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.writeUInt16BE(buf, offset - oldOffset - 2, oldOffset);\n rnull.encode.bytes = offset - oldOffset;\n return buf;\n },\n decode (buf, offset) {\n if (!offset) offset = 0;\n const oldOffset = offset;\n const len = _buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.readUInt16BE(buf, offset);\n offset += 2;\n const data = buf.slice(offset, offset + len);\n offset += len;\n rnull.decode.bytes = offset - oldOffset;\n return data;\n },\n encodingLength (data) {\n if (!data) return 2;\n return (_buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.isU8Arr(data) ? data.length : _buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.bytelength(data)) + 2;\n }\n});\nconst rhinfo = codec({\n encode (data, buf, offset) {\n if (!buf) buf = new Uint8Array(rhinfo.encodingLength(data));\n if (!offset) offset = 0;\n const oldOffset = offset;\n offset += 2;\n string.encode(data.cpu, buf, offset);\n offset += string.encode.bytes;\n string.encode(data.os, buf, offset);\n offset += string.encode.bytes;\n _buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.writeUInt16BE(buf, offset - oldOffset - 2, oldOffset);\n rhinfo.encode.bytes = offset - oldOffset;\n return buf;\n },\n decode (buf, offset) {\n if (!offset) offset = 0;\n const oldOffset = offset;\n const data = {};\n offset += 2;\n data.cpu = string.decode(buf, offset);\n offset += string.decode.bytes;\n data.os = string.decode(buf, offset);\n offset += string.decode.bytes;\n rhinfo.decode.bytes = offset - oldOffset;\n return data;\n },\n encodingLength (data) {\n return string.encodingLength(data.cpu) + string.encodingLength(data.os) + 2;\n }\n});\nconst rptr = codec({\n encode (data, buf, offset) {\n if (!buf) buf = new Uint8Array(rptr.encodingLength(data));\n if (!offset) offset = 0;\n name.encode(data, buf, offset + 2);\n _buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.writeUInt16BE(buf, name.encode.bytes, offset);\n rptr.encode.bytes = name.encode.bytes + 2;\n return buf;\n },\n decode (buf, offset) {\n if (!offset) offset = 0;\n const data = name.decode(buf, offset + 2);\n rptr.decode.bytes = name.decode.bytes + 2;\n return data;\n },\n encodingLength (data) {\n return name.encodingLength(data) + 2;\n }\n});\nconst rsrv = codec({\n encode (data, buf, offset) {\n if (!buf) buf = new Uint8Array(rsrv.encodingLength(data));\n if (!offset) offset = 0;\n _buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.writeUInt16BE(buf, data.priority || 0, offset + 2);\n _buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.writeUInt16BE(buf, data.weight || 0, offset + 4);\n _buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.writeUInt16BE(buf, data.port || 0, offset + 6);\n name.encode(data.target, buf, offset + 8);\n const len = name.encode.bytes + 6;\n _buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.writeUInt16BE(buf, len, offset);\n rsrv.encode.bytes = len + 2;\n return buf;\n },\n decode (buf, offset) {\n if (!offset) offset = 0;\n const len = _buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.readUInt16BE(buf, offset);\n const data = {};\n data.priority = _buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.readUInt16BE(buf, offset + 2);\n data.weight = _buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.readUInt16BE(buf, offset + 4);\n data.port = _buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.readUInt16BE(buf, offset + 6);\n data.target = name.decode(buf, offset + 8);\n rsrv.decode.bytes = len + 2;\n return data;\n },\n encodingLength (data) {\n return 8 + name.encodingLength(data.target);\n }\n});\nconst rcaa = codec({\n encode (data, buf, offset) {\n const len = rcaa.encodingLength(data);\n if (!buf) buf = new Uint8Array(rcaa.encodingLength(data));\n if (!offset) offset = 0;\n if (data.issuerCritical) {\n data.flags = rcaa.ISSUER_CRITICAL;\n }\n _buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.writeUInt16BE(buf, len - 2, offset);\n offset += 2;\n buf[offset] = data.flags || 0;\n offset += 1;\n string.encode(data.tag, buf, offset);\n offset += string.encode.bytes;\n _buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.write(buf, data.value, offset);\n offset += _buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.bytelength(data.value);\n rcaa.encode.bytes = len;\n return buf;\n },\n decode (buf, offset) {\n if (!offset) offset = 0;\n const len = _buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.readUInt16BE(buf, offset);\n offset += 2;\n const oldOffset = offset;\n const data = {};\n data.flags = buf[offset];\n offset += 1;\n data.tag = string.decode(buf, offset);\n offset += string.decode.bytes;\n data.value = (0,utf8_codec__WEBPACK_IMPORTED_MODULE_7__.decode)(buf, offset, oldOffset + len);\n data.issuerCritical = !!(data.flags & rcaa.ISSUER_CRITICAL);\n rcaa.decode.bytes = len + 2;\n return data;\n },\n encodingLength (data) {\n return string.encodingLength(data.tag) + string.encodingLength(data.value) + 2;\n }\n});\nrcaa.ISSUER_CRITICAL = 1 << 7;\nconst rmx = codec({\n encode (data, buf, offset) {\n if (!buf) buf = new Uint8Array(rmx.encodingLength(data));\n if (!offset) offset = 0;\n const oldOffset = offset;\n offset += 2;\n _buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.writeUInt16BE(buf, data.preference || 0, offset);\n offset += 2;\n name.encode(data.exchange, buf, offset);\n offset += name.encode.bytes;\n _buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.writeUInt16BE(buf, offset - oldOffset - 2, oldOffset);\n rmx.encode.bytes = offset - oldOffset;\n return buf;\n },\n decode (buf, offset) {\n if (!offset) offset = 0;\n const oldOffset = offset;\n const data = {};\n offset += 2;\n data.preference = _buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.readUInt16BE(buf, offset);\n offset += 2;\n data.exchange = name.decode(buf, offset);\n offset += name.decode.bytes;\n rmx.decode.bytes = offset - oldOffset;\n return data;\n },\n encodingLength (data) {\n return 4 + name.encodingLength(data.exchange);\n }\n});\nconst ra = codec({\n encode (host, buf, offset) {\n if (!buf) buf = new Uint8Array(ra.encodingLength(host));\n if (!offset) offset = 0;\n _buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.writeUInt16BE(buf, 4, offset);\n offset += 2;\n _leichtgewicht_ip_codec__WEBPACK_IMPORTED_MODULE_0__.v4.encode(host, buf, offset);\n return buf;\n },\n decode (buf, offset) {\n if (!offset) offset = 0;\n offset += 2;\n const host = _leichtgewicht_ip_codec__WEBPACK_IMPORTED_MODULE_0__.v4.decode(buf, offset);\n return host;\n },\n bytes: 6\n});\nconst raaaa = codec({\n encode (host, buf, offset) {\n if (!buf) buf = new Uint8Array(raaaa.encodingLength(host));\n if (!offset) offset = 0;\n _buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.writeUInt16BE(buf, 16, offset);\n offset += 2;\n _leichtgewicht_ip_codec__WEBPACK_IMPORTED_MODULE_0__.v6.encode(host, buf, offset);\n raaaa.encode.bytes = 18;\n return buf;\n },\n decode (buf, offset) {\n if (!offset) offset = 0;\n offset += 2;\n const host = _leichtgewicht_ip_codec__WEBPACK_IMPORTED_MODULE_0__.v6.decode(buf, offset);\n raaaa.decode.bytes = 18;\n return host;\n },\n bytes: 18\n});\nconst alloc = (size)=>new Uint8Array(size);\nconst roption = codec({\n encode (option, buf, offset) {\n if (!buf) buf = new Uint8Array(roption.encodingLength(option));\n if (!offset) offset = 0;\n const oldOffset = offset;\n const code = _optioncodes_mjs__WEBPACK_IMPORTED_MODULE_5__.toCode(option.code);\n _buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.writeUInt16BE(buf, code, offset);\n offset += 2;\n if (option.data) {\n _buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.writeUInt16BE(buf, option.data.length, offset);\n offset += 2;\n _buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.copy(option.data, buf, offset);\n offset += option.data.length;\n } else {\n switch(code){\n // case 3: NSID. No encode makes sense.\n // case 5,6,7: Not implementable\n case 8:\n {\n // note: do IP math before calling\n const spl = option.sourcePrefixLength || 0;\n const fam = option.family || _leichtgewicht_ip_codec__WEBPACK_IMPORTED_MODULE_0__.familyOf(option.ip, alloc);\n const ipBuf = _leichtgewicht_ip_codec__WEBPACK_IMPORTED_MODULE_0__.encode(option.ip, alloc);\n const ipLen = Math.ceil(spl / 8);\n _buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.writeUInt16BE(buf, ipLen + 4, offset);\n offset += 2;\n _buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.writeUInt16BE(buf, fam, offset);\n offset += 2;\n buf[offset++] = spl;\n buf[offset++] = option.scopePrefixLength || 0;\n _buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.copy(ipBuf, buf, offset, 0, ipLen);\n offset += ipLen;\n }\n break;\n // case 9: EXPIRE (experimental)\n // case 10: COOKIE. No encode makes sense.\n case 11:\n if (option.timeout) {\n _buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.writeUInt16BE(buf, 2, offset);\n offset += 2;\n _buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.writeUInt16BE(buf, option.timeout, offset);\n offset += 2;\n } else {\n _buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.writeUInt16BE(buf, 0, offset);\n offset += 2;\n }\n break;\n case 12:\n {\n const len = option.length || 0;\n _buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.writeUInt16BE(buf, len, offset);\n offset += 2;\n buf.fill(0, offset, offset + len);\n offset += len;\n }\n break;\n // case 13: CHAIN. Experimental.\n case 14:\n {\n const tagsLen = option.tags.length * 2;\n _buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.writeUInt16BE(buf, tagsLen, offset);\n offset += 2;\n for (const tag of option.tags){\n _buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.writeUInt16BE(buf, tag, offset);\n offset += 2;\n }\n }\n break;\n default:\n throw new Error(`Unknown roption code: ${option.code}`);\n }\n }\n roption.encode.bytes = offset - oldOffset;\n return buf;\n },\n decode (buf, offset) {\n if (!offset) offset = 0;\n const option = {};\n option.code = _buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.readUInt16BE(buf, offset);\n option.type = _optioncodes_mjs__WEBPACK_IMPORTED_MODULE_5__.toString(option.code);\n offset += 2;\n const len = _buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.readUInt16BE(buf, offset);\n offset += 2;\n option.data = buf.slice(offset, offset + len);\n switch(option.code){\n // case 3: NSID. No decode makes sense.\n case 8:\n option.family = _buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.readUInt16BE(buf, offset);\n offset += 2;\n option.sourcePrefixLength = buf[offset++];\n option.scopePrefixLength = buf[offset++];\n {\n const padded = new Uint8Array(option.family === 1 ? 4 : 16);\n _buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.copy(buf, padded, 0, offset, offset + len - 4);\n option.ip = _leichtgewicht_ip_codec__WEBPACK_IMPORTED_MODULE_0__.decode(padded);\n }\n break;\n // case 12: Padding. No decode makes sense.\n case 11:\n if (len > 0) {\n option.timeout = _buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.readUInt16BE(buf, offset);\n offset += 2;\n }\n break;\n case 14:\n option.tags = [];\n for(let i = 0; i < len; i += 2){\n option.tags.push(_buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.readUInt16BE(buf, offset));\n offset += 2;\n }\n }\n roption.decode.bytes = len + 4;\n return option;\n },\n encodingLength (option) {\n if (option.data) {\n return option.data.length + 4;\n }\n const code = _optioncodes_mjs__WEBPACK_IMPORTED_MODULE_5__.toCode(option.code);\n switch(code){\n case 8:\n {\n const spl = option.sourcePrefixLength || 0;\n return Math.ceil(spl / 8) + 8;\n }\n case 11:\n return typeof option.timeout === \"number\" ? 6 : 4;\n case 12:\n return option.length + 4;\n case 14:\n return 4 + option.tags.length * 2;\n }\n throw new Error(`Unknown roption code: ${option.code}`);\n }\n});\nconst ropt = codec({\n encode (options, buf, offset) {\n if (!buf) buf = new Uint8Array(ropt.encodingLength(options));\n if (!offset) offset = 0;\n const oldOffset = offset;\n const rdlen = encodingLengthList(options, roption);\n _buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.writeUInt16BE(buf, rdlen, offset);\n offset = encodeList(options, roption, buf, offset + 2);\n ropt.encode.bytes = offset - oldOffset;\n return buf;\n },\n decode (buf, offset) {\n if (!offset) offset = 0;\n const oldOffset = offset;\n const options = [];\n let rdlen = _buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.readUInt16BE(buf, offset);\n offset += 2;\n let o = 0;\n while(rdlen > 0){\n options[o++] = roption.decode(buf, offset);\n offset += roption.decode.bytes;\n rdlen -= roption.decode.bytes;\n }\n ropt.decode.bytes = offset - oldOffset;\n return options;\n },\n encodingLength (options) {\n return 2 + encodingLengthList(options || [], roption);\n }\n});\nconst rdnskey = codec({\n encode (key, buf, offset) {\n if (!buf) buf = new Uint8Array(rdnskey.encodingLength(key));\n if (!offset) offset = 0;\n const oldOffset = offset;\n const keydata = key.key;\n if (!_buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.isU8Arr(keydata)) {\n throw new Error(\"Key must be a Buffer\");\n }\n offset += 2 // Leave space for length\n ;\n _buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.writeUInt16BE(buf, key.flags, offset);\n offset += 2;\n buf[offset] = rdnskey.PROTOCOL_DNSSEC;\n offset += 1;\n buf[offset] = key.algorithm;\n offset += 1;\n _buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.copy(keydata, buf, offset, 0, keydata.length);\n offset += keydata.length;\n rdnskey.encode.bytes = offset - oldOffset;\n _buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.writeUInt16BE(buf, rdnskey.encode.bytes - 2, oldOffset);\n return buf;\n },\n decode (buf, offset) {\n if (!offset) offset = 0;\n const oldOffset = offset;\n const key = {};\n const length = _buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.readUInt16BE(buf, offset);\n offset += 2;\n key.flags = _buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.readUInt16BE(buf, offset);\n offset += 2;\n if (buf[offset] !== rdnskey.PROTOCOL_DNSSEC) {\n throw new Error(\"Protocol must be 3\");\n }\n offset += 1;\n key.algorithm = buf[offset];\n offset += 1;\n key.key = buf.slice(offset, oldOffset + length + 2);\n offset += key.key.length;\n rdnskey.decode.bytes = offset - oldOffset;\n return key;\n },\n encodingLength (key) {\n return 6 + _buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.bytelength(key.key);\n }\n});\nrdnskey.PROTOCOL_DNSSEC = 3;\nrdnskey.ZONE_KEY = 0x80;\nrdnskey.SECURE_ENTRYPOINT = 0x8000;\nconst rrrsig = codec({\n encode (sig, buf, offset) {\n if (!buf) buf = new Uint8Array(rrrsig.encodingLength(sig));\n if (!offset) offset = 0;\n const oldOffset = offset;\n const signature = sig.signature;\n if (!_buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.isU8Arr(signature)) {\n throw new Error(\"Signature must be a Buffer\");\n }\n offset += 2 // Leave space for length\n ;\n _buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.writeUInt16BE(buf, _types_mjs__WEBPACK_IMPORTED_MODULE_1__.toType(sig.typeCovered), offset);\n offset += 2;\n buf[offset] = sig.algorithm;\n offset += 1;\n buf[offset] = sig.labels;\n offset += 1;\n _buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.writeUInt32BE(buf, sig.originalTTL, offset);\n offset += 4;\n _buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.writeUInt32BE(buf, sig.expiration, offset);\n offset += 4;\n _buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.writeUInt32BE(buf, sig.inception, offset);\n offset += 4;\n _buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.writeUInt16BE(buf, sig.keyTag, offset);\n offset += 2;\n name.encode(sig.signersName, buf, offset);\n offset += name.encode.bytes;\n _buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.copy(signature, buf, offset, 0, signature.length);\n offset += signature.length;\n rrrsig.encode.bytes = offset - oldOffset;\n _buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.writeUInt16BE(buf, rrrsig.encode.bytes - 2, oldOffset);\n return buf;\n },\n decode (buf, offset) {\n if (!offset) offset = 0;\n const oldOffset = offset;\n const sig = {};\n const length = _buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.readUInt16BE(buf, offset);\n offset += 2;\n sig.typeCovered = _types_mjs__WEBPACK_IMPORTED_MODULE_1__.toString(_buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.readUInt16BE(buf, offset));\n offset += 2;\n sig.algorithm = buf[offset];\n offset += 1;\n sig.labels = buf[offset];\n offset += 1;\n sig.originalTTL = _buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.readUInt32BE(buf, offset);\n offset += 4;\n sig.expiration = _buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.readUInt32BE(buf, offset);\n offset += 4;\n sig.inception = _buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.readUInt32BE(buf, offset);\n offset += 4;\n sig.keyTag = _buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.readUInt16BE(buf, offset);\n offset += 2;\n sig.signersName = name.decode(buf, offset);\n offset += name.decode.bytes;\n sig.signature = buf.slice(offset, oldOffset + length + 2);\n offset += sig.signature.length;\n rrrsig.decode.bytes = offset - oldOffset;\n return sig;\n },\n encodingLength (sig) {\n return 20 + name.encodingLength(sig.signersName) + _buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.bytelength(sig.signature);\n }\n});\nconst rrp = codec({\n encode (data, buf, offset) {\n if (!buf) buf = new Uint8Array(rrp.encodingLength(data));\n if (!offset) offset = 0;\n const oldOffset = offset;\n offset += 2 // Leave space for length\n ;\n name.encode(data.mbox || \".\", buf, offset);\n offset += name.encode.bytes;\n name.encode(data.txt || \".\", buf, offset);\n offset += name.encode.bytes;\n rrp.encode.bytes = offset - oldOffset;\n _buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.writeUInt16BE(buf, rrp.encode.bytes - 2, oldOffset);\n return buf;\n },\n decode (buf, offset) {\n if (!offset) offset = 0;\n const oldOffset = offset;\n const data = {};\n offset += 2;\n data.mbox = name.decode(buf, offset) || \".\";\n offset += name.decode.bytes;\n data.txt = name.decode(buf, offset) || \".\";\n offset += name.decode.bytes;\n rrp.decode.bytes = offset - oldOffset;\n return data;\n },\n encodingLength (data) {\n return 2 + name.encodingLength(data.mbox || \".\") + name.encodingLength(data.txt || \".\");\n }\n});\nconst typebitmap = codec({\n encode (typelist, buf, offset) {\n if (!buf) buf = new Uint8Array(typebitmap.encodingLength(typelist));\n if (!offset) offset = 0;\n const oldOffset = offset;\n const typesByWindow = [];\n for(let i = 0; i < typelist.length; i++){\n const typeid = _types_mjs__WEBPACK_IMPORTED_MODULE_1__.toType(typelist[i]);\n if (typesByWindow[typeid >> 8] === undefined) {\n typesByWindow[typeid >> 8] = [];\n }\n typesByWindow[typeid >> 8][typeid >> 3 & 0x1F] |= 1 << 7 - (typeid & 0x7);\n }\n for(let i = 0; i < typesByWindow.length; i++){\n if (typesByWindow[i] !== undefined) {\n const windowBuf = _buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.from(typesByWindow[i]);\n buf[offset] = i;\n offset += 1;\n buf[offset] = windowBuf.length;\n offset += 1;\n _buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.copy(windowBuf, buf, offset, 0, windowBuf.length);\n offset += windowBuf.length;\n }\n }\n typebitmap.encode.bytes = offset - oldOffset;\n return buf;\n },\n decode (buf, offset, length) {\n if (!offset) offset = 0;\n const oldOffset = offset;\n const typelist = [];\n while(offset - oldOffset < length){\n const window = buf[offset];\n offset += 1;\n const windowLength = buf[offset];\n offset += 1;\n for(let i = 0; i < windowLength; i++){\n const b = buf[offset + i];\n for(let j = 0; j < 8; j++){\n if (b & 1 << 7 - j) {\n const typeid = _types_mjs__WEBPACK_IMPORTED_MODULE_1__.toString(window << 8 | i << 3 | j);\n typelist.push(typeid);\n }\n }\n }\n offset += windowLength;\n }\n typebitmap.decode.bytes = offset - oldOffset;\n return typelist;\n },\n encodingLength (typelist) {\n const extents = [];\n for(let i = 0; i < typelist.length; i++){\n const typeid = _types_mjs__WEBPACK_IMPORTED_MODULE_1__.toType(typelist[i]);\n extents[typeid >> 8] = Math.max(extents[typeid >> 8] || 0, typeid & 0xFF);\n }\n let len = 0;\n for(let i = 0; i < extents.length; i++){\n if (extents[i] !== undefined) {\n len += 2 + Math.ceil((extents[i] + 1) / 8);\n }\n }\n return len;\n }\n});\nconst rnsec = codec({\n encode (record, buf, offset) {\n if (!buf) buf = new Uint8Array(rnsec.encodingLength(record));\n if (!offset) offset = 0;\n const oldOffset = offset;\n offset += 2 // Leave space for length\n ;\n name.encode(record.nextDomain, buf, offset);\n offset += name.encode.bytes;\n typebitmap.encode(record.rrtypes, buf, offset);\n offset += typebitmap.encode.bytes;\n rnsec.encode.bytes = offset - oldOffset;\n _buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.writeUInt16BE(buf, rnsec.encode.bytes - 2, oldOffset);\n return buf;\n },\n decode (buf, offset) {\n if (!offset) offset = 0;\n const oldOffset = offset;\n const record = {};\n const length = _buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.readUInt16BE(buf, offset);\n offset += 2;\n record.nextDomain = name.decode(buf, offset);\n offset += name.decode.bytes;\n record.rrtypes = typebitmap.decode(buf, offset, length - (offset - oldOffset));\n offset += typebitmap.decode.bytes;\n rnsec.decode.bytes = offset - oldOffset;\n return record;\n },\n encodingLength (record) {\n return 2 + name.encodingLength(record.nextDomain) + typebitmap.encodingLength(record.rrtypes);\n }\n});\nconst rnsec3 = codec({\n encode (record, buf, offset) {\n if (!buf) buf = new Uint8Array(rnsec3.encodingLength(record));\n if (!offset) offset = 0;\n const oldOffset = offset;\n const salt = record.salt;\n if (!_buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.isU8Arr(salt)) {\n throw new Error(\"salt must be a Buffer\");\n }\n const nextDomain = record.nextDomain;\n if (!_buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.isU8Arr(nextDomain)) {\n throw new Error(\"nextDomain must be a Buffer\");\n }\n offset += 2 // Leave space for length\n ;\n buf[offset] = record.algorithm;\n offset += 1;\n buf[offset] = record.flags;\n offset += 1;\n _buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.writeUInt16BE(buf, record.iterations, offset);\n offset += 2;\n buf[offset] = salt.length;\n offset += 1;\n _buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.copy(salt, buf, offset, 0, salt.length);\n offset += salt.length;\n buf[offset] = nextDomain.length;\n offset += 1;\n _buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.copy(nextDomain, buf, offset, 0, nextDomain.length);\n offset += nextDomain.length;\n typebitmap.encode(record.rrtypes, buf, offset);\n offset += typebitmap.encode.bytes;\n rnsec3.encode.bytes = offset - oldOffset;\n _buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.writeUInt16BE(buf, rnsec3.encode.bytes - 2, oldOffset);\n return buf;\n },\n decode (buf, offset) {\n if (!offset) offset = 0;\n const oldOffset = offset;\n const record = {};\n const length = _buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.readUInt16BE(buf, offset);\n offset += 2;\n record.algorithm = buf[offset];\n offset += 1;\n record.flags = buf[offset];\n offset += 1;\n record.iterations = _buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.readUInt16BE(buf, offset);\n offset += 2;\n const saltLength = buf[offset];\n offset += 1;\n record.salt = buf.slice(offset, offset + saltLength);\n offset += saltLength;\n const hashLength = buf[offset];\n offset += 1;\n record.nextDomain = buf.slice(offset, offset + hashLength);\n offset += hashLength;\n record.rrtypes = typebitmap.decode(buf, offset, length - (offset - oldOffset));\n offset += typebitmap.decode.bytes;\n rnsec3.decode.bytes = offset - oldOffset;\n return record;\n },\n encodingLength (record) {\n return 8 + record.salt.length + record.nextDomain.length + typebitmap.encodingLength(record.rrtypes);\n }\n});\nconst rds = codec({\n encode (digest, buf, offset) {\n if (!buf) buf = new Uint8Array(rds.encodingLength(digest));\n if (!offset) offset = 0;\n const oldOffset = offset;\n const digestdata = digest.digest;\n if (!_buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.isU8Arr(digestdata)) {\n throw new Error(\"Digest must be a Buffer\");\n }\n offset += 2 // Leave space for length\n ;\n _buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.writeUInt16BE(buf, digest.keyTag, offset);\n offset += 2;\n buf[offset] = digest.algorithm;\n offset += 1;\n buf[offset] = digest.digestType;\n offset += 1;\n _buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.copy(digestdata, buf, offset, 0, digestdata.length);\n offset += digestdata.length;\n rds.encode.bytes = offset - oldOffset;\n _buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.writeUInt16BE(buf, rds.encode.bytes - 2, oldOffset);\n return buf;\n },\n decode (buf, offset) {\n if (!offset) offset = 0;\n const oldOffset = offset;\n const digest = {};\n const length = _buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.readUInt16BE(buf, offset);\n offset += 2;\n digest.keyTag = _buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.readUInt16BE(buf, offset);\n offset += 2;\n digest.algorithm = buf[offset];\n offset += 1;\n digest.digestType = buf[offset];\n offset += 1;\n digest.digest = buf.slice(offset, oldOffset + length + 2);\n offset += digest.digest.length;\n rds.decode.bytes = offset - oldOffset;\n return digest;\n },\n encodingLength (digest) {\n return 6 + _buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.bytelength(digest.digest);\n }\n});\nfunction renc(type) {\n switch(type.toUpperCase()){\n case \"A\":\n return ra;\n case \"PTR\":\n return rptr;\n case \"CNAME\":\n return rptr;\n case \"DNAME\":\n return rptr;\n case \"TXT\":\n return rtxt;\n case \"NULL\":\n return rnull;\n case \"AAAA\":\n return raaaa;\n case \"SRV\":\n return rsrv;\n case \"HINFO\":\n return rhinfo;\n case \"CAA\":\n return rcaa;\n case \"NS\":\n return rns;\n case \"SOA\":\n return rsoa;\n case \"MX\":\n return rmx;\n case \"OPT\":\n return ropt;\n case \"DNSKEY\":\n return rdnskey;\n case \"RRSIG\":\n return rrrsig;\n case \"RP\":\n return rrp;\n case \"NSEC\":\n return rnsec;\n case \"NSEC3\":\n return rnsec3;\n case \"DS\":\n return rds;\n }\n return runknown;\n}\nconst answer = codec({\n encode (a, buf, offset) {\n if (!buf) buf = new Uint8Array(answer.encodingLength(a));\n if (!offset) offset = 0;\n const oldOffset = offset;\n name.encode(a.name, buf, offset);\n offset += name.encode.bytes;\n _buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.writeUInt16BE(buf, _types_mjs__WEBPACK_IMPORTED_MODULE_1__.toType(a.type), offset);\n if (a.type.toUpperCase() === \"OPT\") {\n if (a.name !== \".\") {\n throw new Error(\"OPT name must be root.\");\n }\n _buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.writeUInt16BE(buf, a.udpPayloadSize || 4096, offset + 2);\n buf[offset + 4] = a.extendedRcode || 0;\n buf[offset + 5] = a.ednsVersion || 0;\n _buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.writeUInt16BE(buf, a.flags || 0, offset + 6);\n offset += 8;\n ropt.encode(a.options || [], buf, offset);\n offset += ropt.encode.bytes;\n } else {\n let klass = _classes_mjs__WEBPACK_IMPORTED_MODULE_4__.toClass(a.class === undefined ? \"IN\" : a.class);\n if (a.flush) klass |= FLUSH_MASK // the 1st bit of the class is the flush bit\n ;\n _buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.writeUInt16BE(buf, klass, offset + 2);\n _buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.writeUInt32BE(buf, a.ttl || 0, offset + 4);\n offset += 8;\n const enc = renc(a.type);\n enc.encode(a.data, buf, offset);\n offset += enc.encode.bytes;\n }\n answer.encode.bytes = offset - oldOffset;\n return buf;\n },\n decode (buf, offset) {\n if (!offset) offset = 0;\n const a = {};\n const oldOffset = offset;\n a.name = name.decode(buf, offset);\n offset += name.decode.bytes;\n a.type = _types_mjs__WEBPACK_IMPORTED_MODULE_1__.toString(_buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.readUInt16BE(buf, offset));\n if (a.type === \"OPT\") {\n a.udpPayloadSize = _buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.readUInt16BE(buf, offset + 2);\n a.extendedRcode = buf[offset + 4];\n a.ednsVersion = buf[offset + 5];\n a.flags = _buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.readUInt16BE(buf, offset + 6);\n a.flag_do = (a.flags >> 15 & 0x1) === 1;\n a.options = ropt.decode(buf, offset + 8);\n offset += 8 + ropt.decode.bytes;\n } else {\n const klass = _buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.readUInt16BE(buf, offset + 2);\n a.ttl = _buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.readUInt32BE(buf, offset + 4);\n a.class = _classes_mjs__WEBPACK_IMPORTED_MODULE_4__.toString(klass & NOT_FLUSH_MASK);\n a.flush = !!(klass & FLUSH_MASK);\n const enc = renc(a.type);\n a.data = enc.decode(buf, offset + 8);\n offset += 8 + enc.decode.bytes;\n }\n answer.decode.bytes = offset - oldOffset;\n return a;\n },\n encodingLength (a) {\n const data = a.data !== null && a.data !== undefined ? a.data : a.options;\n return name.encodingLength(a.name) + 8 + renc(a.type).encodingLength(data);\n }\n});\nconst question = codec({\n encode (q, buf, offset) {\n if (!buf) buf = new Uint8Array(question.encodingLength(q));\n if (!offset) offset = 0;\n const oldOffset = offset;\n name.encode(q.name, buf, offset);\n offset += name.encode.bytes;\n _buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.writeUInt16BE(buf, _types_mjs__WEBPACK_IMPORTED_MODULE_1__.toType(q.type), offset);\n offset += 2;\n _buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.writeUInt16BE(buf, _classes_mjs__WEBPACK_IMPORTED_MODULE_4__.toClass(q.class === undefined ? \"IN\" : q.class), offset);\n offset += 2;\n question.encode.bytes = offset - oldOffset;\n return q;\n },\n decode (buf, offset) {\n if (!offset) offset = 0;\n const oldOffset = offset;\n const q = {};\n q.name = name.decode(buf, offset);\n offset += name.decode.bytes;\n q.type = _types_mjs__WEBPACK_IMPORTED_MODULE_1__.toString(_buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.readUInt16BE(buf, offset));\n offset += 2;\n q.class = _classes_mjs__WEBPACK_IMPORTED_MODULE_4__.toString(_buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.readUInt16BE(buf, offset));\n offset += 2;\n const qu = !!(q.class & QU_MASK);\n if (qu) q.class &= NOT_QU_MASK;\n question.decode.bytes = offset - oldOffset;\n return q;\n },\n encodingLength (q) {\n return name.encodingLength(q.name) + 4;\n }\n});\n\nconst AUTHORITATIVE_ANSWER = 1 << 10;\nconst TRUNCATED_RESPONSE = 1 << 9;\nconst RECURSION_DESIRED = 1 << 8;\nconst RECURSION_AVAILABLE = 1 << 7;\nconst AUTHENTIC_DATA = 1 << 5;\nconst CHECKING_DISABLED = 1 << 4;\nconst DNSSEC_OK = 1 << 15;\nconst packet = {\n encode: function(result, buf, offset) {\n const allocing = !buf;\n if (allocing) buf = new Uint8Array(encodingLength(result));\n if (!offset) offset = 0;\n const oldOffset = offset;\n if (!result.questions) result.questions = [];\n if (!result.answers) result.answers = [];\n if (!result.authorities) result.authorities = [];\n if (!result.additionals) result.additionals = [];\n header.encode(result, buf, offset);\n offset += header.encode.bytes;\n offset = encodeList(result.questions, question, buf, offset);\n offset = encodeList(result.answers, answer, buf, offset);\n offset = encodeList(result.authorities, answer, buf, offset);\n offset = encodeList(result.additionals, answer, buf, offset);\n packet.encode.bytes = offset - oldOffset;\n // just a quick sanity check\n if (allocing && encode.bytes !== buf.length) {\n return buf.slice(0, encode.bytes);\n }\n return buf;\n },\n decode: function(buf, offset) {\n if (!offset) offset = 0;\n const oldOffset = offset;\n const result = header.decode(buf, offset);\n offset += header.decode.bytes;\n offset = decodeList(result.questions, question, buf, offset);\n offset = decodeList(result.answers, answer, buf, offset);\n offset = decodeList(result.authorities, answer, buf, offset);\n offset = decodeList(result.additionals, answer, buf, offset);\n packet.decode.bytes = offset - oldOffset;\n return result;\n },\n encodingLength: function(result) {\n return header.encodingLength(result) + encodingLengthList(result.questions || [], question) + encodingLengthList(result.answers || [], answer) + encodingLengthList(result.authorities || [], answer) + encodingLengthList(result.additionals || [], answer);\n }\n};\npacket.encode.bytes = 0;\npacket.decode.bytes = 0;\nfunction sanitizeSingle(input, type) {\n if (input.questions) {\n throw new Error(\"Only one .question object expected instead of a .questions array!\");\n }\n const sanitized = Object.assign({\n type\n }, input);\n if (sanitized.question) {\n sanitized.questions = [\n sanitized.question\n ];\n delete sanitized.question;\n }\n return sanitized;\n}\nconst query = {\n encode: function(result, buf, offset) {\n buf = packet.encode(sanitizeSingle(result, \"query\"), buf, offset);\n query.encode.bytes = packet.encode.bytes;\n return buf;\n },\n decode: function(buf, offset) {\n const res = packet.decode(buf, offset);\n query.decode.bytes = packet.decode.bytes;\n if (res.questions) {\n res.question = res.questions[0];\n delete res.questions;\n }\n return res;\n },\n encodingLength: function(result) {\n return packet.encodingLength(sanitizeSingle(result, \"query\"));\n }\n};\nquery.encode.bytes = 0;\nquery.decode.bytes = 0;\nconst response = {\n encode: function(result, buf, offset) {\n buf = packet.encode(sanitizeSingle(result, \"response\"), buf, offset);\n response.encode.bytes = packet.encode.bytes;\n return buf;\n },\n decode: function(buf, offset) {\n const res = packet.decode(buf, offset);\n response.decode.bytes = packet.decode.bytes;\n if (res.questions) {\n res.question = res.questions[0];\n delete res.questions;\n }\n return res;\n },\n encodingLength: function(result) {\n return packet.encodingLength(sanitizeSingle(result, \"response\"));\n }\n};\nresponse.encode.bytes = 0;\nresponse.decode.bytes = 0;\nconst encode = packet.encode;\nconst decode = packet.decode;\nconst encodingLength = packet.encodingLength;\nfunction streamEncode(result) {\n const buf = encode(result);\n const combine = new Uint8Array(2 + buf.byteLength);\n _buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.writeUInt16BE(combine, buf.byteLength);\n _buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.copy(buf, combine, 2, 0, buf.length);\n streamEncode.bytes = combine.byteLength;\n return combine;\n}\nstreamEncode.bytes = 0;\nfunction streamDecode(sbuf) {\n const len = _buffer_utils_mjs__WEBPACK_IMPORTED_MODULE_6__.readUInt16BE(sbuf, 0);\n if (sbuf.byteLength < len + 2) {\n // not enough data\n return null;\n }\n const result = decode(sbuf.slice(2));\n streamDecode.bytes = decode.bytes;\n return result;\n}\nstreamDecode.bytes = 0;\nfunction encodingLengthList(list, enc) {\n let len = 0;\n for(let i = 0; i < list.length; i++)len += enc.encodingLength(list[i]);\n return len;\n}\nfunction encodeList(list, enc, buf, offset) {\n for(let i = 0; i < list.length; i++){\n enc.encode(list[i], buf, offset);\n offset += enc.encode.bytes;\n }\n return offset;\n}\nfunction decodeList(list, enc, buf, offset) {\n for(let i = 0; i < list.length; i++){\n list[i] = enc.decode(buf, offset);\n offset += enc.decode.bytes;\n }\n return offset;\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"(ssr)/./node_modules/@leichtgewicht/dns-packet/index.mjs","mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAA6C;AACT;AACE;AACE;AACA;AACQ;AACT;AACM;AAE7C,MAAMS,aAAa;AACnB,MAAMC,gBAAgB,KAAK;AAC3B,MAAMC,aAAa,KAAK;AACxB,MAAMC,iBAAiB,CAACD;AACxB,MAAME,UAAU,KAAK;AACrB,MAAMC,cAAc,CAACD;AAErB,SAASE,MAAO,EAAEC,QAAQ,CAAC,EAAEC,MAAM,EAAEV,MAAM,EAAEW,cAAc,EAAE;IAC3DD,OAAOD,KAAK,GAAGA;IACfT,OAAOS,KAAK,GAAGA;IACf,OAAO;QACLC;QACAV;QACAW,gBAAgBA,kBAAmB,KAAMF,KAAI;IAC/C;AACF;AAEO,MAAMG,OAAOJ,MAAM;IACxBE,QAAQG,GAAG,EAAEC,GAAG,EAAEC,MAAM;QACtB,IAAI,CAACD,KAAKA,MAAM,IAAIE,WAAWJ,KAAKD,cAAc,CAACE;QACnD,IAAI,CAACE,QAAQA,SAAS;QACtB,MAAME,YAAYF;QAElB,+BAA+B;QAC/B,MAAMG,IAAIL,IAAIM,OAAO,CAAC,aAAa;QACnC,IAAID,EAAEE,MAAM,EAAE;YACZ,MAAMC,OAAOH,EAAEI,KAAK,CAAC;YAErB,IAAK,IAAIC,IAAI,GAAGA,IAAIF,KAAKD,MAAM,EAAEG,IAAK;gBACpC,MAAMC,MAAMzB,oDAAO,CAACe,KAAKO,IAAI,CAACE,EAAE,EAAER,SAAS;gBAC3CD,GAAG,CAACC,OAAO,GAAGS;gBACdT,UAAUS,MAAM;YAClB;QACF;QAEAV,GAAG,CAACC,SAAS,GAAG;QAEhBH,KAAKF,MAAM,CAACD,KAAK,GAAGM,SAASE;QAC7B,OAAOH;IACT;IACAd,QAAQc,GAAG,EAAEC,MAAM;QACjB,IAAI,CAACA,QAAQA,SAAS;QAEtB,MAAMM,OAAO,EAAE;QACf,IAAIJ,YAAYF;QAChB,IAAIW,cAAc;QAClB,IAAIC,gBAAgB;QACpB,IAAIC,SAAS;QAEb,MAAO,KAAM;YACX,IAAIb,UAAUD,IAAIM,MAAM,EAAE;gBACxB,MAAM,IAAIS,MAAM;YAClB;YACA,MAAML,MAAMV,GAAG,CAACC,SAAS;YACzBY,iBAAiBC,SAAS,IAAI;YAE9B,IAAIJ,QAAQ,GAAG;gBACb;YACF,OAAO,IAAI,CAACA,MAAM,IAAG,MAAO,GAAG;gBAC7B,IAAIT,SAASS,MAAMV,IAAIM,MAAM,EAAE;oBAC7B,MAAM,IAAIS,MAAM;gBAClB;gBACAH,eAAeF,MAAM;gBACrB,IAAIE,cAAc,KAAK;oBACrB,MAAM,IAAIG,MAAM;gBAClB;gBACAR,KAAKS,IAAI,CAAC7B,kDAAMA,CAACa,KAAKC,QAAQA,SAASS;gBACvCT,UAAUS;gBACVG,iBAAiBC,SAAS,IAAIJ;YAChC,OAAO,IAAI,CAACA,MAAM,IAAG,MAAO,MAAM;gBAChC,IAAIT,SAAS,IAAID,IAAIM,MAAM,EAAE;oBAC3B,MAAM,IAAIS,MAAM;gBAClB;gBACA,MAAME,aAAahC,2DAAc,CAACe,KAAKC,SAAS,KAAK;gBACrD,IAAIgB,cAAcd,WAAW;oBAC3B,qEAAqE;oBACrE,+EAA+E;oBAC/E,2EAA2E;oBAC3E,MAAM,IAAIY,MAAM;gBAClB;gBACAd,SAASgB;gBACTd,YAAYc;gBACZJ,iBAAiBC,SAAS,IAAI;gBAC9BA,SAAS;YACX,OAAO;gBACL,MAAM,IAAIC,MAAM;YAClB;QACF;QAEAjB,KAAKZ,MAAM,CAACS,KAAK,GAAGkB;QACpB,OAAON,KAAKD,MAAM,KAAK,IAAI,MAAMC,KAAKY,IAAI,CAAC;IAC7C;IACAtB,gBAAgBO,CAAC;QACf,IAAIA,MAAM,OAAOA,MAAM,MAAM,OAAO;QACpC,OAAOnB,yDAAY,CAACmB,EAAEC,OAAO,CAAC,aAAa,OAAO;IACpD;AACF,GAAE;AAEF,MAAMgB,SAAS3B,MAAM;IACnBE,QAAQ0B,CAAC,EAAEtB,GAAG,EAAEC,MAAM;QACpB,IAAI,CAACD,KAAKA,MAAM,IAAIE,WAAWmB,OAAOxB,cAAc,CAACyB;QACrD,IAAI,CAACrB,QAAQA,SAAS;QAEtB,MAAMS,MAAMzB,oDAAO,CAACe,KAAKsB,GAAGrB,SAAS;QACrCD,GAAG,CAACC,OAAO,GAAGS;QACdW,OAAOzB,MAAM,CAACD,KAAK,GAAGe,MAAM;QAC5B,OAAOV;IACT;IACAd,QAAQc,GAAG,EAAEC,MAAM;QACjB,IAAI,CAACA,QAAQA,SAAS;QAEtB,MAAMS,MAAMV,GAAG,CAACC,OAAO;QACvB,MAAMqB,IAAInC,kDAAMA,CAACa,KAAKC,SAAS,GAAGA,SAAS,IAAIS;QAC/CW,OAAOnC,MAAM,CAACS,KAAK,GAAGe,MAAM;QAC5B,OAAOY;IACT;IACAzB,gBAAgByB,CAAC;QACf,OAAOrC,yDAAY,CAACqC,KAAK;IAC3B;AACF;AAEA,MAAMC,SAAS7B,MAAM;IACnBC,OAAO;IACPC,QAAQ4B,CAAC,EAAExB,GAAG,EAAEC,MAAM;QACpB,IAAI,CAACD,KAAKA,MAAM,IAAIE,WAAWqB,OAAO1B,cAAc,CAAC2B;QACrD,IAAI,CAACvB,QAAQA,SAAS;QAEtB,MAAMwB,QAAQ,CAACD,EAAEC,KAAK,IAAI,KAAK;QAC/B,MAAMC,OAAOF,EAAEE,IAAI,KAAK,aAAarC,gBAAgBD;QAErDH,4DAAe,CAACe,KAAKwB,EAAEI,EAAE,IAAI,GAAG3B;QAChChB,4DAAe,CAACe,KAAKyB,QAAQC,MAAMzB,SAAS;QAC5ChB,4DAAe,CAACe,KAAKwB,EAAEK,SAAS,CAACvB,MAAM,EAAEL,SAAS;QAClDhB,4DAAe,CAACe,KAAKwB,EAAEM,OAAO,CAACxB,MAAM,EAAEL,SAAS;QAChDhB,4DAAe,CAACe,KAAKwB,EAAEO,WAAW,CAACzB,MAAM,EAAEL,SAAS;QACpDhB,4DAAe,CAACe,KAAKwB,EAAEQ,WAAW,CAAC1B,MAAM,EAAEL,SAAS;QAEpD,OAAOD;IACT;IACAd,QAAQc,GAAG,EAAEC,MAAM;QACjB,IAAI,CAACA,QAAQA,SAAS;QACtB,IAAID,IAAIM,MAAM,GAAG,IAAI,MAAM,IAAIS,MAAM;QACrC,MAAMU,QAAQxC,2DAAc,CAACe,KAAKC,SAAS;QAE3C,OAAO;YACL2B,IAAI3C,2DAAc,CAACe,KAAKC;YACxByB,MAAMD,QAAQpC,gBAAgB,aAAa;YAC3CoC,OAAOA,QAAQ;YACfQ,SAAS,CAAC,SAAU,KAAM,GAAE,MAAO;YACnCC,QAAQpD,kDAAgB,CAAC,SAAU,KAAM;YACzCsD,SAAS,CAAC,SAAU,KAAM,GAAE,MAAO;YACnCC,SAAS,CAAC,SAAU,IAAK,GAAE,MAAO;YAClCC,SAAS,CAAC,SAAU,IAAK,GAAE,MAAO;YAClCC,SAAS,CAAC,SAAU,IAAK,GAAE,MAAO;YAClCC,QAAQ,CAAC,SAAU,IAAK,GAAE,MAAO;YACjCC,SAAS,CAAC,SAAU,IAAK,GAAE,MAAO;YAClCC,SAAS,CAAC,SAAU,IAAK,GAAE,MAAO;YAClCC,OAAO9D,iDAAe,CAAC4C,QAAQ;YAC/BI,WAAW,IAAIe,MAAM3D,2DAAc,CAACe,KAAKC,SAAS;YAClD6B,SAAS,IAAIc,MAAM3D,2DAAc,CAACe,KAAKC,SAAS;YAChD8B,aAAa,IAAIa,MAAM3D,2DAAc,CAACe,KAAKC,SAAS;YACpD+B,aAAa,IAAIY,MAAM3D,2DAAc,CAACe,KAAKC,SAAS;QACtD;IACF;IACAJ;QACE,OAAO;IACT;AACF;AAEA,MAAMgD,WAAWnD,MAAM;IACrBE,QAAQkD,IAAI,EAAE9C,GAAG,EAAEC,MAAM;QACvB,IAAI,CAACD,KAAKA,MAAM,IAAIE,WAAW2C,SAAShD,cAAc,CAACiD;QACvD,IAAI,CAAC7C,QAAQA,SAAS;QAEtB,MAAM8C,OAAOD,KAAKxC,MAAM;QACxBrB,4DAAe,CAACe,KAAK+C,MAAM9C;QAC3BhB,mDAAM,CAAC6D,MAAM9C,KAAKC,SAAS,GAAG,GAAG8C;QAEjCF,SAASjD,MAAM,CAACD,KAAK,GAAGoD,OAAO;QAC/B,OAAO/C;IACT;IACAd,QAAQc,GAAG,EAAEC,MAAM;QACjB,IAAI,CAACA,QAAQA,SAAS;QAEtB,MAAMS,MAAMzB,2DAAc,CAACe,KAAKC;QAChC,MAAM6C,OAAO9C,IAAIiD,KAAK,CAAChD,SAAS,GAAGA,SAAS,IAAIS;QAChDmC,SAAS3D,MAAM,CAACS,KAAK,GAAGe,MAAM;QAC9B,OAAOoC;IACT;IACAjD,gBAAgBiD,IAAI;QAClB,OAAOA,KAAKxC,MAAM,GAAG;IACvB;AACF;AAEA,MAAM4C,MAAMxD,MAAM;IAChBE,QAAQkD,IAAI,EAAE9C,GAAG,EAAEC,MAAM;QACvB,IAAI,CAACD,KAAKA,MAAM,IAAIE,WAAWgD,IAAIrD,cAAc,CAACiD;QAClD,IAAI,CAAC7C,QAAQA,SAAS;QAEtBH,KAAKF,MAAM,CAACkD,MAAM9C,KAAKC,SAAS;QAChChB,4DAAe,CAACe,KAAKF,KAAKF,MAAM,CAACD,KAAK,EAAEM;QACxCiD,IAAItD,MAAM,CAACD,KAAK,GAAGG,KAAKF,MAAM,CAACD,KAAK,GAAG;QACvC,OAAOK;IACT;IACAd,QAAQc,GAAG,EAAEC,MAAM;QACjB,IAAI,CAACA,QAAQA,SAAS;QAEtB,MAAMS,MAAMzB,2DAAc,CAACe,KAAKC;QAChC,MAAMkD,KAAKrD,KAAKZ,MAAM,CAACc,KAAKC,SAAS;QAErCiD,IAAIhE,MAAM,CAACS,KAAK,GAAGe,MAAM;QACzB,OAAOyC;IACT;IACAtD,gBAAgBiD,IAAI;QAClB,OAAOhD,KAAKD,cAAc,CAACiD,QAAQ;IACrC;AACF;AAEA,MAAMM,OAAO1D,MAAM;IACjBE,QAAQkD,IAAI,EAAE9C,GAAG,EAAEC,MAAM;QACvB,IAAI,CAACD,KAAKA,MAAM,IAAIE,WAAWkD,KAAKvD,cAAc,CAACiD;QACnD,IAAI,CAAC7C,QAAQA,SAAS;QAEtB,MAAME,YAAYF;QAClBA,UAAU;QACVH,KAAKF,MAAM,CAACkD,KAAKO,KAAK,EAAErD,KAAKC;QAC7BA,UAAUH,KAAKF,MAAM,CAACD,KAAK;QAC3BG,KAAKF,MAAM,CAACkD,KAAKQ,KAAK,EAAEtD,KAAKC;QAC7BA,UAAUH,KAAKF,MAAM,CAACD,KAAK;QAC3BV,4DAAe,CAACe,KAAK8C,KAAKU,MAAM,IAAI,GAAGvD;QACvCA,UAAU;QACVhB,4DAAe,CAACe,KAAK8C,KAAKW,OAAO,IAAI,GAAGxD;QACxCA,UAAU;QACVhB,4DAAe,CAACe,KAAK8C,KAAKY,KAAK,IAAI,GAAGzD;QACtCA,UAAU;QACVhB,4DAAe,CAACe,KAAK8C,KAAKa,MAAM,IAAI,GAAG1D;QACvCA,UAAU;QACVhB,4DAAe,CAACe,KAAK8C,KAAKc,OAAO,IAAI,GAAG3D;QACxCA,UAAU;QAEVhB,4DAAe,CAACe,KAAKC,SAASE,YAAY,GAAGA;QAC7CiD,KAAKxD,MAAM,CAACD,KAAK,GAAGM,SAASE;QAC7B,OAAOH;IACT;IACAd,QAAQc,GAAG,EAAEC,MAAM;QACjB,IAAI,CAACA,QAAQA,SAAS;QAEtB,MAAME,YAAYF;QAElB,MAAM6C,OAAO,CAAC;QACd7C,UAAU;QACV6C,KAAKO,KAAK,GAAGvD,KAAKZ,MAAM,CAACc,KAAKC;QAC9BA,UAAUH,KAAKZ,MAAM,CAACS,KAAK;QAC3BmD,KAAKQ,KAAK,GAAGxD,KAAKZ,MAAM,CAACc,KAAKC;QAC9BA,UAAUH,KAAKZ,MAAM,CAACS,KAAK;QAC3BmD,KAAKU,MAAM,GAAGvE,2DAAc,CAACe,KAAKC;QAClCA,UAAU;QACV6C,KAAKW,OAAO,GAAGxE,2DAAc,CAACe,KAAKC;QACnCA,UAAU;QACV6C,KAAKY,KAAK,GAAGzE,2DAAc,CAACe,KAAKC;QACjCA,UAAU;QACV6C,KAAKa,MAAM,GAAG1E,2DAAc,CAACe,KAAKC;QAClCA,UAAU;QACV6C,KAAKc,OAAO,GAAG3E,2DAAc,CAACe,KAAKC;QACnCA,UAAU;QAEVmD,KAAKlE,MAAM,CAACS,KAAK,GAAGM,SAASE;QAC7B,OAAO2C;IACT;IACAjD,gBAAgBiD,IAAI;QAClB,OAAO,KAAKhD,KAAKD,cAAc,CAACiD,KAAKO,KAAK,IAAIvD,KAAKD,cAAc,CAACiD,KAAKQ,KAAK;IAC9E;AACF;AAEA,MAAMQ,OAAOpE,MAAM;IACjBE,QAAQkD,IAAI,EAAE9C,GAAG,EAAEC,MAAM;QACvB,IAAI,CAAC2C,MAAMmB,OAAO,CAACjB,OAAOA,OAAO;YAACA;SAAK;QACvC,IAAK,IAAIrC,IAAI,GAAGA,IAAIqC,KAAKxC,MAAM,EAAEG,IAAK;YACpC,IAAI,OAAOqC,IAAI,CAACrC,EAAE,KAAK,UAAU;gBAC/BqC,IAAI,CAACrC,EAAE,GAAGxB,mDAAM,CAAC6D,IAAI,CAACrC,EAAE;YAC1B;YACA,IAAI,CAACxB,sDAAS,CAAC6D,IAAI,CAACrC,EAAE,GAAG;gBACvB,MAAM,IAAIM,MAAM;YAClB;QACF;QAEA,IAAI,CAACf,KAAKA,MAAM,IAAIE,WAAW4D,KAAKjE,cAAc,CAACiD;QACnD,IAAI,CAAC7C,QAAQA,SAAS;QAEtB,MAAME,YAAYF;QAClBA,UAAU;QAEV6C,KAAKoB,OAAO,CAAC,SAAUC,CAAC;YACtBnE,GAAG,CAACC,SAAS,GAAGkE,EAAE7D,MAAM;YACxBrB,mDAAM,CAACkF,GAAGnE,KAAKC,QAAQ,GAAGkE,EAAE7D,MAAM;YAClCL,UAAUkE,EAAE7D,MAAM;QACpB;QAEArB,4DAAe,CAACe,KAAKC,SAASE,YAAY,GAAGA;QAC7C2D,KAAKlE,MAAM,CAACD,KAAK,GAAGM,SAASE;QAC7B,OAAOH;IACT;IACAd,QAAQc,GAAG,EAAEC,MAAM;QACjB,IAAI,CAACA,QAAQA,SAAS;QACtB,MAAME,YAAYF;QAClB,IAAImE,YAAYnF,2DAAc,CAACe,KAAKC;QACpCA,UAAU;QAEV,MAAM6C,OAAO,EAAE;QACf,MAAOsB,YAAY,EAAG;YACpB,MAAM1D,MAAMV,GAAG,CAACC,SAAS;YACzB,EAAEmE;YACF,IAAIA,YAAY1D,KAAK;gBACnB,MAAM,IAAIK,MAAM;YAClB;YACA+B,KAAK9B,IAAI,CAAChB,IAAIiD,KAAK,CAAChD,QAAQA,SAASS;YACrCT,UAAUS;YACV0D,aAAa1D;QACf;QAEAoD,KAAK5E,MAAM,CAACS,KAAK,GAAGM,SAASE;QAC7B,OAAO2C;IACT;IACAjD,gBAAgBiD,IAAI;QAClB,IAAI,CAACF,MAAMmB,OAAO,CAACjB,OAAOA,OAAO;YAACA;SAAK;QACvC,IAAIxC,SAAS;QACbwC,KAAKoB,OAAO,CAAC,SAAUlE,GAAG;YACxB,IAAI,OAAOA,QAAQ,UAAU;gBAC3BM,UAAUrB,yDAAY,CAACe,OAAO;YAChC,OAAO;gBACLM,UAAUN,IAAIM,MAAM,GAAG;YACzB;QACF;QACA,OAAOA;IACT;AACF;AAEA,MAAM+D,QAAQ3E,MAAM;IAClBE,QAAQkD,IAAI,EAAE9C,GAAG,EAAEC,MAAM;QACvB,IAAI,CAACD,KAAKA,MAAM,IAAIE,WAAWmE,MAAMxE,cAAc,CAACiD;QACpD,IAAI,CAAC7C,QAAQA,SAAS;QAEtB,IAAI,OAAO6C,SAAS,UAAUA,OAAO7D,mDAAM,CAAC6D;QAC5C,IAAI,CAACA,MAAMA,OAAO,IAAI5C,WAAW;QAEjC,MAAMC,YAAYF;QAClBA,UAAU;QAEV,MAAMS,MAAMoC,KAAKxC,MAAM;QACvBrB,mDAAM,CAAC6D,MAAM9C,KAAKC,QAAQ,GAAGS;QAC7BT,UAAUS;QAEVzB,4DAAe,CAACe,KAAKC,SAASE,YAAY,GAAGA;QAC7CkE,MAAMzE,MAAM,CAACD,KAAK,GAAGM,SAASE;QAC9B,OAAOH;IACT;IACAd,QAAQc,GAAG,EAAEC,MAAM;QACjB,IAAI,CAACA,QAAQA,SAAS;QACtB,MAAME,YAAYF;QAClB,MAAMS,MAAMzB,2DAAc,CAACe,KAAKC;QAEhCA,UAAU;QAEV,MAAM6C,OAAO9C,IAAIiD,KAAK,CAAChD,QAAQA,SAASS;QACxCT,UAAUS;QAEV2D,MAAMnF,MAAM,CAACS,KAAK,GAAGM,SAASE;QAC9B,OAAO2C;IACT;IACAjD,gBAAgBiD,IAAI;QAClB,IAAI,CAACA,MAAM,OAAO;QAClB,OAAO,CAAC7D,sDAAS,CAAC6D,QAAQA,KAAKxC,MAAM,GAAGrB,yDAAY,CAAC6D,KAAI,IAAK;IAChE;AACF;AAEA,MAAMwB,SAAS5E,MAAM;IACnBE,QAAQkD,IAAI,EAAE9C,GAAG,EAAEC,MAAM;QACvB,IAAI,CAACD,KAAKA,MAAM,IAAIE,WAAWoE,OAAOzE,cAAc,CAACiD;QACrD,IAAI,CAAC7C,QAAQA,SAAS;QAEtB,MAAME,YAAYF;QAClBA,UAAU;QACVoB,OAAOzB,MAAM,CAACkD,KAAKyB,GAAG,EAAEvE,KAAKC;QAC7BA,UAAUoB,OAAOzB,MAAM,CAACD,KAAK;QAC7B0B,OAAOzB,MAAM,CAACkD,KAAK0B,EAAE,EAAExE,KAAKC;QAC5BA,UAAUoB,OAAOzB,MAAM,CAACD,KAAK;QAC7BV,4DAAe,CAACe,KAAKC,SAASE,YAAY,GAAGA;QAC7CmE,OAAO1E,MAAM,CAACD,KAAK,GAAGM,SAASE;QAC/B,OAAOH;IACT;IACAd,QAAQc,GAAG,EAAEC,MAAM;QACjB,IAAI,CAACA,QAAQA,SAAS;QAEtB,MAAME,YAAYF;QAElB,MAAM6C,OAAO,CAAC;QACd7C,UAAU;QACV6C,KAAKyB,GAAG,GAAGlD,OAAOnC,MAAM,CAACc,KAAKC;QAC9BA,UAAUoB,OAAOnC,MAAM,CAACS,KAAK;QAC7BmD,KAAK0B,EAAE,GAAGnD,OAAOnC,MAAM,CAACc,KAAKC;QAC7BA,UAAUoB,OAAOnC,MAAM,CAACS,KAAK;QAC7B2E,OAAOpF,MAAM,CAACS,KAAK,GAAGM,SAASE;QAC/B,OAAO2C;IACT;IACAjD,gBAAgBiD,IAAI;QAClB,OAAOzB,OAAOxB,cAAc,CAACiD,KAAKyB,GAAG,IAAIlD,OAAOxB,cAAc,CAACiD,KAAK0B,EAAE,IAAI;IAC5E;AACF;AAEA,MAAMC,OAAO/E,MAAM;IACjBE,QAAQkD,IAAI,EAAE9C,GAAG,EAAEC,MAAM;QACvB,IAAI,CAACD,KAAKA,MAAM,IAAIE,WAAWuE,KAAK5E,cAAc,CAACiD;QACnD,IAAI,CAAC7C,QAAQA,SAAS;QAEtBH,KAAKF,MAAM,CAACkD,MAAM9C,KAAKC,SAAS;QAChChB,4DAAe,CAACe,KAAKF,KAAKF,MAAM,CAACD,KAAK,EAAEM;QACxCwE,KAAK7E,MAAM,CAACD,KAAK,GAAGG,KAAKF,MAAM,CAACD,KAAK,GAAG;QACxC,OAAOK;IACT;IACAd,QAAQc,GAAG,EAAEC,MAAM;QACjB,IAAI,CAACA,QAAQA,SAAS;QAEtB,MAAM6C,OAAOhD,KAAKZ,MAAM,CAACc,KAAKC,SAAS;QACvCwE,KAAKvF,MAAM,CAACS,KAAK,GAAGG,KAAKZ,MAAM,CAACS,KAAK,GAAG;QACxC,OAAOmD;IACT;IACAjD,gBAAgBiD,IAAI;QAClB,OAAOhD,KAAKD,cAAc,CAACiD,QAAQ;IACrC;AACF;AAEA,MAAM4B,OAAOhF,MAAM;IACjBE,QAAQkD,IAAI,EAAE9C,GAAG,EAAEC,MAAM;QACvB,IAAI,CAACD,KAAKA,MAAM,IAAIE,WAAWwE,KAAK7E,cAAc,CAACiD;QACnD,IAAI,CAAC7C,QAAQA,SAAS;QAEtBhB,4DAAe,CAACe,KAAK8C,KAAK6B,QAAQ,IAAI,GAAG1E,SAAS;QAClDhB,4DAAe,CAACe,KAAK8C,KAAK8B,MAAM,IAAI,GAAG3E,SAAS;QAChDhB,4DAAe,CAACe,KAAK8C,KAAK+B,IAAI,IAAI,GAAG5E,SAAS;QAC9CH,KAAKF,MAAM,CAACkD,KAAKgC,MAAM,EAAE9E,KAAKC,SAAS;QAEvC,MAAMS,MAAMZ,KAAKF,MAAM,CAACD,KAAK,GAAG;QAChCV,4DAAe,CAACe,KAAKU,KAAKT;QAE1ByE,KAAK9E,MAAM,CAACD,KAAK,GAAGe,MAAM;QAC1B,OAAOV;IACT;IACAd,QAAQc,GAAG,EAAEC,MAAM;QACjB,IAAI,CAACA,QAAQA,SAAS;QAEtB,MAAMS,MAAMzB,2DAAc,CAACe,KAAKC;QAEhC,MAAM6C,OAAO,CAAC;QACdA,KAAK6B,QAAQ,GAAG1F,2DAAc,CAACe,KAAKC,SAAS;QAC7C6C,KAAK8B,MAAM,GAAG3F,2DAAc,CAACe,KAAKC,SAAS;QAC3C6C,KAAK+B,IAAI,GAAG5F,2DAAc,CAACe,KAAKC,SAAS;QACzC6C,KAAKgC,MAAM,GAAGhF,KAAKZ,MAAM,CAACc,KAAKC,SAAS;QAExCyE,KAAKxF,MAAM,CAACS,KAAK,GAAGe,MAAM;QAC1B,OAAOoC;IACT;IACAjD,gBAAgBiD,IAAI;QAClB,OAAO,IAAIhD,KAAKD,cAAc,CAACiD,KAAKgC,MAAM;IAC5C;AACF;AAEA,MAAMC,OAAOrF,MAAM;IACjBE,QAAQkD,IAAI,EAAE9C,GAAG,EAAEC,MAAM;QACvB,MAAMS,MAAMqE,KAAKlF,cAAc,CAACiD;QAEhC,IAAI,CAAC9C,KAAKA,MAAM,IAAIE,WAAW6E,KAAKlF,cAAc,CAACiD;QACnD,IAAI,CAAC7C,QAAQA,SAAS;QAEtB,IAAI6C,KAAKkC,cAAc,EAAE;YACvBlC,KAAKrB,KAAK,GAAGsD,KAAKE,eAAe;QACnC;QAEAhG,4DAAe,CAACe,KAAKU,MAAM,GAAGT;QAC9BA,UAAU;QACVD,GAAG,CAACC,OAAO,GAAG6C,KAAKrB,KAAK,IAAI;QAC5BxB,UAAU;QACVoB,OAAOzB,MAAM,CAACkD,KAAKoC,GAAG,EAAElF,KAAKC;QAC7BA,UAAUoB,OAAOzB,MAAM,CAACD,KAAK;QAC7BV,oDAAO,CAACe,KAAK8C,KAAKqC,KAAK,EAAElF;QACzBA,UAAUhB,yDAAY,CAAC6D,KAAKqC,KAAK;QAEjCJ,KAAKnF,MAAM,CAACD,KAAK,GAAGe;QACpB,OAAOV;IACT;IACAd,QAAQc,GAAG,EAAEC,MAAM;QACjB,IAAI,CAACA,QAAQA,SAAS;QAEtB,MAAMS,MAAMzB,2DAAc,CAACe,KAAKC;QAChCA,UAAU;QAEV,MAAME,YAAYF;QAClB,MAAM6C,OAAO,CAAC;QACdA,KAAKrB,KAAK,GAAGzB,GAAG,CAACC,OAAO;QACxBA,UAAU;QACV6C,KAAKoC,GAAG,GAAG7D,OAAOnC,MAAM,CAACc,KAAKC;QAC9BA,UAAUoB,OAAOnC,MAAM,CAACS,KAAK;QAC7BmD,KAAKqC,KAAK,GAAGhG,kDAAMA,CAACa,KAAKC,QAAQE,YAAYO;QAE7CoC,KAAKkC,cAAc,GAAG,CAAC,CAAElC,CAAAA,KAAKrB,KAAK,GAAGsD,KAAKE,eAAe;QAE1DF,KAAK7F,MAAM,CAACS,KAAK,GAAGe,MAAM;QAE1B,OAAOoC;IACT;IACAjD,gBAAgBiD,IAAI;QAClB,OAAOzB,OAAOxB,cAAc,CAACiD,KAAKoC,GAAG,IAAI7D,OAAOxB,cAAc,CAACiD,KAAKqC,KAAK,IAAI;IAC/E;AACF;AAEAJ,KAAKE,eAAe,GAAG,KAAK;AAE5B,MAAMG,MAAM1F,MAAM;IAChBE,QAAQkD,IAAI,EAAE9C,GAAG,EAAEC,MAAM;QACvB,IAAI,CAACD,KAAKA,MAAM,IAAIE,WAAWkF,IAAIvF,cAAc,CAACiD;QAClD,IAAI,CAAC7C,QAAQA,SAAS;QAEtB,MAAME,YAAYF;QAClBA,UAAU;QACVhB,4DAAe,CAACe,KAAK8C,KAAKuC,UAAU,IAAI,GAAGpF;QAC3CA,UAAU;QACVH,KAAKF,MAAM,CAACkD,KAAKwC,QAAQ,EAAEtF,KAAKC;QAChCA,UAAUH,KAAKF,MAAM,CAACD,KAAK;QAE3BV,4DAAe,CAACe,KAAKC,SAASE,YAAY,GAAGA;QAC7CiF,IAAIxF,MAAM,CAACD,KAAK,GAAGM,SAASE;QAC5B,OAAOH;IACT;IACAd,QAAQc,GAAG,EAAEC,MAAM;QACjB,IAAI,CAACA,QAAQA,SAAS;QAEtB,MAAME,YAAYF;QAElB,MAAM6C,OAAO,CAAC;QACd7C,UAAU;QACV6C,KAAKuC,UAAU,GAAGpG,2DAAc,CAACe,KAAKC;QACtCA,UAAU;QACV6C,KAAKwC,QAAQ,GAAGxF,KAAKZ,MAAM,CAACc,KAAKC;QACjCA,UAAUH,KAAKZ,MAAM,CAACS,KAAK;QAE3ByF,IAAIlG,MAAM,CAACS,KAAK,GAAGM,SAASE;QAC5B,OAAO2C;IACT;IACAjD,gBAAgBiD,IAAI;QAClB,OAAO,IAAIhD,KAAKD,cAAc,CAACiD,KAAKwC,QAAQ;IAC9C;AACF;AAEA,MAAMC,KAAK7F,MAAM;IACfE,QAAQ4F,IAAI,EAAExF,GAAG,EAAEC,MAAM;QACvB,IAAI,CAACD,KAAKA,MAAM,IAAIE,WAAWqF,GAAG1F,cAAc,CAAC2F;QACjD,IAAI,CAACvF,QAAQA,SAAS;QAEtBhB,4DAAe,CAACe,KAAK,GAAGC;QACxBA,UAAU;QACVtB,uDAAK,CAACiB,MAAM,CAAC4F,MAAMxF,KAAKC;QACxB,OAAOD;IACT;IACAd,QAAQc,GAAG,EAAEC,MAAM;QACjB,IAAI,CAACA,QAAQA,SAAS;QAEtBA,UAAU;QACV,MAAMuF,OAAO7G,uDAAK,CAACO,MAAM,CAACc,KAAKC;QAC/B,OAAOuF;IACT;IACA7F,OAAO;AACT;AAEA,MAAM+F,QAAQhG,MAAM;IAClBE,QAAQ4F,IAAI,EAAExF,GAAG,EAAEC,MAAM;QACvB,IAAI,CAACD,KAAKA,MAAM,IAAIE,WAAWwF,MAAM7F,cAAc,CAAC2F;QACpD,IAAI,CAACvF,QAAQA,SAAS;QAEtBhB,4DAAe,CAACe,KAAK,IAAIC;QACzBA,UAAU;QACVtB,uDAAK,CAACiB,MAAM,CAAC4F,MAAMxF,KAAKC;QACxByF,MAAM9F,MAAM,CAACD,KAAK,GAAG;QACrB,OAAOK;IACT;IACAd,QAAQc,GAAG,EAAEC,MAAM;QACjB,IAAI,CAACA,QAAQA,SAAS;QAEtBA,UAAU;QACV,MAAMuF,OAAO7G,uDAAK,CAACO,MAAM,CAACc,KAAKC;QAC/ByF,MAAMxG,MAAM,CAACS,KAAK,GAAG;QACrB,OAAO6F;IACT;IACA7F,OAAO;AACT;AAEA,MAAMiG,QAAQC,CAAAA,OAAQ,IAAI3F,WAAW2F;AAErC,MAAMC,UAAUpG,MAAM;IACpBE,QAAQmG,MAAM,EAAE/F,GAAG,EAAEC,MAAM;QACzB,IAAI,CAACD,KAAKA,MAAM,IAAIE,WAAW4F,QAAQjG,cAAc,CAACkG;QACtD,IAAI,CAAC9F,QAAQA,SAAS;QACtB,MAAME,YAAYF;QAElB,MAAM+F,OAAOhH,oDAAkB,CAAC+G,OAAOC,IAAI;QAC3C/G,4DAAe,CAACe,KAAKgG,MAAM/F;QAC3BA,UAAU;QACV,IAAI8F,OAAOjD,IAAI,EAAE;YACf7D,4DAAe,CAACe,KAAK+F,OAAOjD,IAAI,CAACxC,MAAM,EAAEL;YACzCA,UAAU;YACVhB,mDAAM,CAAC8G,OAAOjD,IAAI,EAAE9C,KAAKC;YACzBA,UAAU8F,OAAOjD,IAAI,CAACxC,MAAM;QAC9B,OAAO;YACL,OAAQ0F;gBACN,wCAAwC;gBACxC,gCAAgC;gBAChC,KAAK;oBACH;wBACE,kCAAkC;wBAClC,MAAME,MAAMH,OAAOI,kBAAkB,IAAI;wBACzC,MAAMC,MAAML,OAAOM,MAAM,IAAI1H,6DAAW,CAACoH,OAAOpH,EAAE,EAAEiH;wBACpD,MAAMW,QAAQ5H,2DAAS,CAACoH,OAAOpH,EAAE,EAAEiH;wBACnC,MAAMY,QAAQC,KAAKC,IAAI,CAACR,MAAM;wBAC9BjH,4DAAe,CAACe,KAAKwG,QAAQ,GAAGvG;wBAChCA,UAAU;wBACVhB,4DAAe,CAACe,KAAKoG,KAAKnG;wBAC1BA,UAAU;wBACVD,GAAG,CAACC,SAAS,GAAGiG;wBAChBlG,GAAG,CAACC,SAAS,GAAG8F,OAAOY,iBAAiB,IAAI;wBAE5C1H,mDAAM,CAACsH,OAAOvG,KAAKC,QAAQ,GAAGuG;wBAC9BvG,UAAUuG;oBACZ;oBACA;gBACF,gCAAgC;gBAChC,2CAA2C;gBAC3C,KAAK;oBACH,IAAIT,OAAOa,OAAO,EAAE;wBAClB3H,4DAAe,CAACe,KAAK,GAAGC;wBACxBA,UAAU;wBACVhB,4DAAe,CAACe,KAAK+F,OAAOa,OAAO,EAAE3G;wBACrCA,UAAU;oBACZ,OAAO;wBACLhB,4DAAe,CAACe,KAAK,GAAGC;wBACxBA,UAAU;oBACZ;oBACA;gBACF,KAAK;oBACH;wBACE,MAAMS,MAAMqF,OAAOzF,MAAM,IAAI;wBAC7BrB,4DAAe,CAACe,KAAKU,KAAKT;wBAC1BA,UAAU;wBACVD,IAAI6G,IAAI,CAAC,GAAG5G,QAAQA,SAASS;wBAC7BT,UAAUS;oBACZ;oBACA;gBACF,kCAAkC;gBAClC,KAAK;oBACH;wBACE,MAAMoG,UAAUf,OAAOgB,IAAI,CAACzG,MAAM,GAAG;wBACrCrB,4DAAe,CAACe,KAAK8G,SAAS7G;wBAC9BA,UAAU;wBACV,KAAK,MAAMiF,OAAOa,OAAOgB,IAAI,CAAE;4BAC7B9H,4DAAe,CAACe,KAAKkF,KAAKjF;4BAC1BA,UAAU;wBACZ;oBACF;oBACA;gBACF;oBACE,MAAM,IAAIc,MAAM,CAAC,sBAAsB,EAAEgF,OAAOC,IAAI,CAAC,CAAC;YAC1D;QACF;QAEAF,QAAQlG,MAAM,CAACD,KAAK,GAAGM,SAASE;QAChC,OAAOH;IACT;IACAd,QAAQc,GAAG,EAAEC,MAAM;QACjB,IAAI,CAACA,QAAQA,SAAS;QACtB,MAAM8F,SAAS,CAAC;QAChBA,OAAOC,IAAI,GAAG/G,2DAAc,CAACe,KAAKC;QAClC8F,OAAOrE,IAAI,GAAG1C,sDAAoB,CAAC+G,OAAOC,IAAI;QAC9C/F,UAAU;QACV,MAAMS,MAAMzB,2DAAc,CAACe,KAAKC;QAChCA,UAAU;QACV8F,OAAOjD,IAAI,GAAG9C,IAAIiD,KAAK,CAAChD,QAAQA,SAASS;QACzC,OAAQqF,OAAOC,IAAI;YACjB,wCAAwC;YACxC,KAAK;gBACHD,OAAOM,MAAM,GAAGpH,2DAAc,CAACe,KAAKC;gBACpCA,UAAU;gBACV8F,OAAOI,kBAAkB,GAAGnG,GAAG,CAACC,SAAS;gBACzC8F,OAAOY,iBAAiB,GAAG3G,GAAG,CAACC,SAAS;gBACxC;oBACE,MAAM+G,SAAS,IAAI9G,WAAW,OAAQmG,MAAM,KAAK,IAAK,IAAI;oBAC1DpH,mDAAM,CAACe,KAAKgH,QAAQ,GAAG/G,QAAQA,SAASS,MAAM;oBAC9CqF,OAAOpH,EAAE,GAAGA,2DAAS,CAACqI;gBACxB;gBACA;YACF,4CAA4C;YAC5C,KAAK;gBACH,IAAItG,MAAM,GAAG;oBACXqF,OAAOa,OAAO,GAAG3H,2DAAc,CAACe,KAAKC;oBACrCA,UAAU;gBACZ;gBACA;YACF,KAAK;gBACH8F,OAAOgB,IAAI,GAAG,EAAE;gBAChB,IAAK,IAAItG,IAAI,GAAGA,IAAIC,KAAKD,KAAK,EAAG;oBAC/BsF,OAAOgB,IAAI,CAAC/F,IAAI,CAAC/B,2DAAc,CAACe,KAAKC;oBACrCA,UAAU;gBACZ;QAEJ;QAEA6F,QAAQ5G,MAAM,CAACS,KAAK,GAAGe,MAAM;QAC7B,OAAOqF;IACT;IACAlG,gBAAgBkG,MAAM;QACpB,IAAIA,OAAOjD,IAAI,EAAE;YACf,OAAOiD,OAAOjD,IAAI,CAACxC,MAAM,GAAG;QAC9B;QACA,MAAM0F,OAAOhH,oDAAkB,CAAC+G,OAAOC,IAAI;QAC3C,OAAQA;YACN,KAAK;gBACL;oBACE,MAAME,MAAMH,OAAOI,kBAAkB,IAAI;oBACzC,OAAOM,KAAKC,IAAI,CAACR,MAAM,KAAK;gBAC9B;YACA,KAAK;gBACH,OAAO,OAAQH,OAAOa,OAAO,KAAK,WAAY,IAAI;YACpD,KAAK;gBACH,OAAOb,OAAOzF,MAAM,GAAG;YACzB,KAAK;gBACH,OAAO,IAAKyF,OAAOgB,IAAI,CAACzG,MAAM,GAAG;QACrC;QACA,MAAM,IAAIS,MAAM,CAAC,sBAAsB,EAAEgF,OAAOC,IAAI,CAAC,CAAC;IACxD;AACF;AAEA,MAAMiB,OAAOvH,MAAM;IACjBE,QAAQsH,OAAO,EAAElH,GAAG,EAAEC,MAAM;QAC1B,IAAI,CAACD,KAAKA,MAAM,IAAIE,WAAW+G,KAAKpH,cAAc,CAACqH;QACnD,IAAI,CAACjH,QAAQA,SAAS;QACtB,MAAME,YAAYF;QAElB,MAAMkH,QAAQC,mBAAmBF,SAASpB;QAC1C7G,4DAAe,CAACe,KAAKmH,OAAOlH;QAC5BA,SAASoH,WAAWH,SAASpB,SAAS9F,KAAKC,SAAS;QAEpDgH,KAAKrH,MAAM,CAACD,KAAK,GAAGM,SAASE;QAC7B,OAAOH;IACT;IACAd,QAAQc,GAAG,EAAEC,MAAM;QACjB,IAAI,CAACA,QAAQA,SAAS;QACtB,MAAME,YAAYF;QAElB,MAAMiH,UAAU,EAAE;QAClB,IAAIC,QAAQlI,2DAAc,CAACe,KAAKC;QAChCA,UAAU;QACV,IAAIqH,IAAI;QACR,MAAOH,QAAQ,EAAG;YAChBD,OAAO,CAACI,IAAI,GAAGxB,QAAQ5G,MAAM,CAACc,KAAKC;YACnCA,UAAU6F,QAAQ5G,MAAM,CAACS,KAAK;YAC9BwH,SAASrB,QAAQ5G,MAAM,CAACS,KAAK;QAC/B;QACAsH,KAAK/H,MAAM,CAACS,KAAK,GAAGM,SAASE;QAC7B,OAAO+G;IACT;IACArH,gBAAgBqH,OAAO;QACrB,OAAO,IAAIE,mBAAmBF,WAAW,EAAE,EAAEpB;IAC/C;AACF;AAEA,MAAMyB,UAAU7H,MAAM;IACpBE,QAAQ4H,GAAG,EAAExH,GAAG,EAAEC,MAAM;QACtB,IAAI,CAACD,KAAKA,MAAM,IAAIE,WAAWqH,QAAQ1H,cAAc,CAAC2H;QACtD,IAAI,CAACvH,QAAQA,SAAS;QACtB,MAAME,YAAYF;QAElB,MAAMwH,UAAUD,IAAIA,GAAG;QACvB,IAAI,CAACvI,sDAAS,CAACwI,UAAU;YACvB,MAAM,IAAI1G,MAAM;QAClB;QAEAd,UAAU,EAAE,yBAAyB;;QACrChB,4DAAe,CAACe,KAAKwH,IAAI/F,KAAK,EAAExB;QAChCA,UAAU;QACVD,GAAG,CAACC,OAAO,GAAGsH,QAAQG,eAAe;QACrCzH,UAAU;QACVD,GAAG,CAACC,OAAO,GAAGuH,IAAIG,SAAS;QAC3B1H,UAAU;QACVhB,mDAAM,CAACwI,SAASzH,KAAKC,QAAQ,GAAGwH,QAAQnH,MAAM;QAC9CL,UAAUwH,QAAQnH,MAAM;QAExBiH,QAAQ3H,MAAM,CAACD,KAAK,GAAGM,SAASE;QAChClB,4DAAe,CAACe,KAAKuH,QAAQ3H,MAAM,CAACD,KAAK,GAAG,GAAGQ;QAC/C,OAAOH;IACT;IACAd,QAAQc,GAAG,EAAEC,MAAM;QACjB,IAAI,CAACA,QAAQA,SAAS;QACtB,MAAME,YAAYF;QAElB,MAAMuH,MAAM,CAAC;QACb,MAAMlH,SAASrB,2DAAc,CAACe,KAAKC;QACnCA,UAAU;QACVuH,IAAI/F,KAAK,GAAGxC,2DAAc,CAACe,KAAKC;QAChCA,UAAU;QACV,IAAID,GAAG,CAACC,OAAO,KAAKsH,QAAQG,eAAe,EAAE;YAC3C,MAAM,IAAI3G,MAAM;QAClB;QACAd,UAAU;QACVuH,IAAIG,SAAS,GAAG3H,GAAG,CAACC,OAAO;QAC3BA,UAAU;QACVuH,IAAIA,GAAG,GAAGxH,IAAIiD,KAAK,CAAChD,QAAQE,YAAYG,SAAS;QACjDL,UAAUuH,IAAIA,GAAG,CAAClH,MAAM;QACxBiH,QAAQrI,MAAM,CAACS,KAAK,GAAGM,SAASE;QAChC,OAAOqH;IACT;IACA3H,gBAAgB2H,GAAG;QACjB,OAAO,IAAIvI,yDAAY,CAACuI,IAAIA,GAAG;IACjC;AACF;AAEAD,QAAQG,eAAe,GAAG;AAC1BH,QAAQK,QAAQ,GAAG;AACnBL,QAAQM,iBAAiB,GAAG;AAE5B,MAAMC,SAASpI,MAAM;IACnBE,QAAQmI,GAAG,EAAE/H,GAAG,EAAEC,MAAM;QACtB,IAAI,CAACD,KAAKA,MAAM,IAAIE,WAAW4H,OAAOjI,cAAc,CAACkI;QACrD,IAAI,CAAC9H,QAAQA,SAAS;QACtB,MAAME,YAAYF;QAElB,MAAM+H,YAAYD,IAAIC,SAAS;QAC/B,IAAI,CAAC/I,sDAAS,CAAC+I,YAAY;YACzB,MAAM,IAAIjH,MAAM;QAClB;QAEAd,UAAU,EAAE,yBAAyB;;QACrChB,4DAAe,CAACe,KAAKpB,8CAAY,CAACmJ,IAAIG,WAAW,GAAGjI;QACpDA,UAAU;QACVD,GAAG,CAACC,OAAO,GAAG8H,IAAIJ,SAAS;QAC3B1H,UAAU;QACVD,GAAG,CAACC,OAAO,GAAG8H,IAAII,MAAM;QACxBlI,UAAU;QACVhB,4DAAe,CAACe,KAAK+H,IAAIK,WAAW,EAAEnI;QACtCA,UAAU;QACVhB,4DAAe,CAACe,KAAK+H,IAAIM,UAAU,EAAEpI;QACrCA,UAAU;QACVhB,4DAAe,CAACe,KAAK+H,IAAIO,SAAS,EAAErI;QACpCA,UAAU;QACVhB,4DAAe,CAACe,KAAK+H,IAAIQ,MAAM,EAAEtI;QACjCA,UAAU;QACVH,KAAKF,MAAM,CAACmI,IAAIS,WAAW,EAAExI,KAAKC;QAClCA,UAAUH,KAAKF,MAAM,CAACD,KAAK;QAC3BV,mDAAM,CAAC+I,WAAWhI,KAAKC,QAAQ,GAAG+H,UAAU1H,MAAM;QAClDL,UAAU+H,UAAU1H,MAAM;QAE1BwH,OAAOlI,MAAM,CAACD,KAAK,GAAGM,SAASE;QAC/BlB,4DAAe,CAACe,KAAK8H,OAAOlI,MAAM,CAACD,KAAK,GAAG,GAAGQ;QAC9C,OAAOH;IACT;IACAd,QAAQc,GAAG,EAAEC,MAAM;QACjB,IAAI,CAACA,QAAQA,SAAS;QACtB,MAAME,YAAYF;QAElB,MAAM8H,MAAM,CAAC;QACb,MAAMzH,SAASrB,2DAAc,CAACe,KAAKC;QACnCA,UAAU;QACV8H,IAAIG,WAAW,GAAGtJ,gDAAc,CAACK,2DAAc,CAACe,KAAKC;QACrDA,UAAU;QACV8H,IAAIJ,SAAS,GAAG3H,GAAG,CAACC,OAAO;QAC3BA,UAAU;QACV8H,IAAII,MAAM,GAAGnI,GAAG,CAACC,OAAO;QACxBA,UAAU;QACV8H,IAAIK,WAAW,GAAGnJ,2DAAc,CAACe,KAAKC;QACtCA,UAAU;QACV8H,IAAIM,UAAU,GAAGpJ,2DAAc,CAACe,KAAKC;QACrCA,UAAU;QACV8H,IAAIO,SAAS,GAAGrJ,2DAAc,CAACe,KAAKC;QACpCA,UAAU;QACV8H,IAAIQ,MAAM,GAAGtJ,2DAAc,CAACe,KAAKC;QACjCA,UAAU;QACV8H,IAAIS,WAAW,GAAG1I,KAAKZ,MAAM,CAACc,KAAKC;QACnCA,UAAUH,KAAKZ,MAAM,CAACS,KAAK;QAC3BoI,IAAIC,SAAS,GAAGhI,IAAIiD,KAAK,CAAChD,QAAQE,YAAYG,SAAS;QACvDL,UAAU8H,IAAIC,SAAS,CAAC1H,MAAM;QAC9BwH,OAAO5I,MAAM,CAACS,KAAK,GAAGM,SAASE;QAC/B,OAAO4H;IACT;IACAlI,gBAAgBkI,GAAG;QACjB,OAAO,KACLjI,KAAKD,cAAc,CAACkI,IAAIS,WAAW,IACnCvJ,yDAAY,CAAC8I,IAAIC,SAAS;IAC9B;AACF;AACA,MAAMS,MAAM/I,MAAM;IAChBE,QAAQkD,IAAI,EAAE9C,GAAG,EAAEC,MAAM;QACvB,IAAI,CAACD,KAAKA,MAAM,IAAIE,WAAWuI,IAAI5I,cAAc,CAACiD;QAClD,IAAI,CAAC7C,QAAQA,SAAS;QACtB,MAAME,YAAYF;QAElBA,UAAU,EAAE,yBAAyB;;QACrCH,KAAKF,MAAM,CAACkD,KAAK4F,IAAI,IAAI,KAAK1I,KAAKC;QACnCA,UAAUH,KAAKF,MAAM,CAACD,KAAK;QAC3BG,KAAKF,MAAM,CAACkD,KAAK6F,GAAG,IAAI,KAAK3I,KAAKC;QAClCA,UAAUH,KAAKF,MAAM,CAACD,KAAK;QAC3B8I,IAAI7I,MAAM,CAACD,KAAK,GAAGM,SAASE;QAC5BlB,4DAAe,CAACe,KAAKyI,IAAI7I,MAAM,CAACD,KAAK,GAAG,GAAGQ;QAC3C,OAAOH;IACT;IACAd,QAAQc,GAAG,EAAEC,MAAM;QACjB,IAAI,CAACA,QAAQA,SAAS;QACtB,MAAME,YAAYF;QAElB,MAAM6C,OAAO,CAAC;QACd7C,UAAU;QACV6C,KAAK4F,IAAI,GAAG5I,KAAKZ,MAAM,CAACc,KAAKC,WAAW;QACxCA,UAAUH,KAAKZ,MAAM,CAACS,KAAK;QAC3BmD,KAAK6F,GAAG,GAAG7I,KAAKZ,MAAM,CAACc,KAAKC,WAAW;QACvCA,UAAUH,KAAKZ,MAAM,CAACS,KAAK;QAC3B8I,IAAIvJ,MAAM,CAACS,KAAK,GAAGM,SAASE;QAC5B,OAAO2C;IACT;IACAjD,gBAAgBiD,IAAI;QAClB,OAAO,IAAIhD,KAAKD,cAAc,CAACiD,KAAK4F,IAAI,IAAI,OAAO5I,KAAKD,cAAc,CAACiD,KAAK6F,GAAG,IAAI;IACrF;AACF;AAEA,MAAMC,aAAalJ,MAAM;IACvBE,QAAQiJ,QAAQ,EAAE7I,GAAG,EAAEC,MAAM;QAC3B,IAAI,CAACD,KAAKA,MAAM,IAAIE,WAAW0I,WAAW/I,cAAc,CAACgJ;QACzD,IAAI,CAAC5I,QAAQA,SAAS;QACtB,MAAME,YAAYF;QAElB,MAAM6I,gBAAgB,EAAE;QACxB,IAAK,IAAIrI,IAAI,GAAGA,IAAIoI,SAASvI,MAAM,EAAEG,IAAK;YACxC,MAAMsI,SAASnK,8CAAY,CAACiK,QAAQ,CAACpI,EAAE;YACvC,IAAIqI,aAAa,CAACC,UAAU,EAAE,KAAKC,WAAW;gBAC5CF,aAAa,CAACC,UAAU,EAAE,GAAG,EAAE;YACjC;YACAD,aAAa,CAACC,UAAU,EAAE,CAAC,UAAW,IAAK,KAAK,IAAI,KAAM,IAAKA,CAAAA,SAAS,GAAE;QAC5E;QAEA,IAAK,IAAItI,IAAI,GAAGA,IAAIqI,cAAcxI,MAAM,EAAEG,IAAK;YAC7C,IAAIqI,aAAa,CAACrI,EAAE,KAAKuI,WAAW;gBAClC,MAAMC,YAAYhK,mDAAM,CAAC6J,aAAa,CAACrI,EAAE;gBACzCT,GAAG,CAACC,OAAO,GAAGQ;gBACdR,UAAU;gBACVD,GAAG,CAACC,OAAO,GAAGgJ,UAAU3I,MAAM;gBAC9BL,UAAU;gBACVhB,mDAAM,CAACgK,WAAWjJ,KAAKC,QAAQ,GAAGgJ,UAAU3I,MAAM;gBAClDL,UAAUgJ,UAAU3I,MAAM;YAC5B;QACF;QAEAsI,WAAWhJ,MAAM,CAACD,KAAK,GAAGM,SAASE;QACnC,OAAOH;IACT;IACAd,QAAQc,GAAG,EAAEC,MAAM,EAAEK,MAAM;QACzB,IAAI,CAACL,QAAQA,SAAS;QACtB,MAAME,YAAYF;QAElB,MAAM4I,WAAW,EAAE;QACnB,MAAO5I,SAASE,YAAYG,OAAQ;YAClC,MAAM4I,SAASlJ,GAAG,CAACC,OAAO;YAC1BA,UAAU;YACV,MAAMkJ,eAAenJ,GAAG,CAACC,OAAO;YAChCA,UAAU;YACV,IAAK,IAAIQ,IAAI,GAAGA,IAAI0I,cAAc1I,IAAK;gBACrC,MAAMxB,IAAIe,GAAG,CAACC,SAASQ,EAAE;gBACzB,IAAK,IAAI2I,IAAI,GAAGA,IAAI,GAAGA,IAAK;oBAC1B,IAAInK,IAAK,KAAM,IAAImK,GAAK;wBACtB,MAAML,SAASnK,gDAAc,CAAC,UAAW,IAAM6B,KAAK,IAAK2I;wBACzDP,SAAS7H,IAAI,CAAC+H;oBAChB;gBACF;YACF;YACA9I,UAAUkJ;QACZ;QAEAP,WAAW1J,MAAM,CAACS,KAAK,GAAGM,SAASE;QACnC,OAAO0I;IACT;IACAhJ,gBAAgBgJ,QAAQ;QACtB,MAAMQ,UAAU,EAAE;QAClB,IAAK,IAAI5I,IAAI,GAAGA,IAAIoI,SAASvI,MAAM,EAAEG,IAAK;YACxC,MAAMsI,SAASnK,8CAAY,CAACiK,QAAQ,CAACpI,EAAE;YACvC4I,OAAO,CAACN,UAAU,EAAE,GAAGtC,KAAK6C,GAAG,CAACD,OAAO,CAACN,UAAU,EAAE,IAAI,GAAGA,SAAS;QACtE;QAEA,IAAIrI,MAAM;QACV,IAAK,IAAID,IAAI,GAAGA,IAAI4I,QAAQ/I,MAAM,EAAEG,IAAK;YACvC,IAAI4I,OAAO,CAAC5I,EAAE,KAAKuI,WAAW;gBAC5BtI,OAAO,IAAI+F,KAAKC,IAAI,CAAC,CAAC2C,OAAO,CAAC5I,EAAE,GAAG,KAAK;YAC1C;QACF;QAEA,OAAOC;IACT;AACF;AAEA,MAAM6I,QAAQ7J,MAAM;IAClBE,QAAQ4J,MAAM,EAAExJ,GAAG,EAAEC,MAAM;QACzB,IAAI,CAACD,KAAKA,MAAM,IAAIE,WAAWqJ,MAAM1J,cAAc,CAAC2J;QACpD,IAAI,CAACvJ,QAAQA,SAAS;QACtB,MAAME,YAAYF;QAElBA,UAAU,EAAE,yBAAyB;;QACrCH,KAAKF,MAAM,CAAC4J,OAAOC,UAAU,EAAEzJ,KAAKC;QACpCA,UAAUH,KAAKF,MAAM,CAACD,KAAK;QAC3BiJ,WAAWhJ,MAAM,CAAC4J,OAAOE,OAAO,EAAE1J,KAAKC;QACvCA,UAAU2I,WAAWhJ,MAAM,CAACD,KAAK;QAEjC4J,MAAM3J,MAAM,CAACD,KAAK,GAAGM,SAASE;QAC9BlB,4DAAe,CAACe,KAAKuJ,MAAM3J,MAAM,CAACD,KAAK,GAAG,GAAGQ;QAC7C,OAAOH;IACT;IACAd,QAAQc,GAAG,EAAEC,MAAM;QACjB,IAAI,CAACA,QAAQA,SAAS;QACtB,MAAME,YAAYF;QAElB,MAAMuJ,SAAS,CAAC;QAChB,MAAMlJ,SAASrB,2DAAc,CAACe,KAAKC;QACnCA,UAAU;QACVuJ,OAAOC,UAAU,GAAG3J,KAAKZ,MAAM,CAACc,KAAKC;QACrCA,UAAUH,KAAKZ,MAAM,CAACS,KAAK;QAC3B6J,OAAOE,OAAO,GAAGd,WAAW1J,MAAM,CAACc,KAAKC,QAAQK,SAAUL,CAAAA,SAASE,SAAQ;QAC3EF,UAAU2I,WAAW1J,MAAM,CAACS,KAAK;QAEjC4J,MAAMrK,MAAM,CAACS,KAAK,GAAGM,SAASE;QAC9B,OAAOqJ;IACT;IACA3J,gBAAgB2J,MAAM;QACpB,OAAO,IACL1J,KAAKD,cAAc,CAAC2J,OAAOC,UAAU,IACrCb,WAAW/I,cAAc,CAAC2J,OAAOE,OAAO;IAC5C;AACF;AAEA,MAAMC,SAASjK,MAAM;IACnBE,QAAQ4J,MAAM,EAAExJ,GAAG,EAAEC,MAAM;QACzB,IAAI,CAACD,KAAKA,MAAM,IAAIE,WAAWyJ,OAAO9J,cAAc,CAAC2J;QACrD,IAAI,CAACvJ,QAAQA,SAAS;QACtB,MAAME,YAAYF;QAElB,MAAM2J,OAAOJ,OAAOI,IAAI;QACxB,IAAI,CAAC3K,sDAAS,CAAC2K,OAAO;YACpB,MAAM,IAAI7I,MAAM;QAClB;QAEA,MAAM0I,aAAaD,OAAOC,UAAU;QACpC,IAAI,CAACxK,sDAAS,CAACwK,aAAa;YAC1B,MAAM,IAAI1I,MAAM;QAClB;QAEAd,UAAU,EAAE,yBAAyB;;QACrCD,GAAG,CAACC,OAAO,GAAGuJ,OAAO7B,SAAS;QAC9B1H,UAAU;QACVD,GAAG,CAACC,OAAO,GAAGuJ,OAAO/H,KAAK;QAC1BxB,UAAU;QACVhB,4DAAe,CAACe,KAAKwJ,OAAOK,UAAU,EAAE5J;QACxCA,UAAU;QACVD,GAAG,CAACC,OAAO,GAAG2J,KAAKtJ,MAAM;QACzBL,UAAU;QACVhB,mDAAM,CAAC2K,MAAM5J,KAAKC,QAAQ,GAAG2J,KAAKtJ,MAAM;QACxCL,UAAU2J,KAAKtJ,MAAM;QACrBN,GAAG,CAACC,OAAO,GAAGwJ,WAAWnJ,MAAM;QAC/BL,UAAU;QACVhB,mDAAM,CAACwK,YAAYzJ,KAAKC,QAAQ,GAAGwJ,WAAWnJ,MAAM;QACpDL,UAAUwJ,WAAWnJ,MAAM;QAC3BsI,WAAWhJ,MAAM,CAAC4J,OAAOE,OAAO,EAAE1J,KAAKC;QACvCA,UAAU2I,WAAWhJ,MAAM,CAACD,KAAK;QAEjCgK,OAAO/J,MAAM,CAACD,KAAK,GAAGM,SAASE;QAC/BlB,4DAAe,CAACe,KAAK2J,OAAO/J,MAAM,CAACD,KAAK,GAAG,GAAGQ;QAC9C,OAAOH;IACT;IACAd,QAAQc,GAAG,EAAEC,MAAM;QACjB,IAAI,CAACA,QAAQA,SAAS;QACtB,MAAME,YAAYF;QAElB,MAAMuJ,SAAS,CAAC;QAChB,MAAMlJ,SAASrB,2DAAc,CAACe,KAAKC;QACnCA,UAAU;QACVuJ,OAAO7B,SAAS,GAAG3H,GAAG,CAACC,OAAO;QAC9BA,UAAU;QACVuJ,OAAO/H,KAAK,GAAGzB,GAAG,CAACC,OAAO;QAC1BA,UAAU;QACVuJ,OAAOK,UAAU,GAAG5K,2DAAc,CAACe,KAAKC;QACxCA,UAAU;QACV,MAAM6J,aAAa9J,GAAG,CAACC,OAAO;QAC9BA,UAAU;QACVuJ,OAAOI,IAAI,GAAG5J,IAAIiD,KAAK,CAAChD,QAAQA,SAAS6J;QACzC7J,UAAU6J;QACV,MAAMC,aAAa/J,GAAG,CAACC,OAAO;QAC9BA,UAAU;QACVuJ,OAAOC,UAAU,GAAGzJ,IAAIiD,KAAK,CAAChD,QAAQA,SAAS8J;QAC/C9J,UAAU8J;QACVP,OAAOE,OAAO,GAAGd,WAAW1J,MAAM,CAACc,KAAKC,QAAQK,SAAUL,CAAAA,SAASE,SAAQ;QAC3EF,UAAU2I,WAAW1J,MAAM,CAACS,KAAK;QAEjCgK,OAAOzK,MAAM,CAACS,KAAK,GAAGM,SAASE;QAC/B,OAAOqJ;IACT;IACA3J,gBAAgB2J,MAAM;QACpB,OAAO,IACLA,OAAOI,IAAI,CAACtJ,MAAM,GAClBkJ,OAAOC,UAAU,CAACnJ,MAAM,GACxBsI,WAAW/I,cAAc,CAAC2J,OAAOE,OAAO;IAC5C;AACF;AAEA,MAAMM,MAAMtK,MAAM;IAChBE,QAAQqK,MAAM,EAAEjK,GAAG,EAAEC,MAAM;QACzB,IAAI,CAACD,KAAKA,MAAM,IAAIE,WAAW8J,IAAInK,cAAc,CAACoK;QAClD,IAAI,CAAChK,QAAQA,SAAS;QACtB,MAAME,YAAYF;QAElB,MAAMiK,aAAaD,OAAOA,MAAM;QAChC,IAAI,CAAChL,sDAAS,CAACiL,aAAa;YAC1B,MAAM,IAAInJ,MAAM;QAClB;QAEAd,UAAU,EAAE,yBAAyB;;QACrChB,4DAAe,CAACe,KAAKiK,OAAO1B,MAAM,EAAEtI;QACpCA,UAAU;QACVD,GAAG,CAACC,OAAO,GAAGgK,OAAOtC,SAAS;QAC9B1H,UAAU;QACVD,GAAG,CAACC,OAAO,GAAGgK,OAAOE,UAAU;QAC/BlK,UAAU;QACVhB,mDAAM,CAACiL,YAAYlK,KAAKC,QAAQ,GAAGiK,WAAW5J,MAAM;QACpDL,UAAUiK,WAAW5J,MAAM;QAE3B0J,IAAIpK,MAAM,CAACD,KAAK,GAAGM,SAASE;QAC5BlB,4DAAe,CAACe,KAAKgK,IAAIpK,MAAM,CAACD,KAAK,GAAG,GAAGQ;QAC3C,OAAOH;IACT;IACAd,QAAQc,GAAG,EAAEC,MAAM;QACjB,IAAI,CAACA,QAAQA,SAAS;QACtB,MAAME,YAAYF;QAElB,MAAMgK,SAAS,CAAC;QAChB,MAAM3J,SAASrB,2DAAc,CAACe,KAAKC;QACnCA,UAAU;QACVgK,OAAO1B,MAAM,GAAGtJ,2DAAc,CAACe,KAAKC;QACpCA,UAAU;QACVgK,OAAOtC,SAAS,GAAG3H,GAAG,CAACC,OAAO;QAC9BA,UAAU;QACVgK,OAAOE,UAAU,GAAGnK,GAAG,CAACC,OAAO;QAC/BA,UAAU;QACVgK,OAAOA,MAAM,GAAGjK,IAAIiD,KAAK,CAAChD,QAAQE,YAAYG,SAAS;QACvDL,UAAUgK,OAAOA,MAAM,CAAC3J,MAAM;QAC9B0J,IAAI9K,MAAM,CAACS,KAAK,GAAGM,SAASE;QAC5B,OAAO8J;IACT;IACApK,gBAAgBoK,MAAM;QACpB,OAAO,IAAIhL,yDAAY,CAACgL,OAAOA,MAAM;IACvC;AACF;AAEA,SAASG,KAAM1I,IAAI;IACjB,OAAQA,KAAK2I,WAAW;QACtB,KAAK;YAAK,OAAO9E;QACjB,KAAK;YAAO,OAAOd;QACnB,KAAK;YAAS,OAAOA;QACrB,KAAK;YAAS,OAAOA;QACrB,KAAK;YAAO,OAAOX;QACnB,KAAK;YAAQ,OAAOO;QACpB,KAAK;YAAQ,OAAOqB;QACpB,KAAK;YAAO,OAAOhB;QACnB,KAAK;YAAS,OAAOJ;QACrB,KAAK;YAAO,OAAOS;QACnB,KAAK;YAAM,OAAO7B;QAClB,KAAK;YAAO,OAAOE;QACnB,KAAK;YAAM,OAAOgC;QAClB,KAAK;YAAO,OAAO6B;QACnB,KAAK;YAAU,OAAOM;QACtB,KAAK;YAAS,OAAOO;QACrB,KAAK;YAAM,OAAOW;QAClB,KAAK;YAAQ,OAAOc;QACpB,KAAK;YAAS,OAAOI;QACrB,KAAK;YAAM,OAAOK;IACpB;IACA,OAAOnH;AACT;AAEO,MAAMyH,SAAS5K,MAAM;IAC1BE,QAAQ2K,CAAC,EAAEvK,GAAG,EAAEC,MAAM;QACpB,IAAI,CAACD,KAAKA,MAAM,IAAIE,WAAWoK,OAAOzK,cAAc,CAAC0K;QACrD,IAAI,CAACtK,QAAQA,SAAS;QAEtB,MAAME,YAAYF;QAElBH,KAAKF,MAAM,CAAC2K,EAAEzK,IAAI,EAAEE,KAAKC;QACzBA,UAAUH,KAAKF,MAAM,CAACD,KAAK;QAE3BV,4DAAe,CAACe,KAAKpB,8CAAY,CAAC2L,EAAE7I,IAAI,GAAGzB;QAE3C,IAAIsK,EAAE7I,IAAI,CAAC2I,WAAW,OAAO,OAAO;YAClC,IAAIE,EAAEzK,IAAI,KAAK,KAAK;gBAClB,MAAM,IAAIiB,MAAM;YAClB;YACA9B,4DAAe,CAACe,KAAKuK,EAAEC,cAAc,IAAI,MAAMvK,SAAS;YACxDD,GAAG,CAACC,SAAS,EAAE,GAAGsK,EAAEE,aAAa,IAAI;YACrCzK,GAAG,CAACC,SAAS,EAAE,GAAGsK,EAAEG,WAAW,IAAI;YACnCzL,4DAAe,CAACe,KAAKuK,EAAE9I,KAAK,IAAI,GAAGxB,SAAS;YAE5CA,UAAU;YACVgH,KAAKrH,MAAM,CAAC2K,EAAErD,OAAO,IAAI,EAAE,EAAElH,KAAKC;YAClCA,UAAUgH,KAAKrH,MAAM,CAACD,KAAK;QAC7B,OAAO;YACL,IAAIgL,QAAQ5L,iDAAe,CAACwL,EAAEM,KAAK,KAAK7B,YAAY,OAAOuB,EAAEM,KAAK;YAClE,IAAIN,EAAEO,KAAK,EAAEH,SAASrL,WAAW,4CAA4C;;YAC7EL,4DAAe,CAACe,KAAK2K,OAAO1K,SAAS;YACrChB,4DAAe,CAACe,KAAKuK,EAAEQ,GAAG,IAAI,GAAG9K,SAAS;YAE1CA,UAAU;YACV,MAAM+K,MAAMZ,KAAKG,EAAE7I,IAAI;YACvBsJ,IAAIpL,MAAM,CAAC2K,EAAEzH,IAAI,EAAE9C,KAAKC;YACxBA,UAAU+K,IAAIpL,MAAM,CAACD,KAAK;QAC5B;QAEA2K,OAAO1K,MAAM,CAACD,KAAK,GAAGM,SAASE;QAC/B,OAAOH;IACT;IACAd,QAAQc,GAAG,EAAEC,MAAM;QACjB,IAAI,CAACA,QAAQA,SAAS;QAEtB,MAAMsK,IAAI,CAAC;QACX,MAAMpK,YAAYF;QAElBsK,EAAEzK,IAAI,GAAGA,KAAKZ,MAAM,CAACc,KAAKC;QAC1BA,UAAUH,KAAKZ,MAAM,CAACS,KAAK;QAC3B4K,EAAE7I,IAAI,GAAG9C,gDAAc,CAACK,2DAAc,CAACe,KAAKC;QAC5C,IAAIsK,EAAE7I,IAAI,KAAK,OAAO;YACpB6I,EAAEC,cAAc,GAAGvL,2DAAc,CAACe,KAAKC,SAAS;YAChDsK,EAAEE,aAAa,GAAGzK,GAAG,CAACC,SAAS,EAAE;YACjCsK,EAAEG,WAAW,GAAG1K,GAAG,CAACC,SAAS,EAAE;YAC/BsK,EAAE9I,KAAK,GAAGxC,2DAAc,CAACe,KAAKC,SAAS;YACvCsK,EAAEU,OAAO,GAAG,CAAC,EAAGxJ,KAAK,IAAI,KAAM,GAAE,MAAO;YACxC8I,EAAErD,OAAO,GAAGD,KAAK/H,MAAM,CAACc,KAAKC,SAAS;YACtCA,UAAU,IAAIgH,KAAK/H,MAAM,CAACS,KAAK;QACjC,OAAO;YACL,MAAMgL,QAAQ1L,2DAAc,CAACe,KAAKC,SAAS;YAC3CsK,EAAEQ,GAAG,GAAG9L,2DAAc,CAACe,KAAKC,SAAS;YAErCsK,EAAEM,KAAK,GAAG9L,kDAAgB,CAAC4L,QAAQpL;YACnCgL,EAAEO,KAAK,GAAG,CAAC,CAAEH,CAAAA,QAAQrL,UAAS;YAE9B,MAAM0L,MAAMZ,KAAKG,EAAE7I,IAAI;YACvB6I,EAAEzH,IAAI,GAAGkI,IAAI9L,MAAM,CAACc,KAAKC,SAAS;YAClCA,UAAU,IAAI+K,IAAI9L,MAAM,CAACS,KAAK;QAChC;QAEA2K,OAAOpL,MAAM,CAACS,KAAK,GAAGM,SAASE;QAC/B,OAAOoK;IACT;IACA1K,gBAAgB0K,CAAC;QACf,MAAMzH,OAAO,EAAGA,IAAI,KAAK,QAAQyH,EAAEzH,IAAI,KAAKkG,YAAauB,EAAEzH,IAAI,GAAGyH,EAAErD,OAAO;QAC3E,OAAOpH,KAAKD,cAAc,CAAC0K,EAAEzK,IAAI,IAAI,IAAIsK,KAAKG,EAAE7I,IAAI,EAAE7B,cAAc,CAACiD;IACvE;AACF,GAAE;AAEK,MAAMoI,WAAWxL,MAAM;IAC5BE,QAAQuL,CAAC,EAAEnL,GAAG,EAAEC,MAAM;QACpB,IAAI,CAACD,KAAKA,MAAM,IAAIE,WAAWgL,SAASrL,cAAc,CAACsL;QACvD,IAAI,CAAClL,QAAQA,SAAS;QAEtB,MAAME,YAAYF;QAElBH,KAAKF,MAAM,CAACuL,EAAErL,IAAI,EAAEE,KAAKC;QACzBA,UAAUH,KAAKF,MAAM,CAACD,KAAK;QAE3BV,4DAAe,CAACe,KAAKpB,8CAAY,CAACuM,EAAEzJ,IAAI,GAAGzB;QAC3CA,UAAU;QAEVhB,4DAAe,CAACe,KAAKjB,iDAAe,CAACoM,EAAEN,KAAK,KAAK7B,YAAY,OAAOmC,EAAEN,KAAK,GAAG5K;QAC9EA,UAAU;QAEViL,SAAStL,MAAM,CAACD,KAAK,GAAGM,SAASE;QACjC,OAAOgL;IACT;IACAjM,QAAQc,GAAG,EAAEC,MAAM;QACjB,IAAI,CAACA,QAAQA,SAAS;QAEtB,MAAME,YAAYF;QAClB,MAAMkL,IAAI,CAAC;QAEXA,EAAErL,IAAI,GAAGA,KAAKZ,MAAM,CAACc,KAAKC;QAC1BA,UAAUH,KAAKZ,MAAM,CAACS,KAAK;QAE3BwL,EAAEzJ,IAAI,GAAG9C,gDAAc,CAACK,2DAAc,CAACe,KAAKC;QAC5CA,UAAU;QAEVkL,EAAEN,KAAK,GAAG9L,kDAAgB,CAACE,2DAAc,CAACe,KAAKC;QAC/CA,UAAU;QAEV,MAAMmL,KAAK,CAAC,CAAED,CAAAA,EAAEN,KAAK,GAAGrL,OAAM;QAC9B,IAAI4L,IAAID,EAAEN,KAAK,IAAIpL;QAEnByL,SAAShM,MAAM,CAACS,KAAK,GAAGM,SAASE;QACjC,OAAOgL;IACT;IACAtL,gBAAgBsL,CAAC;QACf,OAAOrL,KAAKD,cAAc,CAACsL,EAAErL,IAAI,IAAI;IACvC;AACF,GAAE;AA0BD;AAEM,MAAM0M,uBAAuB,KAAK,GAAE;AACpC,MAAMC,qBAAqB,KAAK,EAAC;AACjC,MAAMC,oBAAoB,KAAK,EAAC;AAChC,MAAMC,sBAAsB,KAAK,EAAC;AAClC,MAAMC,iBAAiB,KAAK,EAAC;AAC7B,MAAMC,oBAAoB,KAAK,EAAC;AAChC,MAAMC,YAAY,KAAK,GAAE;AAEzB,MAAMC,SAAS;IACpBnN,QAAQ,SAAUoN,MAAM,EAAEhN,GAAG,EAAEC,MAAM;QACnC,MAAMgN,WAAW,CAACjN;QAElB,IAAIiN,UAAUjN,MAAM,IAAIE,WAAWL,eAAemN;QAClD,IAAI,CAAC/M,QAAQA,SAAS;QAEtB,MAAME,YAAYF;QAElB,IAAI,CAAC+M,OAAOnL,SAAS,EAAEmL,OAAOnL,SAAS,GAAG,EAAE;QAC5C,IAAI,CAACmL,OAAOlL,OAAO,EAAEkL,OAAOlL,OAAO,GAAG,EAAE;QACxC,IAAI,CAACkL,OAAOjL,WAAW,EAAEiL,OAAOjL,WAAW,GAAG,EAAE;QAChD,IAAI,CAACiL,OAAOhL,WAAW,EAAEgL,OAAOhL,WAAW,GAAG,EAAE;QAEhDT,OAAO3B,MAAM,CAACoN,QAAQhN,KAAKC;QAC3BA,UAAUsB,OAAO3B,MAAM,CAACD,KAAK;QAE7BM,SAASoH,WAAW2F,OAAOnL,SAAS,EAAEqJ,UAAUlL,KAAKC;QACrDA,SAASoH,WAAW2F,OAAOlL,OAAO,EAAEwI,QAAQtK,KAAKC;QACjDA,SAASoH,WAAW2F,OAAOjL,WAAW,EAAEuI,QAAQtK,KAAKC;QACrDA,SAASoH,WAAW2F,OAAOhL,WAAW,EAAEsI,QAAQtK,KAAKC;QAErD8M,OAAOnN,MAAM,CAACD,KAAK,GAAGM,SAASE;QAE/B,4BAA4B;QAC5B,IAAI8M,YAAYrN,OAAOD,KAAK,KAAKK,IAAIM,MAAM,EAAE;YAC3C,OAAON,IAAIiD,KAAK,CAAC,GAAGrD,OAAOD,KAAK;QAClC;QAEA,OAAOK;IACT;IACAd,QAAQ,SAAUc,GAAG,EAAEC,MAAM;QAC3B,IAAI,CAACA,QAAQA,SAAS;QAEtB,MAAME,YAAYF;QAClB,MAAM+M,SAASzL,OAAOrC,MAAM,CAACc,KAAKC;QAClCA,UAAUsB,OAAOrC,MAAM,CAACS,KAAK;QAE7BM,SAASiN,WAAWF,OAAOnL,SAAS,EAAEqJ,UAAUlL,KAAKC;QACrDA,SAASiN,WAAWF,OAAOlL,OAAO,EAAEwI,QAAQtK,KAAKC;QACjDA,SAASiN,WAAWF,OAAOjL,WAAW,EAAEuI,QAAQtK,KAAKC;QACrDA,SAASiN,WAAWF,OAAOhL,WAAW,EAAEsI,QAAQtK,KAAKC;QAErD8M,OAAO7N,MAAM,CAACS,KAAK,GAAGM,SAASE;QAE/B,OAAO6M;IACT;IACAnN,gBAAgB,SAAUmN,MAAM;QAC9B,OAAOzL,OAAO1B,cAAc,CAACmN,UAC3B5F,mBAAmB4F,OAAOnL,SAAS,IAAI,EAAE,EAAEqJ,YAC3C9D,mBAAmB4F,OAAOlL,OAAO,IAAI,EAAE,EAAEwI,UACzClD,mBAAmB4F,OAAOjL,WAAW,IAAI,EAAE,EAAEuI,UAC7ClD,mBAAmB4F,OAAOhL,WAAW,IAAI,EAAE,EAAEsI;IACjD;AACF,EAAC;AACDyC,OAAOnN,MAAM,CAACD,KAAK,GAAG;AACtBoN,OAAO7N,MAAM,CAACS,KAAK,GAAG;AAEtB,SAASwN,eAAgBC,KAAK,EAAE1L,IAAI;IAClC,IAAI0L,MAAMvL,SAAS,EAAE;QACnB,MAAM,IAAId,MAAM;IAClB;IACA,MAAMsM,YAAYC,OAAOC,MAAM,CAAC;QAC9B7L;IACF,GAAG0L;IACH,IAAIC,UAAUnC,QAAQ,EAAE;QACtBmC,UAAUxL,SAAS,GAAG;YAACwL,UAAUnC,QAAQ;SAAC;QAC1C,OAAOmC,UAAUnC,QAAQ;IAC3B;IACA,OAAOmC;AACT;AAEO,MAAMG,QAAQ;IACnB5N,QAAQ,SAAUoN,MAAM,EAAEhN,GAAG,EAAEC,MAAM;QACnCD,MAAM+M,OAAOnN,MAAM,CAACuN,eAAeH,QAAQ,UAAUhN,KAAKC;QAC1DuN,MAAM5N,MAAM,CAACD,KAAK,GAAGoN,OAAOnN,MAAM,CAACD,KAAK;QACxC,OAAOK;IACT;IACAd,QAAQ,SAAUc,GAAG,EAAEC,MAAM;QAC3B,MAAMwN,MAAMV,OAAO7N,MAAM,CAACc,KAAKC;QAC/BuN,MAAMtO,MAAM,CAACS,KAAK,GAAGoN,OAAO7N,MAAM,CAACS,KAAK;QACxC,IAAI8N,IAAI5L,SAAS,EAAE;YACjB4L,IAAIvC,QAAQ,GAAGuC,IAAI5L,SAAS,CAAC,EAAE;YAC/B,OAAO4L,IAAI5L,SAAS;QACtB;QACA,OAAO4L;IACT;IACA5N,gBAAgB,SAAUmN,MAAM;QAC9B,OAAOD,OAAOlN,cAAc,CAACsN,eAAeH,QAAQ;IACtD;AACF,EAAC;AACDQ,MAAM5N,MAAM,CAACD,KAAK,GAAG;AACrB6N,MAAMtO,MAAM,CAACS,KAAK,GAAG;AAEd,MAAM+N,WAAW;IACtB9N,QAAQ,SAAUoN,MAAM,EAAEhN,GAAG,EAAEC,MAAM;QACnCD,MAAM+M,OAAOnN,MAAM,CAACuN,eAAeH,QAAQ,aAAahN,KAAKC;QAC7DyN,SAAS9N,MAAM,CAACD,KAAK,GAAGoN,OAAOnN,MAAM,CAACD,KAAK;QAC3C,OAAOK;IACT;IACAd,QAAQ,SAAUc,GAAG,EAAEC,MAAM;QAC3B,MAAMwN,MAAMV,OAAO7N,MAAM,CAACc,KAAKC;QAC/ByN,SAASxO,MAAM,CAACS,KAAK,GAAGoN,OAAO7N,MAAM,CAACS,KAAK;QAC3C,IAAI8N,IAAI5L,SAAS,EAAE;YACjB4L,IAAIvC,QAAQ,GAAGuC,IAAI5L,SAAS,CAAC,EAAE;YAC/B,OAAO4L,IAAI5L,SAAS;QACtB;QACA,OAAO4L;IACT;IACA5N,gBAAgB,SAAUmN,MAAM;QAC9B,OAAOD,OAAOlN,cAAc,CAACsN,eAAeH,QAAQ;IACtD;AACF,EAAC;AACDU,SAAS9N,MAAM,CAACD,KAAK,GAAG;AACxB+N,SAASxO,MAAM,CAACS,KAAK,GAAG;AAEjB,MAAMC,SAASmN,OAAOnN,MAAM;AAC5B,MAAMV,SAAS6N,OAAO7N,MAAM;AAC5B,MAAMW,iBAAiBkN,OAAOlN,cAAc;AAE5C,SAAS8N,aAAcX,MAAM;IAClC,MAAMhN,MAAMJ,OAAOoN;IACnB,MAAMY,UAAU,IAAI1N,WAAW,IAAIF,IAAI6N,UAAU;IACjD5O,4DAAe,CAAC2O,SAAS5N,IAAI6N,UAAU;IACvC5O,mDAAM,CAACe,KAAK4N,SAAS,GAAG,GAAG5N,IAAIM,MAAM;IACrCqN,aAAahO,KAAK,GAAGiO,QAAQC,UAAU;IACvC,OAAOD;AACT;AACAD,aAAahO,KAAK,GAAG;AAEd,SAASmO,aAAcC,IAAI;IAChC,MAAMrN,MAAMzB,2DAAc,CAAC8O,MAAM;IACjC,IAAIA,KAAKF,UAAU,GAAGnN,MAAM,GAAG;QAC7B,kBAAkB;QAClB,OAAO;IACT;IACA,MAAMsM,SAAS9N,OAAO6O,KAAK9K,KAAK,CAAC;IACjC6K,aAAanO,KAAK,GAAGT,OAAOS,KAAK;IACjC,OAAOqN;AACT;AACAc,aAAanO,KAAK,GAAG;AAEd,SAASyH,mBAAoB7G,IAAI,EAAEyK,GAAG;IAC3C,IAAItK,MAAM;IACV,IAAK,IAAID,IAAI,GAAGA,IAAIF,KAAKD,MAAM,EAAEG,IAAKC,OAAOsK,IAAInL,cAAc,CAACU,IAAI,CAACE,EAAE;IACvE,OAAOC;AACT;AAEO,SAAS2G,WAAY9G,IAAI,EAAEyK,GAAG,EAAEhL,GAAG,EAAEC,MAAM;IAChD,IAAK,IAAIQ,IAAI,GAAGA,IAAIF,KAAKD,MAAM,EAAEG,IAAK;QACpCuK,IAAIpL,MAAM,CAACW,IAAI,CAACE,EAAE,EAAET,KAAKC;QACzBA,UAAU+K,IAAIpL,MAAM,CAACD,KAAK;IAC5B;IACA,OAAOM;AACT;AAEO,SAASiN,WAAY3M,IAAI,EAAEyK,GAAG,EAAEhL,GAAG,EAAEC,MAAM;IAChD,IAAK,IAAIQ,IAAI,GAAGA,IAAIF,KAAKD,MAAM,EAAEG,IAAK;QACpCF,IAAI,CAACE,EAAE,GAAGuK,IAAI9L,MAAM,CAACc,KAAKC;QAC1BA,UAAU+K,IAAI9L,MAAM,CAACS,KAAK;IAC5B;IACA,OAAOM;AACT","sources":["webpack://flush-notes/./node_modules/@leichtgewicht/dns-packet/index.mjs?7a0b"],"sourcesContent":["import * as ip from '@leichtgewicht/ip-codec'\nimport * as types from './types.mjs'\nimport * as rcodes from './rcodes.mjs'\nimport * as opcodes from './opcodes.mjs'\nimport * as classes from './classes.mjs'\nimport * as optioncodes from './optioncodes.mjs'\nimport * as b from './buffer_utils.mjs'\nimport { decode as toUtf8 } from 'utf8-codec'\n\nconst QUERY_FLAG = 0\nconst RESPONSE_FLAG = 1 << 15\nconst FLUSH_MASK = 1 << 15\nconst NOT_FLUSH_MASK = ~FLUSH_MASK\nconst QU_MASK = 1 << 15\nconst NOT_QU_MASK = ~QU_MASK\n\nfunction codec ({ bytes = 0, encode, decode, encodingLength }) {\n  encode.bytes = bytes\n  decode.bytes = bytes\n  return {\n    encode,\n    decode,\n    encodingLength: encodingLength || (() => bytes)\n  }\n}\n\nexport const name = codec({\n  encode (str, buf, offset) {\n    if (!buf) buf = new Uint8Array(name.encodingLength(str))\n    if (!offset) offset = 0\n    const oldOffset = offset\n\n    // strip leading and trailing .\n    const n = str.replace(/^\\.|\\.$/gm, '')\n    if (n.length) {\n      const list = n.split('.')\n\n      for (let i = 0; i < list.length; i++) {\n        const len = b.write(buf, list[i], offset + 1)\n        buf[offset] = len\n        offset += len + 1\n      }\n    }\n\n    buf[offset++] = 0\n\n    name.encode.bytes = offset - oldOffset\n    return buf\n  },\n  decode (buf, offset) {\n    if (!offset) offset = 0\n\n    const list = []\n    let oldOffset = offset\n    let totalLength = 0\n    let consumedBytes = 0\n    let jumped = false\n\n    while (true) {\n      if (offset >= buf.length) {\n        throw new Error('Cannot decode name (buffer overflow)')\n      }\n      const len = buf[offset++]\n      consumedBytes += jumped ? 0 : 1\n\n      if (len === 0) {\n        break\n      } else if ((len & 0xc0) === 0) {\n        if (offset + len > buf.length) {\n          throw new Error('Cannot decode name (buffer overflow)')\n        }\n        totalLength += len + 1\n        if (totalLength > 254) {\n          throw new Error('Cannot decode name (name too long)')\n        }\n        list.push(toUtf8(buf, offset, offset + len))\n        offset += len\n        consumedBytes += jumped ? 0 : len\n      } else if ((len & 0xc0) === 0xc0) {\n        if (offset + 1 > buf.length) {\n          throw new Error('Cannot decode name (buffer overflow)')\n        }\n        const jumpOffset = b.readUInt16BE(buf, offset - 1) - 0xc000\n        if (jumpOffset >= oldOffset) {\n          // Allow only pointers to prior data. RFC 1035, section 4.1.4 states:\n          // \"[...] an entire domain name or a list of labels at the end of a domain name\n          // is replaced with a pointer to a prior occurance (sic) of the same name.\"\n          throw new Error('Cannot decode name (bad pointer)')\n        }\n        offset = jumpOffset\n        oldOffset = jumpOffset\n        consumedBytes += jumped ? 0 : 1\n        jumped = true\n      } else {\n        throw new Error('Cannot decode name (bad label)')\n      }\n    }\n\n    name.decode.bytes = consumedBytes\n    return list.length === 0 ? '.' : list.join('.')\n  },\n  encodingLength (n) {\n    if (n === '.' || n === '..') return 1\n    return b.bytelength(n.replace(/^\\.|\\.$/gm, '')) + 2\n  }\n})\n\nconst string = codec({\n  encode (s, buf, offset) {\n    if (!buf) buf = new Uint8Array(string.encodingLength(s))\n    if (!offset) offset = 0\n\n    const len = b.write(buf, s, offset + 1)\n    buf[offset] = len\n    string.encode.bytes = len + 1\n    return buf\n  },\n  decode (buf, offset) {\n    if (!offset) offset = 0\n\n    const len = buf[offset]\n    const s = toUtf8(buf, offset + 1, offset + 1 + len)\n    string.decode.bytes = len + 1\n    return s\n  },\n  encodingLength (s) {\n    return b.bytelength(s) + 1\n  }\n})\n\nconst header = codec({\n  bytes: 12,\n  encode (h, buf, offset) {\n    if (!buf) buf = new Uint8Array(header.encodingLength(h))\n    if (!offset) offset = 0\n\n    const flags = (h.flags || 0) & 32767\n    const type = h.type === 'response' ? RESPONSE_FLAG : QUERY_FLAG\n\n    b.writeUInt16BE(buf, h.id || 0, offset)\n    b.writeUInt16BE(buf, flags | type, offset + 2)\n    b.writeUInt16BE(buf, h.questions.length, offset + 4)\n    b.writeUInt16BE(buf, h.answers.length, offset + 6)\n    b.writeUInt16BE(buf, h.authorities.length, offset + 8)\n    b.writeUInt16BE(buf, h.additionals.length, offset + 10)\n\n    return buf\n  },\n  decode (buf, offset) {\n    if (!offset) offset = 0\n    if (buf.length < 12) throw new Error('Header must be 12 bytes')\n    const flags = b.readUInt16BE(buf, offset + 2)\n\n    return {\n      id: b.readUInt16BE(buf, offset),\n      type: flags & RESPONSE_FLAG ? 'response' : 'query',\n      flags: flags & 32767,\n      flag_qr: ((flags >> 15) & 0x1) === 1,\n      opcode: opcodes.toString((flags >> 11) & 0xf),\n      flag_aa: ((flags >> 10) & 0x1) === 1,\n      flag_tc: ((flags >> 9) & 0x1) === 1,\n      flag_rd: ((flags >> 8) & 0x1) === 1,\n      flag_ra: ((flags >> 7) & 0x1) === 1,\n      flag_z: ((flags >> 6) & 0x1) === 1,\n      flag_ad: ((flags >> 5) & 0x1) === 1,\n      flag_cd: ((flags >> 4) & 0x1) === 1,\n      rcode: rcodes.toString(flags & 0xf),\n      questions: new Array(b.readUInt16BE(buf, offset + 4)),\n      answers: new Array(b.readUInt16BE(buf, offset + 6)),\n      authorities: new Array(b.readUInt16BE(buf, offset + 8)),\n      additionals: new Array(b.readUInt16BE(buf, offset + 10))\n    }\n  },\n  encodingLength () {\n    return 12\n  }\n})\n\nconst runknown = codec({\n  encode (data, buf, offset) {\n    if (!buf) buf = new Uint8Array(runknown.encodingLength(data))\n    if (!offset) offset = 0\n\n    const dLen = data.length\n    b.writeUInt16BE(buf, dLen, offset)\n    b.copy(data, buf, offset + 2, 0, dLen)\n\n    runknown.encode.bytes = dLen + 2\n    return buf\n  },\n  decode (buf, offset) {\n    if (!offset) offset = 0\n\n    const len = b.readUInt16BE(buf, offset)\n    const data = buf.slice(offset + 2, offset + 2 + len)\n    runknown.decode.bytes = len + 2\n    return data\n  },\n  encodingLength (data) {\n    return data.length + 2\n  }\n})\n\nconst rns = codec({\n  encode (data, buf, offset) {\n    if (!buf) buf = new Uint8Array(rns.encodingLength(data))\n    if (!offset) offset = 0\n\n    name.encode(data, buf, offset + 2)\n    b.writeUInt16BE(buf, name.encode.bytes, offset)\n    rns.encode.bytes = name.encode.bytes + 2\n    return buf\n  },\n  decode (buf, offset) {\n    if (!offset) offset = 0\n\n    const len = b.readUInt16BE(buf, offset)\n    const dd = name.decode(buf, offset + 2)\n\n    rns.decode.bytes = len + 2\n    return dd\n  },\n  encodingLength (data) {\n    return name.encodingLength(data) + 2\n  }\n})\n\nconst rsoa = codec({\n  encode (data, buf, offset) {\n    if (!buf) buf = new Uint8Array(rsoa.encodingLength(data))\n    if (!offset) offset = 0\n\n    const oldOffset = offset\n    offset += 2\n    name.encode(data.mname, buf, offset)\n    offset += name.encode.bytes\n    name.encode(data.rname, buf, offset)\n    offset += name.encode.bytes\n    b.writeUInt32BE(buf, data.serial || 0, offset)\n    offset += 4\n    b.writeUInt32BE(buf, data.refresh || 0, offset)\n    offset += 4\n    b.writeUInt32BE(buf, data.retry || 0, offset)\n    offset += 4\n    b.writeUInt32BE(buf, data.expire || 0, offset)\n    offset += 4\n    b.writeUInt32BE(buf, data.minimum || 0, offset)\n    offset += 4\n\n    b.writeUInt16BE(buf, offset - oldOffset - 2, oldOffset)\n    rsoa.encode.bytes = offset - oldOffset\n    return buf\n  },\n  decode (buf, offset) {\n    if (!offset) offset = 0\n\n    const oldOffset = offset\n\n    const data = {}\n    offset += 2\n    data.mname = name.decode(buf, offset)\n    offset += name.decode.bytes\n    data.rname = name.decode(buf, offset)\n    offset += name.decode.bytes\n    data.serial = b.readUInt32BE(buf, offset)\n    offset += 4\n    data.refresh = b.readUInt32BE(buf, offset)\n    offset += 4\n    data.retry = b.readUInt32BE(buf, offset)\n    offset += 4\n    data.expire = b.readUInt32BE(buf, offset)\n    offset += 4\n    data.minimum = b.readUInt32BE(buf, offset)\n    offset += 4\n\n    rsoa.decode.bytes = offset - oldOffset\n    return data\n  },\n  encodingLength (data) {\n    return 22 + name.encodingLength(data.mname) + name.encodingLength(data.rname)\n  }\n})\n\nconst rtxt = codec({\n  encode (data, buf, offset) {\n    if (!Array.isArray(data)) data = [data]\n    for (let i = 0; i < data.length; i++) {\n      if (typeof data[i] === 'string') {\n        data[i] = b.from(data[i])\n      }\n      if (!b.isU8Arr(data[i])) {\n        throw new Error('Must be a Buffer')\n      }\n    }\n\n    if (!buf) buf = new Uint8Array(rtxt.encodingLength(data))\n    if (!offset) offset = 0\n\n    const oldOffset = offset\n    offset += 2\n\n    data.forEach(function (d) {\n      buf[offset++] = d.length\n      b.copy(d, buf, offset, 0, d.length)\n      offset += d.length\n    })\n\n    b.writeUInt16BE(buf, offset - oldOffset - 2, oldOffset)\n    rtxt.encode.bytes = offset - oldOffset\n    return buf\n  },\n  decode (buf, offset) {\n    if (!offset) offset = 0\n    const oldOffset = offset\n    let remaining = b.readUInt16BE(buf, offset)\n    offset += 2\n\n    const data = []\n    while (remaining > 0) {\n      const len = buf[offset++]\n      --remaining\n      if (remaining < len) {\n        throw new Error('Buffer overflow')\n      }\n      data.push(buf.slice(offset, offset + len))\n      offset += len\n      remaining -= len\n    }\n\n    rtxt.decode.bytes = offset - oldOffset\n    return data\n  },\n  encodingLength (data) {\n    if (!Array.isArray(data)) data = [data]\n    let length = 2\n    data.forEach(function (buf) {\n      if (typeof buf === 'string') {\n        length += b.bytelength(buf) + 1\n      } else {\n        length += buf.length + 1\n      }\n    })\n    return length\n  }\n})\n\nconst rnull = codec({\n  encode (data, buf, offset) {\n    if (!buf) buf = new Uint8Array(rnull.encodingLength(data))\n    if (!offset) offset = 0\n\n    if (typeof data === 'string') data = b.from(data)\n    if (!data) data = new Uint8Array(0)\n\n    const oldOffset = offset\n    offset += 2\n\n    const len = data.length\n    b.copy(data, buf, offset, 0, len)\n    offset += len\n\n    b.writeUInt16BE(buf, offset - oldOffset - 2, oldOffset)\n    rnull.encode.bytes = offset - oldOffset\n    return buf\n  },\n  decode (buf, offset) {\n    if (!offset) offset = 0\n    const oldOffset = offset\n    const len = b.readUInt16BE(buf, offset)\n\n    offset += 2\n\n    const data = buf.slice(offset, offset + len)\n    offset += len\n\n    rnull.decode.bytes = offset - oldOffset\n    return data\n  },\n  encodingLength (data) {\n    if (!data) return 2\n    return (b.isU8Arr(data) ? data.length : b.bytelength(data)) + 2\n  }\n})\n\nconst rhinfo = codec({\n  encode (data, buf, offset) {\n    if (!buf) buf = new Uint8Array(rhinfo.encodingLength(data))\n    if (!offset) offset = 0\n\n    const oldOffset = offset\n    offset += 2\n    string.encode(data.cpu, buf, offset)\n    offset += string.encode.bytes\n    string.encode(data.os, buf, offset)\n    offset += string.encode.bytes\n    b.writeUInt16BE(buf, offset - oldOffset - 2, oldOffset)\n    rhinfo.encode.bytes = offset - oldOffset\n    return buf\n  },\n  decode (buf, offset) {\n    if (!offset) offset = 0\n\n    const oldOffset = offset\n\n    const data = {}\n    offset += 2\n    data.cpu = string.decode(buf, offset)\n    offset += string.decode.bytes\n    data.os = string.decode(buf, offset)\n    offset += string.decode.bytes\n    rhinfo.decode.bytes = offset - oldOffset\n    return data\n  },\n  encodingLength (data) {\n    return string.encodingLength(data.cpu) + string.encodingLength(data.os) + 2\n  }\n})\n\nconst rptr = codec({\n  encode (data, buf, offset) {\n    if (!buf) buf = new Uint8Array(rptr.encodingLength(data))\n    if (!offset) offset = 0\n\n    name.encode(data, buf, offset + 2)\n    b.writeUInt16BE(buf, name.encode.bytes, offset)\n    rptr.encode.bytes = name.encode.bytes + 2\n    return buf\n  },\n  decode (buf, offset) {\n    if (!offset) offset = 0\n\n    const data = name.decode(buf, offset + 2)\n    rptr.decode.bytes = name.decode.bytes + 2\n    return data\n  },\n  encodingLength (data) {\n    return name.encodingLength(data) + 2\n  }\n})\n\nconst rsrv = codec({\n  encode (data, buf, offset) {\n    if (!buf) buf = new Uint8Array(rsrv.encodingLength(data))\n    if (!offset) offset = 0\n\n    b.writeUInt16BE(buf, data.priority || 0, offset + 2)\n    b.writeUInt16BE(buf, data.weight || 0, offset + 4)\n    b.writeUInt16BE(buf, data.port || 0, offset + 6)\n    name.encode(data.target, buf, offset + 8)\n\n    const len = name.encode.bytes + 6\n    b.writeUInt16BE(buf, len, offset)\n\n    rsrv.encode.bytes = len + 2\n    return buf\n  },\n  decode (buf, offset) {\n    if (!offset) offset = 0\n\n    const len = b.readUInt16BE(buf, offset)\n\n    const data = {}\n    data.priority = b.readUInt16BE(buf, offset + 2)\n    data.weight = b.readUInt16BE(buf, offset + 4)\n    data.port = b.readUInt16BE(buf, offset + 6)\n    data.target = name.decode(buf, offset + 8)\n\n    rsrv.decode.bytes = len + 2\n    return data\n  },\n  encodingLength (data) {\n    return 8 + name.encodingLength(data.target)\n  }\n})\n\nconst rcaa = codec({\n  encode (data, buf, offset) {\n    const len = rcaa.encodingLength(data)\n\n    if (!buf) buf = new Uint8Array(rcaa.encodingLength(data))\n    if (!offset) offset = 0\n\n    if (data.issuerCritical) {\n      data.flags = rcaa.ISSUER_CRITICAL\n    }\n\n    b.writeUInt16BE(buf, len - 2, offset)\n    offset += 2\n    buf[offset] = data.flags || 0\n    offset += 1\n    string.encode(data.tag, buf, offset)\n    offset += string.encode.bytes\n    b.write(buf, data.value, offset)\n    offset += b.bytelength(data.value)\n\n    rcaa.encode.bytes = len\n    return buf\n  },\n  decode (buf, offset) {\n    if (!offset) offset = 0\n\n    const len = b.readUInt16BE(buf, offset)\n    offset += 2\n\n    const oldOffset = offset\n    const data = {}\n    data.flags = buf[offset]\n    offset += 1\n    data.tag = string.decode(buf, offset)\n    offset += string.decode.bytes\n    data.value = toUtf8(buf, offset, oldOffset + len)\n\n    data.issuerCritical = !!(data.flags & rcaa.ISSUER_CRITICAL)\n\n    rcaa.decode.bytes = len + 2\n\n    return data\n  },\n  encodingLength (data) {\n    return string.encodingLength(data.tag) + string.encodingLength(data.value) + 2\n  }\n})\n\nrcaa.ISSUER_CRITICAL = 1 << 7\n\nconst rmx = codec({\n  encode (data, buf, offset) {\n    if (!buf) buf = new Uint8Array(rmx.encodingLength(data))\n    if (!offset) offset = 0\n\n    const oldOffset = offset\n    offset += 2\n    b.writeUInt16BE(buf, data.preference || 0, offset)\n    offset += 2\n    name.encode(data.exchange, buf, offset)\n    offset += name.encode.bytes\n\n    b.writeUInt16BE(buf, offset - oldOffset - 2, oldOffset)\n    rmx.encode.bytes = offset - oldOffset\n    return buf\n  },\n  decode (buf, offset) {\n    if (!offset) offset = 0\n\n    const oldOffset = offset\n\n    const data = {}\n    offset += 2\n    data.preference = b.readUInt16BE(buf, offset)\n    offset += 2\n    data.exchange = name.decode(buf, offset)\n    offset += name.decode.bytes\n\n    rmx.decode.bytes = offset - oldOffset\n    return data\n  },\n  encodingLength (data) {\n    return 4 + name.encodingLength(data.exchange)\n  }\n})\n\nconst ra = codec({\n  encode (host, buf, offset) {\n    if (!buf) buf = new Uint8Array(ra.encodingLength(host))\n    if (!offset) offset = 0\n\n    b.writeUInt16BE(buf, 4, offset)\n    offset += 2\n    ip.v4.encode(host, buf, offset)\n    return buf\n  },\n  decode (buf, offset) {\n    if (!offset) offset = 0\n\n    offset += 2\n    const host = ip.v4.decode(buf, offset)\n    return host\n  },\n  bytes: 6\n})\n\nconst raaaa = codec({\n  encode (host, buf, offset) {\n    if (!buf) buf = new Uint8Array(raaaa.encodingLength(host))\n    if (!offset) offset = 0\n\n    b.writeUInt16BE(buf, 16, offset)\n    offset += 2\n    ip.v6.encode(host, buf, offset)\n    raaaa.encode.bytes = 18\n    return buf\n  },\n  decode (buf, offset) {\n    if (!offset) offset = 0\n\n    offset += 2\n    const host = ip.v6.decode(buf, offset)\n    raaaa.decode.bytes = 18\n    return host\n  },\n  bytes: 18\n})\n\nconst alloc = size => new Uint8Array(size)\n\nconst roption = codec({\n  encode (option, buf, offset) {\n    if (!buf) buf = new Uint8Array(roption.encodingLength(option))\n    if (!offset) offset = 0\n    const oldOffset = offset\n\n    const code = optioncodes.toCode(option.code)\n    b.writeUInt16BE(buf, code, offset)\n    offset += 2\n    if (option.data) {\n      b.writeUInt16BE(buf, option.data.length, offset)\n      offset += 2\n      b.copy(option.data, buf, offset)\n      offset += option.data.length\n    } else {\n      switch (code) {\n        // case 3: NSID.  No encode makes sense.\n        // case 5,6,7: Not implementable\n        case 8: // ECS\n          {\n            // note: do IP math before calling\n            const spl = option.sourcePrefixLength || 0\n            const fam = option.family || ip.familyOf(option.ip, alloc)\n            const ipBuf = ip.encode(option.ip, alloc)\n            const ipLen = Math.ceil(spl / 8)\n            b.writeUInt16BE(buf, ipLen + 4, offset)\n            offset += 2\n            b.writeUInt16BE(buf, fam, offset)\n            offset += 2\n            buf[offset++] = spl\n            buf[offset++] = option.scopePrefixLength || 0\n\n            b.copy(ipBuf, buf, offset, 0, ipLen)\n            offset += ipLen\n          }\n          break\n        // case 9: EXPIRE (experimental)\n        // case 10: COOKIE.  No encode makes sense.\n        case 11: // KEEP-ALIVE\n          if (option.timeout) {\n            b.writeUInt16BE(buf, 2, offset)\n            offset += 2\n            b.writeUInt16BE(buf, option.timeout, offset)\n            offset += 2\n          } else {\n            b.writeUInt16BE(buf, 0, offset)\n            offset += 2\n          }\n          break\n        case 12: // PADDING\n          {\n            const len = option.length || 0\n            b.writeUInt16BE(buf, len, offset)\n            offset += 2\n            buf.fill(0, offset, offset + len)\n            offset += len\n          }\n          break\n        // case 13:  CHAIN.  Experimental.\n        case 14: // KEY-TAG\n          {\n            const tagsLen = option.tags.length * 2\n            b.writeUInt16BE(buf, tagsLen, offset)\n            offset += 2\n            for (const tag of option.tags) {\n              b.writeUInt16BE(buf, tag, offset)\n              offset += 2\n            }\n          }\n          break\n        default:\n          throw new Error(`Unknown roption code: ${option.code}`)\n      }\n    }\n\n    roption.encode.bytes = offset - oldOffset\n    return buf\n  },\n  decode (buf, offset) {\n    if (!offset) offset = 0\n    const option = {}\n    option.code = b.readUInt16BE(buf, offset)\n    option.type = optioncodes.toString(option.code)\n    offset += 2\n    const len = b.readUInt16BE(buf, offset)\n    offset += 2\n    option.data = buf.slice(offset, offset + len)\n    switch (option.code) {\n      // case 3: NSID.  No decode makes sense.\n      case 8: // ECS\n        option.family = b.readUInt16BE(buf, offset)\n        offset += 2\n        option.sourcePrefixLength = buf[offset++]\n        option.scopePrefixLength = buf[offset++]\n        {\n          const padded = new Uint8Array((option.family === 1) ? 4 : 16)\n          b.copy(buf, padded, 0, offset, offset + len - 4)\n          option.ip = ip.decode(padded)\n        }\n        break\n      // case 12: Padding.  No decode makes sense.\n      case 11: // KEEP-ALIVE\n        if (len > 0) {\n          option.timeout = b.readUInt16BE(buf, offset)\n          offset += 2\n        }\n        break\n      case 14:\n        option.tags = []\n        for (let i = 0; i < len; i += 2) {\n          option.tags.push(b.readUInt16BE(buf, offset))\n          offset += 2\n        }\n      // don't worry about default.  caller will use data if desired\n    }\n\n    roption.decode.bytes = len + 4\n    return option\n  },\n  encodingLength (option) {\n    if (option.data) {\n      return option.data.length + 4\n    }\n    const code = optioncodes.toCode(option.code)\n    switch (code) {\n      case 8: // ECS\n      {\n        const spl = option.sourcePrefixLength || 0\n        return Math.ceil(spl / 8) + 8\n      }\n      case 11: // KEEP-ALIVE\n        return (typeof option.timeout === 'number') ? 6 : 4\n      case 12: // PADDING\n        return option.length + 4\n      case 14: // KEY-TAG\n        return 4 + (option.tags.length * 2)\n    }\n    throw new Error(`Unknown roption code: ${option.code}`)\n  }\n})\n\nconst ropt = codec({\n  encode (options, buf, offset) {\n    if (!buf) buf = new Uint8Array(ropt.encodingLength(options))\n    if (!offset) offset = 0\n    const oldOffset = offset\n\n    const rdlen = encodingLengthList(options, roption)\n    b.writeUInt16BE(buf, rdlen, offset)\n    offset = encodeList(options, roption, buf, offset + 2)\n\n    ropt.encode.bytes = offset - oldOffset\n    return buf\n  },\n  decode (buf, offset) {\n    if (!offset) offset = 0\n    const oldOffset = offset\n\n    const options = []\n    let rdlen = b.readUInt16BE(buf, offset)\n    offset += 2\n    let o = 0\n    while (rdlen > 0) {\n      options[o++] = roption.decode(buf, offset)\n      offset += roption.decode.bytes\n      rdlen -= roption.decode.bytes\n    }\n    ropt.decode.bytes = offset - oldOffset\n    return options\n  },\n  encodingLength (options) {\n    return 2 + encodingLengthList(options || [], roption)\n  }\n})\n\nconst rdnskey = codec({\n  encode (key, buf, offset) {\n    if (!buf) buf = new Uint8Array(rdnskey.encodingLength(key))\n    if (!offset) offset = 0\n    const oldOffset = offset\n\n    const keydata = key.key\n    if (!b.isU8Arr(keydata)) {\n      throw new Error('Key must be a Buffer')\n    }\n\n    offset += 2 // Leave space for length\n    b.writeUInt16BE(buf, key.flags, offset)\n    offset += 2\n    buf[offset] = rdnskey.PROTOCOL_DNSSEC\n    offset += 1\n    buf[offset] = key.algorithm\n    offset += 1\n    b.copy(keydata, buf, offset, 0, keydata.length)\n    offset += keydata.length\n\n    rdnskey.encode.bytes = offset - oldOffset\n    b.writeUInt16BE(buf, rdnskey.encode.bytes - 2, oldOffset)\n    return buf\n  },\n  decode (buf, offset) {\n    if (!offset) offset = 0\n    const oldOffset = offset\n\n    const key = {}\n    const length = b.readUInt16BE(buf, offset)\n    offset += 2\n    key.flags = b.readUInt16BE(buf, offset)\n    offset += 2\n    if (buf[offset] !== rdnskey.PROTOCOL_DNSSEC) {\n      throw new Error('Protocol must be 3')\n    }\n    offset += 1\n    key.algorithm = buf[offset]\n    offset += 1\n    key.key = buf.slice(offset, oldOffset + length + 2)\n    offset += key.key.length\n    rdnskey.decode.bytes = offset - oldOffset\n    return key\n  },\n  encodingLength (key) {\n    return 6 + b.bytelength(key.key)\n  }\n})\n\nrdnskey.PROTOCOL_DNSSEC = 3\nrdnskey.ZONE_KEY = 0x80\nrdnskey.SECURE_ENTRYPOINT = 0x8000\n\nconst rrrsig = codec({\n  encode (sig, buf, offset) {\n    if (!buf) buf = new Uint8Array(rrrsig.encodingLength(sig))\n    if (!offset) offset = 0\n    const oldOffset = offset\n\n    const signature = sig.signature\n    if (!b.isU8Arr(signature)) {\n      throw new Error('Signature must be a Buffer')\n    }\n\n    offset += 2 // Leave space for length\n    b.writeUInt16BE(buf, types.toType(sig.typeCovered), offset)\n    offset += 2\n    buf[offset] = sig.algorithm\n    offset += 1\n    buf[offset] = sig.labels\n    offset += 1\n    b.writeUInt32BE(buf, sig.originalTTL, offset)\n    offset += 4\n    b.writeUInt32BE(buf, sig.expiration, offset)\n    offset += 4\n    b.writeUInt32BE(buf, sig.inception, offset)\n    offset += 4\n    b.writeUInt16BE(buf, sig.keyTag, offset)\n    offset += 2\n    name.encode(sig.signersName, buf, offset)\n    offset += name.encode.bytes\n    b.copy(signature, buf, offset, 0, signature.length)\n    offset += signature.length\n\n    rrrsig.encode.bytes = offset - oldOffset\n    b.writeUInt16BE(buf, rrrsig.encode.bytes - 2, oldOffset)\n    return buf\n  },\n  decode (buf, offset) {\n    if (!offset) offset = 0\n    const oldOffset = offset\n\n    const sig = {}\n    const length = b.readUInt16BE(buf, offset)\n    offset += 2\n    sig.typeCovered = types.toString(b.readUInt16BE(buf, offset))\n    offset += 2\n    sig.algorithm = buf[offset]\n    offset += 1\n    sig.labels = buf[offset]\n    offset += 1\n    sig.originalTTL = b.readUInt32BE(buf, offset)\n    offset += 4\n    sig.expiration = b.readUInt32BE(buf, offset)\n    offset += 4\n    sig.inception = b.readUInt32BE(buf, offset)\n    offset += 4\n    sig.keyTag = b.readUInt16BE(buf, offset)\n    offset += 2\n    sig.signersName = name.decode(buf, offset)\n    offset += name.decode.bytes\n    sig.signature = buf.slice(offset, oldOffset + length + 2)\n    offset += sig.signature.length\n    rrrsig.decode.bytes = offset - oldOffset\n    return sig\n  },\n  encodingLength (sig) {\n    return 20 +\n      name.encodingLength(sig.signersName) +\n      b.bytelength(sig.signature)\n  }\n})\nconst rrp = codec({\n  encode (data, buf, offset) {\n    if (!buf) buf = new Uint8Array(rrp.encodingLength(data))\n    if (!offset) offset = 0\n    const oldOffset = offset\n\n    offset += 2 // Leave space for length\n    name.encode(data.mbox || '.', buf, offset)\n    offset += name.encode.bytes\n    name.encode(data.txt || '.', buf, offset)\n    offset += name.encode.bytes\n    rrp.encode.bytes = offset - oldOffset\n    b.writeUInt16BE(buf, rrp.encode.bytes - 2, oldOffset)\n    return buf\n  },\n  decode (buf, offset) {\n    if (!offset) offset = 0\n    const oldOffset = offset\n\n    const data = {}\n    offset += 2\n    data.mbox = name.decode(buf, offset) || '.'\n    offset += name.decode.bytes\n    data.txt = name.decode(buf, offset) || '.'\n    offset += name.decode.bytes\n    rrp.decode.bytes = offset - oldOffset\n    return data\n  },\n  encodingLength (data) {\n    return 2 + name.encodingLength(data.mbox || '.') + name.encodingLength(data.txt || '.')\n  }\n})\n\nconst typebitmap = codec({\n  encode (typelist, buf, offset) {\n    if (!buf) buf = new Uint8Array(typebitmap.encodingLength(typelist))\n    if (!offset) offset = 0\n    const oldOffset = offset\n\n    const typesByWindow = []\n    for (let i = 0; i < typelist.length; i++) {\n      const typeid = types.toType(typelist[i])\n      if (typesByWindow[typeid >> 8] === undefined) {\n        typesByWindow[typeid >> 8] = []\n      }\n      typesByWindow[typeid >> 8][(typeid >> 3) & 0x1F] |= 1 << (7 - (typeid & 0x7))\n    }\n\n    for (let i = 0; i < typesByWindow.length; i++) {\n      if (typesByWindow[i] !== undefined) {\n        const windowBuf = b.from(typesByWindow[i])\n        buf[offset] = i\n        offset += 1\n        buf[offset] = windowBuf.length\n        offset += 1\n        b.copy(windowBuf, buf, offset, 0, windowBuf.length)\n        offset += windowBuf.length\n      }\n    }\n\n    typebitmap.encode.bytes = offset - oldOffset\n    return buf\n  },\n  decode (buf, offset, length) {\n    if (!offset) offset = 0\n    const oldOffset = offset\n\n    const typelist = []\n    while (offset - oldOffset < length) {\n      const window = buf[offset]\n      offset += 1\n      const windowLength = buf[offset]\n      offset += 1\n      for (let i = 0; i < windowLength; i++) {\n        const b = buf[offset + i]\n        for (let j = 0; j < 8; j++) {\n          if (b & (1 << (7 - j))) {\n            const typeid = types.toString((window << 8) | (i << 3) | j)\n            typelist.push(typeid)\n          }\n        }\n      }\n      offset += windowLength\n    }\n\n    typebitmap.decode.bytes = offset - oldOffset\n    return typelist\n  },\n  encodingLength (typelist) {\n    const extents = []\n    for (let i = 0; i < typelist.length; i++) {\n      const typeid = types.toType(typelist[i])\n      extents[typeid >> 8] = Math.max(extents[typeid >> 8] || 0, typeid & 0xFF)\n    }\n\n    let len = 0\n    for (let i = 0; i < extents.length; i++) {\n      if (extents[i] !== undefined) {\n        len += 2 + Math.ceil((extents[i] + 1) / 8)\n      }\n    }\n\n    return len\n  }\n})\n\nconst rnsec = codec({\n  encode (record, buf, offset) {\n    if (!buf) buf = new Uint8Array(rnsec.encodingLength(record))\n    if (!offset) offset = 0\n    const oldOffset = offset\n\n    offset += 2 // Leave space for length\n    name.encode(record.nextDomain, buf, offset)\n    offset += name.encode.bytes\n    typebitmap.encode(record.rrtypes, buf, offset)\n    offset += typebitmap.encode.bytes\n\n    rnsec.encode.bytes = offset - oldOffset\n    b.writeUInt16BE(buf, rnsec.encode.bytes - 2, oldOffset)\n    return buf\n  },\n  decode (buf, offset) {\n    if (!offset) offset = 0\n    const oldOffset = offset\n\n    const record = {}\n    const length = b.readUInt16BE(buf, offset)\n    offset += 2\n    record.nextDomain = name.decode(buf, offset)\n    offset += name.decode.bytes\n    record.rrtypes = typebitmap.decode(buf, offset, length - (offset - oldOffset))\n    offset += typebitmap.decode.bytes\n\n    rnsec.decode.bytes = offset - oldOffset\n    return record\n  },\n  encodingLength (record) {\n    return 2 +\n      name.encodingLength(record.nextDomain) +\n      typebitmap.encodingLength(record.rrtypes)\n  }\n})\n\nconst rnsec3 = codec({\n  encode (record, buf, offset) {\n    if (!buf) buf = new Uint8Array(rnsec3.encodingLength(record))\n    if (!offset) offset = 0\n    const oldOffset = offset\n\n    const salt = record.salt\n    if (!b.isU8Arr(salt)) {\n      throw new Error('salt must be a Buffer')\n    }\n\n    const nextDomain = record.nextDomain\n    if (!b.isU8Arr(nextDomain)) {\n      throw new Error('nextDomain must be a Buffer')\n    }\n\n    offset += 2 // Leave space for length\n    buf[offset] = record.algorithm\n    offset += 1\n    buf[offset] = record.flags\n    offset += 1\n    b.writeUInt16BE(buf, record.iterations, offset)\n    offset += 2\n    buf[offset] = salt.length\n    offset += 1\n    b.copy(salt, buf, offset, 0, salt.length)\n    offset += salt.length\n    buf[offset] = nextDomain.length\n    offset += 1\n    b.copy(nextDomain, buf, offset, 0, nextDomain.length)\n    offset += nextDomain.length\n    typebitmap.encode(record.rrtypes, buf, offset)\n    offset += typebitmap.encode.bytes\n\n    rnsec3.encode.bytes = offset - oldOffset\n    b.writeUInt16BE(buf, rnsec3.encode.bytes - 2, oldOffset)\n    return buf\n  },\n  decode (buf, offset) {\n    if (!offset) offset = 0\n    const oldOffset = offset\n\n    const record = {}\n    const length = b.readUInt16BE(buf, offset)\n    offset += 2\n    record.algorithm = buf[offset]\n    offset += 1\n    record.flags = buf[offset]\n    offset += 1\n    record.iterations = b.readUInt16BE(buf, offset)\n    offset += 2\n    const saltLength = buf[offset]\n    offset += 1\n    record.salt = buf.slice(offset, offset + saltLength)\n    offset += saltLength\n    const hashLength = buf[offset]\n    offset += 1\n    record.nextDomain = buf.slice(offset, offset + hashLength)\n    offset += hashLength\n    record.rrtypes = typebitmap.decode(buf, offset, length - (offset - oldOffset))\n    offset += typebitmap.decode.bytes\n\n    rnsec3.decode.bytes = offset - oldOffset\n    return record\n  },\n  encodingLength (record) {\n    return 8 +\n      record.salt.length +\n      record.nextDomain.length +\n      typebitmap.encodingLength(record.rrtypes)\n  }\n})\n\nconst rds = codec({\n  encode (digest, buf, offset) {\n    if (!buf) buf = new Uint8Array(rds.encodingLength(digest))\n    if (!offset) offset = 0\n    const oldOffset = offset\n\n    const digestdata = digest.digest\n    if (!b.isU8Arr(digestdata)) {\n      throw new Error('Digest must be a Buffer')\n    }\n\n    offset += 2 // Leave space for length\n    b.writeUInt16BE(buf, digest.keyTag, offset)\n    offset += 2\n    buf[offset] = digest.algorithm\n    offset += 1\n    buf[offset] = digest.digestType\n    offset += 1\n    b.copy(digestdata, buf, offset, 0, digestdata.length)\n    offset += digestdata.length\n\n    rds.encode.bytes = offset - oldOffset\n    b.writeUInt16BE(buf, rds.encode.bytes - 2, oldOffset)\n    return buf\n  },\n  decode (buf, offset) {\n    if (!offset) offset = 0\n    const oldOffset = offset\n\n    const digest = {}\n    const length = b.readUInt16BE(buf, offset)\n    offset += 2\n    digest.keyTag = b.readUInt16BE(buf, offset)\n    offset += 2\n    digest.algorithm = buf[offset]\n    offset += 1\n    digest.digestType = buf[offset]\n    offset += 1\n    digest.digest = buf.slice(offset, oldOffset + length + 2)\n    offset += digest.digest.length\n    rds.decode.bytes = offset - oldOffset\n    return digest\n  },\n  encodingLength (digest) {\n    return 6 + b.bytelength(digest.digest)\n  }\n})\n\nfunction renc (type) {\n  switch (type.toUpperCase()) {\n    case 'A': return ra\n    case 'PTR': return rptr\n    case 'CNAME': return rptr\n    case 'DNAME': return rptr\n    case 'TXT': return rtxt\n    case 'NULL': return rnull\n    case 'AAAA': return raaaa\n    case 'SRV': return rsrv\n    case 'HINFO': return rhinfo\n    case 'CAA': return rcaa\n    case 'NS': return rns\n    case 'SOA': return rsoa\n    case 'MX': return rmx\n    case 'OPT': return ropt\n    case 'DNSKEY': return rdnskey\n    case 'RRSIG': return rrrsig\n    case 'RP': return rrp\n    case 'NSEC': return rnsec\n    case 'NSEC3': return rnsec3\n    case 'DS': return rds\n  }\n  return runknown\n}\n\nexport const answer = codec({\n  encode (a, buf, offset) {\n    if (!buf) buf = new Uint8Array(answer.encodingLength(a))\n    if (!offset) offset = 0\n\n    const oldOffset = offset\n\n    name.encode(a.name, buf, offset)\n    offset += name.encode.bytes\n\n    b.writeUInt16BE(buf, types.toType(a.type), offset)\n\n    if (a.type.toUpperCase() === 'OPT') {\n      if (a.name !== '.') {\n        throw new Error('OPT name must be root.')\n      }\n      b.writeUInt16BE(buf, a.udpPayloadSize || 4096, offset + 2)\n      buf[offset + 4] = a.extendedRcode || 0\n      buf[offset + 5] = a.ednsVersion || 0\n      b.writeUInt16BE(buf, a.flags || 0, offset + 6)\n\n      offset += 8\n      ropt.encode(a.options || [], buf, offset)\n      offset += ropt.encode.bytes\n    } else {\n      let klass = classes.toClass(a.class === undefined ? 'IN' : a.class)\n      if (a.flush) klass |= FLUSH_MASK // the 1st bit of the class is the flush bit\n      b.writeUInt16BE(buf, klass, offset + 2)\n      b.writeUInt32BE(buf, a.ttl || 0, offset + 4)\n\n      offset += 8\n      const enc = renc(a.type)\n      enc.encode(a.data, buf, offset)\n      offset += enc.encode.bytes\n    }\n\n    answer.encode.bytes = offset - oldOffset\n    return buf\n  },\n  decode (buf, offset) {\n    if (!offset) offset = 0\n\n    const a = {}\n    const oldOffset = offset\n\n    a.name = name.decode(buf, offset)\n    offset += name.decode.bytes\n    a.type = types.toString(b.readUInt16BE(buf, offset))\n    if (a.type === 'OPT') {\n      a.udpPayloadSize = b.readUInt16BE(buf, offset + 2)\n      a.extendedRcode = buf[offset + 4]\n      a.ednsVersion = buf[offset + 5]\n      a.flags = b.readUInt16BE(buf, offset + 6)\n      a.flag_do = ((a.flags >> 15) & 0x1) === 1\n      a.options = ropt.decode(buf, offset + 8)\n      offset += 8 + ropt.decode.bytes\n    } else {\n      const klass = b.readUInt16BE(buf, offset + 2)\n      a.ttl = b.readUInt32BE(buf, offset + 4)\n\n      a.class = classes.toString(klass & NOT_FLUSH_MASK)\n      a.flush = !!(klass & FLUSH_MASK)\n\n      const enc = renc(a.type)\n      a.data = enc.decode(buf, offset + 8)\n      offset += 8 + enc.decode.bytes\n    }\n\n    answer.decode.bytes = offset - oldOffset\n    return a\n  },\n  encodingLength (a) {\n    const data = (a.data !== null && a.data !== undefined) ? a.data : a.options\n    return name.encodingLength(a.name) + 8 + renc(a.type).encodingLength(data)\n  }\n})\n\nexport const question = codec({\n  encode (q, buf, offset) {\n    if (!buf) buf = new Uint8Array(question.encodingLength(q))\n    if (!offset) offset = 0\n\n    const oldOffset = offset\n\n    name.encode(q.name, buf, offset)\n    offset += name.encode.bytes\n\n    b.writeUInt16BE(buf, types.toType(q.type), offset)\n    offset += 2\n\n    b.writeUInt16BE(buf, classes.toClass(q.class === undefined ? 'IN' : q.class), offset)\n    offset += 2\n\n    question.encode.bytes = offset - oldOffset\n    return q\n  },\n  decode (buf, offset) {\n    if (!offset) offset = 0\n\n    const oldOffset = offset\n    const q = {}\n\n    q.name = name.decode(buf, offset)\n    offset += name.decode.bytes\n\n    q.type = types.toString(b.readUInt16BE(buf, offset))\n    offset += 2\n\n    q.class = classes.toString(b.readUInt16BE(buf, offset))\n    offset += 2\n\n    const qu = !!(q.class & QU_MASK)\n    if (qu) q.class &= NOT_QU_MASK\n\n    question.decode.bytes = offset - oldOffset\n    return q\n  },\n  encodingLength (q) {\n    return name.encodingLength(q.name) + 4\n  }\n})\n\nexport {\n  rsoa as soa,\n  rtxt as txt,\n  rnull as null,\n  runknown as unknown,\n  rns as ns,\n  rhinfo as hinfo,\n  rptr as ptr,\n  rptr as cname,\n  rptr as dname,\n  rsrv as srv,\n  rcaa as caa,\n  rmx as mx,\n  ra as a,\n  raaaa as aaaa,\n  roption as option,\n  ropt as opt,\n  rdnskey as dnskey,\n  rrrsig as rrsig,\n  rrp as rp,\n  rnsec as nsec,\n  rnsec3 as nsec3,\n  rds as ds,\n  renc as enc\n}\n\nexport const AUTHORITATIVE_ANSWER = 1 << 10\nexport const TRUNCATED_RESPONSE = 1 << 9\nexport const RECURSION_DESIRED = 1 << 8\nexport const RECURSION_AVAILABLE = 1 << 7\nexport const AUTHENTIC_DATA = 1 << 5\nexport const CHECKING_DISABLED = 1 << 4\nexport const DNSSEC_OK = 1 << 15\n\nexport const packet = {\n  encode: function (result, buf, offset) {\n    const allocing = !buf\n\n    if (allocing) buf = new Uint8Array(encodingLength(result))\n    if (!offset) offset = 0\n\n    const oldOffset = offset\n\n    if (!result.questions) result.questions = []\n    if (!result.answers) result.answers = []\n    if (!result.authorities) result.authorities = []\n    if (!result.additionals) result.additionals = []\n\n    header.encode(result, buf, offset)\n    offset += header.encode.bytes\n\n    offset = encodeList(result.questions, question, buf, offset)\n    offset = encodeList(result.answers, answer, buf, offset)\n    offset = encodeList(result.authorities, answer, buf, offset)\n    offset = encodeList(result.additionals, answer, buf, offset)\n\n    packet.encode.bytes = offset - oldOffset\n\n    // just a quick sanity check\n    if (allocing && encode.bytes !== buf.length) {\n      return buf.slice(0, encode.bytes)\n    }\n\n    return buf\n  },\n  decode: function (buf, offset) {\n    if (!offset) offset = 0\n\n    const oldOffset = offset\n    const result = header.decode(buf, offset)\n    offset += header.decode.bytes\n\n    offset = decodeList(result.questions, question, buf, offset)\n    offset = decodeList(result.answers, answer, buf, offset)\n    offset = decodeList(result.authorities, answer, buf, offset)\n    offset = decodeList(result.additionals, answer, buf, offset)\n\n    packet.decode.bytes = offset - oldOffset\n\n    return result\n  },\n  encodingLength: function (result) {\n    return header.encodingLength(result) +\n      encodingLengthList(result.questions || [], question) +\n      encodingLengthList(result.answers || [], answer) +\n      encodingLengthList(result.authorities || [], answer) +\n      encodingLengthList(result.additionals || [], answer)\n  }\n}\npacket.encode.bytes = 0\npacket.decode.bytes = 0\n\nfunction sanitizeSingle (input, type) {\n  if (input.questions) {\n    throw new Error('Only one .question object expected instead of a .questions array!')\n  }\n  const sanitized = Object.assign({\n    type\n  }, input)\n  if (sanitized.question) {\n    sanitized.questions = [sanitized.question]\n    delete sanitized.question\n  }\n  return sanitized\n}\n\nexport const query = {\n  encode: function (result, buf, offset) {\n    buf = packet.encode(sanitizeSingle(result, 'query'), buf, offset)\n    query.encode.bytes = packet.encode.bytes\n    return buf\n  },\n  decode: function (buf, offset) {\n    const res = packet.decode(buf, offset)\n    query.decode.bytes = packet.decode.bytes\n    if (res.questions) {\n      res.question = res.questions[0]\n      delete res.questions\n    }\n    return res\n  },\n  encodingLength: function (result) {\n    return packet.encodingLength(sanitizeSingle(result, 'query'))\n  }\n}\nquery.encode.bytes = 0\nquery.decode.bytes = 0\n\nexport const response = {\n  encode: function (result, buf, offset) {\n    buf = packet.encode(sanitizeSingle(result, 'response'), buf, offset)\n    response.encode.bytes = packet.encode.bytes\n    return buf\n  },\n  decode: function (buf, offset) {\n    const res = packet.decode(buf, offset)\n    response.decode.bytes = packet.decode.bytes\n    if (res.questions) {\n      res.question = res.questions[0]\n      delete res.questions\n    }\n    return res\n  },\n  encodingLength: function (result) {\n    return packet.encodingLength(sanitizeSingle(result, 'response'))\n  }\n}\nresponse.encode.bytes = 0\nresponse.decode.bytes = 0\n\nexport const encode = packet.encode\nexport const decode = packet.decode\nexport const encodingLength = packet.encodingLength\n\nexport function streamEncode (result) {\n  const buf = encode(result)\n  const combine = new Uint8Array(2 + buf.byteLength)\n  b.writeUInt16BE(combine, buf.byteLength)\n  b.copy(buf, combine, 2, 0, buf.length)\n  streamEncode.bytes = combine.byteLength\n  return combine\n}\nstreamEncode.bytes = 0\n\nexport function streamDecode (sbuf) {\n  const len = b.readUInt16BE(sbuf, 0)\n  if (sbuf.byteLength < len + 2) {\n    // not enough data\n    return null\n  }\n  const result = decode(sbuf.slice(2))\n  streamDecode.bytes = decode.bytes\n  return result\n}\nstreamDecode.bytes = 0\n\nexport function encodingLengthList (list, enc) {\n  let len = 0\n  for (let i = 0; i < list.length; i++) len += enc.encodingLength(list[i])\n  return len\n}\n\nexport function encodeList (list, enc, buf, offset) {\n  for (let i = 0; i < list.length; i++) {\n    enc.encode(list[i], buf, offset)\n    offset += enc.encode.bytes\n  }\n  return offset\n}\n\nexport function decodeList (list, enc, buf, offset) {\n  for (let i = 0; i < list.length; i++) {\n    list[i] = enc.decode(buf, offset)\n    offset += enc.decode.bytes\n  }\n  return offset\n}\n"],"names":["ip","types","rcodes","opcodes","classes","optioncodes","b","decode","toUtf8","QUERY_FLAG","RESPONSE_FLAG","FLUSH_MASK","NOT_FLUSH_MASK","QU_MASK","NOT_QU_MASK","codec","bytes","encode","encodingLength","name","str","buf","offset","Uint8Array","oldOffset","n","replace","length","list","split","i","len","write","totalLength","consumedBytes","jumped","Error","push","jumpOffset","readUInt16BE","join","bytelength","string","s","header","h","flags","type","writeUInt16BE","id","questions","answers","authorities","additionals","flag_qr","opcode","toString","flag_aa","flag_tc","flag_rd","flag_ra","flag_z","flag_ad","flag_cd","rcode","Array","runknown","data","dLen","copy","slice","rns","dd","rsoa","mname","rname","writeUInt32BE","serial","refresh","retry","expire","minimum","readUInt32BE","rtxt","isArray","from","isU8Arr","forEach","d","remaining","rnull","rhinfo","cpu","os","rptr","rsrv","priority","weight","port","target","rcaa","issuerCritical","ISSUER_CRITICAL","tag","value","rmx","preference","exchange","ra","host","v4","raaaa","v6","alloc","size","roption","option","code","toCode","spl","sourcePrefixLength","fam","family","familyOf","ipBuf","ipLen","Math","ceil","scopePrefixLength","timeout","fill","tagsLen","tags","padded","ropt","options","rdlen","encodingLengthList","encodeList","o","rdnskey","key","keydata","PROTOCOL_DNSSEC","algorithm","ZONE_KEY","SECURE_ENTRYPOINT","rrrsig","sig","signature","toType","typeCovered","labels","originalTTL","expiration","inception","keyTag","signersName","rrp","mbox","txt","typebitmap","typelist","typesByWindow","typeid","undefined","windowBuf","window","windowLength","j","extents","max","rnsec","record","nextDomain","rrtypes","rnsec3","salt","iterations","saltLength","hashLength","rds","digest","digestdata","digestType","renc","toUpperCase","answer","a","udpPayloadSize","extendedRcode","ednsVersion","klass","toClass","class","flush","ttl","enc","flag_do","question","q","qu","soa","null","unknown","ns","hinfo","ptr","cname","dname","srv","caa","mx","aaaa","opt","dnskey","rrsig","rp","nsec","nsec3","ds","AUTHORITATIVE_ANSWER","TRUNCATED_RESPONSE","RECURSION_DESIRED","RECURSION_AVAILABLE","AUTHENTIC_DATA","CHECKING_DISABLED","DNSSEC_OK","packet","result","allocing","decodeList","sanitizeSingle","input","sanitized","Object","assign","query","res","response","streamEncode","combine","byteLength","streamDecode","sbuf"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/@leichtgewicht/dns-packet/index.mjs\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(ssr)/./node_modules/@leichtgewicht/dns-packet/opcodes.mjs":
|
|
/*!************************************************************!*\
|
|
!*** ./node_modules/@leichtgewicht/dns-packet/opcodes.mjs ***!
|
|
\************************************************************/
|
|
/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => {
|
|
|
|
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ toOpcode: () => (/* binding */ toOpcode),\n/* harmony export */ toString: () => (/* binding */ toString)\n/* harmony export */ });\n/*\n * Traditional DNS header OPCODEs (4-bits) defined by IANA in\n * https://www.iana.org/assignments/dns-parameters/dns-parameters.xhtml#dns-parameters-5\n */ function toString(opcode) {\n switch(opcode){\n case 0:\n return \"QUERY\";\n case 1:\n return \"IQUERY\";\n case 2:\n return \"STATUS\";\n case 3:\n return \"OPCODE_3\";\n case 4:\n return \"NOTIFY\";\n case 5:\n return \"UPDATE\";\n case 6:\n return \"OPCODE_6\";\n case 7:\n return \"OPCODE_7\";\n case 8:\n return \"OPCODE_8\";\n case 9:\n return \"OPCODE_9\";\n case 10:\n return \"OPCODE_10\";\n case 11:\n return \"OPCODE_11\";\n case 12:\n return \"OPCODE_12\";\n case 13:\n return \"OPCODE_13\";\n case 14:\n return \"OPCODE_14\";\n case 15:\n return \"OPCODE_15\";\n }\n return \"OPCODE_\" + opcode;\n}\nfunction toOpcode(code) {\n switch(code.toUpperCase()){\n case \"QUERY\":\n return 0;\n case \"IQUERY\":\n return 1;\n case \"STATUS\":\n return 2;\n case \"OPCODE_3\":\n return 3;\n case \"NOTIFY\":\n return 4;\n case \"UPDATE\":\n return 5;\n case \"OPCODE_6\":\n return 6;\n case \"OPCODE_7\":\n return 7;\n case \"OPCODE_8\":\n return 8;\n case \"OPCODE_9\":\n return 9;\n case \"OPCODE_10\":\n return 10;\n case \"OPCODE_11\":\n return 11;\n case \"OPCODE_12\":\n return 12;\n case \"OPCODE_13\":\n return 13;\n case \"OPCODE_14\":\n return 14;\n case \"OPCODE_15\":\n return 15;\n }\n return 0;\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvQGxlaWNodGdld2ljaHQvZG5zLXBhY2tldC9vcGNvZGVzLm1qcyIsIm1hcHBpbmdzIjoiOzs7OztBQUFBOzs7Q0FHQyxHQUVNLFNBQVNBLFNBQVVDLE1BQU07SUFDOUIsT0FBUUE7UUFDTixLQUFLO1lBQUcsT0FBTztRQUNmLEtBQUs7WUFBRyxPQUFPO1FBQ2YsS0FBSztZQUFHLE9BQU87UUFDZixLQUFLO1lBQUcsT0FBTztRQUNmLEtBQUs7WUFBRyxPQUFPO1FBQ2YsS0FBSztZQUFHLE9BQU87UUFDZixLQUFLO1lBQUcsT0FBTztRQUNmLEtBQUs7WUFBRyxPQUFPO1FBQ2YsS0FBSztZQUFHLE9BQU87UUFDZixLQUFLO1lBQUcsT0FBTztRQUNmLEtBQUs7WUFBSSxPQUFPO1FBQ2hCLEtBQUs7WUFBSSxPQUFPO1FBQ2hCLEtBQUs7WUFBSSxPQUFPO1FBQ2hCLEtBQUs7WUFBSSxPQUFPO1FBQ2hCLEtBQUs7WUFBSSxPQUFPO1FBQ2hCLEtBQUs7WUFBSSxPQUFPO0lBQ2xCO0lBQ0EsT0FBTyxZQUFZQTtBQUNyQjtBQUVPLFNBQVNDLFNBQVVDLElBQUk7SUFDNUIsT0FBUUEsS0FBS0MsV0FBVztRQUN0QixLQUFLO1lBQVMsT0FBTztRQUNyQixLQUFLO1lBQVUsT0FBTztRQUN0QixLQUFLO1lBQVUsT0FBTztRQUN0QixLQUFLO1lBQVksT0FBTztRQUN4QixLQUFLO1lBQVUsT0FBTztRQUN0QixLQUFLO1lBQVUsT0FBTztRQUN0QixLQUFLO1lBQVksT0FBTztRQUN4QixLQUFLO1lBQVksT0FBTztRQUN4QixLQUFLO1lBQVksT0FBTztRQUN4QixLQUFLO1lBQVksT0FBTztRQUN4QixLQUFLO1lBQWEsT0FBTztRQUN6QixLQUFLO1lBQWEsT0FBTztRQUN6QixLQUFLO1lBQWEsT0FBTztRQUN6QixLQUFLO1lBQWEsT0FBTztRQUN6QixLQUFLO1lBQWEsT0FBTztRQUN6QixLQUFLO1lBQWEsT0FBTztJQUMzQjtJQUNBLE9BQU87QUFDVCIsInNvdXJjZXMiOlsid2VicGFjazovL2ZsdXNoLW5vdGVzLy4vbm9kZV9tb2R1bGVzL0BsZWljaHRnZXdpY2h0L2Rucy1wYWNrZXQvb3Bjb2Rlcy5tanM/YTcwMCJdLCJzb3VyY2VzQ29udGVudCI6WyIvKlxuICogVHJhZGl0aW9uYWwgRE5TIGhlYWRlciBPUENPREVzICg0LWJpdHMpIGRlZmluZWQgYnkgSUFOQSBpblxuICogaHR0cHM6Ly93d3cuaWFuYS5vcmcvYXNzaWdubWVudHMvZG5zLXBhcmFtZXRlcnMvZG5zLXBhcmFtZXRlcnMueGh0bWwjZG5zLXBhcmFtZXRlcnMtNVxuICovXG5cbmV4cG9ydCBmdW5jdGlvbiB0b1N0cmluZyAob3Bjb2RlKSB7XG4gIHN3aXRjaCAob3Bjb2RlKSB7XG4gICAgY2FzZSAwOiByZXR1cm4gJ1FVRVJZJ1xuICAgIGNhc2UgMTogcmV0dXJuICdJUVVFUlknXG4gICAgY2FzZSAyOiByZXR1cm4gJ1NUQVRVUydcbiAgICBjYXNlIDM6IHJldHVybiAnT1BDT0RFXzMnXG4gICAgY2FzZSA0OiByZXR1cm4gJ05PVElGWSdcbiAgICBjYXNlIDU6IHJldHVybiAnVVBEQVRFJ1xuICAgIGNhc2UgNjogcmV0dXJuICdPUENPREVfNidcbiAgICBjYXNlIDc6IHJldHVybiAnT1BDT0RFXzcnXG4gICAgY2FzZSA4OiByZXR1cm4gJ09QQ09ERV84J1xuICAgIGNhc2UgOTogcmV0dXJuICdPUENPREVfOSdcbiAgICBjYXNlIDEwOiByZXR1cm4gJ09QQ09ERV8xMCdcbiAgICBjYXNlIDExOiByZXR1cm4gJ09QQ09ERV8xMSdcbiAgICBjYXNlIDEyOiByZXR1cm4gJ09QQ09ERV8xMidcbiAgICBjYXNlIDEzOiByZXR1cm4gJ09QQ09ERV8xMydcbiAgICBjYXNlIDE0OiByZXR1cm4gJ09QQ09ERV8xNCdcbiAgICBjYXNlIDE1OiByZXR1cm4gJ09QQ09ERV8xNSdcbiAgfVxuICByZXR1cm4gJ09QQ09ERV8nICsgb3Bjb2RlXG59XG5cbmV4cG9ydCBmdW5jdGlvbiB0b09wY29kZSAoY29kZSkge1xuICBzd2l0Y2ggKGNvZGUudG9VcHBlckNhc2UoKSkge1xuICAgIGNhc2UgJ1FVRVJZJzogcmV0dXJuIDBcbiAgICBjYXNlICdJUVVFUlknOiByZXR1cm4gMVxuICAgIGNhc2UgJ1NUQVRVUyc6IHJldHVybiAyXG4gICAgY2FzZSAnT1BDT0RFXzMnOiByZXR1cm4gM1xuICAgIGNhc2UgJ05PVElGWSc6IHJldHVybiA0XG4gICAgY2FzZSAnVVBEQVRFJzogcmV0dXJuIDVcbiAgICBjYXNlICdPUENPREVfNic6IHJldHVybiA2XG4gICAgY2FzZSAnT1BDT0RFXzcnOiByZXR1cm4gN1xuICAgIGNhc2UgJ09QQ09ERV84JzogcmV0dXJuIDhcbiAgICBjYXNlICdPUENPREVfOSc6IHJldHVybiA5XG4gICAgY2FzZSAnT1BDT0RFXzEwJzogcmV0dXJuIDEwXG4gICAgY2FzZSAnT1BDT0RFXzExJzogcmV0dXJuIDExXG4gICAgY2FzZSAnT1BDT0RFXzEyJzogcmV0dXJuIDEyXG4gICAgY2FzZSAnT1BDT0RFXzEzJzogcmV0dXJuIDEzXG4gICAgY2FzZSAnT1BDT0RFXzE0JzogcmV0dXJuIDE0XG4gICAgY2FzZSAnT1BDT0RFXzE1JzogcmV0dXJuIDE1XG4gIH1cbiAgcmV0dXJuIDBcbn1cbiJdLCJuYW1lcyI6WyJ0b1N0cmluZyIsIm9wY29kZSIsInRvT3Bjb2RlIiwiY29kZSIsInRvVXBwZXJDYXNlIl0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/@leichtgewicht/dns-packet/opcodes.mjs\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(ssr)/./node_modules/@leichtgewicht/dns-packet/optioncodes.mjs":
|
|
/*!****************************************************************!*\
|
|
!*** ./node_modules/@leichtgewicht/dns-packet/optioncodes.mjs ***!
|
|
\****************************************************************/
|
|
/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => {
|
|
|
|
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ toCode: () => (/* binding */ toCode),\n/* harmony export */ toString: () => (/* binding */ toString)\n/* harmony export */ });\nfunction toString(type) {\n switch(type){\n // list at\n // https://www.iana.org/assignments/dns-parameters/dns-parameters.xhtml#dns-parameters-11\n case 1:\n return \"LLQ\";\n case 2:\n return \"UL\";\n case 3:\n return \"NSID\";\n case 5:\n return \"DAU\";\n case 6:\n return \"DHU\";\n case 7:\n return \"N3U\";\n case 8:\n return \"CLIENT_SUBNET\";\n case 9:\n return \"EXPIRE\";\n case 10:\n return \"COOKIE\";\n case 11:\n return \"TCP_KEEPALIVE\";\n case 12:\n return \"PADDING\";\n case 13:\n return \"CHAIN\";\n case 14:\n return \"KEY_TAG\";\n case 26946:\n return \"DEVICEID\";\n }\n if (type < 0) {\n return null;\n }\n return `OPTION_${type}`;\n}\nfunction toCode(name) {\n if (typeof name === \"number\") {\n return name;\n }\n if (!name) {\n return -1;\n }\n switch(name.toUpperCase()){\n case \"OPTION_0\":\n return 0;\n case \"LLQ\":\n return 1;\n case \"UL\":\n return 2;\n case \"NSID\":\n return 3;\n case \"OPTION_4\":\n return 4;\n case \"DAU\":\n return 5;\n case \"DHU\":\n return 6;\n case \"N3U\":\n return 7;\n case \"CLIENT_SUBNET\":\n return 8;\n case \"EXPIRE\":\n return 9;\n case \"COOKIE\":\n return 10;\n case \"TCP_KEEPALIVE\":\n return 11;\n case \"PADDING\":\n return 12;\n case \"CHAIN\":\n return 13;\n case \"KEY_TAG\":\n return 14;\n case \"DEVICEID\":\n return 26946;\n case \"OPTION_65535\":\n return 65535;\n }\n const m = name.match(/_(\\d+)$/);\n if (m) {\n return parseInt(m[1], 10);\n }\n return -1;\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvQGxlaWNodGdld2ljaHQvZG5zLXBhY2tldC9vcHRpb25jb2Rlcy5tanMiLCJtYXBwaW5ncyI6Ijs7Ozs7QUFBTyxTQUFTQSxTQUFVQyxJQUFJO0lBQzVCLE9BQVFBO1FBQ04sVUFBVTtRQUNWLHlGQUF5RjtRQUN6RixLQUFLO1lBQUcsT0FBTztRQUNmLEtBQUs7WUFBRyxPQUFPO1FBQ2YsS0FBSztZQUFHLE9BQU87UUFDZixLQUFLO1lBQUcsT0FBTztRQUNmLEtBQUs7WUFBRyxPQUFPO1FBQ2YsS0FBSztZQUFHLE9BQU87UUFDZixLQUFLO1lBQUcsT0FBTztRQUNmLEtBQUs7WUFBRyxPQUFPO1FBQ2YsS0FBSztZQUFJLE9BQU87UUFDaEIsS0FBSztZQUFJLE9BQU87UUFDaEIsS0FBSztZQUFJLE9BQU87UUFDaEIsS0FBSztZQUFJLE9BQU87UUFDaEIsS0FBSztZQUFJLE9BQU87UUFDaEIsS0FBSztZQUFPLE9BQU87SUFDckI7SUFDQSxJQUFJQSxPQUFPLEdBQUc7UUFDWixPQUFPO0lBQ1Q7SUFDQSxPQUFPLENBQUMsT0FBTyxFQUFFQSxLQUFLLENBQUM7QUFDekI7QUFFTyxTQUFTQyxPQUFRQyxJQUFJO0lBQzFCLElBQUksT0FBT0EsU0FBUyxVQUFVO1FBQzVCLE9BQU9BO0lBQ1Q7SUFDQSxJQUFJLENBQUNBLE1BQU07UUFDVCxPQUFPLENBQUM7SUFDVjtJQUNBLE9BQVFBLEtBQUtDLFdBQVc7UUFDdEIsS0FBSztZQUFZLE9BQU87UUFDeEIsS0FBSztZQUFPLE9BQU87UUFDbkIsS0FBSztZQUFNLE9BQU87UUFDbEIsS0FBSztZQUFRLE9BQU87UUFDcEIsS0FBSztZQUFZLE9BQU87UUFDeEIsS0FBSztZQUFPLE9BQU87UUFDbkIsS0FBSztZQUFPLE9BQU87UUFDbkIsS0FBSztZQUFPLE9BQU87UUFDbkIsS0FBSztZQUFpQixPQUFPO1FBQzdCLEtBQUs7WUFBVSxPQUFPO1FBQ3RCLEtBQUs7WUFBVSxPQUFPO1FBQ3RCLEtBQUs7WUFBaUIsT0FBTztRQUM3QixLQUFLO1lBQVcsT0FBTztRQUN2QixLQUFLO1lBQVMsT0FBTztRQUNyQixLQUFLO1lBQVcsT0FBTztRQUN2QixLQUFLO1lBQVksT0FBTztRQUN4QixLQUFLO1lBQWdCLE9BQU87SUFDOUI7SUFDQSxNQUFNQyxJQUFJRixLQUFLRyxLQUFLLENBQUM7SUFDckIsSUFBSUQsR0FBRztRQUNMLE9BQU9FLFNBQVNGLENBQUMsQ0FBQyxFQUFFLEVBQUU7SUFDeEI7SUFDQSxPQUFPLENBQUM7QUFDViIsInNvdXJjZXMiOlsid2VicGFjazovL2ZsdXNoLW5vdGVzLy4vbm9kZV9tb2R1bGVzL0BsZWljaHRnZXdpY2h0L2Rucy1wYWNrZXQvb3B0aW9uY29kZXMubWpzPzJjMGEiXSwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGZ1bmN0aW9uIHRvU3RyaW5nICh0eXBlKSB7XG4gIHN3aXRjaCAodHlwZSkge1xuICAgIC8vIGxpc3QgYXRcbiAgICAvLyBodHRwczovL3d3dy5pYW5hLm9yZy9hc3NpZ25tZW50cy9kbnMtcGFyYW1ldGVycy9kbnMtcGFyYW1ldGVycy54aHRtbCNkbnMtcGFyYW1ldGVycy0xMVxuICAgIGNhc2UgMTogcmV0dXJuICdMTFEnXG4gICAgY2FzZSAyOiByZXR1cm4gJ1VMJ1xuICAgIGNhc2UgMzogcmV0dXJuICdOU0lEJ1xuICAgIGNhc2UgNTogcmV0dXJuICdEQVUnXG4gICAgY2FzZSA2OiByZXR1cm4gJ0RIVSdcbiAgICBjYXNlIDc6IHJldHVybiAnTjNVJ1xuICAgIGNhc2UgODogcmV0dXJuICdDTElFTlRfU1VCTkVUJ1xuICAgIGNhc2UgOTogcmV0dXJuICdFWFBJUkUnXG4gICAgY2FzZSAxMDogcmV0dXJuICdDT09LSUUnXG4gICAgY2FzZSAxMTogcmV0dXJuICdUQ1BfS0VFUEFMSVZFJ1xuICAgIGNhc2UgMTI6IHJldHVybiAnUEFERElORydcbiAgICBjYXNlIDEzOiByZXR1cm4gJ0NIQUlOJ1xuICAgIGNhc2UgMTQ6IHJldHVybiAnS0VZX1RBRydcbiAgICBjYXNlIDI2OTQ2OiByZXR1cm4gJ0RFVklDRUlEJ1xuICB9XG4gIGlmICh0eXBlIDwgMCkge1xuICAgIHJldHVybiBudWxsXG4gIH1cbiAgcmV0dXJuIGBPUFRJT05fJHt0eXBlfWBcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIHRvQ29kZSAobmFtZSkge1xuICBpZiAodHlwZW9mIG5hbWUgPT09ICdudW1iZXInKSB7XG4gICAgcmV0dXJuIG5hbWVcbiAgfVxuICBpZiAoIW5hbWUpIHtcbiAgICByZXR1cm4gLTFcbiAgfVxuICBzd2l0Y2ggKG5hbWUudG9VcHBlckNhc2UoKSkge1xuICAgIGNhc2UgJ09QVElPTl8wJzogcmV0dXJuIDBcbiAgICBjYXNlICdMTFEnOiByZXR1cm4gMVxuICAgIGNhc2UgJ1VMJzogcmV0dXJuIDJcbiAgICBjYXNlICdOU0lEJzogcmV0dXJuIDNcbiAgICBjYXNlICdPUFRJT05fNCc6IHJldHVybiA0XG4gICAgY2FzZSAnREFVJzogcmV0dXJuIDVcbiAgICBjYXNlICdESFUnOiByZXR1cm4gNlxuICAgIGNhc2UgJ04zVSc6IHJldHVybiA3XG4gICAgY2FzZSAnQ0xJRU5UX1NVQk5FVCc6IHJldHVybiA4XG4gICAgY2FzZSAnRVhQSVJFJzogcmV0dXJuIDlcbiAgICBjYXNlICdDT09LSUUnOiByZXR1cm4gMTBcbiAgICBjYXNlICdUQ1BfS0VFUEFMSVZFJzogcmV0dXJuIDExXG4gICAgY2FzZSAnUEFERElORyc6IHJldHVybiAxMlxuICAgIGNhc2UgJ0NIQUlOJzogcmV0dXJuIDEzXG4gICAgY2FzZSAnS0VZX1RBRyc6IHJldHVybiAxNFxuICAgIGNhc2UgJ0RFVklDRUlEJzogcmV0dXJuIDI2OTQ2XG4gICAgY2FzZSAnT1BUSU9OXzY1NTM1JzogcmV0dXJuIDY1NTM1XG4gIH1cbiAgY29uc3QgbSA9IG5hbWUubWF0Y2goL18oXFxkKykkLylcbiAgaWYgKG0pIHtcbiAgICByZXR1cm4gcGFyc2VJbnQobVsxXSwgMTApXG4gIH1cbiAgcmV0dXJuIC0xXG59XG4iXSwibmFtZXMiOlsidG9TdHJpbmciLCJ0eXBlIiwidG9Db2RlIiwibmFtZSIsInRvVXBwZXJDYXNlIiwibSIsIm1hdGNoIiwicGFyc2VJbnQiXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/@leichtgewicht/dns-packet/optioncodes.mjs\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(ssr)/./node_modules/@leichtgewicht/dns-packet/rcodes.mjs":
|
|
/*!***********************************************************!*\
|
|
!*** ./node_modules/@leichtgewicht/dns-packet/rcodes.mjs ***!
|
|
\***********************************************************/
|
|
/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => {
|
|
|
|
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ toRcode: () => (/* binding */ toRcode),\n/* harmony export */ toString: () => (/* binding */ toString)\n/* harmony export */ });\n/*\n * Traditional DNS header RCODEs (4-bits) defined by IANA in\n * https://www.iana.org/assignments/dns-parameters/dns-parameters.xhtml\n */ function toString(rcode) {\n switch(rcode){\n case 0:\n return \"NOERROR\";\n case 1:\n return \"FORMERR\";\n case 2:\n return \"SERVFAIL\";\n case 3:\n return \"NXDOMAIN\";\n case 4:\n return \"NOTIMP\";\n case 5:\n return \"REFUSED\";\n case 6:\n return \"YXDOMAIN\";\n case 7:\n return \"YXRRSET\";\n case 8:\n return \"NXRRSET\";\n case 9:\n return \"NOTAUTH\";\n case 10:\n return \"NOTZONE\";\n case 11:\n return \"RCODE_11\";\n case 12:\n return \"RCODE_12\";\n case 13:\n return \"RCODE_13\";\n case 14:\n return \"RCODE_14\";\n case 15:\n return \"RCODE_15\";\n }\n return \"RCODE_\" + rcode;\n}\nfunction toRcode(code) {\n switch(code.toUpperCase()){\n case \"NOERROR\":\n return 0;\n case \"FORMERR\":\n return 1;\n case \"SERVFAIL\":\n return 2;\n case \"NXDOMAIN\":\n return 3;\n case \"NOTIMP\":\n return 4;\n case \"REFUSED\":\n return 5;\n case \"YXDOMAIN\":\n return 6;\n case \"YXRRSET\":\n return 7;\n case \"NXRRSET\":\n return 8;\n case \"NOTAUTH\":\n return 9;\n case \"NOTZONE\":\n return 10;\n case \"RCODE_11\":\n return 11;\n case \"RCODE_12\":\n return 12;\n case \"RCODE_13\":\n return 13;\n case \"RCODE_14\":\n return 14;\n case \"RCODE_15\":\n return 15;\n }\n return 0;\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvQGxlaWNodGdld2ljaHQvZG5zLXBhY2tldC9yY29kZXMubWpzIiwibWFwcGluZ3MiOiI7Ozs7O0FBQUE7OztDQUdDLEdBRU0sU0FBU0EsU0FBVUMsS0FBSztJQUM3QixPQUFRQTtRQUNOLEtBQUs7WUFBRyxPQUFPO1FBQ2YsS0FBSztZQUFHLE9BQU87UUFDZixLQUFLO1lBQUcsT0FBTztRQUNmLEtBQUs7WUFBRyxPQUFPO1FBQ2YsS0FBSztZQUFHLE9BQU87UUFDZixLQUFLO1lBQUcsT0FBTztRQUNmLEtBQUs7WUFBRyxPQUFPO1FBQ2YsS0FBSztZQUFHLE9BQU87UUFDZixLQUFLO1lBQUcsT0FBTztRQUNmLEtBQUs7WUFBRyxPQUFPO1FBQ2YsS0FBSztZQUFJLE9BQU87UUFDaEIsS0FBSztZQUFJLE9BQU87UUFDaEIsS0FBSztZQUFJLE9BQU87UUFDaEIsS0FBSztZQUFJLE9BQU87UUFDaEIsS0FBSztZQUFJLE9BQU87UUFDaEIsS0FBSztZQUFJLE9BQU87SUFDbEI7SUFDQSxPQUFPLFdBQVdBO0FBQ3BCO0FBRU8sU0FBU0MsUUFBU0MsSUFBSTtJQUMzQixPQUFRQSxLQUFLQyxXQUFXO1FBQ3RCLEtBQUs7WUFBVyxPQUFPO1FBQ3ZCLEtBQUs7WUFBVyxPQUFPO1FBQ3ZCLEtBQUs7WUFBWSxPQUFPO1FBQ3hCLEtBQUs7WUFBWSxPQUFPO1FBQ3hCLEtBQUs7WUFBVSxPQUFPO1FBQ3RCLEtBQUs7WUFBVyxPQUFPO1FBQ3ZCLEtBQUs7WUFBWSxPQUFPO1FBQ3hCLEtBQUs7WUFBVyxPQUFPO1FBQ3ZCLEtBQUs7WUFBVyxPQUFPO1FBQ3ZCLEtBQUs7WUFBVyxPQUFPO1FBQ3ZCLEtBQUs7WUFBVyxPQUFPO1FBQ3ZCLEtBQUs7WUFBWSxPQUFPO1FBQ3hCLEtBQUs7WUFBWSxPQUFPO1FBQ3hCLEtBQUs7WUFBWSxPQUFPO1FBQ3hCLEtBQUs7WUFBWSxPQUFPO1FBQ3hCLEtBQUs7WUFBWSxPQUFPO0lBQzFCO0lBQ0EsT0FBTztBQUNUIiwic291cmNlcyI6WyJ3ZWJwYWNrOi8vZmx1c2gtbm90ZXMvLi9ub2RlX21vZHVsZXMvQGxlaWNodGdld2ljaHQvZG5zLXBhY2tldC9yY29kZXMubWpzPzFjMzMiXSwic291cmNlc0NvbnRlbnQiOlsiLypcbiAqIFRyYWRpdGlvbmFsIEROUyBoZWFkZXIgUkNPREVzICg0LWJpdHMpIGRlZmluZWQgYnkgSUFOQSBpblxuICogaHR0cHM6Ly93d3cuaWFuYS5vcmcvYXNzaWdubWVudHMvZG5zLXBhcmFtZXRlcnMvZG5zLXBhcmFtZXRlcnMueGh0bWxcbiAqL1xuXG5leHBvcnQgZnVuY3Rpb24gdG9TdHJpbmcgKHJjb2RlKSB7XG4gIHN3aXRjaCAocmNvZGUpIHtcbiAgICBjYXNlIDA6IHJldHVybiAnTk9FUlJPUidcbiAgICBjYXNlIDE6IHJldHVybiAnRk9STUVSUidcbiAgICBjYXNlIDI6IHJldHVybiAnU0VSVkZBSUwnXG4gICAgY2FzZSAzOiByZXR1cm4gJ05YRE9NQUlOJ1xuICAgIGNhc2UgNDogcmV0dXJuICdOT1RJTVAnXG4gICAgY2FzZSA1OiByZXR1cm4gJ1JFRlVTRUQnXG4gICAgY2FzZSA2OiByZXR1cm4gJ1lYRE9NQUlOJ1xuICAgIGNhc2UgNzogcmV0dXJuICdZWFJSU0VUJ1xuICAgIGNhc2UgODogcmV0dXJuICdOWFJSU0VUJ1xuICAgIGNhc2UgOTogcmV0dXJuICdOT1RBVVRIJ1xuICAgIGNhc2UgMTA6IHJldHVybiAnTk9UWk9ORSdcbiAgICBjYXNlIDExOiByZXR1cm4gJ1JDT0RFXzExJ1xuICAgIGNhc2UgMTI6IHJldHVybiAnUkNPREVfMTInXG4gICAgY2FzZSAxMzogcmV0dXJuICdSQ09ERV8xMydcbiAgICBjYXNlIDE0OiByZXR1cm4gJ1JDT0RFXzE0J1xuICAgIGNhc2UgMTU6IHJldHVybiAnUkNPREVfMTUnXG4gIH1cbiAgcmV0dXJuICdSQ09ERV8nICsgcmNvZGVcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIHRvUmNvZGUgKGNvZGUpIHtcbiAgc3dpdGNoIChjb2RlLnRvVXBwZXJDYXNlKCkpIHtcbiAgICBjYXNlICdOT0VSUk9SJzogcmV0dXJuIDBcbiAgICBjYXNlICdGT1JNRVJSJzogcmV0dXJuIDFcbiAgICBjYXNlICdTRVJWRkFJTCc6IHJldHVybiAyXG4gICAgY2FzZSAnTlhET01BSU4nOiByZXR1cm4gM1xuICAgIGNhc2UgJ05PVElNUCc6IHJldHVybiA0XG4gICAgY2FzZSAnUkVGVVNFRCc6IHJldHVybiA1XG4gICAgY2FzZSAnWVhET01BSU4nOiByZXR1cm4gNlxuICAgIGNhc2UgJ1lYUlJTRVQnOiByZXR1cm4gN1xuICAgIGNhc2UgJ05YUlJTRVQnOiByZXR1cm4gOFxuICAgIGNhc2UgJ05PVEFVVEgnOiByZXR1cm4gOVxuICAgIGNhc2UgJ05PVFpPTkUnOiByZXR1cm4gMTBcbiAgICBjYXNlICdSQ09ERV8xMSc6IHJldHVybiAxMVxuICAgIGNhc2UgJ1JDT0RFXzEyJzogcmV0dXJuIDEyXG4gICAgY2FzZSAnUkNPREVfMTMnOiByZXR1cm4gMTNcbiAgICBjYXNlICdSQ09ERV8xNCc6IHJldHVybiAxNFxuICAgIGNhc2UgJ1JDT0RFXzE1JzogcmV0dXJuIDE1XG4gIH1cbiAgcmV0dXJuIDBcbn1cbiJdLCJuYW1lcyI6WyJ0b1N0cmluZyIsInJjb2RlIiwidG9SY29kZSIsImNvZGUiLCJ0b1VwcGVyQ2FzZSJdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/@leichtgewicht/dns-packet/rcodes.mjs\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(ssr)/./node_modules/@leichtgewicht/dns-packet/types.mjs":
|
|
/*!**********************************************************!*\
|
|
!*** ./node_modules/@leichtgewicht/dns-packet/types.mjs ***!
|
|
\**********************************************************/
|
|
/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => {
|
|
|
|
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ toString: () => (/* binding */ toString),\n/* harmony export */ toType: () => (/* binding */ toType)\n/* harmony export */ });\nfunction toString(type) {\n switch(type){\n case 1:\n return \"A\";\n case 10:\n return \"NULL\";\n case 28:\n return \"AAAA\";\n case 18:\n return \"AFSDB\";\n case 42:\n return \"APL\";\n case 257:\n return \"CAA\";\n case 60:\n return \"CDNSKEY\";\n case 59:\n return \"CDS\";\n case 37:\n return \"CERT\";\n case 5:\n return \"CNAME\";\n case 49:\n return \"DHCID\";\n case 32769:\n return \"DLV\";\n case 39:\n return \"DNAME\";\n case 48:\n return \"DNSKEY\";\n case 43:\n return \"DS\";\n case 55:\n return \"HIP\";\n case 13:\n return \"HINFO\";\n case 45:\n return \"IPSECKEY\";\n case 25:\n return \"KEY\";\n case 36:\n return \"KX\";\n case 29:\n return \"LOC\";\n case 15:\n return \"MX\";\n case 35:\n return \"NAPTR\";\n case 2:\n return \"NS\";\n case 47:\n return \"NSEC\";\n case 50:\n return \"NSEC3\";\n case 51:\n return \"NSEC3PARAM\";\n case 12:\n return \"PTR\";\n case 46:\n return \"RRSIG\";\n case 17:\n return \"RP\";\n case 24:\n return \"SIG\";\n case 6:\n return \"SOA\";\n case 99:\n return \"SPF\";\n case 33:\n return \"SRV\";\n case 44:\n return \"SSHFP\";\n case 32768:\n return \"TA\";\n case 249:\n return \"TKEY\";\n case 52:\n return \"TLSA\";\n case 250:\n return \"TSIG\";\n case 16:\n return \"TXT\";\n case 252:\n return \"AXFR\";\n case 251:\n return \"IXFR\";\n case 41:\n return \"OPT\";\n case 255:\n return \"ANY\";\n }\n return \"UNKNOWN_\" + type;\n}\nfunction toType(name) {\n switch(name.toUpperCase()){\n case \"A\":\n return 1;\n case \"NULL\":\n return 10;\n case \"AAAA\":\n return 28;\n case \"AFSDB\":\n return 18;\n case \"APL\":\n return 42;\n case \"CAA\":\n return 257;\n case \"CDNSKEY\":\n return 60;\n case \"CDS\":\n return 59;\n case \"CERT\":\n return 37;\n case \"CNAME\":\n return 5;\n case \"DHCID\":\n return 49;\n case \"DLV\":\n return 32769;\n case \"DNAME\":\n return 39;\n case \"DNSKEY\":\n return 48;\n case \"DS\":\n return 43;\n case \"HIP\":\n return 55;\n case \"HINFO\":\n return 13;\n case \"IPSECKEY\":\n return 45;\n case \"KEY\":\n return 25;\n case \"KX\":\n return 36;\n case \"LOC\":\n return 29;\n case \"MX\":\n return 15;\n case \"NAPTR\":\n return 35;\n case \"NS\":\n return 2;\n case \"NSEC\":\n return 47;\n case \"NSEC3\":\n return 50;\n case \"NSEC3PARAM\":\n return 51;\n case \"PTR\":\n return 12;\n case \"RRSIG\":\n return 46;\n case \"RP\":\n return 17;\n case \"SIG\":\n return 24;\n case \"SOA\":\n return 6;\n case \"SPF\":\n return 99;\n case \"SRV\":\n return 33;\n case \"SSHFP\":\n return 44;\n case \"TA\":\n return 32768;\n case \"TKEY\":\n return 249;\n case \"TLSA\":\n return 52;\n case \"TSIG\":\n return 250;\n case \"TXT\":\n return 16;\n case \"AXFR\":\n return 252;\n case \"IXFR\":\n return 251;\n case \"OPT\":\n return 41;\n case \"ANY\":\n return 255;\n case \"*\":\n return 255;\n }\n if (name.toUpperCase().startsWith(\"UNKNOWN_\")) return parseInt(name.slice(8));\n return 0;\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvQGxlaWNodGdld2ljaHQvZG5zLXBhY2tldC90eXBlcy5tanMiLCJtYXBwaW5ncyI6Ijs7Ozs7QUFBTyxTQUFTQSxTQUFVQyxJQUFJO0lBQzVCLE9BQVFBO1FBQ04sS0FBSztZQUFHLE9BQU87UUFDZixLQUFLO1lBQUksT0FBTztRQUNoQixLQUFLO1lBQUksT0FBTztRQUNoQixLQUFLO1lBQUksT0FBTztRQUNoQixLQUFLO1lBQUksT0FBTztRQUNoQixLQUFLO1lBQUssT0FBTztRQUNqQixLQUFLO1lBQUksT0FBTztRQUNoQixLQUFLO1lBQUksT0FBTztRQUNoQixLQUFLO1lBQUksT0FBTztRQUNoQixLQUFLO1lBQUcsT0FBTztRQUNmLEtBQUs7WUFBSSxPQUFPO1FBQ2hCLEtBQUs7WUFBTyxPQUFPO1FBQ25CLEtBQUs7WUFBSSxPQUFPO1FBQ2hCLEtBQUs7WUFBSSxPQUFPO1FBQ2hCLEtBQUs7WUFBSSxPQUFPO1FBQ2hCLEtBQUs7WUFBSSxPQUFPO1FBQ2hCLEtBQUs7WUFBSSxPQUFPO1FBQ2hCLEtBQUs7WUFBSSxPQUFPO1FBQ2hCLEtBQUs7WUFBSSxPQUFPO1FBQ2hCLEtBQUs7WUFBSSxPQUFPO1FBQ2hCLEtBQUs7WUFBSSxPQUFPO1FBQ2hCLEtBQUs7WUFBSSxPQUFPO1FBQ2hCLEtBQUs7WUFBSSxPQUFPO1FBQ2hCLEtBQUs7WUFBRyxPQUFPO1FBQ2YsS0FBSztZQUFJLE9BQU87UUFDaEIsS0FBSztZQUFJLE9BQU87UUFDaEIsS0FBSztZQUFJLE9BQU87UUFDaEIsS0FBSztZQUFJLE9BQU87UUFDaEIsS0FBSztZQUFJLE9BQU87UUFDaEIsS0FBSztZQUFJLE9BQU87UUFDaEIsS0FBSztZQUFJLE9BQU87UUFDaEIsS0FBSztZQUFHLE9BQU87UUFDZixLQUFLO1lBQUksT0FBTztRQUNoQixLQUFLO1lBQUksT0FBTztRQUNoQixLQUFLO1lBQUksT0FBTztRQUNoQixLQUFLO1lBQU8sT0FBTztRQUNuQixLQUFLO1lBQUssT0FBTztRQUNqQixLQUFLO1lBQUksT0FBTztRQUNoQixLQUFLO1lBQUssT0FBTztRQUNqQixLQUFLO1lBQUksT0FBTztRQUNoQixLQUFLO1lBQUssT0FBTztRQUNqQixLQUFLO1lBQUssT0FBTztRQUNqQixLQUFLO1lBQUksT0FBTztRQUNoQixLQUFLO1lBQUssT0FBTztJQUNuQjtJQUNBLE9BQU8sYUFBYUE7QUFDdEI7QUFFTyxTQUFTQyxPQUFRQyxJQUFJO0lBQzFCLE9BQVFBLEtBQUtDLFdBQVc7UUFDdEIsS0FBSztZQUFLLE9BQU87UUFDakIsS0FBSztZQUFRLE9BQU87UUFDcEIsS0FBSztZQUFRLE9BQU87UUFDcEIsS0FBSztZQUFTLE9BQU87UUFDckIsS0FBSztZQUFPLE9BQU87UUFDbkIsS0FBSztZQUFPLE9BQU87UUFDbkIsS0FBSztZQUFXLE9BQU87UUFDdkIsS0FBSztZQUFPLE9BQU87UUFDbkIsS0FBSztZQUFRLE9BQU87UUFDcEIsS0FBSztZQUFTLE9BQU87UUFDckIsS0FBSztZQUFTLE9BQU87UUFDckIsS0FBSztZQUFPLE9BQU87UUFDbkIsS0FBSztZQUFTLE9BQU87UUFDckIsS0FBSztZQUFVLE9BQU87UUFDdEIsS0FBSztZQUFNLE9BQU87UUFDbEIsS0FBSztZQUFPLE9BQU87UUFDbkIsS0FBSztZQUFTLE9BQU87UUFDckIsS0FBSztZQUFZLE9BQU87UUFDeEIsS0FBSztZQUFPLE9BQU87UUFDbkIsS0FBSztZQUFNLE9BQU87UUFDbEIsS0FBSztZQUFPLE9BQU87UUFDbkIsS0FBSztZQUFNLE9BQU87UUFDbEIsS0FBSztZQUFTLE9BQU87UUFDckIsS0FBSztZQUFNLE9BQU87UUFDbEIsS0FBSztZQUFRLE9BQU87UUFDcEIsS0FBSztZQUFTLE9BQU87UUFDckIsS0FBSztZQUFjLE9BQU87UUFDMUIsS0FBSztZQUFPLE9BQU87UUFDbkIsS0FBSztZQUFTLE9BQU87UUFDckIsS0FBSztZQUFNLE9BQU87UUFDbEIsS0FBSztZQUFPLE9BQU87UUFDbkIsS0FBSztZQUFPLE9BQU87UUFDbkIsS0FBSztZQUFPLE9BQU87UUFDbkIsS0FBSztZQUFPLE9BQU87UUFDbkIsS0FBSztZQUFTLE9BQU87UUFDckIsS0FBSztZQUFNLE9BQU87UUFDbEIsS0FBSztZQUFRLE9BQU87UUFDcEIsS0FBSztZQUFRLE9BQU87UUFDcEIsS0FBSztZQUFRLE9BQU87UUFDcEIsS0FBSztZQUFPLE9BQU87UUFDbkIsS0FBSztZQUFRLE9BQU87UUFDcEIsS0FBSztZQUFRLE9BQU87UUFDcEIsS0FBSztZQUFPLE9BQU87UUFDbkIsS0FBSztZQUFPLE9BQU87UUFDbkIsS0FBSztZQUFLLE9BQU87SUFDbkI7SUFDQSxJQUFJRCxLQUFLQyxXQUFXLEdBQUdDLFVBQVUsQ0FBQyxhQUFhLE9BQU9DLFNBQVNILEtBQUtJLEtBQUssQ0FBQztJQUMxRSxPQUFPO0FBQ1QiLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly9mbHVzaC1ub3Rlcy8uL25vZGVfbW9kdWxlcy9AbGVpY2h0Z2V3aWNodC9kbnMtcGFja2V0L3R5cGVzLm1qcz83OTJiIl0sInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBmdW5jdGlvbiB0b1N0cmluZyAodHlwZSkge1xuICBzd2l0Y2ggKHR5cGUpIHtcbiAgICBjYXNlIDE6IHJldHVybiAnQSdcbiAgICBjYXNlIDEwOiByZXR1cm4gJ05VTEwnXG4gICAgY2FzZSAyODogcmV0dXJuICdBQUFBJ1xuICAgIGNhc2UgMTg6IHJldHVybiAnQUZTREInXG4gICAgY2FzZSA0MjogcmV0dXJuICdBUEwnXG4gICAgY2FzZSAyNTc6IHJldHVybiAnQ0FBJ1xuICAgIGNhc2UgNjA6IHJldHVybiAnQ0ROU0tFWSdcbiAgICBjYXNlIDU5OiByZXR1cm4gJ0NEUydcbiAgICBjYXNlIDM3OiByZXR1cm4gJ0NFUlQnXG4gICAgY2FzZSA1OiByZXR1cm4gJ0NOQU1FJ1xuICAgIGNhc2UgNDk6IHJldHVybiAnREhDSUQnXG4gICAgY2FzZSAzMjc2OTogcmV0dXJuICdETFYnXG4gICAgY2FzZSAzOTogcmV0dXJuICdETkFNRSdcbiAgICBjYXNlIDQ4OiByZXR1cm4gJ0ROU0tFWSdcbiAgICBjYXNlIDQzOiByZXR1cm4gJ0RTJ1xuICAgIGNhc2UgNTU6IHJldHVybiAnSElQJ1xuICAgIGNhc2UgMTM6IHJldHVybiAnSElORk8nXG4gICAgY2FzZSA0NTogcmV0dXJuICdJUFNFQ0tFWSdcbiAgICBjYXNlIDI1OiByZXR1cm4gJ0tFWSdcbiAgICBjYXNlIDM2OiByZXR1cm4gJ0tYJ1xuICAgIGNhc2UgMjk6IHJldHVybiAnTE9DJ1xuICAgIGNhc2UgMTU6IHJldHVybiAnTVgnXG4gICAgY2FzZSAzNTogcmV0dXJuICdOQVBUUidcbiAgICBjYXNlIDI6IHJldHVybiAnTlMnXG4gICAgY2FzZSA0NzogcmV0dXJuICdOU0VDJ1xuICAgIGNhc2UgNTA6IHJldHVybiAnTlNFQzMnXG4gICAgY2FzZSA1MTogcmV0dXJuICdOU0VDM1BBUkFNJ1xuICAgIGNhc2UgMTI6IHJldHVybiAnUFRSJ1xuICAgIGNhc2UgNDY6IHJldHVybiAnUlJTSUcnXG4gICAgY2FzZSAxNzogcmV0dXJuICdSUCdcbiAgICBjYXNlIDI0OiByZXR1cm4gJ1NJRydcbiAgICBjYXNlIDY6IHJldHVybiAnU09BJ1xuICAgIGNhc2UgOTk6IHJldHVybiAnU1BGJ1xuICAgIGNhc2UgMzM6IHJldHVybiAnU1JWJ1xuICAgIGNhc2UgNDQ6IHJldHVybiAnU1NIRlAnXG4gICAgY2FzZSAzMjc2ODogcmV0dXJuICdUQSdcbiAgICBjYXNlIDI0OTogcmV0dXJuICdUS0VZJ1xuICAgIGNhc2UgNTI6IHJldHVybiAnVExTQSdcbiAgICBjYXNlIDI1MDogcmV0dXJuICdUU0lHJ1xuICAgIGNhc2UgMTY6IHJldHVybiAnVFhUJ1xuICAgIGNhc2UgMjUyOiByZXR1cm4gJ0FYRlInXG4gICAgY2FzZSAyNTE6IHJldHVybiAnSVhGUidcbiAgICBjYXNlIDQxOiByZXR1cm4gJ09QVCdcbiAgICBjYXNlIDI1NTogcmV0dXJuICdBTlknXG4gIH1cbiAgcmV0dXJuICdVTktOT1dOXycgKyB0eXBlXG59XG5cbmV4cG9ydCBmdW5jdGlvbiB0b1R5cGUgKG5hbWUpIHtcbiAgc3dpdGNoIChuYW1lLnRvVXBwZXJDYXNlKCkpIHtcbiAgICBjYXNlICdBJzogcmV0dXJuIDFcbiAgICBjYXNlICdOVUxMJzogcmV0dXJuIDEwXG4gICAgY2FzZSAnQUFBQSc6IHJldHVybiAyOFxuICAgIGNhc2UgJ0FGU0RCJzogcmV0dXJuIDE4XG4gICAgY2FzZSAnQVBMJzogcmV0dXJuIDQyXG4gICAgY2FzZSAnQ0FBJzogcmV0dXJuIDI1N1xuICAgIGNhc2UgJ0NETlNLRVknOiByZXR1cm4gNjBcbiAgICBjYXNlICdDRFMnOiByZXR1cm4gNTlcbiAgICBjYXNlICdDRVJUJzogcmV0dXJuIDM3XG4gICAgY2FzZSAnQ05BTUUnOiByZXR1cm4gNVxuICAgIGNhc2UgJ0RIQ0lEJzogcmV0dXJuIDQ5XG4gICAgY2FzZSAnRExWJzogcmV0dXJuIDMyNzY5XG4gICAgY2FzZSAnRE5BTUUnOiByZXR1cm4gMzlcbiAgICBjYXNlICdETlNLRVknOiByZXR1cm4gNDhcbiAgICBjYXNlICdEUyc6IHJldHVybiA0M1xuICAgIGNhc2UgJ0hJUCc6IHJldHVybiA1NVxuICAgIGNhc2UgJ0hJTkZPJzogcmV0dXJuIDEzXG4gICAgY2FzZSAnSVBTRUNLRVknOiByZXR1cm4gNDVcbiAgICBjYXNlICdLRVknOiByZXR1cm4gMjVcbiAgICBjYXNlICdLWCc6IHJldHVybiAzNlxuICAgIGNhc2UgJ0xPQyc6IHJldHVybiAyOVxuICAgIGNhc2UgJ01YJzogcmV0dXJuIDE1XG4gICAgY2FzZSAnTkFQVFInOiByZXR1cm4gMzVcbiAgICBjYXNlICdOUyc6IHJldHVybiAyXG4gICAgY2FzZSAnTlNFQyc6IHJldHVybiA0N1xuICAgIGNhc2UgJ05TRUMzJzogcmV0dXJuIDUwXG4gICAgY2FzZSAnTlNFQzNQQVJBTSc6IHJldHVybiA1MVxuICAgIGNhc2UgJ1BUUic6IHJldHVybiAxMlxuICAgIGNhc2UgJ1JSU0lHJzogcmV0dXJuIDQ2XG4gICAgY2FzZSAnUlAnOiByZXR1cm4gMTdcbiAgICBjYXNlICdTSUcnOiByZXR1cm4gMjRcbiAgICBjYXNlICdTT0EnOiByZXR1cm4gNlxuICAgIGNhc2UgJ1NQRic6IHJldHVybiA5OVxuICAgIGNhc2UgJ1NSVic6IHJldHVybiAzM1xuICAgIGNhc2UgJ1NTSEZQJzogcmV0dXJuIDQ0XG4gICAgY2FzZSAnVEEnOiByZXR1cm4gMzI3NjhcbiAgICBjYXNlICdUS0VZJzogcmV0dXJuIDI0OVxuICAgIGNhc2UgJ1RMU0EnOiByZXR1cm4gNTJcbiAgICBjYXNlICdUU0lHJzogcmV0dXJuIDI1MFxuICAgIGNhc2UgJ1RYVCc6IHJldHVybiAxNlxuICAgIGNhc2UgJ0FYRlInOiByZXR1cm4gMjUyXG4gICAgY2FzZSAnSVhGUic6IHJldHVybiAyNTFcbiAgICBjYXNlICdPUFQnOiByZXR1cm4gNDFcbiAgICBjYXNlICdBTlknOiByZXR1cm4gMjU1XG4gICAgY2FzZSAnKic6IHJldHVybiAyNTVcbiAgfVxuICBpZiAobmFtZS50b1VwcGVyQ2FzZSgpLnN0YXJ0c1dpdGgoJ1VOS05PV05fJykpIHJldHVybiBwYXJzZUludChuYW1lLnNsaWNlKDgpKVxuICByZXR1cm4gMFxufVxuIl0sIm5hbWVzIjpbInRvU3RyaW5nIiwidHlwZSIsInRvVHlwZSIsIm5hbWUiLCJ0b1VwcGVyQ2FzZSIsInN0YXJ0c1dpdGgiLCJwYXJzZUludCIsInNsaWNlIl0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/@leichtgewicht/dns-packet/types.mjs\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(ssr)/./node_modules/@leichtgewicht/dns-socket/index.mjs":
|
|
/*!**********************************************************!*\
|
|
!*** ./node_modules/@leichtgewicht/dns-socket/index.mjs ***!
|
|
\**********************************************************/
|
|
/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => {
|
|
|
|
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ DNSSocket: () => (/* binding */ DNSSocket)\n/* harmony export */ });\n/* harmony import */ var dgram__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! dgram */ \"dgram\");\n/* harmony import */ var _leichtgewicht_dns_packet__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @leichtgewicht/dns-packet */ \"(ssr)/./node_modules/@leichtgewicht/dns-packet/index.mjs\");\n/* harmony import */ var events__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! events */ \"events\");\n/* harmony import */ var buffer__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! buffer */ \"buffer\");\n\n\n\n\nclass DNSSocket extends events__WEBPACK_IMPORTED_MODULE_2__.EventEmitter {\n constructor(opts = {}){\n super();\n this.retries = opts.retries !== undefined ? opts.retries : 5;\n this.timeout = opts.timeout || 7500;\n this.timeoutChecks = opts.timeoutChecks || this.timeout / 10;\n this.destroyed = false;\n this.inflight = 0;\n this.raw = opts.raw === true;\n this.maxQueries = opts.maxQueries || 10000;\n this.maxRedirects = opts.maxRedirects || 0;\n this.socket = opts.socket || dgram__WEBPACK_IMPORTED_MODULE_0__.createSocket(\"udp4\");\n this._id = Math.ceil(Math.random() * this.maxQueries);\n this._queries = new Array(this.maxQueries).fill(null);\n this._interval = null;\n this.socket.on(\"error\", (err)=>{\n if (err.code === \"EACCES\" || err.code === \"EADDRINUSE\") {\n this.emit(\"error\", err);\n } else {\n this.emit(\"warning\", err);\n }\n });\n this.socket.on(\"message\", (message, rinfo)=>{\n this._onmessage(message, rinfo);\n });\n const onlistening = ()=>{\n this._interval = setInterval(()=>this._ontimeoutCheck(), this.timeoutChecks);\n this.emit(\"listening\");\n };\n if (isListening(this.socket)) onlistening();\n else this.socket.on(\"listening\", onlistening);\n this.socket.on(\"close\", ()=>this.emit(\"close\"));\n }\n address() {\n return this.socket.address();\n }\n bind(...args) {\n const onlistening = args.length > 0 && args[args.length - 1];\n if (typeof onlistening === \"function\") {\n this.once(\"listening\", onlistening);\n this.socket.bind(...args.slice(0, -1));\n } else {\n this.socket.bind(...args);\n }\n }\n destroy(onclose) {\n if (onclose) {\n this.once(\"close\", onclose);\n }\n if (this.destroyed) {\n return;\n }\n this.destroyed = true;\n clearInterval(this._interval);\n this.socket.close();\n for(let i = 0; i < this.maxQueries; i++){\n const q = this._queries[i];\n if (q) {\n q.callback(new Error(\"Socket destroyed\"));\n this._queries[i] = null;\n }\n }\n this.inflight = 0;\n }\n _ontimeoutCheck() {\n const now = Date.now();\n for(let i = 0; i < this.maxQueries; i++){\n const q = this._queries[i];\n if (!q || now - q.firstTry < (q.tries + 1) * this.timeout) {\n continue;\n }\n if (q.tries > this.retries) {\n this._queries[i] = null;\n this.inflight--;\n this.emit(\"timeout\", q.query, q.port, q.host);\n q.callback(new Error(\"Query timed out\"));\n continue;\n }\n q.tries++;\n this.socket.send(q.buffer, 0, q.buffer.length, q.port, Array.isArray(q.host) ? q.host[Math.floor(q.host.length * Math.random())] : q.host || \"127.0.0.1\");\n }\n }\n _shouldRedirect(q, result) {\n // no redirects, no query, more than 1 questions, has any A record answer\n if (this.maxRedirects <= 0 || !q || q.query.questions.length !== 1 || result.answers.filter((e)=>e.type === \"A\").length > 0) {\n return false;\n }\n // no more redirects left\n if (q.redirects > this.maxRedirects) {\n return false;\n }\n const cnameresults = result.answers.filter((e)=>e.type === \"CNAME\");\n if (cnameresults.length === 0) {\n return false;\n }\n const id = this._getNextEmptyId();\n if (id === -1) {\n q.callback(new Error(\"Query array is full!\"));\n return true;\n }\n // replace current query with a new one\n q.query = {\n id: id + 1,\n flags: _leichtgewicht_dns_packet__WEBPACK_IMPORTED_MODULE_1__.RECURSION_DESIRED,\n questions: [\n {\n type: \"A\",\n name: cnameresults[0].data\n }\n ]\n };\n q.redirects++;\n q.firstTry = Date.now();\n q.tries = 0;\n q.buffer = buffer__WEBPACK_IMPORTED_MODULE_3__.Buffer.alloc(_leichtgewicht_dns_packet__WEBPACK_IMPORTED_MODULE_1__.encodingLength(q.query));\n _leichtgewicht_dns_packet__WEBPACK_IMPORTED_MODULE_1__.encode(q.query, q.buffer);\n this._queries[id] = q;\n this.socket.send(q.buffer, 0, q.buffer.length, q.port, Array.isArray(q.host) ? q.host[Math.floor(q.host.length * Math.random())] : q.host || \"127.0.0.1\");\n return true;\n }\n _onmessage(buffer, rinfo) {\n let message;\n try {\n message = _leichtgewicht_dns_packet__WEBPACK_IMPORTED_MODULE_1__.decode(buffer);\n } catch (err) {\n this.emit(\"warning\", err);\n return;\n }\n if (message.type === \"response\" && message.id) {\n const q = this._queries[message.id - 1];\n if (q) {\n this._queries[message.id - 1] = null;\n this.inflight--;\n if (!this._shouldRedirect(q, message)) {\n q.callback(null, message);\n }\n }\n }\n this.emit(message.type, message, rinfo.port, rinfo.address);\n }\n unref() {\n this.socket.unref();\n }\n ref() {\n this.socket.ref();\n }\n response(query, response, port, host) {\n if (this.destroyed) {\n return;\n }\n response.type = \"response\";\n response.id = query.id;\n const buffer = buffer__WEBPACK_IMPORTED_MODULE_3__.Buffer.alloc(_leichtgewicht_dns_packet__WEBPACK_IMPORTED_MODULE_1__.encodingLength(response));\n _leichtgewicht_dns_packet__WEBPACK_IMPORTED_MODULE_1__.encode(response, buffer);\n this.socket.send(buffer, 0, buffer.length, port, host);\n }\n cancel(id) {\n const q = this._queries[id];\n if (!q) return;\n this._queries[id] = null;\n this.inflight--;\n q.callback(new Error(\"Query cancelled\"));\n }\n setRetries(id, retries) {\n const q = this._queries[id];\n if (!q) return;\n q.firstTry = q.firstTry - this.timeout * (retries - q.retries);\n q.retries = this.retries - retries;\n }\n _getNextEmptyId() {\n // try to find the next unused id\n let id = -1;\n for(let idtries = this.maxQueries; idtries > 0; idtries--){\n const normalizedId = (this._id + idtries) % this.maxQueries;\n if (this._queries[normalizedId] === null) {\n id = normalizedId;\n this._id = (normalizedId + 1) % this.maxQueries;\n break;\n }\n }\n return id;\n }\n query(query, port, host, cb) {\n if (this.destroyed) {\n cb(new Error(\"Socket destroyed\"));\n return 0;\n }\n this.inflight++;\n query.type = \"query\";\n query.flags = typeof query.flags === \"number\" ? query.flags : DNSSocket.RECURSION_DESIRED;\n const id = this._getNextEmptyId();\n if (id === -1) {\n cb(new Error(\"Query array is full!\"));\n return 0;\n }\n query.id = id + 1;\n const buffer = buffer__WEBPACK_IMPORTED_MODULE_3__.Buffer.alloc(_leichtgewicht_dns_packet__WEBPACK_IMPORTED_MODULE_1__.encodingLength(query));\n _leichtgewicht_dns_packet__WEBPACK_IMPORTED_MODULE_1__.encode(query, buffer);\n this._queries[id] = {\n callback: cb || noop,\n redirects: 0,\n firstTry: Date.now(),\n query,\n tries: 0,\n buffer,\n port,\n host\n };\n this.socket.send(buffer, 0, buffer.length, port, Array.isArray(host) ? host[Math.floor(host.length * Math.random())] : host || \"127.0.0.1\");\n return id;\n }\n}\nDNSSocket.RECURSION_DESIRED = DNSSocket.prototype.RECURSION_DESIRED = _leichtgewicht_dns_packet__WEBPACK_IMPORTED_MODULE_1__.RECURSION_DESIRED;\nDNSSocket.RECURSION_AVAILABLE = DNSSocket.prototype.RECURSION_AVAILABLE = _leichtgewicht_dns_packet__WEBPACK_IMPORTED_MODULE_1__.RECURSION_AVAILABLE;\nDNSSocket.TRUNCATED_RESPONSE = DNSSocket.prototype.TRUNCATED_RESPONSE = _leichtgewicht_dns_packet__WEBPACK_IMPORTED_MODULE_1__.TRUNCATED_RESPONSE;\nDNSSocket.AUTHORITATIVE_ANSWER = DNSSocket.prototype.AUTHORITATIVE_ANSWER = _leichtgewicht_dns_packet__WEBPACK_IMPORTED_MODULE_1__.AUTHORITATIVE_ANSWER;\nDNSSocket.AUTHENTIC_DATA = DNSSocket.prototype.AUTHENTIC_DATA = _leichtgewicht_dns_packet__WEBPACK_IMPORTED_MODULE_1__.AUTHENTIC_DATA;\nDNSSocket.CHECKING_DISABLED = DNSSocket.prototype.CHECKING_DISABLED = _leichtgewicht_dns_packet__WEBPACK_IMPORTED_MODULE_1__.CHECKING_DISABLED;\nfunction noop() {}\nfunction isListening(socket) {\n try {\n return socket.address().port !== 0;\n } catch (err) {\n return false;\n }\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"(ssr)/./node_modules/@leichtgewicht/dns-socket/index.mjs","mappings":"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","sources":["webpack://flush-notes/./node_modules/@leichtgewicht/dns-socket/index.mjs?855e"],"sourcesContent":["import dgram from 'dgram'\nimport * as packet from '@leichtgewicht/dns-packet'\nimport { EventEmitter } from 'events'\nimport { Buffer } from 'buffer'\n\nexport class DNSSocket extends EventEmitter {\n  constructor (opts = {}) {\n    super()\n\n    this.retries = opts.retries !== undefined ? opts.retries : 5\n    this.timeout = opts.timeout || 7500\n    this.timeoutChecks = opts.timeoutChecks || (this.timeout / 10)\n    this.destroyed = false\n    this.inflight = 0\n    this.raw = opts.raw === true\n    this.maxQueries = opts.maxQueries || 10000\n    this.maxRedirects = opts.maxRedirects || 0\n    this.socket = opts.socket || dgram.createSocket('udp4')\n    this._id = Math.ceil(Math.random() * this.maxQueries)\n    this._queries = new Array(this.maxQueries).fill(null)\n    this._interval = null\n\n    this.socket.on('error', err => {\n      if (err.code === 'EACCES' || err.code === 'EADDRINUSE') {\n        this.emit('error', err)\n      } else {\n        this.emit('warning', err)\n      }\n    })\n    this.socket.on('message', (message, rinfo) => {\n      this._onmessage(message, rinfo)\n    })\n\n    const onlistening = () => {\n      this._interval = setInterval(() => this._ontimeoutCheck(), this.timeoutChecks)\n      this.emit('listening')\n    }\n\n    if (isListening(this.socket)) onlistening()\n    else this.socket.on('listening', onlistening)\n    this.socket.on(\n      'close',\n      () => this.emit('close')\n    )\n  }\n\n  address () {\n    return this.socket.address()\n  }\n\n  bind (...args) {\n    const onlistening = args.length > 0 && args[args.length - 1]\n    if (typeof onlistening === 'function') {\n      this.once('listening', onlistening)\n      this.socket.bind(...args.slice(0, -1))\n    } else {\n      this.socket.bind(...args)\n    }\n  }\n\n  destroy (onclose) {\n    if (onclose) {\n      this.once('close', onclose)\n    }\n    if (this.destroyed) {\n      return\n    }\n    this.destroyed = true\n    clearInterval(this._interval)\n    this.socket.close()\n\n    for (let i = 0; i < this.maxQueries; i++) {\n      const q = this._queries[i]\n      if (q) {\n        q.callback(new Error('Socket destroyed'))\n        this._queries[i] = null\n      }\n    }\n    this.inflight = 0\n  }\n\n  _ontimeoutCheck () {\n    const now = Date.now()\n    for (let i = 0; i < this.maxQueries; i++) {\n      const q = this._queries[i]\n\n      if ((!q) || (now - q.firstTry < (q.tries + 1) * this.timeout)) {\n        continue\n      }\n\n      if (q.tries > this.retries) {\n        this._queries[i] = null\n        this.inflight--\n        this.emit('timeout', q.query, q.port, q.host)\n        q.callback(new Error('Query timed out'))\n        continue\n      }\n      q.tries++\n      this.socket.send(q.buffer, 0, q.buffer.length, q.port, Array.isArray(q.host) ? q.host[Math.floor(q.host.length * Math.random())] : q.host || '127.0.0.1')\n    }\n  }\n\n  _shouldRedirect (q, result) {\n    // no redirects, no query, more than 1 questions, has any A record answer\n    if (this.maxRedirects <= 0 || (!q) || (q.query.questions.length !== 1) || result.answers.filter(e => e.type === 'A').length > 0) {\n      return false\n    }\n\n    // no more redirects left\n    if (q.redirects > this.maxRedirects) {\n      return false\n    }\n\n    const cnameresults = result.answers.filter(e => e.type === 'CNAME')\n    if (cnameresults.length === 0) {\n      return false\n    }\n\n    const id = this._getNextEmptyId()\n    if (id === -1) {\n      q.callback(new Error('Query array is full!'))\n      return true\n    }\n\n    // replace current query with a new one\n    q.query = {\n      id: id + 1,\n      flags: packet.RECURSION_DESIRED,\n      questions: [{\n        type: 'A',\n        name: cnameresults[0].data\n      }]\n    }\n    q.redirects++\n    q.firstTry = Date.now()\n    q.tries = 0\n    q.buffer = Buffer.alloc(packet.encodingLength(q.query))\n    packet.encode(q.query, q.buffer)\n    this._queries[id] = q\n    this.socket.send(q.buffer, 0, q.buffer.length, q.port, Array.isArray(q.host) ? q.host[Math.floor(q.host.length * Math.random())] : q.host || '127.0.0.1')\n    return true\n  }\n\n  _onmessage (buffer, rinfo) {\n    let message\n\n    try {\n      message = packet.decode(buffer)\n    } catch (err) {\n      this.emit('warning', err)\n      return\n    }\n\n    if (message.type === 'response' && message.id) {\n      const q = this._queries[message.id - 1]\n      if (q) {\n        this._queries[message.id - 1] = null\n        this.inflight--\n\n        if (!this._shouldRedirect(q, message)) {\n          q.callback(null, message)\n        }\n      }\n    }\n\n    this.emit(message.type, message, rinfo.port, rinfo.address)\n  }\n\n  unref () {\n    this.socket.unref()\n  }\n\n  ref () {\n    this.socket.ref()\n  }\n\n  response (query, response, port, host) {\n    if (this.destroyed) {\n      return\n    }\n\n    response.type = 'response'\n    response.id = query.id\n    const buffer = Buffer.alloc(packet.encodingLength(response))\n    packet.encode(response, buffer)\n    this.socket.send(buffer, 0, buffer.length, port, host)\n  }\n\n  cancel (id) {\n    const q = this._queries[id]\n    if (!q) return\n\n    this._queries[id] = null\n    this.inflight--\n    q.callback(new Error('Query cancelled'))\n  }\n\n  setRetries (id, retries) {\n    const q = this._queries[id]\n    if (!q) return\n    q.firstTry = q.firstTry - this.timeout * (retries - q.retries)\n    q.retries = this.retries - retries\n  }\n\n  _getNextEmptyId () {\n    // try to find the next unused id\n    let id = -1\n    for (let idtries = this.maxQueries; idtries > 0; idtries--) {\n      const normalizedId = (this._id + idtries) % this.maxQueries\n      if (this._queries[normalizedId] === null) {\n        id = normalizedId\n        this._id = (normalizedId + 1) % this.maxQueries\n        break\n      }\n    }\n    return id\n  }\n\n  query (query, port, host, cb) {\n    if (this.destroyed) {\n      cb(new Error('Socket destroyed'))\n      return 0\n    }\n\n    this.inflight++\n    query.type = 'query'\n    query.flags = typeof query.flags === 'number' ? query.flags : DNSSocket.RECURSION_DESIRED\n\n    const id = this._getNextEmptyId()\n    if (id === -1) {\n      cb(new Error('Query array is full!'))\n      return 0\n    }\n\n    query.id = id + 1\n    const buffer = Buffer.alloc(packet.encodingLength(query))\n    packet.encode(query, buffer)\n\n    this._queries[id] = {\n      callback: cb || noop,\n      redirects: 0,\n      firstTry: Date.now(),\n      query,\n      tries: 0,\n      buffer,\n      port,\n      host\n    }\n    this.socket.send(buffer, 0, buffer.length, port, Array.isArray(host) ? host[Math.floor(host.length * Math.random())] : host || '127.0.0.1')\n    return id\n  }\n}\n\nDNSSocket.RECURSION_DESIRED = DNSSocket.prototype.RECURSION_DESIRED = packet.RECURSION_DESIRED\nDNSSocket.RECURSION_AVAILABLE = DNSSocket.prototype.RECURSION_AVAILABLE = packet.RECURSION_AVAILABLE\nDNSSocket.TRUNCATED_RESPONSE = DNSSocket.prototype.TRUNCATED_RESPONSE = packet.TRUNCATED_RESPONSE\nDNSSocket.AUTHORITATIVE_ANSWER = DNSSocket.prototype.AUTHORITATIVE_ANSWER = packet.AUTHORITATIVE_ANSWER\nDNSSocket.AUTHENTIC_DATA = DNSSocket.prototype.AUTHENTIC_DATA = packet.AUTHENTIC_DATA\nDNSSocket.CHECKING_DISABLED = DNSSocket.prototype.CHECKING_DISABLED = packet.CHECKING_DISABLED\n\nfunction noop () {\n}\n\nfunction isListening (socket) {\n  try {\n    return socket.address().port !== 0\n  } catch (err) {\n    return false\n  }\n}\n"],"names":["dgram","packet","EventEmitter","Buffer","DNSSocket","constructor","opts","retries","undefined","timeout","timeoutChecks","destroyed","inflight","raw","maxQueries","maxRedirects","socket","createSocket","_id","Math","ceil","random","_queries","Array","fill","_interval","on","err","code","emit","message","rinfo","_onmessage","onlistening","setInterval","_ontimeoutCheck","isListening","address","bind","args","length","once","slice","destroy","onclose","clearInterval","close","i","q","callback","Error","now","Date","firstTry","tries","query","port","host","send","buffer","isArray","floor","_shouldRedirect","result","questions","answers","filter","e","type","redirects","cnameresults","id","_getNextEmptyId","flags","RECURSION_DESIRED","name","data","alloc","encodingLength","encode","decode","unref","ref","response","cancel","setRetries","idtries","normalizedId","cb","noop","prototype","RECURSION_AVAILABLE","TRUNCATED_RESPONSE","AUTHORITATIVE_ANSWER","AUTHENTIC_DATA","CHECKING_DISABLED"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/@leichtgewicht/dns-socket/index.mjs\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(ssr)/./node_modules/@leichtgewicht/ip-codec/index.mjs":
|
|
/*!********************************************************!*\
|
|
!*** ./node_modules/@leichtgewicht/ip-codec/index.mjs ***!
|
|
\********************************************************/
|
|
/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => {
|
|
|
|
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ decode: () => (/* binding */ decode),\n/* harmony export */ encode: () => (/* binding */ encode),\n/* harmony export */ familyOf: () => (/* binding */ familyOf),\n/* harmony export */ name: () => (/* binding */ name),\n/* harmony export */ sizeOf: () => (/* binding */ sizeOf),\n/* harmony export */ v4: () => (/* binding */ v4),\n/* harmony export */ v6: () => (/* binding */ v6)\n/* harmony export */ });\nconst v4Regex = /^(\\d{1,3}\\.){3,3}\\d{1,3}$/;\nconst v4Size = 4;\nconst v6Regex = /^(::)?(((\\d{1,3}\\.){3}(\\d{1,3}){1})?([0-9a-f]){0,4}:{0,2}){1,8}(::)?$/i;\nconst v6Size = 16;\nconst v4 = {\n name: \"v4\",\n size: v4Size,\n isFormat: (ip)=>v4Regex.test(ip),\n encode (ip, buff, offset) {\n offset = ~~offset;\n buff = buff || new Uint8Array(offset + v4Size);\n const max = ip.length;\n let n = 0;\n for(let i = 0; i < max;){\n const c = ip.charCodeAt(i++);\n if (c === 46) {\n buff[offset++] = n;\n n = 0;\n } else {\n n = n * 10 + (c - 48);\n }\n }\n buff[offset] = n;\n return buff;\n },\n decode (buff, offset) {\n offset = ~~offset;\n return `${buff[offset++]}.${buff[offset++]}.${buff[offset++]}.${buff[offset]}`;\n }\n};\nconst v6 = {\n name: \"v6\",\n size: v6Size,\n isFormat: (ip)=>ip.length > 0 && v6Regex.test(ip),\n encode (ip, buff, offset) {\n offset = ~~offset;\n let end = offset + v6Size;\n let fill = -1;\n let hexN = 0;\n let decN = 0;\n let prevColon = true;\n let useDec = false;\n buff = buff || new Uint8Array(offset + v6Size);\n // Note: This algorithm needs to check if the offset\n // could exceed the buffer boundaries as it supports\n // non-standard compliant encodings that may go beyond\n // the boundary limits. if (offset < end) checks should\n // not be necessary...\n for(let i = 0; i < ip.length; i++){\n let c = ip.charCodeAt(i);\n if (c === 58) {\n if (prevColon) {\n if (fill !== -1) {\n // Not Standard! (standard doesn't allow multiple ::)\n // We need to treat\n if (offset < end) buff[offset] = 0;\n if (offset < end - 1) buff[offset + 1] = 0;\n offset += 2;\n } else if (offset < end) {\n // :: in the middle\n fill = offset;\n }\n } else {\n // : ends the previous number\n if (useDec === true) {\n // Non-standard! (ipv4 should be at end only)\n // A ipv4 address should not be found anywhere else but at\n // the end. This codec also support putting characters\n // after the ipv4 address..\n if (offset < end) buff[offset] = decN;\n offset++;\n } else {\n if (offset < end) buff[offset] = hexN >> 8;\n if (offset < end - 1) buff[offset + 1] = hexN & 0xff;\n offset += 2;\n }\n hexN = 0;\n decN = 0;\n }\n prevColon = true;\n useDec = false;\n } else if (c === 46) {\n if (offset < end) buff[offset] = decN;\n offset++;\n decN = 0;\n hexN = 0;\n prevColon = false;\n useDec = true;\n } else {\n prevColon = false;\n if (c >= 97) {\n c -= 87 // a-f ... 97~102 -87 => 10~15\n ;\n } else if (c >= 65) {\n c -= 55 // A-F ... 65~70 -55 => 10~15\n ;\n } else {\n c -= 48 // 0-9 ... starting from charCode 48\n ;\n decN = decN * 10 + c;\n }\n // We don't know yet if its a dec or hex number\n hexN = (hexN << 4) + c;\n }\n }\n if (prevColon === false) {\n // Commiting last number\n if (useDec === true) {\n if (offset < end) buff[offset] = decN;\n offset++;\n } else {\n if (offset < end) buff[offset] = hexN >> 8;\n if (offset < end - 1) buff[offset + 1] = hexN & 0xff;\n offset += 2;\n }\n } else if (fill === 0) {\n // Not Standard! (standard doesn't allow multiple ::)\n // This means that a : was found at the start AND end which means the\n // end needs to be treated as 0 entry...\n if (offset < end) buff[offset] = 0;\n if (offset < end - 1) buff[offset + 1] = 0;\n offset += 2;\n } else if (fill !== -1) {\n // Non-standard! (standard doens't allow multiple ::)\n // Here we find that there has been a :: somewhere in the middle\n // and the end. To treat the end with priority we need to move all\n // written data two bytes to the right.\n offset += 2;\n for(let i = Math.min(offset - 1, end - 1); i >= fill + 2; i--){\n buff[i] = buff[i - 2];\n }\n buff[fill] = 0;\n buff[fill + 1] = 0;\n fill = offset;\n }\n if (fill !== offset && fill !== -1) {\n // Move the written numbers to the end while filling the everything\n // \"fill\" to the bytes with zeros.\n if (offset > end - 2) {\n // Non Standard support, when the cursor exceeds bounds.\n offset = end - 2;\n }\n while(end > fill){\n buff[--end] = offset < end && offset > fill ? buff[--offset] : 0;\n }\n } else {\n // Fill the rest with zeros\n while(offset < end){\n buff[offset++] = 0;\n }\n }\n return buff;\n },\n decode (buff, offset) {\n offset = ~~offset;\n let result = \"\";\n for(let i = 0; i < v6Size; i += 2){\n if (i !== 0) {\n result += \":\";\n }\n result += (buff[offset + i] << 8 | buff[offset + i + 1]).toString(16);\n }\n return result.replace(/(^|:)0(:0)*:0(:|$)/, \"$1::$3\").replace(/:{3,4}/, \"::\");\n }\n};\nconst name = \"ip\";\nfunction sizeOf(ip) {\n if (v4.isFormat(ip)) return v4.size;\n if (v6.isFormat(ip)) return v6.size;\n throw Error(`Invalid ip address: ${ip}`);\n}\nfunction familyOf(string) {\n return sizeOf(string) === v4.size ? 1 : 2;\n}\nfunction encode(ip, buff, offset) {\n offset = ~~offset;\n const size = sizeOf(ip);\n if (typeof buff === \"function\") {\n buff = buff(offset + size);\n }\n if (size === v4.size) {\n return v4.encode(ip, buff, offset);\n }\n return v6.encode(ip, buff, offset);\n}\nfunction decode(buff, offset, length) {\n offset = ~~offset;\n length = length || buff.length - offset;\n if (length === v4.size) {\n return v4.decode(buff, offset, length);\n }\n if (length === v6.size) {\n return v6.decode(buff, offset, length);\n }\n throw Error(`Invalid buffer size needs to be ${v4.size} for v4 or ${v6.size} for v6.`);\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"(ssr)/./node_modules/@leichtgewicht/ip-codec/index.mjs","mappings":"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","sources":["webpack://flush-notes/./node_modules/@leichtgewicht/ip-codec/index.mjs?f93c"],"sourcesContent":["const v4Regex = /^(\\d{1,3}\\.){3,3}\\d{1,3}$/\nconst v4Size = 4\nconst v6Regex = /^(::)?(((\\d{1,3}\\.){3}(\\d{1,3}){1})?([0-9a-f]){0,4}:{0,2}){1,8}(::)?$/i\nconst v6Size = 16\n\nexport const v4 = {\n  name: 'v4',\n  size: v4Size,\n  isFormat: ip => v4Regex.test(ip),\n  encode (ip, buff, offset) {\n    offset = ~~offset\n    buff = buff || new Uint8Array(offset + v4Size)\n    const max = ip.length\n    let n = 0\n    for (let i = 0; i < max;) {\n      const c = ip.charCodeAt(i++)\n      if (c === 46) { // \".\"\n        buff[offset++] = n\n        n = 0\n      } else {\n        n = n * 10 + (c - 48)\n      }\n    }\n    buff[offset] = n\n    return buff\n  },\n  decode (buff, offset) {\n    offset = ~~offset\n    return `${buff[offset++]}.${buff[offset++]}.${buff[offset++]}.${buff[offset]}`\n  }\n}\n\nexport const v6 = {\n  name: 'v6',\n  size: v6Size,\n  isFormat: ip => ip.length > 0 && v6Regex.test(ip),\n  encode (ip, buff, offset) {\n    offset = ~~offset\n    let end = offset + v6Size\n    let fill = -1\n    let hexN = 0\n    let decN = 0\n    let prevColon = true\n    let useDec = false\n    buff = buff || new Uint8Array(offset + v6Size)\n    // Note: This algorithm needs to check if the offset\n    // could exceed the buffer boundaries as it supports\n    // non-standard compliant encodings that may go beyond\n    // the boundary limits. if (offset < end) checks should\n    // not be necessary...\n    for (let i = 0; i < ip.length; i++) {\n      let c = ip.charCodeAt(i)\n      if (c === 58) { // :\n        if (prevColon) {\n          if (fill !== -1) {\n            // Not Standard! (standard doesn't allow multiple ::)\n            // We need to treat\n            if (offset < end) buff[offset] = 0\n            if (offset < end - 1) buff[offset + 1] = 0\n            offset += 2\n          } else if (offset < end) {\n            // :: in the middle\n            fill = offset\n          }\n        } else {\n          // : ends the previous number\n          if (useDec === true) {\n            // Non-standard! (ipv4 should be at end only)\n            // A ipv4 address should not be found anywhere else but at\n            // the end. This codec also support putting characters\n            // after the ipv4 address..\n            if (offset < end) buff[offset] = decN\n            offset++\n          } else {\n            if (offset < end) buff[offset] = hexN >> 8\n            if (offset < end - 1) buff[offset + 1] = hexN & 0xff\n            offset += 2\n          }\n          hexN = 0\n          decN = 0\n        }\n        prevColon = true\n        useDec = false\n      } else if (c === 46) { // . indicates IPV4 notation\n        if (offset < end) buff[offset] = decN\n        offset++\n        decN = 0\n        hexN = 0\n        prevColon = false\n        useDec = true\n      } else {\n        prevColon = false\n        if (c >= 97) {\n          c -= 87 // a-f ... 97~102 -87 => 10~15\n        } else if (c >= 65) {\n          c -= 55 // A-F ... 65~70 -55 => 10~15\n        } else {\n          c -= 48 // 0-9 ... starting from charCode 48\n          decN = decN * 10 + c\n        }\n        // We don't know yet if its a dec or hex number\n        hexN = (hexN << 4) + c\n      }\n    }\n    if (prevColon === false) {\n      // Commiting last number\n      if (useDec === true) {\n        if (offset < end) buff[offset] = decN\n        offset++\n      } else {\n        if (offset < end) buff[offset] = hexN >> 8\n        if (offset < end - 1) buff[offset + 1] = hexN & 0xff\n        offset += 2\n      }\n    } else if (fill === 0) {\n      // Not Standard! (standard doesn't allow multiple ::)\n      // This means that a : was found at the start AND end which means the\n      // end needs to be treated as 0 entry...\n      if (offset < end) buff[offset] = 0\n      if (offset < end - 1) buff[offset + 1] = 0\n      offset += 2\n    } else if (fill !== -1) {\n      // Non-standard! (standard doens't allow multiple ::)\n      // Here we find that there has been a :: somewhere in the middle\n      // and the end. To treat the end with priority we need to move all\n      // written data two bytes to the right.\n      offset += 2\n      for (let i = Math.min(offset - 1, end - 1); i >= fill + 2; i--) {\n        buff[i] = buff[i - 2]\n      }\n      buff[fill] = 0\n      buff[fill + 1] = 0\n      fill = offset\n    }\n    if (fill !== offset && fill !== -1) {\n      // Move the written numbers to the end while filling the everything\n      // \"fill\" to the bytes with zeros.\n      if (offset > end - 2) {\n        // Non Standard support, when the cursor exceeds bounds.\n        offset = end - 2\n      }\n      while (end > fill) {\n        buff[--end] = offset < end && offset > fill ? buff[--offset] : 0\n      }\n    } else {\n      // Fill the rest with zeros\n      while (offset < end) {\n        buff[offset++] = 0\n      }\n    }\n    return buff\n  },\n  decode (buff, offset) {\n    offset = ~~offset\n    let result = ''\n    for (let i = 0; i < v6Size; i += 2) {\n      if (i !== 0) {\n        result += ':'\n      }\n      result += (buff[offset + i] << 8 | buff[offset + i + 1]).toString(16)\n    }\n    return result\n      .replace(/(^|:)0(:0)*:0(:|$)/, '$1::$3')\n      .replace(/:{3,4}/, '::')\n  }\n}\n\nexport const name = 'ip'\nexport function sizeOf (ip) {\n  if (v4.isFormat(ip)) return v4.size\n  if (v6.isFormat(ip)) return v6.size\n  throw Error(`Invalid ip address: ${ip}`)\n}\n\nexport function familyOf (string) {\n  return sizeOf(string) === v4.size ? 1 : 2\n}\n\nexport function encode (ip, buff, offset) {\n  offset = ~~offset\n  const size = sizeOf(ip)\n  if (typeof buff === 'function') {\n    buff = buff(offset + size)\n  }\n  if (size === v4.size) {\n    return v4.encode(ip, buff, offset)\n  }\n  return v6.encode(ip, buff, offset)\n}\n\nexport function decode (buff, offset, length) {\n  offset = ~~offset\n  length = length || (buff.length - offset)\n  if (length === v4.size) {\n    return v4.decode(buff, offset, length)\n  }\n  if (length === v6.size) {\n    return v6.decode(buff, offset, length)\n  }\n  throw Error(`Invalid buffer size needs to be ${v4.size} for v4 or ${v6.size} for v6.`)\n}\n"],"names":["v4Regex","v4Size","v6Regex","v6Size","v4","name","size","isFormat","ip","test","encode","buff","offset","Uint8Array","max","length","n","i","c","charCodeAt","decode","v6","end","fill","hexN","decN","prevColon","useDec","Math","min","result","toString","replace","sizeOf","Error","familyOf","string"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/@leichtgewicht/ip-codec/index.mjs\n");
|
|
|
|
/***/ })
|
|
|
|
};
|
|
; |