@xyo-network/react-sentinel 2.63.1 → 2.64.0-rc.1

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 (93) hide show
  1. package/dist/contexts/Context.d.mts.map +1 -0
  2. package/dist/contexts/Context.d.ts +4 -0
  3. package/dist/contexts/Context.d.ts.map +1 -0
  4. package/dist/contexts/Provider.d.mts.map +1 -0
  5. package/dist/contexts/Provider.d.ts +18 -0
  6. package/dist/contexts/Provider.d.ts.map +1 -0
  7. package/dist/contexts/State.d.mts.map +1 -0
  8. package/dist/contexts/State.d.ts +31 -0
  9. package/dist/contexts/State.d.ts.map +1 -0
  10. package/dist/contexts/index.d.mts.map +1 -0
  11. package/dist/{esm/contexts/index.js → contexts/index.d.ts} +1 -1
  12. package/dist/contexts/index.d.ts.map +1 -0
  13. package/dist/contexts/use.d.mts.map +1 -0
  14. package/dist/contexts/use.d.ts +78 -0
  15. package/dist/contexts/use.d.ts.map +1 -0
  16. package/dist/hooks/index.d.mts.map +1 -0
  17. package/dist/hooks/index.d.ts +2 -0
  18. package/dist/hooks/index.d.ts.map +1 -0
  19. package/dist/hooks/node/index.d.mts.map +1 -0
  20. package/dist/{esm/hooks/node/index.js → hooks/node/index.d.ts} +1 -1
  21. package/dist/hooks/node/index.d.ts.map +1 -0
  22. package/dist/hooks/node/useSentinelFromNode.d.mts.map +1 -0
  23. package/dist/hooks/node/useSentinelFromNode.d.ts +4 -0
  24. package/dist/hooks/node/useSentinelFromNode.d.ts.map +1 -0
  25. package/dist/hooks/node/useSentinelsFromNode.d.mts.map +1 -0
  26. package/dist/hooks/node/useSentinelsFromNode.d.ts +5 -0
  27. package/dist/hooks/node/useSentinelsFromNode.d.ts.map +1 -0
  28. package/dist/index.d.mts.map +1 -0
  29. package/dist/{esm/index.js → index.d.ts} +1 -1
  30. package/dist/index.d.ts.map +1 -0
  31. package/dist/index.js +194 -0
  32. package/dist/index.js.map +1 -0
  33. package/dist/index.mjs +162 -0
  34. package/dist/index.mjs.map +1 -0
  35. package/package.json +36 -27
  36. package/dist/cjs/contexts/Context.js +0 -6
  37. package/dist/cjs/contexts/Context.js.map +0 -1
  38. package/dist/cjs/contexts/Provider.js +0 -95
  39. package/dist/cjs/contexts/Provider.js.map +0 -1
  40. package/dist/cjs/contexts/State.js +0 -12
  41. package/dist/cjs/contexts/State.js.map +0 -1
  42. package/dist/cjs/contexts/index.js +0 -8
  43. package/dist/cjs/contexts/index.js.map +0 -1
  44. package/dist/cjs/contexts/use.js +0 -11
  45. package/dist/cjs/contexts/use.js.map +0 -1
  46. package/dist/cjs/hooks/index.js +0 -5
  47. package/dist/cjs/hooks/index.js.map +0 -1
  48. package/dist/cjs/hooks/node/index.js +0 -6
  49. package/dist/cjs/hooks/node/index.js.map +0 -1
  50. package/dist/cjs/hooks/node/useSentinelFromNode.js +0 -18
  51. package/dist/cjs/hooks/node/useSentinelFromNode.js.map +0 -1
  52. package/dist/cjs/hooks/node/useSentinelsFromNode.js +0 -27
  53. package/dist/cjs/hooks/node/useSentinelsFromNode.js.map +0 -1
  54. package/dist/cjs/index.js +0 -6
  55. package/dist/cjs/index.js.map +0 -1
  56. package/dist/docs.json +0 -2133
  57. package/dist/esm/contexts/Context.js +0 -3
  58. package/dist/esm/contexts/Context.js.map +0 -1
  59. package/dist/esm/contexts/Provider.js +0 -87
  60. package/dist/esm/contexts/Provider.js.map +0 -1
  61. package/dist/esm/contexts/State.js +0 -9
  62. package/dist/esm/contexts/State.js.map +0 -1
  63. package/dist/esm/contexts/index.js.map +0 -1
  64. package/dist/esm/contexts/use.js +0 -7
  65. package/dist/esm/contexts/use.js.map +0 -1
  66. package/dist/esm/hooks/index.js +0 -2
  67. package/dist/esm/hooks/index.js.map +0 -1
  68. package/dist/esm/hooks/node/index.js.map +0 -1
  69. package/dist/esm/hooks/node/useSentinelFromNode.js +0 -13
  70. package/dist/esm/hooks/node/useSentinelFromNode.js.map +0 -1
  71. package/dist/esm/hooks/node/useSentinelsFromNode.js +0 -23
  72. package/dist/esm/hooks/node/useSentinelsFromNode.js.map +0 -1
  73. package/dist/esm/index.js.map +0 -1
  74. package/dist/types/contexts/Context.d.ts.map +0 -1
  75. package/dist/types/contexts/Provider.d.ts.map +0 -1
  76. package/dist/types/contexts/State.d.ts.map +0 -1
  77. package/dist/types/contexts/index.d.ts.map +0 -1
  78. package/dist/types/contexts/use.d.ts.map +0 -1
  79. package/dist/types/hooks/index.d.ts.map +0 -1
  80. package/dist/types/hooks/node/index.d.ts.map +0 -1
  81. package/dist/types/hooks/node/useSentinelFromNode.d.ts.map +0 -1
  82. package/dist/types/hooks/node/useSentinelsFromNode.d.ts.map +0 -1
  83. package/dist/types/index.d.ts.map +0 -1
  84. /package/dist/{types/contexts/Context.d.ts → contexts/Context.d.mts} +0 -0
  85. /package/dist/{types/contexts/Provider.d.ts → contexts/Provider.d.mts} +0 -0
  86. /package/dist/{types/contexts/State.d.ts → contexts/State.d.mts} +0 -0
  87. /package/dist/{types/contexts/index.d.ts → contexts/index.d.mts} +0 -0
  88. /package/dist/{types/contexts/use.d.ts → contexts/use.d.mts} +0 -0
  89. /package/dist/{types/hooks/index.d.ts → hooks/index.d.mts} +0 -0
  90. /package/dist/{types/hooks/node/index.d.ts → hooks/node/index.d.mts} +0 -0
  91. /package/dist/{types/hooks/node/useSentinelFromNode.d.ts → hooks/node/useSentinelFromNode.d.mts} +0 -0
  92. /package/dist/{types/hooks/node/useSentinelsFromNode.d.ts → hooks/node/useSentinelsFromNode.d.mts} +0 -0
  93. /package/dist/{types/index.d.ts → index.d.mts} +0 -0
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Context.d.ts","sourceRoot":"","sources":["../../src/contexts/Context.ts"],"names":[],"mappings":";AAEA,OAAO,EAAE,oBAAoB,EAAE,MAAM,SAAS,CAAA;AAE9C,eAAO,MAAM,eAAe,oGAA0C,CAAA"}
@@ -0,0 +1,4 @@
1
+ /// <reference types="react" />
2
+ import { SentinelContextState } from './State';
3
+ export declare const SentinelContext: import("react").Context<SentinelContextState & import("@xyo-network/react-shared").ContextExState>;
4
+ //# sourceMappingURL=Context.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Context.d.ts","sourceRoot":"","sources":["../../src/contexts/Context.ts"],"names":[],"mappings":";AAEA,OAAO,EAAE,oBAAoB,EAAE,MAAM,SAAS,CAAA;AAE9C,eAAO,MAAM,eAAe,oGAA0C,CAAA"}
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Provider.d.ts","sourceRoot":"","sources":["../../src/contexts/Provider.tsx"],"names":[],"mappings":";AACA,OAAO,EAAE,YAAY,EAAE,MAAM,sBAAsB,CAAA;AACnD,OAAO,EAAE,eAAe,EAAE,MAAM,4BAA4B,CAAA;AAE5D,OAAO,EAAE,YAAY,EAAE,MAAM,qBAAqB,CAAA;AAGlD,OAAO,EAAE,eAAe,EAAE,MAAM,sBAAsB,CAAA;AAMtD,MAAM,WAAW,qBAAqB;IACpC,+CAA+C;IAC/C,OAAO,EAAE,eAAe,CAAA;IACxB,+EAA+E;IAC/E,OAAO,CAAC,EAAE,MAAM,CAAA;IAChB,SAAS,CAAC,EAAE,MAAM,CAAA;IAClB,MAAM,CAAC,EAAE,YAAY,CAAA;IACrB,IAAI,CAAC,EAAE,MAAM,CAAA;IACb,QAAQ,CAAC,EAAE,OAAO,CAAA;IAClB,SAAS,CAAC,EAAE,eAAe,EAAE,CAAA;CAC9B;AAED,eAAO,MAAM,gBAAgB,EAAE,KAAK,CAAC,EAAE,CAAC,YAAY,CAAC,qBAAqB,CAAC,CA6F1E,CAAA"}
@@ -0,0 +1,18 @@
1
+ /// <reference types="react" />
2
+ import { WithChildren } from '@xylabs/react-shared';
3
+ import { AccountInstance } from '@xyo-network/account-model';
4
+ import { ModuleFilter } from '@xyo-network/module';
5
+ import { WitnessInstance } from '@xyo-network/witness';
6
+ export interface SentinelProviderProps {
7
+ /** Account used by the sentinel for signing */
8
+ account: AccountInstance;
9
+ /** @deprecated - sentinel no longer uses archive but relies on an archivist */
10
+ archive?: string;
11
+ archivist?: string;
12
+ filter?: ModuleFilter;
13
+ name?: string;
14
+ required?: boolean;
15
+ witnesses?: WitnessInstance[];
16
+ }
17
+ export declare const SentinelProvider: React.FC<WithChildren<SentinelProviderProps>>;
18
+ //# sourceMappingURL=Provider.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Provider.d.ts","sourceRoot":"","sources":["../../src/contexts/Provider.tsx"],"names":[],"mappings":";AACA,OAAO,EAAE,YAAY,EAAE,MAAM,sBAAsB,CAAA;AACnD,OAAO,EAAE,eAAe,EAAE,MAAM,4BAA4B,CAAA;AAE5D,OAAO,EAAE,YAAY,EAAE,MAAM,qBAAqB,CAAA;AAGlD,OAAO,EAAE,eAAe,EAAE,MAAM,sBAAsB,CAAA;AAMtD,MAAM,WAAW,qBAAqB;IACpC,+CAA+C;IAC/C,OAAO,EAAE,eAAe,CAAA;IACxB,+EAA+E;IAC/E,OAAO,CAAC,EAAE,MAAM,CAAA;IAChB,SAAS,CAAC,EAAE,MAAM,CAAA;IAClB,MAAM,CAAC,EAAE,YAAY,CAAA;IACrB,IAAI,CAAC,EAAE,MAAM,CAAA;IACb,QAAQ,CAAC,EAAE,OAAO,CAAA;IAClB,SAAS,CAAC,EAAE,eAAe,EAAE,CAAA;CAC9B;AAED,eAAO,MAAM,gBAAgB,EAAE,KAAK,CAAC,EAAE,CAAC,YAAY,CAAC,qBAAqB,CAAC,CA6F1E,CAAA"}
@@ -0,0 +1 @@
1
+ {"version":3,"file":"State.d.ts","sourceRoot":"","sources":["../../src/contexts/State.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,MAAM,wBAAwB,CAAA;AACxD,OAAO,EAAE,YAAY,EAAE,MAAM,iCAAiC,CAAA;AAC9D,OAAO,EAAE,cAAc,EAAE,MAAM,uBAAuB,CAAA;AACtD,OAAO,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAA;AAEpD,oBAAY,oBAAoB;IAC9B,IAAI,SAAS;IACb,MAAM,WAAW;IACjB,OAAO,YAAY;IACnB,SAAS,cAAc;IACvB,MAAM,WAAW;CAClB;AAED,MAAM,WAAW,6BAA6B;IAC5C,MAAM,EAAE,oBAAoB,CAAA;IAC5B,OAAO,EAAE,aAAa,CAAA;CACvB;AAED,MAAM,WAAW,kCAAkC;IACjD,SAAS,EAAE,eAAe,CAAA;IAC1B,MAAM,EAAE,oBAAoB,CAAA;CAC7B;AAED,MAAM,WAAW,sBAAsB;IACrC,UAAU,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,kCAAkC,CAAC,CAAA;IAC/D,SAAS,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,6BAA6B,CAAC,CAAA;CAC1D;AAED,MAAM,WAAW,oBAAoB;IACnC,OAAO,CAAC,EAAE,YAAY,EAAE,CAAA;IACxB,QAAQ,CAAC,EAAE,sBAAsB,CAAA;IACjC,eAAe,CAAC,EAAE,KAAK,EAAE,CAAA;IACzB,QAAQ,CAAC,EAAE,cAAc,CAAA;IACzB,MAAM,CAAC,EAAE,oBAAoB,CAAA;CAC9B"}
@@ -0,0 +1,31 @@
1
+ import { ArchivistModule } from '@xyo-network/archivist';
2
+ import { BoundWitness } from '@xyo-network/boundwitness-model';
3
+ import { SentinelModule } from '@xyo-network/sentinel';
4
+ import { WitnessModule } from '@xyo-network/witness';
5
+ export declare enum SentinelReportStatus {
6
+ Idle = "idle",
7
+ Queued = "queued",
8
+ Started = "started",
9
+ Succeeded = "succeeded",
10
+ Failed = "failed"
11
+ }
12
+ export interface SentinelWitnessReportProgress {
13
+ status: SentinelReportStatus;
14
+ witness: WitnessModule;
15
+ }
16
+ export interface SentinelArchivistApiReportProgress {
17
+ archivist: ArchivistModule;
18
+ status: SentinelReportStatus;
19
+ }
20
+ export interface SentinelReportProgress {
21
+ archivists?: Record<string, SentinelArchivistApiReportProgress>;
22
+ witnesses?: Record<string, SentinelWitnessReportProgress>;
23
+ }
24
+ export interface SentinelContextState {
25
+ history?: BoundWitness[];
26
+ progress?: SentinelReportProgress;
27
+ reportingErrors?: Error[];
28
+ sentinel?: SentinelModule;
29
+ status?: SentinelReportStatus;
30
+ }
31
+ //# sourceMappingURL=State.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"State.d.ts","sourceRoot":"","sources":["../../src/contexts/State.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,MAAM,wBAAwB,CAAA;AACxD,OAAO,EAAE,YAAY,EAAE,MAAM,iCAAiC,CAAA;AAC9D,OAAO,EAAE,cAAc,EAAE,MAAM,uBAAuB,CAAA;AACtD,OAAO,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAA;AAEpD,oBAAY,oBAAoB;IAC9B,IAAI,SAAS;IACb,MAAM,WAAW;IACjB,OAAO,YAAY;IACnB,SAAS,cAAc;IACvB,MAAM,WAAW;CAClB;AAED,MAAM,WAAW,6BAA6B;IAC5C,MAAM,EAAE,oBAAoB,CAAA;IAC5B,OAAO,EAAE,aAAa,CAAA;CACvB;AAED,MAAM,WAAW,kCAAkC;IACjD,SAAS,EAAE,eAAe,CAAA;IAC1B,MAAM,EAAE,oBAAoB,CAAA;CAC7B;AAED,MAAM,WAAW,sBAAsB;IACrC,UAAU,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,kCAAkC,CAAC,CAAA;IAC/D,SAAS,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,6BAA6B,CAAC,CAAA;CAC1D;AAED,MAAM,WAAW,oBAAoB;IACnC,OAAO,CAAC,EAAE,YAAY,EAAE,CAAA;IACxB,QAAQ,CAAC,EAAE,sBAAsB,CAAA;IACjC,eAAe,CAAC,EAAE,KAAK,EAAE,CAAA;IACzB,QAAQ,CAAC,EAAE,cAAc,CAAA;IACzB,MAAM,CAAC,EAAE,oBAAoB,CAAA;CAC9B"}
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/contexts/index.ts"],"names":[],"mappings":"AAAA,cAAc,WAAW,CAAA;AACzB,cAAc,YAAY,CAAA;AAC1B,cAAc,SAAS,CAAA;AACvB,cAAc,OAAO,CAAA"}
@@ -2,4 +2,4 @@ export * from './Context';
2
2
  export * from './Provider';
3
3
  export * from './State';
4
4
  export * from './use';
5
- //# sourceMappingURL=index.js.map
5
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/contexts/index.ts"],"names":[],"mappings":"AAAA,cAAc,WAAW,CAAA;AACzB,cAAc,YAAY,CAAA;AAC1B,cAAc,SAAS,CAAA;AACvB,cAAc,OAAO,CAAA"}
@@ -0,0 +1 @@
1
+ {"version":3,"file":"use.d.ts","sourceRoot":"","sources":["../../src/contexts/use.ts"],"names":[],"mappings":"AAIA,eAAO,MAAM,kBAAkB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CAG9B,CAAA"}
@@ -0,0 +1,78 @@
1
+ export declare const useSentinelContext: () => {
2
+ history: (import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & import("@xyo-network/boundwitness-model").BoundWitnessFields & {
3
+ schema: "network.xyo.boundwitness";
4
+ })[] | undefined;
5
+ progress: import("./State").SentinelReportProgress | undefined;
6
+ reportingErrors: Error[] | undefined;
7
+ sentinel: import("@xyo-network/sentinel-model").SentinelModule<import("@xyo-network/core").BaseParamsFields & {
8
+ account?: import("@xyo-network/account-model").AccountInstance | "random" | undefined;
9
+ config: import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & Omit<{
10
+ accountDerivationPath?: string | undefined;
11
+ readonly archivist?: import("@xyo-network/module-model").ArchivistModuleConfig | undefined;
12
+ readonly labels?: import("@xyo-network/module-model").Labels | undefined;
13
+ readonly name?: string | undefined;
14
+ readonly paging?: Record<string, {
15
+ size?: number | undefined;
16
+ }> | undefined;
17
+ readonly security?: {
18
+ readonly allowAnonymous?: boolean | undefined;
19
+ readonly allowed?: Record<string, (string | import("@xyo-network/module-model").CosigningAddressSet)[]> | undefined;
20
+ readonly disallowed?: Record<string, string[]> | undefined;
21
+ } | undefined;
22
+ readonly sign?: boolean | undefined;
23
+ readonly storeQueries?: boolean | undefined;
24
+ readonly timestamp?: boolean | undefined;
25
+ } & Omit<import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & Omit<{
26
+ accountDerivationPath?: string | undefined;
27
+ readonly archivist?: import("@xyo-network/module-model").ArchivistModuleConfig | undefined;
28
+ readonly labels?: import("@xyo-network/module-model").Labels | undefined;
29
+ readonly name?: string | undefined;
30
+ readonly paging?: Record<string, {
31
+ size?: number | undefined;
32
+ }> | undefined;
33
+ readonly security?: {
34
+ readonly allowAnonymous?: boolean | undefined;
35
+ readonly allowed?: Record<string, (string | import("@xyo-network/module-model").CosigningAddressSet)[]> | undefined;
36
+ readonly disallowed?: Record<string, string[]> | undefined;
37
+ } | undefined;
38
+ readonly sign?: boolean | undefined;
39
+ readonly storeQueries?: boolean | undefined;
40
+ readonly timestamp?: boolean | undefined;
41
+ } & import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & Omit<{
42
+ accountDerivationPath?: string | undefined;
43
+ readonly archivist?: import("@xyo-network/module-model").ArchivistModuleConfig | undefined;
44
+ readonly labels?: import("@xyo-network/module-model").Labels | undefined;
45
+ readonly name?: string | undefined;
46
+ readonly paging?: Record<string, {
47
+ size?: number | undefined;
48
+ }> | undefined;
49
+ readonly security?: {
50
+ readonly allowAnonymous?: boolean | undefined;
51
+ readonly allowed?: Record<string, (string | import("@xyo-network/module-model").CosigningAddressSet)[]> | undefined;
52
+ readonly disallowed?: Record<string, string[]> | undefined;
53
+ } | undefined;
54
+ readonly sign?: boolean | undefined;
55
+ readonly storeQueries?: boolean | undefined;
56
+ readonly timestamp?: boolean | undefined;
57
+ } & {
58
+ archivists?: string[] | undefined;
59
+ schema: string;
60
+ } & import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & {
61
+ schema: "network.xyo.module.config";
62
+ }, "schema"> & {
63
+ schema: "network.xyo.module.config";
64
+ } & {
65
+ witnesses?: string[] | undefined;
66
+ }, "schema"> & {
67
+ schema: "network.xyo.sentinel.config";
68
+ }, "schema"> & {
69
+ schema: string;
70
+ }, "schema"> & {
71
+ schema: string;
72
+ };
73
+ ephemeralQueryAccountEnabled?: boolean | undefined;
74
+ wallet?: import("@xyo-network/wallet-model").WalletInstance | undefined;
75
+ }> | undefined;
76
+ status: import("./State").SentinelReportStatus | undefined;
77
+ };
78
+ //# sourceMappingURL=use.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"use.d.ts","sourceRoot":"","sources":["../../src/contexts/use.ts"],"names":[],"mappings":"AAIA,eAAO,MAAM,kBAAkB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CAG9B,CAAA"}
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/hooks/index.ts"],"names":[],"mappings":"AAAA,cAAc,QAAQ,CAAA"}
@@ -0,0 +1,2 @@
1
+ export * from './node';
2
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/hooks/index.ts"],"names":[],"mappings":"AAAA,cAAc,QAAQ,CAAA"}
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/hooks/node/index.ts"],"names":[],"mappings":"AAAA,cAAc,uBAAuB,CAAA;AACrC,cAAc,wBAAwB,CAAA"}
@@ -1,3 +1,3 @@
1
1
  export * from './useSentinelFromNode';
2
2
  export * from './useSentinelsFromNode';
3
- //# sourceMappingURL=index.js.map
3
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/hooks/node/index.ts"],"names":[],"mappings":"AAAA,cAAc,uBAAuB,CAAA;AACrC,cAAc,wBAAwB,CAAA"}
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useSentinelFromNode.d.ts","sourceRoot":"","sources":["../../../src/hooks/node/useSentinelFromNode.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,oBAAoB,EAAqB,MAAM,yBAAyB,CAAA;AACjF,OAAO,EAAsB,gBAAgB,EAAE,MAAM,uBAAuB,CAAA;AAE5E,eAAO,MAAM,mBAAmB,6BACJ,MAAM,GAAG,gBAAgB,WAC1C,oBAAoB,KAC5B,CAAC,gBAAgB,GAAG,SAAS,EAAE,KAAK,GAAG,SAAS,CASlD,CAAA"}
@@ -0,0 +1,4 @@
1
+ import { ModuleFromNodeConfig } from '@xyo-network/react-node';
2
+ import { SentinelInstance } from '@xyo-network/sentinel';
3
+ export declare const useSentinelFromNode: (nameOrAddressOrInstance?: string | SentinelInstance, config?: ModuleFromNodeConfig) => [SentinelInstance | undefined, Error | undefined];
4
+ //# sourceMappingURL=useSentinelFromNode.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useSentinelFromNode.d.ts","sourceRoot":"","sources":["../../../src/hooks/node/useSentinelFromNode.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,oBAAoB,EAAqB,MAAM,yBAAyB,CAAA;AACjF,OAAO,EAAsB,gBAAgB,EAAE,MAAM,uBAAuB,CAAA;AAE5E,eAAO,MAAM,mBAAmB,6BACJ,MAAM,GAAG,gBAAgB,WAC1C,oBAAoB,KAC5B,CAAC,gBAAgB,GAAG,SAAS,EAAE,KAAK,GAAG,SAAS,CASlD,CAAA"}
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useSentinelsFromNode.d.ts","sourceRoot":"","sources":["../../../src/hooks/node/useSentinelsFromNode.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,2BAA2B,CAAA;AACxD,OAAO,EAAE,oBAAoB,EAAsB,MAAM,yBAAyB,CAAA;AAClF,OAAO,EAAsB,gBAAgB,EAAE,MAAM,uBAAuB,CAAA;AAE5E,eAAO,MAAM,oBAAoB,YACtB,YAAY,WACZ,oBAAoB,KAC5B,CAAC,gBAAgB,EAAE,GAAG,IAAI,GAAG,SAAS,EAAE,KAAK,GAAG,SAAS,CAkB3D,CAAA"}
@@ -0,0 +1,5 @@
1
+ import { ModuleFilter } from '@xyo-network/module-model';
2
+ import { ModuleFromNodeConfig } from '@xyo-network/react-node';
3
+ import { SentinelInstance } from '@xyo-network/sentinel';
4
+ export declare const useSentinelsFromNode: (filter?: ModuleFilter, config?: ModuleFromNodeConfig) => [SentinelInstance[] | null | undefined, Error | undefined];
5
+ //# sourceMappingURL=useSentinelsFromNode.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useSentinelsFromNode.d.ts","sourceRoot":"","sources":["../../../src/hooks/node/useSentinelsFromNode.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,2BAA2B,CAAA;AACxD,OAAO,EAAE,oBAAoB,EAAsB,MAAM,yBAAyB,CAAA;AAClF,OAAO,EAAsB,gBAAgB,EAAE,MAAM,uBAAuB,CAAA;AAE5E,eAAO,MAAM,oBAAoB,YACtB,YAAY,WACZ,oBAAoB,KAC5B,CAAC,gBAAgB,EAAE,GAAG,IAAI,GAAG,SAAS,EAAE,KAAK,GAAG,SAAS,CAkB3D,CAAA"}
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,YAAY,CAAA;AAC1B,cAAc,SAAS,CAAA"}
@@ -1,3 +1,3 @@
1
1
  export * from './contexts';
2
2
  export * from './hooks';
3
- //# sourceMappingURL=index.js.map
3
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,YAAY,CAAA;AAC1B,cAAc,SAAS,CAAA"}
package/dist/index.js ADDED
@@ -0,0 +1,194 @@
1
+ "use strict";
2
+ var __defProp = Object.defineProperty;
3
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
+ var __getOwnPropNames = Object.getOwnPropertyNames;
5
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
6
+ var __export = (target, all) => {
7
+ for (var name in all)
8
+ __defProp(target, name, { get: all[name], enumerable: true });
9
+ };
10
+ var __copyProps = (to, from, except, desc) => {
11
+ if (from && typeof from === "object" || typeof from === "function") {
12
+ for (let key of __getOwnPropNames(from))
13
+ if (!__hasOwnProp.call(to, key) && key !== except)
14
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
15
+ }
16
+ return to;
17
+ };
18
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
19
+
20
+ // src/index.ts
21
+ var src_exports = {};
22
+ __export(src_exports, {
23
+ SentinelContext: () => SentinelContext,
24
+ SentinelProvider: () => SentinelProvider,
25
+ SentinelReportStatus: () => SentinelReportStatus,
26
+ useSentinelContext: () => useSentinelContext,
27
+ useSentinelFromNode: () => useSentinelFromNode,
28
+ useSentinelsFromNode: () => useSentinelsFromNode
29
+ });
30
+ module.exports = __toCommonJS(src_exports);
31
+
32
+ // src/contexts/Context.ts
33
+ var import_react_shared = require("@xyo-network/react-shared");
34
+ var SentinelContext = (0, import_react_shared.createContextEx)();
35
+
36
+ // src/contexts/Provider.tsx
37
+ var import_react_async_effect = require("@xylabs/react-async-effect");
38
+ var import_react_witness = require("@xyo-network/react-witness");
39
+ var import_sentinel = require("@xyo-network/sentinel");
40
+ var import_react = require("react");
41
+
42
+ // src/contexts/State.ts
43
+ var SentinelReportStatus = /* @__PURE__ */ ((SentinelReportStatus2) => {
44
+ SentinelReportStatus2["Idle"] = "idle";
45
+ SentinelReportStatus2["Queued"] = "queued";
46
+ SentinelReportStatus2["Started"] = "started";
47
+ SentinelReportStatus2["Succeeded"] = "succeeded";
48
+ SentinelReportStatus2["Failed"] = "failed";
49
+ return SentinelReportStatus2;
50
+ })(SentinelReportStatus || {});
51
+
52
+ // src/contexts/Provider.tsx
53
+ var import_jsx_runtime = require("react/jsx-runtime");
54
+ var SentinelProvider = ({ account, archivist, children, filter, name, required = false }) => {
55
+ const [sentinel, setSentinel] = (0, import_react.useState)();
56
+ const [history, setHistory] = (0, import_react.useState)();
57
+ const [progress, setProgress] = (0, import_react.useState)({});
58
+ const [status, setStatus] = (0, import_react.useState)("idle" /* Idle */);
59
+ const [reportingErrors, setReportingErrors] = (0, import_react.useState)();
60
+ const [witnesses] = (0, import_react_witness.useWitnessesFromNode)(filter);
61
+ (0, import_react_async_effect.useAsyncEffect)(
62
+ // eslint-disable-next-line react-hooks/exhaustive-deps
63
+ async (mounted) => {
64
+ const sentinel2 = await import_sentinel.MemorySentinel.create({
65
+ account,
66
+ config: {
67
+ archivists: archivist ? [archivist] : void 0,
68
+ name,
69
+ schema: import_sentinel.SentinelConfigSchema,
70
+ witnesses: witnesses?.map((module2) => module2.address)
71
+ }
72
+ });
73
+ const offCallbacks = [];
74
+ offCallbacks.push(
75
+ sentinel2.on("reportEnd", ({ module: module2, outPayloads }) => {
76
+ if (mounted()) {
77
+ setProgress({
78
+ archivists: progress.archivists,
79
+ witnesses: progress.witnesses
80
+ });
81
+ setStatus(outPayloads?.length ? "succeeded" /* Succeeded */ : "failed" /* Failed */);
82
+ setReportingErrors([Error(`Witness failed [${module2?.config?.name ?? module2.address}]`)]);
83
+ }
84
+ })
85
+ );
86
+ offCallbacks.push(
87
+ sentinel2.on("reportStart", () => {
88
+ if (mounted()) {
89
+ setProgress({ archivists: {}, witnesses: {} });
90
+ setStatus("started" /* Started */);
91
+ }
92
+ })
93
+ );
94
+ witnesses?.forEach((witness) => {
95
+ offCallbacks.push(
96
+ witness.on("observeEnd", ({ module: module2, outPayloads }) => {
97
+ const witnesses2 = progress.witnesses ?? {};
98
+ witnesses2[witness.address] = {
99
+ status: outPayloads?.length ? "succeeded" /* Succeeded */ : "failed" /* Failed */,
100
+ witness: module2
101
+ };
102
+ if (mounted()) {
103
+ setProgress({
104
+ archivists: progress.archivists,
105
+ witnesses: witnesses2
106
+ });
107
+ }
108
+ })
109
+ );
110
+ offCallbacks.push(
111
+ witness.on("observeStart", ({ module: module2 }) => {
112
+ const witnesses2 = progress.witnesses ?? {};
113
+ witnesses2[witness.address] = {
114
+ status: "started" /* Started */,
115
+ witness: module2
116
+ };
117
+ if (mounted()) {
118
+ setProgress({
119
+ archivists: progress.archivists,
120
+ witnesses: witnesses2
121
+ });
122
+ }
123
+ })
124
+ );
125
+ });
126
+ setSentinel(sentinel2);
127
+ return () => {
128
+ offCallbacks.forEach((callback) => {
129
+ callback();
130
+ });
131
+ };
132
+ },
133
+ // eslint-disable-next-line react-hooks/exhaustive-deps
134
+ [account, archivist, witnesses]
135
+ );
136
+ (0, import_react.useEffect)(() => {
137
+ setHistory(sentinel?.history);
138
+ }, [sentinel]);
139
+ return !required || sentinel ? /* @__PURE__ */ (0, import_jsx_runtime.jsx)(SentinelContext.Provider, { value: { history, progress, provided: true, reportingErrors, sentinel, status }, children }) : null;
140
+ };
141
+
142
+ // src/contexts/use.ts
143
+ var import_react_shared2 = require("@xyo-network/react-shared");
144
+ var useSentinelContext = () => {
145
+ const { sentinel, history, progress, reportingErrors, status } = (0, import_react_shared2.useContextEx)(SentinelContext, "Sentinel");
146
+ return { history, progress, reportingErrors, sentinel, status };
147
+ };
148
+
149
+ // src/hooks/node/useSentinelFromNode.tsx
150
+ var import_react_node = require("@xyo-network/react-node");
151
+ var import_sentinel2 = require("@xyo-network/sentinel");
152
+ var useSentinelFromNode = (nameOrAddressOrInstance, config) => {
153
+ const [module2, error] = (0, import_react_node.useModuleFromNode)(nameOrAddressOrInstance, config);
154
+ const instance = (0, import_sentinel2.asSentinelInstance)(module2);
155
+ if (module2 && !instance) {
156
+ const error2 = Error(`Resolved module is not a SentinelInstance [${module2.config?.schema}:${module2.config?.name}:${module2.address}]`);
157
+ console.error(error2.message);
158
+ return [void 0, error2];
159
+ }
160
+ return [instance, error];
161
+ };
162
+
163
+ // src/hooks/node/useSentinelsFromNode.tsx
164
+ var import_react_node2 = require("@xyo-network/react-node");
165
+ var import_sentinel3 = require("@xyo-network/sentinel");
166
+ var useSentinelsFromNode = (filter, config) => {
167
+ const [modules, error] = (0, import_react_node2.useModulesFromNode)(filter, config);
168
+ if (error) {
169
+ return [null, error];
170
+ }
171
+ if (modules) {
172
+ return [
173
+ modules.reduce((prev, module2) => {
174
+ if ((0, import_sentinel3.isSentinelInstance)(module2)) {
175
+ prev.push(module2);
176
+ }
177
+ return prev;
178
+ }, []),
179
+ void 0
180
+ ];
181
+ } else {
182
+ return [modules, error];
183
+ }
184
+ };
185
+ // Annotate the CommonJS export names for ESM import in node:
186
+ 0 && (module.exports = {
187
+ SentinelContext,
188
+ SentinelProvider,
189
+ SentinelReportStatus,
190
+ useSentinelContext,
191
+ useSentinelFromNode,
192
+ useSentinelsFromNode
193
+ });
194
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/index.ts","../src/contexts/Context.ts","../src/contexts/Provider.tsx","../src/contexts/State.ts","../src/contexts/use.ts","../src/hooks/node/useSentinelFromNode.tsx","../src/hooks/node/useSentinelsFromNode.tsx"],"sourcesContent":["export * from './contexts'\nexport * from './hooks'\n","import { createContextEx } from '@xyo-network/react-shared'\n\nimport { SentinelContextState } from './State'\n\nexport const SentinelContext = createContextEx<SentinelContextState>()\n","import { useAsyncEffect } from '@xylabs/react-async-effect'\nimport { WithChildren } from '@xylabs/react-shared'\nimport { AccountInstance } from '@xyo-network/account-model'\nimport { BoundWitness } from '@xyo-network/boundwitness-model'\nimport { ModuleFilter } from '@xyo-network/module'\nimport { useWitnessesFromNode } from '@xyo-network/react-witness'\nimport { MemorySentinel, SentinelConfig, SentinelConfigSchema } from '@xyo-network/sentinel'\nimport { WitnessInstance } from '@xyo-network/witness'\nimport { useEffect, useState } from 'react'\n\nimport { SentinelContext } from './Context'\nimport { SentinelReportProgress, SentinelReportStatus } from './State'\n\nexport interface SentinelProviderProps {\n /** Account used by the sentinel for signing */\n account: AccountInstance\n /** @deprecated - sentinel no longer uses archive but relies on an archivist */\n archive?: string\n archivist?: string\n filter?: ModuleFilter\n name?: string\n required?: boolean\n witnesses?: WitnessInstance[]\n}\n\nexport const SentinelProvider: React.FC<WithChildren<SentinelProviderProps>> = ({ account, archivist, children, filter, name, required = false }) => {\n const [sentinel, setSentinel] = useState<MemorySentinel>()\n const [history, setHistory] = useState<BoundWitness[]>()\n const [progress, setProgress] = useState<SentinelReportProgress>({})\n const [status, setStatus] = useState(SentinelReportStatus.Idle)\n const [reportingErrors, setReportingErrors] = useState<Error[]>()\n const [witnesses] = useWitnessesFromNode(filter)\n\n useAsyncEffect(\n // eslint-disable-next-line react-hooks/exhaustive-deps\n async (mounted) => {\n const sentinel = await MemorySentinel.create({\n account,\n config: {\n archivists: archivist ? [archivist] : undefined,\n name,\n\n schema: SentinelConfigSchema,\n witnesses: witnesses?.map((module) => module.address),\n } as SentinelConfig,\n })\n const offCallbacks: (() => void)[] = []\n offCallbacks.push(\n sentinel.on('reportEnd', ({ module, outPayloads }) => {\n if (mounted()) {\n setProgress({\n archivists: progress.archivists,\n witnesses: progress.witnesses,\n })\n setStatus(outPayloads?.length ? SentinelReportStatus.Succeeded : SentinelReportStatus.Failed)\n setReportingErrors([Error(`Witness failed [${module?.config?.name ?? module.address}]`)])\n }\n }),\n )\n offCallbacks.push(\n sentinel.on('reportStart', () => {\n if (mounted()) {\n setProgress({ archivists: {}, witnesses: {} })\n setStatus(SentinelReportStatus.Started)\n }\n }),\n )\n witnesses?.forEach((witness) => {\n offCallbacks.push(\n witness.on('observeEnd', ({ module, outPayloads }) => {\n const witnesses = progress.witnesses ?? {}\n witnesses[witness.address] = {\n status: outPayloads?.length ? SentinelReportStatus.Succeeded : SentinelReportStatus.Failed,\n witness: module,\n }\n if (mounted()) {\n setProgress({\n archivists: progress.archivists,\n witnesses,\n })\n }\n }),\n )\n offCallbacks.push(\n witness.on('observeStart', ({ module }) => {\n const witnesses = progress.witnesses ?? {}\n witnesses[witness.address] = {\n status: SentinelReportStatus.Started,\n witness: module,\n }\n if (mounted()) {\n setProgress({\n archivists: progress.archivists,\n witnesses,\n })\n }\n }),\n )\n })\n setSentinel(sentinel as MemorySentinel)\n return () => {\n //unsubscribe from events\n offCallbacks.forEach((callback) => {\n callback()\n })\n }\n },\n // eslint-disable-next-line react-hooks/exhaustive-deps\n [account, archivist, witnesses],\n )\n\n useEffect(() => {\n setHistory(sentinel?.history as BoundWitness[])\n }, [sentinel])\n\n return !required || sentinel ? (\n <SentinelContext.Provider value={{ history, progress, provided: true, reportingErrors, sentinel, status }}>{children}</SentinelContext.Provider>\n ) : null\n}\n","import { ArchivistModule } from '@xyo-network/archivist'\nimport { BoundWitness } from '@xyo-network/boundwitness-model'\nimport { SentinelModule } from '@xyo-network/sentinel'\nimport { WitnessModule } from '@xyo-network/witness'\n\nexport enum SentinelReportStatus {\n Idle = 'idle',\n Queued = 'queued',\n Started = 'started',\n Succeeded = 'succeeded',\n Failed = 'failed',\n}\n\nexport interface SentinelWitnessReportProgress {\n status: SentinelReportStatus\n witness: WitnessModule\n}\n\nexport interface SentinelArchivistApiReportProgress {\n archivist: ArchivistModule\n status: SentinelReportStatus\n}\n\nexport interface SentinelReportProgress {\n archivists?: Record<string, SentinelArchivistApiReportProgress>\n witnesses?: Record<string, SentinelWitnessReportProgress>\n}\n\nexport interface SentinelContextState {\n history?: BoundWitness[]\n progress?: SentinelReportProgress\n reportingErrors?: Error[]\n sentinel?: SentinelModule\n status?: SentinelReportStatus\n}\n","import { useContextEx } from '@xyo-network/react-shared'\n\nimport { SentinelContext } from './Context'\n\nexport const useSentinelContext = () => {\n const { sentinel, history, progress, reportingErrors, status } = useContextEx(SentinelContext, 'Sentinel')\n return { history, progress, reportingErrors, sentinel, status }\n}\n","import { ModuleFromNodeConfig, useModuleFromNode } from '@xyo-network/react-node'\nimport { asSentinelInstance, SentinelInstance } from '@xyo-network/sentinel'\n\nexport const useSentinelFromNode = (\n nameOrAddressOrInstance?: string | SentinelInstance,\n config?: ModuleFromNodeConfig,\n): [SentinelInstance | undefined, Error | undefined] => {\n const [module, error] = useModuleFromNode(nameOrAddressOrInstance, config)\n const instance = asSentinelInstance(module)\n if (module && !instance) {\n const error = Error(`Resolved module is not a SentinelInstance [${module.config?.schema}:${module.config?.name}:${module.address}]`)\n console.error(error.message)\n return [undefined, error]\n }\n return [instance, error]\n}\n","import { ModuleFilter } from '@xyo-network/module-model'\nimport { ModuleFromNodeConfig, useModulesFromNode } from '@xyo-network/react-node'\nimport { isSentinelInstance, SentinelInstance } from '@xyo-network/sentinel'\n\nexport const useSentinelsFromNode = (\n filter?: ModuleFilter,\n config?: ModuleFromNodeConfig,\n): [SentinelInstance[] | null | undefined, Error | undefined] => {\n const [modules, error] = useModulesFromNode(filter, config)\n if (error) {\n return [null, error]\n }\n if (modules) {\n return [\n modules.reduce<SentinelInstance[]>((prev, module) => {\n if (isSentinelInstance(module)) {\n prev.push(module)\n }\n return prev\n }, []),\n undefined,\n ]\n } else {\n return [modules, error]\n }\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;;;ACAA,0BAAgC;AAIzB,IAAM,sBAAkB,qCAAsC;;;ACJrE,gCAA+B;AAK/B,2BAAqC;AACrC,sBAAqE;AAErE,mBAAoC;;;ACH7B,IAAK,uBAAL,kBAAKA,0BAAL;AACL,EAAAA,sBAAA,UAAO;AACP,EAAAA,sBAAA,YAAS;AACT,EAAAA,sBAAA,aAAU;AACV,EAAAA,sBAAA,eAAY;AACZ,EAAAA,sBAAA,YAAS;AALC,SAAAA;AAAA,GAAA;;;AD+GR;AA3FG,IAAM,mBAAkE,CAAC,EAAE,SAAS,WAAW,UAAU,QAAQ,MAAM,WAAW,MAAM,MAAM;AACnJ,QAAM,CAAC,UAAU,WAAW,QAAI,uBAAyB;AACzD,QAAM,CAAC,SAAS,UAAU,QAAI,uBAAyB;AACvD,QAAM,CAAC,UAAU,WAAW,QAAI,uBAAiC,CAAC,CAAC;AACnE,QAAM,CAAC,QAAQ,SAAS,QAAI,wCAAkC;AAC9D,QAAM,CAAC,iBAAiB,kBAAkB,QAAI,uBAAkB;AAChE,QAAM,CAAC,SAAS,QAAI,2CAAqB,MAAM;AAE/C;AAAA;AAAA,IAEE,OAAO,YAAY;AACjB,YAAMC,YAAW,MAAM,+BAAe,OAAO;AAAA,QAC3C;AAAA,QACA,QAAQ;AAAA,UACN,YAAY,YAAY,CAAC,SAAS,IAAI;AAAA,UACtC;AAAA,UAEA,QAAQ;AAAA,UACR,WAAW,WAAW,IAAI,CAACC,YAAWA,QAAO,OAAO;AAAA,QACtD;AAAA,MACF,CAAC;AACD,YAAM,eAA+B,CAAC;AACtC,mBAAa;AAAA,QACXD,UAAS,GAAG,aAAa,CAAC,EAAE,QAAAC,SAAQ,YAAY,MAAM;AACpD,cAAI,QAAQ,GAAG;AACb,wBAAY;AAAA,cACV,YAAY,SAAS;AAAA,cACrB,WAAW,SAAS;AAAA,YACtB,CAAC;AACD,sBAAU,aAAa,4DAAqE;AAC5F,+BAAmB,CAAC,MAAM,mBAAmBA,SAAQ,QAAQ,QAAQA,QAAO,OAAO,GAAG,CAAC,CAAC;AAAA,UAC1F;AAAA,QACF,CAAC;AAAA,MACH;AACA,mBAAa;AAAA,QACXD,UAAS,GAAG,eAAe,MAAM;AAC/B,cAAI,QAAQ,GAAG;AACb,wBAAY,EAAE,YAAY,CAAC,GAAG,WAAW,CAAC,EAAE,CAAC;AAC7C,6CAAsC;AAAA,UACxC;AAAA,QACF,CAAC;AAAA,MACH;AACA,iBAAW,QAAQ,CAAC,YAAY;AAC9B,qBAAa;AAAA,UACX,QAAQ,GAAG,cAAc,CAAC,EAAE,QAAAC,SAAQ,YAAY,MAAM;AACpD,kBAAMC,aAAY,SAAS,aAAa,CAAC;AACzC,YAAAA,WAAU,QAAQ,OAAO,IAAI;AAAA,cAC3B,QAAQ,aAAa;AAAA,cACrB,SAASD;AAAA,YACX;AACA,gBAAI,QAAQ,GAAG;AACb,0BAAY;AAAA,gBACV,YAAY,SAAS;AAAA,gBACrB,WAAAC;AAAA,cACF,CAAC;AAAA,YACH;AAAA,UACF,CAAC;AAAA,QACH;AACA,qBAAa;AAAA,UACX,QAAQ,GAAG,gBAAgB,CAAC,EAAE,QAAAD,QAAO,MAAM;AACzC,kBAAMC,aAAY,SAAS,aAAa,CAAC;AACzC,YAAAA,WAAU,QAAQ,OAAO,IAAI;AAAA,cAC3B;AAAA,cACA,SAASD;AAAA,YACX;AACA,gBAAI,QAAQ,GAAG;AACb,0BAAY;AAAA,gBACV,YAAY,SAAS;AAAA,gBACrB,WAAAC;AAAA,cACF,CAAC;AAAA,YACH;AAAA,UACF,CAAC;AAAA,QACH;AAAA,MACF,CAAC;AACD,kBAAYF,SAA0B;AACtC,aAAO,MAAM;AAEX,qBAAa,QAAQ,CAAC,aAAa;AACjC,mBAAS;AAAA,QACX,CAAC;AAAA,MACH;AAAA,IACF;AAAA;AAAA,IAEA,CAAC,SAAS,WAAW,SAAS;AAAA,EAChC;AAEA,8BAAU,MAAM;AACd,eAAW,UAAU,OAAyB;AAAA,EAChD,GAAG,CAAC,QAAQ,CAAC;AAEb,SAAO,CAAC,YAAY,WAClB,4CAAC,gBAAgB,UAAhB,EAAyB,OAAO,EAAE,SAAS,UAAU,UAAU,MAAM,iBAAiB,UAAU,OAAO,GAAI,UAAS,IACnH;AACN;;;AEtHA,IAAAG,uBAA6B;AAItB,IAAM,qBAAqB,MAAM;AACtC,QAAM,EAAE,UAAU,SAAS,UAAU,iBAAiB,OAAO,QAAI,mCAAa,iBAAiB,UAAU;AACzG,SAAO,EAAE,SAAS,UAAU,iBAAiB,UAAU,OAAO;AAChE;;;ACPA,wBAAwD;AACxD,IAAAC,mBAAqD;AAE9C,IAAM,sBAAsB,CACjC,yBACA,WACsD;AACtD,QAAM,CAACC,SAAQ,KAAK,QAAI,qCAAkB,yBAAyB,MAAM;AACzE,QAAM,eAAW,qCAAmBA,OAAM;AAC1C,MAAIA,WAAU,CAAC,UAAU;AACvB,UAAMC,SAAQ,MAAM,8CAA8CD,QAAO,QAAQ,MAAM,IAAIA,QAAO,QAAQ,IAAI,IAAIA,QAAO,OAAO,GAAG;AACnI,YAAQ,MAAMC,OAAM,OAAO;AAC3B,WAAO,CAAC,QAAWA,MAAK;AAAA,EAC1B;AACA,SAAO,CAAC,UAAU,KAAK;AACzB;;;ACdA,IAAAC,qBAAyD;AACzD,IAAAC,mBAAqD;AAE9C,IAAM,uBAAuB,CAClC,QACA,WAC+D;AAC/D,QAAM,CAAC,SAAS,KAAK,QAAI,uCAAmB,QAAQ,MAAM;AAC1D,MAAI,OAAO;AACT,WAAO,CAAC,MAAM,KAAK;AAAA,EACrB;AACA,MAAI,SAAS;AACX,WAAO;AAAA,MACL,QAAQ,OAA2B,CAAC,MAAMC,YAAW;AACnD,gBAAI,qCAAmBA,OAAM,GAAG;AAC9B,eAAK,KAAKA,OAAM;AAAA,QAClB;AACA,eAAO;AAAA,MACT,GAAG,CAAC,CAAC;AAAA,MACL;AAAA,IACF;AAAA,EACF,OAAO;AACL,WAAO,CAAC,SAAS,KAAK;AAAA,EACxB;AACF;","names":["SentinelReportStatus","sentinel","module","witnesses","import_react_shared","import_sentinel","module","error","import_react_node","import_sentinel","module"]}
package/dist/index.mjs ADDED
@@ -0,0 +1,162 @@
1
+ // src/contexts/Context.ts
2
+ import { createContextEx } from "@xyo-network/react-shared";
3
+ var SentinelContext = createContextEx();
4
+
5
+ // src/contexts/Provider.tsx
6
+ import { useAsyncEffect } from "@xylabs/react-async-effect";
7
+ import { useWitnessesFromNode } from "@xyo-network/react-witness";
8
+ import { MemorySentinel, SentinelConfigSchema } from "@xyo-network/sentinel";
9
+ import { useEffect, useState } from "react";
10
+
11
+ // src/contexts/State.ts
12
+ var SentinelReportStatus = /* @__PURE__ */ ((SentinelReportStatus2) => {
13
+ SentinelReportStatus2["Idle"] = "idle";
14
+ SentinelReportStatus2["Queued"] = "queued";
15
+ SentinelReportStatus2["Started"] = "started";
16
+ SentinelReportStatus2["Succeeded"] = "succeeded";
17
+ SentinelReportStatus2["Failed"] = "failed";
18
+ return SentinelReportStatus2;
19
+ })(SentinelReportStatus || {});
20
+
21
+ // src/contexts/Provider.tsx
22
+ import { jsx } from "react/jsx-runtime";
23
+ var SentinelProvider = ({ account, archivist, children, filter, name, required = false }) => {
24
+ const [sentinel, setSentinel] = useState();
25
+ const [history, setHistory] = useState();
26
+ const [progress, setProgress] = useState({});
27
+ const [status, setStatus] = useState("idle" /* Idle */);
28
+ const [reportingErrors, setReportingErrors] = useState();
29
+ const [witnesses] = useWitnessesFromNode(filter);
30
+ useAsyncEffect(
31
+ // eslint-disable-next-line react-hooks/exhaustive-deps
32
+ async (mounted) => {
33
+ const sentinel2 = await MemorySentinel.create({
34
+ account,
35
+ config: {
36
+ archivists: archivist ? [archivist] : void 0,
37
+ name,
38
+ schema: SentinelConfigSchema,
39
+ witnesses: witnesses?.map((module) => module.address)
40
+ }
41
+ });
42
+ const offCallbacks = [];
43
+ offCallbacks.push(
44
+ sentinel2.on("reportEnd", ({ module, outPayloads }) => {
45
+ if (mounted()) {
46
+ setProgress({
47
+ archivists: progress.archivists,
48
+ witnesses: progress.witnesses
49
+ });
50
+ setStatus(outPayloads?.length ? "succeeded" /* Succeeded */ : "failed" /* Failed */);
51
+ setReportingErrors([Error(`Witness failed [${module?.config?.name ?? module.address}]`)]);
52
+ }
53
+ })
54
+ );
55
+ offCallbacks.push(
56
+ sentinel2.on("reportStart", () => {
57
+ if (mounted()) {
58
+ setProgress({ archivists: {}, witnesses: {} });
59
+ setStatus("started" /* Started */);
60
+ }
61
+ })
62
+ );
63
+ witnesses?.forEach((witness) => {
64
+ offCallbacks.push(
65
+ witness.on("observeEnd", ({ module, outPayloads }) => {
66
+ const witnesses2 = progress.witnesses ?? {};
67
+ witnesses2[witness.address] = {
68
+ status: outPayloads?.length ? "succeeded" /* Succeeded */ : "failed" /* Failed */,
69
+ witness: module
70
+ };
71
+ if (mounted()) {
72
+ setProgress({
73
+ archivists: progress.archivists,
74
+ witnesses: witnesses2
75
+ });
76
+ }
77
+ })
78
+ );
79
+ offCallbacks.push(
80
+ witness.on("observeStart", ({ module }) => {
81
+ const witnesses2 = progress.witnesses ?? {};
82
+ witnesses2[witness.address] = {
83
+ status: "started" /* Started */,
84
+ witness: module
85
+ };
86
+ if (mounted()) {
87
+ setProgress({
88
+ archivists: progress.archivists,
89
+ witnesses: witnesses2
90
+ });
91
+ }
92
+ })
93
+ );
94
+ });
95
+ setSentinel(sentinel2);
96
+ return () => {
97
+ offCallbacks.forEach((callback) => {
98
+ callback();
99
+ });
100
+ };
101
+ },
102
+ // eslint-disable-next-line react-hooks/exhaustive-deps
103
+ [account, archivist, witnesses]
104
+ );
105
+ useEffect(() => {
106
+ setHistory(sentinel?.history);
107
+ }, [sentinel]);
108
+ return !required || sentinel ? /* @__PURE__ */ jsx(SentinelContext.Provider, { value: { history, progress, provided: true, reportingErrors, sentinel, status }, children }) : null;
109
+ };
110
+
111
+ // src/contexts/use.ts
112
+ import { useContextEx } from "@xyo-network/react-shared";
113
+ var useSentinelContext = () => {
114
+ const { sentinel, history, progress, reportingErrors, status } = useContextEx(SentinelContext, "Sentinel");
115
+ return { history, progress, reportingErrors, sentinel, status };
116
+ };
117
+
118
+ // src/hooks/node/useSentinelFromNode.tsx
119
+ import { useModuleFromNode } from "@xyo-network/react-node";
120
+ import { asSentinelInstance } from "@xyo-network/sentinel";
121
+ var useSentinelFromNode = (nameOrAddressOrInstance, config) => {
122
+ const [module, error] = useModuleFromNode(nameOrAddressOrInstance, config);
123
+ const instance = asSentinelInstance(module);
124
+ if (module && !instance) {
125
+ const error2 = Error(`Resolved module is not a SentinelInstance [${module.config?.schema}:${module.config?.name}:${module.address}]`);
126
+ console.error(error2.message);
127
+ return [void 0, error2];
128
+ }
129
+ return [instance, error];
130
+ };
131
+
132
+ // src/hooks/node/useSentinelsFromNode.tsx
133
+ import { useModulesFromNode } from "@xyo-network/react-node";
134
+ import { isSentinelInstance } from "@xyo-network/sentinel";
135
+ var useSentinelsFromNode = (filter, config) => {
136
+ const [modules, error] = useModulesFromNode(filter, config);
137
+ if (error) {
138
+ return [null, error];
139
+ }
140
+ if (modules) {
141
+ return [
142
+ modules.reduce((prev, module) => {
143
+ if (isSentinelInstance(module)) {
144
+ prev.push(module);
145
+ }
146
+ return prev;
147
+ }, []),
148
+ void 0
149
+ ];
150
+ } else {
151
+ return [modules, error];
152
+ }
153
+ };
154
+ export {
155
+ SentinelContext,
156
+ SentinelProvider,
157
+ SentinelReportStatus,
158
+ useSentinelContext,
159
+ useSentinelFromNode,
160
+ useSentinelsFromNode
161
+ };
162
+ //# sourceMappingURL=index.mjs.map