@xyo-network/archivist-cookie 4.2.1 → 5.0.0
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.
|
@@ -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;
|
|
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;AAGlE,OAAO,EAAE,iBAAiB,EAAqB,MAAM,iCAAiC,CAAA;AACtF,OAAO,KAAK,EACV,eAAe,EAEf,wBAAwB,EACxB,eAAe,EAChB,MAAM,8BAA8B,CAAA;AAQrC,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,iCAAiC,CAAA;AACnE,OAAO,EAAE,KAAK,eAAe,EAAmB,MAAM,2BAA2B,CAAA;AAEjF,OAAO,KAAK,EACV,OAAO,EAAE,MAAM,EAAE,eAAe,EACjC,MAAM,4BAA4B,CAAA;AAGnC,eAAO,MAAM,2BAA2B,EAAG,qCAA8C,CAAA;AACzF,MAAM,MAAM,2BAA2B,GAAG,OAAO,2BAA2B,CAAA;AAE5E,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,qBACa,eAAe,CAC1B,OAAO,SAAS,qBAAqB,GAAG,qBAAqB,EAC7D,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;IAClF,gBAAyB,MAAM;;MAAmD;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,eAAe,CAAC,OAAO,CAAC,CAAC;cAWvD,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,eAAe,CAAC,OAAO,CAAC,EAAE,CAAC;cAaxE,UAAU,CAAC,MAAM,EAAE,IAAI,EAAE,GAAG,UAAU,CAAC,eAAe,CAAC,OAAO,CAAC,EAAE,CAAC;cASlE,aAAa,CAAC,QAAQ,EAAE,eAAe,CAAC,OAAO,CAAC,EAAE,GAAG,eAAe,CAAC,OAAO,CAAC,EAAE;IAgBlG,OAAO,CAAC,WAAW;CAGpB"}
|
package/dist/browser/index.mjs
CHANGED
|
@@ -18,6 +18,7 @@ var __superGet = (cls, obj, key) => __reflectGet(__getProtoOf(cls), key, obj);
|
|
|
18
18
|
import { assertEx } from "@xylabs/assert";
|
|
19
19
|
import { exists } from "@xylabs/exists";
|
|
20
20
|
import { fulfilled } from "@xylabs/promise";
|
|
21
|
+
import { isString } from "@xylabs/typeof";
|
|
21
22
|
import { AbstractArchivist, StorageClassLabel } from "@xyo-network/archivist-abstract";
|
|
22
23
|
import {
|
|
23
24
|
ArchivistAllQuerySchema,
|
|
@@ -104,7 +105,7 @@ var CookieArchivist = class extends AbstractArchivist {
|
|
|
104
105
|
getHandler(hashes) {
|
|
105
106
|
return hashes.map((hash) => {
|
|
106
107
|
const cookieString = Cookies.get(this.keyFromHash(hash));
|
|
107
|
-
return cookieString ? JSON.parse(cookieString) : void 0;
|
|
108
|
+
return isString(cookieString) ? JSON.parse(cookieString) : void 0;
|
|
108
109
|
}).filter(exists);
|
|
109
110
|
}
|
|
110
111
|
insertHandler(payloads) {
|
|
@@ -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, StorageClassLabel } 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, creatableModule } from '@xyo-network/module-model'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport type {\n Payload, Schema, WithStorageMeta,\n} from '@xyo-network/payload-model'\nimport Cookies from 'js-cookie'\n\nexport const CookieArchivistConfigSchema = 'network.xyo.archivist.cookie.config' as const\nexport type CookieArchivistConfigSchema = typeof CookieArchivistConfigSchema\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\n@creatableModule()\nexport class CookieArchivist<\n TParams extends CookieArchivistParams = 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 static override readonly labels = { ...super.labels, [StorageClassLabel]: 'disk' }\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<WithStorageMeta<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<WithStorageMeta<Payload>[]> {\n const payloadPairs = await PayloadBuilder.dataHashPairs(await this.get(hashes))\n const deletedPairs = (\n await Promise.all(\n payloadPairs.map<[WithStorageMeta<Payload>, Hash]>(([payload, hash]) => {\n Cookies.remove(hash)\n return [payload, hash]\n }),\n )\n ).filter(exists)\n return deletedPairs.map(([payload]) => payload)\n }\n\n protected override getHandler(hashes: Hash[]): Promisable<WithStorageMeta<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 insertHandler(payloads: WithStorageMeta<Payload>[]): WithStorageMeta<Payload>[] {\n try {\n const resultPayloads: WithStorageMeta<Payload>[] = payloads.map((payload) => {\n const value = JSON.stringify(payload)\n assertEx(value.length < this.maxEntrySize, () => `Payload too large [${payload._hash}, ${value.length}]`)\n Cookies.set(this.keyFromHash(payload._hash), value)\n Cookies.set(this.keyFromHash(payload._dataHash), value)\n return payload\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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
|
|
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 { isString } from '@xylabs/typeof'\nimport { AbstractArchivist, StorageClassLabel } 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, creatableModule } from '@xyo-network/module-model'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport type {\n Payload, Schema, WithStorageMeta,\n} from '@xyo-network/payload-model'\nimport Cookies from 'js-cookie'\n\nexport const CookieArchivistConfigSchema = 'network.xyo.archivist.cookie.config' as const\nexport type CookieArchivistConfigSchema = typeof CookieArchivistConfigSchema\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\n@creatableModule()\nexport class CookieArchivist<\n TParams extends CookieArchivistParams = 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 static override readonly labels = { ...super.labels, [StorageClassLabel]: 'disk' }\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<WithStorageMeta<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<WithStorageMeta<Payload>[]> {\n const payloadPairs = await PayloadBuilder.dataHashPairs(await this.get(hashes))\n const deletedPairs = (\n await Promise.all(\n payloadPairs.map<[WithStorageMeta<Payload>, Hash]>(([payload, hash]) => {\n Cookies.remove(hash)\n return [payload, hash]\n }),\n )\n ).filter(exists)\n return deletedPairs.map(([payload]) => payload)\n }\n\n protected override getHandler(hashes: Hash[]): Promisable<WithStorageMeta<Payload>[]> {\n return (\n hashes.map((hash) => {\n const cookieString = Cookies.get(this.keyFromHash(hash))\n return isString(cookieString) ? JSON.parse(cookieString) : undefined\n })\n ).filter(exists)\n }\n\n protected override insertHandler(payloads: WithStorageMeta<Payload>[]): WithStorageMeta<Payload>[] {\n try {\n const resultPayloads: WithStorageMeta<Payload>[] = payloads.map((payload) => {\n const value = JSON.stringify(payload)\n assertEx(value.length < this.maxEntrySize, () => `Payload too large [${payload._hash}, ${value.length}]`)\n Cookies.set(this.keyFromHash(payload._hash), value)\n Cookies.set(this.keyFromHash(payload._dataHash), value)\n return payload\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":[]}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@xyo-network/archivist-cookie",
|
|
3
|
-
"version": "
|
|
3
|
+
"version": "5.0.0",
|
|
4
4
|
"description": "Primary SDK for using XYO Protocol 2.0",
|
|
5
5
|
"homepage": "https://xyo.network",
|
|
6
6
|
"bugs": {
|
|
@@ -28,26 +28,31 @@
|
|
|
28
28
|
},
|
|
29
29
|
"module": "dist/browser/index.mjs",
|
|
30
30
|
"types": "dist/browser/index.d.ts",
|
|
31
|
+
"files": [
|
|
32
|
+
"dist",
|
|
33
|
+
"src"
|
|
34
|
+
],
|
|
31
35
|
"dependencies": {
|
|
32
|
-
"@xylabs/assert": "^
|
|
33
|
-
"@xylabs/exists": "^
|
|
34
|
-
"@xylabs/hex": "^
|
|
35
|
-
"@xylabs/promise": "^
|
|
36
|
-
"@
|
|
37
|
-
"@xyo-network/archivist-
|
|
38
|
-
"@xyo-network/
|
|
39
|
-
"@xyo-network/
|
|
40
|
-
"@xyo-network/
|
|
41
|
-
"@xyo-network/payload-
|
|
36
|
+
"@xylabs/assert": "^5.0.0",
|
|
37
|
+
"@xylabs/exists": "^5.0.0",
|
|
38
|
+
"@xylabs/hex": "^5.0.0",
|
|
39
|
+
"@xylabs/promise": "^5.0.0",
|
|
40
|
+
"@xylabs/typeof": "^5.0.0",
|
|
41
|
+
"@xyo-network/archivist-abstract": "^5.0.0",
|
|
42
|
+
"@xyo-network/archivist-model": "^5.0.0",
|
|
43
|
+
"@xyo-network/boundwitness-model": "^5.0.0",
|
|
44
|
+
"@xyo-network/module-model": "^5.0.0",
|
|
45
|
+
"@xyo-network/payload-builder": "^5.0.0",
|
|
46
|
+
"@xyo-network/payload-model": "^5.0.0",
|
|
42
47
|
"js-cookie": "^3.0.5"
|
|
43
48
|
},
|
|
44
49
|
"devDependencies": {
|
|
45
50
|
"@types/js-cookie": "^3.0.6",
|
|
46
|
-
"@xylabs/delay": "^
|
|
47
|
-
"@xylabs/ts-scripts-yarn3": "^7.0.
|
|
48
|
-
"@xylabs/tsconfig": "^7.0.
|
|
49
|
-
"@xyo-network/id-payload-plugin": "^
|
|
50
|
-
"@xyo-network/payload-wrapper": "^
|
|
51
|
+
"@xylabs/delay": "^5.0.0",
|
|
52
|
+
"@xylabs/ts-scripts-yarn3": "^7.0.2",
|
|
53
|
+
"@xylabs/tsconfig": "^7.0.2",
|
|
54
|
+
"@xyo-network/id-payload-plugin": "^5.0.0",
|
|
55
|
+
"@xyo-network/payload-wrapper": "^5.0.0",
|
|
51
56
|
"typescript": "^5.8.3",
|
|
52
57
|
"vitest": "^3.2.4"
|
|
53
58
|
},
|
package/src/CookieArchivist.ts
CHANGED
|
@@ -3,6 +3,7 @@ import { exists } from '@xylabs/exists'
|
|
|
3
3
|
import type { Hash } from '@xylabs/hex'
|
|
4
4
|
import type { Promisable, PromisableArray } from '@xylabs/promise'
|
|
5
5
|
import { fulfilled } from '@xylabs/promise'
|
|
6
|
+
import { isString } from '@xylabs/typeof'
|
|
6
7
|
import { AbstractArchivist, StorageClassLabel } from '@xyo-network/archivist-abstract'
|
|
7
8
|
import type {
|
|
8
9
|
ArchivistConfig,
|
|
@@ -138,7 +139,7 @@ export class CookieArchivist<
|
|
|
138
139
|
return (
|
|
139
140
|
hashes.map((hash) => {
|
|
140
141
|
const cookieString = Cookies.get(this.keyFromHash(hash))
|
|
141
|
-
return cookieString ? JSON.parse(cookieString) : undefined
|
|
142
|
+
return isString(cookieString) ? JSON.parse(cookieString) : undefined
|
|
142
143
|
})
|
|
143
144
|
).filter(exists)
|
|
144
145
|
}
|
|
@@ -0,0 +1,70 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @vitest-environment jsdom
|
|
3
|
+
*/
|
|
4
|
+
|
|
5
|
+
import { delay } from '@xylabs/delay'
|
|
6
|
+
import type { Promisable } from '@xylabs/promise'
|
|
7
|
+
import type { ArchivistInstance } from '@xyo-network/archivist-model'
|
|
8
|
+
import { IdSchema } from '@xyo-network/id-payload-plugin'
|
|
9
|
+
import type { Payload } from '@xyo-network/payload-model'
|
|
10
|
+
import { PayloadWrapper } from '@xyo-network/payload-wrapper'
|
|
11
|
+
import { expect, test } from 'vitest'
|
|
12
|
+
|
|
13
|
+
import { CookieArchivist, CookieArchivistConfigSchema } from '../CookieArchivist.ts'
|
|
14
|
+
|
|
15
|
+
const testArchivistRoundTrip = (archivistPromise: Promisable<ArchivistInstance>, name: string) => {
|
|
16
|
+
test(`Archivist RoundTrip [${name}]`, async () => {
|
|
17
|
+
const idPayload: Payload<{ salt: string }> = {
|
|
18
|
+
salt: Date.now().toString(),
|
|
19
|
+
schema: IdSchema,
|
|
20
|
+
}
|
|
21
|
+
const payloadWrapper = PayloadWrapper.wrap(idPayload)
|
|
22
|
+
|
|
23
|
+
const archivist = await archivistPromise
|
|
24
|
+
await archivist.clear?.()
|
|
25
|
+
const insertResult = await archivist.insert([payloadWrapper.payload])
|
|
26
|
+
expect(insertResult).toBeDefined()
|
|
27
|
+
|
|
28
|
+
const getResult = await archivist.get([await payloadWrapper.dataHash()])
|
|
29
|
+
expect(getResult).toBeDefined()
|
|
30
|
+
expect(getResult.length).toBe(1)
|
|
31
|
+
const gottenPayload = getResult[0]
|
|
32
|
+
if (gottenPayload) {
|
|
33
|
+
const gottenPayloadWrapper = PayloadWrapper.wrap(gottenPayload)
|
|
34
|
+
// expect(await gottenPayloadWrapper.hash()).toBe(await payloadWrapper.hash())
|
|
35
|
+
expect(await gottenPayloadWrapper.dataHash()).toBe(await payloadWrapper.dataHash())
|
|
36
|
+
}
|
|
37
|
+
})
|
|
38
|
+
}
|
|
39
|
+
|
|
40
|
+
const testArchivistAll = (archivistPromise: Promisable<ArchivistInstance>, name: string) => {
|
|
41
|
+
test(`Archivist All [${name}]`, async () => {
|
|
42
|
+
const archivist = await archivistPromise
|
|
43
|
+
await archivist.clear?.()
|
|
44
|
+
for (let x = 0; x < 10; x++) {
|
|
45
|
+
const idPayload = {
|
|
46
|
+
salt: Date.now().toString(),
|
|
47
|
+
schema: IdSchema,
|
|
48
|
+
}
|
|
49
|
+
await archivist.insert([idPayload])
|
|
50
|
+
await delay(10)
|
|
51
|
+
}
|
|
52
|
+
const getResult = await archivist.all?.()
|
|
53
|
+
expect(getResult).toBeDefined()
|
|
54
|
+
// this is 11 here since we double store all these and every one has the same dataHash
|
|
55
|
+
expect(getResult?.length).toBe(10)
|
|
56
|
+
})
|
|
57
|
+
}
|
|
58
|
+
|
|
59
|
+
/**
|
|
60
|
+
* @group module
|
|
61
|
+
* @group archivist
|
|
62
|
+
*/
|
|
63
|
+
testArchivistRoundTrip(
|
|
64
|
+
(async () => await CookieArchivist.create({ account: 'random', config: { namespace: 'test', schema: CookieArchivistConfigSchema } }))(),
|
|
65
|
+
'cookie',
|
|
66
|
+
)
|
|
67
|
+
testArchivistAll(
|
|
68
|
+
(async () => await CookieArchivist.create({ account: 'random', config: { namespace: 'test', schema: CookieArchivistConfigSchema } }))(),
|
|
69
|
+
'cookie',
|
|
70
|
+
)
|