@powerhousedao/reactor 4.1.0-dev.8 → 4.1.0-dev.80

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 (198) hide show
  1. package/dist/src/client/reactor-client.d.ts +103 -0
  2. package/dist/src/client/reactor-client.d.ts.map +1 -0
  3. package/dist/src/client/reactor-client.js +184 -0
  4. package/dist/src/client/reactor-client.js.map +1 -0
  5. package/dist/src/client/types.d.ts +213 -0
  6. package/dist/src/client/types.d.ts.map +1 -0
  7. package/dist/src/client/types.js +14 -0
  8. package/dist/src/client/types.js.map +1 -0
  9. package/dist/src/core/builder.d.ts +20 -0
  10. package/dist/src/core/builder.d.ts.map +1 -0
  11. package/dist/src/core/builder.js +47 -0
  12. package/dist/src/core/builder.js.map +1 -0
  13. package/dist/src/core/reactor.d.ts +92 -0
  14. package/dist/src/core/reactor.d.ts.map +1 -0
  15. package/dist/src/core/reactor.js +647 -0
  16. package/dist/src/core/reactor.js.map +1 -0
  17. package/dist/src/core/types.d.ts +121 -0
  18. package/dist/src/core/types.d.ts.map +1 -0
  19. package/dist/src/core/types.js +2 -0
  20. package/dist/src/core/types.js.map +1 -0
  21. package/dist/src/core/utils.d.ts +11 -0
  22. package/dist/src/core/utils.d.ts.map +1 -0
  23. package/dist/src/core/utils.js +31 -0
  24. package/dist/src/core/utils.js.map +1 -0
  25. package/dist/src/events/event-bus.d.ts +3 -3
  26. package/dist/src/events/event-bus.d.ts.map +1 -1
  27. package/dist/src/events/event-bus.js.map +1 -1
  28. package/dist/src/events/interfaces.d.ts +1 -1
  29. package/dist/src/events/interfaces.d.ts.map +1 -1
  30. package/dist/src/events/types.d.ts +15 -1
  31. package/dist/src/events/types.d.ts.map +1 -1
  32. package/dist/src/events/types.js +6 -0
  33. package/dist/src/events/types.js.map +1 -1
  34. package/dist/src/executor/interfaces.d.ts +31 -54
  35. package/dist/src/executor/interfaces.d.ts.map +1 -1
  36. package/dist/src/executor/simple-job-executor-manager.d.ts +30 -0
  37. package/dist/src/executor/simple-job-executor-manager.d.ts.map +1 -0
  38. package/dist/src/executor/simple-job-executor-manager.js +178 -0
  39. package/dist/src/executor/simple-job-executor-manager.js.map +1 -0
  40. package/dist/src/executor/simple-job-executor.d.ts +60 -0
  41. package/dist/src/executor/simple-job-executor.d.ts.map +1 -0
  42. package/dist/src/executor/simple-job-executor.js +537 -0
  43. package/dist/src/executor/simple-job-executor.js.map +1 -0
  44. package/dist/src/executor/types.d.ts +24 -8
  45. package/dist/src/executor/types.d.ts.map +1 -1
  46. package/dist/src/executor/types.js.map +1 -1
  47. package/dist/src/index.d.ts +26 -3
  48. package/dist/src/index.d.ts.map +1 -1
  49. package/dist/src/index.js +33 -2
  50. package/dist/src/index.js.map +1 -1
  51. package/dist/src/job-tracker/in-memory-job-tracker.d.ts +15 -0
  52. package/dist/src/job-tracker/in-memory-job-tracker.d.ts.map +1 -0
  53. package/dist/src/job-tracker/in-memory-job-tracker.js +78 -0
  54. package/dist/src/job-tracker/in-memory-job-tracker.js.map +1 -0
  55. package/dist/src/job-tracker/index.d.ts +3 -0
  56. package/dist/src/job-tracker/index.d.ts.map +1 -0
  57. package/dist/src/job-tracker/index.js +2 -0
  58. package/dist/src/job-tracker/index.js.map +1 -0
  59. package/dist/src/job-tracker/interfaces.d.ts +41 -0
  60. package/dist/src/job-tracker/interfaces.d.ts.map +1 -0
  61. package/dist/src/job-tracker/interfaces.js +2 -0
  62. package/dist/src/job-tracker/interfaces.js.map +1 -0
  63. package/dist/src/queue/interfaces.d.ts +45 -5
  64. package/dist/src/queue/interfaces.d.ts.map +1 -1
  65. package/dist/src/queue/job-execution-handle.d.ts +24 -0
  66. package/dist/src/queue/job-execution-handle.d.ts.map +1 -0
  67. package/dist/src/queue/job-execution-handle.js +62 -0
  68. package/dist/src/queue/job-execution-handle.js.map +1 -0
  69. package/dist/src/queue/queue.d.ts +54 -5
  70. package/dist/src/queue/queue.d.ts.map +1 -1
  71. package/dist/src/queue/queue.js +265 -36
  72. package/dist/src/queue/queue.js.map +1 -1
  73. package/dist/src/queue/types.d.ts +30 -5
  74. package/dist/src/queue/types.d.ts.map +1 -1
  75. package/dist/src/queue/types.js +12 -0
  76. package/dist/src/queue/types.js.map +1 -1
  77. package/dist/src/read-models/coordinator.d.ts +38 -0
  78. package/dist/src/read-models/coordinator.d.ts.map +1 -0
  79. package/dist/src/read-models/coordinator.js +62 -0
  80. package/dist/src/read-models/coordinator.js.map +1 -0
  81. package/dist/src/read-models/document-view.d.ts +20 -0
  82. package/dist/src/read-models/document-view.d.ts.map +1 -0
  83. package/dist/src/read-models/document-view.js +363 -0
  84. package/dist/src/read-models/document-view.js.map +1 -0
  85. package/dist/src/read-models/interfaces.d.ts +29 -0
  86. package/dist/src/read-models/interfaces.d.ts.map +1 -0
  87. package/dist/src/read-models/interfaces.js +2 -0
  88. package/dist/src/read-models/interfaces.js.map +1 -0
  89. package/dist/src/read-models/types.d.ts +46 -0
  90. package/dist/src/read-models/types.d.ts.map +1 -0
  91. package/dist/src/read-models/types.js +2 -0
  92. package/dist/src/read-models/types.js.map +1 -0
  93. package/dist/src/registry/implementation.d.ts +62 -0
  94. package/dist/src/registry/implementation.d.ts.map +1 -0
  95. package/dist/src/registry/implementation.js +96 -0
  96. package/dist/src/registry/implementation.js.map +1 -0
  97. package/dist/src/registry/index.d.ts +3 -0
  98. package/dist/src/registry/index.d.ts.map +1 -0
  99. package/dist/src/registry/index.js +2 -0
  100. package/dist/src/registry/index.js.map +1 -0
  101. package/dist/src/registry/interfaces.d.ts +39 -0
  102. package/dist/src/registry/interfaces.d.ts.map +1 -0
  103. package/dist/src/registry/interfaces.js +2 -0
  104. package/dist/src/registry/interfaces.js.map +1 -0
  105. package/dist/src/shared/awaiter.d.ts +32 -0
  106. package/dist/src/shared/awaiter.d.ts.map +1 -0
  107. package/dist/src/shared/awaiter.js +132 -0
  108. package/dist/src/shared/awaiter.js.map +1 -0
  109. package/dist/src/shared/errors.d.ts +9 -0
  110. package/dist/src/shared/errors.d.ts.map +1 -0
  111. package/dist/src/shared/errors.js +18 -0
  112. package/dist/src/shared/errors.js.map +1 -0
  113. package/dist/src/shared/factories.d.ts +16 -0
  114. package/dist/src/shared/factories.d.ts.map +1 -0
  115. package/dist/src/shared/factories.js +33 -0
  116. package/dist/src/shared/factories.js.map +1 -0
  117. package/dist/src/shared/types.d.ts +91 -19
  118. package/dist/src/shared/types.d.ts.map +1 -1
  119. package/dist/src/shared/types.js +35 -1
  120. package/dist/src/shared/types.js.map +1 -1
  121. package/dist/src/shared/utils.d.ts +3 -0
  122. package/dist/src/shared/utils.d.ts.map +1 -0
  123. package/dist/src/shared/utils.js +8 -0
  124. package/dist/src/shared/utils.js.map +1 -0
  125. package/dist/src/signer/passthrough-signer.d.ts +6 -0
  126. package/dist/src/signer/passthrough-signer.d.ts.map +1 -0
  127. package/dist/src/signer/passthrough-signer.js +6 -0
  128. package/dist/src/signer/passthrough-signer.js.map +1 -0
  129. package/dist/src/signer/types.d.ts +15 -0
  130. package/dist/src/signer/types.d.ts.map +1 -0
  131. package/dist/src/signer/types.js +2 -0
  132. package/dist/src/signer/types.js.map +1 -0
  133. package/dist/src/storage/interfaces.d.ts +108 -0
  134. package/dist/src/storage/interfaces.d.ts.map +1 -0
  135. package/dist/src/storage/interfaces.js +19 -0
  136. package/dist/src/storage/interfaces.js.map +1 -0
  137. package/dist/src/storage/kysely/store.d.ts +15 -0
  138. package/dist/src/storage/kysely/store.d.ts.map +1 -0
  139. package/dist/src/storage/kysely/store.js +197 -0
  140. package/dist/src/storage/kysely/store.js.map +1 -0
  141. package/dist/src/storage/kysely/types.d.ts +26 -0
  142. package/dist/src/storage/kysely/types.d.ts.map +1 -0
  143. package/dist/src/storage/kysely/types.js +2 -0
  144. package/dist/src/storage/kysely/types.js.map +1 -0
  145. package/dist/src/storage/txn.d.ts +15 -0
  146. package/dist/src/storage/txn.d.ts.map +1 -0
  147. package/dist/src/storage/txn.js +42 -0
  148. package/dist/src/storage/txn.js.map +1 -0
  149. package/dist/src/subs/default-error-handler.d.ts +13 -0
  150. package/dist/src/subs/default-error-handler.d.ts.map +1 -0
  151. package/dist/src/subs/default-error-handler.js +27 -0
  152. package/dist/src/subs/default-error-handler.js.map +1 -0
  153. package/dist/src/subs/react-subscription-manager.d.ts +45 -0
  154. package/dist/src/subs/react-subscription-manager.d.ts.map +1 -0
  155. package/dist/src/subs/react-subscription-manager.js +185 -0
  156. package/dist/src/subs/react-subscription-manager.js.map +1 -0
  157. package/dist/src/subs/types.d.ts +64 -0
  158. package/dist/src/subs/types.d.ts.map +1 -0
  159. package/dist/src/subs/types.js +2 -0
  160. package/dist/src/subs/types.js.map +1 -0
  161. package/dist/src/utils/reshuffle.d.ts +30 -0
  162. package/dist/src/utils/reshuffle.d.ts.map +1 -0
  163. package/dist/src/utils/reshuffle.js +47 -0
  164. package/dist/src/utils/reshuffle.js.map +1 -0
  165. package/package.json +15 -6
  166. package/dist/bench/end-to-end-flow.bench.d.ts +0 -2
  167. package/dist/bench/end-to-end-flow.bench.d.ts.map +0 -1
  168. package/dist/bench/end-to-end-flow.bench.js +0 -256
  169. package/dist/bench/end-to-end-flow.bench.js.map +0 -1
  170. package/dist/bench/event-bus.bench.d.ts +0 -2
  171. package/dist/bench/event-bus.bench.d.ts.map +0 -1
  172. package/dist/bench/event-bus.bench.js +0 -238
  173. package/dist/bench/event-bus.bench.js.map +0 -1
  174. package/dist/bench/queue-only.bench.d.ts +0 -2
  175. package/dist/bench/queue-only.bench.d.ts.map +0 -1
  176. package/dist/bench/queue-only.bench.js +0 -40
  177. package/dist/bench/queue-only.bench.js.map +0 -1
  178. package/dist/bench/reactor-throughput.bench.d.ts +0 -2
  179. package/dist/bench/reactor-throughput.bench.d.ts.map +0 -1
  180. package/dist/bench/reactor-throughput.bench.js +0 -137
  181. package/dist/bench/reactor-throughput.bench.js.map +0 -1
  182. package/dist/src/executor/job-executor.d.ts +0 -62
  183. package/dist/src/executor/job-executor.d.ts.map +0 -1
  184. package/dist/src/executor/job-executor.js +0 -325
  185. package/dist/src/executor/job-executor.js.map +0 -1
  186. package/dist/test/event-bus.test.d.ts +0 -2
  187. package/dist/test/event-bus.test.d.ts.map +0 -1
  188. package/dist/test/event-bus.test.js +0 -532
  189. package/dist/test/event-bus.test.js.map +0 -1
  190. package/dist/test/job-executor.test.d.ts +0 -2
  191. package/dist/test/job-executor.test.d.ts.map +0 -1
  192. package/dist/test/job-executor.test.js +0 -581
  193. package/dist/test/job-executor.test.js.map +0 -1
  194. package/dist/test/queue.test.d.ts +0 -2
  195. package/dist/test/queue.test.d.ts.map +0 -1
  196. package/dist/test/queue.test.js +0 -396
  197. package/dist/test/queue.test.js.map +0 -1
  198. package/dist/tsconfig.tsbuildinfo +0 -1
@@ -0,0 +1,108 @@
1
+ import type { Operation, PHDocument } from "document-model";
2
+ export type OperationContext = {
3
+ documentId: string;
4
+ documentType: string;
5
+ scope: string;
6
+ branch: string;
7
+ };
8
+ export type OperationWithContext = {
9
+ operation: Operation;
10
+ context: OperationContext;
11
+ };
12
+ export declare class DuplicateOperationError extends Error {
13
+ constructor(opId: string);
14
+ }
15
+ export declare class OptimisticLockError extends Error {
16
+ constructor(message: string);
17
+ }
18
+ export declare class RevisionMismatchError extends Error {
19
+ constructor(expected: number, actual: number);
20
+ }
21
+ export interface AtomicTxn {
22
+ addOperations(...operations: Operation[]): void;
23
+ }
24
+ export type DocumentRevisions = {
25
+ /** Map of scope to operation index for that scope */
26
+ revision: Record<string, number>;
27
+ /** Latest timestamp across revisions */
28
+ latestTimestamp: string;
29
+ };
30
+ export interface IOperationStore {
31
+ apply(documentId: string, documentType: string, scope: string, branch: string, revision: number, fn: (txn: AtomicTxn) => void | Promise<void>, signal?: AbortSignal): Promise<void>;
32
+ getSince(documentId: string, scope: string, branch: string, revision: number, paging?: PagingOptions, signal?: AbortSignal): Promise<PagedResults<Operation>>;
33
+ getSinceId(id: number, paging?: PagingOptions, signal?: AbortSignal): Promise<PagedResults<OperationWithContext>>;
34
+ /**
35
+ * Gets the latest operation index for each scope of a document, along with
36
+ * the latest timestamp across all scopes. This is used to efficiently reconstruct
37
+ * the revision map and lastModified timestamp for document headers.
38
+ *
39
+ * @param documentId - The document id
40
+ * @param branch - The branch name
41
+ * @param signal - Optional abort signal to cancel the request
42
+ * @returns Object containing revision map and latest timestamp
43
+ */
44
+ getRevisions(documentId: string, branch: string, signal?: AbortSignal): Promise<DocumentRevisions>;
45
+ }
46
+ export interface ViewFilter {
47
+ branch?: string;
48
+ scopes?: string[];
49
+ }
50
+ export interface SearchFilter {
51
+ documentType?: string;
52
+ parentId?: string;
53
+ identifiers?: Record<string, any>;
54
+ includeDeleted?: boolean;
55
+ }
56
+ export interface PagingOptions {
57
+ cursor?: string;
58
+ limit?: number;
59
+ }
60
+ export interface PagedResults<T> {
61
+ items: T[];
62
+ nextCursor?: string;
63
+ hasMore: boolean;
64
+ }
65
+ export interface DocumentSnapshot {
66
+ id: string;
67
+ documentId: string;
68
+ slug: string | null;
69
+ name: string | null;
70
+ scope: string;
71
+ branch: string;
72
+ content: string;
73
+ documentType: string;
74
+ lastOperationIndex: number;
75
+ lastOperationHash: string;
76
+ lastUpdatedAt: Date;
77
+ snapshotVersion: number;
78
+ identifiers: string | null;
79
+ metadata: string | null;
80
+ isDeleted: boolean;
81
+ deletedAt: Date | null;
82
+ }
83
+ export interface IDocumentView {
84
+ /**
85
+ * Initializes the view.
86
+ */
87
+ init(): Promise<void>;
88
+ /**
89
+ * Indexes a list of operations.
90
+ */
91
+ indexOperations(items: OperationWithContext[]): Promise<void>;
92
+ /**
93
+ * Returns true if and only if the documents exist.
94
+ *
95
+ * @param documentIds - The list of document ids to check.
96
+ * @param signal - Optional abort signal to cancel the request
97
+ */
98
+ exists(documentIds: string[], signal?: AbortSignal): Promise<boolean[]>;
99
+ /**
100
+ * Returns the document with the given id.
101
+ *
102
+ * @param documentId - The id of the document to get.
103
+ * @param view - Optional filter containing branch and scopes information
104
+ * @param signal - Optional abort signal to cancel the request
105
+ */
106
+ get<TDocument extends PHDocument>(documentId: string, view?: ViewFilter, signal?: AbortSignal): Promise<TDocument>;
107
+ }
108
+ //# sourceMappingURL=interfaces.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"interfaces.d.ts","sourceRoot":"","sources":["../../../src/storage/interfaces.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,19 @@
1
+ export class DuplicateOperationError extends Error {
2
+ constructor(opId) {
3
+ super(`Operation with opId ${opId} already exists`);
4
+ this.name = "DuplicateOperationError";
5
+ }
6
+ }
7
+ export class OptimisticLockError extends Error {
8
+ constructor(message) {
9
+ super(message);
10
+ this.name = "OptimisticLockError";
11
+ }
12
+ }
13
+ export class RevisionMismatchError extends Error {
14
+ constructor(expected, actual) {
15
+ super(`Revision mismatch: expected ${expected}, got ${actual}`);
16
+ this.name = "RevisionMismatchError";
17
+ }
18
+ }
19
+ //# sourceMappingURL=interfaces.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"interfaces.js","sourceRoot":"","sources":["../../../src/storage/interfaces.ts"],"names":[],"mappings":"AAcA,MAAM,OAAO,uBAAwB,SAAQ,KAAK;IAChD,YAAY,IAAY;QACtB,KAAK,CAAC,uBAAuB,IAAI,iBAAiB,CAAC,CAAC;QACpD,IAAI,CAAC,IAAI,GAAG,yBAAyB,CAAC;IACxC,CAAC;CACF;AAED,MAAM,OAAO,mBAAoB,SAAQ,KAAK;IAC5C,YAAY,OAAe;QACzB,KAAK,CAAC,OAAO,CAAC,CAAC;QACf,IAAI,CAAC,IAAI,GAAG,qBAAqB,CAAC;IACpC,CAAC;CACF;AAED,MAAM,OAAO,qBAAsB,SAAQ,KAAK;IAC9C,YAAY,QAAgB,EAAE,MAAc;QAC1C,KAAK,CAAC,+BAA+B,QAAQ,SAAS,MAAM,EAAE,CAAC,CAAC;QAChE,IAAI,CAAC,IAAI,GAAG,uBAAuB,CAAC;IACtC,CAAC;CACF"}
@@ -0,0 +1,15 @@
1
+ import { type Operation } from "document-model";
2
+ import type { Kysely } from "kysely";
3
+ import { type AtomicTxn, type DocumentRevisions, type IOperationStore, type OperationWithContext, type PagedResults, type PagingOptions } from "../interfaces.js";
4
+ import type { Database } from "./types.js";
5
+ export declare class KyselyOperationStore implements IOperationStore {
6
+ private db;
7
+ constructor(db: Kysely<Database>);
8
+ apply(documentId: string, documentType: string, scope: string, branch: string, revision: number, fn: (txn: AtomicTxn) => void | Promise<void>, signal?: AbortSignal): Promise<void>;
9
+ getSince(documentId: string, scope: string, branch: string, revision: number, paging?: PagingOptions, signal?: AbortSignal): Promise<PagedResults<Operation>>;
10
+ getSinceId(id: number, paging?: PagingOptions, signal?: AbortSignal): Promise<PagedResults<OperationWithContext>>;
11
+ getRevisions(documentId: string, branch: string, signal?: AbortSignal): Promise<DocumentRevisions>;
12
+ private rowToOperation;
13
+ private rowToOperationWithContext;
14
+ }
15
+ //# sourceMappingURL=store.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"store.d.ts","sourceRoot":"","sources":["../../../../src/storage/kysely/store.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAChD,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,QAAQ,CAAC;AACrC,OAAO,EAGL,KAAK,SAAS,EACd,KAAK,iBAAiB,EACtB,KAAK,eAAe,EACpB,KAAK,oBAAoB,EACzB,KAAK,YAAY,EACjB,KAAK,aAAa,EACnB,MAAM,kBAAkB,CAAC;AAE1B,OAAO,KAAK,EAAE,QAAQ,EAAgB,MAAM,YAAY,CAAC;AAEzD,qBAAa,oBAAqB,YAAW,eAAe;IAC9C,OAAO,CAAC,EAAE;gBAAF,EAAE,EAAE,MAAM,CAAC,QAAQ,CAAC;IAElC,KAAK,CACT,UAAU,EAAE,MAAM,EAClB,YAAY,EAAE,MAAM,EACpB,KAAK,EAAE,MAAM,EACb,MAAM,EAAE,MAAM,EACd,QAAQ,EAAE,MAAM,EAChB,EAAE,EAAE,CAAC,GAAG,EAAE,SAAS,KAAK,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC,EAC5C,MAAM,CAAC,EAAE,WAAW,GACnB,OAAO,CAAC,IAAI,CAAC;IAiEV,QAAQ,CACZ,UAAU,EAAE,MAAM,EAClB,KAAK,EAAE,MAAM,EACb,MAAM,EAAE,MAAM,EACd,QAAQ,EAAE,MAAM,EAChB,MAAM,CAAC,EAAE,aAAa,EACtB,MAAM,CAAC,EAAE,WAAW,GACnB,OAAO,CAAC,YAAY,CAAC,SAAS,CAAC,CAAC;IAoD7B,UAAU,CACd,EAAE,EAAE,MAAM,EACV,MAAM,CAAC,EAAE,aAAa,EACtB,MAAM,CAAC,EAAE,WAAW,GACnB,OAAO,CAAC,YAAY,CAAC,oBAAoB,CAAC,CAAC;IAiDxC,YAAY,CAChB,UAAU,EAAE,MAAM,EAClB,MAAM,EAAE,MAAM,EACd,MAAM,CAAC,EAAE,WAAW,GACnB,OAAO,CAAC,iBAAiB,CAAC;IA2C7B,OAAO,CAAC,cAAc;IAatB,OAAO,CAAC,yBAAyB;CAWlC"}
@@ -0,0 +1,197 @@
1
+ import {} from "document-model";
2
+ import { DuplicateOperationError, RevisionMismatchError, } from "../interfaces.js";
3
+ import { AtomicTransaction } from "../txn.js";
4
+ export class KyselyOperationStore {
5
+ db;
6
+ constructor(db) {
7
+ this.db = db;
8
+ }
9
+ async apply(documentId, documentType, scope, branch, revision, fn, signal) {
10
+ await this.db.transaction().execute(async (trx) => {
11
+ // Check for abort signal
12
+ if (signal?.aborted) {
13
+ throw new Error("Operation aborted");
14
+ }
15
+ // Get the latest operation for this stream to verify revision
16
+ const latestOp = await trx
17
+ .selectFrom("Operation")
18
+ .selectAll()
19
+ .where("documentId", "=", documentId)
20
+ .where("scope", "=", scope)
21
+ .where("branch", "=", branch)
22
+ .orderBy("index", "desc")
23
+ .limit(1)
24
+ .executeTakeFirst();
25
+ // Check revision matches
26
+ const currentRevision = latestOp ? latestOp.index : -1;
27
+ if (currentRevision !== revision - 1) {
28
+ throw new RevisionMismatchError(revision - 1, currentRevision);
29
+ }
30
+ // Create atomic transaction
31
+ const atomicTxn = new AtomicTransaction(documentId, documentType, scope, branch, revision);
32
+ await fn(atomicTxn);
33
+ // Get operations and header updates
34
+ const operations = atomicTxn.getOperations();
35
+ // Insert operations
36
+ if (operations.length > 0) {
37
+ // Set prevOpId for each operation
38
+ let prevOpId = latestOp?.opId || "";
39
+ for (const op of operations) {
40
+ op.prevOpId = prevOpId;
41
+ prevOpId = op.opId;
42
+ }
43
+ try {
44
+ await trx.insertInto("Operation").values(operations).execute();
45
+ }
46
+ catch (error) {
47
+ if (error instanceof Error) {
48
+ if (error.message.includes("unique constraint")) {
49
+ // Extract the opId from the error if possible
50
+ const opId = operations[0]?.opId || "unknown";
51
+ throw new DuplicateOperationError(opId);
52
+ }
53
+ throw error;
54
+ }
55
+ throw error;
56
+ }
57
+ }
58
+ });
59
+ }
60
+ async getSince(documentId, scope, branch, revision, paging, signal) {
61
+ if (signal?.aborted) {
62
+ throw new Error("Operation aborted");
63
+ }
64
+ let query = this.db
65
+ .selectFrom("Operation")
66
+ .selectAll()
67
+ .where("documentId", "=", documentId)
68
+ .where("scope", "=", scope)
69
+ .where("branch", "=", branch)
70
+ .where("index", ">", revision)
71
+ .orderBy("index", "asc");
72
+ // Handle cursor-based pagination
73
+ if (paging) {
74
+ // Cursor encodes the last seen index
75
+ if (paging.cursor) {
76
+ const lastIndex = Number.parseInt(paging.cursor, 10);
77
+ query = query.where("index", ">", lastIndex);
78
+ }
79
+ // Apply limit if specified (fetch one extra to determine hasMore)
80
+ if (paging.limit) {
81
+ query = query.limit(paging.limit + 1);
82
+ }
83
+ }
84
+ const rows = await query.execute();
85
+ // Determine if there are more results
86
+ let hasMore = false;
87
+ let items = rows;
88
+ if (paging?.limit && rows.length > paging.limit) {
89
+ hasMore = true;
90
+ items = rows.slice(0, paging.limit);
91
+ }
92
+ // Generate next cursor from last item's index
93
+ const nextCursor = hasMore && items.length > 0
94
+ ? items[items.length - 1].index.toString()
95
+ : undefined;
96
+ return {
97
+ items: items.map((row) => this.rowToOperation(row)),
98
+ nextCursor,
99
+ hasMore,
100
+ };
101
+ }
102
+ async getSinceId(id, paging, signal) {
103
+ if (signal?.aborted) {
104
+ throw new Error("Operation aborted");
105
+ }
106
+ let query = this.db
107
+ .selectFrom("Operation")
108
+ .selectAll()
109
+ .where("id", ">", id)
110
+ .orderBy("id", "asc");
111
+ // Handle cursor-based pagination
112
+ if (paging) {
113
+ // Cursor encodes the last seen id
114
+ if (paging.cursor) {
115
+ const lastId = Number.parseInt(paging.cursor, 10);
116
+ query = query.where("id", ">", lastId);
117
+ }
118
+ // Apply limit if specified (fetch one extra to determine hasMore)
119
+ if (paging.limit) {
120
+ query = query.limit(paging.limit + 1);
121
+ }
122
+ }
123
+ const rows = await query.execute();
124
+ // Determine if there are more results
125
+ let hasMore = false;
126
+ let items = rows;
127
+ if (paging?.limit && rows.length > paging.limit) {
128
+ hasMore = true;
129
+ items = rows.slice(0, paging.limit);
130
+ }
131
+ // Generate next cursor from last item's id
132
+ const nextCursor = hasMore && items.length > 0
133
+ ? items[items.length - 1].id.toString()
134
+ : undefined;
135
+ return {
136
+ items: items.map((row) => this.rowToOperationWithContext(row)),
137
+ nextCursor,
138
+ hasMore,
139
+ };
140
+ }
141
+ async getRevisions(documentId, branch, signal) {
142
+ if (signal?.aborted) {
143
+ throw new Error("Operation aborted");
144
+ }
145
+ // Get the latest operation for each scope in a single query
146
+ // Uses a subquery to find operations where the index equals the max index for that scope
147
+ const scopeRevisions = await this.db
148
+ .selectFrom("Operation as o1")
149
+ .select(["o1.scope", "o1.index", "o1.timestampUtcMs"])
150
+ .where("o1.documentId", "=", documentId)
151
+ .where("o1.branch", "=", branch)
152
+ .where((eb) => eb("o1.index", "=", eb
153
+ .selectFrom("Operation as o2")
154
+ .select((eb2) => eb2.fn.max("o2.index").as("maxIndex"))
155
+ .where("o2.documentId", "=", eb.ref("o1.documentId"))
156
+ .where("o2.branch", "=", eb.ref("o1.branch"))
157
+ .where("o2.scope", "=", eb.ref("o1.scope"))))
158
+ .execute();
159
+ const revision = {};
160
+ let latestTimestamp = new Date(0).toISOString();
161
+ for (const row of scopeRevisions) {
162
+ revision[row.scope] = row.index + 1;
163
+ const timestamp = row.timestampUtcMs.toISOString();
164
+ if (timestamp > latestTimestamp) {
165
+ latestTimestamp = timestamp;
166
+ }
167
+ }
168
+ return {
169
+ revision,
170
+ latestTimestamp,
171
+ };
172
+ }
173
+ rowToOperation(row) {
174
+ return {
175
+ index: row.index,
176
+ timestampUtcMs: row.timestampUtcMs.toISOString(),
177
+ hash: row.hash,
178
+ skip: row.skip,
179
+ error: row.error || undefined,
180
+ resultingState: row.resultingState || undefined,
181
+ id: row.opId,
182
+ action: JSON.parse(row.action),
183
+ };
184
+ }
185
+ rowToOperationWithContext(row) {
186
+ return {
187
+ operation: this.rowToOperation(row),
188
+ context: {
189
+ documentId: row.documentId,
190
+ documentType: row.documentType,
191
+ scope: row.scope,
192
+ branch: row.branch,
193
+ },
194
+ };
195
+ }
196
+ }
197
+ //# sourceMappingURL=store.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"store.js","sourceRoot":"","sources":["../../../../src/storage/kysely/store.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,26 @@
1
+ import type { Generated, Insertable, Selectable, Updateable } from "kysely";
2
+ export interface OperationTable {
3
+ id: Generated<number>;
4
+ jobId: string;
5
+ opId: string;
6
+ prevOpId: string;
7
+ writeTimestampUtcMs: Generated<Date>;
8
+ documentId: string;
9
+ documentType: string;
10
+ scope: string;
11
+ branch: string;
12
+ timestampUtcMs: Date;
13
+ index: number;
14
+ action: string;
15
+ skip: number;
16
+ resultingState?: string | null;
17
+ error?: string | null;
18
+ hash: string;
19
+ }
20
+ export interface Database {
21
+ Operation: OperationTable;
22
+ }
23
+ export type OperationRow = Selectable<OperationTable>;
24
+ export type InsertableOperation = Insertable<OperationTable>;
25
+ export type UpdateableOperation = Updateable<OperationTable>;
26
+ //# sourceMappingURL=types.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../../src/storage/kysely/types.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,SAAS,EAAE,UAAU,EAAE,UAAU,EAAE,UAAU,EAAE,MAAM,QAAQ,CAAC;AAE5E,MAAM,WAAW,cAAc;IAC7B,EAAE,EAAE,SAAS,CAAC,MAAM,CAAC,CAAC;IACtB,KAAK,EAAE,MAAM,CAAC;IACd,IAAI,EAAE,MAAM,CAAC;IACb,QAAQ,EAAE,MAAM,CAAC;IACjB,mBAAmB,EAAE,SAAS,CAAC,IAAI,CAAC,CAAC;IACrC,UAAU,EAAE,MAAM,CAAC;IACnB,YAAY,EAAE,MAAM,CAAC;IACrB,KAAK,EAAE,MAAM,CAAC;IACd,MAAM,EAAE,MAAM,CAAC;IACf,cAAc,EAAE,IAAI,CAAC;IACrB,KAAK,EAAE,MAAM,CAAC;IACd,MAAM,EAAE,MAAM,CAAC;IACf,IAAI,EAAE,MAAM,CAAC;IACb,cAAc,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;IAC/B,KAAK,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;IACtB,IAAI,EAAE,MAAM,CAAC;CACd;AAED,MAAM,WAAW,QAAQ;IACvB,SAAS,EAAE,cAAc,CAAC;CAC3B;AAED,MAAM,MAAM,YAAY,GAAG,UAAU,CAAC,cAAc,CAAC,CAAC;AACtD,MAAM,MAAM,mBAAmB,GAAG,UAAU,CAAC,cAAc,CAAC,CAAC;AAC7D,MAAM,MAAM,mBAAmB,GAAG,UAAU,CAAC,cAAc,CAAC,CAAC"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=types.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.js","sourceRoot":"","sources":["../../../../src/storage/kysely/types.ts"],"names":[],"mappings":""}
@@ -0,0 +1,15 @@
1
+ import type { Operation } from "document-model";
2
+ import { type AtomicTxn as IAtomicTxn } from "./interfaces.js";
3
+ import type { InsertableOperation } from "./kysely/types.js";
4
+ export declare class AtomicTransaction implements IAtomicTxn {
5
+ private documentId;
6
+ private documentType;
7
+ private scope;
8
+ private branch;
9
+ private baseRevision;
10
+ private operations;
11
+ constructor(documentId: string, documentType: string, scope: string, branch: string, baseRevision: number);
12
+ addOperations(...operations: Operation[]): void;
13
+ getOperations(): InsertableOperation[];
14
+ }
15
+ //# sourceMappingURL=txn.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"txn.d.ts","sourceRoot":"","sources":["../../../src/storage/txn.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAEhD,OAAO,EAAE,KAAK,SAAS,IAAI,UAAU,EAAE,MAAM,iBAAiB,CAAC;AAC/D,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,mBAAmB,CAAC;AAE7D,qBAAa,iBAAkB,YAAW,UAAU;IAIhD,OAAO,CAAC,UAAU;IAClB,OAAO,CAAC,YAAY;IACpB,OAAO,CAAC,KAAK;IACb,OAAO,CAAC,MAAM;IACd,OAAO,CAAC,YAAY;IAPtB,OAAO,CAAC,UAAU,CAA6B;gBAGrC,UAAU,EAAE,MAAM,EAClB,YAAY,EAAE,MAAM,EACpB,KAAK,EAAE,MAAM,EACb,MAAM,EAAE,MAAM,EACd,YAAY,EAAE,MAAM;IAK9B,aAAa,CAAC,GAAG,UAAU,EAAE,SAAS,EAAE,GAAG,IAAI;IAqB/C,aAAa,IAAI,mBAAmB,EAAE;CAGvC"}
@@ -0,0 +1,42 @@
1
+ import { v4 as uuidv4 } from "uuid";
2
+ import {} from "./interfaces.js";
3
+ export class AtomicTransaction {
4
+ documentId;
5
+ documentType;
6
+ scope;
7
+ branch;
8
+ baseRevision;
9
+ operations = [];
10
+ constructor(documentId, documentType, scope, branch, baseRevision) {
11
+ this.documentId = documentId;
12
+ this.documentType = documentType;
13
+ this.scope = scope;
14
+ this.branch = branch;
15
+ this.baseRevision = baseRevision;
16
+ //
17
+ }
18
+ addOperations(...operations) {
19
+ for (const op of operations) {
20
+ this.operations.push({
21
+ jobId: uuidv4(),
22
+ opId: op.id || uuidv4(),
23
+ prevOpId: "", // Will be set during apply
24
+ documentId: this.documentId,
25
+ documentType: this.documentType,
26
+ scope: this.scope,
27
+ branch: this.branch,
28
+ timestampUtcMs: new Date(op.timestampUtcMs),
29
+ index: op.index,
30
+ action: JSON.stringify(op.action),
31
+ skip: op.skip,
32
+ resultingState: op.resultingState || null,
33
+ error: op.error || null,
34
+ hash: op.hash,
35
+ });
36
+ }
37
+ }
38
+ getOperations() {
39
+ return this.operations;
40
+ }
41
+ }
42
+ //# sourceMappingURL=txn.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"txn.js","sourceRoot":"","sources":["../../../src/storage/txn.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,EAAE,IAAI,MAAM,EAAE,MAAM,MAAM,CAAC;AACpC,OAAO,EAAgC,MAAM,iBAAiB,CAAC;AAG/D,MAAM,OAAO,iBAAiB;IAIlB;IACA;IACA;IACA;IACA;IAPF,UAAU,GAA0B,EAAE,CAAC;IAE/C,YACU,UAAkB,EAClB,YAAoB,EACpB,KAAa,EACb,MAAc,EACd,YAAoB;QAJpB,eAAU,GAAV,UAAU,CAAQ;QAClB,iBAAY,GAAZ,YAAY,CAAQ;QACpB,UAAK,GAAL,KAAK,CAAQ;QACb,WAAM,GAAN,MAAM,CAAQ;QACd,iBAAY,GAAZ,YAAY,CAAQ;QAE5B,EAAE;IACJ,CAAC;IAED,aAAa,CAAC,GAAG,UAAuB;QACtC,KAAK,MAAM,EAAE,IAAI,UAAU,EAAE,CAAC;YAC5B,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC;gBACnB,KAAK,EAAE,MAAM,EAAE;gBACf,IAAI,EAAE,EAAE,CAAC,EAAE,IAAI,MAAM,EAAE;gBACvB,QAAQ,EAAE,EAAE,EAAE,2BAA2B;gBACzC,UAAU,EAAE,IAAI,CAAC,UAAU;gBAC3B,YAAY,EAAE,IAAI,CAAC,YAAY;gBAC/B,KAAK,EAAE,IAAI,CAAC,KAAK;gBACjB,MAAM,EAAE,IAAI,CAAC,MAAM;gBACnB,cAAc,EAAE,IAAI,IAAI,CAAC,EAAE,CAAC,cAAc,CAAC;gBAC3C,KAAK,EAAE,EAAE,CAAC,KAAK;gBACf,MAAM,EAAE,IAAI,CAAC,SAAS,CAAC,EAAE,CAAC,MAAM,CAAC;gBACjC,IAAI,EAAE,EAAE,CAAC,IAAI;gBACb,cAAc,EAAE,EAAE,CAAC,cAAc,IAAI,IAAI;gBACzC,KAAK,EAAE,EAAE,CAAC,KAAK,IAAI,IAAI;gBACvB,IAAI,EAAE,EAAE,CAAC,IAAI;aACd,CAAC,CAAC;QACL,CAAC;IACH,CAAC;IAED,aAAa;QACX,OAAO,IAAI,CAAC,UAAU,CAAC;IACzB,CAAC;CACF"}
@@ -0,0 +1,13 @@
1
+ import type { ISubscriptionErrorHandler, SubscriptionErrorContext } from "./types.js";
2
+ /**
3
+ * Default error handler that re-throws subscription errors.
4
+ * This ensures that errors are not silently swallowed.
5
+ */
6
+ export declare class DefaultSubscriptionErrorHandler implements ISubscriptionErrorHandler {
7
+ handleError(error: unknown, context: SubscriptionErrorContext): void;
8
+ }
9
+ /**
10
+ * Creates a default subscription error handler instance
11
+ */
12
+ export declare function createDefaultSubscriptionErrorHandler(): ISubscriptionErrorHandler;
13
+ //# sourceMappingURL=default-error-handler.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"default-error-handler.d.ts","sourceRoot":"","sources":["../../../src/subs/default-error-handler.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EACV,yBAAyB,EACzB,wBAAwB,EACzB,MAAM,YAAY,CAAC;AAEpB;;;GAGG;AACH,qBAAa,+BACX,YAAW,yBAAyB;IAEpC,WAAW,CAAC,KAAK,EAAE,OAAO,EAAE,OAAO,EAAE,wBAAwB,GAAG,IAAI;CAcrE;AAED;;GAEG;AACH,wBAAgB,qCAAqC,IAAI,yBAAyB,CAEjF"}
@@ -0,0 +1,27 @@
1
+ /**
2
+ * Default error handler that re-throws subscription errors.
3
+ * This ensures that errors are not silently swallowed.
4
+ */
5
+ export class DefaultSubscriptionErrorHandler {
6
+ handleError(error, context) {
7
+ const errorMessage = `Subscription error in ${context.eventType} (${context.subscriptionId})`;
8
+ if (error instanceof Error) {
9
+ // Preserve the original error with additional context
10
+ const enhancedError = new Error(`${errorMessage}: ${error.message}`);
11
+ enhancedError.cause = error;
12
+ enhancedError.stack = error.stack;
13
+ throw enhancedError;
14
+ }
15
+ else {
16
+ // Handle non-Error objects
17
+ throw new Error(`${errorMessage}: ${String(error)}`);
18
+ }
19
+ }
20
+ }
21
+ /**
22
+ * Creates a default subscription error handler instance
23
+ */
24
+ export function createDefaultSubscriptionErrorHandler() {
25
+ return new DefaultSubscriptionErrorHandler();
26
+ }
27
+ //# sourceMappingURL=default-error-handler.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"default-error-handler.js","sourceRoot":"","sources":["../../../src/subs/default-error-handler.ts"],"names":[],"mappings":"AAKA;;;GAGG;AACH,MAAM,OAAO,+BAA+B;IAG1C,WAAW,CAAC,KAAc,EAAE,OAAiC;QAC3D,MAAM,YAAY,GAAG,yBAAyB,OAAO,CAAC,SAAS,KAAK,OAAO,CAAC,cAAc,GAAG,CAAC;QAE9F,IAAI,KAAK,YAAY,KAAK,EAAE,CAAC;YAC3B,sDAAsD;YACtD,MAAM,aAAa,GAAG,IAAI,KAAK,CAAC,GAAG,YAAY,KAAK,KAAK,CAAC,OAAO,EAAE,CAAC,CAAC;YACrE,aAAa,CAAC,KAAK,GAAG,KAAK,CAAC;YAC5B,aAAa,CAAC,KAAK,GAAG,KAAK,CAAC,KAAK,CAAC;YAClC,MAAM,aAAa,CAAC;QACtB,CAAC;aAAM,CAAC;YACN,2BAA2B;YAC3B,MAAM,IAAI,KAAK,CAAC,GAAG,YAAY,KAAK,MAAM,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC;QACvD,CAAC;IACH,CAAC;CACF;AAED;;GAEG;AACH,MAAM,UAAU,qCAAqC;IACnD,OAAO,IAAI,+BAA+B,EAAE,CAAC;AAC/C,CAAC"}
@@ -0,0 +1,45 @@
1
+ import type { PHDocument } from "document-model";
2
+ import type { PagedResults, RelationshipChangeType, SearchFilter, ViewFilter } from "../shared/types.js";
3
+ import type { IReactorSubscriptionManager, ISubscriptionErrorHandler } from "./types.js";
4
+ type DocumentCreatedCallback = (result: PagedResults<string>) => void;
5
+ type DocumentDeletedCallback = (documentIds: string[]) => void;
6
+ type DocumentStateUpdatedCallback = (result: PagedResults<PHDocument>) => void;
7
+ type RelationshipChangedCallback = (parentId: string, childId: string, changeType: RelationshipChangeType) => void;
8
+ export declare class ReactorSubscriptionManager implements IReactorSubscriptionManager {
9
+ private createdSubscriptions;
10
+ private deletedSubscriptions;
11
+ private updatedSubscriptions;
12
+ private relationshipSubscriptions;
13
+ private subscriptionCounter;
14
+ private errorHandler;
15
+ constructor(errorHandler: ISubscriptionErrorHandler);
16
+ onDocumentCreated(callback: DocumentCreatedCallback, search?: SearchFilter): () => void;
17
+ onDocumentDeleted(callback: DocumentDeletedCallback, search?: SearchFilter): () => void;
18
+ onDocumentStateUpdated(callback: DocumentStateUpdatedCallback, search?: SearchFilter, view?: ViewFilter): () => void;
19
+ onRelationshipChanged(callback: RelationshipChangedCallback, search?: SearchFilter): () => void;
20
+ /**
21
+ * Notify subscribers about created documents
22
+ */
23
+ notifyDocumentsCreated(documentIds: string[], documentTypes?: Map<string, string>, parentIds?: Map<string, string | null>): void;
24
+ /**
25
+ * Notify subscribers about deleted documents
26
+ */
27
+ notifyDocumentsDeleted(documentIds: string[], documentTypes?: Map<string, string>, parentIds?: Map<string, string | null>): void;
28
+ /**
29
+ * Notify subscribers about updated documents
30
+ */
31
+ notifyDocumentsUpdated(documents: PHDocument[]): void;
32
+ /**
33
+ * Notify subscribers about relationship changes
34
+ */
35
+ notifyRelationshipChanged(parentId: string, childId: string, changeType: RelationshipChangeType, childType?: string): void;
36
+ /**
37
+ * Clear all subscriptions
38
+ */
39
+ clearAll(): void;
40
+ private filterDocumentIds;
41
+ private filterDocuments;
42
+ private matchesRelationshipFilter;
43
+ }
44
+ export {};
45
+ //# sourceMappingURL=react-subscription-manager.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"react-subscription-manager.d.ts","sourceRoot":"","sources":["../../../src/subs/react-subscription-manager.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,gBAAgB,CAAC;AACjD,OAAO,KAAK,EACV,YAAY,EACZ,sBAAsB,EACtB,YAAY,EACZ,UAAU,EACX,MAAM,oBAAoB,CAAC;AAC5B,OAAO,KAAK,EACV,2BAA2B,EAC3B,yBAAyB,EAC1B,MAAM,YAAY,CAAC;AAEpB,KAAK,uBAAuB,GAAG,CAAC,MAAM,EAAE,YAAY,CAAC,MAAM,CAAC,KAAK,IAAI,CAAC;AACtE,KAAK,uBAAuB,GAAG,CAAC,WAAW,EAAE,MAAM,EAAE,KAAK,IAAI,CAAC;AAC/D,KAAK,4BAA4B,GAAG,CAAC,MAAM,EAAE,YAAY,CAAC,UAAU,CAAC,KAAK,IAAI,CAAC;AAC/E,KAAK,2BAA2B,GAAG,CACjC,QAAQ,EAAE,MAAM,EAChB,OAAO,EAAE,MAAM,EACf,UAAU,EAAE,sBAAsB,KAC/B,IAAI,CAAC;AASV,qBAAa,0BAA2B,YAAW,2BAA2B;IAC5E,OAAO,CAAC,oBAAoB,CAGxB;IACJ,OAAO,CAAC,oBAAoB,CAGxB;IACJ,OAAO,CAAC,oBAAoB,CAGxB;IACJ,OAAO,CAAC,yBAAyB,CAG7B;IAEJ,OAAO,CAAC,mBAAmB,CAAK;IAChC,OAAO,CAAC,YAAY,CAA4B;gBAEpC,YAAY,EAAE,yBAAyB;IAInD,iBAAiB,CACf,QAAQ,EAAE,uBAAuB,EACjC,MAAM,CAAC,EAAE,YAAY,GACpB,MAAM,IAAI;IASb,iBAAiB,CACf,QAAQ,EAAE,uBAAuB,EACjC,MAAM,CAAC,EAAE,YAAY,GACpB,MAAM,IAAI;IASb,sBAAsB,CACpB,QAAQ,EAAE,4BAA4B,EACtC,MAAM,CAAC,EAAE,YAAY,EACrB,IAAI,CAAC,EAAE,UAAU,GAChB,MAAM,IAAI;IASb,qBAAqB,CACnB,QAAQ,EAAE,2BAA2B,EACrC,MAAM,CAAC,EAAE,YAAY,GACpB,MAAM,IAAI;IASb;;OAEG;IACH,sBAAsB,CACpB,WAAW,EAAE,MAAM,EAAE,EACrB,aAAa,CAAC,EAAE,GAAG,CAAC,MAAM,EAAE,MAAM,CAAC,EACnC,SAAS,CAAC,EAAE,GAAG,CAAC,MAAM,EAAE,MAAM,GAAG,IAAI,CAAC,GACrC,IAAI;IA+BP;;OAEG;IACH,sBAAsB,CACpB,WAAW,EAAE,MAAM,EAAE,EACrB,aAAa,CAAC,EAAE,GAAG,CAAC,MAAM,EAAE,MAAM,CAAC,EACnC,SAAS,CAAC,EAAE,GAAG,CAAC,MAAM,EAAE,MAAM,GAAG,IAAI,CAAC,GACrC,IAAI;IAuBP;;OAEG;IACH,sBAAsB,CAAC,SAAS,EAAE,UAAU,EAAE,GAAG,IAAI;IA0BrD;;OAEG;IACH,yBAAyB,CACvB,QAAQ,EAAE,MAAM,EAChB,OAAO,EAAE,MAAM,EACf,UAAU,EAAE,sBAAsB,EAClC,SAAS,CAAC,EAAE,MAAM,GACjB,IAAI;IAuBP;;OAEG;IACH,QAAQ,IAAI,IAAI;IAOhB,OAAO,CAAC,iBAAiB;IAyBzB,OAAO,CAAC,eAAe;IAevB,OAAO,CAAC,yBAAyB;CAclC"}