zeed 0.7.97 → 0.7.98
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/chunk-7JBAYE5X.js +7 -0
- package/dist/{chunk-7YV5VFZP.js.map → chunk-7JBAYE5X.js.map} +1 -1
- package/dist/chunk-7Y3767YF.js +5 -0
- package/dist/chunk-7Y3767YF.js.map +1 -0
- package/dist/{chunk-JL5GA55T.js → chunk-GLNZJHZB.js} +2 -2
- package/dist/{chunk-JL5GA55T.js.map → chunk-GLNZJHZB.js.map} +1 -1
- package/dist/chunk-JGD3KNXY.js +2 -0
- package/dist/{chunk-LNZLD7Y3.js.map → chunk-JGD3KNXY.js.map} +1 -1
- package/dist/{chunk-H5ICAAIH.js → chunk-Z6YJI5EY.js} +2 -2
- package/dist/{chunk-H5ICAAIH.js.map → chunk-Z6YJI5EY.js.map} +1 -1
- package/dist/index.all.cjs +9 -9
- package/dist/index.all.cjs.map +1 -1
- package/dist/index.all.d.ts +3 -3
- package/dist/index.all.js +1 -1
- package/dist/index.browser.cjs +4 -4
- package/dist/index.browser.cjs.map +1 -1
- package/dist/index.browser.d.ts +2 -2
- package/dist/index.browser.js +1 -1
- package/dist/index.log.cjs +1 -1
- package/dist/index.log.cjs.map +1 -1
- package/dist/index.log.js +1 -1
- package/dist/index.node.cjs +9 -9
- package/dist/index.node.cjs.map +1 -1
- package/dist/index.node.d.ts +2 -2
- package/dist/index.node.js +1 -1
- package/dist/{log-colors-1600acaa.d.ts → log-colors-b7e5d323.d.ts} +1 -1
- package/dist/{log-util-0c3d62ff.d.ts → log-util-4271fe11.d.ts} +1 -1
- package/dist/{uuid-349b7a26.d.ts → uuid-6c269ea2.d.ts} +3 -1
- package/package.json +1 -1
- package/dist/chunk-7YV5VFZP.js +0 -7
- package/dist/chunk-BHQJ5YK3.js +0 -5
- package/dist/chunk-BHQJ5YK3.js.map +0 -1
- package/dist/chunk-LNZLD7Y3.js +0 -2
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import{Xa as K,ib as j,oa as $}from"./chunk-7Y3767YF.js";import{c as l,q as T,r as F,s as m,x,y as P,z as _}from"./chunk-JGD3KNXY.js";import O from"fs";import{resolve as ae}from"path";var L=x("zeed:env"),ce=`
|
|
2
|
+
`,fe=/^\s*([\w_.-]+)\s*=\s*(.*)?\s*$/,ge=/\\n/g,ue=/\n|\r|\r\n/;function U(e,t={}){let r={};return e.toString().split(ue).forEach(function(n,i){let o=n.match(fe);if(o!=null){let c=o[1],s=o[2]||"",g=s.length-1,p=s[0]==='"'&&s[g]==='"';s[0]==="'"&&s[g]==="'"||p?(s=s.substring(1,g),p&&(s=s.replace(ge,ce))):s=s.trim(),r[c]=s}else L.debug(`did not match key and value when parsing line ${i+1}: ${n}`)}),r}l(U,"parse");function me(e,t="."){return ae(process.cwd(),e!=null?e:t)}l(me,"stringToPath");function de(e,t=""){return e==null&&(e=t),me(String(e).trim(),t)}l(de,"valueToPath");var R=de;function Ie(e={}){var i,o,c,s;let t=(o=e==null?void 0:e.path)!=null?o:R((i=e==null?void 0:e.filename)!=null?i:".env"),r=(c=e==null?void 0:e.encoding)!=null?c:"utf8",n=(e==null?void 0:e.debug)||!1;n!==!0&&(L.level=1/0);try{let g=O.existsSync(t)?U(O.readFileSync(t,{encoding:r}),{debug:n}):{},p=O.existsSync(t+".local")?U(O.readFileSync(t+".local",{encoding:r}),{debug:n}):{},y=Object.assign({},g,p),f=(s=e==null?void 0:e.env)!=null?s:process.env;return Object.entries(y).forEach(([u,d])=>{typeof(e==null?void 0:e.prefix)=="string"&&(u=(e==null?void 0:e.prefix)+u),Object.prototype.hasOwnProperty.call(f,u)?L.debug(`"${u}" is already defined and will not be overwritten`):d!=null&&(L.info(`set env.${u} = ${d}`),f[u]=d)}),{parsed:y}}catch(g){return L.error(g),{error:g}}}l(Ie,"setupEnv");import{mkdirSync as pe,readdirSync as he,readFileSync as Y,rmSync as ye,unlinkSync as be,writeFileSync as Se}from"fs";import{dirname as ve,resolve as J}from"path";var B=x("zeed:filestorage"),Q=class{constructor(t={}){this.store={};this.fileKeys=void 0;this.pretty=!1;var r,n,i,o;this.dirname=J(process.cwd(),t.path||".fileStorage"),this.pretty=!!t.pretty,this.extension=(r=t.extension)!=null?r:".json",t.extension&&!this.extension.startsWith(".")&&(this.extension="."+this.extension),this.extensionLength=this.extension.length,this.objectToString=(n=t.objectToString)!=null?n:c=>this.pretty?JSON.stringify(c,null,2):JSON.stringify(c),this.objectFromString=(i=t.objectFromString)!=null?i:c=>{try{return JSON.parse(c)}catch(s){B.warn(`fileStorage parse error '${s}' in`,c)}},this.keyToFilename=(o=t.keyToFilename)!=null?o:K}setItem(t,r){this.store[t]=j(r);try{let n=this.objectToString(r),i=this.getPath(t);pe(ve(i),{recursive:!0}),Se(i,n,"utf8")}catch(n){B.error("setItem error",n)}}getPath(t){return J(this.dirname,this.keyToFilename(t)+this.extension)}getBuffer(t){let r=this.getPath(t);return Buffer.from(Y(r))}getItem(t){let r=this.store[t];if(r!==null){if(r!=null)return j(r);try{let n=this.getPath(t),i=Y(n,"utf8");if(i!=null){let o=this.objectFromString(i);return this.store[t]=o,o}}catch(n){B.warn("getItem error",n),this.store[t]=null}}}removeItem(t){if(delete this.store[t],this.fileKeys!=null){let r=this.fileKeys.indexOf(t);r!==-1&&this.fileKeys.splice(r,1)}try{let r=this.getPath(t);be(r)}catch{}}clear(){this.fileKeys=[],this.store={},ye(this.dirname,{recursive:!0,force:!0})}allKeys(){if(this.fileKeys==null)try{this.fileKeys=he(this.dirname,{withFileTypes:!0}).filter(r=>!r.isDirectory()&&r.name.endsWith(this.extension)).map(r=>r.name.slice(0,-this.extensionLength))||[]}catch{}let t=[...this.fileKeys||[]];for(let r of Object.keys(this.store))t.includes(r)||t.push(r);return t.sort(),t}};l(Q,"FileStorage");import{createWriteStream as xe,mkdirSync as Le}from"fs";import{dirname as Ee,resolve as we}from"path";var z={};function V(e,t={}){let{level:r=-1,filter:n="*"}=t;e=we(process.cwd(),e),Le(Ee(e),{recursive:!0});var i=xe(e,{flags:"a"});let o=T(n),c=F(r);return s=>{if(!c(s.level)||!o(s.name))return;let g=new Date().toISOString(),p=s.name||"",y=z[p||""];y==null&&(z[p]=y);let f=[`[${p||"*"}]`,$(s.messages,{pretty:!1})];function u(...d){i.write(d.join(" ")+`
|
|
3
|
+
`)}switch(l(u,"write"),s.level){case 1:u(g,"I|* ",...f);break;case 2:u(g,"W|** ",...f);break;case 3:u(g,"E|***",...f);break;default:u(g,"D| ",...f);break}}}l(V,"LoggerFileHandler");import{resolve as Z}from"path";function Ne(e){var t,r;return typeof e!="string"?[]:((r=(t=e==null?void 0:e.split(`
|
|
4
|
+
`))==null?void 0:t.map(n=>{let i=n.match(/^\s+at.*(\((.*)\)|file:\/\/(.*)$)/);if(i){let o=i[3]||i[2];return o.endsWith(")")&&(o=o.slice(0,-1)),o}}))==null?void 0:r.filter(n=>n!=null))||[]}l(Ne,"getStackLlocationList");var D=Z(process.cwd()),ee,te,H=((ee=process.env)==null?void 0:ee.HOME)?Z((te=process.env)==null?void 0:te.HOME):"";function q(e){if(e.includes("/node_modules/"))return"";let t="file://";return e.startsWith(t)?e.substr(t.length):D&&e.startsWith(D)?e.substr(D.length+1):(H&&e.startsWith(H)&&(e="~/"+e.substr(H.length+1)),e)}l(q,"pathStripCwd");function Te(e){let t=e.match(/^\s*at.*(\((.*)\)|file:\/\/(.*)$)/);if(t){let r=t[3]||t[2];return r.endsWith(")")&&(r=r.slice(0,-1)),r}return""}l(Te,"extractFileInfo");function I(e=2,t=!0){var i;let r=new Error().stack||"",n=(i=Ne(r))==null?void 0:i[e];return n&&t&&(n=q(n)),n||""}l(I,"getSourceLocation");function X(){return new Error().stack||""}l(X,"getStack");function C(e,t=!0){let r="",n=new Error().stack||"";if(typeof n=="string"){let i=n.split(`
|
|
5
|
+
`).map(c=>c.trim()),o=i.findIndex(c=>e.some(s=>c.startsWith(s)));r=i[o+1],r&&(r=Te(r)),r&&t&&(r=q(r))}return r}l(C,"getSourceLocationByPrecedingPattern");import re from"tty";function Fe(){try{return re.isatty(process.stdout.fd)}catch{}return!1}l(Fe,"isTTY");var ne=[6,2,3,4,5,1];function $e(e){let t=0;for(let r=0;r<e.length;r++)t=(t<<5)-t+e.charCodeAt(r),t|=0;return ne[Math.abs(t)%ne.length]}l($e,"selectColor");var ie={},Oe=P(),W=re.isatty(process.stderr.fd);function k(...e){return process.stderr.write($(e)+`
|
|
6
|
+
`)}l(k,"log");var E={BOLD:"[1m",UNBOLD:"[2m",RED:"[31m",GREEN:"[32m",BLUE:"[34m",PURPLE:"[35m",GRAY:"[37m",ORANGE:"[38;5;208m",UNCOLOR:"[0m"};var se="[0m";function w(e,t){return`${t===8?E.ORANGE:"[3"+(t<8?t:"8;5;"+t)+"m"}${e}${se}`}l(w,"colorString");function oe(e,t,r=!0){return e.map(n=>{if(typeof n!="string")return n;let i=t,o=se;return r&&(i=`${E.BOLD}${i}`,o=`${o}${E.BOLD}`),`${i}${n}${o}`})}l(oe,"colorStringList");var ke="loggerStackTraceDebug-7d38e5a9214b58d29734374cdb9521fd964d7485";function le(e={}){let{level:t=void 0,filter:r=void 0,colors:n=Fe(),levelHelper:i=!0,nameBrackets:o=!0,padding:c=0,fill:s=0,stack:g=!0}=e,p=T(r),y=F(t);return f=>{var M;if(!y(f.level)||!p(f.name))return;let u=P(),d=f.name||"",N=ie[d||""];N==null&&(N={color:$e(d)},ie[d]=N);let G=_(u-Oe),a,v=o?`[${d}]`:d;if(c>0&&(v=v.padStart(c," ")),s>0&&(v=v.padEnd(s," ")),n&&W){let h=N.color;a=[w(v,h)+" | "],f.level===2?a.push(...oe(f.messages,E.ORANGE)):f.level===3?a.push(...oe(f.messages,E.RED)):a.push(...f.messages),a.push(w(`+${G}`,h))}else a=[v,...f.messages],a.push(`+${G}`);if(((M=f.messages)==null?void 0:M[0])===ke&&console.log(X()),g){let h="";typeof g=="boolean"?(h=C(["at Function.","at null.log (","at log ("],!0),h||(h=I(0,!0))):h=I(typeof g=="number"?g:3,!0),h&&a.push(w(`(${h})`,7))}switch(f.level){case 1:i&&(a[0]="I|* "+a[0]),k(...a);break;case 2:i&&(a[0]=(n&&W?w("W|** ",8):"W|** ")+a[0]),k(...a);break;case 3:i&&(a[0]=(n&&W?w("E|*** ",1):"E|*** ")+a[0]),k(...a);break;default:i&&(a[0]="D| "+a[0]),k(...a);break}}}l(le,"LoggerNodeHandler");import A from"crypto";try{A&&A.webcrypto&&typeof globalThis!="undefined"&&typeof globalThis.crypto=="undefined"&&(globalThis.crypto=A.webcrypto)}catch(e){console.warn("Failed to polyfill webcrypto",e)}function je(){var r;let e=[le({padding:32,nameBrackets:!1})],t=(r=process.env.ZEED_LOG)!=null?r:process.env.LOG;t&&e.unshift(V(R(t))),x.setHandlers(e)}l(je,"setupLogContextNode");je();export{me as a,de as b,R as c,Ie as d,Q as e,V as f,Ne as g,I as h,X as i,C as j,Fe as k,w as l,oe as m,ke as n,le as o};
|
|
7
|
+
//# sourceMappingURL=chunk-7JBAYE5X.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/node/env.ts","../src/node/filestorage.ts","../src/node/log-file.ts","../src/node/log-util.ts","../src/node/log-node.ts","../src/node/crypto.ts","../src/node/log-context-node.ts"],"sourcesContent":["// (C)opyright 2021-07-15 Dirk Holtwick, holtwick.it. All rights reserved.\n\n// Adopted from https://github.com/motdotla/dotenv BSD-2\n\nimport { LogLevel } from \"../common/log-base\"\nimport { Logger } from \"../common/log\"\n\nimport fs from \"fs\"\nimport { resolve } from \"path\"\n\nconst log = Logger(\"zeed:env\")\n\nconst NEWLINE = \"\\n\"\nconst RE_INI_KEY_VAL = /^\\s*([\\w_.-]+)\\s*=\\s*(.*)?\\s*$/\nconst RE_NEWLINES = /\\\\n/g\nconst NEWLINES_MATCH = /\\n|\\r|\\r\\n/\n\ntype csvOptions = {\n /** @deprecated will probably be replaced by logLevel */\n debug?: boolean\n path?: string\n filename?: string\n encoding?: BufferEncoding\n prefix?: string\n env?: Record<string, string>\n}\n\n// Parses src into an Object\nfunction parse(src: string, options: csvOptions = {}) {\n let obj: Record<string, string> = {}\n\n // convert Buffers before splitting into lines and processing\n src\n .toString()\n .split(NEWLINES_MATCH)\n .forEach(function (line, idx) {\n // matching \"KEY' and 'VAL' in 'KEY=VAL'\n const keyValueArr = line.match(RE_INI_KEY_VAL)\n // matched?\n\n // log.debug(\"keyValueArr\", keyValueArr)\n\n if (keyValueArr != null) {\n const key = keyValueArr[1]\n // default undefined or missing values to empty string\n let val = keyValueArr[2] || \"\"\n const end = val.length - 1\n const isDoubleQuoted = val[0] === '\"' && val[end] === '\"'\n const isSingleQuoted = val[0] === \"'\" && val[end] === \"'\"\n\n // if single or double quoted, remove quotes\n if (isSingleQuoted || isDoubleQuoted) {\n val = val.substring(1, end)\n\n // if double quoted, expand newlines\n if (isDoubleQuoted) {\n val = val.replace(RE_NEWLINES, NEWLINE)\n }\n } else {\n // remove surrounding whitespace\n val = val.trim()\n }\n obj[key] = val\n } else {\n log.debug(\n `did not match key and value when parsing line ${idx + 1}: ${line}`\n )\n }\n })\n\n // log.debug(\"obj\", obj)\n return obj\n}\n\n/**\n * Return a path relative to the current working directory\n */\nexport function stringToPath(\n value?: string,\n defaultValue: string = \".\"\n): string {\n return resolve(process.cwd(), value ?? defaultValue)\n}\n\nexport function valueToPath(value?: any, defaultValue = \"\"): string {\n if (value == null) value = defaultValue\n return stringToPath(String(value).trim(), defaultValue)\n}\n\nexport const toPath = valueToPath\n\n// Populates process.env from .env file\nexport function setupEnv(options: csvOptions = {}) {\n const dotenvPath: string =\n options?.path ?? toPath(options?.filename ?? \".env\")\n const encoding: BufferEncoding = options?.encoding ?? \"utf8\"\n const debug = options?.debug || false\n\n if (debug !== true) log.level = LogLevel.off\n\n try {\n // specifying an encoding returns a string instead of a buffer\n const parsedEnv = fs.existsSync(dotenvPath)\n ? parse(fs.readFileSync(dotenvPath, { encoding }), { debug })\n : {}\n const parsedEnvLocal = fs.existsSync(dotenvPath + \".local\")\n ? parse(fs.readFileSync(dotenvPath + \".local\", { encoding }), { debug })\n : {}\n\n const parsed: Record<string, string> = Object.assign(\n {},\n parsedEnv,\n parsedEnvLocal\n )\n let env = options?.env ?? process.env\n\n Object.entries(parsed).forEach(([key, value]) => {\n if (typeof options?.prefix === \"string\") {\n key = options?.prefix + key\n }\n if (!Object.prototype.hasOwnProperty.call(env, key)) {\n if (value != null) {\n log.info(`set env.${key} = ${value}`)\n env[key] = value\n }\n } else {\n log.debug(`\"${key}\" is already defined and will not be overwritten`)\n }\n })\n return { parsed }\n } catch (e) {\n log.error(e)\n return { error: e }\n }\n}\n","// (C)opyright 2021-07-15 Dirk Holtwick, holtwick.it. All rights reserved.\n\nimport {\n mkdirSync,\n readdirSync,\n readFileSync,\n rmSync,\n unlinkSync,\n writeFileSync,\n} from \"fs\"\nimport { dirname, resolve } from \"path\"\nimport { toValidFilename } from \"../common/data/path\"\nimport { cloneObject } from \"../common/data/utils\"\nimport { Logger } from \"../common/log\"\nimport { Json, ObjectStorage } from \"../common/types\"\n\nconst log = Logger(\"zeed:filestorage\")\n\nexport interface FileStorageOptions {\n pretty?: boolean\n path?: string\n extension?: string\n objectFromString?: (data: string) => any\n objectToString?: (data: any) => string\n keyToFilename?: (key: string) => string\n}\n\nexport class FileStorage<T = Json> implements ObjectStorage<T> {\n private store: Record<string, T | null> = {}\n private dirname: string\n private fileKeys?: string[] = undefined\n private pretty: boolean = false\n private extension: string\n private extensionLength: number\n private objectFromString: (data: string) => any\n private objectToString: (data: any) => string\n private keyToFilename: (key: string) => string\n\n constructor(opt: FileStorageOptions = {}) {\n this.dirname = resolve(process.cwd(), opt.path || \".fileStorage\")\n this.pretty = !!opt.pretty\n this.extension = opt.extension ?? \".json\"\n\n if (opt.extension && !this.extension.startsWith(\".\")) {\n this.extension = \".\" + this.extension\n }\n this.extensionLength = this.extension.length\n\n this.objectToString =\n opt.objectToString ??\n ((data: any): string => {\n return this.pretty\n ? JSON.stringify(data, null, 2)\n : JSON.stringify(data)\n })\n\n this.objectFromString =\n opt.objectFromString ??\n ((data: string) => {\n try {\n return JSON.parse(data)\n } catch (err) {\n log.warn(`fileStorage parse error '${err}' in`, data)\n }\n })\n\n this.keyToFilename = opt.keyToFilename ?? toValidFilename\n }\n\n setItem(key: string, value: T): void {\n this.store[key] = cloneObject(value)\n try {\n const data = this.objectToString(value)\n const path = this.getPath(key)\n mkdirSync(dirname(path), { recursive: true })\n writeFileSync(path, data, \"utf8\")\n } catch (err) {\n log.error(\"setItem error\", err)\n }\n }\n\n getPath(key: string): string {\n return resolve(this.dirname, this.keyToFilename(key) + this.extension)\n }\n\n getBuffer(key: string): Buffer {\n const path = this.getPath(key)\n return Buffer.from(readFileSync(path))\n }\n\n getItem(key: string): T | undefined {\n let value = this.store[key]\n\n // null is an indicator for not existing!\n if (value === null) return\n\n if (value != null) {\n return cloneObject(value) // this.objectFromString(value)\n }\n\n try {\n const path = this.getPath(key)\n const data = readFileSync(path, \"utf8\")\n if (data != null) {\n const value = this.objectFromString(data)\n this.store[key] = value\n return value\n }\n } catch (err) {\n log.warn(\"getItem error\", err)\n this.store[key] = null // do not retry next time\n }\n }\n\n removeItem(key: string): void {\n delete this.store[key]\n if (this.fileKeys != null) {\n const index: number = this.fileKeys.indexOf(key)\n if (index !== -1) {\n this.fileKeys.splice(index, 1)\n }\n }\n try {\n const path = this.getPath(key)\n unlinkSync(path)\n } catch (err) {}\n }\n\n clear(): void {\n this.fileKeys = []\n this.store = {}\n rmSync(this.dirname, { recursive: true, force: true })\n }\n\n allKeys(): string[] {\n if (this.fileKeys == null) {\n try {\n this.fileKeys =\n readdirSync(this.dirname, { withFileTypes: true })\n .filter(\n (item) =>\n !item.isDirectory() && item.name.endsWith(this.extension)\n )\n .map((item) => item.name.slice(0, -this.extensionLength)) || []\n } catch (err) {}\n }\n let keys = [...(this.fileKeys || [])]\n for (let key of Object.keys(this.store)) {\n if (!keys.includes(key)) {\n keys.push(key)\n }\n }\n keys.sort()\n return keys\n }\n}\n","// (C)opyright 2021-07-15 Dirk Holtwick, holtwick.it. All rights reserved.\n\nimport { createWriteStream, mkdirSync } from \"fs\"\nimport { dirname, resolve } from \"path\"\nimport { renderMessages } from \"../common/data/convert\"\nimport { LogHandlerOptions, LogLevel, LogMessage } from \"../common/log-base\"\nimport { useLevelFilter, useNamespaceFilter } from \"../common/log-filter\"\n\nlet namespaces: Record<string, any> = {}\n\nexport function LoggerFileHandler(path: string, opt: LogHandlerOptions = {}) {\n const { level = LogLevel.all, filter = \"*\" } = opt\n path = resolve(process.cwd(), path)\n mkdirSync(dirname(path), { recursive: true })\n var stream = createWriteStream(path, { flags: \"a\" })\n // stream.end()\n const matchesNamespace = useNamespaceFilter(filter)\n const matchesLevel = useLevelFilter(level)\n return (msg: LogMessage) => {\n if (!matchesLevel(msg.level)) return\n if (!matchesNamespace(msg.name)) return\n\n const time = new Date().toISOString()\n let name = msg.name || \"\"\n let ninfo = namespaces[name || \"\"]\n if (ninfo == null) {\n namespaces[name] = ninfo\n }\n\n let args: string[] = [\n `[${name || \"*\"}]`,\n renderMessages(msg.messages, { pretty: false }),\n ]\n\n function write(...args: string[]): void {\n stream.write(args.join(\"\\t\") + \"\\n\")\n }\n\n switch (msg.level) {\n case LogLevel.info:\n write(time, `I|* `, ...args)\n break\n case LogLevel.warn:\n write(time, `W|** `, ...args)\n break\n case LogLevel.error:\n write(time, `E|***`, ...args)\n break\n default:\n write(time, `D| `, ...args)\n break\n }\n }\n}\n","// (C)opyright 2021-07-15 Dirk Holtwick, holtwick.it. All rights reserved.\n\nimport { resolve } from \"path\"\n\nexport function getStackLlocationList(stack: string): any[] {\n if (typeof stack !== \"string\") return []\n // console.log(\"stack\", stack)\n return (\n stack\n ?.split(\"\\n\")\n ?.map((rawLine) => {\n let m = rawLine.match(/^\\s+at.*(\\((.*)\\)|file:\\/\\/(.*)$)/)\n if (m) {\n let line = m[3] || m[2]\n if (line.endsWith(\")\")) line = line.slice(0, -1)\n return line\n }\n })\n ?.filter((v) => v != null) || []\n )\n}\n\nconst cwd = resolve(process.cwd())\nconst home = process.env?.HOME ? resolve(process.env?.HOME) : \"\"\n// console.log(`cwd = ${cwd}, home = ${home}}`)\n\nfunction pathStripCwd(path: string) {\n // console.log(\">\", path)\n\n if (path.includes(\"/node_modules/\")) {\n return \"\"\n }\n\n const fileURL = \"file://\"\n if (path.startsWith(fileURL)) {\n return path.substr(fileURL.length)\n }\n\n if (cwd && path.startsWith(cwd)) {\n return path.substr(cwd.length + 1)\n }\n\n if (home && path.startsWith(home)) {\n path = \"~/\" + path.substr(home.length + 1)\n }\n\n return path\n}\n\nfunction extractFileInfo(stackLine: string): string {\n let m = stackLine.match(/^\\s*at.*(\\((.*)\\)|file:\\/\\/(.*)$)/)\n if (m) {\n let line = m[3] || m[2]\n if (line.endsWith(\")\")) line = line.slice(0, -1)\n return line\n }\n return \"\"\n}\n\n/**\n * Get the source code location of the caller\n * https://stackoverflow.com/a/47296370/140927\n *\n * @param level Number of levels to go down the stack trace\n * @param stripCwd Strip the current working directory, only reasonable for Node.js environment\n * @returns\n */\nexport function getSourceLocation(level = 2, stripCwd = true): string {\n let stack = new Error().stack || \"\"\n let line: string | undefined = getStackLlocationList(stack)?.[level]\n if (line && stripCwd) {\n line = pathStripCwd(line)\n }\n return line || \"\"\n}\n\nexport function getStack(): string {\n return new Error().stack || \"\"\n}\n\nexport function getSourceLocationByPrecedingPattern(\n patterns: string[],\n stripCwd = true\n) {\n let line = \"\"\n let stack = new Error().stack || \"\"\n if (typeof stack === \"string\") {\n const lines = stack.split(\"\\n\").map((l) => l.trim())\n // console.log(lines)\n const index = lines.findIndex((l) => patterns.some((p) => l.startsWith(p)))\n line = lines[index + 1]\n if (line) {\n line = extractFileInfo(line)\n }\n if (line && stripCwd) {\n line = pathStripCwd(line)\n }\n }\n return line\n}\n","// (C)opyright 2021-07-15 Dirk Holtwick, holtwick.it. All rights reserved.\n\nimport tty from \"tty\"\nimport { renderMessages } from \"../common/data/convert\"\nimport {\n LogHandler,\n LogHandlerOptions,\n LogLevel,\n LogMessage,\n} from \"../common/log-base\"\nimport { useLevelFilter, useNamespaceFilter } from \"../common/log-filter\"\nimport {\n getSourceLocation,\n getSourceLocationByPrecedingPattern,\n getStack,\n} from \"./log-util\"\nimport { formatMilliseconds, getTimestamp } from \"../common/time\"\n\nexport function isTTY(): boolean {\n try {\n return tty.isatty(process.stdout.fd)\n } catch (err) {}\n return false\n}\n\nconst colors = [6, 2, 3, 4, 5, 1]\n\nfunction selectColor(namespace: string) {\n let hash = 0\n for (let i = 0; i < namespace.length; i++) {\n hash = (hash << 5) - hash + namespace.charCodeAt(i)\n hash |= 0 // Convert to 32bit integer\n }\n return colors[Math.abs(hash) % colors.length]\n}\n\nlet namespaces: Record<string, any> = {}\n\nlet time = getTimestamp()\n\nconst useColors = tty.isatty(process.stderr.fd)\n\nfunction log(...args: any[]) {\n return process.stderr.write(renderMessages(args) + \"\\n\")\n}\n\n// export const BOLD = Symbol()\n// export const UNBOLD = Symbol()\n// export const BLUE = Symbol()\n// export const GREY = Symbol()\n// export const GREEN = Symbol()\n// export const RED = Symbol()\n// export const PURPLE = Symbol()\n// export const ORANGE = Symbol()\n// export const UNCOLOR = Symbol()\n\n// const _browserStyleMap = {\n// [BOLD]: pair.create(\"font-weight\", \"bold\"),\n// [UNBOLD]: pair.create(\"font-weight\", \"normal\"),\n// [BLUE]: pair.create(\"color\", \"blue\"),\n// [GREEN]: pair.create(\"color\", \"green\"),\n// [GREY]: pair.create(\"color\", \"grey\"),\n// [RED]: pair.create(\"color\", \"red\"),\n// [PURPLE]: pair.create(\"color\", \"purple\"),\n// [ORANGE]: pair.create(\"color\", \"orange\"), // not well supported in chrome when debugging node with inspector - TODO: deprecate\n// [UNCOLOR]: pair.create(\"color\", \"black\"),\n// }\n\nconst TTY_STYLE = {\n BOLD: \"\\u001b[1m\",\n UNBOLD: \"\\u001b[2m\",\n RED: \"\\u001b[31m\",\n GREEN: \"\\u001b[32m\",\n BLUE: \"\\u001b[34m\",\n PURPLE: \"\\u001b[35m\",\n GRAY: \"\\u001b[37m\",\n ORANGE: \"\\u001b[38;5;208m\",\n UNCOLOR: \"\\u001b[0m\",\n}\n\nenum COLOR {\n RED = 1,\n GREEN = 2,\n BLUE = 4,\n PURPLE = 5,\n GRAY = 7,\n ORANGE = 8,\n}\n\nconst colorEnd = \"\\u001B[0m\"\n\nexport function colorString(value: string, colorCode: number) {\n const colorStart =\n colorCode === COLOR.ORANGE\n ? TTY_STYLE.ORANGE\n : \"\\u001B[3\" + (colorCode < 8 ? colorCode : \"8;5;\" + colorCode) + \"m\"\n return `${colorStart}${value}${colorEnd}`\n}\n\nexport function colorStringList(\n list: Array<any>,\n style: string,\n bold: boolean = true\n) {\n return list.map((value) => {\n if (typeof value !== \"string\") return value\n let start = style\n let end = colorEnd\n if (bold) {\n start = `${TTY_STYLE.BOLD}${start}`\n end = `${end}${TTY_STYLE.BOLD}`\n }\n return `${start}${value}${end}`\n })\n}\n\nexport const loggerStackTraceDebug =\n \"loggerStackTraceDebug-7d38e5a9214b58d29734374cdb9521fd964d7485\"\n\nexport function LoggerNodeHandler(opt: LogHandlerOptions = {}): LogHandler {\n const {\n level = undefined,\n filter = undefined,\n colors = isTTY(),\n levelHelper = true,\n nameBrackets = true,\n padding = 0,\n fill = 0,\n stack = true,\n } = opt\n const matchesNamespace = useNamespaceFilter(filter)\n const matchesLevel = useLevelFilter(level)\n return (msg: LogMessage) => {\n if (!matchesLevel(msg.level)) return\n if (!matchesNamespace(msg.name)) return\n const timeNow = getTimestamp()\n let name = msg.name || \"\"\n let ninfo = namespaces[name || \"\"]\n if (ninfo == null) {\n ninfo = {\n color: selectColor(name),\n // time: timeNow\n }\n namespaces[name] = ninfo\n }\n const diff = formatMilliseconds(timeNow - time)\n\n let args: string[]\n\n let displayName = nameBrackets ? `[${name}]` : name\n\n if (padding > 0) {\n displayName = displayName.padStart(padding, \" \")\n }\n\n if (fill > 0) {\n displayName = displayName.padEnd(fill, \" \")\n }\n\n if (colors && useColors) {\n const c = ninfo.color\n args = [colorString(displayName, c) + ` | `] // nameBrackets ? [`%c[${name}]`] : [`%c${name}`]\n if (msg.level === LogLevel.warn) {\n args.push(...colorStringList(msg.messages, TTY_STYLE.ORANGE))\n } else if (msg.level === LogLevel.error) {\n args.push(...colorStringList(msg.messages, TTY_STYLE.RED))\n } else {\n args.push(...msg.messages)\n }\n args.push(colorString(`+${diff}`, c))\n } else {\n args = [displayName, ...msg.messages]\n args.push(`+${diff}`)\n }\n\n if (msg.messages?.[0] === loggerStackTraceDebug) {\n console.log(getStack())\n }\n\n if (stack) {\n let line: string = \"\"\n if (typeof stack === \"boolean\") {\n line = getSourceLocationByPrecedingPattern(\n [\"at Function.\", \"at null.log (\", \"at log (\"],\n true\n )\n if (!line) {\n line = getSourceLocation(0, true)\n }\n } else {\n const depth = typeof stack === \"number\" ? stack : 3\n line = getSourceLocation(depth, true)\n }\n if (line) {\n args.push(colorString(`(${line})`, COLOR.GRAY))\n }\n }\n switch (msg.level) {\n case LogLevel.info:\n if (levelHelper) args[0] = `I|* ` + args[0]\n log(...args)\n break\n case LogLevel.warn:\n if (levelHelper)\n args[0] =\n (colors && useColors\n ? colorString(`W|** `, COLOR.ORANGE)\n : `W|** `) + args[0]\n log(...args)\n break\n case LogLevel.error:\n if (levelHelper)\n args[0] =\n (colors && useColors\n ? colorString(`E|*** `, COLOR.RED)\n : `E|*** `) + args[0]\n log(...args)\n break\n default:\n if (levelHelper) args[0] = `D| ` + args[0]\n log(...args)\n break\n }\n }\n}\n","// https://nodejs.org/api/webcrypto.html\nimport nodeCrypto from \"crypto\"\n\nexport {}\n\ndeclare module NodeJS {\n interface Global {\n crypto: Crypto\n }\n}\n\ntry {\n if (\n nodeCrypto &&\n nodeCrypto.webcrypto &&\n typeof globalThis !== \"undefined\" &&\n typeof globalThis.crypto === \"undefined\"\n ) {\n // @ts-ignore\n globalThis.crypto = nodeCrypto.webcrypto\n }\n} catch (err) {\n console.warn(\"Failed to polyfill webcrypto\", err)\n}\n","import { Logger } from \"../common/log\"\nimport { toPath } from \"./env\"\nimport { LoggerFileHandler } from \"./log-file\"\nimport { LoggerNodeHandler } from \"./log-node\"\n\nfunction setupLogContextNode() {\n let handlers = [\n LoggerNodeHandler({\n padding: 32,\n nameBrackets: false,\n // levelHelper: false,\n }),\n ]\n\n let logFilePath = process.env.ZEED_LOG ?? process.env.LOG\n if (logFilePath) {\n handlers.unshift(LoggerFileHandler(toPath(logFilePath)))\n }\n\n Logger.setHandlers(handlers)\n}\n\nsetupLogContextNode()\n"],"mappings":"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","names":[]}
|
|
1
|
+
{"version":3,"sources":["../src/node/env.ts","../src/node/filestorage.ts","../src/node/log-file.ts","../src/node/log-util.ts","../src/node/log-node.ts","../src/node/crypto.ts","../src/node/log-context-node.ts"],"sourcesContent":["// (C)opyright 2021-07-15 Dirk Holtwick, holtwick.it. All rights reserved.\n\n// Adopted from https://github.com/motdotla/dotenv BSD-2\n\nimport { LogLevel } from \"../common/log-base\"\nimport { Logger } from \"../common/log\"\n\nimport fs from \"fs\"\nimport { resolve } from \"path\"\n\nconst log = Logger(\"zeed:env\")\n\nconst NEWLINE = \"\\n\"\nconst RE_INI_KEY_VAL = /^\\s*([\\w_.-]+)\\s*=\\s*(.*)?\\s*$/\nconst RE_NEWLINES = /\\\\n/g\nconst NEWLINES_MATCH = /\\n|\\r|\\r\\n/\n\ntype csvOptions = {\n /** @deprecated will probably be replaced by logLevel */\n debug?: boolean\n path?: string\n filename?: string\n encoding?: BufferEncoding\n prefix?: string\n env?: Record<string, string>\n}\n\n// Parses src into an Object\nfunction parse(src: string, options: csvOptions = {}) {\n let obj: Record<string, string> = {}\n\n // convert Buffers before splitting into lines and processing\n src\n .toString()\n .split(NEWLINES_MATCH)\n .forEach(function (line, idx) {\n // matching \"KEY' and 'VAL' in 'KEY=VAL'\n const keyValueArr = line.match(RE_INI_KEY_VAL)\n // matched?\n\n // log.debug(\"keyValueArr\", keyValueArr)\n\n if (keyValueArr != null) {\n const key = keyValueArr[1]\n // default undefined or missing values to empty string\n let val = keyValueArr[2] || \"\"\n const end = val.length - 1\n const isDoubleQuoted = val[0] === '\"' && val[end] === '\"'\n const isSingleQuoted = val[0] === \"'\" && val[end] === \"'\"\n\n // if single or double quoted, remove quotes\n if (isSingleQuoted || isDoubleQuoted) {\n val = val.substring(1, end)\n\n // if double quoted, expand newlines\n if (isDoubleQuoted) {\n val = val.replace(RE_NEWLINES, NEWLINE)\n }\n } else {\n // remove surrounding whitespace\n val = val.trim()\n }\n obj[key] = val\n } else {\n log.debug(\n `did not match key and value when parsing line ${idx + 1}: ${line}`\n )\n }\n })\n\n // log.debug(\"obj\", obj)\n return obj\n}\n\n/**\n * Return a path relative to the current working directory\n */\nexport function stringToPath(\n value?: string,\n defaultValue: string = \".\"\n): string {\n return resolve(process.cwd(), value ?? defaultValue)\n}\n\nexport function valueToPath(value?: any, defaultValue = \"\"): string {\n if (value == null) value = defaultValue\n return stringToPath(String(value).trim(), defaultValue)\n}\n\nexport const toPath = valueToPath\n\n// Populates process.env from .env file\nexport function setupEnv(options: csvOptions = {}) {\n const dotenvPath: string =\n options?.path ?? toPath(options?.filename ?? \".env\")\n const encoding: BufferEncoding = options?.encoding ?? \"utf8\"\n const debug = options?.debug || false\n\n if (debug !== true) log.level = LogLevel.off\n\n try {\n // specifying an encoding returns a string instead of a buffer\n const parsedEnv = fs.existsSync(dotenvPath)\n ? parse(fs.readFileSync(dotenvPath, { encoding }), { debug })\n : {}\n const parsedEnvLocal = fs.existsSync(dotenvPath + \".local\")\n ? parse(fs.readFileSync(dotenvPath + \".local\", { encoding }), { debug })\n : {}\n\n const parsed: Record<string, string> = Object.assign(\n {},\n parsedEnv,\n parsedEnvLocal\n )\n let env = options?.env ?? process.env\n\n Object.entries(parsed).forEach(([key, value]) => {\n if (typeof options?.prefix === \"string\") {\n key = options?.prefix + key\n }\n if (!Object.prototype.hasOwnProperty.call(env, key)) {\n if (value != null) {\n log.info(`set env.${key} = ${value}`)\n env[key] = value\n }\n } else {\n log.debug(`\"${key}\" is already defined and will not be overwritten`)\n }\n })\n return { parsed }\n } catch (e) {\n log.error(e)\n return { error: e }\n }\n}\n","// (C)opyright 2021-07-15 Dirk Holtwick, holtwick.it. All rights reserved.\n\nimport {\n mkdirSync,\n readdirSync,\n readFileSync,\n rmSync,\n unlinkSync,\n writeFileSync,\n} from \"fs\"\nimport { dirname, resolve } from \"path\"\nimport { toValidFilename } from \"../common/data/path\"\nimport { cloneObject } from \"../common/data/utils\"\nimport { Logger } from \"../common/log\"\nimport { Json, ObjectStorage } from \"../common/types\"\n\nconst log = Logger(\"zeed:filestorage\")\n\nexport interface FileStorageOptions {\n pretty?: boolean\n path?: string\n extension?: string\n objectFromString?: (data: string) => any\n objectToString?: (data: any) => string\n keyToFilename?: (key: string) => string\n}\n\nexport class FileStorage<T = Json> implements ObjectStorage<T> {\n private store: Record<string, T | null> = {}\n private dirname: string\n private fileKeys?: string[] = undefined\n private pretty: boolean = false\n private extension: string\n private extensionLength: number\n private objectFromString: (data: string) => any\n private objectToString: (data: any) => string\n private keyToFilename: (key: string) => string\n\n constructor(opt: FileStorageOptions = {}) {\n this.dirname = resolve(process.cwd(), opt.path || \".fileStorage\")\n this.pretty = !!opt.pretty\n this.extension = opt.extension ?? \".json\"\n\n if (opt.extension && !this.extension.startsWith(\".\")) {\n this.extension = \".\" + this.extension\n }\n this.extensionLength = this.extension.length\n\n this.objectToString =\n opt.objectToString ??\n ((data: any): string => {\n return this.pretty\n ? JSON.stringify(data, null, 2)\n : JSON.stringify(data)\n })\n\n this.objectFromString =\n opt.objectFromString ??\n ((data: string) => {\n try {\n return JSON.parse(data)\n } catch (err) {\n log.warn(`fileStorage parse error '${err}' in`, data)\n }\n })\n\n this.keyToFilename = opt.keyToFilename ?? toValidFilename\n }\n\n setItem(key: string, value: T): void {\n this.store[key] = cloneObject(value)\n try {\n const data = this.objectToString(value)\n const path = this.getPath(key)\n mkdirSync(dirname(path), { recursive: true })\n writeFileSync(path, data, \"utf8\")\n } catch (err) {\n log.error(\"setItem error\", err)\n }\n }\n\n getPath(key: string): string {\n return resolve(this.dirname, this.keyToFilename(key) + this.extension)\n }\n\n getBuffer(key: string): Buffer {\n const path = this.getPath(key)\n return Buffer.from(readFileSync(path))\n }\n\n getItem(key: string): T | undefined {\n let value = this.store[key]\n\n // null is an indicator for not existing!\n if (value === null) return\n\n if (value != null) {\n return cloneObject(value) // this.objectFromString(value)\n }\n\n try {\n const path = this.getPath(key)\n const data = readFileSync(path, \"utf8\")\n if (data != null) {\n const value = this.objectFromString(data)\n this.store[key] = value\n return value\n }\n } catch (err) {\n log.warn(\"getItem error\", err)\n this.store[key] = null // do not retry next time\n }\n }\n\n removeItem(key: string): void {\n delete this.store[key]\n if (this.fileKeys != null) {\n const index: number = this.fileKeys.indexOf(key)\n if (index !== -1) {\n this.fileKeys.splice(index, 1)\n }\n }\n try {\n const path = this.getPath(key)\n unlinkSync(path)\n } catch (err) {}\n }\n\n clear(): void {\n this.fileKeys = []\n this.store = {}\n rmSync(this.dirname, { recursive: true, force: true })\n }\n\n allKeys(): string[] {\n if (this.fileKeys == null) {\n try {\n this.fileKeys =\n readdirSync(this.dirname, { withFileTypes: true })\n .filter(\n (item) =>\n !item.isDirectory() && item.name.endsWith(this.extension)\n )\n .map((item) => item.name.slice(0, -this.extensionLength)) || []\n } catch (err) {}\n }\n let keys = [...(this.fileKeys || [])]\n for (let key of Object.keys(this.store)) {\n if (!keys.includes(key)) {\n keys.push(key)\n }\n }\n keys.sort()\n return keys\n }\n}\n","// (C)opyright 2021-07-15 Dirk Holtwick, holtwick.it. All rights reserved.\n\nimport { createWriteStream, mkdirSync } from \"fs\"\nimport { dirname, resolve } from \"path\"\nimport { renderMessages } from \"../common/data/convert\"\nimport { LogHandlerOptions, LogLevel, LogMessage } from \"../common/log-base\"\nimport { useLevelFilter, useNamespaceFilter } from \"../common/log-filter\"\n\nlet namespaces: Record<string, any> = {}\n\nexport function LoggerFileHandler(path: string, opt: LogHandlerOptions = {}) {\n const { level = LogLevel.all, filter = \"*\" } = opt\n path = resolve(process.cwd(), path)\n mkdirSync(dirname(path), { recursive: true })\n var stream = createWriteStream(path, { flags: \"a\" })\n // stream.end()\n const matchesNamespace = useNamespaceFilter(filter)\n const matchesLevel = useLevelFilter(level)\n return (msg: LogMessage) => {\n if (!matchesLevel(msg.level)) return\n if (!matchesNamespace(msg.name)) return\n\n const time = new Date().toISOString()\n let name = msg.name || \"\"\n let ninfo = namespaces[name || \"\"]\n if (ninfo == null) {\n namespaces[name] = ninfo\n }\n\n let args: string[] = [\n `[${name || \"*\"}]`,\n renderMessages(msg.messages, { pretty: false }),\n ]\n\n function write(...args: string[]): void {\n stream.write(args.join(\"\\t\") + \"\\n\")\n }\n\n switch (msg.level) {\n case LogLevel.info:\n write(time, `I|* `, ...args)\n break\n case LogLevel.warn:\n write(time, `W|** `, ...args)\n break\n case LogLevel.error:\n write(time, `E|***`, ...args)\n break\n default:\n write(time, `D| `, ...args)\n break\n }\n }\n}\n","// (C)opyright 2021-07-15 Dirk Holtwick, holtwick.it. All rights reserved.\n\nimport { resolve } from \"path\"\n\nexport function getStackLlocationList(stack: string): any[] {\n if (typeof stack !== \"string\") return []\n // console.log(\"stack\", stack)\n return (\n stack\n ?.split(\"\\n\")\n ?.map((rawLine) => {\n let m = rawLine.match(/^\\s+at.*(\\((.*)\\)|file:\\/\\/(.*)$)/)\n if (m) {\n let line = m[3] || m[2]\n if (line.endsWith(\")\")) line = line.slice(0, -1)\n return line\n }\n })\n ?.filter((v) => v != null) || []\n )\n}\n\nconst cwd = resolve(process.cwd())\nconst home = process.env?.HOME ? resolve(process.env?.HOME) : \"\"\n// console.log(`cwd = ${cwd}, home = ${home}}`)\n\nfunction pathStripCwd(path: string) {\n // console.log(\">\", path)\n\n if (path.includes(\"/node_modules/\")) {\n return \"\"\n }\n\n const fileURL = \"file://\"\n if (path.startsWith(fileURL)) {\n return path.substr(fileURL.length)\n }\n\n if (cwd && path.startsWith(cwd)) {\n return path.substr(cwd.length + 1)\n }\n\n if (home && path.startsWith(home)) {\n path = \"~/\" + path.substr(home.length + 1)\n }\n\n return path\n}\n\nfunction extractFileInfo(stackLine: string): string {\n let m = stackLine.match(/^\\s*at.*(\\((.*)\\)|file:\\/\\/(.*)$)/)\n if (m) {\n let line = m[3] || m[2]\n if (line.endsWith(\")\")) line = line.slice(0, -1)\n return line\n }\n return \"\"\n}\n\n/**\n * Get the source code location of the caller\n * https://stackoverflow.com/a/47296370/140927\n *\n * @param level Number of levels to go down the stack trace\n * @param stripCwd Strip the current working directory, only reasonable for Node.js environment\n * @returns\n */\nexport function getSourceLocation(level = 2, stripCwd = true): string {\n let stack = new Error().stack || \"\"\n let line: string | undefined = getStackLlocationList(stack)?.[level]\n if (line && stripCwd) {\n line = pathStripCwd(line)\n }\n return line || \"\"\n}\n\nexport function getStack(): string {\n return new Error().stack || \"\"\n}\n\nexport function getSourceLocationByPrecedingPattern(\n patterns: string[],\n stripCwd = true\n) {\n let line = \"\"\n let stack = new Error().stack || \"\"\n if (typeof stack === \"string\") {\n const lines = stack.split(\"\\n\").map((l) => l.trim())\n // console.log(lines)\n const index = lines.findIndex((l) => patterns.some((p) => l.startsWith(p)))\n line = lines[index + 1]\n if (line) {\n line = extractFileInfo(line)\n }\n if (line && stripCwd) {\n line = pathStripCwd(line)\n }\n }\n return line\n}\n","// (C)opyright 2021-07-15 Dirk Holtwick, holtwick.it. All rights reserved.\n\nimport tty from \"tty\"\nimport { renderMessages } from \"../common/data/convert\"\nimport {\n LogHandler,\n LogHandlerOptions,\n LogLevel,\n LogMessage,\n} from \"../common/log-base\"\nimport { useLevelFilter, useNamespaceFilter } from \"../common/log-filter\"\nimport {\n getSourceLocation,\n getSourceLocationByPrecedingPattern,\n getStack,\n} from \"./log-util\"\nimport { formatMilliseconds, getTimestamp } from \"../common/time\"\n\nexport function isTTY(): boolean {\n try {\n return tty.isatty(process.stdout.fd)\n } catch (err) {}\n return false\n}\n\nconst colors = [6, 2, 3, 4, 5, 1]\n\nfunction selectColor(namespace: string) {\n let hash = 0\n for (let i = 0; i < namespace.length; i++) {\n hash = (hash << 5) - hash + namespace.charCodeAt(i)\n hash |= 0 // Convert to 32bit integer\n }\n return colors[Math.abs(hash) % colors.length]\n}\n\nlet namespaces: Record<string, any> = {}\n\nlet time = getTimestamp()\n\nconst useColors = tty.isatty(process.stderr.fd)\n\nfunction log(...args: any[]) {\n return process.stderr.write(renderMessages(args) + \"\\n\")\n}\n\n// export const BOLD = Symbol()\n// export const UNBOLD = Symbol()\n// export const BLUE = Symbol()\n// export const GREY = Symbol()\n// export const GREEN = Symbol()\n// export const RED = Symbol()\n// export const PURPLE = Symbol()\n// export const ORANGE = Symbol()\n// export const UNCOLOR = Symbol()\n\n// const _browserStyleMap = {\n// [BOLD]: pair.create(\"font-weight\", \"bold\"),\n// [UNBOLD]: pair.create(\"font-weight\", \"normal\"),\n// [BLUE]: pair.create(\"color\", \"blue\"),\n// [GREEN]: pair.create(\"color\", \"green\"),\n// [GREY]: pair.create(\"color\", \"grey\"),\n// [RED]: pair.create(\"color\", \"red\"),\n// [PURPLE]: pair.create(\"color\", \"purple\"),\n// [ORANGE]: pair.create(\"color\", \"orange\"), // not well supported in chrome when debugging node with inspector - TODO: deprecate\n// [UNCOLOR]: pair.create(\"color\", \"black\"),\n// }\n\nconst TTY_STYLE = {\n BOLD: \"\\u001b[1m\",\n UNBOLD: \"\\u001b[2m\",\n RED: \"\\u001b[31m\",\n GREEN: \"\\u001b[32m\",\n BLUE: \"\\u001b[34m\",\n PURPLE: \"\\u001b[35m\",\n GRAY: \"\\u001b[37m\",\n ORANGE: \"\\u001b[38;5;208m\",\n UNCOLOR: \"\\u001b[0m\",\n}\n\nenum COLOR {\n RED = 1,\n GREEN = 2,\n BLUE = 4,\n PURPLE = 5,\n GRAY = 7,\n ORANGE = 8,\n}\n\nconst colorEnd = \"\\u001B[0m\"\n\nexport function colorString(value: string, colorCode: number) {\n const colorStart =\n colorCode === COLOR.ORANGE\n ? TTY_STYLE.ORANGE\n : \"\\u001B[3\" + (colorCode < 8 ? colorCode : \"8;5;\" + colorCode) + \"m\"\n return `${colorStart}${value}${colorEnd}`\n}\n\nexport function colorStringList(\n list: Array<any>,\n style: string,\n bold: boolean = true\n) {\n return list.map((value) => {\n if (typeof value !== \"string\") return value\n let start = style\n let end = colorEnd\n if (bold) {\n start = `${TTY_STYLE.BOLD}${start}`\n end = `${end}${TTY_STYLE.BOLD}`\n }\n return `${start}${value}${end}`\n })\n}\n\nexport const loggerStackTraceDebug =\n \"loggerStackTraceDebug-7d38e5a9214b58d29734374cdb9521fd964d7485\"\n\nexport function LoggerNodeHandler(opt: LogHandlerOptions = {}): LogHandler {\n const {\n level = undefined,\n filter = undefined,\n colors = isTTY(),\n levelHelper = true,\n nameBrackets = true,\n padding = 0,\n fill = 0,\n stack = true,\n } = opt\n const matchesNamespace = useNamespaceFilter(filter)\n const matchesLevel = useLevelFilter(level)\n return (msg: LogMessage) => {\n if (!matchesLevel(msg.level)) return\n if (!matchesNamespace(msg.name)) return\n const timeNow = getTimestamp()\n let name = msg.name || \"\"\n let ninfo = namespaces[name || \"\"]\n if (ninfo == null) {\n ninfo = {\n color: selectColor(name),\n // time: timeNow\n }\n namespaces[name] = ninfo\n }\n const diff = formatMilliseconds(timeNow - time)\n\n let args: string[]\n\n let displayName = nameBrackets ? `[${name}]` : name\n\n if (padding > 0) {\n displayName = displayName.padStart(padding, \" \")\n }\n\n if (fill > 0) {\n displayName = displayName.padEnd(fill, \" \")\n }\n\n if (colors && useColors) {\n const c = ninfo.color\n args = [colorString(displayName, c) + ` | `] // nameBrackets ? [`%c[${name}]`] : [`%c${name}`]\n if (msg.level === LogLevel.warn) {\n args.push(...colorStringList(msg.messages, TTY_STYLE.ORANGE))\n } else if (msg.level === LogLevel.error) {\n args.push(...colorStringList(msg.messages, TTY_STYLE.RED))\n } else {\n args.push(...msg.messages)\n }\n args.push(colorString(`+${diff}`, c))\n } else {\n args = [displayName, ...msg.messages]\n args.push(`+${diff}`)\n }\n\n if (msg.messages?.[0] === loggerStackTraceDebug) {\n console.log(getStack())\n }\n\n if (stack) {\n let line: string = \"\"\n if (typeof stack === \"boolean\") {\n line = getSourceLocationByPrecedingPattern(\n [\"at Function.\", \"at null.log (\", \"at log (\"],\n true\n )\n if (!line) {\n line = getSourceLocation(0, true)\n }\n } else {\n const depth = typeof stack === \"number\" ? stack : 3\n line = getSourceLocation(depth, true)\n }\n if (line) {\n args.push(colorString(`(${line})`, COLOR.GRAY))\n }\n }\n switch (msg.level) {\n case LogLevel.info:\n if (levelHelper) args[0] = `I|* ` + args[0]\n log(...args)\n break\n case LogLevel.warn:\n if (levelHelper)\n args[0] =\n (colors && useColors\n ? colorString(`W|** `, COLOR.ORANGE)\n : `W|** `) + args[0]\n log(...args)\n break\n case LogLevel.error:\n if (levelHelper)\n args[0] =\n (colors && useColors\n ? colorString(`E|*** `, COLOR.RED)\n : `E|*** `) + args[0]\n log(...args)\n break\n default:\n if (levelHelper) args[0] = `D| ` + args[0]\n log(...args)\n break\n }\n }\n}\n","// https://nodejs.org/api/webcrypto.html\nimport nodeCrypto from \"crypto\"\n\nexport {}\n\ndeclare module NodeJS {\n interface Global {\n crypto: Crypto\n }\n}\n\ntry {\n if (\n nodeCrypto &&\n nodeCrypto.webcrypto &&\n typeof globalThis !== \"undefined\" &&\n typeof globalThis.crypto === \"undefined\"\n ) {\n // @ts-ignore\n globalThis.crypto = nodeCrypto.webcrypto\n }\n} catch (err) {\n console.warn(\"Failed to polyfill webcrypto\", err)\n}\n","import { Logger } from \"../common/log\"\nimport { toPath } from \"./env\"\nimport { LoggerFileHandler } from \"./log-file\"\nimport { LoggerNodeHandler } from \"./log-node\"\n\nfunction setupLogContextNode() {\n let handlers = [\n LoggerNodeHandler({\n padding: 32,\n nameBrackets: false,\n // levelHelper: false,\n }),\n ]\n\n let logFilePath = process.env.ZEED_LOG ?? process.env.LOG\n if (logFilePath) {\n handlers.unshift(LoggerFileHandler(toPath(logFilePath)))\n }\n\n Logger.setHandlers(handlers)\n}\n\nsetupLogContextNode()\n"],"mappings":"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","names":[]}
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
import{a as I,b as Q,c as o,s as Te,w as ie,x as b,y as we}from"./chunk-JGD3KNXY.js";var Ae=b("bin"),Y;function Me(e){return typeof TextEncoder=="undefined"?new Uint8Array:(Y!=null?Y:Y=new TextEncoder).encode(e.normalize("NFC"))}o(Me,"stringToUInt8Array");var X;function et(e){return typeof TextDecoder=="undefined"?"":(X!=null?X:X=new TextDecoder("utf-8",{ignoreBOM:!0})).decode(e).normalize("NFC")}o(et,"Uint8ArrayToString");function D(e){return e instanceof ArrayBuffer?new Uint8Array(e):typeof e=="string"?Me(e):e.length?new Uint8Array(e):e}o(D,"toUint8Array");function jt(e){if(typeof Buffer!="undefined")return Buffer.from(D(e)).toString("hex");let t="0123456789abcdef",r="";for(let n of[...D(e)])r+=t[n>>4]+t[n&15];return r}o(jt,"toHex");function Wt(e){let t=D(e);if(typeof Buffer!="undefined")return Buffer.from(t).toString("base64");let r="";for(let n=0;n<t.byteLength;n++)r+=String.fromCharCode(t[n]);return btoa(r)}o(Wt,"toBase64");function Qt(e){let t=D(e);if(typeof Buffer!="undefined")return Buffer.from(t).toString("base64url");let r="";for(let n=0;n<t.byteLength;n++)r+=String.fromCharCode(t[n]);return btoa(r).replace(/\+/g,"-").replace(/\//g,"_")}o(Qt,"toBase64Url");function Pe(e,t){if(e.byteLength!==t.byteLength)return!1;let r=D(e),n=D(t);for(let i=0;i<r.length;i++)if(r[i]!==n[i])return!1;return!0}o(Pe,"equalBinary");function se(e){try{return Me(JSON.stringify(e))}catch(t){throw Ae.warn("jsonToUint8Array",e),t}}o(se,"jsonToUint8Array");function ae(e){try{return JSON.parse(et(e))}catch(t){throw Ae.warn("Uint8ArrayToJson",e),t}}o(ae,"Uint8ArrayToJson");function H(e=16){let t=new Uint8Array(e);if(typeof crypto!="undefined"&&crypto.getRandomValues)crypto.getRandomValues(t);else for(let r=0;r<e;r++)t[r]=Math.floor(Math.random()*256);return t}o(H,"randomUint8Array");var Ee="SHA-256",ue="AES-GCM",Le="PBKDF2";async function Kt(e,t=Ee){return await crypto.subtle.digest(t,D(e))}o(Kt,"digest");async function Yt(e,t={}){var i;let r=D(e),n=await crypto.subtle.importKey("raw",r,Le,!1,["deriveKey"]);return await crypto.subtle.deriveKey({name:Le,salt:t.salt?D(t.salt):new Uint8Array(0),iterations:(i=t.iterations)!=null?i:1e5,hash:Ee},n,{name:ue,length:256},!0,["encrypt","decrypt"])}o(Yt,"deriveKeyPbkdf2");var ee=new Uint8Array([1,1]);async function Ce(e,t){let r=H(12),n=await crypto.subtle.encrypt({name:ue,iv:r},t,e),i=new Uint8Array(n),s=ee.length+r.length+i.length,u=new Uint8Array(s),a=0;return u.set(ee,a),a+=ee.length,u.set(r,a),a+=r.length,u.set(i,a),u}o(Ce,"encrypt");async function Ue(e,t){let r=e.subarray(0,2);if(!Pe(r,ee))return Promise.reject(`Unknown magic ${r}`);let n=e.subarray(2,2+12),i=e.subarray(2+12,e.length),s=await crypto.subtle.decrypt({name:ue,iv:n},t,i);return new Uint8Array(s)}o(Ue,"decrypt");var De=",",tt=!1,rt=!0;function nt(e){return/^([-+])?([0-9]+(\.[0-9]+)?|Infinity)$/.test(e)?Number(e):NaN}o(nt,"filterFloat");function ot(e){return rt&&e==null?"":tt?'="'+String(e).replace(/"/g,'""')+'"':!isNaN(nt(e))&&isFinite(e)?parseFloat(e):'"'+String(e).replace(/"/g,'""')+'"'}o(ot,"escape");function er(e,t){let r="";t&&(r=t.join(De)+`\r
|
|
2
|
+
`);for(let n=0;n<e.length;n++)r+=e[n].map(ot).join(De)+`\r
|
|
3
|
+
`;return r}o(er,"csv");function it(e=""){let[t="",r="asc"]=e.split(" ");return r=r.toLowerCase(),{field:t,orderby:r,asc:r!=="desc",desc:r==="desc"}}o(it,"parseOrderby");function rr(e,t=!0){return`${e} ${t?"asc":"desc"}`}o(rr,"composeOrderby");function ce(e,t,r=!0){let n=e||0,i=t||0;return n>i?r?1:-1:n<i?r?-1:1:0}o(ce,"cmp");function nr(e,...t){if(t.length>0){let r=t.map(it),n=Array.from(e);return n.sort((i,s)=>{for(let{field:u,asc:a}of r){let c=ce(i[u],s[u],a);if(c!==0)return c}return 0}),n}return e}o(nr,"sortedOrderby");function fe(e){return e.filter((t,r)=>e.indexOf(t)===r)}o(fe,"arrayUnique");function st(e,t){return fe(e.filter(r=>!t.includes(r)))}o(st,"arrayMinus");function at(...e){return fe(e.reduce((t=[],r)=>t.concat(r),[]))}o(at,"arrayUnion");function V(...e){return e.flat(1/0)}o(V,"arrayFlatten");function ut(e,t){return fe(e).filter(r=>t.includes(r))}o(ut,"arrayIntersection");function sr(e,t){return st(at(e,t),ut(e,t))}o(sr,"arraySymmetricDifference");function ar(e,t){if(e&&Array.isArray(e)){let r;for(;(r=e.indexOf(t))!==-1;)e.splice(r,1);return e}return[]}o(ar,"arrayRemoveElement");function ur(e,t){return e.includes(t)||e.push(t),e}o(ur,"arraySetElement");function le(e,t){return e.splice(0,e.length,...e.filter(t)),e}o(le,"arrayFilterInPlace");function cr(e,t){let r=e.findIndex(n=>n===t);return r>=0?e.splice(r,1):e.push(t),e}o(cr,"arrayToggleInPlace");function fr(e){return e.splice(0,e.length),e}o(fr,"arrayEmptyInPlace");function ct(e,t=ce){return Array.from(e).sort(t)}o(ct,"arraySorted");function lr(e){return ct(e,(t,r)=>t-r)}o(lr,"arraySortedNumbers");function ft(e,t){return e.length===t.length&&e.every((r,n)=>r===t[n])}o(ft,"arrayIsEqual");function ke(e){return e.sort(()=>Math.random()>.5?1:-1),e}o(ke,"arrayShuffleInPlace");function pr(e){return ke(Array.from(e))}o(pr,"arrayShuffle");function dr(e){for(;e.length>1;){let t=Array.from(e);if(ke(t),!ft(e,t))return t}return e}o(dr,"arrayShuffleForce");function mr(e){return e[Math.floor(Math.random()*e.length)]}o(mr,"arrayRandomElement");function yr(...e){return V(e).reduce((t,r)=>t!=null?r>t?r:t:r,void 0)}o(yr,"arrayMax");function gr(...e){return V(e).reduce((t,r)=>t!=null?r<t?r:t:r,void 0)}o(gr,"arrayMin");function hr(e=0,t){if(e<=0)return[];let r=new Array(e);for(let n=0;n<e;n++)r[n]=t instanceof Function?t(n):t;return r}o(hr,"createArray");var lt=b("zeed:basex"),pt={"2":"01","8":"01234567","11":"0123456789a","16":"0123456789abcdef","32":"0123456789ABCDEFGHJKMNPQRSTVWXYZ","32-rfc":"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567","32-hex":"0123456789ABCDEFGHIJKLMNOPQRSTUV","32-zbase":"ybndrfg8ejkmcpqxot1uwisza345h769","36":"0123456789abcdefghijklmnopqrstuvwxyz","58":"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz","62":"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz","64":"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/","64-url":"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_","66":"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_.!~","85":"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz!#$%&()*+-;<=>?@^_`{|}~"};function O(e){let t;if(typeof e=="string")t=e;else if(t=pt[e.toString()],t==null)throw new Error(`Unknown base ${e}`);if(t.length>=255)throw new TypeError("Alphabet too long");let r=new Uint8Array(256);for(let f=0;f<r.length;f++)r[f]=255;for(let f=0;f<t.length;f++){let d=t.charAt(f),m=d.charCodeAt(0);if(r[m]!==255)throw new TypeError(d+" is ambiguous");r[m]=f}let n=t.length,i=t.charAt(0),s=Math.log(n)/Math.log(256),u=Math.log(256)/Math.log(n);function a(f,d=-1){let m=D(f);if(m.byteLength===0)return"";let L=0,M=0,P=m.byteLength;for(;M!==P&&m[M]===0;)M++;let x=(P-M)*u+1>>>0,y=new Uint8Array(x);for(;M!==P;){let S=m[M],T=0;for(let k=x-1;(S!==0||T<L)&&k!==-1;k--,T++)S+=256*y[k]>>>0,y[k]=S%n>>>0,S=S/n>>>0;if(S!==0)throw lt.warn("Non-zero carry",m,d,T,x),new Error("Non-zero carry");L=T,M++}let g=x-L;for(;g!==x&&y[g]===0;)g++;let E="";for(;g<x;++g)E+=t.charAt(y[g]);return d>0?E.padStart(d,i):E}o(a,"encode");function c(f,d=-1){if(typeof f!="string")throw new TypeError("Expected String");if(f.length===0)return new Uint8Array;f=f.replace(/\s+/gi,"");let m=0,L=0;for(;f[m]===i;)m++;let M=(f.length-m)*s+1>>>0,P=new Uint8Array(M);for(;f[m];){let y=r[f.charCodeAt(m)];if(y===255)throw new Error(`Unsupported character "${f[m]}"`);let g=0;for(let E=M-1;(y!==0||g<L)&&E!==-1;E--,g++)y+=n*P[E]>>>0,P[E]=y%256>>>0,y=y/256>>>0;if(y!==0)throw new Error("Non-zero carry");L=g,m++}let x=M-L;for(;x!==M&&P[x]===0;)x++;return d>0?new Uint8Array([...new Uint8Array(d-P.length+x),...P.slice(x)]):P.slice(x)}return o(c,"decode"),{encode:a,decode:c}}o(O,"useBase");var{encode:Ar,decode:Mr}=O(16),{encode:Pr,decode:Er}=O(32),{encode:Lr,decode:Cr}=O(58),{encode:Ur,decode:Dr}=O(62),{encode:kr,decode:Sr}=O(62);var Or=o(e=>(e.length>0&&(/^[A-Z0-9_\-\ ]*$/g.test(e)&&(e=e.toLowerCase()),e=e.replace(/^[-_\ ]+/gi,"").replace(/[-_\ ]+$/gi,"").replace(/[-_\ ]+([a-z0-9])/gi,(t,r)=>r.toUpperCase()),e=e[0].toLowerCase()+e.substring(1)),e),"toCamelCase");function dt(e){return e.charAt(0).toUpperCase()+e.toLowerCase().slice(1)}o(dt,"toCapitalize");function Fr(e){return e.replace(/\w\S*/g,dt)}o(Fr,"toCapitalizeWords");function Rr(e,t="-"){return t=typeof t=="undefined"?"_":t,e.replace(/([a-z\d])([A-Z])/g,"$1"+t+"$2").replace(/([A-Z]+)([A-Z][a-z\d]+)/g,"$1"+t+"$2").toLowerCase()}o(Rr,"fromCamelCase");function mt(e,t){var r=[],n=[];return t==null&&(t=o(function(i,s){return r[0]===s?"[Circular ~]":"[Circular ~."+n.slice(0,r.indexOf(s)).join(".")+"]"},"cycleReplacer")),function(i,s){if(r.length>0){var u=r.indexOf(this);~u?r.splice(u+1):r.push(this),~u?n.splice(u,1/0,i):n.push(i),~r.indexOf(s)&&(s=t==null?void 0:t.call(this,i,s))}else r.push(s);return e==null?s:e.call(this,i,s)}}o(mt,"serializer");function pe(e,t,r,n){return JSON.stringify(e,mt(t,n),r)}o(pe,"jsonStringify");var Se=["1","true","yes","y","on"];function Br(e,t=!1){return e==null||typeof e!="string"?t:Se.includes(String(e).trim().toLowerCase())}o(Br,"stringToBoolean");function Nr(e,t=0){var r;return e==null||typeof e!="string"?t:(r=parseInt(e.trim(),10))!=null?r:t}o(Nr,"stringToInteger");function zr(e,t=0){var r;return e==null||typeof e!="string"?t:(r=parseFloat(e.trim()))!=null?r:t}o(zr,"stringToFloat");function yt(e,t=!1){return e==null?t:typeof e=="boolean"?e:typeof e=="number"?e!==0:Se.includes(String(e).trim().toLowerCase())}o(yt,"valueToBoolean");function gt(e,t=0){var r;return e==null?t:typeof e=="boolean"?e?1:0:typeof e=="number"?Math.floor(e):(r=parseInt(String(e).trim(),10))!=null?r:t}o(gt,"valueToInteger");function ht(e,t=0){var r;return e==null?t:typeof e=="boolean"?e?1:0:typeof e=="number"?Math.floor(e):(r=parseFloat(String(e).trim()))!=null?r:t}o(ht,"valueToFloat");function de(e,t=""){var r;return e==null?t:(r=String(e))!=null?r:t}o(de,"valueToString");var Hr=ht,Jr=gt,qr=de,Gr=yt;function xt(e,t={}){let{trace:r=!0,pretty:n=!0}=t;return e.map(i=>i&&typeof i=="object"?i instanceof Error?r?`${i.name||"Error"}: ${i.message}
|
|
4
|
+
${i.stack}`:`${i.name||"Error"}: ${i.message}`:n?pe(i,null,2):pe(i):String(i))}o(xt,"formatMessages");function Wr(e,t={}){return xt(e,t).join(" ")}o(Wr,"renderMessages");function Qr(e){try{return decodeURIComponent(escape(e))}catch{}return e}o(Qr,"fixBrokenUth8String");var bt={symbol:"$",separator:",",decimal:".",errorOnInvalid:!1,precision:2,pattern:"!#",negativePattern:"-!#",format:Mt,fromCents:!1},Ie=o(e=>Math.round(e),"round"),me=o(e=>Math.pow(10,e),"pow"),Tt=o((e,t)=>Ie(e/t)*t,"rounding"),wt=/(\d)(?=(\d{3})+\b)/g,At=/(\d)(?=(\d\d)+\d\b)/g;function B(e,t={}){return new F(e,t)}o(B,"currency");var re=class{constructor(t,r={}){var u;let n=Object.assign({},bt,r),i=me((u=n.precision)!=null?u:2),s=te(t,n);this.intValue=s,this.value=s/i,n.increment=n.increment||1/i,n.useVedic?n.groups=At:n.groups=wt,this._settings=n,this._precision=i}add(t){let{intValue:r,_settings:n,_precision:i}=this;return B((r+=te(t,n))/(n.fromCents?1:i),n)}subtract(t){let{intValue:r,_settings:n,_precision:i}=this;return B((r-=te(t,n))/(n.fromCents?1:i),n)}multiply(t){let{intValue:r,_settings:n,_precision:i}=this;return B((r*=t)/(n.fromCents?1:me(i)),n)}divide(t){let{intValue:r,_settings:n}=this;return B(r/=te(t,n,!1),n)}distribute(t){let{intValue:r,_precision:n,_settings:i}=this,s=[],u=Math[r>=0?"floor":"ceil"](r/t),a=Math.abs(r-u*t),c=i.fromCents?1:n;for(;t!==0;t--){let f=B(u/c,i);a-- >0&&(f=f[r>=0?"add":"subtract"](1/c)),s.push(f)}return s}dollars(){return~~this.value}cents(){let{intValue:t,_precision:r}=this;return~~(t%r)}format(t){let{_settings:r}=this;return typeof t=="function"?t(this,r):r.format(this,Object.assign({},r,t))}toString(){let{intValue:t,_precision:r,_settings:n}=this;return Tt(t/r,n.increment).toFixed(n.precision)}toJSON(){return this.value}static sum(...t){return V(t).reduce((r,n)=>B(r).add(n),this.zero)}static avg(...t){let r=V(t);return r.reduce((n,i)=>B(n).add(i),this.zero).divide(r.length)}},F=re;o(F,"Currency"),F.zero=new re(0),F.one=new re(1);function te(e,t,r=!0){let n=0,{decimal:i,errorOnInvalid:s,precision:u,fromCents:a}=t,c=me(u),f=typeof e=="number";if(e instanceof F&&a)return e.intValue;if(f||e instanceof F)n=e instanceof F?e.value:e;else if(typeof e=="string"){let d=new RegExp("[^-\\d"+i+"]","g"),m=new RegExp("\\"+i,"g");n=e.replace(/\((.*)\)/,"-$1").replace(d,"").replace(m,"."),n=n||0}else{if(s)throw Error("Invalid Input");n=0}return a||(n*=c,n=n.toFixed(4)),r?Ie(n):n}o(te,"parse");function Mt(e,t){let{pattern:r,negativePattern:n,symbol:i,separator:s,decimal:u,groups:a}=t,c=(""+e).replace(/^-/,"").split("."),f=c[0],d=c[1];return(e.value>=0?r:n).replace("!",i).replace("#",f.replace(a,"$1"+s)+(d?u+d:""))}o(Mt,"format");var _=o(e=>Math.abs(e)%1===.5,"isHalf"),Oe=o(e=>e%2===0,"isEven"),Zr=o(e=>Math.ceil(e),"roundUp"),Kr=o(e=>Math.floor(e),"roundDown"),Yr=o(e=>Math.round(e),"roundHalfUp"),Xr=o(e=>{let t=Math.round(e);return _(e)&&Oe(t)?t-1:t},"roundHalfOdd"),en=o(e=>_(e)?Math.sign(e)*Math.ceil(Math.abs(e)):Math.round(e),"roundHalfAwayFromZero"),tn=o(e=>_(e)?Math.floor(e):Math.round(e),"roundHalfDown"),rn=o(e=>{let t=Math.round(e);return _(e)?Oe(t)?t:t-1:t},"roundHalfEven"),nn=o(e=>_(e)?Math.sign(e)*Math.floor(Math.abs(e)):Math.round(e),"roundHalfTowardsZero");var{warn:Fe}=b("zeed:promise");async function an(e){return new Promise(t=>setTimeout(t,e))}o(an,"sleep");async function un(){return new Promise(e=>setTimeout(e,0))}o(un,"immediate");var Re=Symbol("timeout");async function cn(e,t,r=Re){return new Promise(async(n,i)=>{let s=!1,u=setTimeout(()=>{s=!0,n(r)},t);try{let a=await e;clearTimeout(u),s||n(a)}catch(a){clearTimeout(u),s||i(a)}})}o(cn,"timeout");var $e=new Error("Timeout reached");function fn(e){return e===Re||e===$e}o(fn,"isTimeout");async function ve(e,t){return t<=0?await e:new Promise(async(r,n)=>{let i=!1,s=setTimeout(()=>{i=!0,n($e)},t);try{let u=await e;clearTimeout(s),i||r(u)}catch(u){clearTimeout(s),i||n(u)}})}o(ve,"tryTimeout");function ln(e,t,r=1e3){return new Promise((n,i)=>{let s=o(c=>{a&&(clearTimeout(a),u(),n(c))},"fn"),u=o(()=>{a=null,e.off?e.off(t,s):e.removeEventListener?e.removeEventListener(t,s):Fe("No remove listener method found for",e,t)},"done"),a=setTimeout(()=>{u(),i(new Error("Did not response in time"))},r);e.on?e.on(t,s):e.addEventListener?e.addEventListener(t,s):Fe("No listener method found for",e)})}o(ln,"waitOn");function C(e){return Boolean(e&&(e instanceof Promise||typeof e.then=="function"))}o(C,"isPromise");function N(e){return Promise.resolve(e)}o(N,"promisify");var Be=1e3*60*60*24,w=class{constructor(t){var r;if(typeof t=="number"){this.days=t;return}if(t!=null&&(t=(r=w.from(t))==null?void 0:r.days),t==null){let n=new Date;this.days=n.getFullYear()*1e4+(n.getMonth()+1)*100+n.getDate()}else this.days=t}static fromNumber(t){return new w(t)}static fromString(t){return new w(+t.replace(/[^0-9]/g,""))}static fromDate(t,r=!1){return r?w.fromString(t.toISOString().substr(0,10)):new w(t.getFullYear()*1e4+(t.getMonth()+1)*100+t.getDate())}static fromDateGMT(t){return w.fromDate(t,!0)}static from(t,r=!1){if(typeof t=="number")return new w(t);if(typeof t=="string")return w.fromString(t);if(t instanceof Date)return w.fromDate(t,r);if(t instanceof w)return t}toNumber(){return this.days}toJson(){return this.days}toString(t="-"){let r=String(this.days);return r.slice(0,4)+t+r.slice(4,6)+t+r.slice(6,8)}toDate(t=!1){return t?new Date(`${this.toString()}T00:00:00.000Z`):new Date(this.days/1e4,this.days/100%100-1,this.days%100)}toDateGMT(){return this.toDate(!0)}dayOffset(t){return w.fromDateGMT(new Date(this.toDateGMT().getTime()+t*Be))}daysUntil(t){var r;return Math.round((((r=new w(t))==null?void 0:r.toDateGMT().getTime())-this.toDateGMT().getTime())/Be)}yesterday(){return this.dayOffset(-1)}tomorrow(){return this.dayOffset(1)}};o(w,"Day");async function mn(e,t,r){let n=w.from(e),i=w.from(t);for(;n&&i&&(n==null?void 0:n.days)<=(i==null?void 0:i.days);){let s=r(n);C(s)&&await s,n=n.dayOffset(1)}}o(mn,"forEachDay");function yn(){return new w}o(yn,"today");function gn(e){return new w(e)}o(gn,"day");var Ne=o(e=>e.replace(/&/g,"&").replace(/</g,"<").replace(/>/g,">").replace(/'/g,"'").replace(/"/g,"""),"escapeHTML"),xn=o(e=>e.replace(/</gi,"<").replace(/>/gi,">").replace(/"/gi,'"').replace(/'/gi,"'").replace(/&/gi,"&"),"unescapeHTML");function Tn(e=.25){return Math.random()<e}o(Tn,"randomBoolean");function wn(e=100,t=0){return t+Math.floor(Math.random()*(e-t))}o(wn,"randomInt");function An(e=100,t=0){return t+Math.random()*(e-t)}o(An,"randomFloat");function Mn(e,t,r){return Math.max(e,Math.min(r,t))}o(Mn,"between");var Pt=100,ze=/[\u0000-\u001F\u0080-\u009F]/g,Et=/^\.+/,Lt=/\.+$/;function He(){return/[<>:"/\\|?*\u0000-\u001F]/g}o(He,"filenameReservedRegex");function Ct(){return/^(con|prn|aux|nul|com\d|lpt\d)$/i}o(Ct,"windowsReservedNameRegex");function En(e){if(typeof e!="string")throw new TypeError("Expected a string");let t="_";if(He().test(t)&&ze.test(t))throw new Error("Replacement string cannot contain reserved filename characters");return e=e.replace(He(),t).replace(ze,t).replace(Et,t).replace(Lt,""),e=Ct().test(e)?e+t:e,e.slice(0,Pt)}o(En,"toValidFilename");var Ut=/[\\\-\[\]\/{}()*+?.^$|]/g;function Cn(e){return e?e instanceof RegExp?e.source:e.replace(Ut,"\\$&"):""}o(Cn,"escapeRegExp");function Je(e){return e.reduce((t,r)=>Math.min(t,r.sort_weight||0),0)-1-Math.random()}o(Je,"startSortWeight");function qe(e){return e.reduce((t,r)=>Math.max(t,r.sort_weight||0),0)+1+Math.random()}o(qe,"endSortWeight");function Dn(e,t,r){let n=r.length,i=e<t;if(n<=0||e>=n-1)return qe(r);if(e<=0)return Je(r);r=Dt([...r]);let s=i?-1:0,u=r[e+s].sort_weight||0,c=(r[e+s+1].sort_weight||0)-u;if(c===0)return i?Je(r):qe(r);let f=u+c/2,d=c*.01*(Math.random()-.5);return f+d}o(Dn,"moveSortWeight");function Dt(e){return e.sort((t,r)=>(t.sort_weight||0)-(r.sort_weight||0)),e}o(Dt,"sortedItems");var kt=/((?:(?:(?:https?|ftp):)?\/\/)(?:\S+(?::\S*)?@)?(?:(?!(?:10|127)(?:\.\d{1,3}){3})(?!(?:169\.254|192\.168)(?:\.\d{1,3}){2})(?!172\.(?:1[6-9]|2\d|3[0-1])(?:\.\d{1,3}){2})(?:[1-9]\d?|1\d\d|2[01]\d|22[0-3])(?:\.(?:1?\d{1,2}|2[0-4]\d|25[0-5])){2}(?:\.(?:[1-9]\d?|1\d\d|2[0-4]\d|25[0-4]))|(?:(?:[a-z0-9\u00a1-\uffff][a-z0-9\u00a1-\uffff_-]{0,62})?[a-z0-9\u00a1-\uffff]\.)+(?:[a-z\u00a1-\uffff]{2,}\.?))(?::\d{2,5})?(?:[/?#]\S*)?)/gim;function In(e){return e.split(kt).map((t,r)=>{let n=Ne(t);return r%2?`<a target="_blank" href="${n}">${St(n)}</a>`:n}).join("")}o(In,"linkifyPlainText");function St(e){return e.replace(/^https?:\/\/(www\.)?/,"").replace(/\/$/,"")}o(St,"toHumanReadableUrl");function Ge(e){let t=[];for(let[r,n]of Object.entries(e))if(n!=null){Array.isArray(n)||(n=[n]);for(let i of n)i!=null&&t.push(encodeURIComponent(r)+"="+encodeURIComponent(i.toString()||""))}return t.join("&")}o(Ge,"encodeQuery");function On(e){let t={},r=(e[0]==="?"?e.substr(1):e).split("&");for(let n=0;n<r.length;n++){let i=r[n].split("="),s=decodeURIComponent(i[0]),u=decodeURIComponent(i[1]||"");t[s]!=null?(Array.isArray(t[s])||(t[s]=[t[s]]),t[s].push(u)):t[s]=u}return t}o(On,"parseQuery");function Rn(e){return e!=null?e.size!=null?e.size:e.length!=null?e.length:Object.keys(e).length:0}o(Rn,"size");function $n(e){return e!=null&&e.length>0?e[e.length-1]:void 0}o($n,"last");function vn(e){try{if(e!=null)return Array.isArray(e)||typeof e=="string"?e.length<=0:(e==null?void 0:e.size)!=null?e.size<=0:Object.keys(e).length<=0}catch(t){console.error("Failed to check if empty for",e,t)}return!0}o(vn,"empty");function ye(e){return Object(e)!==e?e:JSON.parse(JSON.stringify(e))}o(ye,"cloneObject");function Bn(e){return Object(e)!==e?e:JSON.parse(JSON.stringify(e))}o(Bn,"cloneJsonObject");async function It(e){typeof e=="function"?await N(e()):C(e)?await e:typeof e.dispose=="function"?await N(e.dispose()):C(e.dispose)?await e.dispose:typeof e.cleanup=="function"?await N(e.cleanup()):C(e.cleanup)&&await e.cleanup}o(It,"callDisposer");function Ot(){let e=[],t=o(async i=>{e.includes(i)&&(le(e,s=>s!==i),await It(i))},"untrack"),r=o(async()=>{for(;e.length>0;)await t(e[0])},"dispose"),n=o(i=>(e.unshift(i),()=>t(i)),"track");return Object.assign(r,{track:n,add:n,untrack:t,dispose:r,exec:r,getSize(){return e.length}})}o(Ot,"useDispose");var Jn=Ot;function qn(e={}){let{mode:t="fifo"}=e,r=[],n=o(async(s=!1)=>{for(;r.length>0;){let u=r[0];if(le(r,a=>a!==u),typeof u=="function"){let a=u();if(C(a)){if(s)throw new Error(`Expected sync only function, but found async: ${u}`);await a}}else if(C(u)){if(s)throw new Error(`Expected sync only function, but found async: ${u}`);await u}else throw new Error(`Unhandled disposable: ${u}`)}},"exec");return Object.assign(n,{add:o(s=>{t==="lifo"?r.unshift(s):r.push(s)},"add"),exec:n,getSize(){return r.length}})}o(qn,"useDefer");function Gn(e,t=0){let r=setTimeout(e,t);return()=>{r&&(clearTimeout(r),r=void 0)}}o(Gn,"useTimeout");function jn(e,t){let r=setInterval(e,t);return()=>{r&&(clearInterval(r),r=void 0)}}o(jn,"useInterval");function Wn(e,t,r,...n){return e==null?()=>{}:(e.on?e.on(t,r,...n):e.addEventListener&&e.addEventListener(t,r,...n),()=>{e.off?e.off(t,r,...n):e.removeEventListener&&e.removeEventListener(t,r,...n)})}o(Wn,"useEventListener");function Vn(e=(r=>(r=(t=>(t=globalThis==null?void 0:globalThis.location)==null?void 0:t.hostname)())!=null?r:"")()){return["localhost","127.0.0.1","","::1","::"].includes(e)||e.startsWith("192.168.")||e.startsWith("10.0.")||e.endsWith(".local")}o(Vn,"isLocalHost");var{encode:ge,decode:je}=O(62),{encode:Ft}=O(32);function We(){return H(16)}o(We,"uuidBytes");var Xn=o(()=>new Uint32Array(H(4))[0],"uuid32bit");function Z(){return ge(We(),22)}o(Z,"uuid");function eo(e){return ge(e,22)}o(eo,"uuidEncode");function to(e){return je(e,16)}o(to,"uuidDecode");function ro(){return Ft(We(),26)}o(ro,"uuidB32");var he={};function z(e="id"){return he[e]==null&&(he[e]=0),`${e}-${he[e]++}`}o(z,"uname");var Rt=0;function no(){return`id-${Rt++}`}o(no,"qid");var $t="10000000-1000-4000-8000-100000000000",oo=o(()=>$t.replace(/[018]/g,e=>(e^H(1)[0]&15>>e/4).toString(16)),"uuidv4"),Qe=16e11;function vt(e){var t=new Uint8Array([0,0,0,0,0,0]);let r=t.length-1;for(var n=0;n<t.length;n++){var i=e&255;t[r-n]=i,e=(e-i)/256}return t}o(vt,"longToByteArray");function Bt(){let e=we()-Qe;return new Uint8Array([...vt(e),...H(10)])}o(Bt,"suidBytes");function io(){return ge(Bt(),22)}o(io,"suid");function so(e){return Nt(je(e,16))}o(so,"suidDate");function Nt(e){return new Date(Qe+e.slice(0,6).reduce((t,r)=>t*256+r,0))}o(Nt,"suidBytesDate");var J=b("zeed:emitter"),R=class{constructor(){this.subscribers={};this.subscribersOnAny=[];this.call=new Proxy({},{get:(t,r)=>(...n)=>this.emit(r,...n)})}async emit(t,...r){let n=!1;try{let i=this.subscribers[t]||[];if(this.subscribersOnAny.forEach(s=>s(t,...r)),i.length>0){let s=i.map(u=>{try{return N(u(...r))}catch(a){J.warn("emit warning:",a)}});n=!0,await Promise.all(s)}}catch(i){J.error("emit exception",i)}return n}onAny(t){this.subscribersOnAny.push(t)}on(t,r){let n=this.subscribers[t]||[];return n.push(r),this.subscribers[t]=n,()=>{this.off(t,r)}}onCall(t){for(let[r,n]of Object.entries(t))this.on(r,n)}once(t,r){let n=o(async(...i)=>(this.off(t,n),await N(r(...i))),"onceListener");return this.on(t,n),()=>{this.off(t,r)}}off(t,r){return this.subscribers[t]=(this.subscribers[t]||[]).filter(n=>r&&n!==r),this}removeAllListeners(t){return this.subscribers={},this}dispose(){this.subscribers={},this.subscribersOnAny=[]}};o(R,"Emitter");function lo(){let e=ie().emitter;return e||(e=new R,ie().emitter=e),e}o(lo,"getGlobalEmitter");var po=new R;function mo(e,t){let r=Math.round(Math.random()*100);var n=[],i;let s=o((a,c)=>{let f={key:a,obj:c};n.push(f),i&&i()},"incoming");return t?e.on?e.on(t,a=>{s(t,a)}):e.addEventListener?e.addEventListener(t,a=>{s(t,a)}):J.error(r,"Cannot listen to key"):e.onAny?e.onAny((a,c)=>{s(a,c)}):J.error(r,"cannot listen to all for",e),o((a,c=!0)=>new Promise((f,d)=>{a||(a=t,a||n.length&&(a=n[0].key)),i=o(()=>{for(;n.length>0;){let m=n.shift();if(m.key===a)i=void 0,f(m.obj);else{if(c){J.warn(r,`Unhandled event ${a} with value: ${m.obj}`);continue}d(`Expected ${a}, but found ${m.key} with value=${m.obj}`),J.error(r,`Unhandled event ${a} with value: ${m.obj}`)}break}},"lazyResolve"),i()}),"on")}o(mo,"lazyListener");var xe=class extends R{constructor(){super(...arguments);this.id=Z()}close(){}};o(xe,"Channel");var ne=class extends xe{constructor(){super(...arguments);this.isConnected=!0}postMessage(t){var r;(r=this.other)==null||r.emit("message",{data:t,origin:"local",lastEventId:Z()})}};o(ne,"LocalChannel");function xo(){let e=new ne,t=new ne;return e.other=t,t.other=e,[e,t]}o(xo,"fakeWorkerPair");var q=class{async encode(t){return se(t)}async decode(t){return ae(t)}};o(q,"JsonEncoder");var Ve=class{constructor(t){this.key=t}async encode(t){let r=se(t);return await Ce(r,this.key)}async decode(t){let r=await Ue(t,this.key);return ae(r)}};o(Ve,"CryptoEncoder");var _e=o((e,t,r={})=>new Proxy(r,{get:(n,i)=>i in n?n[i]:(...s)=>e(i,s,t)}),"createPromiseProxy");function Do(e={}){let{name:t=z("hub"),encoder:r=new q,retryAfter:n=1e3,ignoreUnhandled:i=!0}=e,s=b(t),u={},a,c=[],f,d={},m=o(()=>{clearTimeout(f)},"dispose"),L=o(async()=>{if(clearTimeout(f),a){if(a.isConnected)for(;c.length;){let y=c[0];try{a.postMessage(await r.encode(y)),c.shift()}catch(g){s.warn("postMessage",g);break}}c.length>0&&n>0&&(f=setTimeout(L,n))}},"postNext"),M=o(async y=>{s("enqueue postMessage",y),c.push(y),await L()},"postMessage"),P=o(async y=>{a=y,a.on("connect",L),a.on("message",async g=>{s("onmessage",typeof g);let{name:E,args:S,id:T,result:k,error:$}=await r.decode(g.data);if(E){s(`name ${E} id ${T}`);try{if(u[E]==null)throw new Error(`handler for ${E} was not found`);let U=u[E](...S);C(U)&&(U=await U),s(`result ${U}`),T&&M({id:T,result:U})}catch(U){let v=U instanceof Error?U:new Error(de(U));s.warn("execution error",v.name),M({id:T,error:{message:v.message,stack:v.stack,name:v.name}})}}else if(T)if(s(`response for id=${T}: result=${k}, error=${$}`),d[T]==null)k===void 0?s(`skip response for ${T}`):s.warn(`no response hook for ${T}`);else{let[U,v]=d[T];if(U&&v)if(delete d[T],$){let K=new Error($.message);K.stack=$.stack,K.name=$.name,s.warn("reject",K.name),v(K)}else s("resolve",k),U(k)}else i||s.warn("Unhandled message",g)}),L()},"connect"),x=o(async(y,g,E={})=>{let{timeout:S=5e3}=E,T=Z();return M({name:y,args:g,id:T}),ve(new Promise((k,$)=>d[T]=[k,$]),S)},"fetchMessage");return e.channel&&P(e.channel),{dispose:m,connect:P,listen(y){Object.assign(u,y)},send(){return _e(x,{},{options(y){return _e(x,I({},y))}})}}}o(Do,"useMessageHub");var be=class extends R{constructor(t){super();this.publish=this.emit;this.subscribe=this.on;var u;let{name:r,encoder:n=new q,channel:i,debug:s=!1}=t;this.channel=i,this.encoder=n,this.debug=s,this.name=(u=r!=null?r:this.channel.id)!=null?u:z("pubsub"),this.log=b(`${this.shortId}`),this.debug&&(this.channel.on("connect",()=>{this.log("channel connected")}),this.channel.on("disconnect",()=>{this.log("channel disconnected")})),this.channel.on("message",async({data:a})=>{let c=await this.encoder.decode(a);if(this.debug?this.log(`channel message, event=${c==null?void 0:c.event}, info=`,c):this.log(`channel message, event=${c==null?void 0:c.event}`),c){let{event:f,args:d}=c;await this.emitSuper(f,...d)}})}get shortId(){return this.name.substr(0,6)}async emitSuper(t,...r){return await super.emit(t,...r)}async emit(t,...r){try{if(this.debug?this.log(`emit(${t})`,t):this.log(`emit(${t})`,r.length),!this.channel.isConnected)return this.log.warn("channel not connected"),!1;let n=await this.encoder.encode({event:t,args:r});return this.channel.postMessage(n),!0}catch(n){this.log.warn(`emit(${t})`,n)}return!1}};o(be,"PubSub");function Bo(e){return new be(e)}o(Bo,"usePubSub");function Ho(){let e=!0;return(t,r)=>{let n=!1;if(e){e=!1;try{t(),n=!0}finally{e=!0}}else r!==void 0&&r();return n}}o(Ho,"useMutex");function Jo(){let e=!0;return async(t,r)=>{let n=!1;if(e){e=!1;try{let i=t();C(i)&&await i,n=!0}finally{e=!0}}else if(r!==void 0){let i=r();C(i)&&await i}return n}}o(Jo,"useAsyncMutex");var G=b("network"),oe={cache:"no-cache",redirect:"follow"};async function Ze(e,t={},r=fetch){try{let n=await r(e,t);if(n.status<400)return n;try{G.warn(`Fetch of ${e} with ${t} returned status=${n.status}`),G.warn(`Response: ${await n.text()}`)}catch(i){G.error("Exception:",i)}}catch(n){G.error("fetchBasic",n)}}o(Ze,"fetchBasic");async function Wo(e,t={},r=fetch){try{let n=await Ze(e,I(Q(I({method:"GET"},oe),{headers:{}}),t),r);if(n)return await n.json()}catch(n){G.error("fetchJSON error:",n)}}o(Wo,"fetchJson");function Qo(e,t="POST"){return Q(I({method:t},oe),{headers:{"Content-Type":"application/x-www-form-urlencoded; charset=utf-8"},body:Ge(e)})}o(Qo,"fetchOptionsFormURLEncoded");function Vo(e,t="POST"){return Q(I({method:t},oe),{headers:{"Content-Type":"application/json; charset=utf-8",Accept:"application/json"},body:JSON.stringify(e)})}o(Vo,"fetchOptionsJson");async function _o(e,t={},r=fetch){try{let n=await Ze(e,I(Q(I({method:"GET"},oe),{headers:{}}),t),r);if(n)return await n.text()}catch(n){G.error("fetchHTML error:",n)}}o(_o,"fetchText");function Ke(){if(typeof window!="undefined")return window}o(Ke,"getWindow");function zt(){if(typeof navigator!="undefined")return navigator}o(zt,"getNavigator");function Ko(){var e;return((e=Ke())!=null?e:typeof WorkerGlobalScope!="undefined")?self:typeof global!="undefined"?global:Function("return this;")()}o(Ko,"getGlobal");var h=zt(),A=Ke();function Ht(e={ios:!1,macos:!1,windows:!1,beaker:!1,electron:!1,wkwebview:!1,pwa:!1,pwaInstalled:!1,browser:!1,node:!1,worker:!1,jest:!1,macosNative:!1,iosNative:!1,appleNative:!1,touch:!1}){var t,r,n,i,s,u,a,c,f;return e.ios=((t=h==null?void 0:h.platform)==null?void 0:t.match(/(iPhone|iPod|iPad)/i))!=null,e.macos=!!((r=h==null?void 0:h.platform)==null?void 0:r.startsWith("Mac")),e.windows=!!((n=h==null?void 0:h.platform)==null?void 0:n.startsWith("Win")),e.beaker=(A==null?void 0:A.beaker)!=null,e.electron=(((s=(i=h==null?void 0:h.userAgent)==null?void 0:i.toLowerCase())==null?void 0:s.indexOf(" electron/"))||-1)>-1&&!e.beaker,e.wkwebview=((u=A==null?void 0:A.webkit)==null?void 0:u.messageHandlers)!=null,e.pwa=(h==null?void 0:h.serviceWorker)!=null,e.pwaInstalled=(h==null?void 0:h.standalone)||((c=(a=A==null?void 0:A.matchMedia)==null?void 0:a.call(A,"(display-mode: standalone)"))==null?void 0:c.matches),e.node=typeof process!="undefined"&&((f=process==null?void 0:process.release)==null?void 0:f.name)==="node",e.browser=!e.electron&&!e.wkwebview&&!e.node,e.worker=typeof WorkerGlobalScope!="undefined"&&self instanceof WorkerGlobalScope,e.jest=typeof jest!="undefined",e.macosNative=e.wkwebview&&e.macos,e.iosNative=e.wkwebview&&e.ios,e.appleNative=e.wkwebview,e.touch=A&&"ontouchstart"in A||((h==null?void 0:h.maxTouchPoints)||0)>1||(h==null?void 0:h.msPointerEnabled)&&(A==null?void 0:A.MSGesture)||(A==null?void 0:A.DocumentTouch)&&document instanceof DocumentTouch,e}o(Ht,"detect");var Jt=o(()=>typeof window!="undefined"&&globalThis===window,"isBrowser"),Yo=Ht();function Xo(e){Jt()?window.addEventListener("beforeunload",e):typeof process!="undefined"&&process.on("exit",()=>e)}o(Xo,"useExitHandler");function ti(e={}){let{maxParallel:t=3}=e,r=0,n=0,i={};function s(){if(r>=t)return;let a=Object.values(i).filter(c=>!c.running);if(a.length>0){let c;for(let f of a)(c==null||f.priority<c.priority)&&(c=f);c&&(c.running=!0,++r,c.task().then(f=>{(c==null?void 0:c.id)&&delete i[c.id],--r,s()}).catch(f=>{(c==null?void 0:c.id)&&delete i[c.id],--r,s()}))}}o(s,"performNext");function u(a){let c=i[a];c&&c.running!==!0&&delete i[a]}return o(u,"cancel"),{cancel:u,enqueue(a,c){return i[a]==null&&(i[a]={id:a,task:c,priority:++n,running:!1},s()),()=>u(a)}}}o(ti,"usePool");var qt=b("zeed:queue"),Ye=class{constructor(t={}){this.queue=[];this.isPaused=!1;this.waitToFinish=[];let{name:r=z("queue"),logLevel:n}=t;this.name=r,this.log=b(`zeed:queue:${r}`),this.log.level=n!=null?n:1/0}async performNext(){if(this.log("performNext, queue.length =",this.queue.length),this.currentTask!=null){this.log("performNext => skip while another task is running");return}if(this.isPaused){this.log("performNext => skip while is paused");return}for(;this.currentTask==null&&!this.isPaused;){let t=this.queue.shift();if(this.log(`performNext => ${t==null?void 0:t.name}`),t==null)break;let{name:r,task:n,resolve:i}=t;this.currentTask=n();let s;try{this.log.info(`start task ${r}`),s=await this.currentTask,this.log(`finished task ${r} with result =`,s)}catch(u){qt.warn("Error performing task",u)}i(s),this.currentTask=void 0}for(;this.waitToFinish.length>0;)this.waitToFinish.shift()()}async enqueue(t,r={}){let{immediate:n=!1,name:i=z(this.name)}=r;return n?(this.log.info(`immediate execution ${i}`),await t()):(this.log(`enqueue ${i}`),new Promise(s=>{this.queue.push({name:i,task:t,resolve:s}),this.performNext()}))}async enqueueReentrant(t,r={}){return this.enqueue(t,{immediate:this.currentTask!=null,name:r.name})}async cancelAll(t=!0){this.log("cancelAll");let r=this.queue.map(n=>n.resolve);this.queue=[],r.forEach(n=>n(void 0)),await this.wait()}async pause(){this.log("pause"),this.isPaused=!0,await this.wait()}resume(){this.log("resume"),this.isPaused=!1,this.performNext()}async wait(){if(this.log("wait"),!(this.currentTask==null&&(this.queue.length===0||this.isPaused)))return new Promise(t=>{this.waitToFinish.push(t)})}};o(Ye,"SerialQueue");var fi=b("zeed:memstorage"),Xe=class{constructor(t={}){this.store={}}setItem(t,r){this.store[t]=ye(r)}getItem(t){if(this.store.hasOwnProperty(t))return ye(this.store[t])}removeItem(t){delete this.store[t]}clear(){this.store={}}allKeys(){return Object.keys(this.store)}};o(Xe,"MemStorage");var j=!1,W=j?b("zeed:throttle"):()=>{};function di(e,t={}){let{delay:r=100,trailing:n=!0,leading:i=!0}=t,s=0,u=0,a=0,c=Date.now();function f(){s&&(clearTimeout(s),s=void 0)}o(f,"clearExistingTimeout");function d(...m){let L=Date.now(),M=this,P=L-u;function x(){let g=Date.now();return`total ${(g-c).toFixed(1)}ms - elapsed ${(g-u).toFixed(1)}ms - visited ${a}x`}o(x,"debugElapsed");function y(){a=0,u=Date.now(),e.apply(M,m)}if(o(y,"exec"),P>r||!s){j&&W("elapsed",x()),i&&(P>r?(j&&W("\u{1F680} leading",x()),y()):++a);let g=P>r?r:r-P;W(`\u23F1 start timeout with ${g.toFixed(1)}ms}`,x()),f(),u=L,s=setTimeout(()=>{j&&W("\u23F1 reached timeout",x()),s=0,n&&(!i||a>0)&&(j&&W("\u{1F680} trailing",x()),y())},g)}else++a,j&&W("visited",x())}return o(d,"wrapper"),d.cancel=f,d.dispose=f,d}o(di,"throttle");function mi(e,t={}){let{delay:r=100}=t,n=0;function i(){n&&(clearTimeout(n),n=0)}o(i,"clearExistingTimeout");function s(...u){let a=this;i(),n=setTimeout(()=>{n=0,e.apply(a,u)},r)}return o(s,"wrapper"),s.cancel=i,s.dispose=i,s}o(mi,"debounce");export{Me as a,et as b,D as c,jt as d,Wt as e,Qt as f,Pe as g,se as h,ae as i,H as j,Kt as k,Yt as l,Ce as m,Ue as n,er as o,it as p,rr as q,ce as r,nr as s,fe as t,st as u,at as v,V as w,ut as x,sr as y,ar as z,ur as A,le as B,cr as C,fr as D,ct as E,lr as F,ft as G,ke as H,pr as I,dr as J,mr as K,yr as L,gr as M,hr as N,O,Ar as P,Mr as Q,Pr as R,Er as S,Lr as T,Cr as U,Ur as V,Dr as W,kr as X,Sr as Y,Or as Z,dt as _,Fr as $,Rr as aa,pe as ba,Br as ca,Nr as da,zr as ea,yt as fa,gt as ga,ht as ha,de as ia,Hr as ja,Jr as ka,qr as la,Gr as ma,xt as na,Wr as oa,Qr as pa,B as qa,F as ra,_ as sa,Oe as ta,Zr as ua,Kr as va,Yr as wa,Xr as xa,en as ya,tn as za,rn as Aa,nn as Ba,an as Ca,un as Da,Re as Ea,cn as Fa,$e as Ga,fn as Ha,ve as Ia,ln as Ja,C as Ka,N as La,Be as Ma,w as Na,mn as Oa,yn as Pa,gn as Qa,Ne as Ra,xn as Sa,Tn as Ta,wn as Ua,An as Va,Mn as Wa,En as Xa,Cn as Ya,Je as Za,qe as _a,Dn as $a,Dt as ab,In as bb,St as cb,Ge as db,On as eb,Rn as fb,$n as gb,vn as hb,ye as ib,Bn as jb,Ot as kb,Jn as lb,qn as mb,Gn as nb,jn as ob,Wn as pb,Vn as qb,We as rb,Xn as sb,Z as tb,eo as ub,to as vb,ro as wb,z as xb,no as yb,oo as zb,Bt as Ab,io as Bb,so as Cb,Nt as Db,R as Eb,lo as Fb,po as Gb,mo as Hb,xe as Ib,ne as Jb,xo as Kb,q as Lb,Ve as Mb,_e as Nb,Do as Ob,be as Pb,Bo as Qb,Ho as Rb,Jo as Sb,Ze as Tb,Wo as Ub,Qo as Vb,Vo as Wb,_o as Xb,Ke as Yb,zt as Zb,Ko as _b,Ht as $b,Jt as ac,Yo as bc,Xo as cc,ti as dc,Ye as ec,Xe as fc,di as gc,mi as hc};
|
|
5
|
+
//# sourceMappingURL=chunk-7Y3767YF.js.map
|