@xyo-network/archivist 2.85.3 → 2.85.5

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.
Files changed (49) hide show
  1. package/dist/browser/index.cjs +1 -282
  2. package/dist/browser/index.cjs.map +1 -1
  3. package/dist/browser/index.d.cts +1 -3
  4. package/dist/browser/index.d.cts.map +1 -1
  5. package/dist/browser/index.d.mts +1 -3
  6. package/dist/browser/index.d.mts.map +1 -1
  7. package/dist/browser/index.d.ts +1 -3
  8. package/dist/browser/index.d.ts.map +1 -1
  9. package/dist/browser/index.js +1 -268
  10. package/dist/browser/index.js.map +1 -1
  11. package/dist/node/index.cjs +3 -307
  12. package/dist/node/index.cjs.map +1 -1
  13. package/dist/node/index.d.cts +1 -3
  14. package/dist/node/index.d.cts.map +1 -1
  15. package/dist/node/index.d.mts +1 -3
  16. package/dist/node/index.d.mts.map +1 -1
  17. package/dist/node/index.d.ts +1 -3
  18. package/dist/node/index.d.ts.map +1 -1
  19. package/dist/node/index.js +1 -287
  20. package/dist/node/index.js.map +1 -1
  21. package/package.json +5 -21
  22. package/src/index.ts +1 -3
  23. package/dist/browser/CookieArchivist.d.cts +0 -32
  24. package/dist/browser/CookieArchivist.d.cts.map +0 -1
  25. package/dist/browser/CookieArchivist.d.mts +0 -32
  26. package/dist/browser/CookieArchivist.d.mts.map +0 -1
  27. package/dist/browser/CookieArchivist.d.ts +0 -32
  28. package/dist/browser/CookieArchivist.d.ts.map +0 -1
  29. package/dist/browser/StorageArchivist.d.cts +0 -39
  30. package/dist/browser/StorageArchivist.d.cts.map +0 -1
  31. package/dist/browser/StorageArchivist.d.mts +0 -39
  32. package/dist/browser/StorageArchivist.d.mts.map +0 -1
  33. package/dist/browser/StorageArchivist.d.ts +0 -39
  34. package/dist/browser/StorageArchivist.d.ts.map +0 -1
  35. package/dist/node/CookieArchivist.d.cts +0 -32
  36. package/dist/node/CookieArchivist.d.cts.map +0 -1
  37. package/dist/node/CookieArchivist.d.mts +0 -32
  38. package/dist/node/CookieArchivist.d.mts.map +0 -1
  39. package/dist/node/CookieArchivist.d.ts +0 -32
  40. package/dist/node/CookieArchivist.d.ts.map +0 -1
  41. package/dist/node/StorageArchivist.d.cts +0 -39
  42. package/dist/node/StorageArchivist.d.cts.map +0 -1
  43. package/dist/node/StorageArchivist.d.mts +0 -39
  44. package/dist/node/StorageArchivist.d.mts.map +0 -1
  45. package/dist/node/StorageArchivist.d.ts +0 -39
  46. package/dist/node/StorageArchivist.d.ts.map +0 -1
  47. package/src/CookieArchivist.ts +0 -164
  48. package/src/StorageArchivist.ts +0 -191
  49. package/src/spec/testArchivist.ts +0 -50
@@ -1 +0,0 @@
1
- {"version":3,"file":"StorageArchivist.d.ts","sourceRoot":"","sources":["../../src/StorageArchivist.ts"],"names":[],"mappings":"AAEA,OAAO,EAAa,UAAU,EAAE,eAAe,EAAE,MAAM,iBAAiB,CAAA;AACxE,OAAO,EAAE,iBAAiB,EAAE,MAAM,iCAAiC,CAAA;AACnE,OAAO,EAIL,eAAe,EAIf,iBAAiB,EACjB,wBAAwB,EACxB,eAAe,EAChB,MAAM,8BAA8B,CAAA;AACrC,OAAO,EAAE,YAAY,EAAE,MAAM,iCAAiC,CAAA;AAE9D,OAAO,EAAE,eAAe,EAAE,MAAM,2BAA2B,CAAA;AAC3D,OAAO,EAAE,OAAO,EAAE,MAAM,4BAA4B,CAAA;AAIpD,MAAM,MAAM,4BAA4B,GAAG,sCAAsC,CAAA;AACjF,eAAO,MAAM,4BAA4B,EAAE,4BAAqE,CAAA;AAEhH,MAAM,MAAM,sBAAsB,GAAG,eAAe,CAAC;IACnD,UAAU,CAAC,EAAE,MAAM,CAAA;IACnB,YAAY,CAAC,EAAE,MAAM,CAAA;IACrB,SAAS,CAAC,EAAE,MAAM,CAAA;IAClB,cAAc,CAAC,EAAE,OAAO,CAAA;IACxB,MAAM,EAAE,4BAA4B,CAAA;IACpC,IAAI,CAAC,EAAE,OAAO,GAAG,SAAS,GAAG,MAAM,CAAA;CACpC,CAAC,CAAA;AAEF,MAAM,MAAM,sBAAsB,GAAG,eAAe,CAAC,eAAe,CAAC,sBAAsB,CAAC,CAAC,CAAA;AAC7F,qBAAa,gBAAgB,CACzB,OAAO,SAAS,sBAAsB,GAAG,sBAAsB,EAC/D,UAAU,SAAS,wBAAwB,GAAG,wBAAwB,CAExE,SAAQ,iBAAiB,CAAC,OAAO,EAAE,UAAU,CAC7C,YAAW,iBAAiB;IAE5B,OAAgB,aAAa,2CAAiC;IAE9D,OAAO,CAAC,eAAe,CAAuB;IAC9C,OAAO,CAAC,QAAQ,CAAuB;IAEvC,IAAI,UAAU,WAEb;IAED,IAAI,YAAY,WAEf;IAED,IAAI,SAAS,WAEZ;IAED,IAAI,cAAc,YAEjB;IAED,IAAa,OAAO,IAAI,MAAM,EAAE,CAS/B;IAED,IAAI,IAAI,iCAEP;IAGD,OAAO,KAAK,cAAc,GAGzB;IAGD,OAAO,KAAK,OAAO,GAGlB;cAoBkB,UAAU,IAAI,eAAe,CAAC,OAAO,CAAC;cAKtC,YAAY,IAAI,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC;cAM9B,aAAa,IAAI,OAAO,CAAC,YAAY,EAAE,CAAC;cAoBxC,aAAa,CAAC,MAAM,EAAE,MAAM,EAAE,GAAG,OAAO,CAAC,MAAM,EAAE,CAAC;cAexD,UAAU,CAAC,MAAM,EAAE,MAAM,EAAE,GAAG,UAAU,CAAC,OAAO,EAAE,CAAC;cAQ7C,aAAa,CAAC,QAAQ,EAAE,OAAO,EAAE,GAAG,OAAO,CAAC,OAAO,EAAE,CAAC;IAc/E,SAAS,CAAC,WAAW;cAQI,YAAY;CAKtC"}
@@ -1,32 +0,0 @@
1
- import { Promisable, PromisableArray } from '@xylabs/promise';
2
- import { AbstractArchivist } from '@xyo-network/archivist-abstract';
3
- import { ArchivistConfig, ArchivistModuleEventData, ArchivistParams } from '@xyo-network/archivist-model';
4
- import { BoundWitness } from '@xyo-network/boundwitness-model';
5
- import { AnyConfigSchema } from '@xyo-network/module-model';
6
- import { Payload } from '@xyo-network/payload-model';
7
- export type CookieArchivistConfigSchema = 'network.xyo.archivist.cookie.config';
8
- export declare const CookieArchivistConfigSchema: CookieArchivistConfigSchema;
9
- export type CookieArchivistConfig = ArchivistConfig<{
10
- domain?: string;
11
- maxEntries?: number;
12
- maxEntrySize?: number;
13
- namespace?: string;
14
- schema: CookieArchivistConfigSchema;
15
- }>;
16
- export type CookieArchivistParams = ArchivistParams<AnyConfigSchema<CookieArchivistConfig>>;
17
- export declare class CookieArchivist<TParams extends CookieArchivistParams, TEventData extends ArchivistModuleEventData = ArchivistModuleEventData> extends AbstractArchivist<TParams, TEventData> {
18
- static configSchemas: "network.xyo.archivist.cookie.config"[];
19
- get domain(): string | undefined;
20
- get maxEntries(): number;
21
- get maxEntrySize(): number;
22
- get namespace(): string;
23
- get queries(): string[];
24
- protected allHandler(): PromisableArray<Payload>;
25
- protected clearHandler(): void | Promise<void>;
26
- protected commitHandler(): Promise<BoundWitness[]>;
27
- protected deleteHandler(hashes: string[]): Promise<string[]>;
28
- protected getHandler(hashes: string[]): Promisable<Payload[]>;
29
- protected insertHandler(payloads: Payload[]): Promise<Payload[]>;
30
- private keyFromHash;
31
- }
32
- //# sourceMappingURL=CookieArchivist.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"CookieArchivist.d.ts","sourceRoot":"","sources":["../../src/CookieArchivist.ts"],"names":[],"mappings":"AAEA,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;AAE9D,OAAO,EAAE,eAAe,EAAE,MAAM,2BAA2B,CAAA;AAC3D,OAAO,EAAE,OAAO,EAAE,MAAM,4BAA4B,CAAA;AAIpD,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,MAAM,EAAE,GAAG,OAAO,CAAC,MAAM,EAAE,CAAC;cAexD,UAAU,CAAC,MAAM,EAAE,MAAM,EAAE,GAAG,UAAU,CAAC,OAAO,EAAE,CAAC;cAS7C,aAAa,CAAC,QAAQ,EAAE,OAAO,EAAE,GAAG,OAAO,CAAC,OAAO,EAAE,CAAC;IAmB/E,OAAO,CAAC,WAAW;CAGpB"}
@@ -1,32 +0,0 @@
1
- import { Promisable, PromisableArray } from '@xylabs/promise';
2
- import { AbstractArchivist } from '@xyo-network/archivist-abstract';
3
- import { ArchivistConfig, ArchivistModuleEventData, ArchivistParams } from '@xyo-network/archivist-model';
4
- import { BoundWitness } from '@xyo-network/boundwitness-model';
5
- import { AnyConfigSchema } from '@xyo-network/module-model';
6
- import { Payload } from '@xyo-network/payload-model';
7
- export type CookieArchivistConfigSchema = 'network.xyo.archivist.cookie.config';
8
- export declare const CookieArchivistConfigSchema: CookieArchivistConfigSchema;
9
- export type CookieArchivistConfig = ArchivistConfig<{
10
- domain?: string;
11
- maxEntries?: number;
12
- maxEntrySize?: number;
13
- namespace?: string;
14
- schema: CookieArchivistConfigSchema;
15
- }>;
16
- export type CookieArchivistParams = ArchivistParams<AnyConfigSchema<CookieArchivistConfig>>;
17
- export declare class CookieArchivist<TParams extends CookieArchivistParams, TEventData extends ArchivistModuleEventData = ArchivistModuleEventData> extends AbstractArchivist<TParams, TEventData> {
18
- static configSchemas: "network.xyo.archivist.cookie.config"[];
19
- get domain(): string | undefined;
20
- get maxEntries(): number;
21
- get maxEntrySize(): number;
22
- get namespace(): string;
23
- get queries(): string[];
24
- protected allHandler(): PromisableArray<Payload>;
25
- protected clearHandler(): void | Promise<void>;
26
- protected commitHandler(): Promise<BoundWitness[]>;
27
- protected deleteHandler(hashes: string[]): Promise<string[]>;
28
- protected getHandler(hashes: string[]): Promisable<Payload[]>;
29
- protected insertHandler(payloads: Payload[]): Promise<Payload[]>;
30
- private keyFromHash;
31
- }
32
- //# sourceMappingURL=CookieArchivist.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"CookieArchivist.d.ts","sourceRoot":"","sources":["../../src/CookieArchivist.ts"],"names":[],"mappings":"AAEA,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;AAE9D,OAAO,EAAE,eAAe,EAAE,MAAM,2BAA2B,CAAA;AAC3D,OAAO,EAAE,OAAO,EAAE,MAAM,4BAA4B,CAAA;AAIpD,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,MAAM,EAAE,GAAG,OAAO,CAAC,MAAM,EAAE,CAAC;cAexD,UAAU,CAAC,MAAM,EAAE,MAAM,EAAE,GAAG,UAAU,CAAC,OAAO,EAAE,CAAC;cAS7C,aAAa,CAAC,QAAQ,EAAE,OAAO,EAAE,GAAG,OAAO,CAAC,OAAO,EAAE,CAAC;IAmB/E,OAAO,CAAC,WAAW;CAGpB"}
@@ -1,32 +0,0 @@
1
- import { Promisable, PromisableArray } from '@xylabs/promise';
2
- import { AbstractArchivist } from '@xyo-network/archivist-abstract';
3
- import { ArchivistConfig, ArchivistModuleEventData, ArchivistParams } from '@xyo-network/archivist-model';
4
- import { BoundWitness } from '@xyo-network/boundwitness-model';
5
- import { AnyConfigSchema } from '@xyo-network/module-model';
6
- import { Payload } from '@xyo-network/payload-model';
7
- export type CookieArchivistConfigSchema = 'network.xyo.archivist.cookie.config';
8
- export declare const CookieArchivistConfigSchema: CookieArchivistConfigSchema;
9
- export type CookieArchivistConfig = ArchivistConfig<{
10
- domain?: string;
11
- maxEntries?: number;
12
- maxEntrySize?: number;
13
- namespace?: string;
14
- schema: CookieArchivistConfigSchema;
15
- }>;
16
- export type CookieArchivistParams = ArchivistParams<AnyConfigSchema<CookieArchivistConfig>>;
17
- export declare class CookieArchivist<TParams extends CookieArchivistParams, TEventData extends ArchivistModuleEventData = ArchivistModuleEventData> extends AbstractArchivist<TParams, TEventData> {
18
- static configSchemas: "network.xyo.archivist.cookie.config"[];
19
- get domain(): string | undefined;
20
- get maxEntries(): number;
21
- get maxEntrySize(): number;
22
- get namespace(): string;
23
- get queries(): string[];
24
- protected allHandler(): PromisableArray<Payload>;
25
- protected clearHandler(): void | Promise<void>;
26
- protected commitHandler(): Promise<BoundWitness[]>;
27
- protected deleteHandler(hashes: string[]): Promise<string[]>;
28
- protected getHandler(hashes: string[]): Promisable<Payload[]>;
29
- protected insertHandler(payloads: Payload[]): Promise<Payload[]>;
30
- private keyFromHash;
31
- }
32
- //# sourceMappingURL=CookieArchivist.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"CookieArchivist.d.ts","sourceRoot":"","sources":["../../src/CookieArchivist.ts"],"names":[],"mappings":"AAEA,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;AAE9D,OAAO,EAAE,eAAe,EAAE,MAAM,2BAA2B,CAAA;AAC3D,OAAO,EAAE,OAAO,EAAE,MAAM,4BAA4B,CAAA;AAIpD,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,MAAM,EAAE,GAAG,OAAO,CAAC,MAAM,EAAE,CAAC;cAexD,UAAU,CAAC,MAAM,EAAE,MAAM,EAAE,GAAG,UAAU,CAAC,OAAO,EAAE,CAAC;cAS7C,aAAa,CAAC,QAAQ,EAAE,OAAO,EAAE,GAAG,OAAO,CAAC,OAAO,EAAE,CAAC;IAmB/E,OAAO,CAAC,WAAW;CAGpB"}
@@ -1,39 +0,0 @@
1
- import { Promisable, PromisableArray } from '@xylabs/promise';
2
- import { AbstractArchivist } from '@xyo-network/archivist-abstract';
3
- import { ArchivistConfig, ArchivistInstance, ArchivistModuleEventData, ArchivistParams } from '@xyo-network/archivist-model';
4
- import { BoundWitness } from '@xyo-network/boundwitness-model';
5
- import { AnyConfigSchema } from '@xyo-network/module-model';
6
- import { Payload } from '@xyo-network/payload-model';
7
- export type StorageArchivistConfigSchema = 'network.xyo.archivist.storage.config';
8
- export declare const StorageArchivistConfigSchema: StorageArchivistConfigSchema;
9
- export type StorageArchivistConfig = ArchivistConfig<{
10
- maxEntries?: number;
11
- maxEntrySize?: number;
12
- namespace?: string;
13
- persistAccount?: boolean;
14
- schema: StorageArchivistConfigSchema;
15
- type?: 'local' | 'session' | 'page';
16
- }>;
17
- export type StorageArchivistParams = ArchivistParams<AnyConfigSchema<StorageArchivistConfig>>;
18
- export declare class StorageArchivist<TParams extends StorageArchivistParams = StorageArchivistParams, TEventData extends ArchivistModuleEventData = ArchivistModuleEventData> extends AbstractArchivist<TParams, TEventData> implements ArchivistInstance {
19
- static configSchemas: "network.xyo.archivist.storage.config"[];
20
- private _privateStorage;
21
- private _storage;
22
- get maxEntries(): number;
23
- get maxEntrySize(): number;
24
- get namespace(): string;
25
- get persistAccount(): boolean;
26
- get queries(): string[];
27
- get type(): "local" | "session" | "page";
28
- private get privateStorage();
29
- private get storage();
30
- protected allHandler(): PromisableArray<Payload>;
31
- protected clearHandler(): void | Promise<void>;
32
- protected commitHandler(): Promise<BoundWitness[]>;
33
- protected deleteHandler(hashes: string[]): Promise<string[]>;
34
- protected getHandler(hashes: string[]): Promisable<Payload[]>;
35
- protected insertHandler(payloads: Payload[]): Promise<Payload[]>;
36
- protected saveAccount(): void;
37
- protected startHandler(): Promise<boolean>;
38
- }
39
- //# sourceMappingURL=StorageArchivist.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"StorageArchivist.d.ts","sourceRoot":"","sources":["../../src/StorageArchivist.ts"],"names":[],"mappings":"AAEA,OAAO,EAAa,UAAU,EAAE,eAAe,EAAE,MAAM,iBAAiB,CAAA;AACxE,OAAO,EAAE,iBAAiB,EAAE,MAAM,iCAAiC,CAAA;AACnE,OAAO,EAIL,eAAe,EAIf,iBAAiB,EACjB,wBAAwB,EACxB,eAAe,EAChB,MAAM,8BAA8B,CAAA;AACrC,OAAO,EAAE,YAAY,EAAE,MAAM,iCAAiC,CAAA;AAE9D,OAAO,EAAE,eAAe,EAAE,MAAM,2BAA2B,CAAA;AAC3D,OAAO,EAAE,OAAO,EAAE,MAAM,4BAA4B,CAAA;AAIpD,MAAM,MAAM,4BAA4B,GAAG,sCAAsC,CAAA;AACjF,eAAO,MAAM,4BAA4B,EAAE,4BAAqE,CAAA;AAEhH,MAAM,MAAM,sBAAsB,GAAG,eAAe,CAAC;IACnD,UAAU,CAAC,EAAE,MAAM,CAAA;IACnB,YAAY,CAAC,EAAE,MAAM,CAAA;IACrB,SAAS,CAAC,EAAE,MAAM,CAAA;IAClB,cAAc,CAAC,EAAE,OAAO,CAAA;IACxB,MAAM,EAAE,4BAA4B,CAAA;IACpC,IAAI,CAAC,EAAE,OAAO,GAAG,SAAS,GAAG,MAAM,CAAA;CACpC,CAAC,CAAA;AAEF,MAAM,MAAM,sBAAsB,GAAG,eAAe,CAAC,eAAe,CAAC,sBAAsB,CAAC,CAAC,CAAA;AAC7F,qBAAa,gBAAgB,CACzB,OAAO,SAAS,sBAAsB,GAAG,sBAAsB,EAC/D,UAAU,SAAS,wBAAwB,GAAG,wBAAwB,CAExE,SAAQ,iBAAiB,CAAC,OAAO,EAAE,UAAU,CAC7C,YAAW,iBAAiB;IAE5B,OAAgB,aAAa,2CAAiC;IAE9D,OAAO,CAAC,eAAe,CAAuB;IAC9C,OAAO,CAAC,QAAQ,CAAuB;IAEvC,IAAI,UAAU,WAEb;IAED,IAAI,YAAY,WAEf;IAED,IAAI,SAAS,WAEZ;IAED,IAAI,cAAc,YAEjB;IAED,IAAa,OAAO,IAAI,MAAM,EAAE,CAS/B;IAED,IAAI,IAAI,iCAEP;IAGD,OAAO,KAAK,cAAc,GAGzB;IAGD,OAAO,KAAK,OAAO,GAGlB;cAoBkB,UAAU,IAAI,eAAe,CAAC,OAAO,CAAC;cAKtC,YAAY,IAAI,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC;cAM9B,aAAa,IAAI,OAAO,CAAC,YAAY,EAAE,CAAC;cAoBxC,aAAa,CAAC,MAAM,EAAE,MAAM,EAAE,GAAG,OAAO,CAAC,MAAM,EAAE,CAAC;cAexD,UAAU,CAAC,MAAM,EAAE,MAAM,EAAE,GAAG,UAAU,CAAC,OAAO,EAAE,CAAC;cAQ7C,aAAa,CAAC,QAAQ,EAAE,OAAO,EAAE,GAAG,OAAO,CAAC,OAAO,EAAE,CAAC;IAc/E,SAAS,CAAC,WAAW;cAQI,YAAY;CAKtC"}
@@ -1,39 +0,0 @@
1
- import { Promisable, PromisableArray } from '@xylabs/promise';
2
- import { AbstractArchivist } from '@xyo-network/archivist-abstract';
3
- import { ArchivistConfig, ArchivistInstance, ArchivistModuleEventData, ArchivistParams } from '@xyo-network/archivist-model';
4
- import { BoundWitness } from '@xyo-network/boundwitness-model';
5
- import { AnyConfigSchema } from '@xyo-network/module-model';
6
- import { Payload } from '@xyo-network/payload-model';
7
- export type StorageArchivistConfigSchema = 'network.xyo.archivist.storage.config';
8
- export declare const StorageArchivistConfigSchema: StorageArchivistConfigSchema;
9
- export type StorageArchivistConfig = ArchivistConfig<{
10
- maxEntries?: number;
11
- maxEntrySize?: number;
12
- namespace?: string;
13
- persistAccount?: boolean;
14
- schema: StorageArchivistConfigSchema;
15
- type?: 'local' | 'session' | 'page';
16
- }>;
17
- export type StorageArchivistParams = ArchivistParams<AnyConfigSchema<StorageArchivistConfig>>;
18
- export declare class StorageArchivist<TParams extends StorageArchivistParams = StorageArchivistParams, TEventData extends ArchivistModuleEventData = ArchivistModuleEventData> extends AbstractArchivist<TParams, TEventData> implements ArchivistInstance {
19
- static configSchemas: "network.xyo.archivist.storage.config"[];
20
- private _privateStorage;
21
- private _storage;
22
- get maxEntries(): number;
23
- get maxEntrySize(): number;
24
- get namespace(): string;
25
- get persistAccount(): boolean;
26
- get queries(): string[];
27
- get type(): "local" | "session" | "page";
28
- private get privateStorage();
29
- private get storage();
30
- protected allHandler(): PromisableArray<Payload>;
31
- protected clearHandler(): void | Promise<void>;
32
- protected commitHandler(): Promise<BoundWitness[]>;
33
- protected deleteHandler(hashes: string[]): Promise<string[]>;
34
- protected getHandler(hashes: string[]): Promisable<Payload[]>;
35
- protected insertHandler(payloads: Payload[]): Promise<Payload[]>;
36
- protected saveAccount(): void;
37
- protected startHandler(): Promise<boolean>;
38
- }
39
- //# sourceMappingURL=StorageArchivist.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"StorageArchivist.d.ts","sourceRoot":"","sources":["../../src/StorageArchivist.ts"],"names":[],"mappings":"AAEA,OAAO,EAAa,UAAU,EAAE,eAAe,EAAE,MAAM,iBAAiB,CAAA;AACxE,OAAO,EAAE,iBAAiB,EAAE,MAAM,iCAAiC,CAAA;AACnE,OAAO,EAIL,eAAe,EAIf,iBAAiB,EACjB,wBAAwB,EACxB,eAAe,EAChB,MAAM,8BAA8B,CAAA;AACrC,OAAO,EAAE,YAAY,EAAE,MAAM,iCAAiC,CAAA;AAE9D,OAAO,EAAE,eAAe,EAAE,MAAM,2BAA2B,CAAA;AAC3D,OAAO,EAAE,OAAO,EAAE,MAAM,4BAA4B,CAAA;AAIpD,MAAM,MAAM,4BAA4B,GAAG,sCAAsC,CAAA;AACjF,eAAO,MAAM,4BAA4B,EAAE,4BAAqE,CAAA;AAEhH,MAAM,MAAM,sBAAsB,GAAG,eAAe,CAAC;IACnD,UAAU,CAAC,EAAE,MAAM,CAAA;IACnB,YAAY,CAAC,EAAE,MAAM,CAAA;IACrB,SAAS,CAAC,EAAE,MAAM,CAAA;IAClB,cAAc,CAAC,EAAE,OAAO,CAAA;IACxB,MAAM,EAAE,4BAA4B,CAAA;IACpC,IAAI,CAAC,EAAE,OAAO,GAAG,SAAS,GAAG,MAAM,CAAA;CACpC,CAAC,CAAA;AAEF,MAAM,MAAM,sBAAsB,GAAG,eAAe,CAAC,eAAe,CAAC,sBAAsB,CAAC,CAAC,CAAA;AAC7F,qBAAa,gBAAgB,CACzB,OAAO,SAAS,sBAAsB,GAAG,sBAAsB,EAC/D,UAAU,SAAS,wBAAwB,GAAG,wBAAwB,CAExE,SAAQ,iBAAiB,CAAC,OAAO,EAAE,UAAU,CAC7C,YAAW,iBAAiB;IAE5B,OAAgB,aAAa,2CAAiC;IAE9D,OAAO,CAAC,eAAe,CAAuB;IAC9C,OAAO,CAAC,QAAQ,CAAuB;IAEvC,IAAI,UAAU,WAEb;IAED,IAAI,YAAY,WAEf;IAED,IAAI,SAAS,WAEZ;IAED,IAAI,cAAc,YAEjB;IAED,IAAa,OAAO,IAAI,MAAM,EAAE,CAS/B;IAED,IAAI,IAAI,iCAEP;IAGD,OAAO,KAAK,cAAc,GAGzB;IAGD,OAAO,KAAK,OAAO,GAGlB;cAoBkB,UAAU,IAAI,eAAe,CAAC,OAAO,CAAC;cAKtC,YAAY,IAAI,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC;cAM9B,aAAa,IAAI,OAAO,CAAC,YAAY,EAAE,CAAC;cAoBxC,aAAa,CAAC,MAAM,EAAE,MAAM,EAAE,GAAG,OAAO,CAAC,MAAM,EAAE,CAAC;cAexD,UAAU,CAAC,MAAM,EAAE,MAAM,EAAE,GAAG,UAAU,CAAC,OAAO,EAAE,CAAC;cAQ7C,aAAa,CAAC,QAAQ,EAAE,OAAO,EAAE,GAAG,OAAO,CAAC,OAAO,EAAE,CAAC;IAc/E,SAAS,CAAC,WAAW;cAQI,YAAY;CAKtC"}
@@ -1,39 +0,0 @@
1
- import { Promisable, PromisableArray } from '@xylabs/promise';
2
- import { AbstractArchivist } from '@xyo-network/archivist-abstract';
3
- import { ArchivistConfig, ArchivistInstance, ArchivistModuleEventData, ArchivistParams } from '@xyo-network/archivist-model';
4
- import { BoundWitness } from '@xyo-network/boundwitness-model';
5
- import { AnyConfigSchema } from '@xyo-network/module-model';
6
- import { Payload } from '@xyo-network/payload-model';
7
- export type StorageArchivistConfigSchema = 'network.xyo.archivist.storage.config';
8
- export declare const StorageArchivistConfigSchema: StorageArchivistConfigSchema;
9
- export type StorageArchivistConfig = ArchivistConfig<{
10
- maxEntries?: number;
11
- maxEntrySize?: number;
12
- namespace?: string;
13
- persistAccount?: boolean;
14
- schema: StorageArchivistConfigSchema;
15
- type?: 'local' | 'session' | 'page';
16
- }>;
17
- export type StorageArchivistParams = ArchivistParams<AnyConfigSchema<StorageArchivistConfig>>;
18
- export declare class StorageArchivist<TParams extends StorageArchivistParams = StorageArchivistParams, TEventData extends ArchivistModuleEventData = ArchivistModuleEventData> extends AbstractArchivist<TParams, TEventData> implements ArchivistInstance {
19
- static configSchemas: "network.xyo.archivist.storage.config"[];
20
- private _privateStorage;
21
- private _storage;
22
- get maxEntries(): number;
23
- get maxEntrySize(): number;
24
- get namespace(): string;
25
- get persistAccount(): boolean;
26
- get queries(): string[];
27
- get type(): "local" | "session" | "page";
28
- private get privateStorage();
29
- private get storage();
30
- protected allHandler(): PromisableArray<Payload>;
31
- protected clearHandler(): void | Promise<void>;
32
- protected commitHandler(): Promise<BoundWitness[]>;
33
- protected deleteHandler(hashes: string[]): Promise<string[]>;
34
- protected getHandler(hashes: string[]): Promisable<Payload[]>;
35
- protected insertHandler(payloads: Payload[]): Promise<Payload[]>;
36
- protected saveAccount(): void;
37
- protected startHandler(): Promise<boolean>;
38
- }
39
- //# sourceMappingURL=StorageArchivist.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"StorageArchivist.d.ts","sourceRoot":"","sources":["../../src/StorageArchivist.ts"],"names":[],"mappings":"AAEA,OAAO,EAAa,UAAU,EAAE,eAAe,EAAE,MAAM,iBAAiB,CAAA;AACxE,OAAO,EAAE,iBAAiB,EAAE,MAAM,iCAAiC,CAAA;AACnE,OAAO,EAIL,eAAe,EAIf,iBAAiB,EACjB,wBAAwB,EACxB,eAAe,EAChB,MAAM,8BAA8B,CAAA;AACrC,OAAO,EAAE,YAAY,EAAE,MAAM,iCAAiC,CAAA;AAE9D,OAAO,EAAE,eAAe,EAAE,MAAM,2BAA2B,CAAA;AAC3D,OAAO,EAAE,OAAO,EAAE,MAAM,4BAA4B,CAAA;AAIpD,MAAM,MAAM,4BAA4B,GAAG,sCAAsC,CAAA;AACjF,eAAO,MAAM,4BAA4B,EAAE,4BAAqE,CAAA;AAEhH,MAAM,MAAM,sBAAsB,GAAG,eAAe,CAAC;IACnD,UAAU,CAAC,EAAE,MAAM,CAAA;IACnB,YAAY,CAAC,EAAE,MAAM,CAAA;IACrB,SAAS,CAAC,EAAE,MAAM,CAAA;IAClB,cAAc,CAAC,EAAE,OAAO,CAAA;IACxB,MAAM,EAAE,4BAA4B,CAAA;IACpC,IAAI,CAAC,EAAE,OAAO,GAAG,SAAS,GAAG,MAAM,CAAA;CACpC,CAAC,CAAA;AAEF,MAAM,MAAM,sBAAsB,GAAG,eAAe,CAAC,eAAe,CAAC,sBAAsB,CAAC,CAAC,CAAA;AAC7F,qBAAa,gBAAgB,CACzB,OAAO,SAAS,sBAAsB,GAAG,sBAAsB,EAC/D,UAAU,SAAS,wBAAwB,GAAG,wBAAwB,CAExE,SAAQ,iBAAiB,CAAC,OAAO,EAAE,UAAU,CAC7C,YAAW,iBAAiB;IAE5B,OAAgB,aAAa,2CAAiC;IAE9D,OAAO,CAAC,eAAe,CAAuB;IAC9C,OAAO,CAAC,QAAQ,CAAuB;IAEvC,IAAI,UAAU,WAEb;IAED,IAAI,YAAY,WAEf;IAED,IAAI,SAAS,WAEZ;IAED,IAAI,cAAc,YAEjB;IAED,IAAa,OAAO,IAAI,MAAM,EAAE,CAS/B;IAED,IAAI,IAAI,iCAEP;IAGD,OAAO,KAAK,cAAc,GAGzB;IAGD,OAAO,KAAK,OAAO,GAGlB;cAoBkB,UAAU,IAAI,eAAe,CAAC,OAAO,CAAC;cAKtC,YAAY,IAAI,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC;cAM9B,aAAa,IAAI,OAAO,CAAC,YAAY,EAAE,CAAC;cAoBxC,aAAa,CAAC,MAAM,EAAE,MAAM,EAAE,GAAG,OAAO,CAAC,MAAM,EAAE,CAAC;cAexD,UAAU,CAAC,MAAM,EAAE,MAAM,EAAE,GAAG,UAAU,CAAC,OAAO,EAAE,CAAC;cAQ7C,aAAa,CAAC,QAAQ,EAAE,OAAO,EAAE,GAAG,OAAO,CAAC,OAAO,EAAE,CAAC;IAc/E,SAAS,CAAC,WAAW;cAQI,YAAY;CAKtC"}
@@ -1,164 +0,0 @@
1
- import { assertEx } from '@xylabs/assert'
2
- import { compact } from '@xylabs/lodash'
3
- import { fulfilled, Promisable, PromisableArray } from '@xylabs/promise'
4
- import { AbstractArchivist } from '@xyo-network/archivist-abstract'
5
- import {
6
- ArchivistAllQuerySchema,
7
- ArchivistClearQuerySchema,
8
- ArchivistCommitQuerySchema,
9
- ArchivistConfig,
10
- ArchivistDeleteQuerySchema,
11
- ArchivistInsertQuery,
12
- ArchivistInsertQuerySchema,
13
- ArchivistModuleEventData,
14
- ArchivistParams,
15
- } from '@xyo-network/archivist-model'
16
- import { BoundWitness } from '@xyo-network/boundwitness-model'
17
- import { PayloadHasher } from '@xyo-network/hash'
18
- import { AnyConfigSchema } from '@xyo-network/module-model'
19
- import { Payload } from '@xyo-network/payload-model'
20
- import { PayloadWrapper } from '@xyo-network/payload-wrapper'
21
- import Cookies from 'js-cookie'
22
-
23
- export type CookieArchivistConfigSchema = 'network.xyo.archivist.cookie.config'
24
- export const CookieArchivistConfigSchema: CookieArchivistConfigSchema = 'network.xyo.archivist.cookie.config'
25
-
26
- export type CookieArchivistConfig = ArchivistConfig<{
27
- domain?: string
28
- maxEntries?: number
29
- maxEntrySize?: number
30
- namespace?: string
31
- schema: CookieArchivistConfigSchema
32
- }>
33
-
34
- export type CookieArchivistParams = ArchivistParams<AnyConfigSchema<CookieArchivistConfig>>
35
-
36
- export class CookieArchivist<
37
- TParams extends CookieArchivistParams,
38
- TEventData extends ArchivistModuleEventData = ArchivistModuleEventData,
39
- > extends AbstractArchivist<TParams, TEventData> {
40
- static override configSchemas = [CookieArchivistConfigSchema]
41
-
42
- get domain() {
43
- return this.config?.domain
44
- }
45
-
46
- get maxEntries() {
47
- //all browsers support at least 60 cookies
48
- return this.config?.maxEntries ?? 60
49
- }
50
-
51
- get maxEntrySize() {
52
- //all browsers support at least 4000 length per cookie
53
- return this.config?.maxEntrySize ?? 4000
54
- }
55
-
56
- get namespace() {
57
- return this.config?.namespace ?? 'xyoarch'
58
- }
59
-
60
- override get queries(): string[] {
61
- return [
62
- ArchivistAllQuerySchema,
63
- ArchivistDeleteQuerySchema,
64
- ArchivistClearQuerySchema,
65
- ArchivistInsertQuerySchema,
66
- ArchivistCommitQuerySchema,
67
- ...super.queries,
68
- ]
69
- }
70
-
71
- protected override allHandler(): PromisableArray<Payload> {
72
- try {
73
- return Object.entries(Cookies.get())
74
- .filter(([key]) => key.startsWith(`${this.namespace}-`))
75
- .map(([, value]) => JSON.parse(value))
76
- } catch (ex) {
77
- console.error(`Error: ${JSON.stringify(ex, null, 2)}`)
78
- throw ex
79
- }
80
- }
81
-
82
- protected override clearHandler(): void | Promise<void> {
83
- try {
84
- Object.entries(Cookies.get()).map(([key]) => {
85
- if (key.startsWith(`${this.namespace}-`)) {
86
- Cookies.remove(key)
87
- }
88
- })
89
- } catch (ex) {
90
- console.error(`Error: ${JSON.stringify(ex, null, 2)}`)
91
- throw ex
92
- }
93
- }
94
-
95
- protected override async commitHandler(): Promise<BoundWitness[]> {
96
- try {
97
- const payloads = await this.all()
98
- assertEx(payloads.length > 0, 'Nothing to commit')
99
- const settled = await Promise.allSettled(
100
- compact(
101
- Object.values((await this.parents()).commit ?? [])?.map(async (parent) => {
102
- const queryPayload: ArchivistInsertQuery = {
103
- schema: ArchivistInsertQuerySchema,
104
- }
105
- const query = await this.bindQuery(queryPayload, payloads)
106
- return (await parent?.query(query[0], query[1]))?.[0]
107
- }),
108
- ),
109
- )
110
- await this.clear()
111
- return compact(settled.filter(fulfilled).map((result) => result.value))
112
- } catch (ex) {
113
- console.error(`Error: ${JSON.stringify(ex, null, 2)}`)
114
- throw ex
115
- }
116
- }
117
-
118
- protected override async deleteHandler(hashes: string[]): Promise<string[]> {
119
- const payloadPairs: [string, Payload][] = await Promise.all(
120
- (await this.get(hashes)).map<Promise<[string, Payload]>>(async (payload) => [await PayloadHasher.hashAsync(payload), payload]),
121
- )
122
- const deletedPairs: [string, Payload][] = compact(
123
- await Promise.all(
124
- payloadPairs.map<[string, Payload] | undefined>(([hash, payload]) => {
125
- Cookies.remove(hash)
126
- return [hash, payload]
127
- }),
128
- ),
129
- )
130
- return deletedPairs.map(([hash]) => hash)
131
- }
132
-
133
- protected override getHandler(hashes: string[]): Promisable<Payload[]> {
134
- return compact(
135
- hashes.map((hash) => {
136
- const cookieString = Cookies.get(this.keyFromHash(hash))
137
- return cookieString ? JSON.parse(cookieString) : undefined
138
- }),
139
- )
140
- }
141
-
142
- protected override async insertHandler(payloads: Payload[]): Promise<Payload[]> {
143
- try {
144
- const resultPayloads: Payload[] = await Promise.all(
145
- payloads.map(async (payload) => {
146
- const wrapper = PayloadWrapper.wrap(payload)
147
- const key = this.keyFromHash(await wrapper.hashAsync())
148
- const value = JSON.stringify(wrapper.payload())
149
- assertEx(value.length < this.maxEntrySize, `Payload too large [${wrapper.hashAsync()}, ${value.length}]`)
150
- Cookies.set(key, JSON.stringify(wrapper.payload()))
151
- return wrapper.payload()
152
- }),
153
- )
154
- return resultPayloads
155
- } catch (ex) {
156
- console.error(`Error: ${JSON.stringify(ex, null, 2)}`)
157
- throw ex
158
- }
159
- }
160
-
161
- private keyFromHash(hash: string) {
162
- return `${this.namespace}-${hash}`
163
- }
164
- }
@@ -1,191 +0,0 @@
1
- import { assertEx } from '@xylabs/assert'
2
- import { compact } from '@xylabs/lodash'
3
- import { fulfilled, Promisable, PromisableArray } from '@xylabs/promise'
4
- import { AbstractArchivist } from '@xyo-network/archivist-abstract'
5
- import {
6
- ArchivistAllQuerySchema,
7
- ArchivistClearQuerySchema,
8
- ArchivistCommitQuerySchema,
9
- ArchivistConfig,
10
- ArchivistDeleteQuerySchema,
11
- ArchivistInsertQuery,
12
- ArchivistInsertQuerySchema,
13
- ArchivistInstance,
14
- ArchivistModuleEventData,
15
- ArchivistParams,
16
- } from '@xyo-network/archivist-model'
17
- import { BoundWitness } from '@xyo-network/boundwitness-model'
18
- import { PayloadHasher } from '@xyo-network/hash'
19
- import { AnyConfigSchema } from '@xyo-network/module-model'
20
- import { Payload } from '@xyo-network/payload-model'
21
- import { PayloadWrapper } from '@xyo-network/payload-wrapper'
22
- import store, { StoreBase } from 'store2'
23
-
24
- export type StorageArchivistConfigSchema = 'network.xyo.archivist.storage.config'
25
- export const StorageArchivistConfigSchema: StorageArchivistConfigSchema = 'network.xyo.archivist.storage.config'
26
-
27
- export type StorageArchivistConfig = ArchivistConfig<{
28
- maxEntries?: number
29
- maxEntrySize?: number
30
- namespace?: string
31
- persistAccount?: boolean
32
- schema: StorageArchivistConfigSchema
33
- type?: 'local' | 'session' | 'page'
34
- }>
35
-
36
- export type StorageArchivistParams = ArchivistParams<AnyConfigSchema<StorageArchivistConfig>>
37
- export class StorageArchivist<
38
- TParams extends StorageArchivistParams = StorageArchivistParams,
39
- TEventData extends ArchivistModuleEventData = ArchivistModuleEventData,
40
- >
41
- extends AbstractArchivist<TParams, TEventData>
42
- implements ArchivistInstance
43
- {
44
- static override configSchemas = [StorageArchivistConfigSchema]
45
-
46
- private _privateStorage: StoreBase | undefined
47
- private _storage: StoreBase | undefined
48
-
49
- get maxEntries() {
50
- return this.config?.maxEntries ?? 1000
51
- }
52
-
53
- get maxEntrySize() {
54
- return this.config?.maxEntrySize ?? 16_000
55
- }
56
-
57
- get namespace() {
58
- return this.config?.namespace ?? 'xyo-archivist'
59
- }
60
-
61
- get persistAccount() {
62
- return this.config?.persistAccount ?? false
63
- }
64
-
65
- override get queries(): string[] {
66
- return [
67
- ArchivistAllQuerySchema,
68
- ArchivistDeleteQuerySchema,
69
- ArchivistClearQuerySchema,
70
- ArchivistInsertQuerySchema,
71
- ArchivistCommitQuerySchema,
72
- ...super.queries,
73
- ]
74
- }
75
-
76
- get type() {
77
- return this.config?.type ?? 'local'
78
- }
79
-
80
- /* This has to be a getter so that it can access it during construction */
81
- private get privateStorage(): StoreBase {
82
- this._privateStorage = this._storage ?? store[this.type].namespace(`${this.namespace}|private`)
83
- return this._privateStorage
84
- }
85
-
86
- /* This has to be a getter so that it can access it during construction */
87
- private get storage(): StoreBase {
88
- this._storage = this._storage ?? store[this.type].namespace(this.namespace)
89
- return this._storage
90
- }
91
-
92
- /*override async loadAccount(account?: AccountInstance, persistAccount?: boolean, privateStorage?: StoreBase, _logger?: Logger) {
93
- if (!this._account) {
94
- if (persistAccount) {
95
- const privateKey = privateStorage?.get('privateKey')
96
- if (privateKey) {
97
- try {
98
- this._account = await Account.create({ privateKey })
99
- return this._account
100
- } catch (ex) {
101
- console.error(`Error reading Account from storage [${ex}] - Recreating Account`)
102
- privateStorage?.remove('privateKey')
103
- }
104
- }
105
- }
106
- }
107
- return await super.loadAccount()
108
- }*/
109
-
110
- protected override allHandler(): PromisableArray<Payload> {
111
- this.logger?.log(`this.storage.length: ${this.storage.length}`)
112
- return Object.entries(this.storage.getAll()).map(([, value]) => value)
113
- }
114
-
115
- protected override clearHandler(): void | Promise<void> {
116
- this.logger?.log(`this.storage.length: ${this.storage.length}`)
117
- this.storage.clear()
118
- return this.emit('cleared', { module: this })
119
- }
120
-
121
- protected override async commitHandler(): Promise<BoundWitness[]> {
122
- this.logger?.log(`this.storage.length: ${this.storage.length}`)
123
- const payloads = await this.all()
124
- assertEx(payloads.length > 0, 'Nothing to commit')
125
- const settled = await Promise.allSettled(
126
- compact(
127
- Object.values((await this.parents()).commit ?? [])?.map(async (parent) => {
128
- const queryPayload: ArchivistInsertQuery = {
129
- schema: ArchivistInsertQuerySchema,
130
- }
131
- const query = await this.bindQuery(queryPayload, payloads)
132
- return (await parent?.query(query[0], query[1]))?.[0]
133
- }),
134
- ),
135
- )
136
- // TODO - rather than clear, delete the payloads that come back as successfully inserted
137
- await this.clear()
138
- return compact(settled.filter(fulfilled).map((result) => result.value))
139
- }
140
-
141
- protected override async deleteHandler(hashes: string[]): Promise<string[]> {
142
- const payloadPairs: [string, Payload][] = await Promise.all(
143
- (await this.get(hashes)).map<Promise<[string, Payload]>>(async (payload) => [await PayloadHasher.hashAsync(payload), payload]),
144
- )
145
- const deletedPairs: [string, Payload][] = compact(
146
- await Promise.all(
147
- payloadPairs.map<[string, Payload] | undefined>(([hash, payload]) => {
148
- this.storage.remove(hash)
149
- return [hash, payload]
150
- }),
151
- ),
152
- )
153
- return deletedPairs.map(([hash]) => hash)
154
- }
155
-
156
- protected override getHandler(hashes: string[]): Promisable<Payload[]> {
157
- return compact(
158
- hashes.map((hash) => {
159
- return this.storage.get(hash)
160
- }),
161
- )
162
- }
163
-
164
- protected override async insertHandler(payloads: Payload[]): Promise<Payload[]> {
165
- const resultPayloads = await Promise.all(
166
- payloads.map(async (payload) => {
167
- const wrapper = PayloadWrapper.wrap(payload)
168
- const hash = await wrapper.hashAsync()
169
- const value = JSON.stringify(wrapper.payload())
170
- assertEx(value.length < this.maxEntrySize, `Payload too large [${hash}, ${value.length}]`)
171
- this.storage.set(hash, wrapper.payload())
172
- return wrapper.payload()
173
- }),
174
- )
175
- return resultPayloads
176
- }
177
-
178
- protected saveAccount() {
179
- if (this.persistAccount) {
180
- const account = this.account
181
- this.logger?.log(account.address)
182
- this.privateStorage.set('privateKey', account.private.hex)
183
- }
184
- }
185
-
186
- protected override async startHandler() {
187
- await super.startHandler()
188
- this.saveAccount()
189
- return true
190
- }
191
- }
@@ -1,50 +0,0 @@
1
- /**
2
- * @jest-environment jsdom
3
- */
4
-
5
- import { delay } from '@xylabs/delay'
6
- import { Promisable } from '@xylabs/promise'
7
- import { ArchivistInstance } from '@xyo-network/archivist-model'
8
- import { IdSchema } from '@xyo-network/id-payload-plugin'
9
- import { Payload } from '@xyo-network/payload-model'
10
- import { PayloadWrapper } from '@xyo-network/payload-wrapper'
11
-
12
- export const testArchivistRoundTrip = (archivistPromise: Promisable<ArchivistInstance>, name: string) => {
13
- test(`Archivist RoundTrip [${name}]`, async () => {
14
- const idPayload: Payload<{ salt: string }> = {
15
- salt: Date.now().toString(),
16
- schema: IdSchema,
17
- }
18
- const payloadWrapper = PayloadWrapper.wrap(idPayload)
19
-
20
- const archivist = await archivistPromise
21
- const insertResult = await archivist.insert([idPayload])
22
- expect(insertResult).toBeDefined()
23
-
24
- const getResult = await archivist.get([await payloadWrapper.hashAsync()])
25
- expect(getResult).toBeDefined()
26
- expect(getResult.length).toBe(1)
27
- const gottenPayload = getResult[0]
28
- if (gottenPayload) {
29
- const gottenPayloadWrapper = PayloadWrapper.wrap(gottenPayload)
30
- expect(await gottenPayloadWrapper.hashAsync()).toBe(await payloadWrapper.hashAsync())
31
- }
32
- })
33
- }
34
-
35
- export const testArchivistAll = (archivist: Promisable<ArchivistInstance>, name: string) => {
36
- test(`Archivist All [${name}]`, async () => {
37
- const idPayload = {
38
- salt: Date.now().toString(),
39
- schema: IdSchema,
40
- }
41
- const archivistModule = await archivist
42
- for (let x = 0; x < 10; x++) {
43
- await archivistModule.insert([idPayload])
44
- await delay(10)
45
- }
46
- const getResult = await archivistModule.all?.()
47
- expect(getResult).toBeDefined()
48
- expect(getResult?.length).toBe(2)
49
- })
50
- }