@xyo-network/archivist-cookie 3.5.2 → 3.6.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.
|
@@ -4,7 +4,7 @@ import { AbstractArchivist } from '@xyo-network/archivist-abstract';
|
|
|
4
4
|
import type { ArchivistConfig, ArchivistModuleEventData, ArchivistParams } from '@xyo-network/archivist-model';
|
|
5
5
|
import type { BoundWitness } from '@xyo-network/boundwitness-model';
|
|
6
6
|
import type { AnyConfigSchema } from '@xyo-network/module-model';
|
|
7
|
-
import type { Payload,
|
|
7
|
+
import type { Payload, Schema } from '@xyo-network/payload-model';
|
|
8
8
|
export type CookieArchivistConfigSchema = 'network.xyo.archivist.cookie.config';
|
|
9
9
|
export declare const CookieArchivistConfigSchema: CookieArchivistConfigSchema;
|
|
10
10
|
export type CookieArchivistConfig = ArchivistConfig<{
|
|
@@ -23,12 +23,12 @@ export declare class CookieArchivist<TParams extends CookieArchivistParams, TEve
|
|
|
23
23
|
get maxEntrySize(): number;
|
|
24
24
|
get namespace(): string;
|
|
25
25
|
get queries(): string[];
|
|
26
|
-
protected allHandler(): PromisableArray<
|
|
26
|
+
protected allHandler(): PromisableArray<Payload>;
|
|
27
27
|
protected clearHandler(): void | Promise<void>;
|
|
28
|
-
protected commitHandler(): Promise<
|
|
28
|
+
protected commitHandler(): Promise<BoundWitness[]>;
|
|
29
29
|
protected deleteHandler(hashes: Hash[]): Promise<Hash[]>;
|
|
30
|
-
protected getHandler(hashes: Hash[]): Promisable<
|
|
31
|
-
protected insertHandler(payloads: Payload[]): Promise<
|
|
30
|
+
protected getHandler(hashes: Hash[]): Promisable<Payload[]>;
|
|
31
|
+
protected insertHandler(payloads: Payload[]): Promise<Payload[]>;
|
|
32
32
|
private keyFromHash;
|
|
33
33
|
}
|
|
34
34
|
//# sourceMappingURL=CookieArchivist.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"CookieArchivist.d.ts","sourceRoot":"","sources":["../../src/CookieArchivist.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,aAAa,CAAA;AACvC,OAAO,KAAK,EAAE,UAAU,EAAE,eAAe,EAAE,MAAM,iBAAiB,CAAA;AAElE,OAAO,EAAE,iBAAiB,EAAE,MAAM,iCAAiC,CAAA;AACnE,OAAO,KAAK,EACV,eAAe,EAEf,wBAAwB,EACxB,eAAe,EAChB,MAAM,8BAA8B,CAAA;AAQrC,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,iCAAiC,CAAA;AACnE,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,2BAA2B,CAAA;AAEhE,OAAO,KAAK,
|
|
1
|
+
{"version":3,"file":"CookieArchivist.d.ts","sourceRoot":"","sources":["../../src/CookieArchivist.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,aAAa,CAAA;AACvC,OAAO,KAAK,EAAE,UAAU,EAAE,eAAe,EAAE,MAAM,iBAAiB,CAAA;AAElE,OAAO,EAAE,iBAAiB,EAAE,MAAM,iCAAiC,CAAA;AACnE,OAAO,KAAK,EACV,eAAe,EAEf,wBAAwB,EACxB,eAAe,EAChB,MAAM,8BAA8B,CAAA;AAQrC,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,iCAAiC,CAAA;AACnE,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,2BAA2B,CAAA;AAEhE,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,EAAE,MAAM,4BAA4B,CAAA;AAGjE,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,gBAAyB,aAAa,EAAE,MAAM,EAAE,CAAwD;IACxG,gBAAyB,mBAAmB,EAAE,MAAM,CAA8B;IAElF,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;cAqBxC,aAAa,CAAC,MAAM,EAAE,IAAI,EAAE,GAAG,OAAO,CAAC,IAAI,EAAE,CAAC;cAapD,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.mjs
CHANGED
|
@@ -66,9 +66,9 @@ var CookieArchivist = class extends AbstractArchivist {
|
|
|
66
66
|
const payloads = await this.all();
|
|
67
67
|
assertEx(payloads.length > 0, () => "Nothing to commit");
|
|
68
68
|
const settled = await Promise.allSettled((Object.values((await this.parentArchivists()).commit ?? [])?.map(async (parent) => {
|
|
69
|
-
const queryPayload =
|
|
69
|
+
const queryPayload = {
|
|
70
70
|
schema: ArchivistInsertQuerySchema
|
|
71
|
-
}
|
|
71
|
+
};
|
|
72
72
|
const query = await this.bindQuery(queryPayload, payloads);
|
|
73
73
|
return (await parent?.query(query[0], query[1]))?.[0];
|
|
74
74
|
})).filter(exists));
|
|
@@ -100,12 +100,12 @@ var CookieArchivist = class extends AbstractArchivist {
|
|
|
100
100
|
try {
|
|
101
101
|
const pairs = await PayloadBuilder.hashPairs(payloads);
|
|
102
102
|
const resultPayloads = await Promise.all(pairs.map(async ([payload, hash]) => {
|
|
103
|
-
const
|
|
104
|
-
const value = JSON.stringify(payloadWithMeta);
|
|
103
|
+
const value = JSON.stringify(payload);
|
|
105
104
|
assertEx(value.length < this.maxEntrySize, () => `Payload too large [${hash}, ${value.length}]`);
|
|
106
105
|
Cookies.set(this.keyFromHash(hash), value);
|
|
107
|
-
|
|
108
|
-
|
|
106
|
+
const dataHash = await PayloadBuilder.dataHash(payload);
|
|
107
|
+
Cookies.set(this.keyFromHash(dataHash), value);
|
|
108
|
+
return payload;
|
|
109
109
|
}));
|
|
110
110
|
return resultPayloads;
|
|
111
111
|
} catch (ex) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/CookieArchivist.ts"],"sourcesContent":["import { assertEx } from '@xylabs/assert'\nimport { exists } from '@xylabs/exists'\nimport type { Hash } from '@xylabs/hex'\nimport type { Promisable, PromisableArray } from '@xylabs/promise'\nimport { fulfilled } from '@xylabs/promise'\nimport { AbstractArchivist } from '@xyo-network/archivist-abstract'\nimport type {\n ArchivistConfig,\n ArchivistInsertQuery,\n ArchivistModuleEventData,\n ArchivistParams,\n} from '@xyo-network/archivist-model'\nimport {\n ArchivistAllQuerySchema,\n ArchivistClearQuerySchema,\n ArchivistCommitQuerySchema,\n ArchivistDeleteQuerySchema,\n ArchivistInsertQuerySchema,\n} from '@xyo-network/archivist-model'\nimport type { BoundWitness } from '@xyo-network/boundwitness-model'\nimport type { AnyConfigSchema } from '@xyo-network/module-model'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport type {
|
|
1
|
+
{"version":3,"sources":["../../src/CookieArchivist.ts"],"sourcesContent":["import { assertEx } from '@xylabs/assert'\nimport { exists } from '@xylabs/exists'\nimport type { Hash } from '@xylabs/hex'\nimport type { Promisable, PromisableArray } from '@xylabs/promise'\nimport { fulfilled } from '@xylabs/promise'\nimport { AbstractArchivist } from '@xyo-network/archivist-abstract'\nimport type {\n ArchivistConfig,\n ArchivistInsertQuery,\n ArchivistModuleEventData,\n ArchivistParams,\n} from '@xyo-network/archivist-model'\nimport {\n ArchivistAllQuerySchema,\n ArchivistClearQuerySchema,\n ArchivistCommitQuerySchema,\n ArchivistDeleteQuerySchema,\n ArchivistInsertQuerySchema,\n} from '@xyo-network/archivist-model'\nimport type { BoundWitness } from '@xyo-network/boundwitness-model'\nimport type { AnyConfigSchema } from '@xyo-network/module-model'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport type { Payload, Schema } 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 readonly configSchemas: Schema[] = [...super.configSchemas, CookieArchivistConfigSchema]\n static override readonly defaultConfigSchema: Schema = 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 for (const [key] of Object.entries(Cookies.get())) {\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 (\n Object.values((await this.parentArchivists()).commit ?? [])?.map(async (parent) => {\n const queryPayload: ArchivistInsertQuery = { schema: ArchivistInsertQuerySchema }\n const query = await this.bindQuery(queryPayload, payloads)\n return (await parent?.query(query[0], query[1]))?.[0]\n })\n ).filter(exists),\n )\n await this.clear()\n return settled.filter(fulfilled).map(result => result.value).filter(exists)\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<Hash[]> {\n const payloadPairs = await PayloadBuilder.dataHashPairs(await this.get(hashes))\n const deletedPairs = (\n await Promise.all(\n payloadPairs.map<[Payload, Hash]>(([payload, hash]) => {\n Cookies.remove(hash)\n return [payload, hash]\n }),\n )\n ).filter(exists)\n return deletedPairs.map(([, hash]) => hash)\n }\n\n protected override getHandler(hashes: Hash[]): Promisable<Payload[]> {\n return (\n hashes.map((hash) => {\n const cookieString = Cookies.get(this.keyFromHash(hash))\n return cookieString ? JSON.parse(cookieString) : undefined\n })\n ).filter(exists)\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 value = JSON.stringify(payload)\n assertEx(value.length < this.maxEntrySize, () => `Payload too large [${hash}, ${value.length}]`)\n Cookies.set(this.keyFromHash(hash), value)\n const dataHash = await PayloadBuilder.dataHash(payload)\n Cookies.set(this.keyFromHash(dataHash), value)\n return payload\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","exists","fulfilled","AbstractArchivist","ArchivistAllQuerySchema","ArchivistClearQuerySchema","ArchivistCommitQuerySchema","ArchivistDeleteQuerySchema","ArchivistInsertQuerySchema","PayloadBuilder","Cookies","CookieArchivistConfigSchema","CookieArchivist","AbstractArchivist","configSchemas","defaultConfigSchema","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","values","parentArchivists","commit","parent","queryPayload","schema","query","bindQuery","exists","clear","fulfilled","result","deleteHandler","hashes","payloadPairs","PayloadBuilder","dataHashPairs","deletedPairs","payload","hash","getHandler","cookieString","keyFromHash","undefined","insertHandler","pairs","hashPairs","resultPayloads","set","dataHash"]}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@xyo-network/archivist-cookie",
|
|
3
|
-
"version": "3.
|
|
3
|
+
"version": "3.6.0-rc.2",
|
|
4
4
|
"description": "Primary SDK for using XYO Protocol 2.0",
|
|
5
5
|
"homepage": "https://xyo.network",
|
|
6
6
|
"bugs": {
|
|
@@ -29,29 +29,30 @@
|
|
|
29
29
|
"module": "dist/browser/index.mjs",
|
|
30
30
|
"types": "dist/browser/index.d.ts",
|
|
31
31
|
"dependencies": {
|
|
32
|
-
"@xylabs/assert": "^4.4.
|
|
33
|
-
"@xylabs/exists": "^4.4.
|
|
34
|
-
"@xylabs/hex": "^4.4.
|
|
35
|
-
"@xylabs/promise": "^4.4.
|
|
36
|
-
"@xyo-network/archivist-abstract": "^3.
|
|
37
|
-
"@xyo-network/archivist-model": "^3.
|
|
38
|
-
"@xyo-network/boundwitness-model": "^3.
|
|
39
|
-
"@xyo-network/module-model": "^3.
|
|
40
|
-
"@xyo-network/payload-builder": "^3.
|
|
41
|
-
"@xyo-network/payload-model": "^3.
|
|
32
|
+
"@xylabs/assert": "^4.4.12",
|
|
33
|
+
"@xylabs/exists": "^4.4.12",
|
|
34
|
+
"@xylabs/hex": "^4.4.12",
|
|
35
|
+
"@xylabs/promise": "^4.4.12",
|
|
36
|
+
"@xyo-network/archivist-abstract": "^3.6.0-rc.2",
|
|
37
|
+
"@xyo-network/archivist-model": "^3.6.0-rc.2",
|
|
38
|
+
"@xyo-network/boundwitness-model": "^3.6.0-rc.2",
|
|
39
|
+
"@xyo-network/module-model": "^3.6.0-rc.2",
|
|
40
|
+
"@xyo-network/payload-builder": "^3.6.0-rc.2",
|
|
41
|
+
"@xyo-network/payload-model": "^3.6.0-rc.2",
|
|
42
42
|
"js-cookie": "^3.0.5"
|
|
43
43
|
},
|
|
44
44
|
"devDependencies": {
|
|
45
45
|
"@types/js-cookie": "^3.0.6",
|
|
46
|
-
"@xylabs/delay": "^4.4.
|
|
46
|
+
"@xylabs/delay": "^4.4.12",
|
|
47
47
|
"@xylabs/ts-scripts-yarn3": "^4.2.4",
|
|
48
48
|
"@xylabs/tsconfig": "^4.2.4",
|
|
49
|
-
"@xyo-network/id-payload-plugin": "^3.
|
|
50
|
-
"@xyo-network/payload-wrapper": "^3.
|
|
49
|
+
"@xyo-network/id-payload-plugin": "^3.6.0-rc.2",
|
|
50
|
+
"@xyo-network/payload-wrapper": "^3.6.0-rc.2",
|
|
51
51
|
"typescript": "^5.7.2",
|
|
52
|
-
"vitest": "^2.1.
|
|
52
|
+
"vitest": "^2.1.8"
|
|
53
53
|
},
|
|
54
54
|
"publishConfig": {
|
|
55
55
|
"access": "public"
|
|
56
|
-
}
|
|
56
|
+
},
|
|
57
|
+
"stableVersion": "3.5.2"
|
|
57
58
|
}
|
package/src/CookieArchivist.ts
CHANGED
|
@@ -20,9 +20,7 @@ import {
|
|
|
20
20
|
import type { BoundWitness } from '@xyo-network/boundwitness-model'
|
|
21
21
|
import type { AnyConfigSchema } from '@xyo-network/module-model'
|
|
22
22
|
import { PayloadBuilder } from '@xyo-network/payload-builder'
|
|
23
|
-
import type {
|
|
24
|
-
Payload, PayloadWithMeta, Schema, WithMeta,
|
|
25
|
-
} from '@xyo-network/payload-model'
|
|
23
|
+
import type { Payload, Schema } from '@xyo-network/payload-model'
|
|
26
24
|
import Cookies from 'js-cookie'
|
|
27
25
|
|
|
28
26
|
export type CookieArchivistConfigSchema = 'network.xyo.archivist.cookie.config'
|
|
@@ -74,7 +72,7 @@ export class CookieArchivist<
|
|
|
74
72
|
]
|
|
75
73
|
}
|
|
76
74
|
|
|
77
|
-
protected override allHandler(): PromisableArray<
|
|
75
|
+
protected override allHandler(): PromisableArray<Payload> {
|
|
78
76
|
try {
|
|
79
77
|
return Object.entries(Cookies.get())
|
|
80
78
|
.filter(([key]) => key.startsWith(`${this.namespace}-`))
|
|
@@ -98,14 +96,14 @@ export class CookieArchivist<
|
|
|
98
96
|
}
|
|
99
97
|
}
|
|
100
98
|
|
|
101
|
-
protected override async commitHandler(): Promise<
|
|
99
|
+
protected override async commitHandler(): Promise<BoundWitness[]> {
|
|
102
100
|
try {
|
|
103
101
|
const payloads = await this.all()
|
|
104
102
|
assertEx(payloads.length > 0, () => 'Nothing to commit')
|
|
105
103
|
const settled = await Promise.allSettled(
|
|
106
104
|
(
|
|
107
105
|
Object.values((await this.parentArchivists()).commit ?? [])?.map(async (parent) => {
|
|
108
|
-
const queryPayload:
|
|
106
|
+
const queryPayload: ArchivistInsertQuery = { schema: ArchivistInsertQuerySchema }
|
|
109
107
|
const query = await this.bindQuery(queryPayload, payloads)
|
|
110
108
|
return (await parent?.query(query[0], query[1]))?.[0]
|
|
111
109
|
})
|
|
@@ -132,7 +130,7 @@ export class CookieArchivist<
|
|
|
132
130
|
return deletedPairs.map(([, hash]) => hash)
|
|
133
131
|
}
|
|
134
132
|
|
|
135
|
-
protected override getHandler(hashes: Hash[]): Promisable<
|
|
133
|
+
protected override getHandler(hashes: Hash[]): Promisable<Payload[]> {
|
|
136
134
|
return (
|
|
137
135
|
hashes.map((hash) => {
|
|
138
136
|
const cookieString = Cookies.get(this.keyFromHash(hash))
|
|
@@ -141,17 +139,17 @@ export class CookieArchivist<
|
|
|
141
139
|
).filter(exists)
|
|
142
140
|
}
|
|
143
141
|
|
|
144
|
-
protected override async insertHandler(payloads: Payload[]): Promise<
|
|
142
|
+
protected override async insertHandler(payloads: Payload[]): Promise<Payload[]> {
|
|
145
143
|
try {
|
|
146
144
|
const pairs = await PayloadBuilder.hashPairs(payloads)
|
|
147
|
-
const resultPayloads:
|
|
145
|
+
const resultPayloads: Payload[] = await Promise.all(
|
|
148
146
|
pairs.map(async ([payload, hash]) => {
|
|
149
|
-
const
|
|
150
|
-
const value = JSON.stringify(payloadWithMeta)
|
|
147
|
+
const value = JSON.stringify(payload)
|
|
151
148
|
assertEx(value.length < this.maxEntrySize, () => `Payload too large [${hash}, ${value.length}]`)
|
|
152
149
|
Cookies.set(this.keyFromHash(hash), value)
|
|
153
|
-
|
|
154
|
-
|
|
150
|
+
const dataHash = await PayloadBuilder.dataHash(payload)
|
|
151
|
+
Cookies.set(this.keyFromHash(dataHash), value)
|
|
152
|
+
return payload
|
|
155
153
|
}),
|
|
156
154
|
)
|
|
157
155
|
return resultPayloads
|