195 lines
286 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/@multiformats";
exports.ids = ["vendor-chunks/@multiformats"];
exports.modules = {
/***/ "(ssr)/./node_modules/@multiformats/dns/dist/src/dns.js":
/*!********************************************************!*\
!*** ./node_modules/@multiformats/dns/dist/src/dns.js ***!
\********************************************************/
/***/ ((__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 */ DNS: () => (/* binding */ DNS)\n/* harmony export */ });\n/* harmony import */ var progress_events__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! progress-events */ \"(ssr)/./node_modules/progress-events/dist/src/index.js\");\n/* harmony import */ var _resolvers_default_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./resolvers/default.js */ \"(ssr)/./node_modules/@multiformats/dns/dist/src/resolvers/default.js\");\n/* harmony import */ var _utils_cache_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./utils/cache.js */ \"(ssr)/./node_modules/@multiformats/dns/dist/src/utils/cache.js\");\n/* harmony import */ var _utils_get_types_js__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./utils/get-types.js */ \"(ssr)/./node_modules/@multiformats/dns/dist/src/utils/get-types.js\");\n\n\n\n\nconst DEFAULT_ANSWER_CACHE_SIZE = 1000;\nclass DNS {\n constructor(init){\n this.resolvers = {};\n this.cache = (0,_utils_cache_js__WEBPACK_IMPORTED_MODULE_2__.cache)(init.cacheSize ?? DEFAULT_ANSWER_CACHE_SIZE);\n Object.entries(init.resolvers ?? {}).forEach(([tld, resolver])=>{\n if (!Array.isArray(resolver)) {\n resolver = [\n resolver\n ];\n }\n // convert `com` -> `com.`\n if (!tld.endsWith(\".\")) {\n tld = `${tld}.`;\n }\n this.resolvers[tld] = resolver;\n });\n // configure default resolver if none specified\n if (this.resolvers[\".\"] == null) {\n this.resolvers[\".\"] = (0,_resolvers_default_js__WEBPACK_IMPORTED_MODULE_1__.defaultResolver)();\n }\n }\n /**\n * Queries DNS resolvers for the passed record types for the passed domain.\n *\n * If cached records exist for all desired types they will be returned\n * instead.\n *\n * Any new responses will be added to the cache for subsequent requests.\n */ async query(domain, options = {}) {\n const types = (0,_utils_get_types_js__WEBPACK_IMPORTED_MODULE_3__.getTypes)(options.types);\n const cached = options.cached !== false ? this.cache.get(domain, types) : undefined;\n if (cached != null) {\n options.onProgress?.(new progress_events__WEBPACK_IMPORTED_MODULE_0__.CustomProgressEvent(\"dns:cache\", {\n detail: cached\n }));\n return cached;\n }\n const tld = `${domain.split(\".\").pop()}.`;\n const resolvers = (this.resolvers[tld] ?? this.resolvers[\".\"]).sort(()=>{\n return Math.random() > 0.5 ? -1 : 1;\n });\n const errors = [];\n for (const resolver of resolvers){\n // skip further resolutions if the user aborted the signal\n if (options.signal?.aborted === true) {\n break;\n }\n try {\n const result = await resolver(domain, {\n ...options,\n types\n });\n for (const answer of result.Answer){\n this.cache.add(domain, answer);\n }\n return result;\n } catch (err) {\n errors.push(err);\n options.onProgress?.(new progress_events__WEBPACK_IMPORTED_MODULE_0__.CustomProgressEvent(\"dns:error\", {\n detail: err\n }));\n }\n }\n if (errors.length === 1) {\n throw errors[0];\n }\n throw new AggregateError(errors, `DNS lookup of ${domain} ${types} failed`);\n }\n} //# sourceMappingURL=dns.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvQG11bHRpZm9ybWF0cy9kbnMvZGlzdC9zcmMvZG5zLmpzIiwibWFwcGluZ3MiOiI7Ozs7Ozs7O0FBQXNEO0FBQ0c7QUFDaEI7QUFDTztBQUNoRCxNQUFNSSw0QkFBNEI7QUFDM0IsTUFBTUM7SUFHVEMsWUFBWUMsSUFBSSxDQUFFO1FBQ2QsSUFBSSxDQUFDQyxTQUFTLEdBQUcsQ0FBQztRQUNsQixJQUFJLENBQUNOLEtBQUssR0FBR0Esc0RBQUtBLENBQUNLLEtBQUtFLFNBQVMsSUFBSUw7UUFDckNNLE9BQU9DLE9BQU8sQ0FBQ0osS0FBS0MsU0FBUyxJQUFJLENBQUMsR0FBR0ksT0FBTyxDQUFDLENBQUMsQ0FBQ0MsS0FBS0MsU0FBUztZQUN6RCxJQUFJLENBQUNDLE1BQU1DLE9BQU8sQ0FBQ0YsV0FBVztnQkFDMUJBLFdBQVc7b0JBQUNBO2lCQUFTO1lBQ3pCO1lBQ0EsMEJBQTBCO1lBQzFCLElBQUksQ0FBQ0QsSUFBSUksUUFBUSxDQUFDLE1BQU07Z0JBQ3BCSixNQUFNLENBQUMsRUFBRUEsSUFBSSxDQUFDLENBQUM7WUFDbkI7WUFDQSxJQUFJLENBQUNMLFNBQVMsQ0FBQ0ssSUFBSSxHQUFHQztRQUMxQjtRQUNBLCtDQUErQztRQUMvQyxJQUFJLElBQUksQ0FBQ04sU0FBUyxDQUFDLElBQUksSUFBSSxNQUFNO1lBQzdCLElBQUksQ0FBQ0EsU0FBUyxDQUFDLElBQUksR0FBR1Asc0VBQWVBO1FBQ3pDO0lBQ0o7SUFDQTs7Ozs7OztLQU9DLEdBQ0QsTUFBTWlCLE1BQU1DLE1BQU0sRUFBRUMsVUFBVSxDQUFDLENBQUMsRUFBRTtRQUM5QixNQUFNQyxRQUFRbEIsNkRBQVFBLENBQUNpQixRQUFRQyxLQUFLO1FBQ3BDLE1BQU1DLFNBQVNGLFFBQVFFLE1BQU0sS0FBSyxRQUFRLElBQUksQ0FBQ3BCLEtBQUssQ0FBQ3FCLEdBQUcsQ0FBQ0osUUFBUUUsU0FBU0c7UUFDMUUsSUFBSUYsVUFBVSxNQUFNO1lBQ2hCRixRQUFRSyxVQUFVLEdBQUcsSUFBSXpCLGdFQUFtQkEsQ0FBQyxhQUFhO2dCQUFFMEIsUUFBUUo7WUFBTztZQUMzRSxPQUFPQTtRQUNYO1FBQ0EsTUFBTVQsTUFBTSxDQUFDLEVBQUVNLE9BQU9RLEtBQUssQ0FBQyxLQUFLQyxHQUFHLEdBQUcsQ0FBQyxDQUFDO1FBQ3pDLE1BQU1wQixZQUFZLENBQUMsSUFBSSxDQUFDQSxTQUFTLENBQUNLLElBQUksSUFBSSxJQUFJLENBQUNMLFNBQVMsQ0FBQyxJQUFJLEVBQUVxQixJQUFJLENBQUM7WUFDaEUsT0FBTyxLQUFNRSxNQUFNLEtBQUssTUFBTyxDQUFDLElBQUk7UUFDeEM7UUFDQSxNQUFNQyxTQUFTLEVBQUU7UUFDakIsS0FBSyxNQUFNbEIsWUFBWU4sVUFBVztZQUM5QiwwREFBMEQ7WUFDMUQsSUFBSVksUUFBUWEsTUFBTSxFQUFFQyxZQUFZLE1BQU07Z0JBQ2xDO1lBQ0o7WUFDQSxJQUFJO2dCQUNBLE1BQU1DLFNBQVMsTUFBTXJCLFNBQVNLLFFBQVE7b0JBQ2xDLEdBQUdDLE9BQU87b0JBQ1ZDO2dCQUNKO2dCQUNBLEtBQUssTUFBTWUsVUFBVUQsT0FBT0UsTUFBTSxDQUFFO29CQUNoQyxJQUFJLENBQUNuQyxLQUFLLENBQUNvQyxHQUFHLENBQUNuQixRQUFRaUI7Z0JBQzNCO2dCQUNBLE9BQU9EO1lBQ1gsRUFDQSxPQUFPSSxLQUFLO2dCQUNSUCxPQUFPUSxJQUFJLENBQUNEO2dCQUNabkIsUUFBUUssVUFBVSxHQUFHLElBQUl6QixnRUFBbUJBLENBQUMsYUFBYTtvQkFBRTBCLFFBQVFhO2dCQUFJO1lBQzVFO1FBQ0o7UUFDQSxJQUFJUCxPQUFPUyxNQUFNLEtBQUssR0FBRztZQUNyQixNQUFNVCxNQUFNLENBQUMsRUFBRTtRQUNuQjtRQUNBLE1BQU0sSUFBSVUsZUFBZVYsUUFBUSxDQUFDLGNBQWMsRUFBRWIsT0FBTyxDQUFDLEVBQUVFLE1BQU0sT0FBTyxDQUFDO0lBQzlFO0FBQ0osRUFDQSwrQkFBK0IiLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly9mbHVzaC1ub3Rlcy8uL25vZGVfbW9kdWxlcy9AbXVsdGlmb3JtYXRzL2Rucy9kaXN0L3NyYy9kbnMuanM/Y2ZmYiJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDdXN0b21Qcm9ncmVzc0V2ZW50IH0gZnJvbSAncHJvZ3Jlc3MtZXZlbnRzJztcbmltcG9ydCB7IGRlZmF1bHRSZXNvbHZlciB9IGZyb20gJy4vcmVzb2x2ZXJzL2RlZmF1bHQuanMnO1xuaW1wb3J0IHsgY2FjaGUgfSBmcm9tICcuL3V0aWxzL2NhY2hlLmpzJztcbmltcG9ydCB7IGdldFR5cGVzIH0gZnJvbSAnLi91dGlscy9nZXQtdHlwZXMuanMnO1xuY29uc3QgREVGQVVMVF9BTlNXRVJfQ0FDSEVfU0laRSA9IDEwMDA7XG5leHBvcnQgY2xhc3MgRE5TIHtcbiAgICByZXNvbHZlcnM7XG4gICAgY2FjaGU7XG4gICAgY29uc3RydWN0b3IoaW5pdCkge1xuICAgICAgICB0aGlzLnJlc29sdmVycyA9IHt9O1xuICAgICAgICB0aGlzLmNhY2hlID0gY2FjaGUoaW5pdC5jYWNoZVNpemUgPz8gREVGQVVMVF9BTlNXRVJfQ0FDSEVfU0laRSk7XG4gICAgICAgIE9iamVjdC5lbnRyaWVzKGluaXQucmVzb2x2ZXJzID8/IHt9KS5mb3JFYWNoKChbdGxkLCByZXNvbHZlcl0pID0+IHtcbiAgICAgICAgICAgIGlmICghQXJyYXkuaXNBcnJheShyZXNvbHZlcikpIHtcbiAgICAgICAgICAgICAgICByZXNvbHZlciA9IFtyZXNvbHZlcl07XG4gICAgICAgICAgICB9XG4gICAgICAgICAgICAvLyBjb252ZXJ0IGBjb21gIC0+IGBjb20uYFxuICAgICAgICAgICAgaWYgKCF0bGQuZW5kc1dpdGgoJy4nKSkge1xuICAgICAgICAgICAgICAgIHRsZCA9IGAke3RsZH0uYDtcbiAgICAgICAgICAgIH1cbiAgICAgICAgICAgIHRoaXMucmVzb2x2ZXJzW3RsZF0gPSByZXNvbHZlcjtcbiAgICAgICAgfSk7XG4gICAgICAgIC8vIGNvbmZpZ3VyZSBkZWZhdWx0IHJlc29sdmVyIGlmIG5vbmUgc3BlY2lmaWVkXG4gICAgICAgIGlmICh0aGlzLnJlc29sdmVyc1snLiddID09IG51bGwpIHtcbiAgICAgICAgICAgIHRoaXMucmVzb2x2ZXJzWycuJ10gPSBkZWZhdWx0UmVzb2x2ZXIoKTtcbiAgICAgICAgfVxuICAgIH1cbiAgICAvKipcbiAgICAgKiBRdWVyaWVzIEROUyByZXNvbHZlcnMgZm9yIHRoZSBwYXNzZWQgcmVjb3JkIHR5cGVzIGZvciB0aGUgcGFzc2VkIGRvbWFpbi5cbiAgICAgKlxuICAgICAqIElmIGNhY2hlZCByZWNvcmRzIGV4aXN0IGZvciBhbGwgZGVzaXJlZCB0eXBlcyB0aGV5IHdpbGwgYmUgcmV0dXJuZWRcbiAgICAgKiBpbnN0ZWFkLlxuICAgICAqXG4gICAgICogQW55IG5ldyByZXNwb25zZXMgd2lsbCBiZSBhZGRlZCB0byB0aGUgY2FjaGUgZm9yIHN1YnNlcXVlbnQgcmVxdWVzdHMuXG4gICAgICovXG4gICAgYXN5bmMgcXVlcnkoZG9tYWluLCBvcHRpb25zID0ge30pIHtcbiAgICAgICAgY29uc3QgdHlwZXMgPSBnZXRUeXBlcyhvcHRpb25zLnR5cGVzKTtcbiAgICAgICAgY29uc3QgY2FjaGVkID0gb3B0aW9ucy5jYWNoZWQgIT09IGZhbHNlID8gdGhpcy5jYWNoZS5nZXQoZG9tYWluLCB0eXBlcykgOiB1bmRlZmluZWQ7XG4gICAgICAgIGlmIChjYWNoZWQgIT0gbnVsbCkge1xuICAgICAgICAgICAgb3B0aW9ucy5vblByb2dyZXNzPy4obmV3IEN1c3RvbVByb2dyZXNzRXZlbnQoJ2RuczpjYWNoZScsIHsgZGV0YWlsOiBjYWNoZWQgfSkpO1xuICAgICAgICAgICAgcmV0dXJuIGNhY2hlZDtcbiAgICAgICAgfVxuICAgICAgICBjb25zdCB0bGQgPSBgJHtkb21haW4uc3BsaXQoJy4nKS5wb3AoKX0uYDtcbiAgICAgICAgY29uc3QgcmVzb2x2ZXJzID0gKHRoaXMucmVzb2x2ZXJzW3RsZF0gPz8gdGhpcy5yZXNvbHZlcnNbJy4nXSkuc29ydCgoKSA9PiB7XG4gICAgICAgICAgICByZXR1cm4gKE1hdGgucmFuZG9tKCkgPiAwLjUpID8gLTEgOiAxO1xuICAgICAgICB9KTtcbiAgICAgICAgY29uc3QgZXJyb3JzID0gW107XG4gICAgICAgIGZvciAoY29uc3QgcmVzb2x2ZXIgb2YgcmVzb2x2ZXJzKSB7XG4gICAgICAgICAgICAvLyBza2lwIGZ1cnRoZXIgcmVzb2x1dGlvbnMgaWYgdGhlIHVzZXIgYWJvcnRlZCB0aGUgc2lnbmFsXG4gICAgICAgICAgICBpZiAob3B0aW9ucy5zaWduYWw/LmFib3J0ZWQgPT09IHRydWUpIHtcbiAgICAgICAgICAgICAgICBicmVhaztcbiAgICAgICAgICAgIH1cbiAgICAgICAgICAgIHRyeSB7XG4gICAgICAgICAgICAgICAgY29uc3QgcmVzdWx0ID0gYXdhaXQgcmVzb2x2ZXIoZG9tYWluLCB7XG4gICAgICAgICAgICAgICAgICAgIC4uLm9wdGlvbnMsXG4gICAgICAgICAgICAgICAgICAgIHR5cGVzXG4gICAgICAgICAgICAgICAgfSk7XG4gICAgICAgICAgICAgICAgZm9yIChjb25zdCBhbnN3ZXIgb2YgcmVzdWx0LkFuc3dlcikge1xuICAgICAgICAgICAgICAgICAgICB0aGlzLmNhY2hlLmFkZChkb21haW4sIGFuc3dlcik7XG4gICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgICAgIHJldHVybiByZXN1bHQ7XG4gICAgICAgICAgICB9XG4gICAgICAgICAgICBjYXRjaCAoZXJyKSB7XG4gICAgICAgICAgICAgICAgZXJyb3JzLnB1c2goZXJyKTtcbiAgICAgICAgICAgICAgICBvcHRpb25zLm9uUHJvZ3Jlc3M/LihuZXcgQ3VzdG9tUHJvZ3Jlc3NFdmVudCgnZG5zOmVycm9yJywgeyBkZXRhaWw6IGVyciB9KSk7XG4gICAgICAgICAgICB9XG4gICAgICAgIH1cbiAgICAgICAgaWYgKGVycm9ycy5sZW5ndGggPT09IDEpIHtcbiAgICAgICAgICAgIHRocm93IGVycm9yc1swXTtcbiAgICAgICAgfVxuICAgICAgICB0aHJvdyBuZXcgQWdncmVnYXRlRXJyb3IoZXJyb3JzLCBgRE5TIGxvb2t1cCBvZiAke2RvbWFpbn0gJHt0eXBlc30gZmFpbGVkYCk7XG4gICAgfVxufVxuLy8jIHNvdXJjZU1hcHBpbmdVUkw9ZG5zLmpzLm1hcCJdLCJuYW1lcyI6WyJDdXN0b21Qcm9ncmVzc0V2ZW50IiwiZGVmYXVsdFJlc29sdmVyIiwiY2FjaGUiLCJnZXRUeXBlcyIsIkRFRkFVTFRfQU5TV0VSX0NBQ0hFX1NJWkUiLCJETlMiLCJjb25zdHJ1Y3RvciIsImluaXQiLCJyZXNvbHZlcnMiLCJjYWNoZVNpemUiLCJPYmplY3QiLCJlbnRyaWVzIiwiZm9yRWFjaCIsInRsZCIsInJlc29sdmVyIiwiQXJyYXkiLCJpc0FycmF5IiwiZW5kc1dpdGgiLCJxdWVyeSIsImRvbWFpbiIsIm9wdGlvbnMiLCJ0eXBlcyIsImNhY2hlZCIsImdldCIsInVuZGVmaW5lZCIsIm9uUHJvZ3Jlc3MiLCJkZXRhaWwiLCJzcGxpdCIsInBvcCIsInNvcnQiLCJNYXRoIiwicmFuZG9tIiwiZXJyb3JzIiwic2lnbmFsIiwiYWJvcnRlZCIsInJlc3VsdCIsImFuc3dlciIsIkFuc3dlciIsImFkZCIsImVyciIsInB1c2giLCJsZW5ndGgiLCJBZ2dyZWdhdGVFcnJvciJdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/@multiformats/dns/dist/src/dns.js\n");
/***/ }),
/***/ "(ssr)/./node_modules/@multiformats/dns/dist/src/index.js":
/*!**********************************************************!*\
!*** ./node_modules/@multiformats/dns/dist/src/index.js ***!
\**********************************************************/
/***/ ((__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 */ MAX_RECURSIVE_DEPTH: () => (/* binding */ MAX_RECURSIVE_DEPTH),\n/* harmony export */ RecordType: () => (/* binding */ RecordType),\n/* harmony export */ dns: () => (/* binding */ dns)\n/* harmony export */ });\n/* harmony import */ var _dns_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./dns.js */ \"(ssr)/./node_modules/@multiformats/dns/dist/src/dns.js\");\n/**\n * @packageDocumentation\n *\n * Query DNS records using `node:dns`, DNS over HTTP and/or DNSJSON over HTTP.\n *\n * A list of publicly accessible servers can be found [here](https://github.com/curl/curl/wiki/DNS-over-HTTPS#publicly-available-servers).\n *\n * @example Using the default resolver\n *\n * ```TypeScript\n * import { dns } from '@multiformats/dns'\n *\n * const resolver = dns()\n *\n * // resolve A records with a 5s timeout\n * const result = await dns.query('google.com', {\n * signal: AbortSignal.timeout(5000)\n * })\n * ```\n *\n * @example Using per-TLD resolvers\n *\n * ```TypeScript\n * import { dns } from '@multiformats/dns'\n * import { dnsJsonOverHttps } from '@multiformats/dns/resolvers'\n *\n * const resolver = dns({\n * resolvers: {\n * // will only be used to resolve `.com` addresses\n * 'com.': dnsJsonOverHttps('https://cloudflare-dns.com/dns-query'),\n *\n * // this can also be an array, resolvers will be shuffled and tried in\n * // series\n * 'net.': [\n * dnsJsonOverHttps('https://dns.google/resolve'),\n * dnsJsonOverHttps('https://dns.pub/dns-query')\n * ],\n *\n * // will only be used to resolve all other addresses\n * '.': dnsJsonOverHttps('https://dnsforge.de/dns-query'),\n * }\n * })\n * ```\n *\n * @example Query for specific record types\n *\n * ```TypeScript\n * import { dns, RecordType } from '@multiformats/dns'\n *\n * const resolver = dns()\n *\n * // resolve only TXT records\n * const result = await dns.query('google.com', {\n * types: [\n * RecordType.TXT\n * ]\n * })\n * ```\n *\n * ## Caching\n *\n * Individual Aanswers are cached so. If you make a request, for which all\n * record types are cached, all values will be pulled from the cache.\n *\n * If any of the record types are not cached, a new request will be resolved as\n * if none of the records were cached, and the cache will be updated to include\n * the new results.\n *\n * @example Ignoring the cache\n *\n * ```TypeScript\n * import { dns, RecordType } from '@multiformats/dns'\n *\n * const resolver = dns()\n *\n * // do not used cached results, always resolve a new query\n * const result = await dns.query('google.com', {\n * cached: false\n * })\n * ```\n */ \n/**\n * A subset of DNS Record Types\n *\n * @see https://www.iana.org/assignments/dns-parameters/dns-parameters.xhtml#dns-parameters-4.\n */ var RecordType;\n(function(RecordType) {\n RecordType[RecordType[\"A\"] = 1] = \"A\";\n RecordType[RecordType[\"CNAME\"] = 5] = \"CNAME\";\n RecordType[RecordType[\"TXT\"] = 16] = \"TXT\";\n RecordType[RecordType[\"AAAA\"] = 28] = \"AAAA\";\n})(RecordType || (RecordType = {}));\n/**\n * The default maximum amount of recursion allowed during a query\n */ const MAX_RECURSIVE_DEPTH = 32;\nfunction dns(init = {}) {\n return new _dns_js__WEBPACK_IMPORTED_MODULE_0__.DNS(init);\n} //# sourceMappingURL=index.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvQG11bHRpZm9ybWF0cy9kbnMvZGlzdC9zcmMvaW5kZXguanMiLCJtYXBwaW5ncyI6Ijs7Ozs7OztBQUFBOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztDQWdGQyxHQUMwQztBQUMzQzs7OztDQUlDLEdBQ00sSUFBSUUsV0FBVztBQUNyQixVQUFVQSxVQUFVO0lBQ2pCQSxVQUFVLENBQUNBLFVBQVUsQ0FBQyxJQUFJLEdBQUcsRUFBRSxHQUFHO0lBQ2xDQSxVQUFVLENBQUNBLFVBQVUsQ0FBQyxRQUFRLEdBQUcsRUFBRSxHQUFHO0lBQ3RDQSxVQUFVLENBQUNBLFVBQVUsQ0FBQyxNQUFNLEdBQUcsR0FBRyxHQUFHO0lBQ3JDQSxVQUFVLENBQUNBLFVBQVUsQ0FBQyxPQUFPLEdBQUcsR0FBRyxHQUFHO0FBQzFDLEdBQUdBLGNBQWVBLENBQUFBLGFBQWEsQ0FBQztBQUNoQzs7Q0FFQyxHQUNNLE1BQU1DLHNCQUFzQixHQUFHO0FBQy9CLFNBQVNDLElBQUlDLE9BQU8sQ0FBQyxDQUFDO0lBQ3pCLE9BQU8sSUFBSUosd0NBQVFBLENBQUNJO0FBQ3hCLEVBQ0EsaUNBQWlDIiwic291cmNlcyI6WyJ3ZWJwYWNrOi8vZmx1c2gtbm90ZXMvLi9ub2RlX21vZHVsZXMvQG11bHRpZm9ybWF0cy9kbnMvZGlzdC9zcmMvaW5kZXguanM/OTY0MyJdLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEBwYWNrYWdlRG9jdW1lbnRhdGlvblxuICpcbiAqIFF1ZXJ5IEROUyByZWNvcmRzIHVzaW5nIGBub2RlOmRuc2AsIEROUyBvdmVyIEhUVFAgYW5kL29yIEROU0pTT04gb3ZlciBIVFRQLlxuICpcbiAqIEEgbGlzdCBvZiBwdWJsaWNseSBhY2Nlc3NpYmxlIHNlcnZlcnMgY2FuIGJlIGZvdW5kIFtoZXJlXShodHRwczovL2dpdGh1Yi5jb20vY3VybC9jdXJsL3dpa2kvRE5TLW92ZXItSFRUUFMjcHVibGljbHktYXZhaWxhYmxlLXNlcnZlcnMpLlxuICpcbiAqIEBleGFtcGxlIFVzaW5nIHRoZSBkZWZhdWx0IHJlc29sdmVyXG4gKlxuICogYGBgVHlwZVNjcmlwdFxuICogaW1wb3J0IHsgZG5zIH0gZnJvbSAnQG11bHRpZm9ybWF0cy9kbnMnXG4gKlxuICogY29uc3QgcmVzb2x2ZXIgPSBkbnMoKVxuICpcbiAqIC8vIHJlc29sdmUgQSByZWNvcmRzIHdpdGggYSA1cyB0aW1lb3V0XG4gKiBjb25zdCByZXN1bHQgPSBhd2FpdCBkbnMucXVlcnkoJ2dvb2dsZS5jb20nLCB7XG4gKiAgIHNpZ25hbDogQWJvcnRTaWduYWwudGltZW91dCg1MDAwKVxuICogfSlcbiAqIGBgYFxuICpcbiAqIEBleGFtcGxlIFVzaW5nIHBlci1UTEQgcmVzb2x2ZXJzXG4gKlxuICogYGBgVHlwZVNjcmlwdFxuICogaW1wb3J0IHsgZG5zIH0gZnJvbSAnQG11bHRpZm9ybWF0cy9kbnMnXG4gKiBpbXBvcnQgeyBkbnNKc29uT3Zlckh0dHBzIH0gZnJvbSAnQG11bHRpZm9ybWF0cy9kbnMvcmVzb2x2ZXJzJ1xuICpcbiAqIGNvbnN0IHJlc29sdmVyID0gZG5zKHtcbiAqICAgcmVzb2x2ZXJzOiB7XG4gKiAgICAgLy8gd2lsbCBvbmx5IGJlIHVzZWQgdG8gcmVzb2x2ZSBgLmNvbWAgYWRkcmVzc2VzXG4gKiAgICAgJ2NvbS4nOiBkbnNKc29uT3Zlckh0dHBzKCdodHRwczovL2Nsb3VkZmxhcmUtZG5zLmNvbS9kbnMtcXVlcnknKSxcbiAqXG4gKiAgICAgLy8gdGhpcyBjYW4gYWxzbyBiZSBhbiBhcnJheSwgcmVzb2x2ZXJzIHdpbGwgYmUgc2h1ZmZsZWQgYW5kIHRyaWVkIGluXG4gKiAgICAgLy8gc2VyaWVzXG4gKiAgICAgJ25ldC4nOiBbXG4gKiAgICAgICBkbnNKc29uT3Zlckh0dHBzKCdodHRwczovL2Rucy5nb29nbGUvcmVzb2x2ZScpLFxuICogICAgICAgZG5zSnNvbk92ZXJIdHRwcygnaHR0cHM6Ly9kbnMucHViL2Rucy1xdWVyeScpXG4gKiAgICAgXSxcbiAqXG4gKiAgICAgLy8gd2lsbCBvbmx5IGJlIHVzZWQgdG8gcmVzb2x2ZSBhbGwgb3RoZXIgYWRkcmVzc2VzXG4gKiAgICAgJy4nOiBkbnNKc29uT3Zlckh0dHBzKCdodHRwczovL2Ruc2ZvcmdlLmRlL2Rucy1xdWVyeScpLFxuICogICB9XG4gKiB9KVxuICogYGBgXG4gKlxuICogQGV4YW1wbGUgUXVlcnkgZm9yIHNwZWNpZmljIHJlY29yZCB0eXBlc1xuICpcbiAqIGBgYFR5cGVTY3JpcHRcbiAqIGltcG9ydCB7IGRucywgUmVjb3JkVHlwZSB9IGZyb20gJ0BtdWx0aWZvcm1hdHMvZG5zJ1xuICpcbiAqIGNvbnN0IHJlc29sdmVyID0gZG5zKClcbiAqXG4gKiAvLyByZXNvbHZlIG9ubHkgVFhUIHJlY29yZHNcbiAqIGNvbnN0IHJlc3VsdCA9IGF3YWl0IGRucy5xdWVyeSgnZ29vZ2xlLmNvbScsIHtcbiAqICAgdHlwZXM6IFtcbiAqICAgICBSZWNvcmRUeXBlLlRYVFxuICogICBdXG4gKiB9KVxuICogYGBgXG4gKlxuICogIyMgQ2FjaGluZ1xuICpcbiAqIEluZGl2aWR1YWwgQWFuc3dlcnMgYXJlIGNhY2hlZCBzby4gSWYgeW91IG1ha2UgYSByZXF1ZXN0LCBmb3Igd2hpY2ggYWxsXG4gKiByZWNvcmQgdHlwZXMgYXJlIGNhY2hlZCwgYWxsIHZhbHVlcyB3aWxsIGJlIHB1bGxlZCBmcm9tIHRoZSBjYWNoZS5cbiAqXG4gKiBJZiBhbnkgb2YgdGhlIHJlY29yZCB0eXBlcyBhcmUgbm90IGNhY2hlZCwgYSBuZXcgcmVxdWVzdCB3aWxsIGJlIHJlc29sdmVkIGFzXG4gKiBpZiBub25lIG9mIHRoZSByZWNvcmRzIHdlcmUgY2FjaGVkLCBhbmQgdGhlIGNhY2hlIHdpbGwgYmUgdXBkYXRlZCB0byBpbmNsdWRlXG4gKiB0aGUgbmV3IHJlc3VsdHMuXG4gKlxuICogQGV4YW1wbGUgSWdub3JpbmcgdGhlIGNhY2hlXG4gKlxuICogYGBgVHlwZVNjcmlwdFxuICogaW1wb3J0IHsgZG5zLCBSZWNvcmRUeXBlIH0gZnJvbSAnQG11bHRpZm9ybWF0cy9kbnMnXG4gKlxuICogY29uc3QgcmVzb2x2ZXIgPSBkbnMoKVxuICpcbiAqIC8vIGRvIG5vdCB1c2VkIGNhY2hlZCByZXN1bHRzLCBhbHdheXMgcmVzb2x2ZSBhIG5ldyBxdWVyeVxuICogY29uc3QgcmVzdWx0ID0gYXdhaXQgZG5zLnF1ZXJ5KCdnb29nbGUuY29tJywge1xuICogICBjYWNoZWQ6IGZhbHNlXG4gKiB9KVxuICogYGBgXG4gKi9cbmltcG9ydCB7IEROUyBhcyBETlNDbGFzcyB9IGZyb20gJy4vZG5zLmpzJztcbi8qKlxuICogQSBzdWJzZXQgb2YgRE5TIFJlY29yZCBUeXBlc1xuICpcbiAqIEBzZWUgaHR0cHM6Ly93d3cuaWFuYS5vcmcvYXNzaWdubWVudHMvZG5zLXBhcmFtZXRlcnMvZG5zLXBhcmFtZXRlcnMueGh0bWwjZG5zLXBhcmFtZXRlcnMtNC5cbiAqL1xuZXhwb3J0IHZhciBSZWNvcmRUeXBlO1xuKGZ1bmN0aW9uIChSZWNvcmRUeXBlKSB7XG4gICAgUmVjb3JkVHlwZVtSZWNvcmRUeXBlW1wiQVwiXSA9IDFdID0gXCJBXCI7XG4gICAgUmVjb3JkVHlwZVtSZWNvcmRUeXBlW1wiQ05BTUVcIl0gPSA1XSA9IFwiQ05BTUVcIjtcbiAgICBSZWNvcmRUeXBlW1JlY29yZFR5cGVbXCJUWFRcIl0gPSAxNl0gPSBcIlRYVFwiO1xuICAgIFJlY29yZFR5cGVbUmVjb3JkVHlwZVtcIkFBQUFcIl0gPSAyOF0gPSBcIkFBQUFcIjtcbn0pKFJlY29yZFR5cGUgfHwgKFJlY29yZFR5cGUgPSB7fSkpO1xuLyoqXG4gKiBUaGUgZGVmYXVsdCBtYXhpbXVtIGFtb3VudCBvZiByZWN1cnNpb24gYWxsb3dlZCBkdXJpbmcgYSBxdWVyeVxuICovXG5leHBvcnQgY29uc3QgTUFYX1JFQ1VSU0lWRV9ERVBUSCA9IDMyO1xuZXhwb3J0IGZ1bmN0aW9uIGRucyhpbml0ID0ge30pIHtcbiAgICByZXR1cm4gbmV3IEROU0NsYXNzKGluaXQpO1xufVxuLy8jIHNvdXJjZU1hcHBpbmdVUkw9aW5kZXguanMubWFwIl0sIm5hbWVzIjpbIkROUyIsIkROU0NsYXNzIiwiUmVjb3JkVHlwZSIsIk1BWF9SRUNVUlNJVkVfREVQVEgiLCJkbnMiLCJpbml0Il0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/@multiformats/dns/dist/src/index.js\n");
/***/ }),
/***/ "(ssr)/./node_modules/@multiformats/dns/dist/src/resolvers/default.js":
/*!**********************************************************************!*\
!*** ./node_modules/@multiformats/dns/dist/src/resolvers/default.js ***!
\**********************************************************************/
/***/ ((__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 */ defaultResolver: () => (/* binding */ defaultResolver)\n/* harmony export */ });\n/* harmony import */ var dns_promises__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! dns/promises */ \"dns/promises\");\n/* harmony import */ var _index_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../index.js */ \"(ssr)/./node_modules/@multiformats/dns/dist/src/index.js\");\n/* harmony import */ var _utils_get_types_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../utils/get-types.js */ \"(ssr)/./node_modules/@multiformats/dns/dist/src/utils/get-types.js\");\n/* harmony import */ var _utils_to_dns_response_js__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../utils/to-dns-response.js */ \"(ssr)/./node_modules/@multiformats/dns/dist/src/utils/to-dns-response.js\");\n\n\n\n\nconst nodeResolver = async (fqdn, options = {})=>{\n const resolver = new dns_promises__WEBPACK_IMPORTED_MODULE_0__.Resolver();\n const listener = ()=>{\n resolver.cancel();\n };\n const types = (0,_utils_get_types_js__WEBPACK_IMPORTED_MODULE_2__.getTypes)(options.types);\n try {\n options.signal?.addEventListener(\"abort\", listener);\n const answers = await Promise.all(types.map(async (type)=>{\n if (type === _index_js__WEBPACK_IMPORTED_MODULE_1__.RecordType.A) {\n return mapToAnswers(fqdn, type, await resolver.resolve4(fqdn));\n }\n if (type === _index_js__WEBPACK_IMPORTED_MODULE_1__.RecordType.CNAME) {\n return mapToAnswers(fqdn, type, await resolver.resolveCname(fqdn));\n }\n if (type === _index_js__WEBPACK_IMPORTED_MODULE_1__.RecordType.TXT) {\n return mapToAnswers(fqdn, type, await resolver.resolveTxt(fqdn));\n }\n if (type === _index_js__WEBPACK_IMPORTED_MODULE_1__.RecordType.AAAA) {\n return mapToAnswers(fqdn, type, await resolver.resolve6(fqdn));\n }\n throw new TypeError(\"Unsupported DNS record type\");\n }));\n return (0,_utils_to_dns_response_js__WEBPACK_IMPORTED_MODULE_3__.toDNSResponse)({\n Question: types.map((type)=>({\n name: fqdn,\n type\n })),\n Answer: answers.flat()\n });\n } finally{\n options.signal?.removeEventListener(\"abort\", listener);\n }\n};\nfunction defaultResolver() {\n return [\n nodeResolver\n ];\n}\nfunction mapToAnswer(name, type, data) {\n return {\n name,\n type,\n data\n };\n}\nfunction mapToAnswers(name, type, data) {\n if (!Array.isArray(data)) {\n data = [\n data\n ];\n }\n return data.map((data)=>{\n if (Array.isArray(data)) {\n return data.map((data)=>mapToAnswer(name, type, data));\n }\n return mapToAnswer(name, type, data);\n }).flat();\n} //# sourceMappingURL=default.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvQG11bHRpZm9ybWF0cy9kbnMvZGlzdC9zcmMvcmVzb2x2ZXJzL2RlZmF1bHQuanMiLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7QUFBd0M7QUFDQztBQUNRO0FBQ1c7QUFDNUQsTUFBTUksZUFBZSxPQUFPQyxNQUFNQyxVQUFVLENBQUMsQ0FBQztJQUMxQyxNQUFNQyxXQUFXLElBQUlQLGtEQUFRQTtJQUM3QixNQUFNUSxXQUFXO1FBQ2JELFNBQVNFLE1BQU07SUFDbkI7SUFDQSxNQUFNQyxRQUFRUiw2REFBUUEsQ0FBQ0ksUUFBUUksS0FBSztJQUNwQyxJQUFJO1FBQ0FKLFFBQVFLLE1BQU0sRUFBRUMsaUJBQWlCLFNBQVNKO1FBQzFDLE1BQU1LLFVBQVUsTUFBTUMsUUFBUUMsR0FBRyxDQUFDTCxNQUFNTSxHQUFHLENBQUMsT0FBT0M7WUFDL0MsSUFBSUEsU0FBU2hCLGlEQUFVQSxDQUFDaUIsQ0FBQyxFQUFFO2dCQUN2QixPQUFPQyxhQUFhZCxNQUFNWSxNQUFNLE1BQU1WLFNBQVNhLFFBQVEsQ0FBQ2Y7WUFDNUQ7WUFDQSxJQUFJWSxTQUFTaEIsaURBQVVBLENBQUNvQixLQUFLLEVBQUU7Z0JBQzNCLE9BQU9GLGFBQWFkLE1BQU1ZLE1BQU0sTUFBTVYsU0FBU2UsWUFBWSxDQUFDakI7WUFDaEU7WUFDQSxJQUFJWSxTQUFTaEIsaURBQVVBLENBQUNzQixHQUFHLEVBQUU7Z0JBQ3pCLE9BQU9KLGFBQWFkLE1BQU1ZLE1BQU0sTUFBTVYsU0FBU2lCLFVBQVUsQ0FBQ25CO1lBQzlEO1lBQ0EsSUFBSVksU0FBU2hCLGlEQUFVQSxDQUFDd0IsSUFBSSxFQUFFO2dCQUMxQixPQUFPTixhQUFhZCxNQUFNWSxNQUFNLE1BQU1WLFNBQVNtQixRQUFRLENBQUNyQjtZQUM1RDtZQUNBLE1BQU0sSUFBSXNCLFVBQVU7UUFDeEI7UUFDQSxPQUFPeEIsd0VBQWFBLENBQUM7WUFDakJ5QixVQUFVbEIsTUFBTU0sR0FBRyxDQUFDQyxDQUFBQSxPQUFTO29CQUN6QlksTUFBTXhCO29CQUNOWTtnQkFDSjtZQUNBYSxRQUFRakIsUUFBUWtCLElBQUk7UUFDeEI7SUFDSixTQUNRO1FBQ0p6QixRQUFRSyxNQUFNLEVBQUVxQixvQkFBb0IsU0FBU3hCO0lBQ2pEO0FBQ0o7QUFDTyxTQUFTeUI7SUFDWixPQUFPO1FBQ0g3QjtLQUNIO0FBQ0w7QUFDQSxTQUFTOEIsWUFBWUwsSUFBSSxFQUFFWixJQUFJLEVBQUVrQixJQUFJO0lBQ2pDLE9BQU87UUFDSE47UUFDQVo7UUFDQWtCO0lBQ0o7QUFDSjtBQUNBLFNBQVNoQixhQUFhVSxJQUFJLEVBQUVaLElBQUksRUFBRWtCLElBQUk7SUFDbEMsSUFBSSxDQUFDQyxNQUFNQyxPQUFPLENBQUNGLE9BQU87UUFDdEJBLE9BQU87WUFBQ0E7U0FBSztJQUNqQjtJQUNBLE9BQU9BLEtBQUtuQixHQUFHLENBQUNtQixDQUFBQTtRQUNaLElBQUlDLE1BQU1DLE9BQU8sQ0FBQ0YsT0FBTztZQUNyQixPQUFPQSxLQUFLbkIsR0FBRyxDQUFDbUIsQ0FBQUEsT0FBUUQsWUFBWUwsTUFBTVosTUFBTWtCO1FBQ3BEO1FBQ0EsT0FBT0QsWUFBWUwsTUFBTVosTUFBTWtCO0lBQ25DLEdBQ0tKLElBQUk7QUFDYixFQUNBLG1DQUFtQyIsInNvdXJjZXMiOlsid2VicGFjazovL2ZsdXNoLW5vdGVzLy4vbm9kZV9tb2R1bGVzL0BtdWx0aWZvcm1hdHMvZG5zL2Rpc3Qvc3JjL3Jlc29sdmVycy9kZWZhdWx0LmpzPzVhZjEiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgUmVzb2x2ZXIgfSBmcm9tICdkbnMvcHJvbWlzZXMnO1xuaW1wb3J0IHsgUmVjb3JkVHlwZSB9IGZyb20gJy4uL2luZGV4LmpzJztcbmltcG9ydCB7IGdldFR5cGVzIH0gZnJvbSAnLi4vdXRpbHMvZ2V0LXR5cGVzLmpzJztcbmltcG9ydCB7IHRvRE5TUmVzcG9uc2UgfSBmcm9tICcuLi91dGlscy90by1kbnMtcmVzcG9uc2UuanMnO1xuY29uc3Qgbm9kZVJlc29sdmVyID0gYXN5bmMgKGZxZG4sIG9wdGlvbnMgPSB7fSkgPT4ge1xuICAgIGNvbnN0IHJlc29sdmVyID0gbmV3IFJlc29sdmVyKCk7XG4gICAgY29uc3QgbGlzdGVuZXIgPSAoKSA9PiB7XG4gICAgICAgIHJlc29sdmVyLmNhbmNlbCgpO1xuICAgIH07XG4gICAgY29uc3QgdHlwZXMgPSBnZXRUeXBlcyhvcHRpb25zLnR5cGVzKTtcbiAgICB0cnkge1xuICAgICAgICBvcHRpb25zLnNpZ25hbD8uYWRkRXZlbnRMaXN0ZW5lcignYWJvcnQnLCBsaXN0ZW5lcik7XG4gICAgICAgIGNvbnN0IGFuc3dlcnMgPSBhd2FpdCBQcm9taXNlLmFsbCh0eXBlcy5tYXAoYXN5bmMgKHR5cGUpID0+IHtcbiAgICAgICAgICAgIGlmICh0eXBlID09PSBSZWNvcmRUeXBlLkEpIHtcbiAgICAgICAgICAgICAgICByZXR1cm4gbWFwVG9BbnN3ZXJzKGZxZG4sIHR5cGUsIGF3YWl0IHJlc29sdmVyLnJlc29sdmU0KGZxZG4pKTtcbiAgICAgICAgICAgIH1cbiAgICAgICAgICAgIGlmICh0eXBlID09PSBSZWNvcmRUeXBlLkNOQU1FKSB7XG4gICAgICAgICAgICAgICAgcmV0dXJuIG1hcFRvQW5zd2VycyhmcWRuLCB0eXBlLCBhd2FpdCByZXNvbHZlci5yZXNvbHZlQ25hbWUoZnFkbikpO1xuICAgICAgICAgICAgfVxuICAgICAgICAgICAgaWYgKHR5cGUgPT09IFJlY29yZFR5cGUuVFhUKSB7XG4gICAgICAgICAgICAgICAgcmV0dXJuIG1hcFRvQW5zd2VycyhmcWRuLCB0eXBlLCBhd2FpdCByZXNvbHZlci5yZXNvbHZlVHh0KGZxZG4pKTtcbiAgICAgICAgICAgIH1cbiAgICAgICAgICAgIGlmICh0eXBlID09PSBSZWNvcmRUeXBlLkFBQUEpIHtcbiAgICAgICAgICAgICAgICByZXR1cm4gbWFwVG9BbnN3ZXJzKGZxZG4sIHR5cGUsIGF3YWl0IHJlc29sdmVyLnJlc29sdmU2KGZxZG4pKTtcbiAgICAgICAgICAgIH1cbiAgICAgICAgICAgIHRocm93IG5ldyBUeXBlRXJyb3IoJ1Vuc3VwcG9ydGVkIEROUyByZWNvcmQgdHlwZScpO1xuICAgICAgICB9KSk7XG4gICAgICAgIHJldHVybiB0b0ROU1Jlc3BvbnNlKHtcbiAgICAgICAgICAgIFF1ZXN0aW9uOiB0eXBlcy5tYXAodHlwZSA9PiAoe1xuICAgICAgICAgICAgICAgIG5hbWU6IGZxZG4sXG4gICAgICAgICAgICAgICAgdHlwZVxuICAgICAgICAgICAgfSkpLFxuICAgICAgICAgICAgQW5zd2VyOiBhbnN3ZXJzLmZsYXQoKVxuICAgICAgICB9KTtcbiAgICB9XG4gICAgZmluYWxseSB7XG4gICAgICAgIG9wdGlvbnMuc2lnbmFsPy5yZW1vdmVFdmVudExpc3RlbmVyKCdhYm9ydCcsIGxpc3RlbmVyKTtcbiAgICB9XG59O1xuZXhwb3J0IGZ1bmN0aW9uIGRlZmF1bHRSZXNvbHZlcigpIHtcbiAgICByZXR1cm4gW1xuICAgICAgICBub2RlUmVzb2x2ZXJcbiAgICBdO1xufVxuZnVuY3Rpb24gbWFwVG9BbnN3ZXIobmFtZSwgdHlwZSwgZGF0YSkge1xuICAgIHJldHVybiB7XG4gICAgICAgIG5hbWUsXG4gICAgICAgIHR5cGUsXG4gICAgICAgIGRhdGFcbiAgICB9O1xufVxuZnVuY3Rpb24gbWFwVG9BbnN3ZXJzKG5hbWUsIHR5cGUsIGRhdGEpIHtcbiAgICBpZiAoIUFycmF5LmlzQXJyYXkoZGF0YSkpIHtcbiAgICAgICAgZGF0YSA9IFtkYXRhXTtcbiAgICB9XG4gICAgcmV0dXJuIGRhdGEubWFwKGRhdGEgPT4ge1xuICAgICAgICBpZiAoQXJyYXkuaXNBcnJheShkYXRhKSkge1xuICAgICAgICAgICAgcmV0dXJuIGRhdGEubWFwKGRhdGEgPT4gbWFwVG9BbnN3ZXIobmFtZSwgdHlwZSwgZGF0YSkpO1xuICAgICAgICB9XG4gICAgICAgIHJldHVybiBtYXBUb0Fuc3dlcihuYW1lLCB0eXBlLCBkYXRhKTtcbiAgICB9KVxuICAgICAgICAuZmxhdCgpO1xufVxuLy8jIHNvdXJjZU1hcHBpbmdVUkw9ZGVmYXVsdC5qcy5tYXAiXSwibmFtZXMiOlsiUmVzb2x2ZXIiLCJSZWNvcmRUeXBlIiwiZ2V0VHlwZXMiLCJ0b0ROU1Jlc3BvbnNlIiwibm9kZVJlc29sdmVyIiwiZnFkbiIsIm9wdGlvbnMiLCJyZXNvbHZlciIsImxpc3RlbmVyIiwiY2FuY2VsIiwidHlwZXMiLCJzaWduYWwiLCJhZGRFdmVudExpc3RlbmVyIiwiYW5zd2VycyIsIlByb21pc2UiLCJhbGwiLCJtYXAiLCJ0eXBlIiwiQSIsIm1hcFRvQW5zd2VycyIsInJlc29sdmU0IiwiQ05BTUUiLCJyZXNvbHZlQ25hbWUiLCJUWFQiLCJyZXNvbHZlVHh0IiwiQUFBQSIsInJlc29sdmU2IiwiVHlwZUVycm9yIiwiUXVlc3Rpb24iLCJuYW1lIiwiQW5zd2VyIiwiZmxhdCIsInJlbW92ZUV2ZW50TGlzdGVuZXIiLCJkZWZhdWx0UmVzb2x2ZXIiLCJtYXBUb0Fuc3dlciIsImRhdGEiLCJBcnJheSIsImlzQXJyYXkiXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/@multiformats/dns/dist/src/resolvers/default.js\n");
/***/ }),
/***/ "(ssr)/./node_modules/@multiformats/dns/dist/src/utils/cache.js":
/*!****************************************************************!*\
!*** ./node_modules/@multiformats/dns/dist/src/utils/cache.js ***!
\****************************************************************/
/***/ ((__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 */ cache: () => (/* binding */ cache)\n/* harmony export */ });\n/* harmony import */ var hashlru__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! hashlru */ \"(ssr)/./node_modules/hashlru/index.js\");\n/* harmony import */ var _index_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../index.js */ \"(ssr)/./node_modules/@multiformats/dns/dist/src/index.js\");\n/* harmony import */ var _to_dns_response_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./to-dns-response.js */ \"(ssr)/./node_modules/@multiformats/dns/dist/src/utils/to-dns-response.js\");\n\n\n\n/**\n * Time Aware Least Recent Used Cache\n *\n * @see https://arxiv.org/pdf/1801.00390\n */ class CachedAnswers {\n constructor(maxSize){\n this.lru = hashlru__WEBPACK_IMPORTED_MODULE_0__(maxSize);\n }\n get(fqdn, types) {\n let foundAllAnswers = true;\n const answers = [];\n for (const type of types){\n const cached = this.getAnswers(fqdn, type);\n if (cached.length === 0) {\n foundAllAnswers = false;\n break;\n }\n answers.push(...cached);\n }\n if (foundAllAnswers) {\n return (0,_to_dns_response_js__WEBPACK_IMPORTED_MODULE_2__.toDNSResponse)({\n answers\n });\n }\n }\n getAnswers(domain, type) {\n const key = `${domain.toLowerCase()}-${type}`;\n const answers = this.lru.get(key);\n if (answers != null) {\n const cachedAnswers = answers.filter((entry)=>{\n return entry.expires > Date.now();\n }).map(({ expires, value })=>({\n ...value,\n TTL: Math.round((expires - Date.now()) / 1000),\n type: _index_js__WEBPACK_IMPORTED_MODULE_1__.RecordType[value.type]\n }));\n if (cachedAnswers.length === 0) {\n this.lru.remove(key);\n }\n // @ts-expect-error hashlru stringifies stored types which turns enums\n // into strings, we convert back into enums above but tsc doesn't know\n return cachedAnswers;\n }\n return [];\n }\n add(domain, answer) {\n const key = `${domain.toLowerCase()}-${answer.type}`;\n const answers = this.lru.get(key) ?? [];\n answers.push({\n expires: Date.now() + (answer.TTL ?? _to_dns_response_js__WEBPACK_IMPORTED_MODULE_2__.DEFAULT_TTL) * 1000,\n value: answer\n });\n this.lru.set(key, answers);\n }\n remove(domain, type) {\n const key = `${domain.toLowerCase()}-${type}`;\n this.lru.remove(key);\n }\n clear() {\n this.lru.clear();\n }\n}\n/**\n * Avoid sending multiple queries for the same hostname by caching results\n */ function cache(size) {\n return new CachedAnswers(size);\n} //# sourceMappingURL=cache.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvQG11bHRpZm9ybWF0cy9kbnMvZGlzdC9zcmMvdXRpbHMvY2FjaGUuanMiLCJtYXBwaW5ncyI6Ijs7Ozs7OztBQUE4QjtBQUNXO0FBQ3lCO0FBQ2xFOzs7O0NBSUMsR0FDRCxNQUFNSTtJQUVGQyxZQUFZQyxPQUFPLENBQUU7UUFDakIsSUFBSSxDQUFDQyxHQUFHLEdBQUdQLG9DQUFPQSxDQUFDTTtJQUN2QjtJQUNBRSxJQUFJQyxJQUFJLEVBQUVDLEtBQUssRUFBRTtRQUNiLElBQUlDLGtCQUFrQjtRQUN0QixNQUFNQyxVQUFVLEVBQUU7UUFDbEIsS0FBSyxNQUFNQyxRQUFRSCxNQUFPO1lBQ3RCLE1BQU1JLFNBQVMsSUFBSSxDQUFDQyxVQUFVLENBQUNOLE1BQU1JO1lBQ3JDLElBQUlDLE9BQU9FLE1BQU0sS0FBSyxHQUFHO2dCQUNyQkwsa0JBQWtCO2dCQUNsQjtZQUNKO1lBQ0FDLFFBQVFLLElBQUksSUFBSUg7UUFDcEI7UUFDQSxJQUFJSCxpQkFBaUI7WUFDakIsT0FBT1Isa0VBQWFBLENBQUM7Z0JBQUVTO1lBQVE7UUFDbkM7SUFDSjtJQUNBRyxXQUFXRyxNQUFNLEVBQUVMLElBQUksRUFBRTtRQUNyQixNQUFNTSxNQUFNLENBQUMsRUFBRUQsT0FBT0UsV0FBVyxHQUFHLENBQUMsRUFBRVAsS0FBSyxDQUFDO1FBQzdDLE1BQU1ELFVBQVUsSUFBSSxDQUFDTCxHQUFHLENBQUNDLEdBQUcsQ0FBQ1c7UUFDN0IsSUFBSVAsV0FBVyxNQUFNO1lBQ2pCLE1BQU1TLGdCQUFnQlQsUUFDakJVLE1BQU0sQ0FBQyxDQUFDQztnQkFDVCxPQUFPQSxNQUFNQyxPQUFPLEdBQUdDLEtBQUtDLEdBQUc7WUFDbkMsR0FDS0MsR0FBRyxDQUFDLENBQUMsRUFBRUgsT0FBTyxFQUFFSSxLQUFLLEVBQUUsR0FBTTtvQkFDOUIsR0FBR0EsS0FBSztvQkFDUkMsS0FBS0MsS0FBS0MsS0FBSyxDQUFDLENBQUNQLFVBQVVDLEtBQUtDLEdBQUcsRUFBQyxJQUFLO29CQUN6Q2IsTUFBTVosaURBQVUsQ0FBQzJCLE1BQU1mLElBQUksQ0FBQztnQkFDaEM7WUFDQSxJQUFJUSxjQUFjTCxNQUFNLEtBQUssR0FBRztnQkFDNUIsSUFBSSxDQUFDVCxHQUFHLENBQUN5QixNQUFNLENBQUNiO1lBQ3BCO1lBQ0Esc0VBQXNFO1lBQ3RFLHNFQUFzRTtZQUN0RSxPQUFPRTtRQUNYO1FBQ0EsT0FBTyxFQUFFO0lBQ2I7SUFDQVksSUFBSWYsTUFBTSxFQUFFZ0IsTUFBTSxFQUFFO1FBQ2hCLE1BQU1mLE1BQU0sQ0FBQyxFQUFFRCxPQUFPRSxXQUFXLEdBQUcsQ0FBQyxFQUFFYyxPQUFPckIsSUFBSSxDQUFDLENBQUM7UUFDcEQsTUFBTUQsVUFBVSxJQUFJLENBQUNMLEdBQUcsQ0FBQ0MsR0FBRyxDQUFDVyxRQUFRLEVBQUU7UUFDdkNQLFFBQVFLLElBQUksQ0FBQztZQUNUTyxTQUFTQyxLQUFLQyxHQUFHLEtBQU0sQ0FBQ1EsT0FBT0wsR0FBRyxJQUFJM0IsNERBQVUsSUFBSztZQUNyRDBCLE9BQU9NO1FBQ1g7UUFDQSxJQUFJLENBQUMzQixHQUFHLENBQUM0QixHQUFHLENBQUNoQixLQUFLUDtJQUN0QjtJQUNBb0IsT0FBT2QsTUFBTSxFQUFFTCxJQUFJLEVBQUU7UUFDakIsTUFBTU0sTUFBTSxDQUFDLEVBQUVELE9BQU9FLFdBQVcsR0FBRyxDQUFDLEVBQUVQLEtBQUssQ0FBQztRQUM3QyxJQUFJLENBQUNOLEdBQUcsQ0FBQ3lCLE1BQU0sQ0FBQ2I7SUFDcEI7SUFDQWlCLFFBQVE7UUFDSixJQUFJLENBQUM3QixHQUFHLENBQUM2QixLQUFLO0lBQ2xCO0FBQ0o7QUFDQTs7Q0FFQyxHQUNNLFNBQVNDLE1BQU1DLElBQUk7SUFDdEIsT0FBTyxJQUFJbEMsY0FBY2tDO0FBQzdCLEVBQ0EsaUNBQWlDIiwic291cmNlcyI6WyJ3ZWJwYWNrOi8vZmx1c2gtbm90ZXMvLi9ub2RlX21vZHVsZXMvQG11bHRpZm9ybWF0cy9kbnMvZGlzdC9zcmMvdXRpbHMvY2FjaGUuanM/NDZlMyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgaGFzaGxydSBmcm9tICdoYXNobHJ1JztcbmltcG9ydCB7IFJlY29yZFR5cGUgfSBmcm9tICcuLi9pbmRleC5qcyc7XG5pbXBvcnQgeyBERUZBVUxUX1RUTCwgdG9ETlNSZXNwb25zZSB9IGZyb20gJy4vdG8tZG5zLXJlc3BvbnNlLmpzJztcbi8qKlxuICogVGltZSBBd2FyZSBMZWFzdCBSZWNlbnQgVXNlZCBDYWNoZVxuICpcbiAqIEBzZWUgaHR0cHM6Ly9hcnhpdi5vcmcvcGRmLzE4MDEuMDAzOTBcbiAqL1xuY2xhc3MgQ2FjaGVkQW5zd2VycyB7XG4gICAgbHJ1O1xuICAgIGNvbnN0cnVjdG9yKG1heFNpemUpIHtcbiAgICAgICAgdGhpcy5scnUgPSBoYXNobHJ1KG1heFNpemUpO1xuICAgIH1cbiAgICBnZXQoZnFkbiwgdHlwZXMpIHtcbiAgICAgICAgbGV0IGZvdW5kQWxsQW5zd2VycyA9IHRydWU7XG4gICAgICAgIGNvbnN0IGFuc3dlcnMgPSBbXTtcbiAgICAgICAgZm9yIChjb25zdCB0eXBlIG9mIHR5cGVzKSB7XG4gICAgICAgICAgICBjb25zdCBjYWNoZWQgPSB0aGlzLmdldEFuc3dlcnMoZnFkbiwgdHlwZSk7XG4gICAgICAgICAgICBpZiAoY2FjaGVkLmxlbmd0aCA9PT0gMCkge1xuICAgICAgICAgICAgICAgIGZvdW5kQWxsQW5zd2VycyA9IGZhbHNlO1xuICAgICAgICAgICAgICAgIGJyZWFrO1xuICAgICAgICAgICAgfVxuICAgICAgICAgICAgYW5zd2Vycy5wdXNoKC4uLmNhY2hlZCk7XG4gICAgICAgIH1cbiAgICAgICAgaWYgKGZvdW5kQWxsQW5zd2Vycykge1xuICAgICAgICAgICAgcmV0dXJuIHRvRE5TUmVzcG9uc2UoeyBhbnN3ZXJzIH0pO1xuICAgICAgICB9XG4gICAgfVxuICAgIGdldEFuc3dlcnMoZG9tYWluLCB0eXBlKSB7XG4gICAgICAgIGNvbnN0IGtleSA9IGAke2RvbWFpbi50b0xvd2VyQ2FzZSgpfS0ke3R5cGV9YDtcbiAgICAgICAgY29uc3QgYW5zd2VycyA9IHRoaXMubHJ1LmdldChrZXkpO1xuICAgICAgICBpZiAoYW5zd2VycyAhPSBudWxsKSB7XG4gICAgICAgICAgICBjb25zdCBjYWNoZWRBbnN3ZXJzID0gYW5zd2Vyc1xuICAgICAgICAgICAgICAgIC5maWx0ZXIoKGVudHJ5KSA9PiB7XG4gICAgICAgICAgICAgICAgcmV0dXJuIGVudHJ5LmV4cGlyZXMgPiBEYXRlLm5vdygpO1xuICAgICAgICAgICAgfSlcbiAgICAgICAgICAgICAgICAubWFwKCh7IGV4cGlyZXMsIHZhbHVlIH0pID0+ICh7XG4gICAgICAgICAgICAgICAgLi4udmFsdWUsXG4gICAgICAgICAgICAgICAgVFRMOiBNYXRoLnJvdW5kKChleHBpcmVzIC0gRGF0ZS5ub3coKSkgLyAxMDAwKSxcbiAgICAgICAgICAgICAgICB0eXBlOiBSZWNvcmRUeXBlW3ZhbHVlLnR5cGVdXG4gICAgICAgICAgICB9KSk7XG4gICAgICAgICAgICBpZiAoY2FjaGVkQW5zd2Vycy5sZW5ndGggPT09IDApIHtcbiAgICAgICAgICAgICAgICB0aGlzLmxydS5yZW1vdmUoa2V5KTtcbiAgICAgICAgICAgIH1cbiAgICAgICAgICAgIC8vIEB0cy1leHBlY3QtZXJyb3IgaGFzaGxydSBzdHJpbmdpZmllcyBzdG9yZWQgdHlwZXMgd2hpY2ggdHVybnMgZW51bXNcbiAgICAgICAgICAgIC8vIGludG8gc3RyaW5ncywgd2UgY29udmVydCBiYWNrIGludG8gZW51bXMgYWJvdmUgYnV0IHRzYyBkb2Vzbid0IGtub3dcbiAgICAgICAgICAgIHJldHVybiBjYWNoZWRBbnN3ZXJzO1xuICAgICAgICB9XG4gICAgICAgIHJldHVybiBbXTtcbiAgICB9XG4gICAgYWRkKGRvbWFpbiwgYW5zd2VyKSB7XG4gICAgICAgIGNvbnN0IGtleSA9IGAke2RvbWFpbi50b0xvd2VyQ2FzZSgpfS0ke2Fuc3dlci50eXBlfWA7XG4gICAgICAgIGNvbnN0IGFuc3dlcnMgPSB0aGlzLmxydS5nZXQoa2V5KSA/PyBbXTtcbiAgICAgICAgYW5zd2Vycy5wdXNoKHtcbiAgICAgICAgICAgIGV4cGlyZXM6IERhdGUubm93KCkgKyAoKGFuc3dlci5UVEwgPz8gREVGQVVMVF9UVEwpICogMTAwMCksXG4gICAgICAgICAgICB2YWx1ZTogYW5zd2VyXG4gICAgICAgIH0pO1xuICAgICAgICB0aGlzLmxydS5zZXQoa2V5LCBhbnN3ZXJzKTtcbiAgICB9XG4gICAgcmVtb3ZlKGRvbWFpbiwgdHlwZSkge1xuICAgICAgICBjb25zdCBrZXkgPSBgJHtkb21haW4udG9Mb3dlckNhc2UoKX0tJHt0eXBlfWA7XG4gICAgICAgIHRoaXMubHJ1LnJlbW92ZShrZXkpO1xuICAgIH1cbiAgICBjbGVhcigpIHtcbiAgICAgICAgdGhpcy5scnUuY2xlYXIoKTtcbiAgICB9XG59XG4vKipcbiAqIEF2b2lkIHNlbmRpbmcgbXVsdGlwbGUgcXVlcmllcyBmb3IgdGhlIHNhbWUgaG9zdG5hbWUgYnkgY2FjaGluZyByZXN1bHRzXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBjYWNoZShzaXplKSB7XG4gICAgcmV0dXJuIG5ldyBDYWNoZWRBbnN3ZXJzKHNpemUpO1xufVxuLy8jIHNvdXJjZU1hcHBpbmdVUkw9Y2FjaGUuanMubWFwIl0sIm5hbWVzIjpbImhhc2hscnUiLCJSZWNvcmRUeXBlIiwiREVGQVVMVF9UVEwiLCJ0b0ROU1Jlc3BvbnNlIiwiQ2FjaGVkQW5zd2VycyIsImNvbnN0cnVjdG9yIiwibWF4U2l6ZSIsImxydSIsImdldCIsImZxZG4iLCJ0eXBlcyIsImZvdW5kQWxsQW5zd2VycyIsImFuc3dlcnMiLCJ0eXBlIiwiY2FjaGVkIiwiZ2V0QW5zd2VycyIsImxlbmd0aCIsInB1c2giLCJkb21haW4iLCJrZXkiLCJ0b0xvd2VyQ2FzZSIsImNhY2hlZEFuc3dlcnMiLCJmaWx0ZXIiLCJlbnRyeSIsImV4cGlyZXMiLCJEYXRlIiwibm93IiwibWFwIiwidmFsdWUiLCJUVEwiLCJNYXRoIiwicm91bmQiLCJyZW1vdmUiLCJhZGQiLCJhbnN3ZXIiLCJzZXQiLCJjbGVhciIsImNhY2hlIiwic2l6ZSJdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/@multiformats/dns/dist/src/utils/cache.js\n");
/***/ }),
/***/ "(ssr)/./node_modules/@multiformats/dns/dist/src/utils/get-types.js":
/*!********************************************************************!*\
!*** ./node_modules/@multiformats/dns/dist/src/utils/get-types.js ***!
\********************************************************************/
/***/ ((__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 */ getTypes: () => (/* binding */ getTypes)\n/* harmony export */ });\n/* harmony import */ var _index_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../index.js */ \"(ssr)/./node_modules/@multiformats/dns/dist/src/index.js\");\n\nfunction getTypes(types) {\n const DEFAULT_TYPES = [\n _index_js__WEBPACK_IMPORTED_MODULE_0__.RecordType.A\n ];\n if (types == null) {\n return DEFAULT_TYPES;\n }\n if (Array.isArray(types)) {\n if (types.length === 0) {\n return DEFAULT_TYPES;\n }\n return types;\n }\n return [\n types\n ];\n} //# sourceMappingURL=get-types.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvQG11bHRpZm9ybWF0cy9kbnMvZGlzdC9zcmMvdXRpbHMvZ2V0LXR5cGVzLmpzIiwibWFwcGluZ3MiOiI7Ozs7O0FBQXlDO0FBQ2xDLFNBQVNDLFNBQVNDLEtBQUs7SUFDMUIsTUFBTUMsZ0JBQWdCO1FBQ2xCSCxpREFBVUEsQ0FBQ0ksQ0FBQztLQUNmO0lBQ0QsSUFBSUYsU0FBUyxNQUFNO1FBQ2YsT0FBT0M7SUFDWDtJQUNBLElBQUlFLE1BQU1DLE9BQU8sQ0FBQ0osUUFBUTtRQUN0QixJQUFJQSxNQUFNSyxNQUFNLEtBQUssR0FBRztZQUNwQixPQUFPSjtRQUNYO1FBQ0EsT0FBT0Q7SUFDWDtJQUNBLE9BQU87UUFDSEE7S0FDSDtBQUNMLEVBQ0EscUNBQXFDIiwic291cmNlcyI6WyJ3ZWJwYWNrOi8vZmx1c2gtbm90ZXMvLi9ub2RlX21vZHVsZXMvQG11bHRpZm9ybWF0cy9kbnMvZGlzdC9zcmMvdXRpbHMvZ2V0LXR5cGVzLmpzPzMwNzAiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgUmVjb3JkVHlwZSB9IGZyb20gJy4uL2luZGV4LmpzJztcbmV4cG9ydCBmdW5jdGlvbiBnZXRUeXBlcyh0eXBlcykge1xuICAgIGNvbnN0IERFRkFVTFRfVFlQRVMgPSBbXG4gICAgICAgIFJlY29yZFR5cGUuQVxuICAgIF07XG4gICAgaWYgKHR5cGVzID09IG51bGwpIHtcbiAgICAgICAgcmV0dXJuIERFRkFVTFRfVFlQRVM7XG4gICAgfVxuICAgIGlmIChBcnJheS5pc0FycmF5KHR5cGVzKSkge1xuICAgICAgICBpZiAodHlwZXMubGVuZ3RoID09PSAwKSB7XG4gICAgICAgICAgICByZXR1cm4gREVGQVVMVF9UWVBFUztcbiAgICAgICAgfVxuICAgICAgICByZXR1cm4gdHlwZXM7XG4gICAgfVxuICAgIHJldHVybiBbXG4gICAgICAgIHR5cGVzXG4gICAgXTtcbn1cbi8vIyBzb3VyY2VNYXBwaW5nVVJMPWdldC10eXBlcy5qcy5tYXAiXSwibmFtZXMiOlsiUmVjb3JkVHlwZSIsImdldFR5cGVzIiwidHlwZXMiLCJERUZBVUxUX1RZUEVTIiwiQSIsIkFycmF5IiwiaXNBcnJheSIsImxlbmd0aCJdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/@multiformats/dns/dist/src/utils/get-types.js\n");
/***/ }),
/***/ "(ssr)/./node_modules/@multiformats/dns/dist/src/utils/to-dns-response.js":
/*!**************************************************************************!*\
!*** ./node_modules/@multiformats/dns/dist/src/utils/to-dns-response.js ***!
\**************************************************************************/
/***/ ((__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 */ DEFAULT_TTL: () => (/* binding */ DEFAULT_TTL),\n/* harmony export */ toDNSResponse: () => (/* binding */ toDNSResponse)\n/* harmony export */ });\n/* harmony import */ var uint8arrays_to_string__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! uint8arrays/to-string */ \"(ssr)/./node_modules/uint8arrays/dist/src/to-string.node.js\");\n/* harmony import */ var _index_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../index.js */ \"(ssr)/./node_modules/@multiformats/dns/dist/src/index.js\");\n\n\n/**\n * This TTL will be used if the remote service does not return one\n */ const DEFAULT_TTL = 60;\nfunction toDNSResponse(obj) {\n return {\n Status: obj.Status ?? 0,\n TC: obj.TC ?? obj.flag_tc ?? false,\n RD: obj.RD ?? obj.flag_rd ?? false,\n RA: obj.RA ?? obj.flag_ra ?? false,\n AD: obj.AD ?? obj.flag_ad ?? false,\n CD: obj.CD ?? obj.flag_cd ?? false,\n Question: (obj.Question ?? obj.questions ?? []).map((question)=>{\n return {\n name: question.name,\n type: _index_js__WEBPACK_IMPORTED_MODULE_1__.RecordType[question.type]\n };\n }),\n Answer: (obj.Answer ?? obj.answers ?? []).map((answer)=>{\n return {\n name: answer.name,\n type: _index_js__WEBPACK_IMPORTED_MODULE_1__.RecordType[answer.type],\n TTL: answer.TTL ?? answer.ttl ?? DEFAULT_TTL,\n data: answer.data instanceof Uint8Array ? (0,uint8arrays_to_string__WEBPACK_IMPORTED_MODULE_0__.toString)(answer.data) : answer.data\n };\n })\n };\n} //# sourceMappingURL=to-dns-response.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvQG11bHRpZm9ybWF0cy9kbnMvZGlzdC9zcmMvdXRpbHMvdG8tZG5zLXJlc3BvbnNlLmpzIiwibWFwcGluZ3MiOiI7Ozs7Ozs7QUFBdUU7QUFDOUI7QUFDekM7O0NBRUMsR0FDTSxNQUFNRyxjQUFjLEdBQUc7QUFDdkIsU0FBU0MsY0FBY0MsR0FBRztJQUM3QixPQUFPO1FBQ0hDLFFBQVFELElBQUlDLE1BQU0sSUFBSTtRQUN0QkMsSUFBSUYsSUFBSUUsRUFBRSxJQUFJRixJQUFJRyxPQUFPLElBQUk7UUFDN0JDLElBQUlKLElBQUlJLEVBQUUsSUFBSUosSUFBSUssT0FBTyxJQUFJO1FBQzdCQyxJQUFJTixJQUFJTSxFQUFFLElBQUlOLElBQUlPLE9BQU8sSUFBSTtRQUM3QkMsSUFBSVIsSUFBSVEsRUFBRSxJQUFJUixJQUFJUyxPQUFPLElBQUk7UUFDN0JDLElBQUlWLElBQUlVLEVBQUUsSUFBSVYsSUFBSVcsT0FBTyxJQUFJO1FBQzdCQyxVQUFVLENBQUNaLElBQUlZLFFBQVEsSUFBSVosSUFBSWEsU0FBUyxJQUFJLEVBQUUsRUFBRUMsR0FBRyxDQUFDLENBQUNDO1lBQ2pELE9BQU87Z0JBQ0hDLE1BQU1ELFNBQVNDLElBQUk7Z0JBQ25CQyxNQUFNcEIsaURBQVUsQ0FBQ2tCLFNBQVNFLElBQUksQ0FBQztZQUNuQztRQUNKO1FBQ0FDLFFBQVEsQ0FBQ2xCLElBQUlrQixNQUFNLElBQUlsQixJQUFJbUIsT0FBTyxJQUFJLEVBQUUsRUFBRUwsR0FBRyxDQUFDLENBQUNNO1lBQzNDLE9BQU87Z0JBQ0hKLE1BQU1JLE9BQU9KLElBQUk7Z0JBQ2pCQyxNQUFNcEIsaURBQVUsQ0FBQ3VCLE9BQU9ILElBQUksQ0FBQztnQkFDN0JJLEtBQU1ELE9BQU9DLEdBQUcsSUFBSUQsT0FBT0UsR0FBRyxJQUFJeEI7Z0JBQ2xDeUIsTUFBTUgsT0FBT0csSUFBSSxZQUFZQyxhQUFhNUIsK0RBQWtCQSxDQUFDd0IsT0FBT0csSUFBSSxJQUFJSCxPQUFPRyxJQUFJO1lBQzNGO1FBQ0o7SUFDSjtBQUNKLEVBQ0EsMkNBQTJDIiwic291cmNlcyI6WyJ3ZWJwYWNrOi8vZmx1c2gtbm90ZXMvLi9ub2RlX21vZHVsZXMvQG11bHRpZm9ybWF0cy9kbnMvZGlzdC9zcmMvdXRpbHMvdG8tZG5zLXJlc3BvbnNlLmpzPzQ0NTciXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgdG9TdHJpbmcgYXMgdWludDhBcnJheVRvU3RyaW5nIH0gZnJvbSAndWludDhhcnJheXMvdG8tc3RyaW5nJztcbmltcG9ydCB7IFJlY29yZFR5cGUgfSBmcm9tICcuLi9pbmRleC5qcyc7XG4vKipcbiAqIFRoaXMgVFRMIHdpbGwgYmUgdXNlZCBpZiB0aGUgcmVtb3RlIHNlcnZpY2UgZG9lcyBub3QgcmV0dXJuIG9uZVxuICovXG5leHBvcnQgY29uc3QgREVGQVVMVF9UVEwgPSA2MDtcbmV4cG9ydCBmdW5jdGlvbiB0b0ROU1Jlc3BvbnNlKG9iaikge1xuICAgIHJldHVybiB7XG4gICAgICAgIFN0YXR1czogb2JqLlN0YXR1cyA/PyAwLFxuICAgICAgICBUQzogb2JqLlRDID8/IG9iai5mbGFnX3RjID8/IGZhbHNlLFxuICAgICAgICBSRDogb2JqLlJEID8/IG9iai5mbGFnX3JkID8/IGZhbHNlLFxuICAgICAgICBSQTogb2JqLlJBID8/IG9iai5mbGFnX3JhID8/IGZhbHNlLFxuICAgICAgICBBRDogb2JqLkFEID8/IG9iai5mbGFnX2FkID8/IGZhbHNlLFxuICAgICAgICBDRDogb2JqLkNEID8/IG9iai5mbGFnX2NkID8/IGZhbHNlLFxuICAgICAgICBRdWVzdGlvbjogKG9iai5RdWVzdGlvbiA/PyBvYmoucXVlc3Rpb25zID8/IFtdKS5tYXAoKHF1ZXN0aW9uKSA9PiB7XG4gICAgICAgICAgICByZXR1cm4ge1xuICAgICAgICAgICAgICAgIG5hbWU6IHF1ZXN0aW9uLm5hbWUsXG4gICAgICAgICAgICAgICAgdHlwZTogUmVjb3JkVHlwZVtxdWVzdGlvbi50eXBlXVxuICAgICAgICAgICAgfTtcbiAgICAgICAgfSksXG4gICAgICAgIEFuc3dlcjogKG9iai5BbnN3ZXIgPz8gb2JqLmFuc3dlcnMgPz8gW10pLm1hcCgoYW5zd2VyKSA9PiB7XG4gICAgICAgICAgICByZXR1cm4ge1xuICAgICAgICAgICAgICAgIG5hbWU6IGFuc3dlci5uYW1lLFxuICAgICAgICAgICAgICAgIHR5cGU6IFJlY29yZFR5cGVbYW5zd2VyLnR5cGVdLFxuICAgICAgICAgICAgICAgIFRUTDogKGFuc3dlci5UVEwgPz8gYW5zd2VyLnR0bCA/PyBERUZBVUxUX1RUTCksXG4gICAgICAgICAgICAgICAgZGF0YTogYW5zd2VyLmRhdGEgaW5zdGFuY2VvZiBVaW50OEFycmF5ID8gdWludDhBcnJheVRvU3RyaW5nKGFuc3dlci5kYXRhKSA6IGFuc3dlci5kYXRhXG4gICAgICAgICAgICB9O1xuICAgICAgICB9KVxuICAgIH07XG59XG4vLyMgc291cmNlTWFwcGluZ1VSTD10by1kbnMtcmVzcG9uc2UuanMubWFwIl0sIm5hbWVzIjpbInRvU3RyaW5nIiwidWludDhBcnJheVRvU3RyaW5nIiwiUmVjb3JkVHlwZSIsIkRFRkFVTFRfVFRMIiwidG9ETlNSZXNwb25zZSIsIm9iaiIsIlN0YXR1cyIsIlRDIiwiZmxhZ190YyIsIlJEIiwiZmxhZ19yZCIsIlJBIiwiZmxhZ19yYSIsIkFEIiwiZmxhZ19hZCIsIkNEIiwiZmxhZ19jZCIsIlF1ZXN0aW9uIiwicXVlc3Rpb25zIiwibWFwIiwicXVlc3Rpb24iLCJuYW1lIiwidHlwZSIsIkFuc3dlciIsImFuc3dlcnMiLCJhbnN3ZXIiLCJUVEwiLCJ0dGwiLCJkYXRhIiwiVWludDhBcnJheSJdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/@multiformats/dns/dist/src/utils/to-dns-response.js\n");
/***/ }),
/***/ "(ssr)/./node_modules/@multiformats/mafmt/dist/src/index.js":
/*!************************************************************!*\
!*** ./node_modules/@multiformats/mafmt/dist/src/index.js ***!
\************************************************************/
/***/ ((__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 */ Circuit: () => (/* binding */ Circuit),\n/* harmony export */ DNS: () => (/* binding */ DNS),\n/* harmony export */ DNS4: () => (/* binding */ DNS4),\n/* harmony export */ DNS6: () => (/* binding */ DNS6),\n/* harmony export */ DNSADDR: () => (/* binding */ DNSADDR),\n/* harmony export */ HTTP: () => (/* binding */ HTTP),\n/* harmony export */ HTTPS: () => (/* binding */ HTTPS),\n/* harmony export */ IP: () => (/* binding */ IP),\n/* harmony export */ IPFS: () => (/* binding */ IPFS),\n/* harmony export */ P2P: () => (/* binding */ P2P),\n/* harmony export */ P2PWebRTCDirect: () => (/* binding */ P2PWebRTCDirect),\n/* harmony export */ P2PWebRTCStar: () => (/* binding */ P2PWebRTCStar),\n/* harmony export */ QUIC: () => (/* binding */ QUIC),\n/* harmony export */ QUICV1: () => (/* binding */ QUICV1),\n/* harmony export */ Reliable: () => (/* binding */ Reliable),\n/* harmony export */ Stardust: () => (/* binding */ Stardust),\n/* harmony export */ TCP: () => (/* binding */ TCP),\n/* harmony export */ UDP: () => (/* binding */ UDP),\n/* harmony export */ UTP: () => (/* binding */ UTP),\n/* harmony export */ WebRTC: () => (/* binding */ WebRTC),\n/* harmony export */ WebRTCDirect: () => (/* binding */ WebRTCDirect),\n/* harmony export */ WebSocketStar: () => (/* binding */ WebSocketStar),\n/* harmony export */ WebSockets: () => (/* binding */ WebSockets),\n/* harmony export */ WebSocketsSecure: () => (/* binding */ WebSocketsSecure),\n/* harmony export */ WebTransport: () => (/* binding */ WebTransport)\n/* harmony export */ });\n/* harmony import */ var _multiformats_multiaddr__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @multiformats/multiaddr */ \"(ssr)/./node_modules/@multiformats/multiaddr/dist/src/index.js\");\n\n/*\n * Valid combinations\n */ const DNS4 = base(\"dns4\");\nconst DNS6 = base(\"dns6\");\nconst DNSADDR = base(\"dnsaddr\");\nconst DNS = or(base(\"dns\"), DNSADDR, DNS4, DNS6);\nconst IP = or(base(\"ip4\"), base(\"ip6\"));\nconst TCP = or(and(IP, base(\"tcp\")), and(DNS, base(\"tcp\")));\nconst UDP = and(IP, base(\"udp\"));\nconst UTP = and(UDP, base(\"utp\"));\nconst QUIC = and(UDP, base(\"quic\"));\nconst QUICV1 = and(UDP, base(\"quic-v1\"));\nconst _WebSockets = or(and(TCP, base(\"ws\")), and(DNS, base(\"ws\")));\nconst WebSockets = or(and(_WebSockets, base(\"p2p\")), _WebSockets);\nconst _WebSocketsSecure = or(and(TCP, base(\"wss\")), and(DNS, base(\"wss\")), and(TCP, base(\"tls\"), base(\"ws\")), and(DNS, base(\"tls\"), base(\"ws\")));\nconst WebSocketsSecure = or(and(_WebSocketsSecure, base(\"p2p\")), _WebSocketsSecure);\nconst HTTP = or(and(TCP, base(\"http\")), and(IP, base(\"http\")), and(DNS, base(\"http\")));\nconst HTTPS = or(and(TCP, base(\"https\")), and(IP, base(\"https\")), and(DNS, base(\"https\")));\nconst _WebRTCDirect = and(UDP, base(\"webrtc-direct\"), base(\"certhash\"));\nconst WebRTCDirect = or(and(_WebRTCDirect, base(\"p2p\")), _WebRTCDirect);\nconst _WebTransport = and(QUICV1, base(\"webtransport\"), base(\"certhash\"), base(\"certhash\"));\nconst WebTransport = or(and(_WebTransport, base(\"p2p\")), _WebTransport);\n/**\n * @deprecated\n */ const P2PWebRTCStar = or(and(WebSockets, base(\"p2p-webrtc-star\"), base(\"p2p\")), and(WebSocketsSecure, base(\"p2p-webrtc-star\"), base(\"p2p\")), and(WebSockets, base(\"p2p-webrtc-star\")), and(WebSocketsSecure, base(\"p2p-webrtc-star\")));\nconst WebSocketStar = or(and(WebSockets, base(\"p2p-websocket-star\"), base(\"p2p\")), and(WebSocketsSecure, base(\"p2p-websocket-star\"), base(\"p2p\")), and(WebSockets, base(\"p2p-websocket-star\")), and(WebSocketsSecure, base(\"p2p-websocket-star\")));\n/**\n * @deprecated\n */ const P2PWebRTCDirect = or(and(HTTP, base(\"p2p-webrtc-direct\"), base(\"p2p\")), and(HTTPS, base(\"p2p-webrtc-direct\"), base(\"p2p\")), and(HTTP, base(\"p2p-webrtc-direct\")), and(HTTPS, base(\"p2p-webrtc-direct\")));\nconst Reliable = or(_WebSockets, _WebSocketsSecure, HTTP, HTTPS, P2PWebRTCStar, P2PWebRTCDirect, TCP, UTP, QUIC, DNS, WebRTCDirect, WebTransport);\n// Unlike ws-star, stardust can run over any transport thus removing the requirement for websockets (but don't even think about running a stardust server over webrtc-star ;) )\nconst Stardust = or(and(Reliable, base(\"p2p-stardust\"), base(\"p2p\")), and(Reliable, base(\"p2p-stardust\")));\nconst _P2P = or(and(Reliable, base(\"p2p\")), P2PWebRTCStar, P2PWebRTCDirect, WebRTCDirect, WebTransport, base(\"p2p\"));\nconst _Circuit = or(and(_P2P, base(\"p2p-circuit\"), _P2P), and(_P2P, base(\"p2p-circuit\")), and(base(\"p2p-circuit\"), _P2P), and(Reliable, base(\"p2p-circuit\")), and(base(\"p2p-circuit\"), Reliable), base(\"p2p-circuit\"));\nconst CircuitRecursive = ()=>or(and(_Circuit, CircuitRecursive), _Circuit);\nconst Circuit = CircuitRecursive();\nconst P2P = or(and(Circuit, _P2P, Circuit), and(_P2P, Circuit), and(Circuit, _P2P), Circuit, _P2P);\nconst IPFS = P2P;\nconst WebRTC = or(and(Circuit, base(\"webrtc\"), base(\"p2p\")), and(Circuit, base(\"webrtc\")), and(Reliable, base(\"webrtc\"), base(\"p2p\")), and(Reliable, base(\"webrtc\")), base(\"webrtc\"));\n/*\n * Validation funcs\n */ function makeMatchesFunction(partialMatch) {\n function matches(a) {\n let ma;\n try {\n ma = (0,_multiformats_multiaddr__WEBPACK_IMPORTED_MODULE_0__.multiaddr)(a);\n } catch (err) {\n return false; // also if it's invalid it's probably not matching as well so return false\n }\n const out = partialMatch(ma.protoNames());\n if (out === null) {\n return false;\n }\n if (out === true || out === false) {\n return out;\n }\n return out.length === 0;\n }\n return matches;\n}\nfunction and(...args) {\n function partialMatch(a) {\n if (a.length < args.length) {\n return null;\n }\n let out = a;\n args.some((arg)=>{\n out = typeof arg === \"function\" ? arg().partialMatch(a) : arg.partialMatch(a);\n if (Array.isArray(out)) {\n a = out;\n }\n if (out === null) {\n return true;\n }\n return false;\n });\n return out;\n }\n return {\n toString: function() {\n return \"{ \" + args.join(\" \") + \" }\";\n },\n input: args,\n matches: makeMatchesFunction(partialMatch),\n partialMatch\n };\n}\nfunction or(...args) {\n function partialMatch(a) {\n let out = null;\n args.some((arg)=>{\n const res = typeof arg === \"function\" ? arg().partialMatch(a) : arg.partialMatch(a);\n if (res != null) {\n out = res;\n return true;\n }\n return false;\n });\n return out;\n }\n const result = {\n toString: function() {\n return \"{ \" + args.join(\" \") + \" }\";\n },\n input: args,\n matches: makeMatchesFunction(partialMatch),\n partialMatch\n };\n return result;\n}\nfunction base(n) {\n const name = n;\n function matches(a) {\n let ma;\n try {\n ma = (0,_multiformats_multiaddr__WEBPACK_IMPORTED_MODULE_0__.multiaddr)(a);\n } catch (err) {\n return false; // also if it's invalid it's probably not matching as well so return false\n }\n const pnames = ma.protoNames();\n if (pnames.length === 1 && pnames[0] === name) {\n return true;\n }\n return false;\n }\n function partialMatch(protos) {\n if (protos.length === 0) {\n return null;\n }\n if (protos[0] === name) {\n return protos.slice(1);\n }\n return null;\n }\n return {\n toString: function() {\n return name;\n },\n matches,\n partialMatch\n };\n} //# sourceMappingURL=index.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"(ssr)/./node_modules/@multiformats/mafmt/dist/src/index.js","mappings":"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","sources":["webpack://flush-notes/./node_modules/@multiformats/mafmt/dist/src/index.js?2465"],"sourcesContent":["import { multiaddr } from '@multiformats/multiaddr';\n/*\n * Valid combinations\n */\nexport const DNS4 = base('dns4');\nexport const DNS6 = base('dns6');\nexport const DNSADDR = base('dnsaddr');\nexport const DNS = or(base('dns'), DNSADDR, DNS4, DNS6);\nexport const IP = or(base('ip4'), base('ip6'));\nexport const TCP = or(and(IP, base('tcp')), and(DNS, base('tcp')));\nexport const UDP = and(IP, base('udp'));\nexport const UTP = and(UDP, base('utp'));\nexport const QUIC = and(UDP, base('quic'));\nexport const QUICV1 = and(UDP, base('quic-v1'));\nconst _WebSockets = or(and(TCP, base('ws')), and(DNS, base('ws')));\nexport const WebSockets = or(and(_WebSockets, base('p2p')), _WebSockets);\nconst _WebSocketsSecure = or(and(TCP, base('wss')), and(DNS, base('wss')), and(TCP, base('tls'), base('ws')), and(DNS, base('tls'), base('ws')));\nexport const WebSocketsSecure = or(and(_WebSocketsSecure, base('p2p')), _WebSocketsSecure);\nexport const HTTP = or(and(TCP, base('http')), and(IP, base('http')), and(DNS, base('http')));\nexport const HTTPS = or(and(TCP, base('https')), and(IP, base('https')), and(DNS, base('https')));\nconst _WebRTCDirect = and(UDP, base('webrtc-direct'), base('certhash'));\nexport const WebRTCDirect = or(and(_WebRTCDirect, base('p2p')), _WebRTCDirect);\nconst _WebTransport = and(QUICV1, base('webtransport'), base('certhash'), base('certhash'));\nexport const WebTransport = or(and(_WebTransport, base('p2p')), _WebTransport);\n/**\n * @deprecated\n */\nexport const P2PWebRTCStar = or(and(WebSockets, base('p2p-webrtc-star'), base('p2p')), and(WebSocketsSecure, base('p2p-webrtc-star'), base('p2p')), and(WebSockets, base('p2p-webrtc-star')), and(WebSocketsSecure, base('p2p-webrtc-star')));\nexport const WebSocketStar = or(and(WebSockets, base('p2p-websocket-star'), base('p2p')), and(WebSocketsSecure, base('p2p-websocket-star'), base('p2p')), and(WebSockets, base('p2p-websocket-star')), and(WebSocketsSecure, base('p2p-websocket-star')));\n/**\n * @deprecated\n */\nexport const P2PWebRTCDirect = or(and(HTTP, base('p2p-webrtc-direct'), base('p2p')), and(HTTPS, base('p2p-webrtc-direct'), base('p2p')), and(HTTP, base('p2p-webrtc-direct')), and(HTTPS, base('p2p-webrtc-direct')));\nexport const Reliable = or(_WebSockets, _WebSocketsSecure, HTTP, HTTPS, P2PWebRTCStar, P2PWebRTCDirect, TCP, UTP, QUIC, DNS, WebRTCDirect, WebTransport);\n// Unlike ws-star, stardust can run over any transport thus removing the requirement for websockets (but don't even think about running a stardust server over webrtc-star ;) )\nexport const Stardust = or(and(Reliable, base('p2p-stardust'), base('p2p')), and(Reliable, base('p2p-stardust')));\nconst _P2P = or(and(Reliable, base('p2p')), P2PWebRTCStar, P2PWebRTCDirect, WebRTCDirect, WebTransport, base('p2p'));\nconst _Circuit = or(and(_P2P, base('p2p-circuit'), _P2P), and(_P2P, base('p2p-circuit')), and(base('p2p-circuit'), _P2P), and(Reliable, base('p2p-circuit')), and(base('p2p-circuit'), Reliable), base('p2p-circuit'));\nconst CircuitRecursive = () => or(and(_Circuit, CircuitRecursive), _Circuit);\nexport const Circuit = CircuitRecursive();\nexport const P2P = or(and(Circuit, _P2P, Circuit), and(_P2P, Circuit), and(Circuit, _P2P), Circuit, _P2P);\nexport const IPFS = P2P;\nexport const WebRTC = or(and(Circuit, base('webrtc'), base('p2p')), and(Circuit, base('webrtc')), and(Reliable, base('webrtc'), base('p2p')), and(Reliable, base('webrtc')), base('webrtc'));\n/*\n * Validation funcs\n */\nfunction makeMatchesFunction(partialMatch) {\n    function matches(a) {\n        let ma;\n        try {\n            ma = multiaddr(a);\n        }\n        catch (err) { // catch error\n            return false; // also if it's invalid it's probably not matching as well so return false\n        }\n        const out = partialMatch(ma.protoNames());\n        if (out === null) {\n            return false;\n        }\n        if (out === true || out === false) {\n            return out;\n        }\n        return out.length === 0;\n    }\n    return matches;\n}\nfunction and(...args) {\n    function partialMatch(a) {\n        if (a.length < args.length) {\n            return null;\n        }\n        let out = a;\n        args.some((arg) => {\n            out = typeof arg === 'function'\n                ? arg().partialMatch(a)\n                : arg.partialMatch(a);\n            if (Array.isArray(out)) {\n                a = out;\n            }\n            if (out === null) {\n                return true;\n            }\n            return false;\n        });\n        return out;\n    }\n    return {\n        toString: function () { return '{ ' + args.join(' ') + ' }'; },\n        input: args,\n        matches: makeMatchesFunction(partialMatch),\n        partialMatch\n    };\n}\nfunction or(...args) {\n    function partialMatch(a) {\n        let out = null;\n        args.some((arg) => {\n            const res = typeof arg === 'function'\n                ? arg().partialMatch(a)\n                : arg.partialMatch(a);\n            if (res != null) {\n                out = res;\n                return true;\n            }\n            return false;\n        });\n        return out;\n    }\n    const result = {\n        toString: function () { return '{ ' + args.join(' ') + ' }'; },\n        input: args,\n        matches: makeMatchesFunction(partialMatch),\n        partialMatch\n    };\n    return result;\n}\nfunction base(n) {\n    const name = n;\n    function matches(a) {\n        let ma;\n        try {\n            ma = multiaddr(a);\n        }\n        catch (err) { // catch error\n            return false; // also if it's invalid it's probably not matching as well so return false\n        }\n        const pnames = ma.protoNames();\n        if (pnames.length === 1 && pnames[0] === name) {\n            return true;\n        }\n        return false;\n    }\n    function partialMatch(protos) {\n        if (protos.length === 0) {\n            return null;\n        }\n        if (protos[0] === name) {\n            return protos.slice(1);\n        }\n        return null;\n    }\n    return {\n        toString: function () { return name; },\n        matches,\n        partialMatch\n    };\n}\n//# sourceMappingURL=index.js.map"],"names":["multiaddr","DNS4","base","DNS6","DNSADDR","DNS","or","IP","TCP","and","UDP","UTP","QUIC","QUICV1","_WebSockets","WebSockets","_WebSocketsSecure","WebSocketsSecure","HTTP","HTTPS","_WebRTCDirect","WebRTCDirect","_WebTransport","WebTransport","P2PWebRTCStar","WebSocketStar","P2PWebRTCDirect","Reliable","Stardust","_P2P","_Circuit","CircuitRecursive","Circuit","P2P","IPFS","WebRTC","makeMatchesFunction","partialMatch","matches","a","ma","err","out","protoNames","length","args","some","arg","Array","isArray","toString","join","input","res","result","n","name","pnames","protos","slice"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/@multiformats/mafmt/dist/src/index.js\n");
/***/ }),
/***/ "(ssr)/./node_modules/@multiformats/multiaddr-matcher/dist/src/index.js":
/*!************************************************************************!*\
!*** ./node_modules/@multiformats/multiaddr-matcher/dist/src/index.js ***!
\************************************************************************/
/***/ ((__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 */ Circuit: () => (/* binding */ Circuit),\n/* harmony export */ DNS: () => (/* binding */ DNS),\n/* harmony export */ DNS4: () => (/* binding */ DNS4),\n/* harmony export */ DNS6: () => (/* binding */ DNS6),\n/* harmony export */ DNSADDR: () => (/* binding */ DNSADDR),\n/* harmony export */ HTTP: () => (/* binding */ HTTP),\n/* harmony export */ HTTPS: () => (/* binding */ HTTPS),\n/* harmony export */ IP: () => (/* binding */ IP),\n/* harmony export */ IP4: () => (/* binding */ IP4),\n/* harmony export */ IP6: () => (/* binding */ IP6),\n/* harmony export */ IP_OR_DOMAIN: () => (/* binding */ IP_OR_DOMAIN),\n/* harmony export */ P2P: () => (/* binding */ P2P),\n/* harmony export */ QUIC: () => (/* binding */ QUIC),\n/* harmony export */ QUICV1: () => (/* binding */ QUICV1),\n/* harmony export */ TCP: () => (/* binding */ TCP),\n/* harmony export */ UDP: () => (/* binding */ UDP),\n/* harmony export */ WebRTC: () => (/* binding */ WebRTC),\n/* harmony export */ WebRTCDirect: () => (/* binding */ WebRTCDirect),\n/* harmony export */ WebSockets: () => (/* binding */ WebSockets),\n/* harmony export */ WebSocketsSecure: () => (/* binding */ WebSocketsSecure),\n/* harmony export */ WebTransport: () => (/* binding */ WebTransport)\n/* harmony export */ });\n/* harmony import */ var _chainsafe_is_ip__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @chainsafe/is-ip */ \"(ssr)/./node_modules/@chainsafe/is-ip/lib/is-ip.node.js\");\n/* harmony import */ var _multiformats_multiaddr__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @multiformats/multiaddr */ \"(ssr)/./node_modules/@multiformats/multiaddr/dist/src/index.js\");\n/* harmony import */ var multiformats_bases_base58__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! multiformats/bases/base58 */ \"(ssr)/./node_modules/multiformats/dist/src/bases/base58.js\");\n/* harmony import */ var multiformats_bases_base64__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! multiformats/bases/base64 */ \"(ssr)/./node_modules/multiformats/dist/src/bases/base64.js\");\n/**\n * @packageDocumentation\n *\n * This module exports various matchers that can be used to infer the type of a\n * passed multiaddr.\n *\n * @example\n *\n * ```ts\n * import { multiaddr } from '@multiformats/multiaddr'\n * import { DNS } from '@multiformats/multiaddr-matcher'\n *\n * const ma = multiaddr('/dnsaddr/example.org')\n *\n * DNS.matches(ma) // true - this is a multiaddr with a DNS address at the start\n * ```\n *\n * @example\n *\n * The default matching behaviour ignores any subsequent tuples in the multiaddr.\n * If you want stricter matching you can use `.exactMatch`:\n *\n * ```ts\n * import { multiaddr } from '@multiformats/multiaddr'\n * import { DNS, Circuit } from '@multiformats/multiaddr-matcher'\n *\n * const ma = multiaddr('/dnsaddr/example.org/p2p/QmFoo/p2p-circuit/p2p/QmBar')\n *\n * DNS.exactMatch(ma) // false - this address has extra tuples after the DNS component\n * Circuit.matches(ma) // true\n * Circuit.exactMatch(ma) // true - the extra tuples are circuit relay related\n * ```\n */ \n\n\n\n/**\n * Split a multiaddr into path components\n */ const toParts = (ma)=>{\n return ma.toString().split(\"/\").slice(1);\n};\nconst func = (fn)=>{\n return {\n match: (vals)=>{\n if (vals.length < 1) {\n return false;\n }\n if (fn(vals[0])) {\n return vals.slice(1);\n }\n return false;\n },\n pattern: \"fn\"\n };\n};\nconst literal = (str)=>{\n return {\n match: (vals)=>func((val)=>val === str).match(vals),\n pattern: str\n };\n};\nconst string = ()=>{\n return {\n match: (vals)=>func((val)=>typeof val === \"string\").match(vals),\n pattern: \"{string}\"\n };\n};\nconst number = ()=>{\n return {\n match: (vals)=>func((val)=>!isNaN(parseInt(val))).match(vals),\n pattern: \"{number}\"\n };\n};\nconst peerId = ()=>{\n return {\n match: (vals)=>{\n if (vals.length < 2) {\n return false;\n }\n if (vals[0] !== \"p2p\" && vals[0] !== \"ipfs\") {\n return false;\n }\n // Q is RSA, 1 is Ed25519 or Secp256k1\n if (vals[1].startsWith(\"Q\") || vals[1].startsWith(\"1\")) {\n try {\n multiformats_bases_base58__WEBPACK_IMPORTED_MODULE_2__.base58btc.decode(`z${vals[1]}`);\n } catch (err) {\n return false;\n }\n } else {\n return false;\n }\n return vals.slice(2);\n },\n pattern: \"/p2p/{peerid}\"\n };\n};\nconst certhash = ()=>{\n return {\n match: (vals)=>{\n if (vals.length < 2) {\n return false;\n }\n if (vals[0] !== \"certhash\") {\n return false;\n }\n try {\n multiformats_bases_base64__WEBPACK_IMPORTED_MODULE_3__.base64url.decode(vals[1]);\n } catch {\n return false;\n }\n return vals.slice(2);\n },\n pattern: \"/certhash/{certhash}\"\n };\n};\nconst optional = (matcher)=>{\n return {\n match: (vals)=>{\n const result = matcher.match(vals);\n if (result === false) {\n return vals;\n }\n return result;\n },\n pattern: `optional(${matcher.pattern})`\n };\n};\nconst or = (...matchers)=>{\n return {\n match: (vals)=>{\n let matches;\n for (const matcher of matchers){\n const result = matcher.match(vals);\n // no match\n if (result === false) {\n continue;\n }\n // choose greediest matcher\n if (matches == null || result.length < matches.length) {\n matches = result;\n }\n }\n if (matches == null) {\n return false;\n }\n return matches;\n },\n pattern: `or(${matchers.map((m)=>m.pattern).join(\", \")})`\n };\n};\nconst and = (...matchers)=>{\n return {\n match: (vals)=>{\n for (const matcher of matchers){\n // pass what's left of the array\n const result = matcher.match(vals);\n // no match\n if (result === false) {\n return false;\n }\n vals = result;\n }\n return vals;\n },\n pattern: `and(${matchers.map((m)=>m.pattern).join(\", \")})`\n };\n};\nfunction fmt(...matchers) {\n function match(ma) {\n let parts = toParts(ma);\n for (const matcher of matchers){\n const result = matcher.match(parts);\n if (result === false) {\n return false;\n }\n parts = result;\n }\n return parts;\n }\n function matches(ma) {\n const result = match(ma);\n return result !== false;\n }\n function exactMatch(ma) {\n const result = match(ma);\n if (result === false) {\n return false;\n }\n return result.length === 0;\n }\n return {\n matches,\n exactMatch\n };\n}\n/**\n * DNS matchers\n */ const _DNS4 = and(literal(\"dns4\"), string());\nconst _DNS6 = and(literal(\"dns6\"), string());\nconst _DNSADDR = and(literal(\"dnsaddr\"), string());\nconst _DNS = and(literal(\"dns\"), string());\n/**\n * Matches dns4 addresses.\n *\n * Use {@link DNS DNS} instead to match any type of DNS address.\n *\n * @example\n *\n * ```ts\n * import { multiaddr } from '@multiformats/multiaddr'\n * import { DNS4 } from '@multiformats/multiaddr-matcher'\n *\n * DNS4.matches(multiaddr('/dns4/example.org')) // true\n * ```\n */ const DNS4 = fmt(_DNS4);\n/**\n * Matches dns6 addresses.\n *\n * Use {@link DNS DNS} instead to match any type of DNS address.\n *\n * @example\n *\n * ```ts\n * import { multiaddr } from '@multiformats/multiaddr'\n * import { DNS6 } from '@multiformats/multiaddr-matcher'\n *\n * DNS6.matches(multiaddr('/dns6/example.org')) // true\n * ```\n */ const DNS6 = fmt(_DNS6);\n/**\n * Matches dnsaddr addresses.\n *\n * Use {@link DNS DNS} instead to match any type of DNS address.\n *\n * @example\n *\n * ```ts\n * import { multiaddr } from '@multiformats/multiaddr'\n * import { DNSADDR } from '@multiformats/multiaddr-matcher'\n *\n * DNSADDR.matches(multiaddr('/dnsaddr/example.org')) // true\n * ```\n */ const DNSADDR = fmt(_DNSADDR);\n/**\n * Matches any dns address.\n *\n * @example\n *\n * ```ts\n * import { multiaddr } from '@multiformats/multiaddr'\n * import { DNS } from '@multiformats/multiaddr-matcher'\n *\n * DNS.matches(multiaddr('/dnsaddr/example.org')) // true\n * DNS.matches(multiaddr('/dns4/example.org')) // true\n * DNS.matches(multiaddr('/dns6/example.org')) // true\n * ```\n */ const DNS = fmt(or(_DNS, _DNSADDR, _DNS4, _DNS6));\nconst _IP4 = and(literal(\"ip4\"), func(_chainsafe_is_ip__WEBPACK_IMPORTED_MODULE_0__.isIPv4));\nconst _IP6 = and(literal(\"ip6\"), func(_chainsafe_is_ip__WEBPACK_IMPORTED_MODULE_0__.isIPv6));\nconst _IP = or(_IP4, _IP6);\nconst _IP_OR_DOMAIN = or(_IP, _DNS, _DNS4, _DNS6, _DNSADDR);\n/**\n * A matcher for addresses that start with IP or DNS tuples.\n *\n * @example\n *\n * ```ts\n * import { multiaddr } from '@multiformats/multiaddr'\n * import { IP_OR_DOMAIN } from '@multiformats/multiaddr-matcher'\n *\n * IP_OR_DOMAIN.matches(multiaddr('/ip4/123.123.123.123/p2p/QmFoo')) // true\n * IP_OR_DOMAIN.matches(multiaddr('/dns/example.com/p2p/QmFoo')) // true\n * IP_OR_DOMAIN.matches(multiaddr('/p2p/QmFoo')) // false\n * ```\n */ const IP_OR_DOMAIN = fmt(_IP_OR_DOMAIN);\n/**\n * Matches ip4 addresses.\n *\n * Use {@link IP IP} instead to match any ip4/ip6 address.\n *\n * @example\n *\n * ```ts\n * import { multiaddr } from '@multiformats/multiaddr'\n * import { IP4 } from '@multiformats/multiaddr-matcher'\n *\n * const ma = multiaddr('/ip4/123.123.123.123')\n *\n * IP4.matches(ma) // true\n * ```\n */ const IP4 = fmt(_IP4);\n/**\n * Matches ip6 addresses.\n *\n * Use {@link IP IP} instead to match any ip4/ip6 address.\n *\n * @example\n *\n * ```ts\n * import { multiaddr } from '@multiformats/multiaddr'\n * import { IP6 } from '@multiformats/multiaddr-matcher'\n *\n * const ma = multiaddr('/ip6/fe80::1cc1:a3b8:322f:cf22')\n *\n * IP6.matches(ma) // true\n * ```\n */ const IP6 = fmt(_IP6);\n/**\n * Matches ip4 or ip6 addresses.\n *\n * @example\n *\n * ```ts\n * import { multiaddr } from '@multiformats/multiaddr'\n * import { IP } from '@multiformats/multiaddr-matcher'\n *\n * IP.matches(multiaddr('/ip4/123.123.123.123')) // true\n * IP.matches(multiaddr('/ip6/fe80::1cc1:a3b8:322f:cf22')) // true\n * ```\n */ const IP = fmt(_IP);\nconst _TCP = and(_IP_OR_DOMAIN, literal(\"tcp\"), number());\nconst _UDP = and(_IP_OR_DOMAIN, literal(\"udp\"), number());\nconst TCP_OR_UDP = or(_TCP, _UDP);\n/**\n * Matches TCP addresses.\n *\n * @example\n *\n * ```ts\n * import { multiaddr } from '@multiformats/multiaddr'\n * import { TCP } from '@multiformats/multiaddr-matcher'\n *\n * TCP.matches(multiaddr('/ip4/123.123.123.123/tcp/1234')) // true\n * ```\n */ const TCP = fmt(_TCP);\n/**\n * Matches UDP addresses.\n *\n * @example\n *\n * ```ts\n * import { multiaddr } from '@multiformats/multiaddr'\n * import { UDP } from '@multiformats/multiaddr-matcher'\n *\n * UDP.matches(multiaddr('/ip4/123.123.123.123/udp/1234')) // true\n * ```\n */ const UDP = fmt(_UDP);\nconst _QUIC = and(_UDP, literal(\"quic\"));\nconst _QUICV1 = and(_UDP, literal(\"quic-v1\"));\nconst QUIC_V0_OR_V1 = or(_QUIC, _QUICV1);\n/**\n * Matches QUIC addresses.\n *\n * @example\n *\n * ```ts\n * import { multiaddr } from '@multiformats/multiaddr'\n * import { QUIC } from '@multiformats/multiaddr-matcher'\n *\n * QUIC.matches(multiaddr('/ip4/123.123.123.123/udp/1234/quic')) // true\n * ```\n */ const QUIC = fmt(_QUIC);\n/**\n * Matches QUICv1 addresses.\n *\n * @example\n *\n * ```ts\n * import { multiaddr } from '@multiformats/multiaddr'\n * import { QUICV1 } from '@multiformats/multiaddr-matcher'\n *\n * QUICV1.matches(multiaddr('/ip4/123.123.123.123/udp/1234/quic-v1')) // true\n * ```\n */ const QUICV1 = fmt(_QUICV1);\nconst _WEB = or(_IP_OR_DOMAIN, _TCP, _UDP, _QUIC, _QUICV1);\nconst _WebSockets = or(and(_WEB, literal(\"ws\"), optional(peerId())));\n/**\n * Matches WebSocket addresses.\n *\n * @example\n *\n * ```ts\n * import { multiaddr } from '@multiformats/multiaddr'\n * import { WebSockets } from '@multiformats/multiaddr-matcher'\n *\n * WebSockets.matches(multiaddr('/ip4/123.123.123.123/tcp/1234/ws')) // true\n * ```\n */ const WebSockets = fmt(_WebSockets);\nconst _WebSocketsSecure = or(and(_WEB, literal(\"wss\"), optional(peerId())), and(_WEB, literal(\"tls\"), literal(\"ws\"), optional(peerId())));\n/**\n * Matches secure WebSocket addresses.\n *\n * @example\n *\n * ```ts\n * import { multiaddr } from '@multiformats/multiaddr'\n * import { WebSocketsSecure } from '@multiformats/multiaddr-matcher'\n *\n * WebSocketsSecure.matches(multiaddr('/ip4/123.123.123.123/tcp/1234/wss')) // true\n * ```\n */ const WebSocketsSecure = fmt(_WebSocketsSecure);\nconst _WebRTCDirect = and(TCP_OR_UDP, literal(\"webrtc-direct\"), certhash(), optional(certhash()), optional(peerId()));\n/**\n * Matches WebRTC-direct addresses.\n *\n * @example\n *\n * ```ts\n * import { multiaddr } from '@multiformats/multiaddr'\n * import { WebRTCDirect } from '@multiformats/multiaddr-matcher'\n *\n * WebRTCDirect.matches(multiaddr('/ip4/123.123.123.123/tcp/1234/p2p/QmFoo/webrtc-direct/certhash/u....')) // true\n * ```\n */ const WebRTCDirect = fmt(_WebRTCDirect);\nconst _WebTransport = and(_QUICV1, literal(\"webtransport\"), certhash(), certhash(), optional(peerId()));\n/**\n * Matches WebTransport addresses.\n *\n * @example\n *\n * ```ts\n * import { multiaddr } from '@multiformats/multiaddr'\n * import { WebRTCDirect } from '@multiformats/multiaddr-matcher'\n *\n * WebRTCDirect.matches(multiaddr('/ip4/123.123.123.123/udp/1234/quic-v1/webtransport/certhash/u..../certhash/u..../p2p/QmFoo')) // true\n * ```\n */ const WebTransport = fmt(_WebTransport);\nconst _P2P = or(_WebSockets, _WebSocketsSecure, and(_TCP, optional(peerId())), and(QUIC_V0_OR_V1, optional(peerId())), and(_IP_OR_DOMAIN, optional(peerId())), _WebRTCDirect, _WebTransport, peerId());\n/**\n * Matches peer addresses\n *\n * @example\n *\n * ```ts\n * import { multiaddr } from '@multiformats/multiaddr'\n * import { P2P } from '@multiformats/multiaddr-matcher'\n *\n * P2P.matches(multiaddr('/ip4/123.123.123.123/tcp/1234/p2p/QmFoo')) // true\n * ```\n */ const P2P = fmt(_P2P);\nconst _Circuit = and(_P2P, literal(\"p2p-circuit\"), peerId());\n/**\n * Matches circuit relay addresses\n *\n * @example\n *\n * ```ts\n * import { multiaddr } from '@multiformats/multiaddr'\n * import { Circuit } from '@multiformats/multiaddr-matcher'\n *\n * Circuit.matches(multiaddr('/ip4/123.123.123.123/tcp/1234/p2p/QmRelay/p2p-circuit/p2p/QmTarget')) // true\n * ```\n */ const Circuit = fmt(_Circuit);\nconst _WebRTC = or(and(_P2P, literal(\"p2p-circuit\"), literal(\"webrtc\"), peerId()), and(_P2P, literal(\"webrtc\"), optional(peerId())), literal(\"webrtc\"));\n/**\n * Matches WebRTC addresses\n *\n * @example\n *\n * ```ts\n * import { multiaddr } from '@multiformats/multiaddr'\n * import { WebRTC } from '@multiformats/multiaddr-matcher'\n *\n * WebRTC.matches(multiaddr('/ip4/123.123.123.123/tcp/1234/p2p/QmRelay/p2p-circuit/webrtc/p2p/QmTarget')) // true\n * ```\n */ const WebRTC = fmt(_WebRTC);\nconst _HTTP = or(and(_IP_OR_DOMAIN, literal(\"tcp\"), number(), literal(\"http\"), optional(peerId())), and(_IP_OR_DOMAIN, literal(\"http\"), optional(peerId())));\n/**\n * Matches HTTP addresses\n *\n * @example\n *\n * ```ts\n * import { multiaddr } from '@multiformats/multiaddr'\n * import { HTTP } from '@multiformats/multiaddr-matcher'\n *\n * HTTP.matches(multiaddr('/dns/example.org/http')) // true\n * ```\n */ const HTTP = fmt(_HTTP);\nconst _HTTPS = or(and(_IP_OR_DOMAIN, literal(\"tcp\"), or(and(literal(\"443\"), literal(\"http\")), and(number(), literal(\"https\"))), optional(peerId())), and(_IP_OR_DOMAIN, literal(\"tls\"), literal(\"http\"), optional(peerId())), and(_IP_OR_DOMAIN, literal(\"https\"), optional(peerId())));\n/**\n * Matches HTTPS addresses\n *\n * @example\n *\n * ```ts\n * import { multiaddr } from '@multiformats/multiaddr'\n * import { HTTP } from '@multiformats/multiaddr-matcher'\n *\n * HTTP.matches(multiaddr('/dns/example.org/tls/http')) // true\n * ```\n */ const HTTPS = fmt(_HTTPS); //# sourceMappingURL=index.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"(ssr)/./node_modules/@multiformats/multiaddr-matcher/dist/src/index.js","mappings":"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","sources":["webpack://flush-notes/./node_modules/@multiformats/multiaddr-matcher/dist/src/index.js?f144"],"sourcesContent":["/**\n * @packageDocumentation\n *\n * This module exports various matchers that can be used to infer the type of a\n * passed multiaddr.\n *\n * @example\n *\n * ```ts\n * import { multiaddr } from '@multiformats/multiaddr'\n * import { DNS } from '@multiformats/multiaddr-matcher'\n *\n * const ma = multiaddr('/dnsaddr/example.org')\n *\n * DNS.matches(ma) // true - this is a multiaddr with a DNS address at the start\n * ```\n *\n * @example\n *\n * The default matching behaviour ignores any subsequent tuples in the multiaddr.\n * If you want stricter matching you can use `.exactMatch`:\n *\n * ```ts\n * import { multiaddr } from '@multiformats/multiaddr'\n * import { DNS, Circuit } from '@multiformats/multiaddr-matcher'\n *\n * const ma = multiaddr('/dnsaddr/example.org/p2p/QmFoo/p2p-circuit/p2p/QmBar')\n *\n * DNS.exactMatch(ma) // false - this address has extra tuples after the DNS component\n * Circuit.matches(ma) // true\n * Circuit.exactMatch(ma) // true - the extra tuples are circuit relay related\n * ```\n */\nimport { isIPv4, isIPv6 } from '@chainsafe/is-ip';\nimport {} from '@multiformats/multiaddr';\nimport { base58btc } from 'multiformats/bases/base58';\nimport { base64url } from 'multiformats/bases/base64';\n/**\n * Split a multiaddr into path components\n */\nconst toParts = (ma) => {\n    return ma.toString().split('/').slice(1);\n};\nconst func = (fn) => {\n    return {\n        match: (vals) => {\n            if (vals.length < 1) {\n                return false;\n            }\n            if (fn(vals[0])) {\n                return vals.slice(1);\n            }\n            return false;\n        },\n        pattern: 'fn'\n    };\n};\nconst literal = (str) => {\n    return {\n        match: (vals) => func((val) => val === str).match(vals),\n        pattern: str\n    };\n};\nconst string = () => {\n    return {\n        match: (vals) => func((val) => typeof val === 'string').match(vals),\n        pattern: '{string}'\n    };\n};\nconst number = () => {\n    return {\n        match: (vals) => func((val) => !isNaN(parseInt(val))).match(vals),\n        pattern: '{number}'\n    };\n};\nconst peerId = () => {\n    return {\n        match: (vals) => {\n            if (vals.length < 2) {\n                return false;\n            }\n            if (vals[0] !== 'p2p' && vals[0] !== 'ipfs') {\n                return false;\n            }\n            // Q is RSA, 1 is Ed25519 or Secp256k1\n            if (vals[1].startsWith('Q') || vals[1].startsWith('1')) {\n                try {\n                    base58btc.decode(`z${vals[1]}`);\n                }\n                catch (err) {\n                    return false;\n                }\n            }\n            else {\n                return false;\n            }\n            return vals.slice(2);\n        },\n        pattern: '/p2p/{peerid}'\n    };\n};\nconst certhash = () => {\n    return {\n        match: (vals) => {\n            if (vals.length < 2) {\n                return false;\n            }\n            if (vals[0] !== 'certhash') {\n                return false;\n            }\n            try {\n                base64url.decode(vals[1]);\n            }\n            catch {\n                return false;\n            }\n            return vals.slice(2);\n        },\n        pattern: '/certhash/{certhash}'\n    };\n};\nconst optional = (matcher) => {\n    return {\n        match: (vals) => {\n            const result = matcher.match(vals);\n            if (result === false) {\n                return vals;\n            }\n            return result;\n        },\n        pattern: `optional(${matcher.pattern})`\n    };\n};\nconst or = (...matchers) => {\n    return {\n        match: (vals) => {\n            let matches;\n            for (const matcher of matchers) {\n                const result = matcher.match(vals);\n                // no match\n                if (result === false) {\n                    continue;\n                }\n                // choose greediest matcher\n                if (matches == null || result.length < matches.length) {\n                    matches = result;\n                }\n            }\n            if (matches == null) {\n                return false;\n            }\n            return matches;\n        },\n        pattern: `or(${matchers.map(m => m.pattern).join(', ')})`\n    };\n};\nconst and = (...matchers) => {\n    return {\n        match: (vals) => {\n            for (const matcher of matchers) {\n                // pass what's left of the array\n                const result = matcher.match(vals);\n                // no match\n                if (result === false) {\n                    return false;\n                }\n                vals = result;\n            }\n            return vals;\n        },\n        pattern: `and(${matchers.map(m => m.pattern).join(', ')})`\n    };\n};\nfunction fmt(...matchers) {\n    function match(ma) {\n        let parts = toParts(ma);\n        for (const matcher of matchers) {\n            const result = matcher.match(parts);\n            if (result === false) {\n                return false;\n            }\n            parts = result;\n        }\n        return parts;\n    }\n    function matches(ma) {\n        const result = match(ma);\n        return result !== false;\n    }\n    function exactMatch(ma) {\n        const result = match(ma);\n        if (result === false) {\n            return false;\n        }\n        return result.length === 0;\n    }\n    return {\n        matches,\n        exactMatch\n    };\n}\n/**\n * DNS matchers\n */\nconst _DNS4 = and(literal('dns4'), string());\nconst _DNS6 = and(literal('dns6'), string());\nconst _DNSADDR = and(literal('dnsaddr'), string());\nconst _DNS = and(literal('dns'), string());\n/**\n * Matches dns4 addresses.\n *\n * Use {@link DNS DNS} instead to match any type of DNS address.\n *\n * @example\n *\n * ```ts\n * import { multiaddr } from '@multiformats/multiaddr'\n * import { DNS4 } from '@multiformats/multiaddr-matcher'\n *\n * DNS4.matches(multiaddr('/dns4/example.org')) // true\n * ```\n */\nexport const DNS4 = fmt(_DNS4);\n/**\n * Matches dns6 addresses.\n *\n * Use {@link DNS DNS} instead to match any type of DNS address.\n *\n * @example\n *\n * ```ts\n * import { multiaddr } from '@multiformats/multiaddr'\n * import { DNS6 } from '@multiformats/multiaddr-matcher'\n *\n * DNS6.matches(multiaddr('/dns6/example.org')) // true\n * ```\n */\nexport const DNS6 = fmt(_DNS6);\n/**\n * Matches dnsaddr addresses.\n *\n * Use {@link DNS DNS} instead to match any type of DNS address.\n *\n * @example\n *\n * ```ts\n * import { multiaddr } from '@multiformats/multiaddr'\n * import { DNSADDR } from '@multiformats/multiaddr-matcher'\n *\n * DNSADDR.matches(multiaddr('/dnsaddr/example.org')) // true\n * ```\n */\nexport const DNSADDR = fmt(_DNSADDR);\n/**\n * Matches any dns address.\n *\n * @example\n *\n * ```ts\n * import { multiaddr } from '@multiformats/multiaddr'\n * import { DNS } from '@multiformats/multiaddr-matcher'\n *\n * DNS.matches(multiaddr('/dnsaddr/example.org')) // true\n * DNS.matches(multiaddr('/dns4/example.org')) // true\n * DNS.matches(multiaddr('/dns6/example.org')) // true\n * ```\n */\nexport const DNS = fmt(or(_DNS, _DNSADDR, _DNS4, _DNS6));\nconst _IP4 = and(literal('ip4'), func(isIPv4));\nconst _IP6 = and(literal('ip6'), func(isIPv6));\nconst _IP = or(_IP4, _IP6);\nconst _IP_OR_DOMAIN = or(_IP, _DNS, _DNS4, _DNS6, _DNSADDR);\n/**\n * A matcher for addresses that start with IP or DNS tuples.\n *\n * @example\n *\n * ```ts\n * import { multiaddr } from '@multiformats/multiaddr'\n * import { IP_OR_DOMAIN } from '@multiformats/multiaddr-matcher'\n *\n * IP_OR_DOMAIN.matches(multiaddr('/ip4/123.123.123.123/p2p/QmFoo')) // true\n * IP_OR_DOMAIN.matches(multiaddr('/dns/example.com/p2p/QmFoo')) // true\n * IP_OR_DOMAIN.matches(multiaddr('/p2p/QmFoo')) // false\n * ```\n */\nexport const IP_OR_DOMAIN = fmt(_IP_OR_DOMAIN);\n/**\n * Matches ip4 addresses.\n *\n * Use {@link IP IP} instead to match any ip4/ip6 address.\n *\n * @example\n *\n * ```ts\n * import { multiaddr } from '@multiformats/multiaddr'\n * import { IP4 } from '@multiformats/multiaddr-matcher'\n *\n * const ma = multiaddr('/ip4/123.123.123.123')\n *\n * IP4.matches(ma) // true\n * ```\n */\nexport const IP4 = fmt(_IP4);\n/**\n * Matches ip6 addresses.\n *\n * Use {@link IP IP} instead to match any ip4/ip6 address.\n *\n * @example\n *\n * ```ts\n * import { multiaddr } from '@multiformats/multiaddr'\n * import { IP6 } from '@multiformats/multiaddr-matcher'\n *\n * const ma = multiaddr('/ip6/fe80::1cc1:a3b8:322f:cf22')\n *\n * IP6.matches(ma) // true\n * ```\n */\nexport const IP6 = fmt(_IP6);\n/**\n * Matches ip4 or ip6 addresses.\n *\n * @example\n *\n * ```ts\n * import { multiaddr } from '@multiformats/multiaddr'\n * import { IP } from '@multiformats/multiaddr-matcher'\n *\n * IP.matches(multiaddr('/ip4/123.123.123.123')) // true\n * IP.matches(multiaddr('/ip6/fe80::1cc1:a3b8:322f:cf22')) // true\n * ```\n */\nexport const IP = fmt(_IP);\nconst _TCP = and(_IP_OR_DOMAIN, literal('tcp'), number());\nconst _UDP = and(_IP_OR_DOMAIN, literal('udp'), number());\nconst TCP_OR_UDP = or(_TCP, _UDP);\n/**\n * Matches TCP addresses.\n *\n * @example\n *\n * ```ts\n * import { multiaddr } from '@multiformats/multiaddr'\n * import { TCP } from '@multiformats/multiaddr-matcher'\n *\n * TCP.matches(multiaddr('/ip4/123.123.123.123/tcp/1234')) // true\n * ```\n */\nexport const TCP = fmt(_TCP);\n/**\n * Matches UDP addresses.\n *\n * @example\n *\n * ```ts\n * import { multiaddr } from '@multiformats/multiaddr'\n * import { UDP } from '@multiformats/multiaddr-matcher'\n *\n * UDP.matches(multiaddr('/ip4/123.123.123.123/udp/1234')) // true\n * ```\n */\nexport const UDP = fmt(_UDP);\nconst _QUIC = and(_UDP, literal('quic'));\nconst _QUICV1 = and(_UDP, literal('quic-v1'));\nconst QUIC_V0_OR_V1 = or(_QUIC, _QUICV1);\n/**\n * Matches QUIC addresses.\n *\n * @example\n *\n * ```ts\n * import { multiaddr } from '@multiformats/multiaddr'\n * import { QUIC } from '@multiformats/multiaddr-matcher'\n *\n * QUIC.matches(multiaddr('/ip4/123.123.123.123/udp/1234/quic')) // true\n * ```\n */\nexport const QUIC = fmt(_QUIC);\n/**\n * Matches QUICv1 addresses.\n *\n * @example\n *\n * ```ts\n * import { multiaddr } from '@multiformats/multiaddr'\n * import { QUICV1 } from '@multiformats/multiaddr-matcher'\n *\n * QUICV1.matches(multiaddr('/ip4/123.123.123.123/udp/1234/quic-v1')) // true\n * ```\n */\nexport const QUICV1 = fmt(_QUICV1);\nconst _WEB = or(_IP_OR_DOMAIN, _TCP, _UDP, _QUIC, _QUICV1);\nconst _WebSockets = or(and(_WEB, literal('ws'), optional(peerId())));\n/**\n * Matches WebSocket addresses.\n *\n * @example\n *\n * ```ts\n * import { multiaddr } from '@multiformats/multiaddr'\n * import { WebSockets } from '@multiformats/multiaddr-matcher'\n *\n * WebSockets.matches(multiaddr('/ip4/123.123.123.123/tcp/1234/ws')) // true\n * ```\n */\nexport const WebSockets = fmt(_WebSockets);\nconst _WebSocketsSecure = or(and(_WEB, literal('wss'), optional(peerId())), and(_WEB, literal('tls'), literal('ws'), optional(peerId())));\n/**\n * Matches secure WebSocket addresses.\n *\n * @example\n *\n * ```ts\n * import { multiaddr } from '@multiformats/multiaddr'\n * import { WebSocketsSecure } from '@multiformats/multiaddr-matcher'\n *\n * WebSocketsSecure.matches(multiaddr('/ip4/123.123.123.123/tcp/1234/wss')) // true\n * ```\n */\nexport const WebSocketsSecure = fmt(_WebSocketsSecure);\nconst _WebRTCDirect = and(TCP_OR_UDP, literal('webrtc-direct'), certhash(), optional(certhash()), optional(peerId()));\n/**\n * Matches WebRTC-direct addresses.\n *\n * @example\n *\n * ```ts\n * import { multiaddr } from '@multiformats/multiaddr'\n * import { WebRTCDirect } from '@multiformats/multiaddr-matcher'\n *\n * WebRTCDirect.matches(multiaddr('/ip4/123.123.123.123/tcp/1234/p2p/QmFoo/webrtc-direct/certhash/u....')) // true\n * ```\n */\nexport const WebRTCDirect = fmt(_WebRTCDirect);\nconst _WebTransport = and(_QUICV1, literal('webtransport'), certhash(), certhash(), optional(peerId()));\n/**\n * Matches WebTransport addresses.\n *\n * @example\n *\n * ```ts\n * import { multiaddr } from '@multiformats/multiaddr'\n * import { WebRTCDirect } from '@multiformats/multiaddr-matcher'\n *\n * WebRTCDirect.matches(multiaddr('/ip4/123.123.123.123/udp/1234/quic-v1/webtransport/certhash/u..../certhash/u..../p2p/QmFoo')) // true\n * ```\n */\nexport const WebTransport = fmt(_WebTransport);\nconst _P2P = or(_WebSockets, _WebSocketsSecure, and(_TCP, optional(peerId())), and(QUIC_V0_OR_V1, optional(peerId())), and(_IP_OR_DOMAIN, optional(peerId())), _WebRTCDirect, _WebTransport, peerId());\n/**\n * Matches peer addresses\n *\n * @example\n *\n * ```ts\n * import { multiaddr } from '@multiformats/multiaddr'\n * import { P2P } from '@multiformats/multiaddr-matcher'\n *\n * P2P.matches(multiaddr('/ip4/123.123.123.123/tcp/1234/p2p/QmFoo')) // true\n * ```\n */\nexport const P2P = fmt(_P2P);\nconst _Circuit = and(_P2P, literal('p2p-circuit'), peerId());\n/**\n * Matches circuit relay addresses\n *\n * @example\n *\n * ```ts\n * import { multiaddr } from '@multiformats/multiaddr'\n * import { Circuit } from '@multiformats/multiaddr-matcher'\n *\n * Circuit.matches(multiaddr('/ip4/123.123.123.123/tcp/1234/p2p/QmRelay/p2p-circuit/p2p/QmTarget')) // true\n * ```\n */\nexport const Circuit = fmt(_Circuit);\nconst _WebRTC = or(and(_P2P, literal('p2p-circuit'), literal('webrtc'), peerId()), and(_P2P, literal('webrtc'), optional(peerId())), literal('webrtc'));\n/**\n * Matches WebRTC addresses\n *\n * @example\n *\n * ```ts\n * import { multiaddr } from '@multiformats/multiaddr'\n * import { WebRTC } from '@multiformats/multiaddr-matcher'\n *\n * WebRTC.matches(multiaddr('/ip4/123.123.123.123/tcp/1234/p2p/QmRelay/p2p-circuit/webrtc/p2p/QmTarget')) // true\n * ```\n */\nexport const WebRTC = fmt(_WebRTC);\nconst _HTTP = or(and(_IP_OR_DOMAIN, literal('tcp'), number(), literal('http'), optional(peerId())), and(_IP_OR_DOMAIN, literal('http'), optional(peerId())));\n/**\n * Matches HTTP addresses\n *\n * @example\n *\n * ```ts\n * import { multiaddr } from '@multiformats/multiaddr'\n * import { HTTP } from '@multiformats/multiaddr-matcher'\n *\n * HTTP.matches(multiaddr('/dns/example.org/http')) // true\n * ```\n */\nexport const HTTP = fmt(_HTTP);\nconst _HTTPS = or(and(_IP_OR_DOMAIN, literal('tcp'), or(and(literal('443'), literal('http')), and(number(), literal('https'))), optional(peerId())), and(_IP_OR_DOMAIN, literal('tls'), literal('http'), optional(peerId())), and(_IP_OR_DOMAIN, literal('https'), optional(peerId())));\n/**\n * Matches HTTPS addresses\n *\n * @example\n *\n * ```ts\n * import { multiaddr } from '@multiformats/multiaddr'\n * import { HTTP } from '@multiformats/multiaddr-matcher'\n *\n * HTTP.matches(multiaddr('/dns/example.org/tls/http')) // true\n * ```\n */\nexport const HTTPS = fmt(_HTTPS);\n//# sourceMappingURL=index.js.map"],"names":["isIPv4","isIPv6","base58btc","base64url","toParts","ma","toString","split","slice","func","fn","match","vals","length","pattern","literal","str","val","string","number","isNaN","parseInt","peerId","startsWith","decode","err","certhash","optional","matcher","result","or","matchers","matches","map","m","join","and","fmt","parts","exactMatch","_DNS4","_DNS6","_DNSADDR","_DNS","DNS4","DNS6","DNSADDR","DNS","_IP4","_IP6","_IP","_IP_OR_DOMAIN","IP_OR_DOMAIN","IP4","IP6","IP","_TCP","_UDP","TCP_OR_UDP","TCP","UDP","_QUIC","_QUICV1","QUIC_V0_OR_V1","QUIC","QUICV1","_WEB","_WebSockets","WebSockets","_WebSocketsSecure","WebSocketsSecure","_WebRTCDirect","WebRTCDirect","_WebTransport","WebTransport","_P2P","P2P","_Circuit","Circuit","_WebRTC","WebRTC","_HTTP","HTTP","_HTTPS","HTTPS"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/@multiformats/multiaddr-matcher/dist/src/index.js\n");
/***/ }),
/***/ "(ssr)/./node_modules/@multiformats/multiaddr-to-uri/dist/src/index.js":
/*!***********************************************************************!*\
!*** ./node_modules/@multiformats/multiaddr-to-uri/dist/src/index.js ***!
\***********************************************************************/
/***/ ((__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 */ multiaddrToUri: () => (/* binding */ multiaddrToUri)\n/* harmony export */ });\n/* harmony import */ var _multiformats_multiaddr__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @multiformats/multiaddr */ \"(ssr)/./node_modules/@multiformats/multiaddr/dist/src/index.js\");\n/**\n * @packageDocumentation\n *\n * This module allows easy conversion of Multiaddrs to string URIs.\n *\n * @example Converting multiaddrs to string URIs\n *\n * ```js\n * import { multiaddrToUri } from '@multiformats/multiaddr-to-uri'\n *\n * console.log(multiaddrToUri('/dnsaddr/protocol.ai/https'))\n * // -> https://protocol.ai\n *\n * console.log(multiaddrToUri('/ip4/127.0.0.1/tcp/8080'))\n * // -> http://127.0.0.1:8080\n *\n * console.log(multiaddrToUri('/ip4/127.0.0.1/tcp/8080', { assumeHttp: false }))\n * // -> tcp://127.0.0.1:8080\n * ```\n *\n * Note:\n *\n * - When `/tcp` is the last (terminating) protocol HTTP is assumed by default (implicit `assumeHttp: true`)\n * - this means produced URIs will start with `http://` instead of `tcp://`\n * - passing `{ assumeHttp: false }` disables this behavior\n * - Might be lossy - e.g. a DNSv6 multiaddr\n * - Can throw if the passed multiaddr:\n * - is not a valid multiaddr\n * - is not supported as a URI e.g. circuit\n */ \nconst ASSUME_HTTP_CODES = [\n (0,_multiformats_multiaddr__WEBPACK_IMPORTED_MODULE_0__.protocols)(\"tcp\").code,\n (0,_multiformats_multiaddr__WEBPACK_IMPORTED_MODULE_0__.protocols)(\"dns\").code,\n (0,_multiformats_multiaddr__WEBPACK_IMPORTED_MODULE_0__.protocols)(\"dnsaddr\").code,\n (0,_multiformats_multiaddr__WEBPACK_IMPORTED_MODULE_0__.protocols)(\"dns4\").code,\n (0,_multiformats_multiaddr__WEBPACK_IMPORTED_MODULE_0__.protocols)(\"dns6\").code\n];\nfunction extractSNI(ma) {\n let sniProtoCode;\n try {\n sniProtoCode = (0,_multiformats_multiaddr__WEBPACK_IMPORTED_MODULE_0__.protocols)(\"sni\").code;\n } catch (e) {\n // No SNI protocol in multiaddr\n return null;\n }\n for (const [proto, value] of ma){\n if (proto === sniProtoCode && value !== undefined) {\n return value;\n }\n }\n return null;\n}\nfunction hasTLS(ma) {\n return ma.some(([proto, _])=>proto === (0,_multiformats_multiaddr__WEBPACK_IMPORTED_MODULE_0__.protocols)(\"tls\").code);\n}\nfunction interpretNext(headProtoCode, headProtoVal, restMa) {\n const interpreter = interpreters[(0,_multiformats_multiaddr__WEBPACK_IMPORTED_MODULE_0__.protocols)(headProtoCode).name];\n if (interpreter === undefined) {\n throw new Error(`Can't interpret protocol ${(0,_multiformats_multiaddr__WEBPACK_IMPORTED_MODULE_0__.protocols)(headProtoCode).name}`);\n }\n const restVal = interpreter(headProtoVal, restMa);\n if (headProtoCode === (0,_multiformats_multiaddr__WEBPACK_IMPORTED_MODULE_0__.protocols)(\"ip6\").code) {\n return `[${restVal}]`;\n }\n return restVal;\n}\nconst interpreters = {\n ip4: (value, restMa)=>value,\n ip6: (value, restMa)=>{\n if (restMa.length === 0) {\n return value;\n }\n return `[${value}]`;\n },\n tcp: (value, restMa)=>{\n const tailProto = restMa.pop();\n if (tailProto === undefined) {\n throw new Error(\"Unexpected end of multiaddr\");\n }\n return `tcp://${interpretNext(tailProto[0], tailProto[1] ?? \"\", restMa)}:${value}`;\n },\n udp: (value, restMa)=>{\n const tailProto = restMa.pop();\n if (tailProto === undefined) {\n throw new Error(\"Unexpected end of multiaddr\");\n }\n return `udp://${interpretNext(tailProto[0], tailProto[1] ?? \"\", restMa)}:${value}`;\n },\n dnsaddr: (value, restMa)=>value,\n dns4: (value, restMa)=>value,\n dns6: (value, restMa)=>value,\n dns: (value, restMa)=>value,\n ipfs: (value, restMa)=>{\n const tailProto = restMa.pop();\n if (tailProto === undefined) {\n throw new Error(\"Unexpected end of multiaddr\");\n }\n return `${interpretNext(tailProto[0], tailProto[1] ?? \"\", restMa)}/ipfs/${value}`;\n },\n p2p: (value, restMa)=>{\n const tailProto = restMa.pop();\n if (tailProto === undefined) {\n throw new Error(\"Unexpected end of multiaddr\");\n }\n return `${interpretNext(tailProto[0], tailProto[1] ?? \"\", restMa)}/p2p/${value}`;\n },\n http: (value, restMa)=>{\n const maHasTLS = hasTLS(restMa);\n const sni = extractSNI(restMa);\n if (maHasTLS && sni !== null) {\n return `https://${sni}`;\n }\n const protocol = maHasTLS ? \"https://\" : \"http://\";\n const tailProto = restMa.pop();\n if (tailProto === undefined) {\n throw new Error(\"Unexpected end of multiaddr\");\n }\n let baseVal = interpretNext(tailProto[0], tailProto[1] ?? \"\", restMa);\n // We are reinterpreting the base as http, so we need to remove the tcp:// if it's there\n baseVal = baseVal.replace(\"tcp://\", \"\");\n return `${protocol}${baseVal}`;\n },\n tls: (value, restMa)=>{\n // Noop, the parent context knows that it's tls. We don't need to do\n // anything here\n const tailProto = restMa.pop();\n if (tailProto === undefined) {\n throw new Error(\"Unexpected end of multiaddr\");\n }\n return interpretNext(tailProto[0], tailProto[1] ?? \"\", restMa);\n },\n sni: (value, restMa)=>{\n // Noop, the parent context uses the sni information, we don't need to do\n // anything here\n const tailProto = restMa.pop();\n if (tailProto === undefined) {\n throw new Error(\"Unexpected end of multiaddr\");\n }\n return interpretNext(tailProto[0], tailProto[1] ?? \"\", restMa);\n },\n https: (value, restMa)=>{\n const tailProto = restMa.pop();\n if (tailProto === undefined) {\n throw new Error(\"Unexpected end of multiaddr\");\n }\n let baseVal = interpretNext(tailProto[0], tailProto[1] ?? \"\", restMa);\n // We are reinterpreting the base as http, so we need to remove the tcp:// if it's there\n baseVal = baseVal.replace(\"tcp://\", \"\");\n return `https://${baseVal}`;\n },\n ws: (value, restMa)=>{\n const maHasTLS = hasTLS(restMa);\n const sni = extractSNI(restMa);\n if (maHasTLS && sni !== null) {\n return `wss://${sni}`;\n }\n const protocol = maHasTLS ? \"wss://\" : \"ws://\";\n const tailProto = restMa.pop();\n if (tailProto === undefined) {\n throw new Error(\"Unexpected end of multiaddr\");\n }\n let baseVal = interpretNext(tailProto[0], tailProto[1] ?? \"\", restMa);\n // We are reinterpreting the base, so we need to remove the tcp:// if it's there\n baseVal = baseVal.replace(\"tcp://\", \"\");\n return `${protocol}${baseVal}`;\n },\n wss: (value, restMa)=>{\n const tailProto = restMa.pop();\n if (tailProto === undefined) {\n throw new Error(\"Unexpected end of multiaddr\");\n }\n let baseVal = interpretNext(tailProto[0], tailProto[1] ?? \"\", restMa);\n // We are reinterpreting the base as http, so we need to remove the tcp:// if it's there\n baseVal = baseVal.replace(\"tcp://\", \"\");\n return `wss://${baseVal}`;\n },\n \"p2p-websocket-star\": (value, restMa)=>{\n const tailProto = restMa.pop();\n if (tailProto === undefined) {\n throw new Error(\"Unexpected end of multiaddr\");\n }\n return `${interpretNext(tailProto[0], tailProto[1] ?? \"\", restMa)}/p2p-websocket-star`;\n },\n \"p2p-webrtc-star\": (value, restMa)=>{\n const tailProto = restMa.pop();\n if (tailProto === undefined) {\n throw new Error(\"Unexpected end of multiaddr\");\n }\n return `${interpretNext(tailProto[0], tailProto[1] ?? \"\", restMa)}/p2p-webrtc-star`;\n },\n \"p2p-webrtc-direct\": (value, restMa)=>{\n const tailProto = restMa.pop();\n if (tailProto === undefined) {\n throw new Error(\"Unexpected end of multiaddr\");\n }\n return `${interpretNext(tailProto[0], tailProto[1] ?? \"\", restMa)}/p2p-webrtc-direct`;\n }\n};\nfunction multiaddrToUri(input, opts) {\n const ma = (0,_multiformats_multiaddr__WEBPACK_IMPORTED_MODULE_0__.multiaddr)(input);\n const parts = ma.stringTuples();\n const head = parts.pop();\n if (head === undefined) {\n throw new Error(\"Unexpected end of multiaddr\");\n }\n const protocol = (0,_multiformats_multiaddr__WEBPACK_IMPORTED_MODULE_0__.protocols)(head[0]);\n const interpreter = interpreters[protocol.name];\n if (interpreter == null) {\n throw new Error(`No interpreter found for ${protocol.name}`);\n }\n let uri = interpreter(head[1] ?? \"\", parts);\n if (opts?.assumeHttp !== false && ASSUME_HTTP_CODES.includes(head[0])) {\n // strip any declared protocol\n uri = uri.replace(/^.*:\\/\\//, \"\");\n if (head[1] === \"443\") {\n uri = `https://${uri}`;\n } else {\n uri = `http://${uri}`;\n }\n }\n if (uri.startsWith(\"http://\") || uri.startsWith(\"https://\")) {\n // this will strip default ports while keeping paths intact\n uri = new URL(uri).toString();\n // strip trailing slash, e.g. http://127.0.0.1/ -> http://127.0.0.1\n if (uri.endsWith(\"/\")) {\n uri = uri.substring(0, uri.length - 1);\n }\n }\n return uri;\n} //# sourceMappingURL=index.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"(ssr)/./node_modules/@multiformats/multiaddr-to-uri/dist/src/index.js","mappings":"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","sources":["webpack://flush-notes/./node_modules/@multiformats/multiaddr-to-uri/dist/src/index.js?7792"],"sourcesContent":["/**\n * @packageDocumentation\n *\n * This module allows easy conversion of Multiaddrs to string URIs.\n *\n * @example Converting multiaddrs to string URIs\n *\n * ```js\n * import { multiaddrToUri } from '@multiformats/multiaddr-to-uri'\n *\n * console.log(multiaddrToUri('/dnsaddr/protocol.ai/https'))\n * // -> https://protocol.ai\n *\n * console.log(multiaddrToUri('/ip4/127.0.0.1/tcp/8080'))\n * // -> http://127.0.0.1:8080\n *\n * console.log(multiaddrToUri('/ip4/127.0.0.1/tcp/8080', { assumeHttp: false }))\n * // -> tcp://127.0.0.1:8080\n * ```\n *\n * Note:\n *\n * - When `/tcp` is the last (terminating) protocol HTTP is assumed by default (implicit `assumeHttp: true`)\n *   - this means produced URIs will start with `http://` instead of `tcp://`\n *   - passing `{ assumeHttp: false }` disables this behavior\n * - Might be lossy - e.g. a DNSv6 multiaddr\n * - Can throw if the passed multiaddr:\n *   - is not a valid multiaddr\n *   - is not supported as a URI e.g. circuit\n */\nimport { multiaddr, protocols } from '@multiformats/multiaddr';\nconst ASSUME_HTTP_CODES = [\n    protocols('tcp').code,\n    protocols('dns').code,\n    protocols('dnsaddr').code,\n    protocols('dns4').code,\n    protocols('dns6').code\n];\nfunction extractSNI(ma) {\n    let sniProtoCode;\n    try {\n        sniProtoCode = protocols('sni').code;\n    }\n    catch (e) {\n        // No SNI protocol in multiaddr\n        return null;\n    }\n    for (const [proto, value] of ma) {\n        if (proto === sniProtoCode && value !== undefined) {\n            return value;\n        }\n    }\n    return null;\n}\nfunction hasTLS(ma) {\n    return ma.some(([proto, _]) => proto === protocols('tls').code);\n}\nfunction interpretNext(headProtoCode, headProtoVal, restMa) {\n    const interpreter = interpreters[protocols(headProtoCode).name];\n    if (interpreter === undefined) {\n        throw new Error(`Can't interpret protocol ${protocols(headProtoCode).name}`);\n    }\n    const restVal = interpreter(headProtoVal, restMa);\n    if (headProtoCode === protocols('ip6').code) {\n        return `[${restVal}]`;\n    }\n    return restVal;\n}\nconst interpreters = {\n    ip4: (value, restMa) => value,\n    ip6: (value, restMa) => {\n        if (restMa.length === 0) {\n            return value;\n        }\n        return `[${value}]`;\n    },\n    tcp: (value, restMa) => {\n        const tailProto = restMa.pop();\n        if (tailProto === undefined) {\n            throw new Error('Unexpected end of multiaddr');\n        }\n        return `tcp://${interpretNext(tailProto[0], tailProto[1] ?? '', restMa)}:${value}`;\n    },\n    udp: (value, restMa) => {\n        const tailProto = restMa.pop();\n        if (tailProto === undefined) {\n            throw new Error('Unexpected end of multiaddr');\n        }\n        return `udp://${interpretNext(tailProto[0], tailProto[1] ?? '', restMa)}:${value}`;\n    },\n    dnsaddr: (value, restMa) => value,\n    dns4: (value, restMa) => value,\n    dns6: (value, restMa) => value,\n    dns: (value, restMa) => value,\n    ipfs: (value, restMa) => {\n        const tailProto = restMa.pop();\n        if (tailProto === undefined) {\n            throw new Error('Unexpected end of multiaddr');\n        }\n        return `${interpretNext(tailProto[0], tailProto[1] ?? '', restMa)}/ipfs/${value}`;\n    },\n    p2p: (value, restMa) => {\n        const tailProto = restMa.pop();\n        if (tailProto === undefined) {\n            throw new Error('Unexpected end of multiaddr');\n        }\n        return `${interpretNext(tailProto[0], tailProto[1] ?? '', restMa)}/p2p/${value}`;\n    },\n    http: (value, restMa) => {\n        const maHasTLS = hasTLS(restMa);\n        const sni = extractSNI(restMa);\n        if (maHasTLS && sni !== null) {\n            return `https://${sni}`;\n        }\n        const protocol = maHasTLS ? 'https://' : 'http://';\n        const tailProto = restMa.pop();\n        if (tailProto === undefined) {\n            throw new Error('Unexpected end of multiaddr');\n        }\n        let baseVal = interpretNext(tailProto[0], tailProto[1] ?? '', restMa);\n        // We are reinterpreting the base as http, so we need to remove the tcp:// if it's there\n        baseVal = baseVal.replace('tcp://', '');\n        return `${protocol}${baseVal}`;\n    },\n    tls: (value, restMa) => {\n        // Noop, the parent context knows that it's tls. We don't need to do\n        // anything here\n        const tailProto = restMa.pop();\n        if (tailProto === undefined) {\n            throw new Error('Unexpected end of multiaddr');\n        }\n        return interpretNext(tailProto[0], tailProto[1] ?? '', restMa);\n    },\n    sni: (value, restMa) => {\n        // Noop, the parent context uses the sni information, we don't need to do\n        // anything here\n        const tailProto = restMa.pop();\n        if (tailProto === undefined) {\n            throw new Error('Unexpected end of multiaddr');\n        }\n        return interpretNext(tailProto[0], tailProto[1] ?? '', restMa);\n    },\n    https: (value, restMa) => {\n        const tailProto = restMa.pop();\n        if (tailProto === undefined) {\n            throw new Error('Unexpected end of multiaddr');\n        }\n        let baseVal = interpretNext(tailProto[0], tailProto[1] ?? '', restMa);\n        // We are reinterpreting the base as http, so we need to remove the tcp:// if it's there\n        baseVal = baseVal.replace('tcp://', '');\n        return `https://${baseVal}`;\n    },\n    ws: (value, restMa) => {\n        const maHasTLS = hasTLS(restMa);\n        const sni = extractSNI(restMa);\n        if (maHasTLS && sni !== null) {\n            return `wss://${sni}`;\n        }\n        const protocol = maHasTLS ? 'wss://' : 'ws://';\n        const tailProto = restMa.pop();\n        if (tailProto === undefined) {\n            throw new Error('Unexpected end of multiaddr');\n        }\n        let baseVal = interpretNext(tailProto[0], tailProto[1] ?? '', restMa);\n        // We are reinterpreting the base, so we need to remove the tcp:// if it's there\n        baseVal = baseVal.replace('tcp://', '');\n        return `${protocol}${baseVal}`;\n    },\n    wss: (value, restMa) => {\n        const tailProto = restMa.pop();\n        if (tailProto === undefined) {\n            throw new Error('Unexpected end of multiaddr');\n        }\n        let baseVal = interpretNext(tailProto[0], tailProto[1] ?? '', restMa);\n        // We are reinterpreting the base as http, so we need to remove the tcp:// if it's there\n        baseVal = baseVal.replace('tcp://', '');\n        return `wss://${baseVal}`;\n    },\n    'p2p-websocket-star': (value, restMa) => {\n        const tailProto = restMa.pop();\n        if (tailProto === undefined) {\n            throw new Error('Unexpected end of multiaddr');\n        }\n        return `${interpretNext(tailProto[0], tailProto[1] ?? '', restMa)}/p2p-websocket-star`;\n    },\n    'p2p-webrtc-star': (value, restMa) => {\n        const tailProto = restMa.pop();\n        if (tailProto === undefined) {\n            throw new Error('Unexpected end of multiaddr');\n        }\n        return `${interpretNext(tailProto[0], tailProto[1] ?? '', restMa)}/p2p-webrtc-star`;\n    },\n    'p2p-webrtc-direct': (value, restMa) => {\n        const tailProto = restMa.pop();\n        if (tailProto === undefined) {\n            throw new Error('Unexpected end of multiaddr');\n        }\n        return `${interpretNext(tailProto[0], tailProto[1] ?? '', restMa)}/p2p-webrtc-direct`;\n    }\n};\nexport function multiaddrToUri(input, opts) {\n    const ma = multiaddr(input);\n    const parts = ma.stringTuples();\n    const head = parts.pop();\n    if (head === undefined) {\n        throw new Error('Unexpected end of multiaddr');\n    }\n    const protocol = protocols(head[0]);\n    const interpreter = interpreters[protocol.name];\n    if (interpreter == null) {\n        throw new Error(`No interpreter found for ${protocol.name}`);\n    }\n    let uri = interpreter(head[1] ?? '', parts);\n    if (opts?.assumeHttp !== false && ASSUME_HTTP_CODES.includes(head[0])) {\n        // strip any declared protocol\n        uri = uri.replace(/^.*:\\/\\//, '');\n        if (head[1] === '443') {\n            uri = `https://${uri}`;\n        }\n        else {\n            uri = `http://${uri}`;\n        }\n    }\n    if (uri.startsWith('http://') || uri.startsWith('https://')) {\n        // this will strip default ports while keeping paths intact\n        uri = new URL(uri).toString();\n        // strip trailing slash, e.g. http://127.0.0.1/ -> http://127.0.0.1\n        if (uri.endsWith('/')) {\n            uri = uri.substring(0, uri.length - 1);\n        }\n    }\n    return uri;\n}\n//# sourceMappingURL=index.js.map"],"names":["multiaddr","protocols","ASSUME_HTTP_CODES","code","extractSNI","ma","sniProtoCode","e","proto","value","undefined","hasTLS","some","_","interpretNext","headProtoCode","headProtoVal","restMa","interpreter","interpreters","name","Error","restVal","ip4","ip6","length","tcp","tailProto","pop","udp","dnsaddr","dns4","dns6","dns","ipfs","p2p","http","maHasTLS","sni","protocol","baseVal","replace","tls","https","ws","wss","multiaddrToUri","input","opts","parts","stringTuples","head","uri","assumeHttp","includes","startsWith","URL","toString","endsWith","substring"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/@multiformats/multiaddr-to-uri/dist/src/index.js\n");
/***/ }),
/***/ "(ssr)/./node_modules/@multiformats/multiaddr/dist/src/codec.js":
/*!****************************************************************!*\
!*** ./node_modules/@multiformats/multiaddr/dist/src/codec.js ***!
\****************************************************************/
/***/ ((__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 */ ParseError: () => (/* binding */ ParseError),\n/* harmony export */ bytesToMultiaddrParts: () => (/* binding */ bytesToMultiaddrParts),\n/* harmony export */ bytesToTuples: () => (/* binding */ bytesToTuples),\n/* harmony export */ cleanPath: () => (/* binding */ cleanPath),\n/* harmony export */ stringToMultiaddrParts: () => (/* binding */ stringToMultiaddrParts),\n/* harmony export */ tuplesToBytes: () => (/* binding */ tuplesToBytes)\n/* harmony export */ });\n/* harmony import */ var uint8_varint__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! uint8-varint */ \"(ssr)/./node_modules/uint8-varint/dist/src/index.js\");\n/* harmony import */ var uint8arrays_concat__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! uint8arrays/concat */ \"(ssr)/./node_modules/uint8arrays/dist/src/concat.node.js\");\n/* harmony import */ var uint8arrays_to_string__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! uint8arrays/to-string */ \"(ssr)/./node_modules/uint8arrays/dist/src/to-string.node.js\");\n/* harmony import */ var _convert_js__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./convert.js */ \"(ssr)/./node_modules/@multiformats/multiaddr/dist/src/convert.js\");\n/* harmony import */ var _protocols_table_js__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./protocols-table.js */ \"(ssr)/./node_modules/@multiformats/multiaddr/dist/src/protocols-table.js\");\n\n\n\n\n\nfunction stringToMultiaddrParts(str) {\n str = cleanPath(str);\n const tuples = [];\n const stringTuples = [];\n let path = null;\n const parts = str.split(\"/\").slice(1);\n if (parts.length === 1 && parts[0] === \"\") {\n return {\n bytes: new Uint8Array(),\n string: \"/\",\n tuples: [],\n stringTuples: [],\n path: null\n };\n }\n for(let p = 0; p < parts.length; p++){\n const part = parts[p];\n const proto = (0,_protocols_table_js__WEBPACK_IMPORTED_MODULE_4__.getProtocol)(part);\n if (proto.size === 0) {\n tuples.push([\n proto.code\n ]);\n stringTuples.push([\n proto.code\n ]);\n continue;\n }\n p++; // advance addr part\n if (p >= parts.length) {\n throw ParseError(\"invalid address: \" + str);\n }\n // if it's a path proto, take the rest\n if (proto.path === true) {\n // should we need to check each path part to see if it's a proto?\n // This would allow for other protocols to be added after a unix path,\n // however it would have issues if the path had a protocol name in the path\n path = cleanPath(parts.slice(p).join(\"/\"));\n tuples.push([\n proto.code,\n (0,_convert_js__WEBPACK_IMPORTED_MODULE_3__.convertToBytes)(proto.code, path)\n ]);\n stringTuples.push([\n proto.code,\n path\n ]);\n break;\n }\n const bytes = (0,_convert_js__WEBPACK_IMPORTED_MODULE_3__.convertToBytes)(proto.code, parts[p]);\n tuples.push([\n proto.code,\n bytes\n ]);\n stringTuples.push([\n proto.code,\n (0,_convert_js__WEBPACK_IMPORTED_MODULE_3__.convertToString)(proto.code, bytes)\n ]);\n }\n return {\n string: stringTuplesToString(stringTuples),\n bytes: tuplesToBytes(tuples),\n tuples,\n stringTuples,\n path\n };\n}\nfunction bytesToMultiaddrParts(bytes) {\n const tuples = [];\n const stringTuples = [];\n let path = null;\n let i = 0;\n while(i < bytes.length){\n const code = uint8_varint__WEBPACK_IMPORTED_MODULE_0__.decode(bytes, i);\n const n = uint8_varint__WEBPACK_IMPORTED_MODULE_0__.encodingLength(code);\n const p = (0,_protocols_table_js__WEBPACK_IMPORTED_MODULE_4__.getProtocol)(code);\n const size = sizeForAddr(p, bytes.slice(i + n));\n if (size === 0) {\n tuples.push([\n code\n ]);\n stringTuples.push([\n code\n ]);\n i += n;\n continue;\n }\n const addr = bytes.slice(i + n, i + n + size);\n i += size + n;\n if (i > bytes.length) {\n throw ParseError(\"Invalid address Uint8Array: \" + (0,uint8arrays_to_string__WEBPACK_IMPORTED_MODULE_2__.toString)(bytes, \"base16\"));\n }\n // ok, tuple seems good.\n tuples.push([\n code,\n addr\n ]);\n const stringAddr = (0,_convert_js__WEBPACK_IMPORTED_MODULE_3__.convertToString)(code, addr);\n stringTuples.push([\n code,\n stringAddr\n ]);\n if (p.path === true) {\n // should we need to check each path part to see if it's a proto?\n // This would allow for other protocols to be added after a unix path,\n // however it would have issues if the path had a protocol name in the path\n path = stringAddr;\n break;\n }\n }\n return {\n bytes: Uint8Array.from(bytes),\n string: stringTuplesToString(stringTuples),\n tuples,\n stringTuples,\n path\n };\n}\n/**\n * [[str name, str addr]... ] -> string\n */ function stringTuplesToString(tuples) {\n const parts = [];\n tuples.map((tup)=>{\n const proto = (0,_protocols_table_js__WEBPACK_IMPORTED_MODULE_4__.getProtocol)(tup[0]);\n parts.push(proto.name);\n if (tup.length > 1 && tup[1] != null) {\n parts.push(tup[1]);\n }\n return null;\n });\n return cleanPath(parts.join(\"/\"));\n}\n/**\n * [[int code, Uint8Array ]... ] -> Uint8Array\n */ function tuplesToBytes(tuples) {\n return (0,uint8arrays_concat__WEBPACK_IMPORTED_MODULE_1__.concat)(tuples.map((tup)=>{\n const proto = (0,_protocols_table_js__WEBPACK_IMPORTED_MODULE_4__.getProtocol)(tup[0]);\n let buf = Uint8Array.from(uint8_varint__WEBPACK_IMPORTED_MODULE_0__.encode(proto.code));\n if (tup.length > 1 && tup[1] != null) {\n buf = (0,uint8arrays_concat__WEBPACK_IMPORTED_MODULE_1__.concat)([\n buf,\n tup[1]\n ]); // add address buffer\n }\n return buf;\n }));\n}\n/**\n * For the passed address, return the serialized size\n */ function sizeForAddr(p, addr) {\n if (p.size > 0) {\n return p.size / 8;\n } else if (p.size === 0) {\n return 0;\n } else {\n const size = uint8_varint__WEBPACK_IMPORTED_MODULE_0__.decode(addr instanceof Uint8Array ? addr : Uint8Array.from(addr));\n return size + uint8_varint__WEBPACK_IMPORTED_MODULE_0__.encodingLength(size);\n }\n}\nfunction bytesToTuples(buf) {\n const tuples = [];\n let i = 0;\n while(i < buf.length){\n const code = uint8_varint__WEBPACK_IMPORTED_MODULE_0__.decode(buf, i);\n const n = uint8_varint__WEBPACK_IMPORTED_MODULE_0__.encodingLength(code);\n const p = (0,_protocols_table_js__WEBPACK_IMPORTED_MODULE_4__.getProtocol)(code);\n const size = sizeForAddr(p, buf.slice(i + n));\n if (size === 0) {\n tuples.push([\n code\n ]);\n i += n;\n continue;\n }\n const addr = buf.slice(i + n, i + n + size);\n i += size + n;\n if (i > buf.length) {\n throw ParseError(\"Invalid address Uint8Array: \" + (0,uint8arrays_to_string__WEBPACK_IMPORTED_MODULE_2__.toString)(buf, \"base16\"));\n }\n // ok, tuple seems good.\n tuples.push([\n code,\n addr\n ]);\n }\n return tuples;\n}\nfunction cleanPath(str) {\n return \"/\" + str.trim().split(\"/\").filter((a)=>a).join(\"/\");\n}\nfunction ParseError(str) {\n return new Error(\"Error parsing address: \" + str);\n} //# sourceMappingURL=codec.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"(ssr)/./node_modules/@multiformats/multiaddr/dist/src/codec.js","mappings":"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","sources":["webpack://flush-notes/./node_modules/@multiformats/multiaddr/dist/src/codec.js?d337"],"sourcesContent":["import * as varint from 'uint8-varint';\nimport { concat as uint8ArrayConcat } from 'uint8arrays/concat';\nimport { toString as uint8ArrayToString } from 'uint8arrays/to-string';\nimport { convertToBytes, convertToString } from './convert.js';\nimport { getProtocol } from './protocols-table.js';\nexport function stringToMultiaddrParts(str) {\n    str = cleanPath(str);\n    const tuples = [];\n    const stringTuples = [];\n    let path = null;\n    const parts = str.split('/').slice(1);\n    if (parts.length === 1 && parts[0] === '') {\n        return {\n            bytes: new Uint8Array(),\n            string: '/',\n            tuples: [],\n            stringTuples: [],\n            path: null\n        };\n    }\n    for (let p = 0; p < parts.length; p++) {\n        const part = parts[p];\n        const proto = getProtocol(part);\n        if (proto.size === 0) {\n            tuples.push([proto.code]);\n            stringTuples.push([proto.code]);\n            // eslint-disable-next-line no-continue\n            continue;\n        }\n        p++; // advance addr part\n        if (p >= parts.length) {\n            throw ParseError('invalid address: ' + str);\n        }\n        // if it's a path proto, take the rest\n        if (proto.path === true) {\n            // should we need to check each path part to see if it's a proto?\n            // This would allow for other protocols to be added after a unix path,\n            // however it would have issues if the path had a protocol name in the path\n            path = cleanPath(parts.slice(p).join('/'));\n            tuples.push([proto.code, convertToBytes(proto.code, path)]);\n            stringTuples.push([proto.code, path]);\n            break;\n        }\n        const bytes = convertToBytes(proto.code, parts[p]);\n        tuples.push([proto.code, bytes]);\n        stringTuples.push([proto.code, convertToString(proto.code, bytes)]);\n    }\n    return {\n        string: stringTuplesToString(stringTuples),\n        bytes: tuplesToBytes(tuples),\n        tuples,\n        stringTuples,\n        path\n    };\n}\nexport function bytesToMultiaddrParts(bytes) {\n    const tuples = [];\n    const stringTuples = [];\n    let path = null;\n    let i = 0;\n    while (i < bytes.length) {\n        const code = varint.decode(bytes, i);\n        const n = varint.encodingLength(code);\n        const p = getProtocol(code);\n        const size = sizeForAddr(p, bytes.slice(i + n));\n        if (size === 0) {\n            tuples.push([code]);\n            stringTuples.push([code]);\n            i += n;\n            // eslint-disable-next-line no-continue\n            continue;\n        }\n        const addr = bytes.slice(i + n, i + n + size);\n        i += (size + n);\n        if (i > bytes.length) { // did not end _exactly_ at buffer.length\n            throw ParseError('Invalid address Uint8Array: ' + uint8ArrayToString(bytes, 'base16'));\n        }\n        // ok, tuple seems good.\n        tuples.push([code, addr]);\n        const stringAddr = convertToString(code, addr);\n        stringTuples.push([code, stringAddr]);\n        if (p.path === true) {\n            // should we need to check each path part to see if it's a proto?\n            // This would allow for other protocols to be added after a unix path,\n            // however it would have issues if the path had a protocol name in the path\n            path = stringAddr;\n            break;\n        }\n    }\n    return {\n        bytes: Uint8Array.from(bytes),\n        string: stringTuplesToString(stringTuples),\n        tuples,\n        stringTuples,\n        path\n    };\n}\n/**\n * [[str name, str addr]... ] -> string\n */\nfunction stringTuplesToString(tuples) {\n    const parts = [];\n    tuples.map((tup) => {\n        const proto = getProtocol(tup[0]);\n        parts.push(proto.name);\n        if (tup.length > 1 && tup[1] != null) {\n            parts.push(tup[1]);\n        }\n        return null;\n    });\n    return cleanPath(parts.join('/'));\n}\n/**\n * [[int code, Uint8Array ]... ] -> Uint8Array\n */\nexport function tuplesToBytes(tuples) {\n    return uint8ArrayConcat(tuples.map((tup) => {\n        const proto = getProtocol(tup[0]);\n        let buf = Uint8Array.from(varint.encode(proto.code));\n        if (tup.length > 1 && tup[1] != null) {\n            buf = uint8ArrayConcat([buf, tup[1]]); // add address buffer\n        }\n        return buf;\n    }));\n}\n/**\n * For the passed address, return the serialized size\n */\nfunction sizeForAddr(p, addr) {\n    if (p.size > 0) {\n        return p.size / 8;\n    }\n    else if (p.size === 0) {\n        return 0;\n    }\n    else {\n        const size = varint.decode(addr instanceof Uint8Array ? addr : Uint8Array.from(addr));\n        return size + varint.encodingLength(size);\n    }\n}\nexport function bytesToTuples(buf) {\n    const tuples = [];\n    let i = 0;\n    while (i < buf.length) {\n        const code = varint.decode(buf, i);\n        const n = varint.encodingLength(code);\n        const p = getProtocol(code);\n        const size = sizeForAddr(p, buf.slice(i + n));\n        if (size === 0) {\n            tuples.push([code]);\n            i += n;\n            // eslint-disable-next-line no-continue\n            continue;\n        }\n        const addr = buf.slice(i + n, i + n + size);\n        i += (size + n);\n        if (i > buf.length) { // did not end _exactly_ at buffer.length\n            throw ParseError('Invalid address Uint8Array: ' + uint8ArrayToString(buf, 'base16'));\n        }\n        // ok, tuple seems good.\n        tuples.push([code, addr]);\n    }\n    return tuples;\n}\nexport function cleanPath(str) {\n    return '/' + str.trim().split('/').filter((a) => a).join('/');\n}\nexport function ParseError(str) {\n    return new Error('Error parsing address: ' + str);\n}\n//# sourceMappingURL=codec.js.map"],"names":["varint","concat","uint8ArrayConcat","toString","uint8ArrayToString","convertToBytes","convertToString","getProtocol","stringToMultiaddrParts","str","cleanPath","tuples","stringTuples","path","parts","split","slice","length","bytes","Uint8Array","string","p","part","proto","size","push","code","ParseError","join","stringTuplesToString","tuplesToBytes","bytesToMultiaddrParts","i","decode","n","encodingLength","sizeForAddr","addr","stringAddr","from","map","tup","name","buf","encode","bytesToTuples","trim","filter","a","Error"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/@multiformats/multiaddr/dist/src/codec.js\n");
/***/ }),
/***/ "(ssr)/./node_modules/@multiformats/multiaddr/dist/src/convert.js":
/*!******************************************************************!*\
!*** ./node_modules/@multiformats/multiaddr/dist/src/convert.js ***!
\******************************************************************/
/***/ ((__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 */ convert: () => (/* binding */ convert),\n/* harmony export */ convertToBytes: () => (/* binding */ convertToBytes),\n/* harmony export */ convertToIpNet: () => (/* binding */ convertToIpNet),\n/* harmony export */ convertToString: () => (/* binding */ convertToString)\n/* harmony export */ });\n/* harmony import */ var _chainsafe_netmask__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @chainsafe/netmask */ \"(ssr)/./node_modules/@chainsafe/netmask/dist/src/index.js\");\n/* harmony import */ var multiformats_bases_base32__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! multiformats/bases/base32 */ \"(ssr)/./node_modules/multiformats/dist/src/bases/base32.js\");\n/* harmony import */ var multiformats_bases_base58__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! multiformats/bases/base58 */ \"(ssr)/./node_modules/multiformats/dist/src/bases/base58.js\");\n/* harmony import */ var multiformats_basics__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! multiformats/basics */ \"(ssr)/./node_modules/multiformats/dist/src/basics.js\");\n/* harmony import */ var multiformats_cid__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! multiformats/cid */ \"(ssr)/./node_modules/multiformats/dist/src/cid.js\");\n/* harmony import */ var multiformats_hashes_digest__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! multiformats/hashes/digest */ \"(ssr)/./node_modules/multiformats/dist/src/hashes/digest.js\");\n/* harmony import */ var uint8_varint__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! uint8-varint */ \"(ssr)/./node_modules/uint8-varint/dist/src/index.js\");\n/* harmony import */ var uint8arrays_concat__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! uint8arrays/concat */ \"(ssr)/./node_modules/uint8arrays/dist/src/concat.node.js\");\n/* harmony import */ var uint8arrays_from_string__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(/*! uint8arrays/from-string */ \"(ssr)/./node_modules/uint8arrays/dist/src/from-string.node.js\");\n/* harmony import */ var uint8arrays_to_string__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(/*! uint8arrays/to-string */ \"(ssr)/./node_modules/uint8arrays/dist/src/to-string.node.js\");\n/* harmony import */ var _ip_js__WEBPACK_IMPORTED_MODULE_10__ = __webpack_require__(/*! ./ip.js */ \"(ssr)/./node_modules/@multiformats/multiaddr/dist/src/ip.js\");\n/* harmony import */ var _protocols_table_js__WEBPACK_IMPORTED_MODULE_11__ = __webpack_require__(/*! ./protocols-table.js */ \"(ssr)/./node_modules/@multiformats/multiaddr/dist/src/protocols-table.js\");\n/**\n * @packageDocumentation\n *\n * Provides methods for converting\n */ \n\n\n\n\n\n\n\n\n\n\n\nconst ip4Protocol = (0,_protocols_table_js__WEBPACK_IMPORTED_MODULE_11__.getProtocol)(\"ip4\");\nconst ip6Protocol = (0,_protocols_table_js__WEBPACK_IMPORTED_MODULE_11__.getProtocol)(\"ip6\");\nconst ipcidrProtocol = (0,_protocols_table_js__WEBPACK_IMPORTED_MODULE_11__.getProtocol)(\"ipcidr\");\nfunction convert(proto, a) {\n if (a instanceof Uint8Array) {\n return convertToString(proto, a);\n } else {\n return convertToBytes(proto, a);\n }\n}\n/**\n * Convert [code,Uint8Array] to string\n */ function convertToString(proto, buf) {\n const protocol = (0,_protocols_table_js__WEBPACK_IMPORTED_MODULE_11__.getProtocol)(proto);\n switch(protocol.code){\n case 4:\n case 41:\n return bytes2ip(buf);\n case 42:\n return bytes2str(buf);\n case 6:\n case 273:\n case 33:\n case 132:\n return bytes2port(buf).toString();\n case 53:\n case 54:\n case 55:\n case 56:\n case 400:\n case 449:\n case 777:\n return bytes2str(buf);\n case 421:\n return bytes2mh(buf);\n case 444:\n return bytes2onion(buf);\n case 445:\n return bytes2onion(buf);\n case 466:\n return bytes2mb(buf);\n default:\n return (0,uint8arrays_to_string__WEBPACK_IMPORTED_MODULE_9__.toString)(buf, \"base16\"); // no clue. convert to hex\n }\n}\nfunction convertToBytes(proto, str) {\n const protocol = (0,_protocols_table_js__WEBPACK_IMPORTED_MODULE_11__.getProtocol)(proto);\n switch(protocol.code){\n case 4:\n return ip2bytes(str);\n case 41:\n return ip2bytes(str);\n case 42:\n return str2bytes(str);\n case 6:\n case 273:\n case 33:\n case 132:\n return port2bytes(parseInt(str, 10));\n case 53:\n case 54:\n case 55:\n case 56:\n case 400:\n case 449:\n case 777:\n return str2bytes(str);\n case 421:\n return mh2bytes(str);\n case 444:\n return onion2bytes(str);\n case 445:\n return onion32bytes(str);\n case 466:\n return mb2bytes(str);\n default:\n return (0,uint8arrays_from_string__WEBPACK_IMPORTED_MODULE_8__.fromString)(str, \"base16\"); // no clue. convert from hex\n }\n}\nfunction convertToIpNet(multiaddr) {\n let mask;\n let addr;\n multiaddr.stringTuples().forEach(([code, value])=>{\n if (code === ip4Protocol.code || code === ip6Protocol.code) {\n addr = value;\n }\n if (code === ipcidrProtocol.code) {\n mask = value;\n }\n });\n if (mask == null || addr == null) {\n throw new Error(\"Invalid multiaddr\");\n }\n return new _chainsafe_netmask__WEBPACK_IMPORTED_MODULE_0__.IpNet(addr, mask);\n}\nconst decoders = Object.values(multiformats_basics__WEBPACK_IMPORTED_MODULE_3__.bases).map((c)=>c.decoder);\nconst anybaseDecoder = function() {\n let acc = decoders[0].or(decoders[1]);\n decoders.slice(2).forEach((d)=>acc = acc.or(d));\n return acc;\n}();\nfunction ip2bytes(ipString) {\n if (!_ip_js__WEBPACK_IMPORTED_MODULE_10__.isIP(ipString)) {\n throw new Error(\"invalid ip address\");\n }\n return _ip_js__WEBPACK_IMPORTED_MODULE_10__.toBytes(ipString);\n}\nfunction bytes2ip(ipBuff) {\n const ipString = _ip_js__WEBPACK_IMPORTED_MODULE_10__.toString(ipBuff, 0, ipBuff.length);\n if (ipString == null) {\n throw new Error(\"ipBuff is required\");\n }\n if (!_ip_js__WEBPACK_IMPORTED_MODULE_10__.isIP(ipString)) {\n throw new Error(\"invalid ip address\");\n }\n return ipString;\n}\nfunction port2bytes(port) {\n const buf = new ArrayBuffer(2);\n const view = new DataView(buf);\n view.setUint16(0, port);\n return new Uint8Array(buf);\n}\nfunction bytes2port(buf) {\n const view = new DataView(buf.buffer);\n return view.getUint16(buf.byteOffset);\n}\nfunction str2bytes(str) {\n const buf = (0,uint8arrays_from_string__WEBPACK_IMPORTED_MODULE_8__.fromString)(str);\n const size = Uint8Array.from(uint8_varint__WEBPACK_IMPORTED_MODULE_6__.encode(buf.length));\n return (0,uint8arrays_concat__WEBPACK_IMPORTED_MODULE_7__.concat)([\n size,\n buf\n ], size.length + buf.length);\n}\nfunction bytes2str(buf) {\n const size = uint8_varint__WEBPACK_IMPORTED_MODULE_6__.decode(buf);\n buf = buf.slice(uint8_varint__WEBPACK_IMPORTED_MODULE_6__.encodingLength(size));\n if (buf.length !== size) {\n throw new Error(\"inconsistent lengths\");\n }\n return (0,uint8arrays_to_string__WEBPACK_IMPORTED_MODULE_9__.toString)(buf);\n}\nfunction mh2bytes(hash) {\n let mh;\n if (hash[0] === \"Q\" || hash[0] === \"1\") {\n mh = multiformats_hashes_digest__WEBPACK_IMPORTED_MODULE_5__.decode(multiformats_bases_base58__WEBPACK_IMPORTED_MODULE_2__.base58btc.decode(`z${hash}`)).bytes;\n } else {\n mh = multiformats_cid__WEBPACK_IMPORTED_MODULE_4__.CID.parse(hash).multihash.bytes;\n }\n // the address is a varint prefixed multihash string representation\n const size = Uint8Array.from(uint8_varint__WEBPACK_IMPORTED_MODULE_6__.encode(mh.length));\n return (0,uint8arrays_concat__WEBPACK_IMPORTED_MODULE_7__.concat)([\n size,\n mh\n ], size.length + mh.length);\n}\nfunction mb2bytes(mbstr) {\n const mb = anybaseDecoder.decode(mbstr);\n const size = Uint8Array.from(uint8_varint__WEBPACK_IMPORTED_MODULE_6__.encode(mb.length));\n return (0,uint8arrays_concat__WEBPACK_IMPORTED_MODULE_7__.concat)([\n size,\n mb\n ], size.length + mb.length);\n}\nfunction bytes2mb(buf) {\n const size = uint8_varint__WEBPACK_IMPORTED_MODULE_6__.decode(buf);\n const hash = buf.slice(uint8_varint__WEBPACK_IMPORTED_MODULE_6__.encodingLength(size));\n if (hash.length !== size) {\n throw new Error(\"inconsistent lengths\");\n }\n return \"u\" + (0,uint8arrays_to_string__WEBPACK_IMPORTED_MODULE_9__.toString)(hash, \"base64url\");\n}\n/**\n * Converts bytes to bas58btc string\n */ function bytes2mh(buf) {\n const size = uint8_varint__WEBPACK_IMPORTED_MODULE_6__.decode(buf);\n const address = buf.slice(uint8_varint__WEBPACK_IMPORTED_MODULE_6__.encodingLength(size));\n if (address.length !== size) {\n throw new Error(\"inconsistent lengths\");\n }\n return (0,uint8arrays_to_string__WEBPACK_IMPORTED_MODULE_9__.toString)(address, \"base58btc\");\n}\nfunction onion2bytes(str) {\n const addr = str.split(\":\");\n if (addr.length !== 2) {\n throw new Error(`failed to parse onion addr: [\"'${addr.join('\", \"')}'\"]' does not contain a port number`);\n }\n if (addr[0].length !== 16) {\n throw new Error(`failed to parse onion addr: ${addr[0]} not a Tor onion address.`);\n }\n // onion addresses do not include the multibase prefix, add it before decoding\n const buf = multiformats_bases_base32__WEBPACK_IMPORTED_MODULE_1__.base32.decode(\"b\" + addr[0]);\n // onion port number\n const port = parseInt(addr[1], 10);\n if (port < 1 || port > 65536) {\n throw new Error(\"Port number is not in range(1, 65536)\");\n }\n const portBuf = port2bytes(port);\n return (0,uint8arrays_concat__WEBPACK_IMPORTED_MODULE_7__.concat)([\n buf,\n portBuf\n ], buf.length + portBuf.length);\n}\nfunction onion32bytes(str) {\n const addr = str.split(\":\");\n if (addr.length !== 2) {\n throw new Error(`failed to parse onion addr: [\"'${addr.join('\", \"')}'\"]' does not contain a port number`);\n }\n if (addr[0].length !== 56) {\n throw new Error(`failed to parse onion addr: ${addr[0]} not a Tor onion3 address.`);\n }\n // onion addresses do not include the multibase prefix, add it before decoding\n const buf = multiformats_bases_base32__WEBPACK_IMPORTED_MODULE_1__.base32.decode(`b${addr[0]}`);\n // onion port number\n const port = parseInt(addr[1], 10);\n if (port < 1 || port > 65536) {\n throw new Error(\"Port number is not in range(1, 65536)\");\n }\n const portBuf = port2bytes(port);\n return (0,uint8arrays_concat__WEBPACK_IMPORTED_MODULE_7__.concat)([\n buf,\n portBuf\n ], buf.length + portBuf.length);\n}\nfunction bytes2onion(buf) {\n const addrBytes = buf.slice(0, buf.length - 2);\n const portBytes = buf.slice(buf.length - 2);\n const addr = (0,uint8arrays_to_string__WEBPACK_IMPORTED_MODULE_9__.toString)(addrBytes, \"base32\");\n const port = bytes2port(portBytes);\n return `${addr}:${port}`;\n} //# sourceMappingURL=convert.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"(ssr)/./node_modules/@multiformats/multiaddr/dist/src/convert.js","mappings":"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","sources":["webpack://flush-notes/./node_modules/@multiformats/multiaddr/dist/src/convert.js?cdb5"],"sourcesContent":["/**\n * @packageDocumentation\n *\n * Provides methods for converting\n */\nimport { IpNet } from '@chainsafe/netmask';\nimport { base32 } from 'multiformats/bases/base32';\nimport { base58btc } from 'multiformats/bases/base58';\nimport { bases } from 'multiformats/basics';\nimport { CID } from 'multiformats/cid';\nimport * as Digest from 'multiformats/hashes/digest';\nimport * as varint from 'uint8-varint';\nimport { concat as uint8ArrayConcat } from 'uint8arrays/concat';\nimport { fromString as uint8ArrayFromString } from 'uint8arrays/from-string';\nimport { toString as uint8ArrayToString } from 'uint8arrays/to-string';\nimport * as ip from './ip.js';\nimport { getProtocol } from './protocols-table.js';\nconst ip4Protocol = getProtocol('ip4');\nconst ip6Protocol = getProtocol('ip6');\nconst ipcidrProtocol = getProtocol('ipcidr');\nexport function convert(proto, a) {\n    if (a instanceof Uint8Array) {\n        return convertToString(proto, a);\n    }\n    else {\n        return convertToBytes(proto, a);\n    }\n}\n/**\n * Convert [code,Uint8Array] to string\n */\nexport function convertToString(proto, buf) {\n    const protocol = getProtocol(proto);\n    switch (protocol.code) {\n        case 4: // ipv4\n        case 41: // ipv6\n            return bytes2ip(buf);\n        case 42: // ipv6zone\n            return bytes2str(buf);\n        case 6: // tcp\n        case 273: // udp\n        case 33: // dccp\n        case 132: // sctp\n            return bytes2port(buf).toString();\n        case 53: // dns\n        case 54: // dns4\n        case 55: // dns6\n        case 56: // dnsaddr\n        case 400: // unix\n        case 449: // sni\n        case 777: // memory\n            return bytes2str(buf);\n        case 421: // ipfs\n            return bytes2mh(buf);\n        case 444: // onion\n            return bytes2onion(buf);\n        case 445: // onion3\n            return bytes2onion(buf);\n        case 466: // certhash\n            return bytes2mb(buf);\n        default:\n            return uint8ArrayToString(buf, 'base16'); // no clue. convert to hex\n    }\n}\nexport function convertToBytes(proto, str) {\n    const protocol = getProtocol(proto);\n    switch (protocol.code) {\n        case 4: // ipv4\n            return ip2bytes(str);\n        case 41: // ipv6\n            return ip2bytes(str);\n        case 42: // ipv6zone\n            return str2bytes(str);\n        case 6: // tcp\n        case 273: // udp\n        case 33: // dccp\n        case 132: // sctp\n            return port2bytes(parseInt(str, 10));\n        case 53: // dns\n        case 54: // dns4\n        case 55: // dns6\n        case 56: // dnsaddr\n        case 400: // unix\n        case 449: // sni\n        case 777: // memory\n            return str2bytes(str);\n        case 421: // ipfs\n            return mh2bytes(str);\n        case 444: // onion\n            return onion2bytes(str);\n        case 445: // onion3\n            return onion32bytes(str);\n        case 466: // certhash\n            return mb2bytes(str);\n        default:\n            return uint8ArrayFromString(str, 'base16'); // no clue. convert from hex\n    }\n}\nexport function convertToIpNet(multiaddr) {\n    let mask;\n    let addr;\n    multiaddr.stringTuples().forEach(([code, value]) => {\n        if (code === ip4Protocol.code || code === ip6Protocol.code) {\n            addr = value;\n        }\n        if (code === ipcidrProtocol.code) {\n            mask = value;\n        }\n    });\n    if (mask == null || addr == null) {\n        throw new Error('Invalid multiaddr');\n    }\n    return new IpNet(addr, mask);\n}\nconst decoders = Object.values(bases).map((c) => c.decoder);\nconst anybaseDecoder = (function () {\n    let acc = decoders[0].or(decoders[1]);\n    decoders.slice(2).forEach((d) => (acc = acc.or(d)));\n    return acc;\n})();\nfunction ip2bytes(ipString) {\n    if (!ip.isIP(ipString)) {\n        throw new Error('invalid ip address');\n    }\n    return ip.toBytes(ipString);\n}\nfunction bytes2ip(ipBuff) {\n    const ipString = ip.toString(ipBuff, 0, ipBuff.length);\n    if (ipString == null) {\n        throw new Error('ipBuff is required');\n    }\n    if (!ip.isIP(ipString)) {\n        throw new Error('invalid ip address');\n    }\n    return ipString;\n}\nfunction port2bytes(port) {\n    const buf = new ArrayBuffer(2);\n    const view = new DataView(buf);\n    view.setUint16(0, port);\n    return new Uint8Array(buf);\n}\nfunction bytes2port(buf) {\n    const view = new DataView(buf.buffer);\n    return view.getUint16(buf.byteOffset);\n}\nfunction str2bytes(str) {\n    const buf = uint8ArrayFromString(str);\n    const size = Uint8Array.from(varint.encode(buf.length));\n    return uint8ArrayConcat([size, buf], size.length + buf.length);\n}\nfunction bytes2str(buf) {\n    const size = varint.decode(buf);\n    buf = buf.slice(varint.encodingLength(size));\n    if (buf.length !== size) {\n        throw new Error('inconsistent lengths');\n    }\n    return uint8ArrayToString(buf);\n}\nfunction mh2bytes(hash) {\n    let mh;\n    if (hash[0] === 'Q' || hash[0] === '1') {\n        mh = Digest.decode(base58btc.decode(`z${hash}`)).bytes;\n    }\n    else {\n        mh = CID.parse(hash).multihash.bytes;\n    }\n    // the address is a varint prefixed multihash string representation\n    const size = Uint8Array.from(varint.encode(mh.length));\n    return uint8ArrayConcat([size, mh], size.length + mh.length);\n}\nfunction mb2bytes(mbstr) {\n    const mb = anybaseDecoder.decode(mbstr);\n    const size = Uint8Array.from(varint.encode(mb.length));\n    return uint8ArrayConcat([size, mb], size.length + mb.length);\n}\nfunction bytes2mb(buf) {\n    const size = varint.decode(buf);\n    const hash = buf.slice(varint.encodingLength(size));\n    if (hash.length !== size) {\n        throw new Error('inconsistent lengths');\n    }\n    return 'u' + uint8ArrayToString(hash, 'base64url');\n}\n/**\n * Converts bytes to bas58btc string\n */\nfunction bytes2mh(buf) {\n    const size = varint.decode(buf);\n    const address = buf.slice(varint.encodingLength(size));\n    if (address.length !== size) {\n        throw new Error('inconsistent lengths');\n    }\n    return uint8ArrayToString(address, 'base58btc');\n}\nfunction onion2bytes(str) {\n    const addr = str.split(':');\n    if (addr.length !== 2) {\n        throw new Error(`failed to parse onion addr: [\"'${addr.join('\", \"')}'\"]' does not contain a port number`);\n    }\n    if (addr[0].length !== 16) {\n        throw new Error(`failed to parse onion addr: ${addr[0]} not a Tor onion address.`);\n    }\n    // onion addresses do not include the multibase prefix, add it before decoding\n    const buf = base32.decode('b' + addr[0]);\n    // onion port number\n    const port = parseInt(addr[1], 10);\n    if (port < 1 || port > 65536) {\n        throw new Error('Port number is not in range(1, 65536)');\n    }\n    const portBuf = port2bytes(port);\n    return uint8ArrayConcat([buf, portBuf], buf.length + portBuf.length);\n}\nfunction onion32bytes(str) {\n    const addr = str.split(':');\n    if (addr.length !== 2) {\n        throw new Error(`failed to parse onion addr: [\"'${addr.join('\", \"')}'\"]' does not contain a port number`);\n    }\n    if (addr[0].length !== 56) {\n        throw new Error(`failed to parse onion addr: ${addr[0]} not a Tor onion3 address.`);\n    }\n    // onion addresses do not include the multibase prefix, add it before decoding\n    const buf = base32.decode(`b${addr[0]}`);\n    // onion port number\n    const port = parseInt(addr[1], 10);\n    if (port < 1 || port > 65536) {\n        throw new Error('Port number is not in range(1, 65536)');\n    }\n    const portBuf = port2bytes(port);\n    return uint8ArrayConcat([buf, portBuf], buf.length + portBuf.length);\n}\nfunction bytes2onion(buf) {\n    const addrBytes = buf.slice(0, buf.length - 2);\n    const portBytes = buf.slice(buf.length - 2);\n    const addr = uint8ArrayToString(addrBytes, 'base32');\n    const port = bytes2port(portBytes);\n    return `${addr}:${port}`;\n}\n//# sourceMappingURL=convert.js.map"],"names":["IpNet","base32","base58btc","bases","CID","Digest","varint","concat","uint8ArrayConcat","fromString","uint8ArrayFromString","toString","uint8ArrayToString","ip","getProtocol","ip4Protocol","ip6Protocol","ipcidrProtocol","convert","proto","a","Uint8Array","convertToString","convertToBytes","buf","protocol","code","bytes2ip","bytes2str","bytes2port","bytes2mh","bytes2onion","bytes2mb","str","ip2bytes","str2bytes","port2bytes","parseInt","mh2bytes","onion2bytes","onion32bytes","mb2bytes","convertToIpNet","multiaddr","mask","addr","stringTuples","forEach","value","Error","decoders","Object","values","map","c","decoder","anybaseDecoder","acc","or","slice","d","ipString","isIP","toBytes","ipBuff","length","port","ArrayBuffer","view","DataView","setUint16","buffer","getUint16","byteOffset","size","from","encode","decode","encodingLength","hash","mh","bytes","parse","multihash","mbstr","mb","address","split","join","portBuf","addrBytes","portBytes"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/@multiformats/multiaddr/dist/src/convert.js\n");
/***/ }),
/***/ "(ssr)/./node_modules/@multiformats/multiaddr/dist/src/filter/multiaddr-filter.js":
/*!**********************************************************************************!*\
!*** ./node_modules/@multiformats/multiaddr/dist/src/filter/multiaddr-filter.js ***!
\**********************************************************************************/
/***/ ((__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 */ MultiaddrFilter: () => (/* binding */ MultiaddrFilter)\n/* harmony export */ });\n/* harmony import */ var _convert_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../convert.js */ \"(ssr)/./node_modules/@multiformats/multiaddr/dist/src/convert.js\");\n/* harmony import */ var _index_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../index.js */ \"(ssr)/./node_modules/@multiformats/multiaddr/dist/src/index.js\");\n\n\n/**\n * A utility class to determine if a Multiaddr contains another\n * multiaddr.\n *\n * This can be used with ipcidr ranges to determine if a given\n * multiaddr is in a ipcidr range.\n *\n * @example\n *\n * ```js\n * import { multiaddr, MultiaddrFilter } from '@multiformats/multiaddr'\n *\n * const range = multiaddr('/ip4/192.168.10.10/ipcidr/24')\n * const filter = new MultiaddrFilter(range)\n *\n * const input = multiaddr('/ip4/192.168.10.2/udp/60')\n * console.info(filter.contains(input)) // true\n * ```\n */ class MultiaddrFilter {\n constructor(input){\n this.multiaddr = (0,_index_js__WEBPACK_IMPORTED_MODULE_1__.multiaddr)(input);\n this.netmask = (0,_convert_js__WEBPACK_IMPORTED_MODULE_0__.convertToIpNet)(this.multiaddr);\n }\n contains(input) {\n if (input == null) return false;\n const m = (0,_index_js__WEBPACK_IMPORTED_MODULE_1__.multiaddr)(input);\n let ip;\n for (const [code, value] of m.stringTuples()){\n if (code === 4 || code === 41) {\n ip = value;\n break;\n }\n }\n if (ip === undefined) return false;\n return this.netmask.contains(ip);\n }\n} //# sourceMappingURL=multiaddr-filter.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvQG11bHRpZm9ybWF0cy9tdWx0aWFkZHIvZGlzdC9zcmMvZmlsdGVyL211bHRpYWRkci1maWx0ZXIuanMiLCJtYXBwaW5ncyI6Ijs7Ozs7O0FBQStDO0FBQ1A7QUFDeEM7Ozs7Ozs7Ozs7Ozs7Ozs7OztDQWtCQyxHQUNNLE1BQU1FO0lBR1RDLFlBQVlDLEtBQUssQ0FBRTtRQUNmLElBQUksQ0FBQ0gsU0FBUyxHQUFHQSxvREFBU0EsQ0FBQ0c7UUFDM0IsSUFBSSxDQUFDQyxPQUFPLEdBQUdMLDJEQUFjQSxDQUFDLElBQUksQ0FBQ0MsU0FBUztJQUNoRDtJQUNBSyxTQUFTRixLQUFLLEVBQUU7UUFDWixJQUFJQSxTQUFTLE1BQ1QsT0FBTztRQUNYLE1BQU1HLElBQUlOLG9EQUFTQSxDQUFDRztRQUNwQixJQUFJSTtRQUNKLEtBQUssTUFBTSxDQUFDQyxNQUFNQyxNQUFNLElBQUlILEVBQUVJLFlBQVksR0FBSTtZQUMxQyxJQUFJRixTQUFTLEtBQUtBLFNBQVMsSUFBSTtnQkFDM0JELEtBQUtFO2dCQUNMO1lBQ0o7UUFDSjtRQUNBLElBQUlGLE9BQU9JLFdBQ1AsT0FBTztRQUNYLE9BQU8sSUFBSSxDQUFDUCxPQUFPLENBQUNDLFFBQVEsQ0FBQ0U7SUFDakM7QUFDSixFQUNBLDRDQUE0QyIsInNvdXJjZXMiOlsid2VicGFjazovL2ZsdXNoLW5vdGVzLy4vbm9kZV9tb2R1bGVzL0BtdWx0aWZvcm1hdHMvbXVsdGlhZGRyL2Rpc3Qvc3JjL2ZpbHRlci9tdWx0aWFkZHItZmlsdGVyLmpzPzI2NjAiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgY29udmVydFRvSXBOZXQgfSBmcm9tICcuLi9jb252ZXJ0LmpzJztcbmltcG9ydCB7IG11bHRpYWRkciB9IGZyb20gJy4uL2luZGV4LmpzJztcbi8qKlxuICogQSB1dGlsaXR5IGNsYXNzIHRvIGRldGVybWluZSBpZiBhIE11bHRpYWRkciBjb250YWlucyBhbm90aGVyXG4gKiBtdWx0aWFkZHIuXG4gKlxuICogVGhpcyBjYW4gYmUgdXNlZCB3aXRoIGlwY2lkciByYW5nZXMgdG8gZGV0ZXJtaW5lIGlmIGEgZ2l2ZW5cbiAqIG11bHRpYWRkciBpcyBpbiBhIGlwY2lkciByYW5nZS5cbiAqXG4gKiBAZXhhbXBsZVxuICpcbiAqIGBgYGpzXG4gKiBpbXBvcnQgeyBtdWx0aWFkZHIsIE11bHRpYWRkckZpbHRlciB9IGZyb20gJ0BtdWx0aWZvcm1hdHMvbXVsdGlhZGRyJ1xuICpcbiAqIGNvbnN0IHJhbmdlID0gbXVsdGlhZGRyKCcvaXA0LzE5Mi4xNjguMTAuMTAvaXBjaWRyLzI0JylcbiAqIGNvbnN0IGZpbHRlciA9IG5ldyBNdWx0aWFkZHJGaWx0ZXIocmFuZ2UpXG4gKlxuICogY29uc3QgaW5wdXQgPSBtdWx0aWFkZHIoJy9pcDQvMTkyLjE2OC4xMC4yL3VkcC82MCcpXG4gKiBjb25zb2xlLmluZm8oZmlsdGVyLmNvbnRhaW5zKGlucHV0KSkgLy8gdHJ1ZVxuICogYGBgXG4gKi9cbmV4cG9ydCBjbGFzcyBNdWx0aWFkZHJGaWx0ZXIge1xuICAgIG11bHRpYWRkcjtcbiAgICBuZXRtYXNrO1xuICAgIGNvbnN0cnVjdG9yKGlucHV0KSB7XG4gICAgICAgIHRoaXMubXVsdGlhZGRyID0gbXVsdGlhZGRyKGlucHV0KTtcbiAgICAgICAgdGhpcy5uZXRtYXNrID0gY29udmVydFRvSXBOZXQodGhpcy5tdWx0aWFkZHIpO1xuICAgIH1cbiAgICBjb250YWlucyhpbnB1dCkge1xuICAgICAgICBpZiAoaW5wdXQgPT0gbnVsbClcbiAgICAgICAgICAgIHJldHVybiBmYWxzZTtcbiAgICAgICAgY29uc3QgbSA9IG11bHRpYWRkcihpbnB1dCk7XG4gICAgICAgIGxldCBpcDtcbiAgICAgICAgZm9yIChjb25zdCBbY29kZSwgdmFsdWVdIG9mIG0uc3RyaW5nVHVwbGVzKCkpIHtcbiAgICAgICAgICAgIGlmIChjb2RlID09PSA0IHx8IGNvZGUgPT09IDQxKSB7XG4gICAgICAgICAgICAgICAgaXAgPSB2YWx1ZTtcbiAgICAgICAgICAgICAgICBicmVhaztcbiAgICAgICAgICAgIH1cbiAgICAgICAgfVxuICAgICAgICBpZiAoaXAgPT09IHVuZGVmaW5lZClcbiAgICAgICAgICAgIHJldHVybiBmYWxzZTtcbiAgICAgICAgcmV0dXJuIHRoaXMubmV0bWFzay5jb250YWlucyhpcCk7XG4gICAgfVxufVxuLy8jIHNvdXJjZU1hcHBpbmdVUkw9bXVsdGlhZGRyLWZpbHRlci5qcy5tYXAiXSwibmFtZXMiOlsiY29udmVydFRvSXBOZXQiLCJtdWx0aWFkZHIiLCJNdWx0aWFkZHJGaWx0ZXIiLCJjb25zdHJ1Y3RvciIsImlucHV0IiwibmV0bWFzayIsImNvbnRhaW5zIiwibSIsImlwIiwiY29kZSIsInZhbHVlIiwic3RyaW5nVHVwbGVzIiwidW5kZWZpbmVkIl0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/@multiformats/multiaddr/dist/src/filter/multiaddr-filter.js\n");
/***/ }),
/***/ "(ssr)/./node_modules/@multiformats/multiaddr/dist/src/index.js":
/*!****************************************************************!*\
!*** ./node_modules/@multiformats/multiaddr/dist/src/index.js ***!
\****************************************************************/
/***/ ((__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 */ MultiaddrFilter: () => (/* reexport safe */ _filter_multiaddr_filter_js__WEBPACK_IMPORTED_MODULE_2__.MultiaddrFilter),\n/* harmony export */ fromNodeAddress: () => (/* binding */ fromNodeAddress),\n/* harmony export */ isMultiaddr: () => (/* binding */ isMultiaddr),\n/* harmony export */ isName: () => (/* binding */ isName),\n/* harmony export */ multiaddr: () => (/* binding */ multiaddr),\n/* harmony export */ protocols: () => (/* reexport safe */ _protocols_table_js__WEBPACK_IMPORTED_MODULE_1__.getProtocol),\n/* harmony export */ resolvers: () => (/* binding */ resolvers)\n/* harmony export */ });\n/* harmony import */ var _multiaddr_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./multiaddr.js */ \"(ssr)/./node_modules/@multiformats/multiaddr/dist/src/multiaddr.js\");\n/* harmony import */ var _protocols_table_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./protocols-table.js */ \"(ssr)/./node_modules/@multiformats/multiaddr/dist/src/protocols-table.js\");\n/* harmony import */ var _filter_multiaddr_filter_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./filter/multiaddr-filter.js */ \"(ssr)/./node_modules/@multiformats/multiaddr/dist/src/filter/multiaddr-filter.js\");\n/**\n * @packageDocumentation\n *\n * A standard way to represent addresses that\n *\n * - support any standard network protocol\n * - are self-describing\n * - have a binary packed format\n * - have a nice string representation\n * - encapsulate well\n *\n * @example\n *\n * ```TypeScript\n * import { multiaddr } from '@multiformats/multiaddr'\n * const addr = multiaddr(\"/ip4/127.0.0.1/udp/1234\")\n * // Multiaddr(/ip4/127.0.0.1/udp/1234)\n *\n * const addr = multiaddr(\"/ip4/127.0.0.1/udp/1234\")\n * // Multiaddr(/ip4/127.0.0.1/udp/1234)\n *\n * addr.bytes\n * // <Uint8Array 04 7f 00 00 01 11 04 d2>\n *\n * addr.toString()\n * // '/ip4/127.0.0.1/udp/1234'\n *\n * addr.protos()\n * // [\n * // {code: 4, name: 'ip4', size: 32},\n * // {code: 273, name: 'udp', size: 16}\n * // ]\n *\n * // gives you an object that is friendly with what Node.js core modules expect for addresses\n * addr.nodeAddress()\n * // {\n * // family: 4,\n * // port: 1234,\n * // address: \"127.0.0.1\"\n * // }\n *\n * addr.encapsulate('/sctp/5678')\n * // Multiaddr(/ip4/127.0.0.1/udp/1234/sctp/5678)\n * ```\n *\n * ## Resolving DNSADDR addresses\n *\n * [DNSADDR](https://github.com/multiformats/multiaddr/blob/master/protocols/DNSADDR.md) is a spec that allows storing a TXT DNS record that contains a Multiaddr.\n *\n * To resolve DNSADDR addresses, call the `.resolve()` function the multiaddr, optionally passing a `DNS` resolver.\n *\n * DNSADDR addresses can resolve to multiple multiaddrs, since there is no limit to the number of TXT records that can be stored.\n *\n * @example Resolving DNSADDR Multiaddrs\n *\n * ```TypeScript\n * import { multiaddr, resolvers } from '@multiformats/multiaddr'\n * import { dnsaddr } from '@multiformats/multiaddr/resolvers'\n *\n * resolvers.set('dnsaddr', dnsaddr)\n *\n * const ma = multiaddr('/dnsaddr/bootstrap.libp2p.io')\n *\n * // resolve with a 5s timeout\n * const resolved = await ma.resolve({\n * signal: AbortSignal.timeout(5000)\n * })\n *\n * console.info(await ma.resolve(resolved)\n * // [Multiaddr('/ip4/147.75...'), Multiaddr('/ip4/147.75...'), Multiaddr('/ip4/147.75...')...]\n * ```\n *\n * @example Using a custom DNS resolver to resolve DNSADDR Multiaddrs\n *\n * See the docs for [@multiformats/dns](https://www.npmjs.com/package/@multiformats/dns) for a full breakdown of how to specify multiple resolvers or resolvers that can be used for specific TLDs.\n *\n * ```TypeScript\n * import { multiaddr } from '@multiformats/multiaddr'\n * import { dns } from '@multiformats/dns'\n * import { dnsJsonOverHttps } from '@multiformats/dns/resolvers'\n *\n * const resolver = dns({\n * '.': dnsJsonOverHttps('https://cloudflare-dns.com/dns-query')\n * })\n *\n * const ma = multiaddr('/dnsaddr/bootstrap.libp2p.io')\n * const resolved = await ma.resolve({\n * dns: resolver\n * })\n *\n * console.info(resolved)\n * // [Multiaddr('/ip4/147.75...'), Multiaddr('/ip4/147.75...'), Multiaddr('/ip4/147.75...')...]\n * ```\n */ \n\n/**\n * All configured {@link Resolver}s\n */ const resolvers = new Map();\n\n/**\n * Creates a Multiaddr from a node-friendly address object\n *\n * @example\n * ```js\n * import { fromNodeAddress } from '@multiformats/multiaddr'\n *\n * fromNodeAddress({address: '127.0.0.1', port: '4001'}, 'tcp')\n * // Multiaddr(/ip4/127.0.0.1/tcp/4001)\n * ```\n */ function fromNodeAddress(addr, transport) {\n if (addr == null) {\n throw new Error(\"requires node address object\");\n }\n if (transport == null) {\n throw new Error(\"requires transport protocol\");\n }\n let ip;\n let host = addr.address;\n switch(addr.family){\n case 4:\n ip = \"ip4\";\n break;\n case 6:\n ip = \"ip6\";\n if (host.includes(\"%\")) {\n const parts = host.split(\"%\");\n if (parts.length !== 2) {\n throw Error(\"Multiple ip6 zones in multiaddr\");\n }\n host = parts[0];\n const zone = parts[1];\n ip = `/ip6zone/${zone}/ip6`;\n }\n break;\n default:\n throw Error(\"Invalid addr family, should be 4 or 6.\");\n }\n return new _multiaddr_js__WEBPACK_IMPORTED_MODULE_0__.Multiaddr(\"/\" + [\n ip,\n host,\n transport,\n addr.port\n ].join(\"/\"));\n}\n/**\n * Returns if something is a {@link Multiaddr} that is a resolvable name\n *\n * @example\n *\n * ```js\n * import { isName, multiaddr } from '@multiformats/multiaddr'\n *\n * isName(multiaddr('/ip4/127.0.0.1'))\n * // false\n * isName(multiaddr('/dns/ipfs.io'))\n * // true\n * ```\n */ function isName(addr) {\n if (!isMultiaddr(addr)) {\n return false;\n }\n // if a part of the multiaddr is resolvable, then return true\n return addr.protos().some((proto)=>proto.resolvable);\n}\n/**\n * Check if object is a {@link Multiaddr} instance\n *\n * @example\n *\n * ```js\n * import { isMultiaddr, multiaddr } from '@multiformats/multiaddr'\n *\n * isMultiaddr(5)\n * // false\n * isMultiaddr(multiaddr('/ip4/127.0.0.1'))\n * // true\n * ```\n */ function isMultiaddr(value) {\n return Boolean(value?.[_multiaddr_js__WEBPACK_IMPORTED_MODULE_0__.symbol]);\n}\n/**\n * A function that takes a {@link MultiaddrInput} and returns a {@link Multiaddr}\n *\n * @example\n * ```js\n * import { multiaddr } from '@libp2p/multiaddr'\n *\n * multiaddr('/ip4/127.0.0.1/tcp/4001')\n * // Multiaddr(/ip4/127.0.0.1/tcp/4001)\n * ```\n *\n * @param {MultiaddrInput} [addr] - If String or Uint8Array, needs to adhere to the address format of a [multiaddr](https://github.com/multiformats/multiaddr#string-format)\n */ function multiaddr(addr) {\n return new _multiaddr_js__WEBPACK_IMPORTED_MODULE_0__.Multiaddr(addr);\n}\n //# sourceMappingURL=index.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"(ssr)/./node_modules/@multiformats/multiaddr/dist/src/index.js","mappings":";;;;;;;;;;;;;AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CA6FC,GACoE;AAClB;AACnD;;CAEC,GACM,MAAMI,YAAY,IAAIC,MAAM;AAC4B;AAC/D;;;;;;;;;;CAUC,GACM,SAASE,gBAAgBC,IAAI,EAAEC,SAAS;IAC3C,IAAID,QAAQ,MAAM;QACd,MAAM,IAAIE,MAAM;IACpB;IACA,IAAID,aAAa,MAAM;QACnB,MAAM,IAAIC,MAAM;IACpB;IACA,IAAIC;IACJ,IAAIC,OAAOJ,KAAKK,OAAO;IACvB,OAAQL,KAAKM,MAAM;QACf,KAAK;YACDH,KAAK;YACL;QACJ,KAAK;YACDA,KAAK;YACL,IAAIC,KAAKG,QAAQ,CAAC,MAAM;gBACpB,MAAMC,QAAQJ,KAAKK,KAAK,CAAC;gBACzB,IAAID,MAAME,MAAM,KAAK,GAAG;oBACpB,MAAMR,MAAM;gBAChB;gBACAE,OAAOI,KAAK,CAAC,EAAE;gBACf,MAAMG,OAAOH,KAAK,CAAC,EAAE;gBACrBL,KAAK,CAAC,SAAS,EAAEQ,KAAK,IAAI,CAAC;YAC/B;YACA;QACJ;YACI,MAAMT,MAAM;IACpB;IACA,OAAO,IAAIT,oDAAcA,CAAC,MAAM;QAACU;QAAIC;QAAMH;QAAWD,KAAKY,IAAI;KAAC,CAACC,IAAI,CAAC;AAC1E;AACA;;;;;;;;;;;;;CAaC,GACM,SAASC,OAAOd,IAAI;IACvB,IAAI,CAACe,YAAYf,OAAO;QACpB,OAAO;IACX;IACA,6DAA6D;IAC7D,OAAOA,KAAKgB,MAAM,GAAGC,IAAI,CAAC,CAACC,QAAUA,MAAMC,UAAU;AACzD;AACA;;;;;;;;;;;;;CAaC,GACM,SAASJ,YAAYK,KAAK;IAC7B,OAAOC,QAAQD,OAAO,CAAC1B,iDAAMA,CAAC;AAClC;AACA;;;;;;;;;;;;CAYC,GACM,SAAS4B,UAAUtB,IAAI;IAC1B,OAAO,IAAIP,oDAAcA,CAACO;AAC9B;AACoC,CACpC,iCAAiC","sources":["webpack://flush-notes/./node_modules/@multiformats/multiaddr/dist/src/index.js?dd07"],"sourcesContent":["/**\n * @packageDocumentation\n *\n * A standard way to represent addresses that\n *\n * - support any standard network protocol\n * - are self-describing\n * - have a binary packed format\n * - have a nice string representation\n * - encapsulate well\n *\n * @example\n *\n * ```TypeScript\n * import { multiaddr } from '@multiformats/multiaddr'\n * const addr =  multiaddr(\"/ip4/127.0.0.1/udp/1234\")\n * // Multiaddr(/ip4/127.0.0.1/udp/1234)\n *\n * const addr = multiaddr(\"/ip4/127.0.0.1/udp/1234\")\n * // Multiaddr(/ip4/127.0.0.1/udp/1234)\n *\n * addr.bytes\n * // <Uint8Array 04 7f 00 00 01 11 04 d2>\n *\n * addr.toString()\n * // '/ip4/127.0.0.1/udp/1234'\n *\n * addr.protos()\n * // [\n * //   {code: 4, name: 'ip4', size: 32},\n * //   {code: 273, name: 'udp', size: 16}\n * // ]\n *\n * // gives you an object that is friendly with what Node.js core modules expect for addresses\n * addr.nodeAddress()\n * // {\n * //   family: 4,\n * //   port: 1234,\n * //   address: \"127.0.0.1\"\n * // }\n *\n * addr.encapsulate('/sctp/5678')\n * // Multiaddr(/ip4/127.0.0.1/udp/1234/sctp/5678)\n * ```\n *\n * ## Resolving DNSADDR addresses\n *\n * [DNSADDR](https://github.com/multiformats/multiaddr/blob/master/protocols/DNSADDR.md) is a spec that allows storing a TXT DNS record that contains a Multiaddr.\n *\n * To resolve DNSADDR addresses, call the `.resolve()` function the multiaddr, optionally passing a `DNS` resolver.\n *\n * DNSADDR addresses can resolve to multiple multiaddrs, since there is no limit to the number of TXT records that can be stored.\n *\n * @example Resolving DNSADDR Multiaddrs\n *\n * ```TypeScript\n * import { multiaddr, resolvers } from '@multiformats/multiaddr'\n * import { dnsaddr } from '@multiformats/multiaddr/resolvers'\n *\n * resolvers.set('dnsaddr', dnsaddr)\n *\n * const ma = multiaddr('/dnsaddr/bootstrap.libp2p.io')\n *\n * // resolve with a 5s timeout\n * const resolved = await ma.resolve({\n *   signal: AbortSignal.timeout(5000)\n * })\n *\n * console.info(await ma.resolve(resolved)\n * // [Multiaddr('/ip4/147.75...'), Multiaddr('/ip4/147.75...'), Multiaddr('/ip4/147.75...')...]\n * ```\n *\n * @example Using a custom DNS resolver to resolve DNSADDR Multiaddrs\n *\n * See the docs for [@multiformats/dns](https://www.npmjs.com/package/@multiformats/dns) for a full breakdown of how to specify multiple resolvers or resolvers that can be used for specific TLDs.\n *\n * ```TypeScript\n * import { multiaddr } from '@multiformats/multiaddr'\n * import { dns } from '@multiformats/dns'\n * import { dnsJsonOverHttps } from '@multiformats/dns/resolvers'\n *\n * const resolver = dns({\n *   '.': dnsJsonOverHttps('https://cloudflare-dns.com/dns-query')\n * })\n *\n * const ma = multiaddr('/dnsaddr/bootstrap.libp2p.io')\n * const resolved = await ma.resolve({\n *  dns: resolver\n * })\n *\n * console.info(resolved)\n * // [Multiaddr('/ip4/147.75...'), Multiaddr('/ip4/147.75...'), Multiaddr('/ip4/147.75...')...]\n * ```\n */\nimport { Multiaddr as MultiaddrClass, symbol } from './multiaddr.js';\nimport { getProtocol } from './protocols-table.js';\n/**\n * All configured {@link Resolver}s\n */\nexport const resolvers = new Map();\nexport { MultiaddrFilter } from './filter/multiaddr-filter.js';\n/**\n * Creates a Multiaddr from a node-friendly address object\n *\n * @example\n * ```js\n * import { fromNodeAddress } from '@multiformats/multiaddr'\n *\n * fromNodeAddress({address: '127.0.0.1', port: '4001'}, 'tcp')\n * // Multiaddr(/ip4/127.0.0.1/tcp/4001)\n * ```\n */\nexport function fromNodeAddress(addr, transport) {\n    if (addr == null) {\n        throw new Error('requires node address object');\n    }\n    if (transport == null) {\n        throw new Error('requires transport protocol');\n    }\n    let ip;\n    let host = addr.address;\n    switch (addr.family) {\n        case 4:\n            ip = 'ip4';\n            break;\n        case 6:\n            ip = 'ip6';\n            if (host.includes('%')) {\n                const parts = host.split('%');\n                if (parts.length !== 2) {\n                    throw Error('Multiple ip6 zones in multiaddr');\n                }\n                host = parts[0];\n                const zone = parts[1];\n                ip = `/ip6zone/${zone}/ip6`;\n            }\n            break;\n        default:\n            throw Error('Invalid addr family, should be 4 or 6.');\n    }\n    return new MultiaddrClass('/' + [ip, host, transport, addr.port].join('/'));\n}\n/**\n * Returns if something is a {@link Multiaddr} that is a resolvable name\n *\n * @example\n *\n * ```js\n * import { isName, multiaddr } from '@multiformats/multiaddr'\n *\n * isName(multiaddr('/ip4/127.0.0.1'))\n * // false\n * isName(multiaddr('/dns/ipfs.io'))\n * // true\n * ```\n */\nexport function isName(addr) {\n    if (!isMultiaddr(addr)) {\n        return false;\n    }\n    // if a part of the multiaddr is resolvable, then return true\n    return addr.protos().some((proto) => proto.resolvable);\n}\n/**\n * Check if object is a {@link Multiaddr} instance\n *\n * @example\n *\n * ```js\n * import { isMultiaddr, multiaddr } from '@multiformats/multiaddr'\n *\n * isMultiaddr(5)\n * // false\n * isMultiaddr(multiaddr('/ip4/127.0.0.1'))\n * // true\n * ```\n */\nexport function isMultiaddr(value) {\n    return Boolean(value?.[symbol]);\n}\n/**\n * A function that takes a {@link MultiaddrInput} and returns a {@link Multiaddr}\n *\n * @example\n * ```js\n * import { multiaddr } from '@libp2p/multiaddr'\n *\n * multiaddr('/ip4/127.0.0.1/tcp/4001')\n * // Multiaddr(/ip4/127.0.0.1/tcp/4001)\n * ```\n *\n * @param {MultiaddrInput} [addr] - If String or Uint8Array, needs to adhere to the address format of a [multiaddr](https://github.com/multiformats/multiaddr#string-format)\n */\nexport function multiaddr(addr) {\n    return new MultiaddrClass(addr);\n}\nexport { getProtocol as protocols };\n//# sourceMappingURL=index.js.map"],"names":["Multiaddr","MultiaddrClass","symbol","getProtocol","resolvers","Map","MultiaddrFilter","fromNodeAddress","addr","transport","Error","ip","host","address","family","includes","parts","split","length","zone","port","join","isName","isMultiaddr","protos","some","proto","resolvable","value","Boolean","multiaddr","protocols"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/@multiformats/multiaddr/dist/src/index.js\n");
/***/ }),
/***/ "(ssr)/./node_modules/@multiformats/multiaddr/dist/src/ip.js":
/*!*************************************************************!*\
!*** ./node_modules/@multiformats/multiaddr/dist/src/ip.js ***!
\*************************************************************/
/***/ ((__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 */ isIP: () => (/* reexport safe */ _chainsafe_is_ip__WEBPACK_IMPORTED_MODULE_0__.isIP),\n/* harmony export */ isV4: () => (/* binding */ isV4),\n/* harmony export */ isV6: () => (/* binding */ isV6),\n/* harmony export */ toBytes: () => (/* binding */ toBytes),\n/* harmony export */ toString: () => (/* binding */ toString)\n/* harmony export */ });\n/* harmony import */ var _chainsafe_is_ip__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @chainsafe/is-ip */ \"(ssr)/./node_modules/@chainsafe/is-ip/lib/is-ip.node.js\");\n/* harmony import */ var uint8arrays_to_string__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! uint8arrays/to-string */ \"(ssr)/./node_modules/uint8arrays/dist/src/to-string.node.js\");\n\n\n\nconst isV4 = _chainsafe_is_ip__WEBPACK_IMPORTED_MODULE_0__.isIPv4;\nconst isV6 = _chainsafe_is_ip__WEBPACK_IMPORTED_MODULE_0__.isIPv6;\n// Copied from https://github.com/indutny/node-ip/blob/master/lib/ip.js#L7\n// but with buf/offset args removed because we don't use them\nconst toBytes = function(ip) {\n let offset = 0;\n ip = ip.toString().trim();\n if (isV4(ip)) {\n const bytes = new Uint8Array(offset + 4);\n ip.split(/\\./g).forEach((byte)=>{\n bytes[offset++] = parseInt(byte, 10) & 0xff;\n });\n return bytes;\n }\n if (isV6(ip)) {\n const sections = ip.split(\":\", 8);\n let i;\n for(i = 0; i < sections.length; i++){\n const isv4 = isV4(sections[i]);\n let v4Buffer;\n if (isv4) {\n v4Buffer = toBytes(sections[i]);\n sections[i] = (0,uint8arrays_to_string__WEBPACK_IMPORTED_MODULE_1__.toString)(v4Buffer.slice(0, 2), \"base16\");\n }\n if (v4Buffer != null && ++i < 8) {\n sections.splice(i, 0, (0,uint8arrays_to_string__WEBPACK_IMPORTED_MODULE_1__.toString)(v4Buffer.slice(2, 4), \"base16\"));\n }\n }\n if (sections[0] === \"\") {\n while(sections.length < 8)sections.unshift(\"0\");\n } else if (sections[sections.length - 1] === \"\") {\n while(sections.length < 8)sections.push(\"0\");\n } else if (sections.length < 8) {\n for(i = 0; i < sections.length && sections[i] !== \"\"; i++);\n const argv = [\n i,\n 1\n ];\n for(i = 9 - sections.length; i > 0; i--){\n argv.push(\"0\");\n }\n sections.splice.apply(sections, argv);\n }\n const bytes = new Uint8Array(offset + 16);\n for(i = 0; i < sections.length; i++){\n const word = parseInt(sections[i], 16);\n bytes[offset++] = word >> 8 & 0xff;\n bytes[offset++] = word & 0xff;\n }\n return bytes;\n }\n throw new Error(\"invalid ip address\");\n};\n// Copied from https://github.com/indutny/node-ip/blob/master/lib/ip.js#L63\nconst toString = function(buf, offset = 0, length) {\n offset = ~~offset;\n length = length ?? buf.length - offset;\n const view = new DataView(buf.buffer);\n if (length === 4) {\n const result = [];\n // IPv4\n for(let i = 0; i < length; i++){\n result.push(buf[offset + i]);\n }\n return result.join(\".\");\n }\n if (length === 16) {\n const result = [];\n // IPv6\n for(let i = 0; i < length; i += 2){\n result.push(view.getUint16(offset + i).toString(16));\n }\n return result.join(\":\").replace(/(^|:)0(:0)*:0(:|$)/, \"$1::$3\").replace(/:{3,4}/, \"::\");\n }\n return \"\";\n}; //# sourceMappingURL=ip.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvQG11bHRpZm9ybWF0cy9tdWx0aWFkZHIvZGlzdC9zcmMvaXAuanMiLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7OztBQUFrRDtBQUNxQjtBQUMvQjtBQUNqQyxNQUFNSyxPQUFPTCxvREFBTUEsQ0FBQztBQUNwQixNQUFNTSxPQUFPTCxvREFBTUEsQ0FBQztBQUMzQiwwRUFBMEU7QUFDMUUsNkRBQTZEO0FBQ3RELE1BQU1NLFVBQVUsU0FBVUMsRUFBRTtJQUMvQixJQUFJQyxTQUFTO0lBQ2JELEtBQUtBLEdBQUdOLFFBQVEsR0FBR1EsSUFBSTtJQUN2QixJQUFJTCxLQUFLRyxLQUFLO1FBQ1YsTUFBTUcsUUFBUSxJQUFJQyxXQUFXSCxTQUFTO1FBQ3RDRCxHQUFHSyxLQUFLLENBQUMsT0FBT0MsT0FBTyxDQUFDLENBQUNDO1lBQ3JCSixLQUFLLENBQUNGLFNBQVMsR0FBR08sU0FBU0QsTUFBTSxNQUFNO1FBQzNDO1FBQ0EsT0FBT0o7SUFDWDtJQUNBLElBQUlMLEtBQUtFLEtBQUs7UUFDVixNQUFNUyxXQUFXVCxHQUFHSyxLQUFLLENBQUMsS0FBSztRQUMvQixJQUFJSztRQUNKLElBQUtBLElBQUksR0FBR0EsSUFBSUQsU0FBU0UsTUFBTSxFQUFFRCxJQUFLO1lBQ2xDLE1BQU1FLE9BQU9mLEtBQUtZLFFBQVEsQ0FBQ0MsRUFBRTtZQUM3QixJQUFJRztZQUNKLElBQUlELE1BQU07Z0JBQ05DLFdBQVdkLFFBQVFVLFFBQVEsQ0FBQ0MsRUFBRTtnQkFDOUJELFFBQVEsQ0FBQ0MsRUFBRSxHQUFHZiwrREFBa0JBLENBQUNrQixTQUFTQyxLQUFLLENBQUMsR0FBRyxJQUFJO1lBQzNEO1lBQ0EsSUFBSUQsWUFBWSxRQUFRLEVBQUVILElBQUksR0FBRztnQkFDN0JELFNBQVNNLE1BQU0sQ0FBQ0wsR0FBRyxHQUFHZiwrREFBa0JBLENBQUNrQixTQUFTQyxLQUFLLENBQUMsR0FBRyxJQUFJO1lBQ25FO1FBQ0o7UUFDQSxJQUFJTCxRQUFRLENBQUMsRUFBRSxLQUFLLElBQUk7WUFDcEIsTUFBT0EsU0FBU0UsTUFBTSxHQUFHLEVBQ3JCRixTQUFTTyxPQUFPLENBQUM7UUFDekIsT0FDSyxJQUFJUCxRQUFRLENBQUNBLFNBQVNFLE1BQU0sR0FBRyxFQUFFLEtBQUssSUFBSTtZQUMzQyxNQUFPRixTQUFTRSxNQUFNLEdBQUcsRUFDckJGLFNBQVNRLElBQUksQ0FBQztRQUN0QixPQUNLLElBQUlSLFNBQVNFLE1BQU0sR0FBRyxHQUFHO1lBQzFCLElBQUtELElBQUksR0FBR0EsSUFBSUQsU0FBU0UsTUFBTSxJQUFJRixRQUFRLENBQUNDLEVBQUUsS0FBSyxJQUFJQTtZQUV2RCxNQUFNUSxPQUFPO2dCQUFDUjtnQkFBRzthQUFFO1lBQ25CLElBQUtBLElBQUksSUFBSUQsU0FBU0UsTUFBTSxFQUFFRCxJQUFJLEdBQUdBLElBQUs7Z0JBQ3RDUSxLQUFLRCxJQUFJLENBQUM7WUFDZDtZQUNBUixTQUFTTSxNQUFNLENBQUNJLEtBQUssQ0FBQ1YsVUFBVVM7UUFDcEM7UUFDQSxNQUFNZixRQUFRLElBQUlDLFdBQVdILFNBQVM7UUFDdEMsSUFBS1MsSUFBSSxHQUFHQSxJQUFJRCxTQUFTRSxNQUFNLEVBQUVELElBQUs7WUFDbEMsTUFBTVUsT0FBT1osU0FBU0MsUUFBUSxDQUFDQyxFQUFFLEVBQUU7WUFDbkNQLEtBQUssQ0FBQ0YsU0FBUyxHQUFHLFFBQVMsSUFBSztZQUNoQ0UsS0FBSyxDQUFDRixTQUFTLEdBQUdtQixPQUFPO1FBQzdCO1FBQ0EsT0FBT2pCO0lBQ1g7SUFDQSxNQUFNLElBQUlrQixNQUFNO0FBQ3BCLEVBQUU7QUFDRiwyRUFBMkU7QUFDcEUsTUFBTTNCLFdBQVcsU0FBVTRCLEdBQUcsRUFBRXJCLFNBQVMsQ0FBQyxFQUFFVSxNQUFNO0lBQ3JEVixTQUFTLENBQUMsQ0FBQ0E7SUFDWFUsU0FBU0EsVUFBV1csSUFBSVgsTUFBTSxHQUFHVjtJQUNqQyxNQUFNc0IsT0FBTyxJQUFJQyxTQUFTRixJQUFJRyxNQUFNO0lBQ3BDLElBQUlkLFdBQVcsR0FBRztRQUNkLE1BQU1lLFNBQVMsRUFBRTtRQUNqQixPQUFPO1FBQ1AsSUFBSyxJQUFJaEIsSUFBSSxHQUFHQSxJQUFJQyxRQUFRRCxJQUFLO1lBQzdCZ0IsT0FBT1QsSUFBSSxDQUFDSyxHQUFHLENBQUNyQixTQUFTUyxFQUFFO1FBQy9CO1FBQ0EsT0FBT2dCLE9BQU9DLElBQUksQ0FBQztJQUN2QjtJQUNBLElBQUloQixXQUFXLElBQUk7UUFDZixNQUFNZSxTQUFTLEVBQUU7UUFDakIsT0FBTztRQUNQLElBQUssSUFBSWhCLElBQUksR0FBR0EsSUFBSUMsUUFBUUQsS0FBSyxFQUFHO1lBQ2hDZ0IsT0FBT1QsSUFBSSxDQUFDTSxLQUFLSyxTQUFTLENBQUMzQixTQUFTUyxHQUFHaEIsUUFBUSxDQUFDO1FBQ3BEO1FBQ0EsT0FBT2dDLE9BQU9DLElBQUksQ0FBQyxLQUNkRSxPQUFPLENBQUMsc0JBQXNCLFVBQzlCQSxPQUFPLENBQUMsVUFBVTtJQUMzQjtJQUNBLE9BQU87QUFDWCxFQUFFLENBQ0YsOEJBQThCIiwic291cmNlcyI6WyJ3ZWJwYWNrOi8vZmx1c2gtbm90ZXMvLi9ub2RlX21vZHVsZXMvQG11bHRpZm9ybWF0cy9tdWx0aWFkZHIvZGlzdC9zcmMvaXAuanM/MGYyMSJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBpc0lQdjQsIGlzSVB2NiB9IGZyb20gJ0BjaGFpbnNhZmUvaXMtaXAnO1xuaW1wb3J0IHsgdG9TdHJpbmcgYXMgdWludDhBcnJheVRvU3RyaW5nIH0gZnJvbSAndWludDhhcnJheXMvdG8tc3RyaW5nJztcbmV4cG9ydCB7IGlzSVAgfSBmcm9tICdAY2hhaW5zYWZlL2lzLWlwJztcbmV4cG9ydCBjb25zdCBpc1Y0ID0gaXNJUHY0O1xuZXhwb3J0IGNvbnN0IGlzVjYgPSBpc0lQdjY7XG4vLyBDb3BpZWQgZnJvbSBodHRwczovL2dpdGh1Yi5jb20vaW5kdXRueS9ub2RlLWlwL2Jsb2IvbWFzdGVyL2xpYi9pcC5qcyNMN1xuLy8gYnV0IHdpdGggYnVmL29mZnNldCBhcmdzIHJlbW92ZWQgYmVjYXVzZSB3ZSBkb24ndCB1c2UgdGhlbVxuZXhwb3J0IGNvbnN0IHRvQnl0ZXMgPSBmdW5jdGlvbiAoaXApIHtcbiAgICBsZXQgb2Zmc2V0ID0gMDtcbiAgICBpcCA9IGlwLnRvU3RyaW5nKCkudHJpbSgpO1xuICAgIGlmIChpc1Y0KGlwKSkge1xuICAgICAgICBjb25zdCBieXRlcyA9IG5ldyBVaW50OEFycmF5KG9mZnNldCArIDQpO1xuICAgICAgICBpcC5zcGxpdCgvXFwuL2cpLmZvckVhY2goKGJ5dGUpID0+IHtcbiAgICAgICAgICAgIGJ5dGVzW29mZnNldCsrXSA9IHBhcnNlSW50KGJ5dGUsIDEwKSAmIDB4ZmY7XG4gICAgICAgIH0pO1xuICAgICAgICByZXR1cm4gYnl0ZXM7XG4gICAgfVxuICAgIGlmIChpc1Y2KGlwKSkge1xuICAgICAgICBjb25zdCBzZWN0aW9ucyA9IGlwLnNwbGl0KCc6JywgOCk7XG4gICAgICAgIGxldCBpO1xuICAgICAgICBmb3IgKGkgPSAwOyBpIDwgc2VjdGlvbnMubGVuZ3RoOyBpKyspIHtcbiAgICAgICAgICAgIGNvbnN0IGlzdjQgPSBpc1Y0KHNlY3Rpb25zW2ldKTtcbiAgICAgICAgICAgIGxldCB2NEJ1ZmZlcjtcbiAgICAgICAgICAgIGlmIChpc3Y0KSB7XG4gICAgICAgICAgICAgICAgdjRCdWZmZXIgPSB0b0J5dGVzKHNlY3Rpb25zW2ldKTtcbiAgICAgICAgICAgICAgICBzZWN0aW9uc1tpXSA9IHVpbnQ4QXJyYXlUb1N0cmluZyh2NEJ1ZmZlci5zbGljZSgwLCAyKSwgJ2Jhc2UxNicpO1xuICAgICAgICAgICAgfVxuICAgICAgICAgICAgaWYgKHY0QnVmZmVyICE9IG51bGwgJiYgKytpIDwgOCkge1xuICAgICAgICAgICAgICAgIHNlY3Rpb25zLnNwbGljZShpLCAwLCB1aW50OEFycmF5VG9TdHJpbmcodjRCdWZmZXIuc2xpY2UoMiwgNCksICdiYXNlMTYnKSk7XG4gICAgICAgICAgICB9XG4gICAgICAgIH1cbiAgICAgICAgaWYgKHNlY3Rpb25zWzBdID09PSAnJykge1xuICAgICAgICAgICAgd2hpbGUgKHNlY3Rpb25zLmxlbmd0aCA8IDgpXG4gICAgICAgICAgICAgICAgc2VjdGlvbnMudW5zaGlmdCgnMCcpO1xuICAgICAgICB9XG4gICAgICAgIGVsc2UgaWYgKHNlY3Rpb25zW3NlY3Rpb25zLmxlbmd0aCAtIDFdID09PSAnJykge1xuICAgICAgICAgICAgd2hpbGUgKHNlY3Rpb25zLmxlbmd0aCA8IDgpXG4gICAgICAgICAgICAgICAgc2VjdGlvbnMucHVzaCgnMCcpO1xuICAgICAgICB9XG4gICAgICAgIGVsc2UgaWYgKHNlY3Rpb25zLmxlbmd0aCA8IDgpIHtcbiAgICAgICAgICAgIGZvciAoaSA9IDA7IGkgPCBzZWN0aW9ucy5sZW5ndGggJiYgc2VjdGlvbnNbaV0gIT09ICcnOyBpKyspXG4gICAgICAgICAgICAgICAgO1xuICAgICAgICAgICAgY29uc3QgYXJndiA9IFtpLCAxXTtcbiAgICAgICAgICAgIGZvciAoaSA9IDkgLSBzZWN0aW9ucy5sZW5ndGg7IGkgPiAwOyBpLS0pIHtcbiAgICAgICAgICAgICAgICBhcmd2LnB1c2goJzAnKTtcbiAgICAgICAgICAgIH1cbiAgICAgICAgICAgIHNlY3Rpb25zLnNwbGljZS5hcHBseShzZWN0aW9ucywgYXJndik7XG4gICAgICAgIH1cbiAgICAgICAgY29uc3QgYnl0ZXMgPSBuZXcgVWludDhBcnJheShvZmZzZXQgKyAxNik7XG4gICAgICAgIGZvciAoaSA9IDA7IGkgPCBzZWN0aW9ucy5sZW5ndGg7IGkrKykge1xuICAgICAgICAgICAgY29uc3Qgd29yZCA9IHBhcnNlSW50KHNlY3Rpb25zW2ldLCAxNik7XG4gICAgICAgICAgICBieXRlc1tvZmZzZXQrK10gPSAod29yZCA+PiA4KSAmIDB4ZmY7XG4gICAgICAgICAgICBieXRlc1tvZmZzZXQrK10gPSB3b3JkICYgMHhmZjtcbiAgICAgICAgfVxuICAgICAgICByZXR1cm4gYnl0ZXM7XG4gICAgfVxuICAgIHRocm93IG5ldyBFcnJvcignaW52YWxpZCBpcCBhZGRyZXNzJyk7XG59O1xuLy8gQ29waWVkIGZyb20gaHR0cHM6Ly9naXRodWIuY29tL2luZHV0bnkvbm9kZS1pcC9ibG9iL21hc3Rlci9saWIvaXAuanMjTDYzXG5leHBvcnQgY29uc3QgdG9TdHJpbmcgPSBmdW5jdGlvbiAoYnVmLCBvZmZzZXQgPSAwLCBsZW5ndGgpIHtcbiAgICBvZmZzZXQgPSB+fm9mZnNldDtcbiAgICBsZW5ndGggPSBsZW5ndGggPz8gKGJ1Zi5sZW5ndGggLSBvZmZzZXQpO1xuICAgIGNvbnN0IHZpZXcgPSBuZXcgRGF0YVZpZXcoYnVmLmJ1ZmZlcik7XG4gICAgaWYgKGxlbmd0aCA9PT0gNCkge1xuICAgICAgICBjb25zdCByZXN1bHQgPSBbXTtcbiAgICAgICAgLy8gSVB2NFxuICAgICAgICBmb3IgKGxldCBpID0gMDsgaSA8IGxlbmd0aDsgaSsrKSB7XG4gICAgICAgICAgICByZXN1bHQucHVzaChidWZbb2Zmc2V0ICsgaV0pO1xuICAgICAgICB9XG4gICAgICAgIHJldHVybiByZXN1bHQuam9pbignLicpO1xuICAgIH1cbiAgICBpZiAobGVuZ3RoID09PSAxNikge1xuICAgICAgICBjb25zdCByZXN1bHQgPSBbXTtcbiAgICAgICAgLy8gSVB2NlxuICAgICAgICBmb3IgKGxldCBpID0gMDsgaSA8IGxlbmd0aDsgaSArPSAyKSB7XG4gICAgICAgICAgICByZXN1bHQucHVzaCh2aWV3LmdldFVpbnQxNihvZmZzZXQgKyBpKS50b1N0cmluZygxNikpO1xuICAgICAgICB9XG4gICAgICAgIHJldHVybiByZXN1bHQuam9pbignOicpXG4gICAgICAgICAgICAucmVwbGFjZSgvKF58OikwKDowKSo6MCg6fCQpLywgJyQxOjokMycpXG4gICAgICAgICAgICAucmVwbGFjZSgvOnszLDR9LywgJzo6Jyk7XG4gICAgfVxuICAgIHJldHVybiAnJztcbn07XG4vLyMgc291cmNlTWFwcGluZ1VSTD1pcC5qcy5tYXAiXSwibmFtZXMiOlsiaXNJUHY0IiwiaXNJUHY2IiwidG9TdHJpbmciLCJ1aW50OEFycmF5VG9TdHJpbmciLCJpc0lQIiwiaXNWNCIsImlzVjYiLCJ0b0J5dGVzIiwiaXAiLCJvZmZzZXQiLCJ0cmltIiwiYnl0ZXMiLCJVaW50OEFycmF5Iiwic3BsaXQiLCJmb3JFYWNoIiwiYnl0ZSIsInBhcnNlSW50Iiwic2VjdGlvbnMiLCJpIiwibGVuZ3RoIiwiaXN2NCIsInY0QnVmZmVyIiwic2xpY2UiLCJzcGxpY2UiLCJ1bnNoaWZ0IiwicHVzaCIsImFyZ3YiLCJhcHBseSIsIndvcmQiLCJFcnJvciIsImJ1ZiIsInZpZXciLCJEYXRhVmlldyIsImJ1ZmZlciIsInJlc3VsdCIsImpvaW4iLCJnZXRVaW50MTYiLCJyZXBsYWNlIl0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/@multiformats/multiaddr/dist/src/ip.js\n");
/***/ }),
/***/ "(ssr)/./node_modules/@multiformats/multiaddr/dist/src/multiaddr.js":
/*!********************************************************************!*\
!*** ./node_modules/@multiformats/multiaddr/dist/src/multiaddr.js ***!
\********************************************************************/
/***/ ((__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 */ Multiaddr: () => (/* binding */ Multiaddr),\n/* harmony export */ symbol: () => (/* binding */ symbol)\n/* harmony export */ });\n/* harmony import */ var _libp2p_interface__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! @libp2p/interface */ \"(ssr)/./node_modules/@libp2p/interface/dist/src/errors.js\");\n/* harmony import */ var multiformats_bases_base58__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! multiformats/bases/base58 */ \"(ssr)/./node_modules/multiformats/dist/src/bases/base58.js\");\n/* harmony import */ var multiformats_cid__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! multiformats/cid */ \"(ssr)/./node_modules/multiformats/dist/src/cid.js\");\n/* harmony import */ var uint8arrays_equals__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! uint8arrays/equals */ \"(ssr)/./node_modules/uint8arrays/dist/src/equals.js\");\n/* harmony import */ var uint8arrays_to_string__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! uint8arrays/to-string */ \"(ssr)/./node_modules/uint8arrays/dist/src/to-string.node.js\");\n/* harmony import */ var _codec_js__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./codec.js */ \"(ssr)/./node_modules/@multiformats/multiaddr/dist/src/codec.js\");\n/* harmony import */ var _protocols_table_js__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./protocols-table.js */ \"(ssr)/./node_modules/@multiformats/multiaddr/dist/src/protocols-table.js\");\n/* harmony import */ var _index_js__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ./index.js */ \"(ssr)/./node_modules/@multiformats/multiaddr/dist/src/index.js\");\n/**\n * @packageDocumentation\n *\n * An implementation of a Multiaddr in JavaScript\n *\n * @example\n *\n * ```js\n * import { multiaddr } from '@multiformats/multiaddr'\n *\n * const ma = multiaddr('/ip4/127.0.0.1/tcp/1234')\n * ```\n */ \n\n\n\n\n\n\n\nconst inspect = Symbol.for(\"nodejs.util.inspect.custom\");\nconst symbol = Symbol.for(\"@multiformats/js-multiaddr/multiaddr\");\nconst DNS_CODES = [\n (0,_protocols_table_js__WEBPACK_IMPORTED_MODULE_5__.getProtocol)(\"dns\").code,\n (0,_protocols_table_js__WEBPACK_IMPORTED_MODULE_5__.getProtocol)(\"dns4\").code,\n (0,_protocols_table_js__WEBPACK_IMPORTED_MODULE_5__.getProtocol)(\"dns6\").code,\n (0,_protocols_table_js__WEBPACK_IMPORTED_MODULE_5__.getProtocol)(\"dnsaddr\").code\n];\n/**\n * Creates a {@link Multiaddr} from a {@link MultiaddrInput}\n */ class Multiaddr {\n #string;\n #tuples;\n #stringTuples;\n #path;\n constructor(addr){\n this[symbol] = true;\n // default\n if (addr == null) {\n addr = \"\";\n }\n let parts;\n if (addr instanceof Uint8Array) {\n parts = (0,_codec_js__WEBPACK_IMPORTED_MODULE_4__.bytesToMultiaddrParts)(addr);\n } else if (typeof addr === \"string\") {\n if (addr.length > 0 && addr.charAt(0) !== \"/\") {\n throw new Error(`multiaddr \"${addr}\" must start with a \"/\"`);\n }\n parts = (0,_codec_js__WEBPACK_IMPORTED_MODULE_4__.stringToMultiaddrParts)(addr);\n } else if ((0,_index_js__WEBPACK_IMPORTED_MODULE_6__.isMultiaddr)(addr)) {\n parts = (0,_codec_js__WEBPACK_IMPORTED_MODULE_4__.bytesToMultiaddrParts)(addr.bytes);\n } else {\n throw new Error(\"addr must be a string, Buffer, or another Multiaddr\");\n }\n this.bytes = parts.bytes;\n this.#string = parts.string;\n this.#tuples = parts.tuples;\n this.#stringTuples = parts.stringTuples;\n this.#path = parts.path;\n }\n toString() {\n return this.#string;\n }\n toJSON() {\n return this.toString();\n }\n toOptions() {\n let family;\n let transport;\n let host;\n let port;\n let zone = \"\";\n const tcp = (0,_protocols_table_js__WEBPACK_IMPORTED_MODULE_5__.getProtocol)(\"tcp\");\n const udp = (0,_protocols_table_js__WEBPACK_IMPORTED_MODULE_5__.getProtocol)(\"udp\");\n const ip4 = (0,_protocols_table_js__WEBPACK_IMPORTED_MODULE_5__.getProtocol)(\"ip4\");\n const ip6 = (0,_protocols_table_js__WEBPACK_IMPORTED_MODULE_5__.getProtocol)(\"ip6\");\n const dns6 = (0,_protocols_table_js__WEBPACK_IMPORTED_MODULE_5__.getProtocol)(\"dns6\");\n const ip6zone = (0,_protocols_table_js__WEBPACK_IMPORTED_MODULE_5__.getProtocol)(\"ip6zone\");\n for (const [code, value] of this.stringTuples()){\n if (code === ip6zone.code) {\n zone = `%${value ?? \"\"}`;\n }\n // default to https when protocol & port are omitted from DNS addrs\n if (DNS_CODES.includes(code)) {\n transport = tcp.name;\n port = 443;\n host = `${value ?? \"\"}${zone}`;\n family = code === dns6.code ? 6 : 4;\n }\n if (code === tcp.code || code === udp.code) {\n transport = (0,_protocols_table_js__WEBPACK_IMPORTED_MODULE_5__.getProtocol)(code).name;\n port = parseInt(value ?? \"\");\n }\n if (code === ip4.code || code === ip6.code) {\n transport = (0,_protocols_table_js__WEBPACK_IMPORTED_MODULE_5__.getProtocol)(code).name;\n host = `${value ?? \"\"}${zone}`;\n family = code === ip6.code ? 6 : 4;\n }\n }\n if (family == null || transport == null || host == null || port == null) {\n throw new Error('multiaddr must have a valid format: \"/{ip4, ip6, dns4, dns6, dnsaddr}/{address}/{tcp, udp}/{port}\".');\n }\n const opts = {\n family,\n host,\n transport,\n port\n };\n return opts;\n }\n protos() {\n return this.#tuples.map(([code])=>Object.assign({}, (0,_protocols_table_js__WEBPACK_IMPORTED_MODULE_5__.getProtocol)(code)));\n }\n protoCodes() {\n return this.#tuples.map(([code])=>code);\n }\n protoNames() {\n return this.#tuples.map(([code])=>(0,_protocols_table_js__WEBPACK_IMPORTED_MODULE_5__.getProtocol)(code).name);\n }\n tuples() {\n return this.#tuples;\n }\n stringTuples() {\n return this.#stringTuples;\n }\n encapsulate(addr) {\n addr = new Multiaddr(addr);\n return new Multiaddr(this.toString() + addr.toString());\n }\n decapsulate(addr) {\n const addrString = addr.toString();\n const s = this.toString();\n const i = s.lastIndexOf(addrString);\n if (i < 0) {\n throw new Error(`Address ${this.toString()} does not contain subaddress: ${addr.toString()}`);\n }\n return new Multiaddr(s.slice(0, i));\n }\n decapsulateCode(code) {\n const tuples = this.tuples();\n for(let i = tuples.length - 1; i >= 0; i--){\n if (tuples[i][0] === code) {\n return new Multiaddr((0,_codec_js__WEBPACK_IMPORTED_MODULE_4__.tuplesToBytes)(tuples.slice(0, i)));\n }\n }\n return this;\n }\n getPeerId() {\n try {\n let tuples = [];\n this.stringTuples().forEach(([code, name])=>{\n if (code === _protocols_table_js__WEBPACK_IMPORTED_MODULE_5__.names.p2p.code) {\n tuples.push([\n code,\n name\n ]);\n }\n // if this is a p2p-circuit address, return the target peer id if present\n // not the peer id of the relay\n if (code === _protocols_table_js__WEBPACK_IMPORTED_MODULE_5__.names[\"p2p-circuit\"].code) {\n tuples = [];\n }\n });\n // Get the last ipfs tuple ['p2p', 'peerid string']\n const tuple = tuples.pop();\n if (tuple?.[1] != null) {\n const peerIdStr = tuple[1];\n // peer id is base58btc encoded string but not multibase encoded so add the `z`\n // prefix so we can validate that it is correctly encoded\n if (peerIdStr[0] === \"Q\" || peerIdStr[0] === \"1\") {\n return (0,uint8arrays_to_string__WEBPACK_IMPORTED_MODULE_3__.toString)(multiformats_bases_base58__WEBPACK_IMPORTED_MODULE_0__.base58btc.decode(`z${peerIdStr}`), \"base58btc\");\n }\n // try to parse peer id as CID\n return (0,uint8arrays_to_string__WEBPACK_IMPORTED_MODULE_3__.toString)(multiformats_cid__WEBPACK_IMPORTED_MODULE_1__.CID.parse(peerIdStr).multihash.bytes, \"base58btc\");\n }\n return null;\n } catch (e) {\n return null;\n }\n }\n getPath() {\n return this.#path;\n }\n equals(addr) {\n return (0,uint8arrays_equals__WEBPACK_IMPORTED_MODULE_2__.equals)(this.bytes, addr.bytes);\n }\n async resolve(options) {\n const resolvableProto = this.protos().find((p)=>p.resolvable);\n // Multiaddr is not resolvable?\n if (resolvableProto == null) {\n return [\n this\n ];\n }\n const resolver = _index_js__WEBPACK_IMPORTED_MODULE_6__.resolvers.get(resolvableProto.name);\n if (resolver == null) {\n throw new _libp2p_interface__WEBPACK_IMPORTED_MODULE_7__.CodeError(`no available resolver for ${resolvableProto.name}`, \"ERR_NO_AVAILABLE_RESOLVER\");\n }\n const result = await resolver(this, options);\n return result.map((str)=>(0,_index_js__WEBPACK_IMPORTED_MODULE_6__.multiaddr)(str));\n }\n nodeAddress() {\n const options = this.toOptions();\n if (options.transport !== \"tcp\" && options.transport !== \"udp\") {\n throw new Error(`multiaddr must have a valid format - no protocol with name: \"${options.transport}\". Must have a valid transport protocol: \"{tcp, udp}\"`);\n }\n return {\n family: options.family,\n address: options.host,\n port: options.port\n };\n }\n isThinWaistAddress(addr) {\n const protos = (addr ?? this).protos();\n if (protos.length !== 2) {\n return false;\n }\n if (protos[0].code !== 4 && protos[0].code !== 41) {\n return false;\n }\n if (protos[1].code !== 6 && protos[1].code !== 273) {\n return false;\n }\n return true;\n }\n /**\n * Returns Multiaddr as a human-readable string\n * https://nodejs.org/api/util.html#utilinspectcustom\n *\n * @example\n * ```js\n * import { multiaddr } from '@multiformats/multiaddr'\n *\n * console.info(multiaddr('/ip4/127.0.0.1/tcp/4001'))\n * // 'Multiaddr(/ip4/127.0.0.1/tcp/4001)'\n * ```\n */ [inspect]() {\n return `Multiaddr(${this.#string})`;\n }\n} //# sourceMappingURL=multiaddr.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"(ssr)/./node_modules/@multiformats/multiaddr/dist/src/multiaddr.js","mappings":";;;;;;;;;;;;;AAAA;;;;;;;;;;;;CAYC,GAC6C;AACQ;AACf;AACyB;AACO;AACmB;AAChC;AACK;AAC/D,MAAMe,UAAUC,OAAOC,GAAG,CAAC;AACpB,MAAMC,SAASF,OAAOC,GAAG,CAAC,wCAAwC;AACzE,MAAME,YAAY;IACdT,gEAAWA,CAAC,OAAOU,IAAI;IACvBV,gEAAWA,CAAC,QAAQU,IAAI;IACxBV,gEAAWA,CAAC,QAAQU,IAAI;IACxBV,gEAAWA,CAAC,WAAWU,IAAI;CAC9B;AACD;;CAEC,GACM,MAAMC;IAET,CAACC,MAAM,CAAC;IACR,CAACC,MAAM,CAAC;IACR,CAACC,YAAY,CAAC;IACd,CAACC,IAAI,CAAC;IAENC,YAAYC,IAAI,CAAE;YADlB,CAACT,OAAO,GAAG;QAEP,UAAU;QACV,IAAIS,QAAQ,MAAM;YACdA,OAAO;QACX;QACA,IAAIC;QACJ,IAAID,gBAAgBE,YAAY;YAC5BD,QAAQrB,gEAAqBA,CAACoB;QAClC,OACK,IAAI,OAAOA,SAAS,UAAU;YAC/B,IAAIA,KAAKG,MAAM,GAAG,KAAKH,KAAKI,MAAM,CAAC,OAAO,KAAK;gBAC3C,MAAM,IAAIC,MAAM,CAAC,WAAW,EAAEL,KAAK,uBAAuB,CAAC;YAC/D;YACAC,QAAQpB,iEAAsBA,CAACmB;QACnC,OACK,IAAIf,sDAAWA,CAACe,OAAO;YACxBC,QAAQrB,gEAAqBA,CAACoB,KAAKM,KAAK;QAC5C,OACK;YACD,MAAM,IAAID,MAAM;QACpB;QACA,IAAI,CAACC,KAAK,GAAGL,MAAMK,KAAK;QACxB,IAAI,CAAC,CAACX,MAAM,GAAGM,MAAMN,MAAM;QAC3B,IAAI,CAAC,CAACC,MAAM,GAAGK,MAAML,MAAM;QAC3B,IAAI,CAAC,CAACC,YAAY,GAAGI,MAAMJ,YAAY;QACvC,IAAI,CAAC,CAACC,IAAI,GAAGG,MAAMH,IAAI;IAC3B;IACApB,WAAW;QACP,OAAO,IAAI,CAAC,CAACiB,MAAM;IACvB;IACAY,SAAS;QACL,OAAO,IAAI,CAAC7B,QAAQ;IACxB;IACA8B,YAAY;QACR,IAAIC;QACJ,IAAIC;QACJ,IAAIC;QACJ,IAAIC;QACJ,IAAIC,OAAO;QACX,MAAMC,MAAM/B,gEAAWA,CAAC;QACxB,MAAMgC,MAAMhC,gEAAWA,CAAC;QACxB,MAAMiC,MAAMjC,gEAAWA,CAAC;QACxB,MAAMkC,MAAMlC,gEAAWA,CAAC;QACxB,MAAMmC,OAAOnC,gEAAWA,CAAC;QACzB,MAAMoC,UAAUpC,gEAAWA,CAAC;QAC5B,KAAK,MAAM,CAACU,MAAM2B,MAAM,IAAI,IAAI,CAACvB,YAAY,GAAI;YAC7C,IAAIJ,SAAS0B,QAAQ1B,IAAI,EAAE;gBACvBoB,OAAO,CAAC,CAAC,EAAEO,SAAS,GAAG,CAAC;YAC5B;YACA,mEAAmE;YACnE,IAAI5B,UAAU6B,QAAQ,CAAC5B,OAAO;gBAC1BiB,YAAYI,IAAIQ,IAAI;gBACpBV,OAAO;gBACPD,OAAO,CAAC,EAAES,SAAS,GAAG,EAAEP,KAAK,CAAC;gBAC9BJ,SAAShB,SAASyB,KAAKzB,IAAI,GAAG,IAAI;YACtC;YACA,IAAIA,SAASqB,IAAIrB,IAAI,IAAIA,SAASsB,IAAItB,IAAI,EAAE;gBACxCiB,YAAY3B,gEAAWA,CAACU,MAAM6B,IAAI;gBAClCV,OAAOW,SAASH,SAAS;YAC7B;YACA,IAAI3B,SAASuB,IAAIvB,IAAI,IAAIA,SAASwB,IAAIxB,IAAI,EAAE;gBACxCiB,YAAY3B,gEAAWA,CAACU,MAAM6B,IAAI;gBAClCX,OAAO,CAAC,EAAES,SAAS,GAAG,EAAEP,KAAK,CAAC;gBAC9BJ,SAAShB,SAASwB,IAAIxB,IAAI,GAAG,IAAI;YACrC;QACJ;QACA,IAAIgB,UAAU,QAAQC,aAAa,QAAQC,QAAQ,QAAQC,QAAQ,MAAM;YACrE,MAAM,IAAIP,MAAM;QACpB;QACA,MAAMmB,OAAO;YACTf;YACAE;YACAD;YACAE;QACJ;QACA,OAAOY;IACX;IACAC,SAAS;QACL,OAAO,IAAI,CAAC,CAAC7B,MAAM,CAAC8B,GAAG,CAAC,CAAC,CAACjC,KAAK,GAAKkC,OAAOC,MAAM,CAAC,CAAC,GAAG7C,gEAAWA,CAACU;IACtE;IACAoC,aAAa;QACT,OAAO,IAAI,CAAC,CAACjC,MAAM,CAAC8B,GAAG,CAAC,CAAC,CAACjC,KAAK,GAAKA;IACxC;IACAqC,aAAa;QACT,OAAO,IAAI,CAAC,CAAClC,MAAM,CAAC8B,GAAG,CAAC,CAAC,CAACjC,KAAK,GAAKV,gEAAWA,CAACU,MAAM6B,IAAI;IAC9D;IACA1B,SAAS;QACL,OAAO,IAAI,CAAC,CAACA,MAAM;IACvB;IACAC,eAAe;QACX,OAAO,IAAI,CAAC,CAACA,YAAY;IAC7B;IACAkC,YAAY/B,IAAI,EAAE;QACdA,OAAO,IAAIN,UAAUM;QACrB,OAAO,IAAIN,UAAU,IAAI,CAAChB,QAAQ,KAAKsB,KAAKtB,QAAQ;IACxD;IACAsD,YAAYhC,IAAI,EAAE;QACd,MAAMiC,aAAajC,KAAKtB,QAAQ;QAChC,MAAMwD,IAAI,IAAI,CAACxD,QAAQ;QACvB,MAAMyD,IAAID,EAAEE,WAAW,CAACH;QACxB,IAAIE,IAAI,GAAG;YACP,MAAM,IAAI9B,MAAM,CAAC,QAAQ,EAAE,IAAI,CAAC3B,QAAQ,GAAG,8BAA8B,EAAEsB,KAAKtB,QAAQ,GAAG,CAAC;QAChG;QACA,OAAO,IAAIgB,UAAUwC,EAAEG,KAAK,CAAC,GAAGF;IACpC;IACAG,gBAAgB7C,IAAI,EAAE;QAClB,MAAMG,SAAS,IAAI,CAACA,MAAM;QAC1B,IAAK,IAAIuC,IAAIvC,OAAOO,MAAM,GAAG,GAAGgC,KAAK,GAAGA,IAAK;YACzC,IAAIvC,MAAM,CAACuC,EAAE,CAAC,EAAE,KAAK1C,MAAM;gBACvB,OAAO,IAAIC,UAAUZ,wDAAaA,CAACc,OAAOyC,KAAK,CAAC,GAAGF;YACvD;QACJ;QACA,OAAO,IAAI;IACf;IACAI,YAAY;QACR,IAAI;YACA,IAAI3C,SAAS,EAAE;YACf,IAAI,CAACC,YAAY,GAAG2C,OAAO,CAAC,CAAC,CAAC/C,MAAM6B,KAAK;gBACrC,IAAI7B,SAAST,sDAAKA,CAACyD,GAAG,CAAChD,IAAI,EAAE;oBACzBG,OAAO8C,IAAI,CAAC;wBAACjD;wBAAM6B;qBAAK;gBAC5B;gBACA,yEAAyE;gBACzE,+BAA+B;gBAC/B,IAAI7B,SAAST,sDAAK,CAAC,cAAc,CAACS,IAAI,EAAE;oBACpCG,SAAS,EAAE;gBACf;YACJ;YACA,mDAAmD;YACnD,MAAM+C,QAAQ/C,OAAOgD,GAAG;YACxB,IAAID,OAAO,CAAC,EAAE,IAAI,MAAM;gBACpB,MAAME,YAAYF,KAAK,CAAC,EAAE;gBAC1B,+EAA+E;gBAC/E,yDAAyD;gBACzD,IAAIE,SAAS,CAAC,EAAE,KAAK,OAAOA,SAAS,CAAC,EAAE,KAAK,KAAK;oBAC9C,OAAOlE,+DAAkBA,CAACL,gEAASA,CAACwE,MAAM,CAAC,CAAC,CAAC,EAAED,UAAU,CAAC,GAAG;gBACjE;gBACA,8BAA8B;gBAC9B,OAAOlE,+DAAkBA,CAACJ,iDAAGA,CAACwE,KAAK,CAACF,WAAWG,SAAS,CAAC1C,KAAK,EAAE;YACpE;YACA,OAAO;QACX,EACA,OAAO2C,GAAG;YACN,OAAO;QACX;IACJ;IACAC,UAAU;QACN,OAAO,IAAI,CAAC,CAACpD,IAAI;IACrB;IACAtB,OAAOwB,IAAI,EAAE;QACT,OAAOvB,0DAAgBA,CAAC,IAAI,CAAC6B,KAAK,EAAEN,KAAKM,KAAK;IAClD;IACA,MAAM6C,QAAQC,OAAO,EAAE;QACnB,MAAMC,kBAAkB,IAAI,CAAC5B,MAAM,GAAG6B,IAAI,CAAC,CAACC,IAAMA,EAAEC,UAAU;QAC9D,+BAA+B;QAC/B,IAAIH,mBAAmB,MAAM;YACzB,OAAO;gBAAC,IAAI;aAAC;QACjB;QACA,MAAMI,WAAWtE,gDAASA,CAACuE,GAAG,CAACL,gBAAgB/B,IAAI;QACnD,IAAImC,YAAY,MAAM;YAClB,MAAM,IAAIpF,wDAASA,CAAC,CAAC,0BAA0B,EAAEgF,gBAAgB/B,IAAI,CAAC,CAAC,EAAE;QAC7E;QACA,MAAMqC,SAAS,MAAMF,SAAS,IAAI,EAAEL;QACpC,OAAOO,OAAOjC,GAAG,CAACkC,CAAAA,MAAO1E,oDAASA,CAAC0E;IACvC;IACAC,cAAc;QACV,MAAMT,UAAU,IAAI,CAAC5C,SAAS;QAC9B,IAAI4C,QAAQ1C,SAAS,KAAK,SAAS0C,QAAQ1C,SAAS,KAAK,OAAO;YAC5D,MAAM,IAAIL,MAAM,CAAC,6DAA6D,EAAE+C,QAAQ1C,SAAS,CAAC,qDAAqD,CAAC;QAC5J;QACA,OAAO;YACHD,QAAQ2C,QAAQ3C,MAAM;YACtBqD,SAASV,QAAQzC,IAAI;YACrBC,MAAMwC,QAAQxC,IAAI;QACtB;IACJ;IACAmD,mBAAmB/D,IAAI,EAAE;QACrB,MAAMyB,SAAS,CAACzB,QAAQ,IAAI,EAAEyB,MAAM;QACpC,IAAIA,OAAOtB,MAAM,KAAK,GAAG;YACrB,OAAO;QACX;QACA,IAAIsB,MAAM,CAAC,EAAE,CAAChC,IAAI,KAAK,KAAKgC,MAAM,CAAC,EAAE,CAAChC,IAAI,KAAK,IAAI;YAC/C,OAAO;QACX;QACA,IAAIgC,MAAM,CAAC,EAAE,CAAChC,IAAI,KAAK,KAAKgC,MAAM,CAAC,EAAE,CAAChC,IAAI,KAAK,KAAK;YAChD,OAAO;QACX;QACA,OAAO;IACX;IACA;;;;;;;;;;;KAWC,GACD,CAACL,QAAQ,GAAG;QACR,OAAO,CAAC,UAAU,EAAE,IAAI,CAAC,CAACO,MAAM,CAAC,CAAC,CAAC;IACvC;AACJ,EACA,qCAAqC","sources":["webpack://flush-notes/./node_modules/@multiformats/multiaddr/dist/src/multiaddr.js?8ba9"],"sourcesContent":["/**\n * @packageDocumentation\n *\n * An implementation of a Multiaddr in JavaScript\n *\n * @example\n *\n * ```js\n * import { multiaddr } from '@multiformats/multiaddr'\n *\n * const ma = multiaddr('/ip4/127.0.0.1/tcp/1234')\n * ```\n */\nimport { CodeError } from '@libp2p/interface';\nimport { base58btc } from 'multiformats/bases/base58';\nimport { CID } from 'multiformats/cid';\nimport { equals as uint8ArrayEquals } from 'uint8arrays/equals';\nimport { toString as uint8ArrayToString } from 'uint8arrays/to-string';\nimport { bytesToMultiaddrParts, stringToMultiaddrParts, tuplesToBytes } from './codec.js';\nimport { getProtocol, names } from './protocols-table.js';\nimport { isMultiaddr, multiaddr, resolvers } from './index.js';\nconst inspect = Symbol.for('nodejs.util.inspect.custom');\nexport const symbol = Symbol.for('@multiformats/js-multiaddr/multiaddr');\nconst DNS_CODES = [\n    getProtocol('dns').code,\n    getProtocol('dns4').code,\n    getProtocol('dns6').code,\n    getProtocol('dnsaddr').code\n];\n/**\n * Creates a {@link Multiaddr} from a {@link MultiaddrInput}\n */\nexport class Multiaddr {\n    bytes;\n    #string;\n    #tuples;\n    #stringTuples;\n    #path;\n    [symbol] = true;\n    constructor(addr) {\n        // default\n        if (addr == null) {\n            addr = '';\n        }\n        let parts;\n        if (addr instanceof Uint8Array) {\n            parts = bytesToMultiaddrParts(addr);\n        }\n        else if (typeof addr === 'string') {\n            if (addr.length > 0 && addr.charAt(0) !== '/') {\n                throw new Error(`multiaddr \"${addr}\" must start with a \"/\"`);\n            }\n            parts = stringToMultiaddrParts(addr);\n        }\n        else if (isMultiaddr(addr)) { // Multiaddr\n            parts = bytesToMultiaddrParts(addr.bytes);\n        }\n        else {\n            throw new Error('addr must be a string, Buffer, or another Multiaddr');\n        }\n        this.bytes = parts.bytes;\n        this.#string = parts.string;\n        this.#tuples = parts.tuples;\n        this.#stringTuples = parts.stringTuples;\n        this.#path = parts.path;\n    }\n    toString() {\n        return this.#string;\n    }\n    toJSON() {\n        return this.toString();\n    }\n    toOptions() {\n        let family;\n        let transport;\n        let host;\n        let port;\n        let zone = '';\n        const tcp = getProtocol('tcp');\n        const udp = getProtocol('udp');\n        const ip4 = getProtocol('ip4');\n        const ip6 = getProtocol('ip6');\n        const dns6 = getProtocol('dns6');\n        const ip6zone = getProtocol('ip6zone');\n        for (const [code, value] of this.stringTuples()) {\n            if (code === ip6zone.code) {\n                zone = `%${value ?? ''}`;\n            }\n            // default to https when protocol & port are omitted from DNS addrs\n            if (DNS_CODES.includes(code)) {\n                transport = tcp.name;\n                port = 443;\n                host = `${value ?? ''}${zone}`;\n                family = code === dns6.code ? 6 : 4;\n            }\n            if (code === tcp.code || code === udp.code) {\n                transport = getProtocol(code).name;\n                port = parseInt(value ?? '');\n            }\n            if (code === ip4.code || code === ip6.code) {\n                transport = getProtocol(code).name;\n                host = `${value ?? ''}${zone}`;\n                family = code === ip6.code ? 6 : 4;\n            }\n        }\n        if (family == null || transport == null || host == null || port == null) {\n            throw new Error('multiaddr must have a valid format: \"/{ip4, ip6, dns4, dns6, dnsaddr}/{address}/{tcp, udp}/{port}\".');\n        }\n        const opts = {\n            family,\n            host,\n            transport,\n            port\n        };\n        return opts;\n    }\n    protos() {\n        return this.#tuples.map(([code]) => Object.assign({}, getProtocol(code)));\n    }\n    protoCodes() {\n        return this.#tuples.map(([code]) => code);\n    }\n    protoNames() {\n        return this.#tuples.map(([code]) => getProtocol(code).name);\n    }\n    tuples() {\n        return this.#tuples;\n    }\n    stringTuples() {\n        return this.#stringTuples;\n    }\n    encapsulate(addr) {\n        addr = new Multiaddr(addr);\n        return new Multiaddr(this.toString() + addr.toString());\n    }\n    decapsulate(addr) {\n        const addrString = addr.toString();\n        const s = this.toString();\n        const i = s.lastIndexOf(addrString);\n        if (i < 0) {\n            throw new Error(`Address ${this.toString()} does not contain subaddress: ${addr.toString()}`);\n        }\n        return new Multiaddr(s.slice(0, i));\n    }\n    decapsulateCode(code) {\n        const tuples = this.tuples();\n        for (let i = tuples.length - 1; i >= 0; i--) {\n            if (tuples[i][0] === code) {\n                return new Multiaddr(tuplesToBytes(tuples.slice(0, i)));\n            }\n        }\n        return this;\n    }\n    getPeerId() {\n        try {\n            let tuples = [];\n            this.stringTuples().forEach(([code, name]) => {\n                if (code === names.p2p.code) {\n                    tuples.push([code, name]);\n                }\n                // if this is a p2p-circuit address, return the target peer id if present\n                // not the peer id of the relay\n                if (code === names['p2p-circuit'].code) {\n                    tuples = [];\n                }\n            });\n            // Get the last ipfs tuple ['p2p', 'peerid string']\n            const tuple = tuples.pop();\n            if (tuple?.[1] != null) {\n                const peerIdStr = tuple[1];\n                // peer id is base58btc encoded string but not multibase encoded so add the `z`\n                // prefix so we can validate that it is correctly encoded\n                if (peerIdStr[0] === 'Q' || peerIdStr[0] === '1') {\n                    return uint8ArrayToString(base58btc.decode(`z${peerIdStr}`), 'base58btc');\n                }\n                // try to parse peer id as CID\n                return uint8ArrayToString(CID.parse(peerIdStr).multihash.bytes, 'base58btc');\n            }\n            return null;\n        }\n        catch (e) {\n            return null;\n        }\n    }\n    getPath() {\n        return this.#path;\n    }\n    equals(addr) {\n        return uint8ArrayEquals(this.bytes, addr.bytes);\n    }\n    async resolve(options) {\n        const resolvableProto = this.protos().find((p) => p.resolvable);\n        // Multiaddr is not resolvable?\n        if (resolvableProto == null) {\n            return [this];\n        }\n        const resolver = resolvers.get(resolvableProto.name);\n        if (resolver == null) {\n            throw new CodeError(`no available resolver for ${resolvableProto.name}`, 'ERR_NO_AVAILABLE_RESOLVER');\n        }\n        const result = await resolver(this, options);\n        return result.map(str => multiaddr(str));\n    }\n    nodeAddress() {\n        const options = this.toOptions();\n        if (options.transport !== 'tcp' && options.transport !== 'udp') {\n            throw new Error(`multiaddr must have a valid format - no protocol with name: \"${options.transport}\". Must have a valid transport protocol: \"{tcp, udp}\"`);\n        }\n        return {\n            family: options.family,\n            address: options.host,\n            port: options.port\n        };\n    }\n    isThinWaistAddress(addr) {\n        const protos = (addr ?? this).protos();\n        if (protos.length !== 2) {\n            return false;\n        }\n        if (protos[0].code !== 4 && protos[0].code !== 41) {\n            return false;\n        }\n        if (protos[1].code !== 6 && protos[1].code !== 273) {\n            return false;\n        }\n        return true;\n    }\n    /**\n     * Returns Multiaddr as a human-readable string\n     * https://nodejs.org/api/util.html#utilinspectcustom\n     *\n     * @example\n     * ```js\n     * import { multiaddr } from '@multiformats/multiaddr'\n     *\n     * console.info(multiaddr('/ip4/127.0.0.1/tcp/4001'))\n     * // 'Multiaddr(/ip4/127.0.0.1/tcp/4001)'\n     * ```\n     */\n    [inspect]() {\n        return `Multiaddr(${this.#string})`;\n    }\n}\n//# sourceMappingURL=multiaddr.js.map"],"names":["CodeError","base58btc","CID","equals","uint8ArrayEquals","toString","uint8ArrayToString","bytesToMultiaddrParts","stringToMultiaddrParts","tuplesToBytes","getProtocol","names","isMultiaddr","multiaddr","resolvers","inspect","Symbol","for","symbol","DNS_CODES","code","Multiaddr","string","tuples","stringTuples","path","constructor","addr","parts","Uint8Array","length","charAt","Error","bytes","toJSON","toOptions","family","transport","host","port","zone","tcp","udp","ip4","ip6","dns6","ip6zone","value","includes","name","parseInt","opts","protos","map","Object","assign","protoCodes","protoNames","encapsulate","decapsulate","addrString","s","i","lastIndexOf","slice","decapsulateCode","getPeerId","forEach","p2p","push","tuple","pop","peerIdStr","decode","parse","multihash","e","getPath","resolve","options","resolvableProto","find","p","resolvable","resolver","get","result","str","nodeAddress","address","isThinWaistAddress"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/@multiformats/multiaddr/dist/src/multiaddr.js\n");
/***/ }),
/***/ "(ssr)/./node_modules/@multiformats/multiaddr/dist/src/protocols-table.js":
/*!**************************************************************************!*\
!*** ./node_modules/@multiformats/multiaddr/dist/src/protocols-table.js ***!
\**************************************************************************/
/***/ ((__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 */ codes: () => (/* binding */ codes),\n/* harmony export */ createProtocol: () => (/* binding */ createProtocol),\n/* harmony export */ getProtocol: () => (/* binding */ getProtocol),\n/* harmony export */ names: () => (/* binding */ names),\n/* harmony export */ table: () => (/* binding */ table)\n/* harmony export */ });\nconst V = -1;\nconst names = {};\nconst codes = {};\nconst table = [\n [\n 4,\n 32,\n \"ip4\"\n ],\n [\n 6,\n 16,\n \"tcp\"\n ],\n [\n 33,\n 16,\n \"dccp\"\n ],\n [\n 41,\n 128,\n \"ip6\"\n ],\n [\n 42,\n V,\n \"ip6zone\"\n ],\n [\n 43,\n 8,\n \"ipcidr\"\n ],\n [\n 53,\n V,\n \"dns\",\n true\n ],\n [\n 54,\n V,\n \"dns4\",\n true\n ],\n [\n 55,\n V,\n \"dns6\",\n true\n ],\n [\n 56,\n V,\n \"dnsaddr\",\n true\n ],\n [\n 132,\n 16,\n \"sctp\"\n ],\n [\n 273,\n 16,\n \"udp\"\n ],\n [\n 275,\n 0,\n \"p2p-webrtc-star\"\n ],\n [\n 276,\n 0,\n \"p2p-webrtc-direct\"\n ],\n [\n 277,\n 0,\n \"p2p-stardust\"\n ],\n [\n 280,\n 0,\n \"webrtc-direct\"\n ],\n [\n 281,\n 0,\n \"webrtc\"\n ],\n [\n 290,\n 0,\n \"p2p-circuit\"\n ],\n [\n 301,\n 0,\n \"udt\"\n ],\n [\n 302,\n 0,\n \"utp\"\n ],\n [\n 400,\n V,\n \"unix\",\n false,\n true\n ],\n // `ipfs` is added before `p2p` for legacy support.\n // All text representations will default to `p2p`, but `ipfs` will\n // still be supported\n [\n 421,\n V,\n \"ipfs\"\n ],\n // `p2p` is the preferred name for 421, and is now the default\n [\n 421,\n V,\n \"p2p\"\n ],\n [\n 443,\n 0,\n \"https\"\n ],\n [\n 444,\n 96,\n \"onion\"\n ],\n [\n 445,\n 296,\n \"onion3\"\n ],\n [\n 446,\n V,\n \"garlic64\"\n ],\n [\n 448,\n 0,\n \"tls\"\n ],\n [\n 449,\n V,\n \"sni\"\n ],\n [\n 460,\n 0,\n \"quic\"\n ],\n [\n 461,\n 0,\n \"quic-v1\"\n ],\n [\n 465,\n 0,\n \"webtransport\"\n ],\n [\n 466,\n V,\n \"certhash\"\n ],\n [\n 477,\n 0,\n \"ws\"\n ],\n [\n 478,\n 0,\n \"wss\"\n ],\n [\n 479,\n 0,\n \"p2p-websocket-star\"\n ],\n [\n 480,\n 0,\n \"http\"\n ],\n [\n 777,\n V,\n \"memory\"\n ]\n];\n// populate tables\ntable.forEach((row)=>{\n const proto = createProtocol(...row);\n codes[proto.code] = proto;\n names[proto.name] = proto;\n});\nfunction createProtocol(code, size, name, resolvable, path) {\n return {\n code,\n size,\n name,\n resolvable: Boolean(resolvable),\n path: Boolean(path)\n };\n}\n/**\n * For the passed proto string or number, return a {@link Protocol}\n *\n * @example\n *\n * ```js\n * import { protocol } from '@multiformats/multiaddr'\n *\n * console.info(protocol(4))\n * // { code: 4, size: 32, name: 'ip4', resolvable: false, path: false }\n * ```\n */ function getProtocol(proto) {\n if (typeof proto === \"number\") {\n if (codes[proto] != null) {\n return codes[proto];\n }\n throw new Error(`no protocol with code: ${proto}`);\n } else if (typeof proto === \"string\") {\n if (names[proto] != null) {\n return names[proto];\n }\n throw new Error(`no protocol with name: ${proto}`);\n }\n throw new Error(`invalid protocol id type: ${typeof proto}`);\n} //# sourceMappingURL=protocols-table.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvQG11bHRpZm9ybWF0cy9tdWx0aWFkZHIvZGlzdC9zcmMvcHJvdG9jb2xzLXRhYmxlLmpzIiwibWFwcGluZ3MiOiI7Ozs7Ozs7O0FBQUEsTUFBTUEsSUFBSSxDQUFDO0FBQ0osTUFBTUMsUUFBUSxDQUFDLEVBQUU7QUFDakIsTUFBTUMsUUFBUSxDQUFDLEVBQUU7QUFDakIsTUFBTUMsUUFBUTtJQUNqQjtRQUFDO1FBQUc7UUFBSTtLQUFNO0lBQ2Q7UUFBQztRQUFHO1FBQUk7S0FBTTtJQUNkO1FBQUM7UUFBSTtRQUFJO0tBQU87SUFDaEI7UUFBQztRQUFJO1FBQUs7S0FBTTtJQUNoQjtRQUFDO1FBQUlIO1FBQUc7S0FBVTtJQUNsQjtRQUFDO1FBQUk7UUFBRztLQUFTO0lBQ2pCO1FBQUM7UUFBSUE7UUFBRztRQUFPO0tBQUs7SUFDcEI7UUFBQztRQUFJQTtRQUFHO1FBQVE7S0FBSztJQUNyQjtRQUFDO1FBQUlBO1FBQUc7UUFBUTtLQUFLO0lBQ3JCO1FBQUM7UUFBSUE7UUFBRztRQUFXO0tBQUs7SUFDeEI7UUFBQztRQUFLO1FBQUk7S0FBTztJQUNqQjtRQUFDO1FBQUs7UUFBSTtLQUFNO0lBQ2hCO1FBQUM7UUFBSztRQUFHO0tBQWtCO0lBQzNCO1FBQUM7UUFBSztRQUFHO0tBQW9CO0lBQzdCO1FBQUM7UUFBSztRQUFHO0tBQWU7SUFDeEI7UUFBQztRQUFLO1FBQUc7S0FBZ0I7SUFDekI7UUFBQztRQUFLO1FBQUc7S0FBUztJQUNsQjtRQUFDO1FBQUs7UUFBRztLQUFjO0lBQ3ZCO1FBQUM7UUFBSztRQUFHO0tBQU07SUFDZjtRQUFDO1FBQUs7UUFBRztLQUFNO0lBQ2Y7UUFBQztRQUFLQTtRQUFHO1FBQVE7UUFBTztLQUFLO0lBQzdCLG1EQUFtRDtJQUNuRCxrRUFBa0U7SUFDbEUscUJBQXFCO0lBQ3JCO1FBQUM7UUFBS0E7UUFBRztLQUFPO0lBQ2hCLDhEQUE4RDtJQUM5RDtRQUFDO1FBQUtBO1FBQUc7S0FBTTtJQUNmO1FBQUM7UUFBSztRQUFHO0tBQVE7SUFDakI7UUFBQztRQUFLO1FBQUk7S0FBUTtJQUNsQjtRQUFDO1FBQUs7UUFBSztLQUFTO0lBQ3BCO1FBQUM7UUFBS0E7UUFBRztLQUFXO0lBQ3BCO1FBQUM7UUFBSztRQUFHO0tBQU07SUFDZjtRQUFDO1FBQUtBO1FBQUc7S0FBTTtJQUNmO1FBQUM7UUFBSztRQUFHO0tBQU87SUFDaEI7UUFBQztRQUFLO1FBQUc7S0FBVTtJQUNuQjtRQUFDO1FBQUs7UUFBRztLQUFlO0lBQ3hCO1FBQUM7UUFBS0E7UUFBRztLQUFXO0lBQ3BCO1FBQUM7UUFBSztRQUFHO0tBQUs7SUFDZDtRQUFDO1FBQUs7UUFBRztLQUFNO0lBQ2Y7UUFBQztRQUFLO1FBQUc7S0FBcUI7SUFDOUI7UUFBQztRQUFLO1FBQUc7S0FBTztJQUNoQjtRQUFDO1FBQUtBO1FBQUc7S0FBUztDQUNyQixDQUFDO0FBQ0Ysa0JBQWtCO0FBQ2xCRyxNQUFNQyxPQUFPLENBQUNDLENBQUFBO0lBQ1YsTUFBTUMsUUFBUUMsa0JBQWtCRjtJQUNoQ0gsS0FBSyxDQUFDSSxNQUFNRSxJQUFJLENBQUMsR0FBR0Y7SUFDcEJMLEtBQUssQ0FBQ0ssTUFBTUcsSUFBSSxDQUFDLEdBQUdIO0FBQ3hCO0FBQ08sU0FBU0MsZUFBZUMsSUFBSSxFQUFFRSxJQUFJLEVBQUVELElBQUksRUFBRUUsVUFBVSxFQUFFQyxJQUFJO0lBQzdELE9BQU87UUFDSEo7UUFDQUU7UUFDQUQ7UUFDQUUsWUFBWUUsUUFBUUY7UUFDcEJDLE1BQU1DLFFBQVFEO0lBQ2xCO0FBQ0o7QUFDQTs7Ozs7Ozs7Ozs7Q0FXQyxHQUNNLFNBQVNFLFlBQVlSLEtBQUs7SUFDN0IsSUFBSSxPQUFPQSxVQUFVLFVBQVU7UUFDM0IsSUFBSUosS0FBSyxDQUFDSSxNQUFNLElBQUksTUFBTTtZQUN0QixPQUFPSixLQUFLLENBQUNJLE1BQU07UUFDdkI7UUFDQSxNQUFNLElBQUlTLE1BQU0sQ0FBQyx1QkFBdUIsRUFBRVQsTUFBTSxDQUFDO0lBQ3JELE9BQ0ssSUFBSSxPQUFPQSxVQUFVLFVBQVU7UUFDaEMsSUFBSUwsS0FBSyxDQUFDSyxNQUFNLElBQUksTUFBTTtZQUN0QixPQUFPTCxLQUFLLENBQUNLLE1BQU07UUFDdkI7UUFDQSxNQUFNLElBQUlTLE1BQU0sQ0FBQyx1QkFBdUIsRUFBRVQsTUFBTSxDQUFDO0lBQ3JEO0lBQ0EsTUFBTSxJQUFJUyxNQUFNLENBQUMsMEJBQTBCLEVBQUUsT0FBT1QsTUFBTSxDQUFDO0FBQy9ELEVBQ0EsMkNBQTJDIiwic291cmNlcyI6WyJ3ZWJwYWNrOi8vZmx1c2gtbm90ZXMvLi9ub2RlX21vZHVsZXMvQG11bHRpZm9ybWF0cy9tdWx0aWFkZHIvZGlzdC9zcmMvcHJvdG9jb2xzLXRhYmxlLmpzPzc1Y2MiXSwic291cmNlc0NvbnRlbnQiOlsiY29uc3QgViA9IC0xO1xuZXhwb3J0IGNvbnN0IG5hbWVzID0ge307XG5leHBvcnQgY29uc3QgY29kZXMgPSB7fTtcbmV4cG9ydCBjb25zdCB0YWJsZSA9IFtcbiAgICBbNCwgMzIsICdpcDQnXSxcbiAgICBbNiwgMTYsICd0Y3AnXSxcbiAgICBbMzMsIDE2LCAnZGNjcCddLFxuICAgIFs0MSwgMTI4LCAnaXA2J10sXG4gICAgWzQyLCBWLCAnaXA2em9uZSddLFxuICAgIFs0MywgOCwgJ2lwY2lkciddLFxuICAgIFs1MywgViwgJ2RucycsIHRydWVdLFxuICAgIFs1NCwgViwgJ2RuczQnLCB0cnVlXSxcbiAgICBbNTUsIFYsICdkbnM2JywgdHJ1ZV0sXG4gICAgWzU2LCBWLCAnZG5zYWRkcicsIHRydWVdLFxuICAgIFsxMzIsIDE2LCAnc2N0cCddLFxuICAgIFsyNzMsIDE2LCAndWRwJ10sXG4gICAgWzI3NSwgMCwgJ3AycC13ZWJydGMtc3RhciddLFxuICAgIFsyNzYsIDAsICdwMnAtd2VicnRjLWRpcmVjdCddLFxuICAgIFsyNzcsIDAsICdwMnAtc3RhcmR1c3QnXSxcbiAgICBbMjgwLCAwLCAnd2VicnRjLWRpcmVjdCddLFxuICAgIFsyODEsIDAsICd3ZWJydGMnXSxcbiAgICBbMjkwLCAwLCAncDJwLWNpcmN1aXQnXSxcbiAgICBbMzAxLCAwLCAndWR0J10sXG4gICAgWzMwMiwgMCwgJ3V0cCddLFxuICAgIFs0MDAsIFYsICd1bml4JywgZmFsc2UsIHRydWVdLFxuICAgIC8vIGBpcGZzYCBpcyBhZGRlZCBiZWZvcmUgYHAycGAgZm9yIGxlZ2FjeSBzdXBwb3J0LlxuICAgIC8vIEFsbCB0ZXh0IHJlcHJlc2VudGF0aW9ucyB3aWxsIGRlZmF1bHQgdG8gYHAycGAsIGJ1dCBgaXBmc2Agd2lsbFxuICAgIC8vIHN0aWxsIGJlIHN1cHBvcnRlZFxuICAgIFs0MjEsIFYsICdpcGZzJ10sXG4gICAgLy8gYHAycGAgaXMgdGhlIHByZWZlcnJlZCBuYW1lIGZvciA0MjEsIGFuZCBpcyBub3cgdGhlIGRlZmF1bHRcbiAgICBbNDIxLCBWLCAncDJwJ10sXG4gICAgWzQ0MywgMCwgJ2h0dHBzJ10sXG4gICAgWzQ0NCwgOTYsICdvbmlvbiddLFxuICAgIFs0NDUsIDI5NiwgJ29uaW9uMyddLFxuICAgIFs0NDYsIFYsICdnYXJsaWM2NCddLFxuICAgIFs0NDgsIDAsICd0bHMnXSxcbiAgICBbNDQ5LCBWLCAnc25pJ10sXG4gICAgWzQ2MCwgMCwgJ3F1aWMnXSxcbiAgICBbNDYxLCAwLCAncXVpYy12MSddLFxuICAgIFs0NjUsIDAsICd3ZWJ0cmFuc3BvcnQnXSxcbiAgICBbNDY2LCBWLCAnY2VydGhhc2gnXSxcbiAgICBbNDc3LCAwLCAnd3MnXSxcbiAgICBbNDc4LCAwLCAnd3NzJ10sXG4gICAgWzQ3OSwgMCwgJ3AycC13ZWJzb2NrZXQtc3RhciddLFxuICAgIFs0ODAsIDAsICdodHRwJ10sXG4gICAgWzc3NywgViwgJ21lbW9yeSddXG5dO1xuLy8gcG9wdWxhdGUgdGFibGVzXG50YWJsZS5mb3JFYWNoKHJvdyA9PiB7XG4gICAgY29uc3QgcHJvdG8gPSBjcmVhdGVQcm90b2NvbCguLi5yb3cpO1xuICAgIGNvZGVzW3Byb3RvLmNvZGVdID0gcHJvdG87XG4gICAgbmFtZXNbcHJvdG8ubmFtZV0gPSBwcm90bztcbn0pO1xuZXhwb3J0IGZ1bmN0aW9uIGNyZWF0ZVByb3RvY29sKGNvZGUsIHNpemUsIG5hbWUsIHJlc29sdmFibGUsIHBhdGgpIHtcbiAgICByZXR1cm4ge1xuICAgICAgICBjb2RlLFxuICAgICAgICBzaXplLFxuICAgICAgICBuYW1lLFxuICAgICAgICByZXNvbHZhYmxlOiBCb29sZWFuKHJlc29sdmFibGUpLFxuICAgICAgICBwYXRoOiBCb29sZWFuKHBhdGgpXG4gICAgfTtcbn1cbi8qKlxuICogRm9yIHRoZSBwYXNzZWQgcHJvdG8gc3RyaW5nIG9yIG51bWJlciwgcmV0dXJuIGEge0BsaW5rIFByb3RvY29sfVxuICpcbiAqIEBleGFtcGxlXG4gKlxuICogYGBganNcbiAqIGltcG9ydCB7IHByb3RvY29sIH0gZnJvbSAnQG11bHRpZm9ybWF0cy9tdWx0aWFkZHInXG4gKlxuICogY29uc29sZS5pbmZvKHByb3RvY29sKDQpKVxuICogLy8geyBjb2RlOiA0LCBzaXplOiAzMiwgbmFtZTogJ2lwNCcsIHJlc29sdmFibGU6IGZhbHNlLCBwYXRoOiBmYWxzZSB9XG4gKiBgYGBcbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIGdldFByb3RvY29sKHByb3RvKSB7XG4gICAgaWYgKHR5cGVvZiBwcm90byA9PT0gJ251bWJlcicpIHtcbiAgICAgICAgaWYgKGNvZGVzW3Byb3RvXSAhPSBudWxsKSB7XG4gICAgICAgICAgICByZXR1cm4gY29kZXNbcHJvdG9dO1xuICAgICAgICB9XG4gICAgICAgIHRocm93IG5ldyBFcnJvcihgbm8gcHJvdG9jb2wgd2l0aCBjb2RlOiAke3Byb3RvfWApO1xuICAgIH1cbiAgICBlbHNlIGlmICh0eXBlb2YgcHJvdG8gPT09ICdzdHJpbmcnKSB7XG4gICAgICAgIGlmIChuYW1lc1twcm90b10gIT0gbnVsbCkge1xuICAgICAgICAgICAgcmV0dXJuIG5hbWVzW3Byb3RvXTtcbiAgICAgICAgfVxuICAgICAgICB0aHJvdyBuZXcgRXJyb3IoYG5vIHByb3RvY29sIHdpdGggbmFtZTogJHtwcm90b31gKTtcbiAgICB9XG4gICAgdGhyb3cgbmV3IEVycm9yKGBpbnZhbGlkIHByb3RvY29sIGlkIHR5cGU6ICR7dHlwZW9mIHByb3RvfWApO1xufVxuLy8jIHNvdXJjZU1hcHBpbmdVUkw9cHJvdG9jb2xzLXRhYmxlLmpzLm1hcCJdLCJuYW1lcyI6WyJWIiwibmFtZXMiLCJjb2RlcyIsInRhYmxlIiwiZm9yRWFjaCIsInJvdyIsInByb3RvIiwiY3JlYXRlUHJvdG9jb2wiLCJjb2RlIiwibmFtZSIsInNpemUiLCJyZXNvbHZhYmxlIiwicGF0aCIsIkJvb2xlYW4iLCJnZXRQcm90b2NvbCIsIkVycm9yIl0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/@multiformats/multiaddr/dist/src/protocols-table.js\n");
/***/ }),
/***/ "(ssr)/./node_modules/@multiformats/multiaddr/dist/src/resolvers/dnsaddr.js":
/*!****************************************************************************!*\
!*** ./node_modules/@multiformats/multiaddr/dist/src/resolvers/dnsaddr.js ***!
\****************************************************************************/
/***/ ((__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 */ dnsaddrResolver: () => (/* binding */ dnsaddrResolver)\n/* harmony export */ });\n/* harmony import */ var _libp2p_interface__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! @libp2p/interface */ \"(ssr)/./node_modules/@libp2p/interface/dist/src/errors.js\");\n/* harmony import */ var _multiformats_dns__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @multiformats/dns */ \"(ssr)/./node_modules/@multiformats/dns/dist/src/index.js\");\n/* harmony import */ var _index_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../index.js */ \"(ssr)/./node_modules/@multiformats/multiaddr/dist/src/index.js\");\n/* harmony import */ var _protocols_table_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../protocols-table.js */ \"(ssr)/./node_modules/@multiformats/multiaddr/dist/src/protocols-table.js\");\n\n\n\n\nconst MAX_RECURSIVE_DEPTH = 32;\nconst { code: dnsaddrCode } = (0,_protocols_table_js__WEBPACK_IMPORTED_MODULE_2__.getProtocol)(\"dnsaddr\");\nconst dnsaddrResolver = async function dnsaddrResolver(ma, options = {}) {\n const recursionLimit = options.maxRecursiveDepth ?? MAX_RECURSIVE_DEPTH;\n if (recursionLimit === 0) {\n throw new _libp2p_interface__WEBPACK_IMPORTED_MODULE_3__.CodeError(\"Max recursive depth reached\", \"ERR_MAX_RECURSIVE_DEPTH_REACHED\");\n }\n const [, hostname] = ma.stringTuples().find(([proto])=>proto === dnsaddrCode) ?? [];\n const resolver = options?.dns ?? (0,_multiformats_dns__WEBPACK_IMPORTED_MODULE_0__.dns)();\n const result = await resolver.query(`_dnsaddr.${hostname}`, {\n signal: options?.signal,\n types: [\n _multiformats_dns__WEBPACK_IMPORTED_MODULE_0__.RecordType.TXT\n ]\n });\n const peerId = ma.getPeerId();\n const output = [];\n for (const answer of result.Answer){\n const addr = answer.data.split(\"=\")[1];\n if (addr == null) {\n continue;\n }\n if (peerId != null && !addr.includes(peerId)) {\n continue;\n }\n const ma = (0,_index_js__WEBPACK_IMPORTED_MODULE_1__.multiaddr)(addr);\n if (addr.startsWith(\"/dnsaddr\")) {\n const resolved = await ma.resolve({\n ...options,\n maxRecursiveDepth: recursionLimit - 1\n });\n output.push(...resolved.map((ma)=>ma.toString()));\n } else {\n output.push(ma.toString());\n }\n }\n return output;\n}; //# sourceMappingURL=dnsaddr.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvQG11bHRpZm9ybWF0cy9tdWx0aWFkZHIvZGlzdC9zcmMvcmVzb2x2ZXJzL2Ruc2FkZHIuanMiLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7QUFBOEM7QUFDTTtBQUNaO0FBQ1k7QUFDcEQsTUFBTUssc0JBQXNCO0FBQzVCLE1BQU0sRUFBRUMsTUFBTUMsV0FBVyxFQUFFLEdBQUdILGdFQUFXQSxDQUFDO0FBQ25DLE1BQU1JLGtCQUFrQixlQUFlQSxnQkFBZ0JDLEVBQUUsRUFBRUMsVUFBVSxDQUFDLENBQUM7SUFDMUUsTUFBTUMsaUJBQWlCRCxRQUFRRSxpQkFBaUIsSUFBSVA7SUFDcEQsSUFBSU0sbUJBQW1CLEdBQUc7UUFDdEIsTUFBTSxJQUFJWCx3REFBU0EsQ0FBQywrQkFBK0I7SUFDdkQ7SUFDQSxNQUFNLEdBQUdhLFNBQVMsR0FBR0osR0FBR0ssWUFBWSxHQUFHQyxJQUFJLENBQUMsQ0FBQyxDQUFDQyxNQUFNLEdBQUtBLFVBQVVULGdCQUFnQixFQUFFO0lBQ3JGLE1BQU1VLFdBQVdQLFNBQVNULE9BQU9BLHNEQUFHQTtJQUNwQyxNQUFNaUIsU0FBUyxNQUFNRCxTQUFTRSxLQUFLLENBQUMsQ0FBQyxTQUFTLEVBQUVOLFNBQVMsQ0FBQyxFQUFFO1FBQ3hETyxRQUFRVixTQUFTVTtRQUNqQkMsT0FBTztZQUNIbkIseURBQVVBLENBQUNvQixHQUFHO1NBQ2pCO0lBQ0w7SUFDQSxNQUFNQyxTQUFTZCxHQUFHZSxTQUFTO0lBQzNCLE1BQU1DLFNBQVMsRUFBRTtJQUNqQixLQUFLLE1BQU1DLFVBQVVSLE9BQU9TLE1BQU0sQ0FBRTtRQUNoQyxNQUFNQyxPQUFPRixPQUFPRyxJQUFJLENBQUNDLEtBQUssQ0FBQyxJQUFJLENBQUMsRUFBRTtRQUN0QyxJQUFJRixRQUFRLE1BQU07WUFDZDtRQUNKO1FBQ0EsSUFBSUwsVUFBVSxRQUFRLENBQUNLLEtBQUtHLFFBQVEsQ0FBQ1IsU0FBUztZQUMxQztRQUNKO1FBQ0EsTUFBTWQsS0FBS04sb0RBQVNBLENBQUN5QjtRQUNyQixJQUFJQSxLQUFLSSxVQUFVLENBQUMsYUFBYTtZQUM3QixNQUFNQyxXQUFXLE1BQU14QixHQUFHeUIsT0FBTyxDQUFDO2dCQUM5QixHQUFHeEIsT0FBTztnQkFDVkUsbUJBQW1CRCxpQkFBaUI7WUFDeEM7WUFDQWMsT0FBT1UsSUFBSSxJQUFJRixTQUFTRyxHQUFHLENBQUMzQixDQUFBQSxLQUFNQSxHQUFHNEIsUUFBUTtRQUNqRCxPQUNLO1lBQ0RaLE9BQU9VLElBQUksQ0FBQzFCLEdBQUc0QixRQUFRO1FBQzNCO0lBQ0o7SUFDQSxPQUFPWjtBQUNYLEVBQUUsQ0FDRixtQ0FBbUMiLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly9mbHVzaC1ub3Rlcy8uL25vZGVfbW9kdWxlcy9AbXVsdGlmb3JtYXRzL211bHRpYWRkci9kaXN0L3NyYy9yZXNvbHZlcnMvZG5zYWRkci5qcz81MmUyIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvZGVFcnJvciB9IGZyb20gJ0BsaWJwMnAvaW50ZXJmYWNlJztcbmltcG9ydCB7IGRucywgUmVjb3JkVHlwZSB9IGZyb20gJ0BtdWx0aWZvcm1hdHMvZG5zJztcbmltcG9ydCB7IG11bHRpYWRkciB9IGZyb20gJy4uL2luZGV4LmpzJztcbmltcG9ydCB7IGdldFByb3RvY29sIH0gZnJvbSAnLi4vcHJvdG9jb2xzLXRhYmxlLmpzJztcbmNvbnN0IE1BWF9SRUNVUlNJVkVfREVQVEggPSAzMjtcbmNvbnN0IHsgY29kZTogZG5zYWRkckNvZGUgfSA9IGdldFByb3RvY29sKCdkbnNhZGRyJyk7XG5leHBvcnQgY29uc3QgZG5zYWRkclJlc29sdmVyID0gYXN5bmMgZnVuY3Rpb24gZG5zYWRkclJlc29sdmVyKG1hLCBvcHRpb25zID0ge30pIHtcbiAgICBjb25zdCByZWN1cnNpb25MaW1pdCA9IG9wdGlvbnMubWF4UmVjdXJzaXZlRGVwdGggPz8gTUFYX1JFQ1VSU0lWRV9ERVBUSDtcbiAgICBpZiAocmVjdXJzaW9uTGltaXQgPT09IDApIHtcbiAgICAgICAgdGhyb3cgbmV3IENvZGVFcnJvcignTWF4IHJlY3Vyc2l2ZSBkZXB0aCByZWFjaGVkJywgJ0VSUl9NQVhfUkVDVVJTSVZFX0RFUFRIX1JFQUNIRUQnKTtcbiAgICB9XG4gICAgY29uc3QgWywgaG9zdG5hbWVdID0gbWEuc3RyaW5nVHVwbGVzKCkuZmluZCgoW3Byb3RvXSkgPT4gcHJvdG8gPT09IGRuc2FkZHJDb2RlKSA/PyBbXTtcbiAgICBjb25zdCByZXNvbHZlciA9IG9wdGlvbnM/LmRucyA/PyBkbnMoKTtcbiAgICBjb25zdCByZXN1bHQgPSBhd2FpdCByZXNvbHZlci5xdWVyeShgX2Ruc2FkZHIuJHtob3N0bmFtZX1gLCB7XG4gICAgICAgIHNpZ25hbDogb3B0aW9ucz8uc2lnbmFsLFxuICAgICAgICB0eXBlczogW1xuICAgICAgICAgICAgUmVjb3JkVHlwZS5UWFRcbiAgICAgICAgXVxuICAgIH0pO1xuICAgIGNvbnN0IHBlZXJJZCA9IG1hLmdldFBlZXJJZCgpO1xuICAgIGNvbnN0IG91dHB1dCA9IFtdO1xuICAgIGZvciAoY29uc3QgYW5zd2VyIG9mIHJlc3VsdC5BbnN3ZXIpIHtcbiAgICAgICAgY29uc3QgYWRkciA9IGFuc3dlci5kYXRhLnNwbGl0KCc9JylbMV07XG4gICAgICAgIGlmIChhZGRyID09IG51bGwpIHtcbiAgICAgICAgICAgIGNvbnRpbnVlO1xuICAgICAgICB9XG4gICAgICAgIGlmIChwZWVySWQgIT0gbnVsbCAmJiAhYWRkci5pbmNsdWRlcyhwZWVySWQpKSB7XG4gICAgICAgICAgICBjb250aW51ZTtcbiAgICAgICAgfVxuICAgICAgICBjb25zdCBtYSA9IG11bHRpYWRkcihhZGRyKTtcbiAgICAgICAgaWYgKGFkZHIuc3RhcnRzV2l0aCgnL2Ruc2FkZHInKSkge1xuICAgICAgICAgICAgY29uc3QgcmVzb2x2ZWQgPSBhd2FpdCBtYS5yZXNvbHZlKHtcbiAgICAgICAgICAgICAgICAuLi5vcHRpb25zLFxuICAgICAgICAgICAgICAgIG1heFJlY3Vyc2l2ZURlcHRoOiByZWN1cnNpb25MaW1pdCAtIDFcbiAgICAgICAgICAgIH0pO1xuICAgICAgICAgICAgb3V0cHV0LnB1c2goLi4ucmVzb2x2ZWQubWFwKG1hID0+IG1hLnRvU3RyaW5nKCkpKTtcbiAgICAgICAgfVxuICAgICAgICBlbHNlIHtcbiAgICAgICAgICAgIG91dHB1dC5wdXNoKG1hLnRvU3RyaW5nKCkpO1xuICAgICAgICB9XG4gICAgfVxuICAgIHJldHVybiBvdXRwdXQ7XG59O1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9ZG5zYWRkci5qcy5tYXAiXSwibmFtZXMiOlsiQ29kZUVycm9yIiwiZG5zIiwiUmVjb3JkVHlwZSIsIm11bHRpYWRkciIsImdldFByb3RvY29sIiwiTUFYX1JFQ1VSU0lWRV9ERVBUSCIsImNvZGUiLCJkbnNhZGRyQ29kZSIsImRuc2FkZHJSZXNvbHZlciIsIm1hIiwib3B0aW9ucyIsInJlY3Vyc2lvbkxpbWl0IiwibWF4UmVjdXJzaXZlRGVwdGgiLCJob3N0bmFtZSIsInN0cmluZ1R1cGxlcyIsImZpbmQiLCJwcm90byIsInJlc29sdmVyIiwicmVzdWx0IiwicXVlcnkiLCJzaWduYWwiLCJ0eXBlcyIsIlRYVCIsInBlZXJJZCIsImdldFBlZXJJZCIsIm91dHB1dCIsImFuc3dlciIsIkFuc3dlciIsImFkZHIiLCJkYXRhIiwic3BsaXQiLCJpbmNsdWRlcyIsInN0YXJ0c1dpdGgiLCJyZXNvbHZlZCIsInJlc29sdmUiLCJwdXNoIiwibWFwIiwidG9TdHJpbmciXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/@multiformats/multiaddr/dist/src/resolvers/dnsaddr.js\n");
/***/ }),
/***/ "(ssr)/./node_modules/@multiformats/multiaddr/dist/src/resolvers/index.js":
/*!**************************************************************************!*\
!*** ./node_modules/@multiformats/multiaddr/dist/src/resolvers/index.js ***!
\**************************************************************************/
/***/ ((__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 */ dnsaddrResolver: () => (/* reexport safe */ _dnsaddr_js__WEBPACK_IMPORTED_MODULE_0__.dnsaddrResolver)\n/* harmony export */ });\n/* harmony import */ var _dnsaddr_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./dnsaddr.js */ \"(ssr)/./node_modules/@multiformats/multiaddr/dist/src/resolvers/dnsaddr.js\");\n //# sourceMappingURL=index.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvQG11bHRpZm9ybWF0cy9tdWx0aWFkZHIvZGlzdC9zcmMvcmVzb2x2ZXJzL2luZGV4LmpzIiwibWFwcGluZ3MiOiI7Ozs7O0FBQStDLENBQy9DLGlDQUFpQyIsInNvdXJjZXMiOlsid2VicGFjazovL2ZsdXNoLW5vdGVzLy4vbm9kZV9tb2R1bGVzL0BtdWx0aWZvcm1hdHMvbXVsdGlhZGRyL2Rpc3Qvc3JjL3Jlc29sdmVycy9pbmRleC5qcz83Nzk4Il0sInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCB7IGRuc2FkZHJSZXNvbHZlciB9IGZyb20gJy4vZG5zYWRkci5qcyc7XG4vLyMgc291cmNlTWFwcGluZ1VSTD1pbmRleC5qcy5tYXAiXSwibmFtZXMiOlsiZG5zYWRkclJlc29sdmVyIl0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/@multiformats/multiaddr/dist/src/resolvers/index.js\n");
/***/ })
};
;