25 lines
33 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/interface-datastore";
exports.ids = ["vendor-chunks/interface-datastore"];
exports.modules = {
/***/ "(ssr)/./node_modules/interface-datastore/dist/src/key.js":
/*!**********************************************************!*\
!*** ./node_modules/interface-datastore/dist/src/key.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 */ Key: () => (/* binding */ Key)\n/* harmony export */ });\n/* harmony import */ var uint8arrays_from_string__WEBPACK_IMPORTED_MODULE_0__ = __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_1__ = __webpack_require__(/*! uint8arrays/to-string */ \"(ssr)/./node_modules/uint8arrays/dist/src/to-string.node.js\");\n\n\nconst pathSepS = \"/\";\nconst pathSepB = new TextEncoder().encode(pathSepS);\nconst pathSep = pathSepB[0];\n/**\n * A Key represents the unique identifier of an object.\n * Our Key scheme is inspired by file systems and Google App Engine key model.\n * Keys are meant to be unique across a system. Keys are hierarchical,\n * incorporating more and more specific namespaces. Thus keys can be deemed\n * 'children' or 'ancestors' of other keys:\n * - `new Key('/Comedy')`\n * - `new Key('/Comedy/MontyPython')`\n * Also, every namespace can be parametrized to embed relevant object\n * information. For example, the Key `name` (most specific namespace) could\n * include the object type:\n * - `new Key('/Comedy/MontyPython/Actor:JohnCleese')`\n * - `new Key('/Comedy/MontyPython/Sketch:CheeseShop')`\n * - `new Key('/Comedy/MontyPython/Sketch:CheeseShop/Character:Mousebender')`\n *\n */ class Key {\n /**\n * @param {string | Uint8Array} s\n * @param {boolean} [clean]\n */ constructor(s, clean){\n if (typeof s === \"string\") {\n this._buf = (0,uint8arrays_from_string__WEBPACK_IMPORTED_MODULE_0__.fromString)(s);\n } else if (s instanceof Uint8Array) {\n this._buf = s;\n } else {\n throw new Error(\"Invalid key, should be String of Uint8Array\");\n }\n if (clean == null) {\n clean = true;\n }\n if (clean) {\n this.clean();\n }\n if (this._buf.byteLength === 0 || this._buf[0] !== pathSep) {\n throw new Error(\"Invalid key\");\n }\n }\n /**\n * Convert to the string representation\n *\n * @param {import('uint8arrays/to-string').SupportedEncodings} [encoding='utf8'] - The encoding to use.\n * @returns {string}\n */ toString(encoding = \"utf8\") {\n return (0,uint8arrays_to_string__WEBPACK_IMPORTED_MODULE_1__.toString)(this._buf, encoding);\n }\n /**\n * Return the Uint8Array representation of the key\n *\n * @returns {Uint8Array}\n */ uint8Array() {\n return this._buf;\n }\n /**\n * Return string representation of the key\n *\n * @returns {string}\n */ get [Symbol.toStringTag]() {\n return `Key(${this.toString()})`;\n }\n /**\n * Constructs a key out of a namespace array.\n *\n * @param {Array<string>} list - The array of namespaces\n * @returns {Key}\n *\n * @example\n * ```js\n * Key.withNamespaces(['one', 'two'])\n * // => Key('/one/two')\n * ```\n */ static withNamespaces(list) {\n return new Key(list.join(pathSepS));\n }\n /**\n * Returns a randomly (uuid) generated key.\n *\n * @returns {Key}\n *\n * @example\n * ```js\n * Key.random()\n * // => Key('/344502982398')\n * ```\n */ static random() {\n return new Key(Math.random().toString().substring(2));\n }\n /**\n * @param {*} other\n */ static asKey(other) {\n if (other instanceof Uint8Array || typeof other === \"string\") {\n // we can create a key from this\n return new Key(other);\n }\n if (typeof other.uint8Array === \"function\") {\n // this is an older version or may have crossed the esm/cjs boundary\n return new Key(other.uint8Array());\n }\n return null;\n }\n /**\n * Cleanup the current key\n *\n * @returns {void}\n */ clean() {\n if (this._buf == null || this._buf.byteLength === 0) {\n this._buf = pathSepB;\n }\n if (this._buf[0] !== pathSep) {\n const bytes = new Uint8Array(this._buf.byteLength + 1);\n bytes.fill(pathSep, 0, 1);\n bytes.set(this._buf, 1);\n this._buf = bytes;\n }\n // normalize does not remove trailing slashes\n while(this._buf.byteLength > 1 && this._buf[this._buf.byteLength - 1] === pathSep){\n this._buf = this._buf.subarray(0, -1);\n }\n }\n /**\n * Check if the given key is sorted lower than ourself.\n *\n * @param {Key} key - The other Key to check against\n * @returns {boolean}\n */ less(key) {\n const list1 = this.list();\n const list2 = key.list();\n for(let i = 0; i < list1.length; i++){\n if (list2.length < i + 1) {\n return false;\n }\n const c1 = list1[i];\n const c2 = list2[i];\n if (c1 < c2) {\n return true;\n } else if (c1 > c2) {\n return false;\n }\n }\n return list1.length < list2.length;\n }\n /**\n * Returns the key with all parts in reversed order.\n *\n * @returns {Key}\n *\n * @example\n * ```js\n * new Key('/Comedy/MontyPython/Actor:JohnCleese').reverse()\n * // => Key('/Actor:JohnCleese/MontyPython/Comedy')\n * ```\n */ reverse() {\n return Key.withNamespaces(this.list().slice().reverse());\n }\n /**\n * Returns the `namespaces` making up this Key.\n *\n * @returns {Array<string>}\n */ namespaces() {\n return this.list();\n }\n /** Returns the \"base\" namespace of this key.\n *\n * @returns {string}\n *\n * @example\n * ```js\n * new Key('/Comedy/MontyPython/Actor:JohnCleese').baseNamespace()\n * // => 'Actor:JohnCleese'\n * ```\n */ baseNamespace() {\n const ns = this.namespaces();\n return ns[ns.length - 1];\n }\n /**\n * Returns the `list` representation of this key.\n *\n * @returns {Array<string>}\n *\n * @example\n * ```js\n * new Key('/Comedy/MontyPython/Actor:JohnCleese').list()\n * // => ['Comedy', 'MontyPythong', 'Actor:JohnCleese']\n * ```\n */ list() {\n return this.toString().split(pathSepS).slice(1);\n }\n /**\n * Returns the \"type\" of this key (value of last namespace).\n *\n * @returns {string}\n *\n * @example\n * ```js\n * new Key('/Comedy/MontyPython/Actor:JohnCleese').type()\n * // => 'Actor'\n * ```\n */ type() {\n return namespaceType(this.baseNamespace());\n }\n /**\n * Returns the \"name\" of this key (field of last namespace).\n *\n * @returns {string}\n *\n * @example\n * ```js\n * new Key('/Comedy/MontyPython/Actor:JohnCleese').name()\n * // => 'JohnCleese'\n * ```\n */ name() {\n return namespaceValue(this.baseNamespace());\n }\n /**\n * Returns an \"instance\" of this type key (appends value to namespace).\n *\n * @param {string} s - The string to append.\n * @returns {Key}\n *\n * @example\n * ```js\n * new Key('/Comedy/MontyPython/Actor').instance('JohnClesse')\n * // => Key('/Comedy/MontyPython/Actor:JohnCleese')\n * ```\n */ instance(s) {\n return new Key(this.toString() + \":\" + s);\n }\n /**\n * Returns the \"path\" of this key (parent + type).\n *\n * @returns {Key}\n *\n * @example\n * ```js\n * new Key('/Comedy/MontyPython/Actor:JohnCleese').path()\n * // => Key('/Comedy/MontyPython/Actor')\n * ```\n */ path() {\n let p = this.parent().toString();\n if (!p.endsWith(pathSepS)) {\n p += pathSepS;\n }\n p += this.type();\n return new Key(p);\n }\n /**\n * Returns the `parent` Key of this Key.\n *\n * @returns {Key}\n *\n * @example\n * ```js\n * new Key(\"/Comedy/MontyPython/Actor:JohnCleese\").parent()\n * // => Key(\"/Comedy/MontyPython\")\n * ```\n */ parent() {\n const list = this.list();\n if (list.length === 1) {\n return new Key(pathSepS);\n }\n return new Key(list.slice(0, -1).join(pathSepS));\n }\n /**\n * Returns the `child` Key of this Key.\n *\n * @param {Key} key - The child Key to add\n * @returns {Key}\n *\n * @example\n * ```js\n * new Key('/Comedy/MontyPython').child(new Key('Actor:JohnCleese'))\n * // => Key('/Comedy/MontyPython/Actor:JohnCleese')\n * ```\n */ child(key) {\n if (this.toString() === pathSepS) {\n return key;\n } else if (key.toString() === pathSepS) {\n return this;\n }\n return new Key(this.toString() + key.toString(), false);\n }\n /**\n * Returns whether this key is a prefix of `other`\n *\n * @param {Key} other - The other key to test against\n * @returns {boolean}\n *\n * @example\n * ```js\n * new Key('/Comedy').isAncestorOf('/Comedy/MontyPython')\n * // => true\n * ```\n */ isAncestorOf(other) {\n if (other.toString() === this.toString()) {\n return false;\n }\n return other.toString().startsWith(this.toString());\n }\n /**\n * Returns whether this key is a contains another as prefix.\n *\n * @param {Key} other - The other Key to test against\n * @returns {boolean}\n *\n * @example\n * ```js\n * new Key('/Comedy/MontyPython').isDecendantOf('/Comedy')\n * // => true\n * ```\n */ isDecendantOf(other) {\n if (other.toString() === this.toString()) {\n return false;\n }\n return this.toString().startsWith(other.toString());\n }\n /**\n * Checks if this key has only one namespace.\n *\n * @returns {boolean}\n */ isTopLevel() {\n return this.list().length === 1;\n }\n /**\n * Concats one or more Keys into one new Key.\n *\n * @param {Array<Key>} keys - The array of keys to concatenate\n * @returns {Key}\n */ concat(...keys) {\n return Key.withNamespaces([\n ...this.namespaces(),\n ...flatten(keys.map((key)=>key.namespaces()))\n ]);\n }\n}\n/**\n * The first component of a namespace. `foo` in `foo:bar`\n *\n * @param {string} ns\n * @returns {string}\n */ function namespaceType(ns) {\n const parts = ns.split(\":\");\n if (parts.length < 2) {\n return \"\";\n }\n return parts.slice(0, -1).join(\":\");\n}\n/**\n * The last component of a namespace, `baz` in `foo:bar:baz`.\n *\n * @param {string} ns\n * @returns {string}\n */ function namespaceValue(ns) {\n const parts = ns.split(\":\");\n return parts[parts.length - 1];\n}\n/**\n * Flatten array of arrays (only one level)\n *\n * @template T\n * @param {Array<any>} arr\n * @returns {T[]}\n */ function flatten(arr) {\n return [].concat(...arr);\n} //# sourceMappingURL=key.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"(ssr)/./node_modules/interface-datastore/dist/src/key.js","mappings":"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","sources":["webpack://flush-notes/./node_modules/interface-datastore/dist/src/key.js?7da7"],"sourcesContent":["import { fromString as uint8ArrayFromString } from 'uint8arrays/from-string';\nimport { toString as uint8ArrayToString } from 'uint8arrays/to-string';\nconst pathSepS = '/';\nconst pathSepB = new TextEncoder().encode(pathSepS);\nconst pathSep = pathSepB[0];\n/**\n * A Key represents the unique identifier of an object.\n * Our Key scheme is inspired by file systems and Google App Engine key model.\n * Keys are meant to be unique across a system. Keys are hierarchical,\n * incorporating more and more specific namespaces. Thus keys can be deemed\n * 'children' or 'ancestors' of other keys:\n * - `new Key('/Comedy')`\n * - `new Key('/Comedy/MontyPython')`\n * Also, every namespace can be parametrized to embed relevant object\n * information. For example, the Key `name` (most specific namespace) could\n * include the object type:\n * - `new Key('/Comedy/MontyPython/Actor:JohnCleese')`\n * - `new Key('/Comedy/MontyPython/Sketch:CheeseShop')`\n * - `new Key('/Comedy/MontyPython/Sketch:CheeseShop/Character:Mousebender')`\n *\n */\nexport class Key {\n    _buf;\n    /**\n     * @param {string | Uint8Array} s\n     * @param {boolean} [clean]\n     */\n    constructor(s, clean) {\n        if (typeof s === 'string') {\n            this._buf = uint8ArrayFromString(s);\n        }\n        else if (s instanceof Uint8Array) {\n            this._buf = s;\n        }\n        else {\n            throw new Error('Invalid key, should be String of Uint8Array');\n        }\n        if (clean == null) {\n            clean = true;\n        }\n        if (clean) {\n            this.clean();\n        }\n        if (this._buf.byteLength === 0 || this._buf[0] !== pathSep) {\n            throw new Error('Invalid key');\n        }\n    }\n    /**\n     * Convert to the string representation\n     *\n     * @param {import('uint8arrays/to-string').SupportedEncodings} [encoding='utf8'] - The encoding to use.\n     * @returns {string}\n     */\n    toString(encoding = 'utf8') {\n        return uint8ArrayToString(this._buf, encoding);\n    }\n    /**\n     * Return the Uint8Array representation of the key\n     *\n     * @returns {Uint8Array}\n     */\n    uint8Array() {\n        return this._buf;\n    }\n    /**\n     * Return string representation of the key\n     *\n     * @returns {string}\n     */\n    get [Symbol.toStringTag]() {\n        return `Key(${this.toString()})`;\n    }\n    /**\n     * Constructs a key out of a namespace array.\n     *\n     * @param {Array<string>} list - The array of namespaces\n     * @returns {Key}\n     *\n     * @example\n     * ```js\n     * Key.withNamespaces(['one', 'two'])\n     * // => Key('/one/two')\n     * ```\n     */\n    static withNamespaces(list) {\n        return new Key(list.join(pathSepS));\n    }\n    /**\n     * Returns a randomly (uuid) generated key.\n     *\n     * @returns {Key}\n     *\n     * @example\n     * ```js\n     * Key.random()\n     * // => Key('/344502982398')\n     * ```\n     */\n    static random() {\n        return new Key(Math.random().toString().substring(2));\n    }\n    /**\n     * @param {*} other\n     */\n    static asKey(other) {\n        if (other instanceof Uint8Array || typeof other === 'string') {\n            // we can create a key from this\n            return new Key(other);\n        }\n        if (typeof other.uint8Array === 'function') {\n            // this is an older version or may have crossed the esm/cjs boundary\n            return new Key(other.uint8Array());\n        }\n        return null;\n    }\n    /**\n     * Cleanup the current key\n     *\n     * @returns {void}\n     */\n    clean() {\n        if (this._buf == null || this._buf.byteLength === 0) {\n            this._buf = pathSepB;\n        }\n        if (this._buf[0] !== pathSep) {\n            const bytes = new Uint8Array(this._buf.byteLength + 1);\n            bytes.fill(pathSep, 0, 1);\n            bytes.set(this._buf, 1);\n            this._buf = bytes;\n        }\n        // normalize does not remove trailing slashes\n        while (this._buf.byteLength > 1 && this._buf[this._buf.byteLength - 1] === pathSep) {\n            this._buf = this._buf.subarray(0, -1);\n        }\n    }\n    /**\n     * Check if the given key is sorted lower than ourself.\n     *\n     * @param {Key} key - The other Key to check against\n     * @returns {boolean}\n     */\n    less(key) {\n        const list1 = this.list();\n        const list2 = key.list();\n        for (let i = 0; i < list1.length; i++) {\n            if (list2.length < i + 1) {\n                return false;\n            }\n            const c1 = list1[i];\n            const c2 = list2[i];\n            if (c1 < c2) {\n                return true;\n            }\n            else if (c1 > c2) {\n                return false;\n            }\n        }\n        return list1.length < list2.length;\n    }\n    /**\n     * Returns the key with all parts in reversed order.\n     *\n     * @returns {Key}\n     *\n     * @example\n     * ```js\n     * new Key('/Comedy/MontyPython/Actor:JohnCleese').reverse()\n     * // => Key('/Actor:JohnCleese/MontyPython/Comedy')\n     * ```\n     */\n    reverse() {\n        return Key.withNamespaces(this.list().slice().reverse());\n    }\n    /**\n     * Returns the `namespaces` making up this Key.\n     *\n     * @returns {Array<string>}\n     */\n    namespaces() {\n        return this.list();\n    }\n    /** Returns the \"base\" namespace of this key.\n     *\n     * @returns {string}\n     *\n     * @example\n     * ```js\n     * new Key('/Comedy/MontyPython/Actor:JohnCleese').baseNamespace()\n     * // => 'Actor:JohnCleese'\n     * ```\n     */\n    baseNamespace() {\n        const ns = this.namespaces();\n        return ns[ns.length - 1];\n    }\n    /**\n     * Returns the `list` representation of this key.\n     *\n     * @returns {Array<string>}\n     *\n     * @example\n     * ```js\n     * new Key('/Comedy/MontyPython/Actor:JohnCleese').list()\n     * // => ['Comedy', 'MontyPythong', 'Actor:JohnCleese']\n     * ```\n     */\n    list() {\n        return this.toString().split(pathSepS).slice(1);\n    }\n    /**\n     * Returns the \"type\" of this key (value of last namespace).\n     *\n     * @returns {string}\n     *\n     * @example\n     * ```js\n     * new Key('/Comedy/MontyPython/Actor:JohnCleese').type()\n     * // => 'Actor'\n     * ```\n     */\n    type() {\n        return namespaceType(this.baseNamespace());\n    }\n    /**\n     * Returns the \"name\" of this key (field of last namespace).\n     *\n     * @returns {string}\n     *\n     * @example\n     * ```js\n     * new Key('/Comedy/MontyPython/Actor:JohnCleese').name()\n     * // => 'JohnCleese'\n     * ```\n     */\n    name() {\n        return namespaceValue(this.baseNamespace());\n    }\n    /**\n     * Returns an \"instance\" of this type key (appends value to namespace).\n     *\n     * @param {string} s - The string to append.\n     * @returns {Key}\n     *\n     * @example\n     * ```js\n     * new Key('/Comedy/MontyPython/Actor').instance('JohnClesse')\n     * // => Key('/Comedy/MontyPython/Actor:JohnCleese')\n     * ```\n     */\n    instance(s) {\n        return new Key(this.toString() + ':' + s);\n    }\n    /**\n     * Returns the \"path\" of this key (parent + type).\n     *\n     * @returns {Key}\n     *\n     * @example\n     * ```js\n     * new Key('/Comedy/MontyPython/Actor:JohnCleese').path()\n     * // => Key('/Comedy/MontyPython/Actor')\n     * ```\n     */\n    path() {\n        let p = this.parent().toString();\n        if (!p.endsWith(pathSepS)) {\n            p += pathSepS;\n        }\n        p += this.type();\n        return new Key(p);\n    }\n    /**\n     * Returns the `parent` Key of this Key.\n     *\n     * @returns {Key}\n     *\n     * @example\n     * ```js\n     * new Key(\"/Comedy/MontyPython/Actor:JohnCleese\").parent()\n     * // => Key(\"/Comedy/MontyPython\")\n     * ```\n     */\n    parent() {\n        const list = this.list();\n        if (list.length === 1) {\n            return new Key(pathSepS);\n        }\n        return new Key(list.slice(0, -1).join(pathSepS));\n    }\n    /**\n     * Returns the `child` Key of this Key.\n     *\n     * @param {Key} key - The child Key to add\n     * @returns {Key}\n     *\n     * @example\n     * ```js\n     * new Key('/Comedy/MontyPython').child(new Key('Actor:JohnCleese'))\n     * // => Key('/Comedy/MontyPython/Actor:JohnCleese')\n     * ```\n     */\n    child(key) {\n        if (this.toString() === pathSepS) {\n            return key;\n        }\n        else if (key.toString() === pathSepS) {\n            return this;\n        }\n        return new Key(this.toString() + key.toString(), false);\n    }\n    /**\n     * Returns whether this key is a prefix of `other`\n     *\n     * @param {Key} other - The other key to test against\n     * @returns {boolean}\n     *\n     * @example\n     * ```js\n     * new Key('/Comedy').isAncestorOf('/Comedy/MontyPython')\n     * // => true\n     * ```\n     */\n    isAncestorOf(other) {\n        if (other.toString() === this.toString()) {\n            return false;\n        }\n        return other.toString().startsWith(this.toString());\n    }\n    /**\n     * Returns whether this key is a contains another as prefix.\n     *\n     * @param {Key} other - The other Key to test against\n     * @returns {boolean}\n     *\n     * @example\n     * ```js\n     * new Key('/Comedy/MontyPython').isDecendantOf('/Comedy')\n     * // => true\n     * ```\n     */\n    isDecendantOf(other) {\n        if (other.toString() === this.toString()) {\n            return false;\n        }\n        return this.toString().startsWith(other.toString());\n    }\n    /**\n     * Checks if this key has only one namespace.\n     *\n     * @returns {boolean}\n     */\n    isTopLevel() {\n        return this.list().length === 1;\n    }\n    /**\n     * Concats one or more Keys into one new Key.\n     *\n     * @param {Array<Key>} keys - The array of keys to concatenate\n     * @returns {Key}\n     */\n    concat(...keys) {\n        return Key.withNamespaces([...this.namespaces(), ...flatten(keys.map(key => key.namespaces()))]);\n    }\n}\n/**\n * The first component of a namespace. `foo` in `foo:bar`\n *\n * @param {string} ns\n * @returns {string}\n */\nfunction namespaceType(ns) {\n    const parts = ns.split(':');\n    if (parts.length < 2) {\n        return '';\n    }\n    return parts.slice(0, -1).join(':');\n}\n/**\n * The last component of a namespace, `baz` in `foo:bar:baz`.\n *\n * @param {string} ns\n * @returns {string}\n */\nfunction namespaceValue(ns) {\n    const parts = ns.split(':');\n    return parts[parts.length - 1];\n}\n/**\n * Flatten array of arrays (only one level)\n *\n * @template T\n * @param {Array<any>} arr\n * @returns {T[]}\n */\nfunction flatten(arr) {\n    return ([]).concat(...arr);\n}\n//# sourceMappingURL=key.js.map"],"names":["fromString","uint8ArrayFromString","toString","uint8ArrayToString","pathSepS","pathSepB","TextEncoder","encode","pathSep","Key","constructor","s","clean","_buf","Uint8Array","Error","byteLength","encoding","uint8Array","Symbol","toStringTag","withNamespaces","list","join","random","Math","substring","asKey","other","bytes","fill","set","subarray","less","key","list1","list2","i","length","c1","c2","reverse","slice","namespaces","baseNamespace","ns","split","type","namespaceType","name","namespaceValue","instance","path","p","parent","endsWith","child","isAncestorOf","startsWith","isDecendantOf","isTopLevel","concat","keys","flatten","map","parts","arr"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/interface-datastore/dist/src/key.js\n");
/***/ })
};
;