@xyo-network/archivist-cookie 2.88.3 → 2.89.0-rc.2
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/browser/CookieArchivist.d.cts +3 -2
- package/dist/browser/CookieArchivist.d.cts.map +1 -1
- package/dist/browser/CookieArchivist.d.mts +3 -2
- package/dist/browser/CookieArchivist.d.mts.map +1 -1
- package/dist/browser/CookieArchivist.d.ts +3 -2
- package/dist/browser/CookieArchivist.d.ts.map +1 -1
- package/dist/browser/index.cjs +14 -17
- package/dist/browser/index.cjs.map +1 -1
- package/dist/browser/index.js +14 -17
- package/dist/browser/index.js.map +1 -1
- package/dist/node/CookieArchivist.d.cts +3 -2
- package/dist/node/CookieArchivist.d.cts.map +1 -1
- package/dist/node/CookieArchivist.d.mts +3 -2
- package/dist/node/CookieArchivist.d.mts.map +1 -1
- package/dist/node/CookieArchivist.d.ts +3 -2
- package/dist/node/CookieArchivist.d.ts.map +1 -1
- package/dist/node/index.cjs +14 -17
- package/dist/node/index.cjs.map +1 -1
- package/dist/node/index.js +14 -17
- package/dist/node/index.js.map +1 -1
- package/package.json +13 -11
- package/src/CookieArchivist.ts +17 -18
|
@@ -1,3 +1,4 @@
|
|
|
1
|
+
import { Hash } from '@xylabs/hex';
|
|
1
2
|
import { Promisable, PromisableArray } from '@xylabs/promise';
|
|
2
3
|
import { AbstractArchivist } from '@xyo-network/archivist-abstract';
|
|
3
4
|
import { ArchivistConfig, ArchivistModuleEventData, ArchivistParams } from '@xyo-network/archivist-model';
|
|
@@ -24,8 +25,8 @@ export declare class CookieArchivist<TParams extends CookieArchivistParams, TEve
|
|
|
24
25
|
protected allHandler(): PromisableArray<Payload>;
|
|
25
26
|
protected clearHandler(): void | Promise<void>;
|
|
26
27
|
protected commitHandler(): Promise<BoundWitness[]>;
|
|
27
|
-
protected deleteHandler(hashes:
|
|
28
|
-
protected getHandler(hashes:
|
|
28
|
+
protected deleteHandler(hashes: Hash[]): Promise<string[]>;
|
|
29
|
+
protected getHandler(hashes: Hash[]): Promisable<Payload[]>;
|
|
29
30
|
protected insertHandler(payloads: Payload[]): Promise<Payload[]>;
|
|
30
31
|
private keyFromHash;
|
|
31
32
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"CookieArchivist.d.ts","sourceRoot":"","sources":["../../src/CookieArchivist.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"CookieArchivist.d.ts","sourceRoot":"","sources":["../../src/CookieArchivist.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,IAAI,EAAE,MAAM,aAAa,CAAA;AAElC,OAAO,EAAa,UAAU,EAAE,eAAe,EAAE,MAAM,iBAAiB,CAAA;AACxE,OAAO,EAAE,iBAAiB,EAAE,MAAM,iCAAiC,CAAA;AACnE,OAAO,EAIL,eAAe,EAIf,wBAAwB,EACxB,eAAe,EAChB,MAAM,8BAA8B,CAAA;AACrC,OAAO,EAAE,YAAY,EAAE,MAAM,iCAAiC,CAAA;AAC9D,OAAO,EAAE,eAAe,EAAE,MAAM,2BAA2B,CAAA;AAE3D,OAAO,EAAE,OAAO,EAAE,MAAM,4BAA4B,CAAA;AAGpD,MAAM,MAAM,2BAA2B,GAAG,qCAAqC,CAAA;AAC/E,eAAO,MAAM,2BAA2B,EAAE,2BAAmE,CAAA;AAE7G,MAAM,MAAM,qBAAqB,GAAG,eAAe,CAAC;IAClD,MAAM,CAAC,EAAE,MAAM,CAAA;IACf,UAAU,CAAC,EAAE,MAAM,CAAA;IACnB,YAAY,CAAC,EAAE,MAAM,CAAA;IACrB,SAAS,CAAC,EAAE,MAAM,CAAA;IAClB,MAAM,EAAE,2BAA2B,CAAA;CACpC,CAAC,CAAA;AAEF,MAAM,MAAM,qBAAqB,GAAG,eAAe,CAAC,eAAe,CAAC,qBAAqB,CAAC,CAAC,CAAA;AAE3F,qBAAa,eAAe,CAC1B,OAAO,SAAS,qBAAqB,EACrC,UAAU,SAAS,wBAAwB,GAAG,wBAAwB,CACtE,SAAQ,iBAAiB,CAAC,OAAO,EAAE,UAAU,CAAC;IAC9C,OAAgB,aAAa,0CAAgC;IAE7D,IAAI,MAAM,uBAET;IAED,IAAI,UAAU,WAGb;IAED,IAAI,YAAY,WAGf;IAED,IAAI,SAAS,WAEZ;IAED,IAAa,OAAO,IAAI,MAAM,EAAE,CAS/B;cAEkB,UAAU,IAAI,eAAe,CAAC,OAAO,CAAC;cAWtC,YAAY,IAAI,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC;cAa9B,aAAa,IAAI,OAAO,CAAC,YAAY,EAAE,CAAC;cAuBxC,aAAa,CAAC,MAAM,EAAE,IAAI,EAAE,GAAG,OAAO,CAAC,MAAM,EAAE,CAAC;cAatD,UAAU,CAAC,MAAM,EAAE,IAAI,EAAE,GAAG,UAAU,CAAC,OAAO,EAAE,CAAC;cAS3C,aAAa,CAAC,QAAQ,EAAE,OAAO,EAAE,GAAG,OAAO,CAAC,OAAO,EAAE,CAAC;IAoB/E,OAAO,CAAC,WAAW;CAGpB"}
|
|
@@ -1,3 +1,4 @@
|
|
|
1
|
+
import { Hash } from '@xylabs/hex';
|
|
1
2
|
import { Promisable, PromisableArray } from '@xylabs/promise';
|
|
2
3
|
import { AbstractArchivist } from '@xyo-network/archivist-abstract';
|
|
3
4
|
import { ArchivistConfig, ArchivistModuleEventData, ArchivistParams } from '@xyo-network/archivist-model';
|
|
@@ -24,8 +25,8 @@ export declare class CookieArchivist<TParams extends CookieArchivistParams, TEve
|
|
|
24
25
|
protected allHandler(): PromisableArray<Payload>;
|
|
25
26
|
protected clearHandler(): void | Promise<void>;
|
|
26
27
|
protected commitHandler(): Promise<BoundWitness[]>;
|
|
27
|
-
protected deleteHandler(hashes:
|
|
28
|
-
protected getHandler(hashes:
|
|
28
|
+
protected deleteHandler(hashes: Hash[]): Promise<string[]>;
|
|
29
|
+
protected getHandler(hashes: Hash[]): Promisable<Payload[]>;
|
|
29
30
|
protected insertHandler(payloads: Payload[]): Promise<Payload[]>;
|
|
30
31
|
private keyFromHash;
|
|
31
32
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"CookieArchivist.d.ts","sourceRoot":"","sources":["../../src/CookieArchivist.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"CookieArchivist.d.ts","sourceRoot":"","sources":["../../src/CookieArchivist.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,IAAI,EAAE,MAAM,aAAa,CAAA;AAElC,OAAO,EAAa,UAAU,EAAE,eAAe,EAAE,MAAM,iBAAiB,CAAA;AACxE,OAAO,EAAE,iBAAiB,EAAE,MAAM,iCAAiC,CAAA;AACnE,OAAO,EAIL,eAAe,EAIf,wBAAwB,EACxB,eAAe,EAChB,MAAM,8BAA8B,CAAA;AACrC,OAAO,EAAE,YAAY,EAAE,MAAM,iCAAiC,CAAA;AAC9D,OAAO,EAAE,eAAe,EAAE,MAAM,2BAA2B,CAAA;AAE3D,OAAO,EAAE,OAAO,EAAE,MAAM,4BAA4B,CAAA;AAGpD,MAAM,MAAM,2BAA2B,GAAG,qCAAqC,CAAA;AAC/E,eAAO,MAAM,2BAA2B,EAAE,2BAAmE,CAAA;AAE7G,MAAM,MAAM,qBAAqB,GAAG,eAAe,CAAC;IAClD,MAAM,CAAC,EAAE,MAAM,CAAA;IACf,UAAU,CAAC,EAAE,MAAM,CAAA;IACnB,YAAY,CAAC,EAAE,MAAM,CAAA;IACrB,SAAS,CAAC,EAAE,MAAM,CAAA;IAClB,MAAM,EAAE,2BAA2B,CAAA;CACpC,CAAC,CAAA;AAEF,MAAM,MAAM,qBAAqB,GAAG,eAAe,CAAC,eAAe,CAAC,qBAAqB,CAAC,CAAC,CAAA;AAE3F,qBAAa,eAAe,CAC1B,OAAO,SAAS,qBAAqB,EACrC,UAAU,SAAS,wBAAwB,GAAG,wBAAwB,CACtE,SAAQ,iBAAiB,CAAC,OAAO,EAAE,UAAU,CAAC;IAC9C,OAAgB,aAAa,0CAAgC;IAE7D,IAAI,MAAM,uBAET;IAED,IAAI,UAAU,WAGb;IAED,IAAI,YAAY,WAGf;IAED,IAAI,SAAS,WAEZ;IAED,IAAa,OAAO,IAAI,MAAM,EAAE,CAS/B;cAEkB,UAAU,IAAI,eAAe,CAAC,OAAO,CAAC;cAWtC,YAAY,IAAI,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC;cAa9B,aAAa,IAAI,OAAO,CAAC,YAAY,EAAE,CAAC;cAuBxC,aAAa,CAAC,MAAM,EAAE,IAAI,EAAE,GAAG,OAAO,CAAC,MAAM,EAAE,CAAC;cAatD,UAAU,CAAC,MAAM,EAAE,IAAI,EAAE,GAAG,UAAU,CAAC,OAAO,EAAE,CAAC;cAS3C,aAAa,CAAC,QAAQ,EAAE,OAAO,EAAE,GAAG,OAAO,CAAC,OAAO,EAAE,CAAC;IAoB/E,OAAO,CAAC,WAAW;CAGpB"}
|
|
@@ -1,3 +1,4 @@
|
|
|
1
|
+
import { Hash } from '@xylabs/hex';
|
|
1
2
|
import { Promisable, PromisableArray } from '@xylabs/promise';
|
|
2
3
|
import { AbstractArchivist } from '@xyo-network/archivist-abstract';
|
|
3
4
|
import { ArchivistConfig, ArchivistModuleEventData, ArchivistParams } from '@xyo-network/archivist-model';
|
|
@@ -24,8 +25,8 @@ export declare class CookieArchivist<TParams extends CookieArchivistParams, TEve
|
|
|
24
25
|
protected allHandler(): PromisableArray<Payload>;
|
|
25
26
|
protected clearHandler(): void | Promise<void>;
|
|
26
27
|
protected commitHandler(): Promise<BoundWitness[]>;
|
|
27
|
-
protected deleteHandler(hashes:
|
|
28
|
-
protected getHandler(hashes:
|
|
28
|
+
protected deleteHandler(hashes: Hash[]): Promise<string[]>;
|
|
29
|
+
protected getHandler(hashes: Hash[]): Promisable<Payload[]>;
|
|
29
30
|
protected insertHandler(payloads: Payload[]): Promise<Payload[]>;
|
|
30
31
|
private keyFromHash;
|
|
31
32
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"CookieArchivist.d.ts","sourceRoot":"","sources":["../../src/CookieArchivist.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"CookieArchivist.d.ts","sourceRoot":"","sources":["../../src/CookieArchivist.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,IAAI,EAAE,MAAM,aAAa,CAAA;AAElC,OAAO,EAAa,UAAU,EAAE,eAAe,EAAE,MAAM,iBAAiB,CAAA;AACxE,OAAO,EAAE,iBAAiB,EAAE,MAAM,iCAAiC,CAAA;AACnE,OAAO,EAIL,eAAe,EAIf,wBAAwB,EACxB,eAAe,EAChB,MAAM,8BAA8B,CAAA;AACrC,OAAO,EAAE,YAAY,EAAE,MAAM,iCAAiC,CAAA;AAC9D,OAAO,EAAE,eAAe,EAAE,MAAM,2BAA2B,CAAA;AAE3D,OAAO,EAAE,OAAO,EAAE,MAAM,4BAA4B,CAAA;AAGpD,MAAM,MAAM,2BAA2B,GAAG,qCAAqC,CAAA;AAC/E,eAAO,MAAM,2BAA2B,EAAE,2BAAmE,CAAA;AAE7G,MAAM,MAAM,qBAAqB,GAAG,eAAe,CAAC;IAClD,MAAM,CAAC,EAAE,MAAM,CAAA;IACf,UAAU,CAAC,EAAE,MAAM,CAAA;IACnB,YAAY,CAAC,EAAE,MAAM,CAAA;IACrB,SAAS,CAAC,EAAE,MAAM,CAAA;IAClB,MAAM,EAAE,2BAA2B,CAAA;CACpC,CAAC,CAAA;AAEF,MAAM,MAAM,qBAAqB,GAAG,eAAe,CAAC,eAAe,CAAC,qBAAqB,CAAC,CAAC,CAAA;AAE3F,qBAAa,eAAe,CAC1B,OAAO,SAAS,qBAAqB,EACrC,UAAU,SAAS,wBAAwB,GAAG,wBAAwB,CACtE,SAAQ,iBAAiB,CAAC,OAAO,EAAE,UAAU,CAAC;IAC9C,OAAgB,aAAa,0CAAgC;IAE7D,IAAI,MAAM,uBAET;IAED,IAAI,UAAU,WAGb;IAED,IAAI,YAAY,WAGf;IAED,IAAI,SAAS,WAEZ;IAED,IAAa,OAAO,IAAI,MAAM,EAAE,CAS/B;cAEkB,UAAU,IAAI,eAAe,CAAC,OAAO,CAAC;cAWtC,YAAY,IAAI,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC;cAa9B,aAAa,IAAI,OAAO,CAAC,YAAY,EAAE,CAAC;cAuBxC,aAAa,CAAC,MAAM,EAAE,IAAI,EAAE,GAAG,OAAO,CAAC,MAAM,EAAE,CAAC;cAatD,UAAU,CAAC,MAAM,EAAE,IAAI,EAAE,GAAG,UAAU,CAAC,OAAO,EAAE,CAAC;cAS3C,aAAa,CAAC,QAAQ,EAAE,OAAO,EAAE,GAAG,OAAO,CAAC,OAAO,EAAE,CAAC;IAoB/E,OAAO,CAAC,WAAW;CAGpB"}
|
package/dist/browser/index.cjs
CHANGED
|
@@ -42,8 +42,7 @@ var import_lodash = require("@xylabs/lodash");
|
|
|
42
42
|
var import_promise = require("@xylabs/promise");
|
|
43
43
|
var import_archivist_abstract = require("@xyo-network/archivist-abstract");
|
|
44
44
|
var import_archivist_model = require("@xyo-network/archivist-model");
|
|
45
|
-
var
|
|
46
|
-
var import_payload_wrapper = require("@xyo-network/payload-wrapper");
|
|
45
|
+
var import_payload_builder = require("@xyo-network/payload-builder");
|
|
47
46
|
var import_js_cookie = __toESM(require("js-cookie"), 1);
|
|
48
47
|
var CookieArchivistConfigSchema = "network.xyo.archivist.cookie.config";
|
|
49
48
|
var CookieArchivist = class extends import_archivist_abstract.AbstractArchivist {
|
|
@@ -114,18 +113,15 @@ var CookieArchivist = class extends import_archivist_abstract.AbstractArchivist
|
|
|
114
113
|
}
|
|
115
114
|
}
|
|
116
115
|
async deleteHandler(hashes) {
|
|
117
|
-
const payloadPairs = await
|
|
118
|
-
|
|
119
|
-
payload
|
|
120
|
-
]));
|
|
121
|
-
const deletedPairs = (0, import_lodash.compact)(await Promise.all(payloadPairs.map(([hash, payload]) => {
|
|
116
|
+
const payloadPairs = await import_payload_builder.PayloadBuilder.dataHashPairs(await this.get(hashes));
|
|
117
|
+
const deletedPairs = (0, import_lodash.compact)(await Promise.all(payloadPairs.map(([payload, hash]) => {
|
|
122
118
|
import_js_cookie.default.remove(hash);
|
|
123
119
|
return [
|
|
124
|
-
|
|
125
|
-
|
|
120
|
+
payload,
|
|
121
|
+
hash
|
|
126
122
|
];
|
|
127
123
|
})));
|
|
128
|
-
return deletedPairs.map(([hash]) => hash);
|
|
124
|
+
return deletedPairs.map(([, hash]) => hash);
|
|
129
125
|
}
|
|
130
126
|
getHandler(hashes) {
|
|
131
127
|
return (0, import_lodash.compact)(hashes.map((hash) => {
|
|
@@ -135,13 +131,14 @@ var CookieArchivist = class extends import_archivist_abstract.AbstractArchivist
|
|
|
135
131
|
}
|
|
136
132
|
async insertHandler(payloads) {
|
|
137
133
|
try {
|
|
138
|
-
const
|
|
139
|
-
|
|
140
|
-
const
|
|
141
|
-
const value = JSON.stringify(
|
|
142
|
-
(0, import_assert.assertEx)(value.length < this.maxEntrySize, `Payload too large [${
|
|
143
|
-
import_js_cookie.default.set(
|
|
144
|
-
|
|
134
|
+
const pairs = await import_payload_builder.PayloadBuilder.hashPairs(payloads);
|
|
135
|
+
const resultPayloads = await Promise.all(pairs.map(async ([payload, hash]) => {
|
|
136
|
+
const payloadWithMeta = await import_payload_builder.PayloadBuilder.build(payload);
|
|
137
|
+
const value = JSON.stringify(payloadWithMeta);
|
|
138
|
+
(0, import_assert.assertEx)(value.length < this.maxEntrySize, `Payload too large [${hash}, ${value.length}]`);
|
|
139
|
+
import_js_cookie.default.set(this.keyFromHash(hash), value);
|
|
140
|
+
import_js_cookie.default.set(this.keyFromHash(payload.$hash), value);
|
|
141
|
+
return payloadWithMeta;
|
|
145
142
|
}));
|
|
146
143
|
return resultPayloads;
|
|
147
144
|
} catch (ex) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/index.ts","../../src/CookieArchivist.ts"],"sourcesContent":["export * from './CookieArchivist'\n","import { assertEx } from '@xylabs/assert'\nimport { compact } from '@xylabs/lodash'\nimport { fulfilled, Promisable, PromisableArray } from '@xylabs/promise'\nimport { AbstractArchivist } from '@xyo-network/archivist-abstract'\nimport {\n ArchivistAllQuerySchema,\n ArchivistClearQuerySchema,\n ArchivistCommitQuerySchema,\n ArchivistConfig,\n ArchivistDeleteQuerySchema,\n ArchivistInsertQuery,\n ArchivistInsertQuerySchema,\n ArchivistModuleEventData,\n ArchivistParams,\n} from '@xyo-network/archivist-model'\nimport { BoundWitness } from '@xyo-network/boundwitness-model'\nimport {
|
|
1
|
+
{"version":3,"sources":["../../src/index.ts","../../src/CookieArchivist.ts"],"sourcesContent":["export * from './CookieArchivist'\n","import { assertEx } from '@xylabs/assert'\nimport { Hash } from '@xylabs/hex'\nimport { compact } from '@xylabs/lodash'\nimport { fulfilled, Promisable, PromisableArray } from '@xylabs/promise'\nimport { AbstractArchivist } from '@xyo-network/archivist-abstract'\nimport {\n ArchivistAllQuerySchema,\n ArchivistClearQuerySchema,\n ArchivistCommitQuerySchema,\n ArchivistConfig,\n ArchivistDeleteQuerySchema,\n ArchivistInsertQuery,\n ArchivistInsertQuerySchema,\n ArchivistModuleEventData,\n ArchivistParams,\n} from '@xyo-network/archivist-model'\nimport { BoundWitness } from '@xyo-network/boundwitness-model'\nimport { AnyConfigSchema } from '@xyo-network/module-model'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport { Payload } from '@xyo-network/payload-model'\nimport Cookies from 'js-cookie'\n\nexport type CookieArchivistConfigSchema = 'network.xyo.archivist.cookie.config'\nexport const CookieArchivistConfigSchema: CookieArchivistConfigSchema = 'network.xyo.archivist.cookie.config'\n\nexport type CookieArchivistConfig = ArchivistConfig<{\n domain?: string\n maxEntries?: number\n maxEntrySize?: number\n namespace?: string\n schema: CookieArchivistConfigSchema\n}>\n\nexport type CookieArchivistParams = ArchivistParams<AnyConfigSchema<CookieArchivistConfig>>\n\nexport class CookieArchivist<\n TParams extends CookieArchivistParams,\n TEventData extends ArchivistModuleEventData = ArchivistModuleEventData,\n> extends AbstractArchivist<TParams, TEventData> {\n static override configSchemas = [CookieArchivistConfigSchema]\n\n get domain() {\n return this.config?.domain\n }\n\n get maxEntries() {\n //all browsers support at least 60 cookies\n return this.config?.maxEntries ?? 60\n }\n\n get maxEntrySize() {\n //all browsers support at least 4000 length per cookie\n return this.config?.maxEntrySize ?? 4000\n }\n\n get namespace() {\n return this.config?.namespace ?? 'xyoarch'\n }\n\n override get queries(): string[] {\n return [\n ArchivistAllQuerySchema,\n ArchivistDeleteQuerySchema,\n ArchivistClearQuerySchema,\n ArchivistInsertQuerySchema,\n ArchivistCommitQuerySchema,\n ...super.queries,\n ]\n }\n\n protected override allHandler(): PromisableArray<Payload> {\n try {\n return Object.entries(Cookies.get())\n .filter(([key]) => key.startsWith(`${this.namespace}-`))\n .map(([, value]) => JSON.parse(value))\n } catch (ex) {\n console.error(`Error: ${JSON.stringify(ex, null, 2)}`)\n throw ex\n }\n }\n\n protected override clearHandler(): void | Promise<void> {\n try {\n Object.entries(Cookies.get()).map(([key]) => {\n if (key.startsWith(`${this.namespace}-`)) {\n Cookies.remove(key)\n }\n })\n } catch (ex) {\n console.error(`Error: ${JSON.stringify(ex, null, 2)}`)\n throw ex\n }\n }\n\n protected override async commitHandler(): Promise<BoundWitness[]> {\n try {\n const payloads = await this.all()\n assertEx(payloads.length > 0, 'Nothing to commit')\n const settled = await Promise.allSettled(\n compact(\n Object.values((await this.parents()).commit ?? [])?.map(async (parent) => {\n const queryPayload: ArchivistInsertQuery = {\n schema: ArchivistInsertQuerySchema,\n }\n const query = await this.bindQuery(queryPayload, payloads)\n return (await parent?.query(query[0], query[1]))?.[0]\n }),\n ),\n )\n await this.clear()\n return compact(settled.filter(fulfilled).map((result) => result.value))\n } catch (ex) {\n console.error(`Error: ${JSON.stringify(ex, null, 2)}`)\n throw ex\n }\n }\n\n protected override async deleteHandler(hashes: Hash[]): Promise<string[]> {\n const payloadPairs = await PayloadBuilder.dataHashPairs(await this.get(hashes))\n const deletedPairs = compact(\n await Promise.all(\n payloadPairs.map<[Payload, Hash]>(([payload, hash]) => {\n Cookies.remove(hash)\n return [payload, hash]\n }),\n ),\n )\n return deletedPairs.map(([, hash]) => hash)\n }\n\n protected override getHandler(hashes: Hash[]): Promisable<Payload[]> {\n return compact(\n hashes.map((hash) => {\n const cookieString = Cookies.get(this.keyFromHash(hash))\n return cookieString ? JSON.parse(cookieString) : undefined\n }),\n )\n }\n\n protected override async insertHandler(payloads: Payload[]): Promise<Payload[]> {\n try {\n const pairs = await PayloadBuilder.hashPairs(payloads)\n const resultPayloads: Payload[] = await Promise.all(\n pairs.map(async ([payload, hash]) => {\n const payloadWithMeta = await PayloadBuilder.build(payload)\n const value = JSON.stringify(payloadWithMeta)\n assertEx(value.length < this.maxEntrySize, `Payload too large [${hash}, ${value.length}]`)\n Cookies.set(this.keyFromHash(hash), value)\n Cookies.set(this.keyFromHash(payload.$hash), value)\n return payloadWithMeta\n }),\n )\n return resultPayloads\n } catch (ex) {\n console.error(`Error: ${JSON.stringify(ex, null, 2)}`)\n throw ex\n }\n }\n\n private keyFromHash(hash: string) {\n return `${this.namespace}-${hash}`\n }\n}\n"],"mappings":"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","names":["CookieArchivistConfigSchema","CookieArchivist","AbstractArchivist","configSchemas","domain","config","maxEntries","maxEntrySize","namespace","queries","ArchivistAllQuerySchema","ArchivistDeleteQuerySchema","ArchivistClearQuerySchema","ArchivistInsertQuerySchema","ArchivistCommitQuerySchema","allHandler","Object","entries","Cookies","get","filter","key","startsWith","map","value","JSON","parse","ex","console","error","stringify","clearHandler","remove","commitHandler","payloads","all","assertEx","length","settled","Promise","allSettled","compact","values","parents","commit","parent","queryPayload","schema","query","bindQuery","clear","fulfilled","result","deleteHandler","hashes","payloadPairs","PayloadBuilder","dataHashPairs","deletedPairs","payload","hash","getHandler","cookieString","keyFromHash","undefined","insertHandler","pairs","hashPairs","resultPayloads","payloadWithMeta","build","set","$hash"]}
|
package/dist/browser/index.js
CHANGED
|
@@ -7,8 +7,7 @@ import { compact } from "@xylabs/lodash";
|
|
|
7
7
|
import { fulfilled } from "@xylabs/promise";
|
|
8
8
|
import { AbstractArchivist } from "@xyo-network/archivist-abstract";
|
|
9
9
|
import { ArchivistAllQuerySchema, ArchivistClearQuerySchema, ArchivistCommitQuerySchema, ArchivistDeleteQuerySchema, ArchivistInsertQuerySchema } from "@xyo-network/archivist-model";
|
|
10
|
-
import {
|
|
11
|
-
import { PayloadWrapper } from "@xyo-network/payload-wrapper";
|
|
10
|
+
import { PayloadBuilder } from "@xyo-network/payload-builder";
|
|
12
11
|
import Cookies from "js-cookie";
|
|
13
12
|
var CookieArchivistConfigSchema = "network.xyo.archivist.cookie.config";
|
|
14
13
|
var CookieArchivist = class extends AbstractArchivist {
|
|
@@ -79,18 +78,15 @@ var CookieArchivist = class extends AbstractArchivist {
|
|
|
79
78
|
}
|
|
80
79
|
}
|
|
81
80
|
async deleteHandler(hashes) {
|
|
82
|
-
const payloadPairs = await
|
|
83
|
-
|
|
84
|
-
payload
|
|
85
|
-
]));
|
|
86
|
-
const deletedPairs = compact(await Promise.all(payloadPairs.map(([hash, payload]) => {
|
|
81
|
+
const payloadPairs = await PayloadBuilder.dataHashPairs(await this.get(hashes));
|
|
82
|
+
const deletedPairs = compact(await Promise.all(payloadPairs.map(([payload, hash]) => {
|
|
87
83
|
Cookies.remove(hash);
|
|
88
84
|
return [
|
|
89
|
-
|
|
90
|
-
|
|
85
|
+
payload,
|
|
86
|
+
hash
|
|
91
87
|
];
|
|
92
88
|
})));
|
|
93
|
-
return deletedPairs.map(([hash]) => hash);
|
|
89
|
+
return deletedPairs.map(([, hash]) => hash);
|
|
94
90
|
}
|
|
95
91
|
getHandler(hashes) {
|
|
96
92
|
return compact(hashes.map((hash) => {
|
|
@@ -100,13 +96,14 @@ var CookieArchivist = class extends AbstractArchivist {
|
|
|
100
96
|
}
|
|
101
97
|
async insertHandler(payloads) {
|
|
102
98
|
try {
|
|
103
|
-
const
|
|
104
|
-
|
|
105
|
-
const
|
|
106
|
-
const value = JSON.stringify(
|
|
107
|
-
assertEx(value.length < this.maxEntrySize, `Payload too large [${
|
|
108
|
-
Cookies.set(
|
|
109
|
-
|
|
99
|
+
const pairs = await PayloadBuilder.hashPairs(payloads);
|
|
100
|
+
const resultPayloads = await Promise.all(pairs.map(async ([payload, hash]) => {
|
|
101
|
+
const payloadWithMeta = await PayloadBuilder.build(payload);
|
|
102
|
+
const value = JSON.stringify(payloadWithMeta);
|
|
103
|
+
assertEx(value.length < this.maxEntrySize, `Payload too large [${hash}, ${value.length}]`);
|
|
104
|
+
Cookies.set(this.keyFromHash(hash), value);
|
|
105
|
+
Cookies.set(this.keyFromHash(payload.$hash), value);
|
|
106
|
+
return payloadWithMeta;
|
|
110
107
|
}));
|
|
111
108
|
return resultPayloads;
|
|
112
109
|
} catch (ex) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/CookieArchivist.ts"],"sourcesContent":["import { assertEx } from '@xylabs/assert'\nimport { compact } from '@xylabs/lodash'\nimport { fulfilled, Promisable, PromisableArray } from '@xylabs/promise'\nimport { AbstractArchivist } from '@xyo-network/archivist-abstract'\nimport {\n ArchivistAllQuerySchema,\n ArchivistClearQuerySchema,\n ArchivistCommitQuerySchema,\n ArchivistConfig,\n ArchivistDeleteQuerySchema,\n ArchivistInsertQuery,\n ArchivistInsertQuerySchema,\n ArchivistModuleEventData,\n ArchivistParams,\n} from '@xyo-network/archivist-model'\nimport { BoundWitness } from '@xyo-network/boundwitness-model'\nimport {
|
|
1
|
+
{"version":3,"sources":["../../src/CookieArchivist.ts"],"sourcesContent":["import { assertEx } from '@xylabs/assert'\nimport { Hash } from '@xylabs/hex'\nimport { compact } from '@xylabs/lodash'\nimport { fulfilled, Promisable, PromisableArray } from '@xylabs/promise'\nimport { AbstractArchivist } from '@xyo-network/archivist-abstract'\nimport {\n ArchivistAllQuerySchema,\n ArchivistClearQuerySchema,\n ArchivistCommitQuerySchema,\n ArchivistConfig,\n ArchivistDeleteQuerySchema,\n ArchivistInsertQuery,\n ArchivistInsertQuerySchema,\n ArchivistModuleEventData,\n ArchivistParams,\n} from '@xyo-network/archivist-model'\nimport { BoundWitness } from '@xyo-network/boundwitness-model'\nimport { AnyConfigSchema } from '@xyo-network/module-model'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport { Payload } from '@xyo-network/payload-model'\nimport Cookies from 'js-cookie'\n\nexport type CookieArchivistConfigSchema = 'network.xyo.archivist.cookie.config'\nexport const CookieArchivistConfigSchema: CookieArchivistConfigSchema = 'network.xyo.archivist.cookie.config'\n\nexport type CookieArchivistConfig = ArchivistConfig<{\n domain?: string\n maxEntries?: number\n maxEntrySize?: number\n namespace?: string\n schema: CookieArchivistConfigSchema\n}>\n\nexport type CookieArchivistParams = ArchivistParams<AnyConfigSchema<CookieArchivistConfig>>\n\nexport class CookieArchivist<\n TParams extends CookieArchivistParams,\n TEventData extends ArchivistModuleEventData = ArchivistModuleEventData,\n> extends AbstractArchivist<TParams, TEventData> {\n static override configSchemas = [CookieArchivistConfigSchema]\n\n get domain() {\n return this.config?.domain\n }\n\n get maxEntries() {\n //all browsers support at least 60 cookies\n return this.config?.maxEntries ?? 60\n }\n\n get maxEntrySize() {\n //all browsers support at least 4000 length per cookie\n return this.config?.maxEntrySize ?? 4000\n }\n\n get namespace() {\n return this.config?.namespace ?? 'xyoarch'\n }\n\n override get queries(): string[] {\n return [\n ArchivistAllQuerySchema,\n ArchivistDeleteQuerySchema,\n ArchivistClearQuerySchema,\n ArchivistInsertQuerySchema,\n ArchivistCommitQuerySchema,\n ...super.queries,\n ]\n }\n\n protected override allHandler(): PromisableArray<Payload> {\n try {\n return Object.entries(Cookies.get())\n .filter(([key]) => key.startsWith(`${this.namespace}-`))\n .map(([, value]) => JSON.parse(value))\n } catch (ex) {\n console.error(`Error: ${JSON.stringify(ex, null, 2)}`)\n throw ex\n }\n }\n\n protected override clearHandler(): void | Promise<void> {\n try {\n Object.entries(Cookies.get()).map(([key]) => {\n if (key.startsWith(`${this.namespace}-`)) {\n Cookies.remove(key)\n }\n })\n } catch (ex) {\n console.error(`Error: ${JSON.stringify(ex, null, 2)}`)\n throw ex\n }\n }\n\n protected override async commitHandler(): Promise<BoundWitness[]> {\n try {\n const payloads = await this.all()\n assertEx(payloads.length > 0, 'Nothing to commit')\n const settled = await Promise.allSettled(\n compact(\n Object.values((await this.parents()).commit ?? [])?.map(async (parent) => {\n const queryPayload: ArchivistInsertQuery = {\n schema: ArchivistInsertQuerySchema,\n }\n const query = await this.bindQuery(queryPayload, payloads)\n return (await parent?.query(query[0], query[1]))?.[0]\n }),\n ),\n )\n await this.clear()\n return compact(settled.filter(fulfilled).map((result) => result.value))\n } catch (ex) {\n console.error(`Error: ${JSON.stringify(ex, null, 2)}`)\n throw ex\n }\n }\n\n protected override async deleteHandler(hashes: Hash[]): Promise<string[]> {\n const payloadPairs = await PayloadBuilder.dataHashPairs(await this.get(hashes))\n const deletedPairs = compact(\n await Promise.all(\n payloadPairs.map<[Payload, Hash]>(([payload, hash]) => {\n Cookies.remove(hash)\n return [payload, hash]\n }),\n ),\n )\n return deletedPairs.map(([, hash]) => hash)\n }\n\n protected override getHandler(hashes: Hash[]): Promisable<Payload[]> {\n return compact(\n hashes.map((hash) => {\n const cookieString = Cookies.get(this.keyFromHash(hash))\n return cookieString ? JSON.parse(cookieString) : undefined\n }),\n )\n }\n\n protected override async insertHandler(payloads: Payload[]): Promise<Payload[]> {\n try {\n const pairs = await PayloadBuilder.hashPairs(payloads)\n const resultPayloads: Payload[] = await Promise.all(\n pairs.map(async ([payload, hash]) => {\n const payloadWithMeta = await PayloadBuilder.build(payload)\n const value = JSON.stringify(payloadWithMeta)\n assertEx(value.length < this.maxEntrySize, `Payload too large [${hash}, ${value.length}]`)\n Cookies.set(this.keyFromHash(hash), value)\n Cookies.set(this.keyFromHash(payload.$hash), value)\n return payloadWithMeta\n }),\n )\n return resultPayloads\n } catch (ex) {\n console.error(`Error: ${JSON.stringify(ex, null, 2)}`)\n throw ex\n }\n }\n\n private keyFromHash(hash: string) {\n return `${this.namespace}-${hash}`\n }\n}\n"],"mappings":";;;;AAAA,SAASA,gBAAgB;AAEzB,SAASC,eAAe;AACxB,SAASC,iBAA8C;AACvD,SAASC,yBAAyB;AAClC,SACEC,yBACAC,2BACAC,4BAEAC,4BAEAC,kCAGK;AAGP,SAASC,sBAAsB;AAE/B,OAAOC,aAAa;AAGb,IAAMC,8BAA2D;AAYjE,IAAMC,kBAAN,cAGGC,kBAAAA;EAtCV,OAsCUA;;;EACR,OAAgBC,gBAAgB;IAACH;;EAEjC,IAAII,SAAS;AACX,WAAO,KAAKC,QAAQD;EACtB;EAEA,IAAIE,aAAa;AAEf,WAAO,KAAKD,QAAQC,cAAc;EACpC;EAEA,IAAIC,eAAe;AAEjB,WAAO,KAAKF,QAAQE,gBAAgB;EACtC;EAEA,IAAIC,YAAY;AACd,WAAO,KAAKH,QAAQG,aAAa;EACnC;EAEA,IAAaC,UAAoB;AAC/B,WAAO;MACLC;MACAC;MACAC;MACAC;MACAC;SACG,MAAML;;EAEb;EAEmBM,aAAuC;AACxD,QAAI;AACF,aAAOC,OAAOC,QAAQC,QAAQC,IAAG,CAAA,EAC9BC,OAAO,CAAC,CAACC,GAAAA,MAASA,IAAIC,WAAW,GAAG,KAAKd,SAAS,GAAG,CAAA,EACrDe,IAAI,CAAC,CAAA,EAAGC,KAAAA,MAAWC,KAAKC,MAAMF,KAAAA,CAAAA;IACnC,SAASG,IAAI;AACXC,cAAQC,MAAM,UAAUJ,KAAKK,UAAUH,IAAI,MAAM,CAAA,CAAA,EAAI;AACrD,YAAMA;IACR;EACF;EAEmBI,eAAqC;AACtD,QAAI;AACFf,aAAOC,QAAQC,QAAQC,IAAG,CAAA,EAAII,IAAI,CAAC,CAACF,GAAAA,MAAI;AACtC,YAAIA,IAAIC,WAAW,GAAG,KAAKd,SAAS,GAAG,GAAG;AACxCU,kBAAQc,OAAOX,GAAAA;QACjB;MACF,CAAA;IACF,SAASM,IAAI;AACXC,cAAQC,MAAM,UAAUJ,KAAKK,UAAUH,IAAI,MAAM,CAAA,CAAA,EAAI;AACrD,YAAMA;IACR;EACF;EAEA,MAAyBM,gBAAyC;AAChE,QAAI;AACF,YAAMC,WAAW,MAAM,KAAKC,IAAG;AAC/BC,eAASF,SAASG,SAAS,GAAG,mBAAA;AAC9B,YAAMC,UAAU,MAAMC,QAAQC,WAC5BC,QACEzB,OAAO0B,QAAQ,MAAM,KAAKC,QAAO,GAAIC,UAAU,CAAA,CAAE,GAAGrB,IAAI,OAAOsB,WAAAA;AAC7D,cAAMC,eAAqC;UACzCC,QAAQlC;QACV;AACA,cAAMmC,QAAQ,MAAM,KAAKC,UAAUH,cAAcZ,QAAAA;AACjD,gBAAQ,MAAMW,QAAQG,MAAMA,MAAM,CAAA,GAAIA,MAAM,CAAA,CAAE,KAAK,CAAA;MACrD,CAAA,CAAA,CAAA;AAGJ,YAAM,KAAKE,MAAK;AAChB,aAAOT,QAAQH,QAAQlB,OAAO+B,SAAAA,EAAW5B,IAAI,CAAC6B,WAAWA,OAAO5B,KAAK,CAAA;IACvE,SAASG,IAAI;AACXC,cAAQC,MAAM,UAAUJ,KAAKK,UAAUH,IAAI,MAAM,CAAA,CAAA,EAAI;AACrD,YAAMA;IACR;EACF;EAEA,MAAyB0B,cAAcC,QAAmC;AACxE,UAAMC,eAAe,MAAMC,eAAeC,cAAc,MAAM,KAAKtC,IAAImC,MAAAA,CAAAA;AACvE,UAAMI,eAAejB,QACnB,MAAMF,QAAQJ,IACZoB,aAAahC,IAAqB,CAAC,CAACoC,SAASC,IAAAA,MAAK;AAChD1C,cAAQc,OAAO4B,IAAAA;AACf,aAAO;QAACD;QAASC;;IACnB,CAAA,CAAA,CAAA;AAGJ,WAAOF,aAAanC,IAAI,CAAC,CAAA,EAAGqC,IAAAA,MAAUA,IAAAA;EACxC;EAEmBC,WAAWP,QAAuC;AACnE,WAAOb,QACLa,OAAO/B,IAAI,CAACqC,SAAAA;AACV,YAAME,eAAe5C,QAAQC,IAAI,KAAK4C,YAAYH,IAAAA,CAAAA;AAClD,aAAOE,eAAerC,KAAKC,MAAMoC,YAAAA,IAAgBE;IACnD,CAAA,CAAA;EAEJ;EAEA,MAAyBC,cAAc/B,UAAyC;AAC9E,QAAI;AACF,YAAMgC,QAAQ,MAAMV,eAAeW,UAAUjC,QAAAA;AAC7C,YAAMkC,iBAA4B,MAAM7B,QAAQJ,IAC9C+B,MAAM3C,IAAI,OAAO,CAACoC,SAASC,IAAAA,MAAK;AAC9B,cAAMS,kBAAkB,MAAMb,eAAec,MAAMX,OAAAA;AACnD,cAAMnC,QAAQC,KAAKK,UAAUuC,eAAAA;AAC7BjC,iBAASZ,MAAMa,SAAS,KAAK9B,cAAc,sBAAsBqD,IAAAA,KAASpC,MAAMa,MAAM,GAAG;AACzFnB,gBAAQqD,IAAI,KAAKR,YAAYH,IAAAA,GAAOpC,KAAAA;AACpCN,gBAAQqD,IAAI,KAAKR,YAAYJ,QAAQa,KAAK,GAAGhD,KAAAA;AAC7C,eAAO6C;MACT,CAAA,CAAA;AAEF,aAAOD;IACT,SAASzC,IAAI;AACXC,cAAQC,MAAM,UAAUJ,KAAKK,UAAUH,IAAI,MAAM,CAAA,CAAA,EAAI;AACrD,YAAMA;IACR;EACF;EAEQoC,YAAYH,MAAc;AAChC,WAAO,GAAG,KAAKpD,SAAS,IAAIoD,IAAAA;EAC9B;AACF;","names":["assertEx","compact","fulfilled","AbstractArchivist","ArchivistAllQuerySchema","ArchivistClearQuerySchema","ArchivistCommitQuerySchema","ArchivistDeleteQuerySchema","ArchivistInsertQuerySchema","PayloadBuilder","Cookies","CookieArchivistConfigSchema","CookieArchivist","AbstractArchivist","configSchemas","domain","config","maxEntries","maxEntrySize","namespace","queries","ArchivistAllQuerySchema","ArchivistDeleteQuerySchema","ArchivistClearQuerySchema","ArchivistInsertQuerySchema","ArchivistCommitQuerySchema","allHandler","Object","entries","Cookies","get","filter","key","startsWith","map","value","JSON","parse","ex","console","error","stringify","clearHandler","remove","commitHandler","payloads","all","assertEx","length","settled","Promise","allSettled","compact","values","parents","commit","parent","queryPayload","schema","query","bindQuery","clear","fulfilled","result","deleteHandler","hashes","payloadPairs","PayloadBuilder","dataHashPairs","deletedPairs","payload","hash","getHandler","cookieString","keyFromHash","undefined","insertHandler","pairs","hashPairs","resultPayloads","payloadWithMeta","build","set","$hash"]}
|
|
@@ -1,3 +1,4 @@
|
|
|
1
|
+
import { Hash } from '@xylabs/hex';
|
|
1
2
|
import { Promisable, PromisableArray } from '@xylabs/promise';
|
|
2
3
|
import { AbstractArchivist } from '@xyo-network/archivist-abstract';
|
|
3
4
|
import { ArchivistConfig, ArchivistModuleEventData, ArchivistParams } from '@xyo-network/archivist-model';
|
|
@@ -24,8 +25,8 @@ export declare class CookieArchivist<TParams extends CookieArchivistParams, TEve
|
|
|
24
25
|
protected allHandler(): PromisableArray<Payload>;
|
|
25
26
|
protected clearHandler(): void | Promise<void>;
|
|
26
27
|
protected commitHandler(): Promise<BoundWitness[]>;
|
|
27
|
-
protected deleteHandler(hashes:
|
|
28
|
-
protected getHandler(hashes:
|
|
28
|
+
protected deleteHandler(hashes: Hash[]): Promise<string[]>;
|
|
29
|
+
protected getHandler(hashes: Hash[]): Promisable<Payload[]>;
|
|
29
30
|
protected insertHandler(payloads: Payload[]): Promise<Payload[]>;
|
|
30
31
|
private keyFromHash;
|
|
31
32
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"CookieArchivist.d.ts","sourceRoot":"","sources":["../../src/CookieArchivist.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"CookieArchivist.d.ts","sourceRoot":"","sources":["../../src/CookieArchivist.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,IAAI,EAAE,MAAM,aAAa,CAAA;AAElC,OAAO,EAAa,UAAU,EAAE,eAAe,EAAE,MAAM,iBAAiB,CAAA;AACxE,OAAO,EAAE,iBAAiB,EAAE,MAAM,iCAAiC,CAAA;AACnE,OAAO,EAIL,eAAe,EAIf,wBAAwB,EACxB,eAAe,EAChB,MAAM,8BAA8B,CAAA;AACrC,OAAO,EAAE,YAAY,EAAE,MAAM,iCAAiC,CAAA;AAC9D,OAAO,EAAE,eAAe,EAAE,MAAM,2BAA2B,CAAA;AAE3D,OAAO,EAAE,OAAO,EAAE,MAAM,4BAA4B,CAAA;AAGpD,MAAM,MAAM,2BAA2B,GAAG,qCAAqC,CAAA;AAC/E,eAAO,MAAM,2BAA2B,EAAE,2BAAmE,CAAA;AAE7G,MAAM,MAAM,qBAAqB,GAAG,eAAe,CAAC;IAClD,MAAM,CAAC,EAAE,MAAM,CAAA;IACf,UAAU,CAAC,EAAE,MAAM,CAAA;IACnB,YAAY,CAAC,EAAE,MAAM,CAAA;IACrB,SAAS,CAAC,EAAE,MAAM,CAAA;IAClB,MAAM,EAAE,2BAA2B,CAAA;CACpC,CAAC,CAAA;AAEF,MAAM,MAAM,qBAAqB,GAAG,eAAe,CAAC,eAAe,CAAC,qBAAqB,CAAC,CAAC,CAAA;AAE3F,qBAAa,eAAe,CAC1B,OAAO,SAAS,qBAAqB,EACrC,UAAU,SAAS,wBAAwB,GAAG,wBAAwB,CACtE,SAAQ,iBAAiB,CAAC,OAAO,EAAE,UAAU,CAAC;IAC9C,OAAgB,aAAa,0CAAgC;IAE7D,IAAI,MAAM,uBAET;IAED,IAAI,UAAU,WAGb;IAED,IAAI,YAAY,WAGf;IAED,IAAI,SAAS,WAEZ;IAED,IAAa,OAAO,IAAI,MAAM,EAAE,CAS/B;cAEkB,UAAU,IAAI,eAAe,CAAC,OAAO,CAAC;cAWtC,YAAY,IAAI,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC;cAa9B,aAAa,IAAI,OAAO,CAAC,YAAY,EAAE,CAAC;cAuBxC,aAAa,CAAC,MAAM,EAAE,IAAI,EAAE,GAAG,OAAO,CAAC,MAAM,EAAE,CAAC;cAatD,UAAU,CAAC,MAAM,EAAE,IAAI,EAAE,GAAG,UAAU,CAAC,OAAO,EAAE,CAAC;cAS3C,aAAa,CAAC,QAAQ,EAAE,OAAO,EAAE,GAAG,OAAO,CAAC,OAAO,EAAE,CAAC;IAoB/E,OAAO,CAAC,WAAW;CAGpB"}
|
|
@@ -1,3 +1,4 @@
|
|
|
1
|
+
import { Hash } from '@xylabs/hex';
|
|
1
2
|
import { Promisable, PromisableArray } from '@xylabs/promise';
|
|
2
3
|
import { AbstractArchivist } from '@xyo-network/archivist-abstract';
|
|
3
4
|
import { ArchivistConfig, ArchivistModuleEventData, ArchivistParams } from '@xyo-network/archivist-model';
|
|
@@ -24,8 +25,8 @@ export declare class CookieArchivist<TParams extends CookieArchivistParams, TEve
|
|
|
24
25
|
protected allHandler(): PromisableArray<Payload>;
|
|
25
26
|
protected clearHandler(): void | Promise<void>;
|
|
26
27
|
protected commitHandler(): Promise<BoundWitness[]>;
|
|
27
|
-
protected deleteHandler(hashes:
|
|
28
|
-
protected getHandler(hashes:
|
|
28
|
+
protected deleteHandler(hashes: Hash[]): Promise<string[]>;
|
|
29
|
+
protected getHandler(hashes: Hash[]): Promisable<Payload[]>;
|
|
29
30
|
protected insertHandler(payloads: Payload[]): Promise<Payload[]>;
|
|
30
31
|
private keyFromHash;
|
|
31
32
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"CookieArchivist.d.ts","sourceRoot":"","sources":["../../src/CookieArchivist.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"CookieArchivist.d.ts","sourceRoot":"","sources":["../../src/CookieArchivist.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,IAAI,EAAE,MAAM,aAAa,CAAA;AAElC,OAAO,EAAa,UAAU,EAAE,eAAe,EAAE,MAAM,iBAAiB,CAAA;AACxE,OAAO,EAAE,iBAAiB,EAAE,MAAM,iCAAiC,CAAA;AACnE,OAAO,EAIL,eAAe,EAIf,wBAAwB,EACxB,eAAe,EAChB,MAAM,8BAA8B,CAAA;AACrC,OAAO,EAAE,YAAY,EAAE,MAAM,iCAAiC,CAAA;AAC9D,OAAO,EAAE,eAAe,EAAE,MAAM,2BAA2B,CAAA;AAE3D,OAAO,EAAE,OAAO,EAAE,MAAM,4BAA4B,CAAA;AAGpD,MAAM,MAAM,2BAA2B,GAAG,qCAAqC,CAAA;AAC/E,eAAO,MAAM,2BAA2B,EAAE,2BAAmE,CAAA;AAE7G,MAAM,MAAM,qBAAqB,GAAG,eAAe,CAAC;IAClD,MAAM,CAAC,EAAE,MAAM,CAAA;IACf,UAAU,CAAC,EAAE,MAAM,CAAA;IACnB,YAAY,CAAC,EAAE,MAAM,CAAA;IACrB,SAAS,CAAC,EAAE,MAAM,CAAA;IAClB,MAAM,EAAE,2BAA2B,CAAA;CACpC,CAAC,CAAA;AAEF,MAAM,MAAM,qBAAqB,GAAG,eAAe,CAAC,eAAe,CAAC,qBAAqB,CAAC,CAAC,CAAA;AAE3F,qBAAa,eAAe,CAC1B,OAAO,SAAS,qBAAqB,EACrC,UAAU,SAAS,wBAAwB,GAAG,wBAAwB,CACtE,SAAQ,iBAAiB,CAAC,OAAO,EAAE,UAAU,CAAC;IAC9C,OAAgB,aAAa,0CAAgC;IAE7D,IAAI,MAAM,uBAET;IAED,IAAI,UAAU,WAGb;IAED,IAAI,YAAY,WAGf;IAED,IAAI,SAAS,WAEZ;IAED,IAAa,OAAO,IAAI,MAAM,EAAE,CAS/B;cAEkB,UAAU,IAAI,eAAe,CAAC,OAAO,CAAC;cAWtC,YAAY,IAAI,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC;cAa9B,aAAa,IAAI,OAAO,CAAC,YAAY,EAAE,CAAC;cAuBxC,aAAa,CAAC,MAAM,EAAE,IAAI,EAAE,GAAG,OAAO,CAAC,MAAM,EAAE,CAAC;cAatD,UAAU,CAAC,MAAM,EAAE,IAAI,EAAE,GAAG,UAAU,CAAC,OAAO,EAAE,CAAC;cAS3C,aAAa,CAAC,QAAQ,EAAE,OAAO,EAAE,GAAG,OAAO,CAAC,OAAO,EAAE,CAAC;IAoB/E,OAAO,CAAC,WAAW;CAGpB"}
|
|
@@ -1,3 +1,4 @@
|
|
|
1
|
+
import { Hash } from '@xylabs/hex';
|
|
1
2
|
import { Promisable, PromisableArray } from '@xylabs/promise';
|
|
2
3
|
import { AbstractArchivist } from '@xyo-network/archivist-abstract';
|
|
3
4
|
import { ArchivistConfig, ArchivistModuleEventData, ArchivistParams } from '@xyo-network/archivist-model';
|
|
@@ -24,8 +25,8 @@ export declare class CookieArchivist<TParams extends CookieArchivistParams, TEve
|
|
|
24
25
|
protected allHandler(): PromisableArray<Payload>;
|
|
25
26
|
protected clearHandler(): void | Promise<void>;
|
|
26
27
|
protected commitHandler(): Promise<BoundWitness[]>;
|
|
27
|
-
protected deleteHandler(hashes:
|
|
28
|
-
protected getHandler(hashes:
|
|
28
|
+
protected deleteHandler(hashes: Hash[]): Promise<string[]>;
|
|
29
|
+
protected getHandler(hashes: Hash[]): Promisable<Payload[]>;
|
|
29
30
|
protected insertHandler(payloads: Payload[]): Promise<Payload[]>;
|
|
30
31
|
private keyFromHash;
|
|
31
32
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"CookieArchivist.d.ts","sourceRoot":"","sources":["../../src/CookieArchivist.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"CookieArchivist.d.ts","sourceRoot":"","sources":["../../src/CookieArchivist.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,IAAI,EAAE,MAAM,aAAa,CAAA;AAElC,OAAO,EAAa,UAAU,EAAE,eAAe,EAAE,MAAM,iBAAiB,CAAA;AACxE,OAAO,EAAE,iBAAiB,EAAE,MAAM,iCAAiC,CAAA;AACnE,OAAO,EAIL,eAAe,EAIf,wBAAwB,EACxB,eAAe,EAChB,MAAM,8BAA8B,CAAA;AACrC,OAAO,EAAE,YAAY,EAAE,MAAM,iCAAiC,CAAA;AAC9D,OAAO,EAAE,eAAe,EAAE,MAAM,2BAA2B,CAAA;AAE3D,OAAO,EAAE,OAAO,EAAE,MAAM,4BAA4B,CAAA;AAGpD,MAAM,MAAM,2BAA2B,GAAG,qCAAqC,CAAA;AAC/E,eAAO,MAAM,2BAA2B,EAAE,2BAAmE,CAAA;AAE7G,MAAM,MAAM,qBAAqB,GAAG,eAAe,CAAC;IAClD,MAAM,CAAC,EAAE,MAAM,CAAA;IACf,UAAU,CAAC,EAAE,MAAM,CAAA;IACnB,YAAY,CAAC,EAAE,MAAM,CAAA;IACrB,SAAS,CAAC,EAAE,MAAM,CAAA;IAClB,MAAM,EAAE,2BAA2B,CAAA;CACpC,CAAC,CAAA;AAEF,MAAM,MAAM,qBAAqB,GAAG,eAAe,CAAC,eAAe,CAAC,qBAAqB,CAAC,CAAC,CAAA;AAE3F,qBAAa,eAAe,CAC1B,OAAO,SAAS,qBAAqB,EACrC,UAAU,SAAS,wBAAwB,GAAG,wBAAwB,CACtE,SAAQ,iBAAiB,CAAC,OAAO,EAAE,UAAU,CAAC;IAC9C,OAAgB,aAAa,0CAAgC;IAE7D,IAAI,MAAM,uBAET;IAED,IAAI,UAAU,WAGb;IAED,IAAI,YAAY,WAGf;IAED,IAAI,SAAS,WAEZ;IAED,IAAa,OAAO,IAAI,MAAM,EAAE,CAS/B;cAEkB,UAAU,IAAI,eAAe,CAAC,OAAO,CAAC;cAWtC,YAAY,IAAI,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC;cAa9B,aAAa,IAAI,OAAO,CAAC,YAAY,EAAE,CAAC;cAuBxC,aAAa,CAAC,MAAM,EAAE,IAAI,EAAE,GAAG,OAAO,CAAC,MAAM,EAAE,CAAC;cAatD,UAAU,CAAC,MAAM,EAAE,IAAI,EAAE,GAAG,UAAU,CAAC,OAAO,EAAE,CAAC;cAS3C,aAAa,CAAC,QAAQ,EAAE,OAAO,EAAE,GAAG,OAAO,CAAC,OAAO,EAAE,CAAC;IAoB/E,OAAO,CAAC,WAAW;CAGpB"}
|
package/dist/node/index.cjs
CHANGED
|
@@ -47,8 +47,7 @@ var import_lodash = require("@xylabs/lodash");
|
|
|
47
47
|
var import_promise = require("@xylabs/promise");
|
|
48
48
|
var import_archivist_abstract = require("@xyo-network/archivist-abstract");
|
|
49
49
|
var import_archivist_model = require("@xyo-network/archivist-model");
|
|
50
|
-
var
|
|
51
|
-
var import_payload_wrapper = require("@xyo-network/payload-wrapper");
|
|
50
|
+
var import_payload_builder = require("@xyo-network/payload-builder");
|
|
52
51
|
var import_js_cookie = __toESM(require("js-cookie"), 1);
|
|
53
52
|
var CookieArchivistConfigSchema = "network.xyo.archivist.cookie.config";
|
|
54
53
|
var _CookieArchivist = class _CookieArchivist extends import_archivist_abstract.AbstractArchivist {
|
|
@@ -119,18 +118,15 @@ var _CookieArchivist = class _CookieArchivist extends import_archivist_abstract.
|
|
|
119
118
|
}
|
|
120
119
|
}
|
|
121
120
|
async deleteHandler(hashes) {
|
|
122
|
-
const payloadPairs = await
|
|
123
|
-
|
|
124
|
-
payload
|
|
125
|
-
]));
|
|
126
|
-
const deletedPairs = (0, import_lodash.compact)(await Promise.all(payloadPairs.map(([hash, payload]) => {
|
|
121
|
+
const payloadPairs = await import_payload_builder.PayloadBuilder.dataHashPairs(await this.get(hashes));
|
|
122
|
+
const deletedPairs = (0, import_lodash.compact)(await Promise.all(payloadPairs.map(([payload, hash]) => {
|
|
127
123
|
import_js_cookie.default.remove(hash);
|
|
128
124
|
return [
|
|
129
|
-
|
|
130
|
-
|
|
125
|
+
payload,
|
|
126
|
+
hash
|
|
131
127
|
];
|
|
132
128
|
})));
|
|
133
|
-
return deletedPairs.map(([hash]) => hash);
|
|
129
|
+
return deletedPairs.map(([, hash]) => hash);
|
|
134
130
|
}
|
|
135
131
|
getHandler(hashes) {
|
|
136
132
|
return (0, import_lodash.compact)(hashes.map((hash) => {
|
|
@@ -140,13 +136,14 @@ var _CookieArchivist = class _CookieArchivist extends import_archivist_abstract.
|
|
|
140
136
|
}
|
|
141
137
|
async insertHandler(payloads) {
|
|
142
138
|
try {
|
|
143
|
-
const
|
|
144
|
-
|
|
145
|
-
const
|
|
146
|
-
const value = JSON.stringify(
|
|
147
|
-
(0, import_assert.assertEx)(value.length < this.maxEntrySize, `Payload too large [${
|
|
148
|
-
import_js_cookie.default.set(
|
|
149
|
-
|
|
139
|
+
const pairs = await import_payload_builder.PayloadBuilder.hashPairs(payloads);
|
|
140
|
+
const resultPayloads = await Promise.all(pairs.map(async ([payload, hash]) => {
|
|
141
|
+
const payloadWithMeta = await import_payload_builder.PayloadBuilder.build(payload);
|
|
142
|
+
const value = JSON.stringify(payloadWithMeta);
|
|
143
|
+
(0, import_assert.assertEx)(value.length < this.maxEntrySize, `Payload too large [${hash}, ${value.length}]`);
|
|
144
|
+
import_js_cookie.default.set(this.keyFromHash(hash), value);
|
|
145
|
+
import_js_cookie.default.set(this.keyFromHash(payload.$hash), value);
|
|
146
|
+
return payloadWithMeta;
|
|
150
147
|
}));
|
|
151
148
|
return resultPayloads;
|
|
152
149
|
} catch (ex) {
|
package/dist/node/index.cjs.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/index.ts","../../src/CookieArchivist.ts"],"sourcesContent":["export * from './CookieArchivist'\n","import { assertEx } from '@xylabs/assert'\nimport { compact } from '@xylabs/lodash'\nimport { fulfilled, Promisable, PromisableArray } from '@xylabs/promise'\nimport { AbstractArchivist } from '@xyo-network/archivist-abstract'\nimport {\n ArchivistAllQuerySchema,\n ArchivistClearQuerySchema,\n ArchivistCommitQuerySchema,\n ArchivistConfig,\n ArchivistDeleteQuerySchema,\n ArchivistInsertQuery,\n ArchivistInsertQuerySchema,\n ArchivistModuleEventData,\n ArchivistParams,\n} from '@xyo-network/archivist-model'\nimport { BoundWitness } from '@xyo-network/boundwitness-model'\nimport {
|
|
1
|
+
{"version":3,"sources":["../../src/index.ts","../../src/CookieArchivist.ts"],"sourcesContent":["export * from './CookieArchivist'\n","import { assertEx } from '@xylabs/assert'\nimport { Hash } from '@xylabs/hex'\nimport { compact } from '@xylabs/lodash'\nimport { fulfilled, Promisable, PromisableArray } from '@xylabs/promise'\nimport { AbstractArchivist } from '@xyo-network/archivist-abstract'\nimport {\n ArchivistAllQuerySchema,\n ArchivistClearQuerySchema,\n ArchivistCommitQuerySchema,\n ArchivistConfig,\n ArchivistDeleteQuerySchema,\n ArchivistInsertQuery,\n ArchivistInsertQuerySchema,\n ArchivistModuleEventData,\n ArchivistParams,\n} from '@xyo-network/archivist-model'\nimport { BoundWitness } from '@xyo-network/boundwitness-model'\nimport { AnyConfigSchema } from '@xyo-network/module-model'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport { Payload } from '@xyo-network/payload-model'\nimport Cookies from 'js-cookie'\n\nexport type CookieArchivistConfigSchema = 'network.xyo.archivist.cookie.config'\nexport const CookieArchivistConfigSchema: CookieArchivistConfigSchema = 'network.xyo.archivist.cookie.config'\n\nexport type CookieArchivistConfig = ArchivistConfig<{\n domain?: string\n maxEntries?: number\n maxEntrySize?: number\n namespace?: string\n schema: CookieArchivistConfigSchema\n}>\n\nexport type CookieArchivistParams = ArchivistParams<AnyConfigSchema<CookieArchivistConfig>>\n\nexport class CookieArchivist<\n TParams extends CookieArchivistParams,\n TEventData extends ArchivistModuleEventData = ArchivistModuleEventData,\n> extends AbstractArchivist<TParams, TEventData> {\n static override configSchemas = [CookieArchivistConfigSchema]\n\n get domain() {\n return this.config?.domain\n }\n\n get maxEntries() {\n //all browsers support at least 60 cookies\n return this.config?.maxEntries ?? 60\n }\n\n get maxEntrySize() {\n //all browsers support at least 4000 length per cookie\n return this.config?.maxEntrySize ?? 4000\n }\n\n get namespace() {\n return this.config?.namespace ?? 'xyoarch'\n }\n\n override get queries(): string[] {\n return [\n ArchivistAllQuerySchema,\n ArchivistDeleteQuerySchema,\n ArchivistClearQuerySchema,\n ArchivistInsertQuerySchema,\n ArchivistCommitQuerySchema,\n ...super.queries,\n ]\n }\n\n protected override allHandler(): PromisableArray<Payload> {\n try {\n return Object.entries(Cookies.get())\n .filter(([key]) => key.startsWith(`${this.namespace}-`))\n .map(([, value]) => JSON.parse(value))\n } catch (ex) {\n console.error(`Error: ${JSON.stringify(ex, null, 2)}`)\n throw ex\n }\n }\n\n protected override clearHandler(): void | Promise<void> {\n try {\n Object.entries(Cookies.get()).map(([key]) => {\n if (key.startsWith(`${this.namespace}-`)) {\n Cookies.remove(key)\n }\n })\n } catch (ex) {\n console.error(`Error: ${JSON.stringify(ex, null, 2)}`)\n throw ex\n }\n }\n\n protected override async commitHandler(): Promise<BoundWitness[]> {\n try {\n const payloads = await this.all()\n assertEx(payloads.length > 0, 'Nothing to commit')\n const settled = await Promise.allSettled(\n compact(\n Object.values((await this.parents()).commit ?? [])?.map(async (parent) => {\n const queryPayload: ArchivistInsertQuery = {\n schema: ArchivistInsertQuerySchema,\n }\n const query = await this.bindQuery(queryPayload, payloads)\n return (await parent?.query(query[0], query[1]))?.[0]\n }),\n ),\n )\n await this.clear()\n return compact(settled.filter(fulfilled).map((result) => result.value))\n } catch (ex) {\n console.error(`Error: ${JSON.stringify(ex, null, 2)}`)\n throw ex\n }\n }\n\n protected override async deleteHandler(hashes: Hash[]): Promise<string[]> {\n const payloadPairs = await PayloadBuilder.dataHashPairs(await this.get(hashes))\n const deletedPairs = compact(\n await Promise.all(\n payloadPairs.map<[Payload, Hash]>(([payload, hash]) => {\n Cookies.remove(hash)\n return [payload, hash]\n }),\n ),\n )\n return deletedPairs.map(([, hash]) => hash)\n }\n\n protected override getHandler(hashes: Hash[]): Promisable<Payload[]> {\n return compact(\n hashes.map((hash) => {\n const cookieString = Cookies.get(this.keyFromHash(hash))\n return cookieString ? JSON.parse(cookieString) : undefined\n }),\n )\n }\n\n protected override async insertHandler(payloads: Payload[]): Promise<Payload[]> {\n try {\n const pairs = await PayloadBuilder.hashPairs(payloads)\n const resultPayloads: Payload[] = await Promise.all(\n pairs.map(async ([payload, hash]) => {\n const payloadWithMeta = await PayloadBuilder.build(payload)\n const value = JSON.stringify(payloadWithMeta)\n assertEx(value.length < this.maxEntrySize, `Payload too large [${hash}, ${value.length}]`)\n Cookies.set(this.keyFromHash(hash), value)\n Cookies.set(this.keyFromHash(payload.$hash), value)\n return payloadWithMeta\n }),\n )\n return resultPayloads\n } catch (ex) {\n console.error(`Error: ${JSON.stringify(ex, null, 2)}`)\n throw ex\n }\n }\n\n private keyFromHash(hash: string) {\n return `${this.namespace}-${hash}`\n }\n}\n"],"mappings":"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","names":["CookieArchivistConfigSchema","CookieArchivist","AbstractArchivist","domain","config","maxEntries","maxEntrySize","namespace","queries","ArchivistAllQuerySchema","ArchivistDeleteQuerySchema","ArchivistClearQuerySchema","ArchivistInsertQuerySchema","ArchivistCommitQuerySchema","allHandler","Object","entries","Cookies","get","filter","key","startsWith","map","value","JSON","parse","ex","console","error","stringify","clearHandler","remove","commitHandler","payloads","all","assertEx","length","settled","Promise","allSettled","compact","values","parents","commit","parent","_a","queryPayload","schema","query","bindQuery","clear","fulfilled","result","deleteHandler","hashes","payloadPairs","PayloadBuilder","dataHashPairs","deletedPairs","payload","hash","getHandler","cookieString","keyFromHash","undefined","insertHandler","pairs","hashPairs","resultPayloads","payloadWithMeta","build","set","$hash","configSchemas"]}
|
package/dist/node/index.js
CHANGED
|
@@ -12,8 +12,7 @@ import { compact } from "@xylabs/lodash";
|
|
|
12
12
|
import { fulfilled } from "@xylabs/promise";
|
|
13
13
|
import { AbstractArchivist } from "@xyo-network/archivist-abstract";
|
|
14
14
|
import { ArchivistAllQuerySchema, ArchivistClearQuerySchema, ArchivistCommitQuerySchema, ArchivistDeleteQuerySchema, ArchivistInsertQuerySchema } from "@xyo-network/archivist-model";
|
|
15
|
-
import {
|
|
16
|
-
import { PayloadWrapper } from "@xyo-network/payload-wrapper";
|
|
15
|
+
import { PayloadBuilder } from "@xyo-network/payload-builder";
|
|
17
16
|
import Cookies from "js-cookie";
|
|
18
17
|
var CookieArchivistConfigSchema = "network.xyo.archivist.cookie.config";
|
|
19
18
|
var _CookieArchivist = class _CookieArchivist extends AbstractArchivist {
|
|
@@ -84,18 +83,15 @@ var _CookieArchivist = class _CookieArchivist extends AbstractArchivist {
|
|
|
84
83
|
}
|
|
85
84
|
}
|
|
86
85
|
async deleteHandler(hashes) {
|
|
87
|
-
const payloadPairs = await
|
|
88
|
-
|
|
89
|
-
payload
|
|
90
|
-
]));
|
|
91
|
-
const deletedPairs = compact(await Promise.all(payloadPairs.map(([hash, payload]) => {
|
|
86
|
+
const payloadPairs = await PayloadBuilder.dataHashPairs(await this.get(hashes));
|
|
87
|
+
const deletedPairs = compact(await Promise.all(payloadPairs.map(([payload, hash]) => {
|
|
92
88
|
Cookies.remove(hash);
|
|
93
89
|
return [
|
|
94
|
-
|
|
95
|
-
|
|
90
|
+
payload,
|
|
91
|
+
hash
|
|
96
92
|
];
|
|
97
93
|
})));
|
|
98
|
-
return deletedPairs.map(([hash]) => hash);
|
|
94
|
+
return deletedPairs.map(([, hash]) => hash);
|
|
99
95
|
}
|
|
100
96
|
getHandler(hashes) {
|
|
101
97
|
return compact(hashes.map((hash) => {
|
|
@@ -105,13 +101,14 @@ var _CookieArchivist = class _CookieArchivist extends AbstractArchivist {
|
|
|
105
101
|
}
|
|
106
102
|
async insertHandler(payloads) {
|
|
107
103
|
try {
|
|
108
|
-
const
|
|
109
|
-
|
|
110
|
-
const
|
|
111
|
-
const value = JSON.stringify(
|
|
112
|
-
assertEx(value.length < this.maxEntrySize, `Payload too large [${
|
|
113
|
-
Cookies.set(
|
|
114
|
-
|
|
104
|
+
const pairs = await PayloadBuilder.hashPairs(payloads);
|
|
105
|
+
const resultPayloads = await Promise.all(pairs.map(async ([payload, hash]) => {
|
|
106
|
+
const payloadWithMeta = await PayloadBuilder.build(payload);
|
|
107
|
+
const value = JSON.stringify(payloadWithMeta);
|
|
108
|
+
assertEx(value.length < this.maxEntrySize, `Payload too large [${hash}, ${value.length}]`);
|
|
109
|
+
Cookies.set(this.keyFromHash(hash), value);
|
|
110
|
+
Cookies.set(this.keyFromHash(payload.$hash), value);
|
|
111
|
+
return payloadWithMeta;
|
|
115
112
|
}));
|
|
116
113
|
return resultPayloads;
|
|
117
114
|
} catch (ex) {
|
package/dist/node/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/CookieArchivist.ts"],"sourcesContent":["import { assertEx } from '@xylabs/assert'\nimport { compact } from '@xylabs/lodash'\nimport { fulfilled, Promisable, PromisableArray } from '@xylabs/promise'\nimport { AbstractArchivist } from '@xyo-network/archivist-abstract'\nimport {\n ArchivistAllQuerySchema,\n ArchivistClearQuerySchema,\n ArchivistCommitQuerySchema,\n ArchivistConfig,\n ArchivistDeleteQuerySchema,\n ArchivistInsertQuery,\n ArchivistInsertQuerySchema,\n ArchivistModuleEventData,\n ArchivistParams,\n} from '@xyo-network/archivist-model'\nimport { BoundWitness } from '@xyo-network/boundwitness-model'\nimport {
|
|
1
|
+
{"version":3,"sources":["../../src/CookieArchivist.ts"],"sourcesContent":["import { assertEx } from '@xylabs/assert'\nimport { Hash } from '@xylabs/hex'\nimport { compact } from '@xylabs/lodash'\nimport { fulfilled, Promisable, PromisableArray } from '@xylabs/promise'\nimport { AbstractArchivist } from '@xyo-network/archivist-abstract'\nimport {\n ArchivistAllQuerySchema,\n ArchivistClearQuerySchema,\n ArchivistCommitQuerySchema,\n ArchivistConfig,\n ArchivistDeleteQuerySchema,\n ArchivistInsertQuery,\n ArchivistInsertQuerySchema,\n ArchivistModuleEventData,\n ArchivistParams,\n} from '@xyo-network/archivist-model'\nimport { BoundWitness } from '@xyo-network/boundwitness-model'\nimport { AnyConfigSchema } from '@xyo-network/module-model'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport { Payload } from '@xyo-network/payload-model'\nimport Cookies from 'js-cookie'\n\nexport type CookieArchivistConfigSchema = 'network.xyo.archivist.cookie.config'\nexport const CookieArchivistConfigSchema: CookieArchivistConfigSchema = 'network.xyo.archivist.cookie.config'\n\nexport type CookieArchivistConfig = ArchivistConfig<{\n domain?: string\n maxEntries?: number\n maxEntrySize?: number\n namespace?: string\n schema: CookieArchivistConfigSchema\n}>\n\nexport type CookieArchivistParams = ArchivistParams<AnyConfigSchema<CookieArchivistConfig>>\n\nexport class CookieArchivist<\n TParams extends CookieArchivistParams,\n TEventData extends ArchivistModuleEventData = ArchivistModuleEventData,\n> extends AbstractArchivist<TParams, TEventData> {\n static override configSchemas = [CookieArchivistConfigSchema]\n\n get domain() {\n return this.config?.domain\n }\n\n get maxEntries() {\n //all browsers support at least 60 cookies\n return this.config?.maxEntries ?? 60\n }\n\n get maxEntrySize() {\n //all browsers support at least 4000 length per cookie\n return this.config?.maxEntrySize ?? 4000\n }\n\n get namespace() {\n return this.config?.namespace ?? 'xyoarch'\n }\n\n override get queries(): string[] {\n return [\n ArchivistAllQuerySchema,\n ArchivistDeleteQuerySchema,\n ArchivistClearQuerySchema,\n ArchivistInsertQuerySchema,\n ArchivistCommitQuerySchema,\n ...super.queries,\n ]\n }\n\n protected override allHandler(): PromisableArray<Payload> {\n try {\n return Object.entries(Cookies.get())\n .filter(([key]) => key.startsWith(`${this.namespace}-`))\n .map(([, value]) => JSON.parse(value))\n } catch (ex) {\n console.error(`Error: ${JSON.stringify(ex, null, 2)}`)\n throw ex\n }\n }\n\n protected override clearHandler(): void | Promise<void> {\n try {\n Object.entries(Cookies.get()).map(([key]) => {\n if (key.startsWith(`${this.namespace}-`)) {\n Cookies.remove(key)\n }\n })\n } catch (ex) {\n console.error(`Error: ${JSON.stringify(ex, null, 2)}`)\n throw ex\n }\n }\n\n protected override async commitHandler(): Promise<BoundWitness[]> {\n try {\n const payloads = await this.all()\n assertEx(payloads.length > 0, 'Nothing to commit')\n const settled = await Promise.allSettled(\n compact(\n Object.values((await this.parents()).commit ?? [])?.map(async (parent) => {\n const queryPayload: ArchivistInsertQuery = {\n schema: ArchivistInsertQuerySchema,\n }\n const query = await this.bindQuery(queryPayload, payloads)\n return (await parent?.query(query[0], query[1]))?.[0]\n }),\n ),\n )\n await this.clear()\n return compact(settled.filter(fulfilled).map((result) => result.value))\n } catch (ex) {\n console.error(`Error: ${JSON.stringify(ex, null, 2)}`)\n throw ex\n }\n }\n\n protected override async deleteHandler(hashes: Hash[]): Promise<string[]> {\n const payloadPairs = await PayloadBuilder.dataHashPairs(await this.get(hashes))\n const deletedPairs = compact(\n await Promise.all(\n payloadPairs.map<[Payload, Hash]>(([payload, hash]) => {\n Cookies.remove(hash)\n return [payload, hash]\n }),\n ),\n )\n return deletedPairs.map(([, hash]) => hash)\n }\n\n protected override getHandler(hashes: Hash[]): Promisable<Payload[]> {\n return compact(\n hashes.map((hash) => {\n const cookieString = Cookies.get(this.keyFromHash(hash))\n return cookieString ? JSON.parse(cookieString) : undefined\n }),\n )\n }\n\n protected override async insertHandler(payloads: Payload[]): Promise<Payload[]> {\n try {\n const pairs = await PayloadBuilder.hashPairs(payloads)\n const resultPayloads: Payload[] = await Promise.all(\n pairs.map(async ([payload, hash]) => {\n const payloadWithMeta = await PayloadBuilder.build(payload)\n const value = JSON.stringify(payloadWithMeta)\n assertEx(value.length < this.maxEntrySize, `Payload too large [${hash}, ${value.length}]`)\n Cookies.set(this.keyFromHash(hash), value)\n Cookies.set(this.keyFromHash(payload.$hash), value)\n return payloadWithMeta\n }),\n )\n return resultPayloads\n } catch (ex) {\n console.error(`Error: ${JSON.stringify(ex, null, 2)}`)\n throw ex\n }\n }\n\n private keyFromHash(hash: string) {\n return `${this.namespace}-${hash}`\n }\n}\n"],"mappings":"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","names":["assertEx","compact","fulfilled","AbstractArchivist","ArchivistAllQuerySchema","ArchivistClearQuerySchema","ArchivistCommitQuerySchema","ArchivistDeleteQuerySchema","ArchivistInsertQuerySchema","PayloadBuilder","Cookies","CookieArchivistConfigSchema","CookieArchivist","AbstractArchivist","domain","config","maxEntries","maxEntrySize","namespace","queries","ArchivistAllQuerySchema","ArchivistDeleteQuerySchema","ArchivistClearQuerySchema","ArchivistInsertQuerySchema","ArchivistCommitQuerySchema","allHandler","Object","entries","Cookies","get","filter","key","startsWith","map","value","JSON","parse","ex","console","error","stringify","clearHandler","remove","commitHandler","payloads","all","assertEx","length","settled","Promise","allSettled","compact","values","parents","commit","parent","_a","queryPayload","schema","query","bindQuery","clear","fulfilled","result","deleteHandler","hashes","payloadPairs","PayloadBuilder","dataHashPairs","deletedPairs","payload","hash","getHandler","cookieString","keyFromHash","undefined","insertHandler","pairs","hashPairs","resultPayloads","payloadWithMeta","build","set","$hash","configSchemas"]}
|
package/package.json
CHANGED
|
@@ -11,15 +11,15 @@
|
|
|
11
11
|
},
|
|
12
12
|
"dependencies": {
|
|
13
13
|
"@xylabs/assert": "^2.13.29",
|
|
14
|
+
"@xylabs/hex": "^2.13.29",
|
|
14
15
|
"@xylabs/lodash": "^2.13.29",
|
|
15
16
|
"@xylabs/promise": "^2.13.29",
|
|
16
|
-
"@xyo-network/archivist-abstract": "~2.
|
|
17
|
-
"@xyo-network/archivist-model": "~2.
|
|
18
|
-
"@xyo-network/boundwitness-model": "~2.
|
|
19
|
-
"@xyo-network/
|
|
20
|
-
"@xyo-network/
|
|
21
|
-
"@xyo-network/payload-model": "~2.
|
|
22
|
-
"@xyo-network/payload-wrapper": "~2.88.3",
|
|
17
|
+
"@xyo-network/archivist-abstract": "~2.89.0-rc.2",
|
|
18
|
+
"@xyo-network/archivist-model": "~2.89.0-rc.2",
|
|
19
|
+
"@xyo-network/boundwitness-model": "~2.89.0-rc.2",
|
|
20
|
+
"@xyo-network/module-model": "~2.89.0-rc.2",
|
|
21
|
+
"@xyo-network/payload-builder": "~2.89.0-rc.2",
|
|
22
|
+
"@xyo-network/payload-model": "~2.89.0-rc.2",
|
|
23
23
|
"js-cookie": "^3.0.5"
|
|
24
24
|
},
|
|
25
25
|
"devDependencies": {
|
|
@@ -27,8 +27,9 @@
|
|
|
27
27
|
"@xylabs/delay": "^2.13.29",
|
|
28
28
|
"@xylabs/ts-scripts-yarn3": "^3.2.42",
|
|
29
29
|
"@xylabs/tsconfig": "^3.2.42",
|
|
30
|
-
"@xyo-network/account": "~2.
|
|
31
|
-
"@xyo-network/id-payload-plugin": "~2.
|
|
30
|
+
"@xyo-network/account": "~2.89.0-rc.2",
|
|
31
|
+
"@xyo-network/id-payload-plugin": "~2.89.0-rc.2",
|
|
32
|
+
"@xyo-network/payload-wrapper": "~2.89.0-rc.2",
|
|
32
33
|
"typescript": "^5.3.3"
|
|
33
34
|
},
|
|
34
35
|
"description": "Primary SDK for using XYO Protocol 2.0",
|
|
@@ -70,6 +71,7 @@
|
|
|
70
71
|
"url": "https://github.com/XYOracleNetwork/sdk-xyo-client-js.git"
|
|
71
72
|
},
|
|
72
73
|
"sideEffects": false,
|
|
73
|
-
"version": "2.
|
|
74
|
-
"type": "module"
|
|
74
|
+
"version": "2.89.0-rc.2",
|
|
75
|
+
"type": "module",
|
|
76
|
+
"stableVersion": "2.88.3"
|
|
75
77
|
}
|
package/src/CookieArchivist.ts
CHANGED
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
import { assertEx } from '@xylabs/assert'
|
|
2
|
+
import { Hash } from '@xylabs/hex'
|
|
2
3
|
import { compact } from '@xylabs/lodash'
|
|
3
4
|
import { fulfilled, Promisable, PromisableArray } from '@xylabs/promise'
|
|
4
5
|
import { AbstractArchivist } from '@xyo-network/archivist-abstract'
|
|
@@ -14,10 +15,9 @@ import {
|
|
|
14
15
|
ArchivistParams,
|
|
15
16
|
} from '@xyo-network/archivist-model'
|
|
16
17
|
import { BoundWitness } from '@xyo-network/boundwitness-model'
|
|
17
|
-
import { PayloadHasher } from '@xyo-network/hash'
|
|
18
18
|
import { AnyConfigSchema } from '@xyo-network/module-model'
|
|
19
|
+
import { PayloadBuilder } from '@xyo-network/payload-builder'
|
|
19
20
|
import { Payload } from '@xyo-network/payload-model'
|
|
20
|
-
import { PayloadWrapper } from '@xyo-network/payload-wrapper'
|
|
21
21
|
import Cookies from 'js-cookie'
|
|
22
22
|
|
|
23
23
|
export type CookieArchivistConfigSchema = 'network.xyo.archivist.cookie.config'
|
|
@@ -115,22 +115,20 @@ export class CookieArchivist<
|
|
|
115
115
|
}
|
|
116
116
|
}
|
|
117
117
|
|
|
118
|
-
protected override async deleteHandler(hashes:
|
|
119
|
-
const payloadPairs
|
|
120
|
-
|
|
121
|
-
)
|
|
122
|
-
const deletedPairs: [string, Payload][] = compact(
|
|
118
|
+
protected override async deleteHandler(hashes: Hash[]): Promise<string[]> {
|
|
119
|
+
const payloadPairs = await PayloadBuilder.dataHashPairs(await this.get(hashes))
|
|
120
|
+
const deletedPairs = compact(
|
|
123
121
|
await Promise.all(
|
|
124
|
-
payloadPairs.map<[
|
|
122
|
+
payloadPairs.map<[Payload, Hash]>(([payload, hash]) => {
|
|
125
123
|
Cookies.remove(hash)
|
|
126
|
-
return [
|
|
124
|
+
return [payload, hash]
|
|
127
125
|
}),
|
|
128
126
|
),
|
|
129
127
|
)
|
|
130
|
-
return deletedPairs.map(([hash]) => hash)
|
|
128
|
+
return deletedPairs.map(([, hash]) => hash)
|
|
131
129
|
}
|
|
132
130
|
|
|
133
|
-
protected override getHandler(hashes:
|
|
131
|
+
protected override getHandler(hashes: Hash[]): Promisable<Payload[]> {
|
|
134
132
|
return compact(
|
|
135
133
|
hashes.map((hash) => {
|
|
136
134
|
const cookieString = Cookies.get(this.keyFromHash(hash))
|
|
@@ -141,14 +139,15 @@ export class CookieArchivist<
|
|
|
141
139
|
|
|
142
140
|
protected override async insertHandler(payloads: Payload[]): Promise<Payload[]> {
|
|
143
141
|
try {
|
|
142
|
+
const pairs = await PayloadBuilder.hashPairs(payloads)
|
|
144
143
|
const resultPayloads: Payload[] = await Promise.all(
|
|
145
|
-
|
|
146
|
-
const
|
|
147
|
-
const
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
Cookies.set(
|
|
151
|
-
return
|
|
144
|
+
pairs.map(async ([payload, hash]) => {
|
|
145
|
+
const payloadWithMeta = await PayloadBuilder.build(payload)
|
|
146
|
+
const value = JSON.stringify(payloadWithMeta)
|
|
147
|
+
assertEx(value.length < this.maxEntrySize, `Payload too large [${hash}, ${value.length}]`)
|
|
148
|
+
Cookies.set(this.keyFromHash(hash), value)
|
|
149
|
+
Cookies.set(this.keyFromHash(payload.$hash), value)
|
|
150
|
+
return payloadWithMeta
|
|
152
151
|
}),
|
|
153
152
|
)
|
|
154
153
|
return resultPayloads
|