@decaf-ts/for-fabric 0.0.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (205) hide show
  1. package/LICENSE.md +22 -0
  2. package/README.md +647 -0
  3. package/dist/for-fabric.cjs +6223 -0
  4. package/dist/for-fabric.esm.cjs +6180 -0
  5. package/lib/client/FabricClientAdapter.cjs +760 -0
  6. package/lib/client/FabricClientAdapter.d.ts +381 -0
  7. package/lib/client/FabricClientDispatch.cjs +186 -0
  8. package/lib/client/FabricClientDispatch.d.ts +125 -0
  9. package/lib/client/FabricClientRepository.cjs +131 -0
  10. package/lib/client/FabricClientRepository.d.ts +100 -0
  11. package/lib/client/erc20/erc20ClientRepository.cjs +343 -0
  12. package/lib/client/erc20/erc20ClientRepository.d.ts +254 -0
  13. package/lib/client/fabric-fs.cjs +234 -0
  14. package/lib/client/fabric-fs.d.ts +92 -0
  15. package/lib/client/index.cjs +30 -0
  16. package/lib/client/index.d.ts +13 -0
  17. package/lib/client/logging.cjs +102 -0
  18. package/lib/client/logging.d.ts +60 -0
  19. package/lib/client/services/LoggedService.cjs +47 -0
  20. package/lib/client/services/LoggedService.d.ts +42 -0
  21. package/lib/client/services/constants.cjs +3 -0
  22. package/lib/client/services/constants.d.ts +15 -0
  23. package/lib/client/services/enrollementService.cjs +344 -0
  24. package/lib/client/services/enrollementService.d.ts +176 -0
  25. package/lib/client/services/index.cjs +18 -0
  26. package/lib/client/services/index.d.ts +1 -0
  27. package/lib/contracts/ContractAdapter.cjs +730 -0
  28. package/lib/contracts/ContractAdapter.d.ts +296 -0
  29. package/lib/contracts/ContractContext.cjs +85 -0
  30. package/lib/contracts/ContractContext.d.ts +64 -0
  31. package/lib/contracts/ContractPrivateDataAdapter.cjs +281 -0
  32. package/lib/contracts/ContractPrivateDataAdapter.d.ts +74 -0
  33. package/lib/contracts/FabricConstruction.cjs +441 -0
  34. package/lib/contracts/FabricConstruction.d.ts +304 -0
  35. package/lib/contracts/FabricContractRepository.cjs +306 -0
  36. package/lib/contracts/FabricContractRepository.d.ts +162 -0
  37. package/lib/contracts/FabricContractRepositoryObservableHandler.cjs +85 -0
  38. package/lib/contracts/FabricContractRepositoryObservableHandler.d.ts +62 -0
  39. package/lib/contracts/FabricContractSequence.cjs +139 -0
  40. package/lib/contracts/FabricContractSequence.d.ts +61 -0
  41. package/lib/contracts/FabricContractStatement.cjs +119 -0
  42. package/lib/contracts/FabricContractStatement.d.ts +34 -0
  43. package/lib/contracts/PrivateSequence.cjs +36 -0
  44. package/lib/contracts/PrivateSequence.d.ts +15 -0
  45. package/lib/contracts/crud/crud-contract.cjs +257 -0
  46. package/lib/contracts/crud/crud-contract.d.ts +168 -0
  47. package/lib/contracts/crud/index.cjs +19 -0
  48. package/lib/contracts/crud/index.d.ts +2 -0
  49. package/lib/contracts/crud/serialized-crud-contract.cjs +172 -0
  50. package/lib/contracts/crud/serialized-crud-contract.d.ts +37 -0
  51. package/lib/contracts/erc20/erc20contract.cjs +569 -0
  52. package/lib/contracts/erc20/erc20contract.d.ts +151 -0
  53. package/lib/contracts/erc20/index.cjs +21 -0
  54. package/lib/contracts/erc20/index.d.ts +2 -0
  55. package/lib/contracts/erc20/models.cjs +209 -0
  56. package/lib/contracts/erc20/models.d.ts +114 -0
  57. package/lib/contracts/index.cjs +32 -0
  58. package/lib/contracts/index.d.ts +15 -0
  59. package/lib/contracts/logging.cjs +96 -0
  60. package/lib/contracts/logging.d.ts +49 -0
  61. package/lib/contracts/private-data.cjs +121 -0
  62. package/lib/contracts/private-data.d.ts +16 -0
  63. package/lib/contracts/types.cjs +3 -0
  64. package/lib/contracts/types.d.ts +26 -0
  65. package/lib/esm/client/FabricClientAdapter.d.ts +381 -0
  66. package/lib/esm/client/FabricClientAdapter.js +723 -0
  67. package/lib/esm/client/FabricClientDispatch.d.ts +125 -0
  68. package/lib/esm/client/FabricClientDispatch.js +182 -0
  69. package/lib/esm/client/FabricClientRepository.d.ts +100 -0
  70. package/lib/esm/client/FabricClientRepository.js +127 -0
  71. package/lib/esm/client/erc20/erc20ClientRepository.d.ts +254 -0
  72. package/lib/esm/client/erc20/erc20ClientRepository.js +339 -0
  73. package/lib/esm/client/fabric-fs.d.ts +92 -0
  74. package/lib/esm/client/fabric-fs.js +191 -0
  75. package/lib/esm/client/index.d.ts +13 -0
  76. package/lib/esm/client/index.js +14 -0
  77. package/lib/esm/client/logging.d.ts +60 -0
  78. package/lib/esm/client/logging.js +98 -0
  79. package/lib/esm/client/services/LoggedService.d.ts +42 -0
  80. package/lib/esm/client/services/LoggedService.js +43 -0
  81. package/lib/esm/client/services/constants.d.ts +15 -0
  82. package/lib/esm/client/services/constants.js +2 -0
  83. package/lib/esm/client/services/enrollementService.d.ts +176 -0
  84. package/lib/esm/client/services/enrollementService.js +337 -0
  85. package/lib/esm/client/services/index.d.ts +1 -0
  86. package/lib/esm/client/services/index.js +2 -0
  87. package/lib/esm/contracts/ContractAdapter.d.ts +296 -0
  88. package/lib/esm/contracts/ContractAdapter.js +724 -0
  89. package/lib/esm/contracts/ContractContext.d.ts +64 -0
  90. package/lib/esm/contracts/ContractContext.js +81 -0
  91. package/lib/esm/contracts/ContractPrivateDataAdapter.d.ts +74 -0
  92. package/lib/esm/contracts/ContractPrivateDataAdapter.js +277 -0
  93. package/lib/esm/contracts/FabricConstruction.d.ts +304 -0
  94. package/lib/esm/contracts/FabricConstruction.js +433 -0
  95. package/lib/esm/contracts/FabricContractRepository.d.ts +162 -0
  96. package/lib/esm/contracts/FabricContractRepository.js +302 -0
  97. package/lib/esm/contracts/FabricContractRepositoryObservableHandler.d.ts +62 -0
  98. package/lib/esm/contracts/FabricContractRepositoryObservableHandler.js +81 -0
  99. package/lib/esm/contracts/FabricContractSequence.d.ts +61 -0
  100. package/lib/esm/contracts/FabricContractSequence.js +135 -0
  101. package/lib/esm/contracts/FabricContractStatement.d.ts +34 -0
  102. package/lib/esm/contracts/FabricContractStatement.js +115 -0
  103. package/lib/esm/contracts/PrivateSequence.d.ts +15 -0
  104. package/lib/esm/contracts/PrivateSequence.js +33 -0
  105. package/lib/esm/contracts/crud/crud-contract.d.ts +168 -0
  106. package/lib/esm/contracts/crud/crud-contract.js +253 -0
  107. package/lib/esm/contracts/crud/index.d.ts +2 -0
  108. package/lib/esm/contracts/crud/index.js +3 -0
  109. package/lib/esm/contracts/crud/serialized-crud-contract.d.ts +37 -0
  110. package/lib/esm/contracts/crud/serialized-crud-contract.js +168 -0
  111. package/lib/esm/contracts/erc20/erc20contract.d.ts +151 -0
  112. package/lib/esm/contracts/erc20/erc20contract.js +565 -0
  113. package/lib/esm/contracts/erc20/index.d.ts +2 -0
  114. package/lib/esm/contracts/erc20/index.js +4 -0
  115. package/lib/esm/contracts/erc20/models.d.ts +114 -0
  116. package/lib/esm/contracts/erc20/models.js +206 -0
  117. package/lib/esm/contracts/index.d.ts +15 -0
  118. package/lib/esm/contracts/index.js +16 -0
  119. package/lib/esm/contracts/logging.d.ts +49 -0
  120. package/lib/esm/contracts/logging.js +92 -0
  121. package/lib/esm/contracts/private-data.d.ts +16 -0
  122. package/lib/esm/contracts/private-data.js +113 -0
  123. package/lib/esm/contracts/types.d.ts +26 -0
  124. package/lib/esm/contracts/types.js +2 -0
  125. package/lib/esm/index.d.ts +8 -0
  126. package/lib/esm/index.js +9 -0
  127. package/lib/esm/shared/ClientSerializer.d.ts +52 -0
  128. package/lib/esm/shared/ClientSerializer.js +80 -0
  129. package/lib/esm/shared/DeterministicSerializer.d.ts +40 -0
  130. package/lib/esm/shared/DeterministicSerializer.js +50 -0
  131. package/lib/esm/shared/SimpleDeterministicSerializer.d.ts +7 -0
  132. package/lib/esm/shared/SimpleDeterministicSerializer.js +42 -0
  133. package/lib/esm/shared/constants.d.ts +39 -0
  134. package/lib/esm/shared/constants.js +42 -0
  135. package/lib/esm/shared/crypto.d.ts +107 -0
  136. package/lib/esm/shared/crypto.js +331 -0
  137. package/lib/esm/shared/decorators.d.ts +24 -0
  138. package/lib/esm/shared/decorators.js +98 -0
  139. package/lib/esm/shared/erc20/erc20-constants.d.ts +25 -0
  140. package/lib/esm/shared/erc20/erc20-constants.js +27 -0
  141. package/lib/esm/shared/errors.d.ts +116 -0
  142. package/lib/esm/shared/errors.js +132 -0
  143. package/lib/esm/shared/events.d.ts +39 -0
  144. package/lib/esm/shared/events.js +47 -0
  145. package/lib/esm/shared/fabric-types.d.ts +33 -0
  146. package/lib/esm/shared/fabric-types.js +2 -0
  147. package/lib/esm/shared/index.d.ts +13 -0
  148. package/lib/esm/shared/index.js +14 -0
  149. package/lib/esm/shared/interfaces/Checkable.d.ts +21 -0
  150. package/lib/esm/shared/interfaces/Checkable.js +2 -0
  151. package/lib/esm/shared/math.d.ts +34 -0
  152. package/lib/esm/shared/math.js +61 -0
  153. package/lib/esm/shared/model/Identity.d.ts +42 -0
  154. package/lib/esm/shared/model/Identity.js +78 -0
  155. package/lib/esm/shared/model/IdentityCredentials.d.ts +41 -0
  156. package/lib/esm/shared/model/IdentityCredentials.js +74 -0
  157. package/lib/esm/shared/model/index.d.ts +1 -0
  158. package/lib/esm/shared/model/index.js +2 -0
  159. package/lib/esm/shared/model/utils.d.ts +60 -0
  160. package/lib/esm/shared/model/utils.js +108 -0
  161. package/lib/esm/shared/types.d.ts +79 -0
  162. package/lib/esm/shared/types.js +2 -0
  163. package/lib/esm/shared/utils.d.ts +55 -0
  164. package/lib/esm/shared/utils.js +148 -0
  165. package/lib/index.cjs +25 -0
  166. package/lib/index.d.ts +8 -0
  167. package/lib/shared/ClientSerializer.cjs +84 -0
  168. package/lib/shared/ClientSerializer.d.ts +52 -0
  169. package/lib/shared/DeterministicSerializer.cjs +54 -0
  170. package/lib/shared/DeterministicSerializer.d.ts +40 -0
  171. package/lib/shared/SimpleDeterministicSerializer.cjs +46 -0
  172. package/lib/shared/SimpleDeterministicSerializer.d.ts +7 -0
  173. package/lib/shared/constants.cjs +45 -0
  174. package/lib/shared/constants.d.ts +39 -0
  175. package/lib/shared/crypto.cjs +369 -0
  176. package/lib/shared/crypto.d.ts +107 -0
  177. package/lib/shared/decorators.cjs +105 -0
  178. package/lib/shared/decorators.d.ts +24 -0
  179. package/lib/shared/erc20/erc20-constants.cjs +30 -0
  180. package/lib/shared/erc20/erc20-constants.d.ts +25 -0
  181. package/lib/shared/errors.cjs +142 -0
  182. package/lib/shared/errors.d.ts +116 -0
  183. package/lib/shared/events.cjs +51 -0
  184. package/lib/shared/events.d.ts +39 -0
  185. package/lib/shared/fabric-types.cjs +4 -0
  186. package/lib/shared/fabric-types.d.ts +33 -0
  187. package/lib/shared/index.cjs +30 -0
  188. package/lib/shared/index.d.ts +13 -0
  189. package/lib/shared/interfaces/Checkable.cjs +3 -0
  190. package/lib/shared/interfaces/Checkable.d.ts +21 -0
  191. package/lib/shared/math.cjs +66 -0
  192. package/lib/shared/math.d.ts +34 -0
  193. package/lib/shared/model/Identity.cjs +81 -0
  194. package/lib/shared/model/Identity.d.ts +42 -0
  195. package/lib/shared/model/IdentityCredentials.cjs +77 -0
  196. package/lib/shared/model/IdentityCredentials.d.ts +41 -0
  197. package/lib/shared/model/index.cjs +18 -0
  198. package/lib/shared/model/index.d.ts +1 -0
  199. package/lib/shared/model/utils.cjs +114 -0
  200. package/lib/shared/model/utils.d.ts +60 -0
  201. package/lib/shared/types.cjs +3 -0
  202. package/lib/shared/types.d.ts +79 -0
  203. package/lib/shared/utils.cjs +185 -0
  204. package/lib/shared/utils.d.ts +55 -0
  205. package/package.json +166 -0
@@ -0,0 +1,125 @@
1
+ import { Dispatch } from "@decaf-ts/core";
2
+ import { Client } from "@grpc/grpc-js";
3
+ import { FabricClientAdapter } from "./FabricClientAdapter";
4
+ /**
5
+ * @description Event dispatcher for Hyperledger Fabric chaincode events
6
+ * @summary Listens for and processes events emitted by Fabric chaincode, dispatching them to registered observers
7
+ * @template PeerConfig - Configuration type for connecting to a Fabric peer
8
+ * @param client - gRPC client for connecting to the Fabric network
9
+ * @class FabricClientDispatch
10
+ * @example
11
+ * ```typescript
12
+ * // Create a new FabricDispatch instance
13
+ * const client = await FabricAdapter.getClient(peerConfig);
14
+ * const dispatch = new FabricDispatch(client);
15
+ *
16
+ * // Configure the dispatch with peer configuration
17
+ * dispatch.configure(peerConfig);
18
+ *
19
+ * // Register an observer for a specific table and event
20
+ * dispatch.observe('users', 'create', (id) => {
21
+ * console.log(`User created: ${id}`);
22
+ * });
23
+ *
24
+ * // Start listening for events
25
+ * await dispatch.start();
26
+ * ```
27
+ * @mermaid
28
+ * sequenceDiagram
29
+ * participant Client
30
+ * participant FabricDispatch
31
+ * participant Gateway
32
+ * participant Network
33
+ * participant Chaincode
34
+ *
35
+ * Client->>FabricDispatch: new FabricDispatch(client)
36
+ * Client->>FabricDispatch: configure(peerConfig)
37
+ * Client->>FabricDispatch: observe(table, event, callback)
38
+ * Client->>FabricDispatch: start()
39
+ * FabricDispatch->>FabricDispatch: initialize()
40
+ * FabricDispatch->>Gateway: getGateway(config, client)
41
+ * Gateway->>Network: getNetwork(channel)
42
+ * Network->>Network: getChaincodeEvents(chaincodeName)
43
+ * FabricDispatch->>FabricDispatch: handleEvents()
44
+ * loop For each event
45
+ * Chaincode-->>FabricDispatch: ChaincodeEvent
46
+ * FabricDispatch->>FabricDispatch: parseEventName(eventName)
47
+ * FabricDispatch->>FabricDispatch: parsePayload(payload)
48
+ * FabricDispatch->>FabricDispatch: updateObservers(table, event, id)
49
+ * FabricDispatch-->>Client: callback(id)
50
+ * end
51
+ */
52
+ export declare class FabricClientDispatch extends Dispatch {
53
+ protected client: Client;
54
+ /**
55
+ * @description Event listening stack for chaincode events
56
+ */
57
+ private listeningStack?;
58
+ /**
59
+ * @description Text decoder for converting event payloads from bytes to strings
60
+ */
61
+ private decoder;
62
+ /**
63
+ * @description Creates a new FabricDispatch instance
64
+ * @summary Initializes a dispatcher for Fabric chaincode events
65
+ * @param {Client} client - gRPC client for connecting to the Fabric network
66
+ */
67
+ constructor(client: Client);
68
+ /**
69
+ * @description Closes the event listening connection
70
+ * @summary Stops listening for chaincode events and releases resources
71
+ * @return {Promise<void>} Promise that resolves when the connection is closed
72
+ */
73
+ close(): Promise<void>;
74
+ /**
75
+ * @description Parses event payload from binary format
76
+ * @summary Converts a Uint8Array containing JSON to an object with an id property
77
+ * @param {Uint8Array} jsonBytes - The binary payload from the chaincode event
78
+ * @return {{ id: string }} The parsed payload containing the record ID
79
+ */
80
+ private parsePayload;
81
+ /**
82
+ * @description Starts observing an adapter
83
+ * @summary Connects this dispatch to an adapter to monitor its operations
84
+ * @param {Adapter<any, any, any, any>} observer - The adapter to observe
85
+ * @return {void}
86
+ */
87
+ observe(observer: FabricClientAdapter): void;
88
+ /**
89
+ * @description Updates observers about a database event
90
+ * @summary Notifies observers about a change in the database
91
+ * @param {string} table - The name of the table where the change occurred
92
+ * @param {OperationKeys|BulkCrudOperationKeys|string} event - The type of operation that occurred
93
+ * @param {any} payload - The event payload
94
+ * @return {Promise<void>} A promise that resolves when all observers have been notified
95
+ */
96
+ updateObservers(table: string, event: string, payload: any): Promise<void>;
97
+ /**
98
+ * @description Processes incoming chaincode events
99
+ * @summary Listens for events from the chaincode and dispatches them to registered observers
100
+ * @return {Promise<void>} Promise that resolves when event handling stops
101
+ * @mermaid
102
+ * sequenceDiagram
103
+ * participant FabricDispatch
104
+ * participant EventStack
105
+ * participant EventParser
106
+ * participant Observers
107
+ *
108
+ * FabricDispatch->>FabricDispatch: handleEvents()
109
+ * FabricDispatch->>EventStack: for await (const evt of listeningStack)
110
+ * EventStack-->>FabricDispatch: ChaincodeEvent
111
+ * FabricDispatch->>EventParser: parseEventName(evt.eventName)
112
+ * EventParser-->>FabricDispatch: { table, event, owner }
113
+ * FabricDispatch->>FabricDispatch: Check if event is for this MSP
114
+ * FabricDispatch->>FabricDispatch: parsePayload(evt.payload)
115
+ * FabricDispatch->>Observers: updateObservers(table, event, payload.id)
116
+ * Observers-->>FabricDispatch: Callbacks executed
117
+ */
118
+ protected handleEvents(): Promise<void>;
119
+ /**
120
+ * @description Initializes the event listener
121
+ * @summary Sets up the connection to the Fabric network and starts listening for chaincode events
122
+ * @return {Promise<void>} Promise that resolves when initialization is complete
123
+ */
124
+ protected initialize(): Promise<void>;
125
+ }
@@ -0,0 +1,182 @@
1
+ import { Adapter, Dispatch, UnsupportedError } from "@decaf-ts/core";
2
+ import { FabricClientAdapter } from "./FabricClientAdapter.js";
3
+ import { InternalError } from "@decaf-ts/db-decorators";
4
+ import { parseEventName } from "./../shared/events.js";
5
+ /**
6
+ * @description Event dispatcher for Hyperledger Fabric chaincode events
7
+ * @summary Listens for and processes events emitted by Fabric chaincode, dispatching them to registered observers
8
+ * @template PeerConfig - Configuration type for connecting to a Fabric peer
9
+ * @param client - gRPC client for connecting to the Fabric network
10
+ * @class FabricClientDispatch
11
+ * @example
12
+ * ```typescript
13
+ * // Create a new FabricDispatch instance
14
+ * const client = await FabricAdapter.getClient(peerConfig);
15
+ * const dispatch = new FabricDispatch(client);
16
+ *
17
+ * // Configure the dispatch with peer configuration
18
+ * dispatch.configure(peerConfig);
19
+ *
20
+ * // Register an observer for a specific table and event
21
+ * dispatch.observe('users', 'create', (id) => {
22
+ * console.log(`User created: ${id}`);
23
+ * });
24
+ *
25
+ * // Start listening for events
26
+ * await dispatch.start();
27
+ * ```
28
+ * @mermaid
29
+ * sequenceDiagram
30
+ * participant Client
31
+ * participant FabricDispatch
32
+ * participant Gateway
33
+ * participant Network
34
+ * participant Chaincode
35
+ *
36
+ * Client->>FabricDispatch: new FabricDispatch(client)
37
+ * Client->>FabricDispatch: configure(peerConfig)
38
+ * Client->>FabricDispatch: observe(table, event, callback)
39
+ * Client->>FabricDispatch: start()
40
+ * FabricDispatch->>FabricDispatch: initialize()
41
+ * FabricDispatch->>Gateway: getGateway(config, client)
42
+ * Gateway->>Network: getNetwork(channel)
43
+ * Network->>Network: getChaincodeEvents(chaincodeName)
44
+ * FabricDispatch->>FabricDispatch: handleEvents()
45
+ * loop For each event
46
+ * Chaincode-->>FabricDispatch: ChaincodeEvent
47
+ * FabricDispatch->>FabricDispatch: parseEventName(eventName)
48
+ * FabricDispatch->>FabricDispatch: parsePayload(payload)
49
+ * FabricDispatch->>FabricDispatch: updateObservers(table, event, id)
50
+ * FabricDispatch-->>Client: callback(id)
51
+ * end
52
+ */
53
+ export class FabricClientDispatch extends Dispatch {
54
+ /**
55
+ * @description Creates a new FabricDispatch instance
56
+ * @summary Initializes a dispatcher for Fabric chaincode events
57
+ * @param {Client} client - gRPC client for connecting to the Fabric network
58
+ */
59
+ constructor(client) {
60
+ super();
61
+ this.client = client;
62
+ /**
63
+ * @description Text decoder for converting event payloads from bytes to strings
64
+ */
65
+ this.decoder = new TextDecoder("utf8");
66
+ }
67
+ /**
68
+ * @description Closes the event listening connection
69
+ * @summary Stops listening for chaincode events and releases resources
70
+ * @return {Promise<void>} Promise that resolves when the connection is closed
71
+ */
72
+ async close() {
73
+ if (this.listeningStack)
74
+ this.listeningStack.close();
75
+ }
76
+ /**
77
+ * @description Parses event payload from binary format
78
+ * @summary Converts a Uint8Array containing JSON to an object with an id property
79
+ * @param {Uint8Array} jsonBytes - The binary payload from the chaincode event
80
+ * @return {{ id: string }} The parsed payload containing the record ID
81
+ */
82
+ parsePayload(jsonBytes) {
83
+ const json = this.decoder.decode(jsonBytes);
84
+ return JSON.parse(json);
85
+ }
86
+ /**
87
+ * @description Starts observing an adapter
88
+ * @summary Connects this dispatch to an adapter to monitor its operations
89
+ * @param {Adapter<any, any, any, any>} observer - The adapter to observe
90
+ * @return {void}
91
+ */
92
+ observe(observer) {
93
+ if (!(observer instanceof FabricClientAdapter))
94
+ throw new UnsupportedError("Only FabricClientAdapter can be observed by dispatch");
95
+ this.adapter = observer;
96
+ this.models = Adapter.models(this.adapter.alias);
97
+ this.initialize().then(() => this.log.verbose(`Dispatch initialized for ${this.adapter.alias} adapter`));
98
+ }
99
+ /**
100
+ * @description Updates observers about a database event
101
+ * @summary Notifies observers about a change in the database
102
+ * @param {string} table - The name of the table where the change occurred
103
+ * @param {OperationKeys|BulkCrudOperationKeys|string} event - The type of operation that occurred
104
+ * @param {any} payload - The event payload
105
+ * @return {Promise<void>} A promise that resolves when all observers have been notified
106
+ */
107
+ async updateObservers(table, event, payload) {
108
+ if (!this.adapter) {
109
+ this.log.verbose(`No adapter observed for dispatch; skipping observer update for ${table}:${event}`);
110
+ return;
111
+ }
112
+ try {
113
+ await this.adapter.refresh(table, event, payload.id ? payload.id : undefined, payload);
114
+ }
115
+ catch (e) {
116
+ throw new InternalError(`Failed to refresh dispatch: ${e}`);
117
+ }
118
+ }
119
+ /**
120
+ * @description Processes incoming chaincode events
121
+ * @summary Listens for events from the chaincode and dispatches them to registered observers
122
+ * @return {Promise<void>} Promise that resolves when event handling stops
123
+ * @mermaid
124
+ * sequenceDiagram
125
+ * participant FabricDispatch
126
+ * participant EventStack
127
+ * participant EventParser
128
+ * participant Observers
129
+ *
130
+ * FabricDispatch->>FabricDispatch: handleEvents()
131
+ * FabricDispatch->>EventStack: for await (const evt of listeningStack)
132
+ * EventStack-->>FabricDispatch: ChaincodeEvent
133
+ * FabricDispatch->>EventParser: parseEventName(evt.eventName)
134
+ * EventParser-->>FabricDispatch: { table, event, owner }
135
+ * FabricDispatch->>FabricDispatch: Check if event is for this MSP
136
+ * FabricDispatch->>FabricDispatch: parsePayload(evt.payload)
137
+ * FabricDispatch->>Observers: updateObservers(table, event, payload.id)
138
+ * Observers-->>FabricDispatch: Callbacks executed
139
+ */
140
+ async handleEvents() {
141
+ if (!this.listeningStack)
142
+ throw new InternalError(`Event stack not initialized. Ensure that "startListening" is called before attempting this operation.`);
143
+ if (!this.adapter || !this.adapter.config)
144
+ throw new InternalError(`No adapter found. should be impossible`);
145
+ const log = this.log.for(this.handleEvents);
146
+ log.info(`Listening for incoming events on chaincode "${this.adapter.config.chaincodeName}" on channel "${this.adapter.config.channel}"...`);
147
+ try {
148
+ for await (const evt of this.listeningStack) {
149
+ const { table, event, owner } = parseEventName(evt.eventName);
150
+ if (owner && owner !== this.adapter.config?.mspId)
151
+ continue;
152
+ const payload = this.parsePayload(evt.payload);
153
+ try {
154
+ await this.updateObservers(table ? table : this.models[0].name, event, payload);
155
+ }
156
+ catch (e) {
157
+ log.error(`Failed update observables for table ${table} event ${event} id: ${payload.id}: ${e}`);
158
+ }
159
+ }
160
+ }
161
+ catch (e) {
162
+ log.error(`Failed to read event for chaincode "${this.adapter.config.chaincodeName}" on channel "${this.adapter.config.channel}": ${e}`);
163
+ await this.close();
164
+ }
165
+ }
166
+ /**
167
+ * @description Initializes the event listener
168
+ * @summary Sets up the connection to the Fabric network and starts listening for chaincode events
169
+ * @return {Promise<void>} Promise that resolves when initialization is complete
170
+ */
171
+ async initialize() {
172
+ if (!this.adapter)
173
+ throw new InternalError(`No adapter or config observed for dispatch`);
174
+ const gateway = await FabricClientAdapter.getGateway(this.adapter.config, this.client);
175
+ const network = gateway.getNetwork(this.adapter.config.channel);
176
+ if (!this.adapter)
177
+ throw new InternalError(`No adapter observed for dispatch`);
178
+ this.listeningStack = await network.getChaincodeEvents(this.adapter.config.chaincodeName);
179
+ this.handleEvents();
180
+ }
181
+ }
182
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"FabricClientDispatch.js","sourceRoot":"","sources":["../../../src/client/FabricClientDispatch.ts"],"names":[],"mappings":"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","sourcesContent":["import { Adapter, Dispatch, UnsupportedError } from \"@decaf-ts/core\";\nimport { PeerConfig } from \"../shared/types\";\nimport { Client } from \"@grpc/grpc-js\";\nimport { FabricClientAdapter } from \"./FabricClientAdapter\";\nimport { InternalError } from \"@decaf-ts/db-decorators\";\nimport {\n  ChaincodeEvent,\n  CloseableAsyncIterable,\n} from \"@hyperledger/fabric-gateway\";\nimport { parseEventName } from \"../shared/events\";\n\n/**\n * @description Event dispatcher for Hyperledger Fabric chaincode events\n * @summary Listens for and processes events emitted by Fabric chaincode, dispatching them to registered observers\n * @template PeerConfig - Configuration type for connecting to a Fabric peer\n * @param client - gRPC client for connecting to the Fabric network\n * @class FabricClientDispatch\n * @example\n * ```typescript\n * // Create a new FabricDispatch instance\n * const client = await FabricAdapter.getClient(peerConfig);\n * const dispatch = new FabricDispatch(client);\n *\n * // Configure the dispatch with peer configuration\n * dispatch.configure(peerConfig);\n *\n * // Register an observer for a specific table and event\n * dispatch.observe('users', 'create', (id) => {\n *   console.log(`User created: ${id}`);\n * });\n *\n * // Start listening for events\n * await dispatch.start();\n * ```\n * @mermaid\n * sequenceDiagram\n *   participant Client\n *   participant FabricDispatch\n *   participant Gateway\n *   participant Network\n *   participant Chaincode\n *\n *   Client->>FabricDispatch: new FabricDispatch(client)\n *   Client->>FabricDispatch: configure(peerConfig)\n *   Client->>FabricDispatch: observe(table, event, callback)\n *   Client->>FabricDispatch: start()\n *   FabricDispatch->>FabricDispatch: initialize()\n *   FabricDispatch->>Gateway: getGateway(config, client)\n *   Gateway->>Network: getNetwork(channel)\n *   Network->>Network: getChaincodeEvents(chaincodeName)\n *   FabricDispatch->>FabricDispatch: handleEvents()\n *   loop For each event\n *     Chaincode-->>FabricDispatch: ChaincodeEvent\n *     FabricDispatch->>FabricDispatch: parseEventName(eventName)\n *     FabricDispatch->>FabricDispatch: parsePayload(payload)\n *     FabricDispatch->>FabricDispatch: updateObservers(table, event, id)\n *     FabricDispatch-->>Client: callback(id)\n *   end\n */\nexport class FabricClientDispatch extends Dispatch {\n  /**\n   * @description Event listening stack for chaincode events\n   */\n  private listeningStack?: CloseableAsyncIterable<ChaincodeEvent>;\n\n  /**\n   * @description Text decoder for converting event payloads from bytes to strings\n   */\n  private decoder = new TextDecoder(\"utf8\");\n\n  /**\n   * @description Creates a new FabricDispatch instance\n   * @summary Initializes a dispatcher for Fabric chaincode events\n   * @param {Client} client - gRPC client for connecting to the Fabric network\n   */\n  constructor(protected client: Client) {\n    super();\n  }\n\n  /**\n   * @description Closes the event listening connection\n   * @summary Stops listening for chaincode events and releases resources\n   * @return {Promise<void>} Promise that resolves when the connection is closed\n   */\n  override async close() {\n    if (this.listeningStack) this.listeningStack.close();\n  }\n\n  /**\n   * @description Parses event payload from binary format\n   * @summary Converts a Uint8Array containing JSON to an object with an id property\n   * @param {Uint8Array} jsonBytes - The binary payload from the chaincode event\n   * @return {{ id: string }} The parsed payload containing the record ID\n   */\n  private parsePayload(jsonBytes: Uint8Array): { id: string } {\n    const json = this.decoder.decode(jsonBytes);\n    return JSON.parse(json);\n  }\n\n  /**\n   * @description Starts observing an adapter\n   * @summary Connects this dispatch to an adapter to monitor its operations\n   * @param {Adapter<any, any, any, any>} observer - The adapter to observe\n   * @return {void}\n   */\n  override observe(observer: FabricClientAdapter): void {\n    if (!(observer instanceof FabricClientAdapter))\n      throw new UnsupportedError(\n        \"Only FabricClientAdapter can be observed by dispatch\"\n      );\n    this.adapter = observer;\n    this.models = Adapter.models(this.adapter.alias);\n    this.initialize().then(() =>\n      this.log.verbose(\n        `Dispatch initialized for ${this.adapter!.alias} adapter`\n      )\n    );\n  }\n\n  /**\n   * @description Updates observers about a database event\n   * @summary Notifies observers about a change in the database\n   * @param {string} table - The name of the table where the change occurred\n   * @param {OperationKeys|BulkCrudOperationKeys|string} event - The type of operation that occurred\n   * @param {any} payload - The event payload\n   * @return {Promise<void>} A promise that resolves when all observers have been notified\n   */\n  override async updateObservers(\n    table: string,\n    event: string,\n    payload: any\n  ): Promise<void> {\n    if (!this.adapter) {\n      this.log.verbose(\n        `No adapter observed for dispatch; skipping observer update for ${table}:${event}`\n      );\n      return;\n    }\n    try {\n      await this.adapter.refresh(\n        table,\n        event,\n        payload.id ? payload.id : undefined,\n        payload\n      );\n    } catch (e: unknown) {\n      throw new InternalError(`Failed to refresh dispatch: ${e}`);\n    }\n  }\n\n  /**\n   * @description Processes incoming chaincode events\n   * @summary Listens for events from the chaincode and dispatches them to registered observers\n   * @return {Promise<void>} Promise that resolves when event handling stops\n   * @mermaid\n   * sequenceDiagram\n   *   participant FabricDispatch\n   *   participant EventStack\n   *   participant EventParser\n   *   participant Observers\n   *\n   *   FabricDispatch->>FabricDispatch: handleEvents()\n   *   FabricDispatch->>EventStack: for await (const evt of listeningStack)\n   *   EventStack-->>FabricDispatch: ChaincodeEvent\n   *   FabricDispatch->>EventParser: parseEventName(evt.eventName)\n   *   EventParser-->>FabricDispatch: { table, event, owner }\n   *   FabricDispatch->>FabricDispatch: Check if event is for this MSP\n   *   FabricDispatch->>FabricDispatch: parsePayload(evt.payload)\n   *   FabricDispatch->>Observers: updateObservers(table, event, payload.id)\n   *   Observers-->>FabricDispatch: Callbacks executed\n   */\n  protected async handleEvents(): Promise<void> {\n    if (!this.listeningStack)\n      throw new InternalError(\n        `Event stack not initialized. Ensure that \"startListening\" is called before attempting this operation.`\n      );\n\n    if (!this.adapter || !this.adapter.config)\n      throw new InternalError(`No adapter found. should be impossible`);\n\n    const log = this.log.for(this.handleEvents);\n    log.info(\n      `Listening for incoming events on chaincode \"${this.adapter.config.chaincodeName}\" on channel \"${this.adapter.config.channel}\"...`\n    );\n\n    try {\n      for await (const evt of this.listeningStack) {\n        const { table, event, owner } = parseEventName(evt.eventName);\n        if (owner && owner !== this.adapter.config?.mspId) continue;\n        const payload: { id: string } = this.parsePayload(evt.payload);\n        try {\n          await this.updateObservers(\n            table ? table : this.models[0].name,\n            event,\n            payload\n          );\n        } catch (e: unknown) {\n          log.error(\n            `Failed update observables for table ${table} event ${event} id: ${payload.id}: ${e}`\n          );\n        }\n      }\n    } catch (e: any) {\n      log.error(\n        `Failed to read event for chaincode \"${this.adapter.config.chaincodeName}\" on channel \"${this.adapter.config.channel}\": ${e}`\n      );\n      await this.close();\n    }\n  }\n\n  /**\n   * @description Initializes the event listener\n   * @summary Sets up the connection to the Fabric network and starts listening for chaincode events\n   * @return {Promise<void>} Promise that resolves when initialization is complete\n   */\n  protected override async initialize(): Promise<void> {\n    if (!this.adapter)\n      throw new InternalError(`No adapter or config observed for dispatch`);\n    const gateway = await FabricClientAdapter.getGateway(\n      this.adapter.config as PeerConfig,\n      this.client\n    );\n    const network = gateway.getNetwork(this.adapter.config.channel);\n    if (!this.adapter)\n      throw new InternalError(`No adapter observed for dispatch`);\n    this.listeningStack = await network.getChaincodeEvents(\n      this.adapter.config.chaincodeName\n    );\n    this.handleEvents();\n  }\n}\n"]}
@@ -0,0 +1,100 @@
1
+ import { Adapter, Repository } from "@decaf-ts/core";
2
+ import { Constructor, Model } from "@decaf-ts/decorator-validation";
3
+ import { MangoQuery } from "@decaf-ts/for-couchdb";
4
+ import { Context } from "@decaf-ts/db-decorators";
5
+ import { FabricFlags } from "../shared";
6
+ /**
7
+ * @description Repository implementation for Fabric client operations
8
+ * @summary Extends the generic Repository to prepare context and arguments for CRUD operations executed via a Fabric client Adapter, wiring RepositoryFlags and Fabric-specific overrides.
9
+ * @template M extends Model - The model type handled by this repository
10
+ * @param {Adapter<any, MangoQuery, FabricFlags, Context<FabricFlags>>} [adapter] - Optional adapter instance used to execute operations
11
+ * @param {Constructor<M>} [clazz] - Optional model constructor used by the repository
12
+ * @return {void}
13
+ * @class FabricClientRepository
14
+ * @example
15
+ * import { Repository } from "@decaf-ts/core";
16
+ * import { FabricClientRepository } from "@decaf-ts/for-fabric";
17
+ *
18
+ * class User extends Model { id!: string; name!: string; }
19
+ * const repo = new FabricClientRepository<User>();
20
+ * const created = await repo.create(new User({ id: "1", name: "Alice" }));
21
+ * const loaded = await repo.read("1");
22
+ *
23
+ * @mermaid
24
+ * sequenceDiagram
25
+ * participant App
26
+ * participant Repo as FabricClientRepository
27
+ * participant Adapter
28
+ * App->>Repo: create(model)
29
+ * Repo->>Repo: createPrefix(model, ...args)
30
+ * Repo->>Adapter: create(table, id, model, flags)
31
+ * Adapter-->>Repo: result
32
+ * Repo-->>App: model
33
+ */
34
+ export declare class FabricClientRepository<M extends Model> extends Repository<M, MangoQuery, Adapter<any, any, MangoQuery, FabricFlags, Context<FabricFlags>>> {
35
+ constructor(adapter?: Adapter<any, any, MangoQuery, FabricFlags, Context<FabricFlags>>, clazz?: Constructor<M>);
36
+ /**
37
+ * @description Prepare arguments and context for create
38
+ * @summary Builds repository context and ensures the model is instantiated with the repository's class before delegating to the adapter
39
+ * @param {M} model - The model instance to create
40
+ * @param {...any[]} args - Additional operation arguments and flags
41
+ * @return {...any[]} Tuple containing the prepared model and the processed arguments
42
+ */
43
+ protected createPrefix(model: M, ...args: any[]): Promise<[M, ...any[]]>;
44
+ /**
45
+ * @description Prepare arguments and context for bulk create
46
+ * @summary Resolves repository context for a createAll operation passing through models and processed arguments
47
+ * @param {M[]} models - Array of model instances to create
48
+ * @param {...any} args - Additional operation arguments and flags
49
+ * @return {...any[]} Tuple containing the models array and processed arguments
50
+ */
51
+ protected createAllPrefix(models: M[], ...args: any[]): Promise<any[]>;
52
+ /**
53
+ * @description Prepare arguments and context for read
54
+ * @summary Resolves repository context for a read operation and forwards the key and processed arguments
55
+ * @param {string} key - The model primary key to read
56
+ * @param {...any} args - Additional operation arguments and flags
57
+ * @return {...any[]} Tuple containing the key and processed arguments
58
+ */
59
+ protected readPrefix(key: string, ...args: any[]): Promise<any[]>;
60
+ /**
61
+ * @description Prepare arguments and context for bulk read
62
+ * @summary Resolves repository context for a readAll operation and forwards the keys and processed arguments
63
+ * @param {(string[]|number[])} keys - Array of model primary keys to read
64
+ * @param {...any} args - Additional operation arguments and flags
65
+ * @return {...any[]} Tuple containing the keys and processed arguments
66
+ */
67
+ protected readAllPrefix(keys: string[] | number[], ...args: any[]): Promise<any[]>;
68
+ /**
69
+ * @description Prepare arguments and context for update
70
+ * @summary Resolves repository context for an update operation and forwards the model and processed arguments
71
+ * @param {M} model - The model instance to update
72
+ * @param {...any[]} args - Additional operation arguments and flags
73
+ * @return {...any[]} Tuple containing the model and processed arguments
74
+ */
75
+ protected updatePrefix(model: M, ...args: any[]): Promise<[M, ...args: any[]]>;
76
+ /**
77
+ * @description Prepare arguments and context for bulk update
78
+ * @summary Resolves repository context for an updateAll operation and forwards the models and processed arguments
79
+ * @param {M[]} models - The model instances to update
80
+ * @param {...any} args - Additional operation arguments and flags
81
+ * @return {...any[]} Tuple containing the models and processed arguments
82
+ */
83
+ protected updateAllPrefix(models: M[], ...args: any[]): Promise<any[]>;
84
+ /**
85
+ * @description Prepare arguments and context for delete
86
+ * @summary Resolves repository context for a delete operation, ensures the target exists via read, then forwards key and processed arguments
87
+ * @param {string|number} key - The model primary key to delete
88
+ * @param {...any} args - Additional operation arguments and flags
89
+ * @return {...any[]} Tuple containing the key and processed arguments
90
+ */
91
+ protected deletePrefix(key: any, ...args: any[]): Promise<any[]>;
92
+ /**
93
+ * @description Prepare arguments and context for bulk delete
94
+ * @summary Resolves repository context for a deleteAll operation, validates existence via readAll, then forwards keys and processed arguments
95
+ * @param {(string[]|number[])} keys - The model primary keys to delete
96
+ * @param {...any} args - Additional operation arguments and flags
97
+ * @return {...any[]} Tuple containing the keys and processed arguments
98
+ */
99
+ protected deleteAllPrefix(keys: string[] | number[], ...args: any[]): Promise<any[]>;
100
+ }
@@ -0,0 +1,127 @@
1
+ import { Repository } from "@decaf-ts/core";
2
+ import { Context, OperationKeys, } from "@decaf-ts/db-decorators";
3
+ /**
4
+ * @description Repository implementation for Fabric client operations
5
+ * @summary Extends the generic Repository to prepare context and arguments for CRUD operations executed via a Fabric client Adapter, wiring RepositoryFlags and Fabric-specific overrides.
6
+ * @template M extends Model - The model type handled by this repository
7
+ * @param {Adapter<any, MangoQuery, FabricFlags, Context<FabricFlags>>} [adapter] - Optional adapter instance used to execute operations
8
+ * @param {Constructor<M>} [clazz] - Optional model constructor used by the repository
9
+ * @return {void}
10
+ * @class FabricClientRepository
11
+ * @example
12
+ * import { Repository } from "@decaf-ts/core";
13
+ * import { FabricClientRepository } from "@decaf-ts/for-fabric";
14
+ *
15
+ * class User extends Model { id!: string; name!: string; }
16
+ * const repo = new FabricClientRepository<User>();
17
+ * const created = await repo.create(new User({ id: "1", name: "Alice" }));
18
+ * const loaded = await repo.read("1");
19
+ *
20
+ * @mermaid
21
+ * sequenceDiagram
22
+ * participant App
23
+ * participant Repo as FabricClientRepository
24
+ * participant Adapter
25
+ * App->>Repo: create(model)
26
+ * Repo->>Repo: createPrefix(model, ...args)
27
+ * Repo->>Adapter: create(table, id, model, flags)
28
+ * Adapter-->>Repo: result
29
+ * Repo-->>App: model
30
+ */
31
+ export class FabricClientRepository extends Repository {
32
+ constructor(adapter, clazz) {
33
+ super(adapter, clazz);
34
+ }
35
+ /**
36
+ * @description Prepare arguments and context for create
37
+ * @summary Builds repository context and ensures the model is instantiated with the repository's class before delegating to the adapter
38
+ * @param {M} model - The model instance to create
39
+ * @param {...any[]} args - Additional operation arguments and flags
40
+ * @return {...any[]} Tuple containing the prepared model and the processed arguments
41
+ */
42
+ async createPrefix(model, ...args) {
43
+ const contextArgs = await Context.args(OperationKeys.CREATE, this.class, args, this.adapter, this._overrides || {});
44
+ model = new this.class(model);
45
+ return [model, ...contextArgs.args];
46
+ }
47
+ /**
48
+ * @description Prepare arguments and context for bulk create
49
+ * @summary Resolves repository context for a createAll operation passing through models and processed arguments
50
+ * @param {M[]} models - Array of model instances to create
51
+ * @param {...any} args - Additional operation arguments and flags
52
+ * @return {...any[]} Tuple containing the models array and processed arguments
53
+ */
54
+ async createAllPrefix(models, ...args) {
55
+ const contextArgs = await Context.args(OperationKeys.CREATE, this.class, args, this.adapter, this._overrides || {});
56
+ return [models, ...contextArgs.args];
57
+ }
58
+ /**
59
+ * @description Prepare arguments and context for read
60
+ * @summary Resolves repository context for a read operation and forwards the key and processed arguments
61
+ * @param {string} key - The model primary key to read
62
+ * @param {...any} args - Additional operation arguments and flags
63
+ * @return {...any[]} Tuple containing the key and processed arguments
64
+ */
65
+ async readPrefix(key, ...args) {
66
+ const contextArgs = await Context.args(OperationKeys.READ, this.class, args, this.adapter, this._overrides || {});
67
+ return [key, ...contextArgs.args];
68
+ }
69
+ /**
70
+ * @description Prepare arguments and context for bulk read
71
+ * @summary Resolves repository context for a readAll operation and forwards the keys and processed arguments
72
+ * @param {(string[]|number[])} keys - Array of model primary keys to read
73
+ * @param {...any} args - Additional operation arguments and flags
74
+ * @return {...any[]} Tuple containing the keys and processed arguments
75
+ */
76
+ async readAllPrefix(keys, ...args) {
77
+ const contextArgs = await Context.args(OperationKeys.READ, this.class, args, this.adapter, this._overrides || {});
78
+ return [keys, ...contextArgs.args];
79
+ }
80
+ /**
81
+ * @description Prepare arguments and context for update
82
+ * @summary Resolves repository context for an update operation and forwards the model and processed arguments
83
+ * @param {M} model - The model instance to update
84
+ * @param {...any[]} args - Additional operation arguments and flags
85
+ * @return {...any[]} Tuple containing the model and processed arguments
86
+ */
87
+ async updatePrefix(model, ...args) {
88
+ const contextArgs = await Context.args(OperationKeys.UPDATE, this.class, args, this.adapter, this._overrides || {});
89
+ return [model, ...contextArgs.args];
90
+ }
91
+ /**
92
+ * @description Prepare arguments and context for bulk update
93
+ * @summary Resolves repository context for an updateAll operation and forwards the models and processed arguments
94
+ * @param {M[]} models - The model instances to update
95
+ * @param {...any} args - Additional operation arguments and flags
96
+ * @return {...any[]} Tuple containing the models and processed arguments
97
+ */
98
+ async updateAllPrefix(models, ...args) {
99
+ const contextArgs = await Context.args(OperationKeys.UPDATE, this.class, args, this.adapter, this._overrides || {});
100
+ return [models, ...contextArgs.args];
101
+ }
102
+ /**
103
+ * @description Prepare arguments and context for delete
104
+ * @summary Resolves repository context for a delete operation, ensures the target exists via read, then forwards key and processed arguments
105
+ * @param {string|number} key - The model primary key to delete
106
+ * @param {...any} args - Additional operation arguments and flags
107
+ * @return {...any[]} Tuple containing the key and processed arguments
108
+ */
109
+ async deletePrefix(key, ...args) {
110
+ const contextArgs = await Context.args(OperationKeys.DELETE, this.class, args, this.adapter, this._overrides || {});
111
+ await this.read(key, ...contextArgs.args);
112
+ return [key, ...contextArgs.args];
113
+ }
114
+ /**
115
+ * @description Prepare arguments and context for bulk delete
116
+ * @summary Resolves repository context for a deleteAll operation, validates existence via readAll, then forwards keys and processed arguments
117
+ * @param {(string[]|number[])} keys - The model primary keys to delete
118
+ * @param {...any} args - Additional operation arguments and flags
119
+ * @return {...any[]} Tuple containing the keys and processed arguments
120
+ */
121
+ async deleteAllPrefix(keys, ...args) {
122
+ const contextArgs = await Context.args(OperationKeys.DELETE, this.class, args, this.adapter, this._overrides || {});
123
+ await this.readAll(keys, ...contextArgs.args);
124
+ return [keys, ...contextArgs.args];
125
+ }
126
+ }
127
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"FabricClientRepository.js","sourceRoot":"","sources":["../../../src/client/FabricClientRepository.ts"],"names":[],"mappings":"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","sourcesContent":["import { Adapter, Repository } from \"@decaf-ts/core\";\nimport { Constructor, Model } from \"@decaf-ts/decorator-validation\";\nimport { MangoQuery } from \"@decaf-ts/for-couchdb\";\nimport {\n  Context,\n  OperationKeys,\n  RepositoryFlags,\n} from \"@decaf-ts/db-decorators\";\nimport { FabricFlags } from \"../shared\";\n\n/**\n * @description Repository implementation for Fabric client operations\n * @summary Extends the generic Repository to prepare context and arguments for CRUD operations executed via a Fabric client Adapter, wiring RepositoryFlags and Fabric-specific overrides.\n * @template M extends Model - The model type handled by this repository\n * @param {Adapter<any, MangoQuery, FabricFlags, Context<FabricFlags>>} [adapter] - Optional adapter instance used to execute operations\n * @param {Constructor<M>} [clazz] - Optional model constructor used by the repository\n * @return {void}\n * @class FabricClientRepository\n * @example\n * import { Repository } from \"@decaf-ts/core\";\n * import { FabricClientRepository } from \"@decaf-ts/for-fabric\";\n *\n * class User extends Model { id!: string; name!: string; }\n * const repo = new FabricClientRepository<User>();\n * const created = await repo.create(new User({ id: \"1\", name: \"Alice\" }));\n * const loaded = await repo.read(\"1\");\n *\n * @mermaid\n * sequenceDiagram\n *   participant App\n *   participant Repo as FabricClientRepository\n *   participant Adapter\n *   App->>Repo: create(model)\n *   Repo->>Repo: createPrefix(model, ...args)\n *   Repo->>Adapter: create(table, id, model, flags)\n *   Adapter-->>Repo: result\n *   Repo-->>App: model\n */\nexport class FabricClientRepository<M extends Model> extends Repository<\n  M,\n  MangoQuery,\n  Adapter<any, any, MangoQuery, FabricFlags, Context<FabricFlags>>\n> {\n  constructor(\n    adapter?: Adapter<any, any, MangoQuery, FabricFlags, Context<FabricFlags>>,\n    clazz?: Constructor<M>\n  ) {\n    super(adapter, clazz);\n  }\n\n  /**\n   * @description Prepare arguments and context for create\n   * @summary Builds repository context and ensures the model is instantiated with the repository's class before delegating to the adapter\n   * @param {M} model - The model instance to create\n   * @param {...any[]} args - Additional operation arguments and flags\n   * @return {...any[]} Tuple containing the prepared model and the processed arguments\n   */\n  protected override async createPrefix(\n    model: M,\n    ...args: any[]\n  ): Promise<[M, ...any[]]> {\n    const contextArgs = await Context.args<\n      M,\n      Context<RepositoryFlags>,\n      RepositoryFlags\n    >(\n      OperationKeys.CREATE,\n      this.class,\n      args,\n      this.adapter,\n      this._overrides || {}\n    );\n    model = new this.class(model);\n    return [model, ...contextArgs.args];\n  }\n\n  /**\n   * @description Prepare arguments and context for bulk create\n   * @summary Resolves repository context for a createAll operation passing through models and processed arguments\n   * @param {M[]} models - Array of model instances to create\n   * @param {...any} args - Additional operation arguments and flags\n   * @return {...any[]} Tuple containing the models array and processed arguments\n   */\n  protected override async createAllPrefix(models: M[], ...args: any[]) {\n    const contextArgs = await Context.args(\n      OperationKeys.CREATE,\n      this.class,\n      args,\n      this.adapter,\n      this._overrides || {}\n    );\n    return [models, ...contextArgs.args];\n  }\n\n  /**\n   * @description Prepare arguments and context for read\n   * @summary Resolves repository context for a read operation and forwards the key and processed arguments\n   * @param {string} key - The model primary key to read\n   * @param {...any} args - Additional operation arguments and flags\n   * @return {...any[]} Tuple containing the key and processed arguments\n   */\n  protected override async readPrefix(key: string, ...args: any[]) {\n    const contextArgs = await Context.args(\n      OperationKeys.READ,\n      this.class,\n      args,\n      this.adapter,\n      this._overrides || {}\n    );\n    return [key, ...contextArgs.args];\n  }\n\n  /**\n   * @description Prepare arguments and context for bulk read\n   * @summary Resolves repository context for a readAll operation and forwards the keys and processed arguments\n   * @param {(string[]|number[])} keys - Array of model primary keys to read\n   * @param {...any} args - Additional operation arguments and flags\n   * @return {...any[]} Tuple containing the keys and processed arguments\n   */\n  protected override async readAllPrefix(\n    keys: string[] | number[],\n    ...args: any[]\n  ) {\n    const contextArgs = await Context.args(\n      OperationKeys.READ,\n      this.class,\n      args,\n      this.adapter,\n      this._overrides || {}\n    );\n    return [keys, ...contextArgs.args];\n  }\n\n  /**\n   * @description Prepare arguments and context for update\n   * @summary Resolves repository context for an update operation and forwards the model and processed arguments\n   * @param {M} model - The model instance to update\n   * @param {...any[]} args - Additional operation arguments and flags\n   * @return {...any[]} Tuple containing the model and processed arguments\n   */\n  protected override async updatePrefix(\n    model: M,\n    ...args: any[]\n  ): Promise<[M, ...args: any[]]> {\n    const contextArgs = await Context.args(\n      OperationKeys.UPDATE,\n      this.class,\n      args,\n      this.adapter,\n      this._overrides || {}\n    );\n    return [model, ...contextArgs.args];\n  }\n\n  /**\n   * @description Prepare arguments and context for bulk update\n   * @summary Resolves repository context for an updateAll operation and forwards the models and processed arguments\n   * @param {M[]} models - The model instances to update\n   * @param {...any} args - Additional operation arguments and flags\n   * @return {...any[]} Tuple containing the models and processed arguments\n   */\n  protected override async updateAllPrefix(\n    models: M[],\n    ...args: any[]\n  ): Promise<any[]> {\n    const contextArgs = await Context.args(\n      OperationKeys.UPDATE,\n      this.class,\n      args,\n      this.adapter,\n      this._overrides || {}\n    );\n    return [models, ...contextArgs.args];\n  }\n\n  /**\n   * @description Prepare arguments and context for delete\n   * @summary Resolves repository context for a delete operation, ensures the target exists via read, then forwards key and processed arguments\n   * @param {string|number} key - The model primary key to delete\n   * @param {...any} args - Additional operation arguments and flags\n   * @return {...any[]} Tuple containing the key and processed arguments\n   */\n  protected override async deletePrefix(key: any, ...args: any[]) {\n    const contextArgs = await Context.args(\n      OperationKeys.DELETE,\n      this.class,\n      args,\n      this.adapter,\n      this._overrides || {}\n    );\n    await this.read(key, ...contextArgs.args);\n    return [key, ...contextArgs.args];\n  }\n\n  /**\n   * @description Prepare arguments and context for bulk delete\n   * @summary Resolves repository context for a deleteAll operation, validates existence via readAll, then forwards keys and processed arguments\n   * @param {(string[]|number[])} keys - The model primary keys to delete\n   * @param {...any} args - Additional operation arguments and flags\n   * @return {...any[]} Tuple containing the keys and processed arguments\n   */\n  protected override async deleteAllPrefix(\n    keys: string[] | number[],\n    ...args: any[]\n  ) {\n    const contextArgs = await Context.args(\n      OperationKeys.DELETE,\n      this.class,\n      args,\n      this.adapter,\n      this._overrides || {}\n    );\n    await this.readAll(keys, ...contextArgs.args);\n    return [keys, ...contextArgs.args];\n  }\n}\n"]}