@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,760 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
19
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
20
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
21
+ else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
22
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
23
+ };
24
+ var __importStar = (this && this.__importStar) || (function () {
25
+ var ownKeys = function(o) {
26
+ ownKeys = Object.getOwnPropertyNames || function (o) {
27
+ var ar = [];
28
+ for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
29
+ return ar;
30
+ };
31
+ return ownKeys(o);
32
+ };
33
+ return function (mod) {
34
+ if (mod && mod.__esModule) return mod;
35
+ var result = {};
36
+ if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
37
+ __setModuleDefault(result, mod);
38
+ return result;
39
+ };
40
+ })();
41
+ var __metadata = (this && this.__metadata) || function (k, v) {
42
+ if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
43
+ };
44
+ Object.defineProperty(exports, "__esModule", { value: true });
45
+ exports.FabricClientAdapter = void 0;
46
+ const for_couchdb_1 = require("@decaf-ts/for-couchdb");
47
+ const grpc_js_1 = require("@grpc/grpc-js");
48
+ const grpc = __importStar(require("@grpc/grpc-js"));
49
+ const decorator_validation_1 = require("@decaf-ts/decorator-validation");
50
+ const logging_1 = require("@decaf-ts/logging");
51
+ const fabric_gateway_1 = require("@hyperledger/fabric-gateway");
52
+ const fabric_fs_1 = require("./fabric-fs.cjs");
53
+ const db_decorators_1 = require("@decaf-ts/db-decorators");
54
+ const core_1 = require("@decaf-ts/core");
55
+ const FabricClientRepository_1 = require("./FabricClientRepository.cjs");
56
+ const constants_1 = require("./../shared/constants.cjs");
57
+ const ClientSerializer_1 = require("./../shared/ClientSerializer.cjs");
58
+ const FabricClientDispatch_1 = require("./FabricClientDispatch.cjs");
59
+ /**
60
+ * @description Adapter for interacting with Hyperledger Fabric networks
61
+ * @summary The FabricAdapter extends CouchDBAdapter to provide a seamless interface for interacting with Hyperledger Fabric networks.
62
+ * It handles connection management, transaction submission, and CRUD operations against Fabric chaincode.
63
+ * @template PeerConfig - Configuration type for connecting to a Fabric peer
64
+ * @template FabricFlags - Flags specific to Fabric operations
65
+ * @template Context<FabricFlags> - Context type containing Fabric-specific flags
66
+ * @param config - Configuration for connecting to a Fabric peer
67
+ * @param alias - Optional alias for the adapter instance
68
+ * @class FabricClientAdapter
69
+ * @example
70
+ * ```typescript
71
+ * // Create a new FabricAdapter instance
72
+ * const config: PeerConfig = {
73
+ * mspId: 'Org1MSP',
74
+ * peerEndpoint: 'localhost:7051',
75
+ * channelName: 'mychannel',
76
+ * chaincodeName: 'mycc',
77
+ * contractName: 'mycontract',
78
+ * tlsCertPath: '/path/to/tls/cert',
79
+ * certDirectoryPath: '/path/to/cert/dir',
80
+ * keyDirectoryPath: '/path/to/key/dir'
81
+ * };
82
+ *
83
+ * const adapter = new FabricAdapter(config, 'org1-adapter');
84
+ *
85
+ * // Use the adapter to interact with the Fabric network
86
+ * const result = await adapter.read('users', 'user1', mySerializer);
87
+ * ```
88
+ * @mermaid
89
+ * sequenceDiagram
90
+ * participant Client
91
+ * participant FabricAdapter
92
+ * participant Gateway
93
+ * participant Network
94
+ * participant Contract
95
+ * participant Chaincode
96
+ *
97
+ * Client->>FabricAdapter: create(tableName, id, model, transient, serializer)
98
+ * FabricAdapter->>FabricAdapter: submitTransaction(OperationKeys.CREATE, [serializedModel], transient)
99
+ * FabricAdapter->>Gateway: connect()
100
+ * Gateway->>Network: getNetwork(channelName)
101
+ * Network->>Contract: getContract(chaincodeName, contractName)
102
+ * FabricAdapter->>Contract: submit(api, proposalOptions)
103
+ * Contract->>Chaincode: invoke
104
+ * Chaincode-->>Contract: response
105
+ * Contract-->>FabricAdapter: result
106
+ * FabricAdapter->>FabricAdapter: decode(result)
107
+ * FabricAdapter->>FabricAdapter: serializer.deserialize(decodedResult)
108
+ * FabricAdapter-->>Client: deserializedResult
109
+ */
110
+ class FabricClientAdapter extends for_couchdb_1.CouchDBAdapter {
111
+ /**
112
+ * @description Static text decoder for converting Uint8Array to string
113
+ */
114
+ static { this.decoder = new TextDecoder("utf8"); }
115
+ static { this.serializer = new ClientSerializer_1.ClientSerializer(); }
116
+ /**
117
+ * @description Static logger instance for the FabricAdapter class
118
+ */
119
+ static { this.log = logging_1.Logging.for(FabricClientAdapter); }
120
+ /**
121
+ * @description Gets the logger instance for this adapter
122
+ * @summary Returns the static logger instance for the FabricAdapter class
123
+ * @return {Logger} The logger instance
124
+ */
125
+ get log() {
126
+ return FabricClientAdapter.log;
127
+ }
128
+ /**
129
+ * @description Creates a new FabricAdapter instance
130
+ * @summary Initializes a new adapter for interacting with a Hyperledger Fabric network
131
+ * @param {PeerConfig} config - Configuration for connecting to a Fabric peer
132
+ * @param {string} [alias] - Optional alias for the adapter instance
133
+ */
134
+ constructor(config, alias) {
135
+ super(config, constants_1.FabricFlavour, alias);
136
+ this.serializer = FabricClientAdapter.serializer;
137
+ }
138
+ /**
139
+ * @description Decodes a Uint8Array to a string
140
+ * @summary Converts binary data received from Fabric to a string using UTF-8 encoding
141
+ * @param {Uint8Array} data - The binary data to decode
142
+ * @return {string} The decoded string
143
+ */
144
+ decode(data) {
145
+ return FabricClientAdapter.decoder.decode(data);
146
+ }
147
+ repository() {
148
+ return FabricClientRepository_1.FabricClientRepository;
149
+ }
150
+ /**
151
+ * @description Creates multiple records in a single transaction
152
+ * @summary Submits a transaction to create multiple records in the Fabric ledger
153
+ * @param {string} tableName - The name of the table/collection
154
+ * @param {string[] | number[]} ids - Array of record identifiers
155
+ * @param {Array<Record<string, any>>} models - Array of record data
156
+ * @param {Record<string, any>} transient - Transient data for the transaction
157
+ * @return {Promise<Array<Record<string, any>>>} Promise resolving to the created records
158
+ */
159
+ async createAll(tableName, ids, models, transient) {
160
+ const log = this.log.for(this.createAll);
161
+ if (ids.length !== models.length)
162
+ throw new db_decorators_1.InternalError(`Ids and models must have the same length: ${ids.length} != ${models.length}`);
163
+ log.info(`adding ${ids.length} entries to ${tableName} table`);
164
+ log.verbose(`pks: ${ids}`);
165
+ const result = await this.submitTransaction(db_decorators_1.BulkCrudOperationKeys.CREATE_ALL, [ids, models.map((m) => this.serializer.serialize(m, tableName))], transient);
166
+ try {
167
+ return JSON.parse(this.decode(result)).map((r) => JSON.parse(r));
168
+ }
169
+ catch (e) {
170
+ throw new db_decorators_1.SerializationError(e);
171
+ }
172
+ }
173
+ /**
174
+ * @description Reads multiple records in a single transaction
175
+ * @summary Submits a transaction to read multiple records from the Fabric ledger
176
+ * @param {string} tableName - The name of the table/collection
177
+ * @param {string[] | number[]} ids - Array of record identifiers to read
178
+ * @return {Promise<Array<Record<string, any>>>} Promise resolving to the retrieved records
179
+ */
180
+ async readAll(tableName, ids) {
181
+ const log = this.log.for(this.readAll);
182
+ log.info(`reading ${ids.length} entries to ${tableName} table`);
183
+ log.verbose(`pks: ${ids}`);
184
+ const result = await this.submitTransaction(db_decorators_1.BulkCrudOperationKeys.READ_ALL, [ids]);
185
+ try {
186
+ return JSON.parse(this.decode(result)).map((r) => JSON.parse(r));
187
+ }
188
+ catch (e) {
189
+ throw new db_decorators_1.SerializationError(e);
190
+ }
191
+ }
192
+ /**
193
+ * @description Updates multiple records in a single transaction
194
+ * @summary Submits a transaction to update multiple records in the Fabric ledger
195
+ * @param {string} tableName - The name of the table/collection
196
+ * @param {string[] | number[]} ids - Array of record identifiers
197
+ * @param {Array<Record<string, any>>} models - Array of updated record data
198
+ * @param {Record<string, any>} transient - Transient data for the transaction
199
+ * @return {Promise<Array<Record<string, any>>>} Promise resolving to the updated records
200
+ */
201
+ async updateAll(tableName, ids, models, transient) {
202
+ const log = this.log.for(this.updateAll);
203
+ if (ids.length !== models.length)
204
+ throw new db_decorators_1.InternalError(`Ids and models must have the same length: ${ids.length} != ${models.length}`);
205
+ log.info(`updating ${ids.length} entries to ${tableName} table`);
206
+ log.verbose(`pks: ${ids}`);
207
+ const result = await this.submitTransaction(db_decorators_1.BulkCrudOperationKeys.UPDATE_ALL, [ids, models.map((m) => this.serializer.serialize(m, tableName))], transient);
208
+ try {
209
+ return JSON.parse(this.decode(result)).map((r) => JSON.parse(r));
210
+ }
211
+ catch (e) {
212
+ throw new db_decorators_1.SerializationError(e);
213
+ }
214
+ }
215
+ /**
216
+ * @description Deletes multiple records in a single transaction
217
+ * @summary Submits a transaction to delete multiple records from the Fabric ledger
218
+ * @param {string} tableName - The name of the table/collection
219
+ * @param {Array<string | number | bigint>} ids - Array of record identifiers to delete
220
+ * @param {Serializer<any>} serializer - Serializer for the model data
221
+ * @return {Promise<Array<Record<string, any>>>} Promise resolving to the deleted records
222
+ */
223
+ async deleteAll(tableName, ids) {
224
+ const log = this.log.for(this.deleteAll);
225
+ log.info(`deleting ${ids.length} entries to ${tableName} table`);
226
+ log.verbose(`pks: ${ids}`);
227
+ const result = await this.submitTransaction(db_decorators_1.BulkCrudOperationKeys.DELETE_ALL, [ids]);
228
+ try {
229
+ return JSON.parse(this.decode(result)).map((r) => JSON.parse(r));
230
+ }
231
+ catch (e) {
232
+ throw new db_decorators_1.SerializationError(e);
233
+ }
234
+ }
235
+ /**
236
+ * @description Prepares a model for persistence
237
+ * @summary Converts a model instance into a format suitable for database storage,
238
+ * handling column mapping and separating transient properties
239
+ * @template M - The model type
240
+ * @param {M} model - The model instance to prepare
241
+ * @param pk - The primary key property name
242
+ * @return The prepared data
243
+ */
244
+ prepare(model, pk) {
245
+ const log = this.log.for(this.prepare);
246
+ const split = (0, db_decorators_1.modelToTransient)(model);
247
+ if (model[core_1.PersistenceKeys.METADATA]) {
248
+ log.silly(`Passing along persistence metadata for ${model[core_1.PersistenceKeys.METADATA]}`);
249
+ Object.defineProperty(split.model, core_1.PersistenceKeys.METADATA, {
250
+ enumerable: false,
251
+ writable: false,
252
+ configurable: true,
253
+ value: model[core_1.PersistenceKeys.METADATA],
254
+ });
255
+ }
256
+ return {
257
+ record: split.model,
258
+ id: model[pk],
259
+ transient: split.transient,
260
+ };
261
+ }
262
+ /**
263
+ * @description Converts database data back into a model instance
264
+ * @summary Reconstructs a model instance from database data, handling column mapping
265
+ * and reattaching transient properties
266
+ * @template M - The model type
267
+ * @param obj - The database record
268
+ * @param {string|Constructor<M>} clazz - The model class or name
269
+ * @param pk - The primary key property name
270
+ * @param {string|number|bigint} id - The primary key value
271
+ * @param [transient] - Transient properties to reattach
272
+ * @return {M} The reconstructed model instance
273
+ */
274
+ revert(obj, clazz, pk, id, transient) {
275
+ const log = this.log.for(this.revert);
276
+ const ob = {};
277
+ ob[pk] = id;
278
+ const m = (typeof clazz === "string" ? decorator_validation_1.Model.build(ob, clazz) : new clazz(ob));
279
+ log.silly(`Rebuilding model ${m.constructor.name} id ${id}`);
280
+ const metadata = obj[core_1.PersistenceKeys.METADATA];
281
+ const result = Object.keys(m).reduce((accum, key) => {
282
+ accum[key] = obj[key];
283
+ return accum;
284
+ }, m);
285
+ if (transient) {
286
+ log.verbose(`re-adding transient properties: ${Object.keys(transient).join(", ")}`);
287
+ Object.entries(transient).forEach(([key, val]) => {
288
+ if (key in result && result[key] !== undefined)
289
+ throw new db_decorators_1.InternalError(`Transient property ${key} already exists on model ${m.constructor.name}. should be impossible`);
290
+ result[key] = val;
291
+ });
292
+ }
293
+ if (metadata) {
294
+ log.silly(`Passing along ${this.flavour} persistence metadata for ${m.constructor.name} id ${id}: ${metadata}`);
295
+ Object.defineProperty(result, core_1.PersistenceKeys.METADATA, {
296
+ enumerable: false,
297
+ configurable: false,
298
+ writable: false,
299
+ value: metadata,
300
+ });
301
+ }
302
+ return result;
303
+ }
304
+ /**
305
+ * @description Creates an index for a model
306
+ * @summary This method is not implemented for Fabric and will throw an error
307
+ * @template M - Type extending Model
308
+ * @param {Constructor<M>} models - The model constructor
309
+ * @return {Promise<void>} Promise that will throw an error
310
+ */
311
+ index(models) {
312
+ throw new Error();
313
+ }
314
+ /**
315
+ * @description Creates a single record
316
+ * @summary Submits a transaction to create a record in the Fabric ledger
317
+ * @param {string} tableName - The name of the table/collection
318
+ * @param {string | number} id - The record identifier
319
+ * @param {Record<string, any>} model - The record data
320
+ * @param {Record<string, any>} transient - Transient data for the transaction
321
+ * @return {Promise<Record<string, any>>} Promise resolving to the created record
322
+ */
323
+ async create(tableName, id, model, transient) {
324
+ const log = this.log.for(this.create);
325
+ log.verbose(`adding entry to ${tableName} table`);
326
+ log.debug(`pk: ${id}`);
327
+ const result = await this.submitTransaction(db_decorators_1.OperationKeys.CREATE, [this.serializer.serialize(model, tableName)], transient);
328
+ return this.serializer.deserialize(this.decode(result));
329
+ }
330
+ /**
331
+ * @description Reads a single record
332
+ * @summary Evaluates a transaction to read a record from the Fabric ledger
333
+ * @param {string} tableName - The name of the table/collection
334
+ * @param {string | number} id - The record identifier
335
+ * @return {Promise<Record<string, any>>} Promise resolving to the retrieved record
336
+ */
337
+ async read(tableName, id) {
338
+ const log = this.log.for(this.read);
339
+ log.verbose(`reading entry from ${tableName} table`);
340
+ log.debug(`pk: ${id}`);
341
+ const result = await this.evaluateTransaction(db_decorators_1.OperationKeys.READ, [
342
+ id.toString(),
343
+ ]);
344
+ return this.serializer.deserialize(this.decode(result));
345
+ }
346
+ /**
347
+ * @description Updates a single record
348
+ * @summary Submits a transaction to update a record in the Fabric ledger
349
+ * @param {string} tableName - The name of the table/collection
350
+ * @param {string | number} id - The record identifier
351
+ * @param {Record<string, any>} model - The updated record data
352
+ * @param {Record<string, any>} transient - Transient data for the transaction
353
+ * @return {Promise<Record<string, any>>} Promise resolving to the updated record
354
+ */
355
+ async update(tableName, id, model, transient) {
356
+ const log = this.log.for(this.update);
357
+ log.verbose(`updating entry to ${tableName} table`);
358
+ log.debug(`pk: ${id}`);
359
+ const result = await this.submitTransaction(db_decorators_1.OperationKeys.UPDATE, [this.serializer.serialize(model, tableName)], transient);
360
+ return this.serializer.deserialize(this.decode(result));
361
+ }
362
+ /**
363
+ * @description Deletes a single record
364
+ * @summary Submits a transaction to delete a record from the Fabric ledger
365
+ * @param {string} tableName - The name of the table/collection
366
+ * @param {string | number} id - The record identifier to delete
367
+ * @return {Promise<Record<string, any>>} Promise resolving to the deleted record
368
+ */
369
+ async delete(tableName, id) {
370
+ const log = this.log.for(this.delete);
371
+ log.verbose(`deleting entry from ${tableName} table`);
372
+ log.debug(`pk: ${id}`);
373
+ const result = await this.submitTransaction(db_decorators_1.OperationKeys.DELETE, [
374
+ tableName,
375
+ id,
376
+ ]);
377
+ return this.serializer.deserialize(this.decode(result));
378
+ }
379
+ /**
380
+ * @description Executes a raw query against the Fabric ledger
381
+ * @summary Evaluates a transaction to perform a query using Mango Query syntax
382
+ * @template V - The return type
383
+ * @param {MangoQuery} rawInput - The Mango Query to execute
384
+ * @param {boolean} process - Whether to process the result
385
+ * @return {Promise<V>} Promise resolving to the query result
386
+ * @mermaid
387
+ * sequenceDiagram
388
+ * participant Client
389
+ * participant FabricAdapter
390
+ * participant Contract
391
+ * participant Chaincode
392
+ *
393
+ * Client->>FabricAdapter: raw(rawInput, process)
394
+ * FabricAdapter->>FabricAdapter: JSON.stringify(rawInput)
395
+ * FabricAdapter->>FabricAdapter: evaluateTransaction("query", [input])
396
+ * FabricAdapter->>Contract: evaluate("query", proposalOptions)
397
+ * Contract->>Chaincode: invoke
398
+ * Chaincode-->>Contract: response
399
+ * Contract-->>FabricAdapter: result
400
+ * FabricAdapter->>FabricAdapter: JSON.parse(decode(result))
401
+ * FabricAdapter->>FabricAdapter: Process result based on type
402
+ * FabricAdapter-->>Client: processed result
403
+ */
404
+ // eslint-disable-next-line @typescript-eslint/no-unused-vars
405
+ async raw(rawInput, process) {
406
+ const log = this.log.for(this.raw);
407
+ log.info(`Performing raw query on table`);
408
+ log.debug(`processing raw input for query: ${JSON.stringify(rawInput)}`);
409
+ let input;
410
+ try {
411
+ input = JSON.stringify(rawInput);
412
+ }
413
+ catch (e) {
414
+ throw new db_decorators_1.SerializationError(`Failed to process raw input for query: ${e}`);
415
+ }
416
+ let transactionResult;
417
+ try {
418
+ transactionResult = await this.evaluateTransaction("query", [input]);
419
+ }
420
+ catch (e) {
421
+ throw this.parseError(e);
422
+ }
423
+ let result;
424
+ try {
425
+ result = JSON.parse(this.decode(transactionResult));
426
+ }
427
+ catch (e) {
428
+ throw new db_decorators_1.SerializationError(`Failed to process result: ${e}`);
429
+ }
430
+ const parseRecord = (record) => {
431
+ if (decorator_validation_1.Model.isModel(record))
432
+ return decorator_validation_1.Model.build(record);
433
+ return record;
434
+ };
435
+ if (Array.isArray(result)) {
436
+ if (!result.length)
437
+ return result;
438
+ const el = result[0];
439
+ if (decorator_validation_1.Model.isModel(el))
440
+ // if the first one is a model, all are models
441
+ return result.map((el) => decorator_validation_1.Model.build(el));
442
+ return result;
443
+ }
444
+ return parseRecord(result);
445
+ }
446
+ /**
447
+ * @description Gets or creates a gRPC client for the Fabric peer
448
+ * @summary Returns a cached client or creates a new one if none exists
449
+ * @return {Promise<Client>} Promise resolving to the gRPC client
450
+ */
451
+ getClient() {
452
+ if (!this._client)
453
+ this._client = FabricClientAdapter.getClient(this.config);
454
+ return this._client;
455
+ }
456
+ /**
457
+ * @description Gets a Gateway instance for the Fabric network
458
+ * @summary Creates a new Gateway instance using the current client
459
+ * @return {Promise<Gateway>} Promise resolving to the Gateway instance
460
+ */
461
+ async Gateway() {
462
+ return FabricClientAdapter.getGateway(this.config, this.client);
463
+ }
464
+ /**
465
+ * @description Gets a Contract instance for the Fabric chaincode
466
+ * @summary Creates a new Contract instance using the current Gateway
467
+ * @return {Promise<Contrakt>} Promise resolving to the Contract instance
468
+ */
469
+ async Contract() {
470
+ return FabricClientAdapter.getContract(await this.Gateway(), this.config);
471
+ }
472
+ /**
473
+ * @description Executes a transaction on the Fabric network
474
+ * @summary Submits or evaluates a transaction on the Fabric chaincode
475
+ * @param {string} api - The chaincode function to call
476
+ * @param {boolean} submit - Whether to submit (true) or evaluate (false) the transaction
477
+ * @param {any[]} [args] - Arguments to pass to the chaincode function
478
+ * @param {Record<string, string>} [transientData] - Transient data for the transaction
479
+ * @param {Array<string>} [endorsingOrganizations] - Organizations that must endorse the transaction
480
+ * @return {Promise<Uint8Array>} Promise resolving to the transaction result
481
+ * @mermaid
482
+ * sequenceDiagram
483
+ * participant FabricAdapter
484
+ * participant Gateway
485
+ * participant Contract
486
+ * participant Chaincode
487
+ *
488
+ * FabricAdapter->>Gateway: connect()
489
+ * FabricAdapter->>Contract: getContract()
490
+ * alt submit transaction
491
+ * FabricAdapter->>Contract: submit(api, proposalOptions)
492
+ * else evaluate transaction
493
+ * FabricAdapter->>Contract: evaluate(api, proposalOptions)
494
+ * end
495
+ * Contract->>Chaincode: invoke
496
+ * Chaincode-->>Contract: response
497
+ * Contract-->>FabricAdapter: result
498
+ * FabricAdapter->>Gateway: close()
499
+ */
500
+ async transaction(api, submit = true, args, transientData, endorsingOrganizations) {
501
+ const log = this.log.for(this.transaction);
502
+ const gateway = await this.Gateway();
503
+ try {
504
+ const contract = await this.Contract();
505
+ log.verbose(`${submit ? "Submit" : "Evaluate"}ting transaction ${this.config.contractName}.${api}`);
506
+ log.debug(`args: ${args?.map((a) => a.toString()).join("\n") || "none"}`);
507
+ const method = submit ? contract.submit : contract.evaluate;
508
+ // eslint-disable-next-line @typescript-eslint/no-unused-vars
509
+ endorsingOrganizations = endorsingOrganizations?.length
510
+ ? endorsingOrganizations
511
+ : undefined;
512
+ const proposalOptions = {
513
+ arguments: args || [],
514
+ transientData: transientData,
515
+ // ...(endorsingOrganizations && { endorsingOrganizations }) // mspId list
516
+ };
517
+ return await method.call(contract, api, proposalOptions);
518
+ }
519
+ catch (e) {
520
+ if (e.code === 10) {
521
+ throw new Error(`${e.details[0].message}`);
522
+ }
523
+ throw this.parseError(e);
524
+ }
525
+ finally {
526
+ this.log.debug(`Closing ${this.config.mspId} gateway connection`);
527
+ gateway.close();
528
+ }
529
+ }
530
+ /**
531
+ * @description Parses an error into a BaseError
532
+ * @summary Converts any error into a standardized BaseError
533
+ * @param {Error | string} err - The error to parse
534
+ * @param {string} [reason] - Optional reason for the error
535
+ * @return {BaseError} The parsed error
536
+ */
537
+ parseError(err, reason) {
538
+ return FabricClientAdapter.parseError(err, reason);
539
+ }
540
+ /**
541
+ * @description Submits a transaction to the Fabric network
542
+ * @summary Executes a transaction that modifies the ledger state
543
+ * @param {string} api - The chaincode function to call
544
+ * @param {any[]} [args] - Arguments to pass to the chaincode function
545
+ * @param {Record<string, string>} [transientData] - Transient data for the transaction
546
+ * @param {Array<string>} [endorsingOrganizations] - Organizations that must endorse the transaction
547
+ * @return {Promise<Uint8Array>} Promise resolving to the transaction result
548
+ */
549
+ async submitTransaction(api, args, transientData, endorsingOrganizations) {
550
+ return this.transaction(api, true, args, transientData, endorsingOrganizations);
551
+ }
552
+ /**
553
+ * @description Evaluates a transaction on the Fabric network
554
+ * @summary Executes a transaction that does not modify the ledger state
555
+ * @param {string} api - The chaincode function to call
556
+ * @param {any[]} [args] - Arguments to pass to the chaincode function
557
+ * @param {Record<string, string>} [transientData] - Transient data for the transaction
558
+ * @param {Array<string>} [endorsingOrganizations] - Organizations that must endorse the transaction
559
+ * @return {Promise<Uint8Array>} Promise resolving to the transaction result
560
+ */
561
+ async evaluateTransaction(api, args, transientData, endorsingOrganizations) {
562
+ return this.transaction(api, false, args, transientData, endorsingOrganizations);
563
+ }
564
+ /**
565
+ * @description Closes the connection to the Fabric network
566
+ * @summary Closes the gRPC client if it exists
567
+ * @return {Promise<void>} Promise that resolves when the client is closed
568
+ */
569
+ async close() {
570
+ if (this.client) {
571
+ this.log.verbose(`Closing ${this.config.mspId} gateway client`);
572
+ this.client.close();
573
+ }
574
+ }
575
+ /**
576
+ * @description Gets a Contract instance from a Gateway
577
+ * @summary Retrieves a chaincode contract from the specified network
578
+ * @param {Gateway} gateway - The Gateway instance
579
+ * @param {PeerConfig} config - The peer configuration
580
+ * @return {Contrakt} The Contract instance
581
+ */
582
+ static getContract(gateway, config) {
583
+ const log = this.log.for(this.getContract);
584
+ const network = this.getNetwork(gateway, config.channel);
585
+ let contract;
586
+ try {
587
+ log.debug(`Retrieving chaincode ${config.chaincodeName} contract ${config.contractName} from network ${config.channel}`);
588
+ contract = network.getContract(config.chaincodeName, config.contractName);
589
+ }
590
+ catch (e) {
591
+ throw this.parseError(e);
592
+ }
593
+ return contract;
594
+ }
595
+ /**
596
+ * @description Gets a Network instance from a Gateway
597
+ * @summary Connects to a specific channel on the Fabric network
598
+ * @param {Gateway} gateway - The Gateway instance
599
+ * @param {string} channelName - The name of the channel to connect to
600
+ * @return {Network} The Network instance
601
+ */
602
+ static getNetwork(gateway, channelName) {
603
+ const log = this.log.for(this.getNetwork);
604
+ let network;
605
+ try {
606
+ log.debug(`Connecting to channel ${channelName}`);
607
+ network = gateway.getNetwork(channelName);
608
+ }
609
+ catch (e) {
610
+ throw this.parseError(e);
611
+ }
612
+ return network;
613
+ }
614
+ /**
615
+ * @description Gets a Gateway instance for connecting to the Fabric network
616
+ * @summary Creates a Gateway using the provided configuration and client
617
+ * @param {PeerConfig} config - The peer configuration
618
+ * @param {Client} [client] - Optional gRPC client, will be created if not provided
619
+ * @return {Promise<Gateway>} Promise resolving to the Gateway instance
620
+ */
621
+ static async getGateway(config, client) {
622
+ return (await this.getConnection(client || (await this.getClient(config)), config));
623
+ }
624
+ /**
625
+ * @description Creates a gRPC client for connecting to a Fabric peer
626
+ * @summary Initializes a client with TLS credentials for secure communication
627
+ * @param {PeerConfig} config - The peer configuration
628
+ * @return {Client} Promise resolving to the gRPC client
629
+ */
630
+ static getClient(config) {
631
+ const log = this.log.for(this.getClient);
632
+ log.debug(`generating TLS credentials for msp ${config.mspId}`);
633
+ const tlsCredentials = grpc.credentials.createSsl(typeof config.tlsCert === "string"
634
+ ? Buffer.from(config.tlsCert)
635
+ : config.tlsCert);
636
+ log.debug(`generating Gateway Client for url ${config.peerEndpoint}`);
637
+ return new grpc_js_1.Client(config.peerEndpoint, tlsCredentials);
638
+ }
639
+ /**
640
+ * @description Establishes a connection to the Fabric network
641
+ * @summary Creates a Gateway connection with identity and signer
642
+ * @param {Client} client - The gRPC client
643
+ * @param {PeerConfig} config - The peer configuration
644
+ * @return {Promise<Gateway>} Promise resolving to the connected Gateway
645
+ * @mermaid
646
+ * sequenceDiagram
647
+ * participant Caller
648
+ * participant FabricAdapter
649
+ * participant Identity
650
+ * participant Signer
651
+ * participant Gateway
652
+ *
653
+ * Caller->>FabricAdapter: getConnection(client, config)
654
+ * FabricAdapter->>Identity: getIdentity(mspId, certDirectoryPath)
655
+ * Identity-->>FabricAdapter: identity
656
+ * FabricAdapter->>Signer: getSigner(keyDirectoryPath)
657
+ * Signer-->>FabricAdapter: signer
658
+ * FabricAdapter->>FabricAdapter: Create ConnectOptions
659
+ * FabricAdapter->>Gateway: connect(options)
660
+ * Gateway-->>FabricAdapter: gateway
661
+ * FabricAdapter-->>Caller: gateway
662
+ */
663
+ static async getConnection(client, config) {
664
+ const log = this.log.for(this.getConnection);
665
+ log.debug(`Retrieving Peer Identity for ${config.mspId} under ${config.certCertOrDirectoryPath}`);
666
+ const identity = await (0, fabric_fs_1.getIdentity)(config.mspId, config.certCertOrDirectoryPath);
667
+ log.debug(`Retrieving signer key from ${config.keyCertOrDirectoryPath}`);
668
+ const signer = await (0, fabric_fs_1.getSigner)(config.keyCertOrDirectoryPath);
669
+ const options = {
670
+ client,
671
+ identity: identity,
672
+ signer: signer,
673
+ // Default timeouts for different gRPC calls
674
+ evaluateOptions: () => {
675
+ return { deadline: Date.now() + 5000 }; // 5 seconds
676
+ },
677
+ endorseOptions: () => {
678
+ return { deadline: Date.now() + 15000 }; // 15 seconds
679
+ },
680
+ submitOptions: () => {
681
+ return { deadline: Date.now() + 5000 }; // 5 seconds
682
+ },
683
+ commitStatusOptions: () => {
684
+ return { deadline: Date.now() + 60000 }; // 1 minute
685
+ },
686
+ };
687
+ log.debug(`Connecting to ${config.mspId}`);
688
+ return (0, fabric_gateway_1.connect)(options);
689
+ }
690
+ /**
691
+ * @description Creates a new Dispatch instance for the Fabric client.
692
+ * @summary This function is responsible for creating a new FabricClientDispatch instance that can be used to interact with the Fabric network.
693
+ * @returns {Dispatch} A new Dispatch instance configured for the Fabric client.
694
+ * @remarks The Dispatch instance is used to encapsulate the logic for interacting with the Fabric network, such as submitting transactions or querying data.
695
+ * @example
696
+ * const fabricDispatch = fabricClientAdapter.Dispatch();
697
+ * fabricDispatch.submitTransaction('createProduct', { name: 'Product A', price: 100 });
698
+ */
699
+ Dispatch() {
700
+ return new FabricClientDispatch_1.FabricClientDispatch(this.getClient());
701
+ }
702
+ /**
703
+ * @description Parses an error into a BaseError
704
+ * @summary Converts any error into a standardized BaseError using the parent class implementation
705
+ * @param {Error | string} err - The error to parse
706
+ * @param {string} [reason] - Optional reason for the error
707
+ * @return {BaseError} The parsed error
708
+ */
709
+ static parseError(err, reason) {
710
+ return super.parseError(err, reason);
711
+ }
712
+ }
713
+ exports.FabricClientAdapter = FabricClientAdapter;
714
+ __decorate([
715
+ (0, logging_1.debug)(true)
716
+ // eslint-disable-next-line @typescript-eslint/no-unused-vars
717
+ ,
718
+ __metadata("design:type", Function),
719
+ __metadata("design:paramtypes", [Object]),
720
+ __metadata("design:returntype", Promise)
721
+ ], FabricClientAdapter.prototype, "index", null);
722
+ __decorate([
723
+ (0, logging_1.debug)(true),
724
+ (0, core_1.final)(),
725
+ __metadata("design:type", Function),
726
+ __metadata("design:paramtypes", [String, Object, Object, Object]),
727
+ __metadata("design:returntype", Promise)
728
+ ], FabricClientAdapter.prototype, "create", null);
729
+ __decorate([
730
+ (0, logging_1.debug)(true),
731
+ (0, core_1.final)(),
732
+ __metadata("design:type", Function),
733
+ __metadata("design:paramtypes", [String, Object]),
734
+ __metadata("design:returntype", Promise)
735
+ ], FabricClientAdapter.prototype, "read", null);
736
+ __decorate([
737
+ (0, logging_1.debug)(true),
738
+ (0, core_1.final)(),
739
+ __metadata("design:type", Function),
740
+ __metadata("design:paramtypes", [String, Object, Object, Object]),
741
+ __metadata("design:returntype", Promise)
742
+ ], FabricClientAdapter.prototype, "update", null);
743
+ __decorate([
744
+ (0, logging_1.debug)(true),
745
+ (0, core_1.final)(),
746
+ __metadata("design:type", Function),
747
+ __metadata("design:paramtypes", [String, Object]),
748
+ __metadata("design:returntype", Promise)
749
+ ], FabricClientAdapter.prototype, "delete", null);
750
+ __decorate([
751
+ (0, logging_1.debug)(true)
752
+ // eslint-disable-next-line @typescript-eslint/no-unused-vars
753
+ ,
754
+ __metadata("design:type", Function),
755
+ __metadata("design:paramtypes", [Object, Boolean]),
756
+ __metadata("design:returntype", Promise)
757
+ ], FabricClientAdapter.prototype, "raw", null);
758
+ FabricClientAdapter.decoration();
759
+ core_1.Adapter.setCurrent(constants_1.FabricFlavour);
760
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"FabricClientAdapter.js","sourceRoot":"","sources":["../../src/client/FabricClientAdapter.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,uDAAwE;AACxE,2CAAuC;AACvC,oDAAsC;AAEtC,yEAIwC;AACxC,+CAA2D;AAE3D,gEAOqC;AACrC,+CAAqD;AACrD,2DAQiC;AACjC,yCAMwB;AACxB,yEAAkE;AAClE,yDAAoD;AACpD,uEAA8D;AAC9D,qEAA8D;AAE9D;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAkDG;AACH,MAAa,mBAAoB,SAAQ,4BAKxC;IACC;;OAEG;aACY,YAAO,GAAG,IAAI,WAAW,CAAC,MAAM,CAAC,AAA1B,CAA2B;aAElC,eAAU,GAAG,IAAI,mCAAgB,EAAE,AAAzB,CAA0B;IAEnD;;OAEG;aACY,QAAG,GAAW,iBAAO,CAAC,GAAG,CAAC,mBAAmB,CAAC,AAA3C,CAA4C;IAE9D;;;;OAIG;IACH,IAAuB,GAAG;QACxB,OAAO,mBAAmB,CAAC,GAAG,CAAC;IACjC,CAAC;IAKD;;;;;OAKG;IACH,YAAY,MAAkB,EAAE,KAAc;QAC5C,KAAK,CAAC,MAAM,EAAE,yBAAa,EAAE,KAAK,CAAC,CAAC;QAVnB,eAAU,GAC3B,mBAAmB,CAAC,UAAU,CAAC;IAUjC,CAAC;IAED;;;;;OAKG;IACH,MAAM,CAAC,IAAgB;QACrB,OAAO,mBAAmB,CAAC,OAAO,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;IAClD,CAAC;IAEQ,UAAU;QAejB,OAAO,+CAAsB,CAAC;IAChC,CAAC;IAED;;;;;;;;OAQG;IACM,KAAK,CAAC,SAAS,CACtB,SAAiB,EACjB,GAAwB,EACxB,MAA6B,EAC7B,SAA8B;QAE9B,MAAM,GAAG,GAAG,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;QACzC,IAAI,GAAG,CAAC,MAAM,KAAK,MAAM,CAAC,MAAM;YAC9B,MAAM,IAAI,6BAAa,CACrB,6CAA6C,GAAG,CAAC,MAAM,OAAO,MAAM,CAAC,MAAM,EAAE,CAC9E,CAAC;QACJ,GAAG,CAAC,IAAI,CAAC,UAAU,GAAG,CAAC,MAAM,eAAe,SAAS,QAAQ,CAAC,CAAC;QAC/D,GAAG,CAAC,OAAO,CAAC,QAAQ,GAAG,EAAE,CAAC,CAAC;QAC3B,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,iBAAiB,CACzC,qCAAqB,CAAC,UAAU,EAChC,CAAC,GAAG,EAAE,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,IAAI,CAAC,UAAU,CAAC,SAAS,CAAC,CAAC,EAAE,SAAS,CAAC,CAAC,CAAC,EACjE,SAAS,CACV,CAAC;QACF,IAAI,CAAC;YACH,OAAO,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAM,EAAE,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC;QACxE,CAAC;QAAC,OAAO,CAAU,EAAE,CAAC;YACpB,MAAM,IAAI,kCAAkB,CAAC,CAAU,CAAC,CAAC;QAC3C,CAAC;IACH,CAAC;IAED;;;;;;OAMG;IACM,KAAK,CAAC,OAAO,CACpB,SAAiB,EACjB,GAAwB;QAExB,MAAM,GAAG,GAAG,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QACvC,GAAG,CAAC,IAAI,CAAC,WAAW,GAAG,CAAC,MAAM,eAAe,SAAS,QAAQ,CAAC,CAAC;QAChE,GAAG,CAAC,OAAO,CAAC,QAAQ,GAAG,EAAE,CAAC,CAAC;QAC3B,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,iBAAiB,CACzC,qCAAqB,CAAC,QAAQ,EAC9B,CAAC,GAAG,CAAC,CACN,CAAC;QACF,IAAI,CAAC;YACH,OAAO,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAM,EAAE,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC;QACxE,CAAC;QAAC,OAAO,CAAU,EAAE,CAAC;YACpB,MAAM,IAAI,kCAAkB,CAAC,CAAU,CAAC,CAAC;QAC3C,CAAC;IACH,CAAC;IAED;;;;;;;;OAQG;IACM,KAAK,CAAC,SAAS,CACtB,SAAiB,EACjB,GAAwB,EACxB,MAA6B,EAC7B,SAA8B;QAE9B,MAAM,GAAG,GAAG,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;QACzC,IAAI,GAAG,CAAC,MAAM,KAAK,MAAM,CAAC,MAAM;YAC9B,MAAM,IAAI,6BAAa,CACrB,6CAA6C,GAAG,CAAC,MAAM,OAAO,MAAM,CAAC,MAAM,EAAE,CAC9E,CAAC;QACJ,GAAG,CAAC,IAAI,CAAC,YAAY,GAAG,CAAC,MAAM,eAAe,SAAS,QAAQ,CAAC,CAAC;QACjE,GAAG,CAAC,OAAO,CAAC,QAAQ,GAAG,EAAE,CAAC,CAAC;QAC3B,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,iBAAiB,CACzC,qCAAqB,CAAC,UAAU,EAChC,CAAC,GAAG,EAAE,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,IAAI,CAAC,UAAU,CAAC,SAAS,CAAC,CAAC,EAAE,SAAS,CAAC,CAAC,CAAC,EACjE,SAAS,CACV,CAAC;QACF,IAAI,CAAC;YACH,OAAO,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAM,EAAE,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC;QACxE,CAAC;QAAC,OAAO,CAAU,EAAE,CAAC;YACpB,MAAM,IAAI,kCAAkB,CAAC,CAAU,CAAC,CAAC;QAC3C,CAAC;IACH,CAAC;IAED;;;;;;;OAOG;IACM,KAAK,CAAC,SAAS,CACtB,SAAiB,EACjB,GAAiC;QAEjC,MAAM,GAAG,GAAG,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;QACzC,GAAG,CAAC,IAAI,CAAC,YAAY,GAAG,CAAC,MAAM,eAAe,SAAS,QAAQ,CAAC,CAAC;QACjE,GAAG,CAAC,OAAO,CAAC,QAAQ,GAAG,EAAE,CAAC,CAAC;QAC3B,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,iBAAiB,CACzC,qCAAqB,CAAC,UAAU,EAChC,CAAC,GAAG,CAAC,CACN,CAAC;QACF,IAAI,CAAC;YACH,OAAO,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAM,EAAE,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC;QACxE,CAAC;QAAC,OAAO,CAAU,EAAE,CAAC;YACpB,MAAM,IAAI,kCAAkB,CAAC,CAAU,CAAC,CAAC;QAC3C,CAAC;IACH,CAAC;IAED;;;;;;;;OAQG;IACM,OAAO,CACd,KAAQ,EACR,EAAW;QAMX,MAAM,GAAG,GAAG,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QACvC,MAAM,KAAK,GAAG,IAAA,gCAAgB,EAAC,KAAK,CAAC,CAAC;QACtC,IAAK,KAAa,CAAC,sBAAe,CAAC,QAAQ,CAAC,EAAE,CAAC;YAC7C,GAAG,CAAC,KAAK,CACP,0CAA2C,KAAa,CAAC,sBAAe,CAAC,QAAQ,CAAC,EAAE,CACrF,CAAC;YACF,MAAM,CAAC,cAAc,CAAC,KAAK,CAAC,KAAK,EAAE,sBAAe,CAAC,QAAQ,EAAE;gBAC3D,UAAU,EAAE,KAAK;gBACjB,QAAQ,EAAE,KAAK;gBACf,YAAY,EAAE,IAAI;gBAClB,KAAK,EAAG,KAAa,CAAC,sBAAe,CAAC,QAAQ,CAAC;aAChD,CAAC,CAAC;QACL,CAAC;QAED,OAAO;YACL,MAAM,EAAE,KAAK,CAAC,KAAK;YACnB,EAAE,EAAE,KAAK,CAAC,EAAE,CAAW;YACvB,SAAS,EAAE,KAAK,CAAC,SAAS;SAC3B,CAAC;IACJ,CAAC;IAED;;;;;;;;;;;OAWG;IACM,MAAM,CACb,GAAwB,EACxB,KAA8B,EAC9B,EAAW,EACX,EAA4B,EAC5B,SAA+B;QAE/B,MAAM,GAAG,GAAG,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QACtC,MAAM,EAAE,GAAwB,EAAE,CAAC;QACnC,EAAE,CAAC,EAAY,CAAC,GAAG,EAAE,CAAC;QACtB,MAAM,CAAC,GAAG,CACR,OAAO,KAAK,KAAK,QAAQ,CAAC,CAAC,CAAC,4BAAK,CAAC,KAAK,CAAC,EAAE,EAAE,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,KAAK,CAAC,EAAE,CAAC,CAC9D,CAAC;QACP,GAAG,CAAC,KAAK,CAAC,oBAAoB,CAAC,CAAC,WAAW,CAAC,IAAI,OAAO,EAAE,EAAE,CAAC,CAAC;QAC7D,MAAM,QAAQ,GAAG,GAAG,CAAC,sBAAe,CAAC,QAAQ,CAAC,CAAC;QAC/C,MAAM,MAAM,GAAG,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,KAAQ,EAAE,GAAG,EAAE,EAAE;YACpD,KAA6B,CAAC,GAAG,CAAC,GAAG,GAAG,CAAC,GAAG,CAAC,CAAC;YAC/C,OAAO,KAAK,CAAC;QACf,CAAC,EAAE,CAAC,CAAC,CAAC;QAEN,IAAI,SAAS,EAAE,CAAC;YACd,GAAG,CAAC,OAAO,CACT,mCAAmC,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CACvE,CAAC;YACF,MAAM,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,GAAG,EAAE,GAAG,CAAC,EAAE,EAAE;gBAC/C,IAAI,GAAG,IAAI,MAAM,IAAK,MAAc,CAAC,GAAG,CAAC,KAAK,SAAS;oBACrD,MAAM,IAAI,6BAAa,CACrB,sBAAsB,GAAG,4BAA4B,CAAC,CAAC,WAAW,CAAC,IAAI,wBAAwB,CAChG,CAAC;gBACJ,MAAM,CAAC,GAAc,CAAC,GAAG,GAAG,CAAC;YAC/B,CAAC,CAAC,CAAC;QACL,CAAC;QAED,IAAI,QAAQ,EAAE,CAAC;YACb,GAAG,CAAC,KAAK,CACP,iBAAiB,IAAI,CAAC,OAAO,6BAA6B,CAAC,CAAC,WAAW,CAAC,IAAI,OAAO,EAAE,KAAK,QAAQ,EAAE,CACrG,CAAC;YACF,MAAM,CAAC,cAAc,CAAC,MAAM,EAAE,sBAAe,CAAC,QAAQ,EAAE;gBACtD,UAAU,EAAE,KAAK;gBACjB,YAAY,EAAE,KAAK;gBACnB,QAAQ,EAAE,KAAK;gBACf,KAAK,EAAE,QAAQ;aAChB,CAAC,CAAC;QACL,CAAC;QAED,OAAO,MAAM,CAAC;IAChB,CAAC;IAED;;;;;;OAMG;IAGO,KAAK,CAAI,MAAsB;QACvC,MAAM,IAAI,KAAK,EAAE,CAAC;IACpB,CAAC;IAED;;;;;;;;OAQG;IAGY,AAAN,KAAK,CAAC,MAAM,CACnB,SAAiB,EACjB,EAAmB,EACnB,KAA0B,EAC1B,SAA8B;QAE9B,MAAM,GAAG,GAAG,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QACtC,GAAG,CAAC,OAAO,CAAC,mBAAmB,SAAS,QAAQ,CAAC,CAAC;QAClD,GAAG,CAAC,KAAK,CAAC,OAAO,EAAE,EAAE,CAAC,CAAC;QACvB,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,iBAAiB,CACzC,6BAAa,CAAC,MAAM,EACpB,CAAC,IAAI,CAAC,UAAU,CAAC,SAAS,CAAC,KAAK,EAAE,SAAS,CAAC,CAAC,EAC7C,SAAS,CACV,CAAC;QACF,OAAO,IAAI,CAAC,UAAU,CAAC,WAAW,CAAC,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC;IAC1D,CAAC;IAED;;;;;;OAMG;IAGG,AAAN,KAAK,CAAC,IAAI,CACR,SAAiB,EACjB,EAAmB;QAEnB,MAAM,GAAG,GAAG,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACpC,GAAG,CAAC,OAAO,CAAC,sBAAsB,SAAS,QAAQ,CAAC,CAAC;QACrD,GAAG,CAAC,KAAK,CAAC,OAAO,EAAE,EAAE,CAAC,CAAC;QACvB,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,mBAAmB,CAAC,6BAAa,CAAC,IAAI,EAAE;YAChE,EAAE,CAAC,QAAQ,EAAE;SACd,CAAC,CAAC;QACH,OAAO,IAAI,CAAC,UAAU,CAAC,WAAW,CAAC,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC;IAC1D,CAAC;IAED;;;;;;;;OAQG;IAGG,AAAN,KAAK,CAAC,MAAM,CACV,SAAiB,EACjB,EAAmB,EACnB,KAA0B,EAC1B,SAA8B;QAE9B,MAAM,GAAG,GAAG,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QACtC,GAAG,CAAC,OAAO,CAAC,qBAAqB,SAAS,QAAQ,CAAC,CAAC;QACpD,GAAG,CAAC,KAAK,CAAC,OAAO,EAAE,EAAE,CAAC,CAAC;QACvB,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,iBAAiB,CACzC,6BAAa,CAAC,MAAM,EACpB,CAAC,IAAI,CAAC,UAAU,CAAC,SAAS,CAAC,KAAK,EAAE,SAAS,CAAC,CAAC,EAC7C,SAAS,CACV,CAAC;QACF,OAAO,IAAI,CAAC,UAAU,CAAC,WAAW,CAAC,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC;IAC1D,CAAC;IAED;;;;;;OAMG;IAGG,AAAN,KAAK,CAAC,MAAM,CACV,SAAiB,EACjB,EAAmB;QAEnB,MAAM,GAAG,GAAG,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QACtC,GAAG,CAAC,OAAO,CAAC,uBAAuB,SAAS,QAAQ,CAAC,CAAC;QACtD,GAAG,CAAC,KAAK,CAAC,OAAO,EAAE,EAAE,CAAC,CAAC;QACvB,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,iBAAiB,CAAC,6BAAa,CAAC,MAAM,EAAE;YAChE,SAAS;YACT,EAAE;SACH,CAAC,CAAC;QACH,OAAO,IAAI,CAAC,UAAU,CAAC,WAAW,CAAC,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC;IAC1D,CAAC;IAED;;;;;;;;;;;;;;;;;;;;;;;;OAwBG;IAGG,AADN,6DAA6D;IAC7D,KAAK,CAAC,GAAG,CAAI,QAAoB,EAAE,OAAgB;QACjD,MAAM,GAAG,GAAG,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;QACnC,GAAG,CAAC,IAAI,CAAC,gCAAgC,CAAC,CAAC;QAC3C,GAAG,CAAC,KAAK,CAAC,mCAAmC,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC;QACzE,IAAI,KAAa,CAAC;QAClB,IAAI,CAAC;YACH,KAAK,GAAG,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC;QACnC,CAAC;QAAC,OAAO,CAAM,EAAE,CAAC;YAChB,MAAM,IAAI,kCAAkB,CAC1B,0CAA0C,CAAC,EAAE,CAC9C,CAAC;QACJ,CAAC;QACD,IAAI,iBAAsB,CAAC;QAC3B,IAAI,CAAC;YACH,iBAAiB,GAAG,MAAM,IAAI,CAAC,mBAAmB,CAAC,OAAO,EAAE,CAAC,KAAK,CAAC,CAAC,CAAC;QACvE,CAAC;QAAC,OAAO,CAAU,EAAE,CAAC;YACpB,MAAM,IAAI,CAAC,UAAU,CAAC,CAAU,CAAC,CAAC;QACpC,CAAC;QACD,IAAI,MAAW,CAAC;QAChB,IAAI,CAAC;YACH,MAAM,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,MAAM,CAAC,iBAAiB,CAAC,CAAC,CAAC;QACtD,CAAC;QAAC,OAAO,CAAM,EAAE,CAAC;YAChB,MAAM,IAAI,kCAAkB,CAAC,6BAA6B,CAAC,EAAE,CAAC,CAAC;QACjE,CAAC;QAED,MAAM,WAAW,GAAG,CAAC,MAAwB,EAAE,EAAE;YAC/C,IAAI,4BAAK,CAAC,OAAO,CAAC,MAAM,CAAC;gBAAE,OAAO,4BAAK,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;YACtD,OAAO,MAAM,CAAC;QAChB,CAAC,CAAC;QAEF,IAAI,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE,CAAC;YAC1B,IAAI,CAAC,MAAM,CAAC,MAAM;gBAAE,OAAO,MAAW,CAAC;YACvC,MAAM,EAAE,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;YACrB,IAAI,4BAAK,CAAC,OAAO,CAAC,EAAE,CAAC;gBACnB,8CAA8C;gBAC9C,OAAO,MAAM,CAAC,GAAG,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC,4BAAK,CAAC,KAAK,CAAC,EAAE,CAAC,CAAM,CAAC;YAClD,OAAO,MAAW,CAAC;QACrB,CAAC;QAED,OAAO,WAAW,CAAC,MAAa,CAAM,CAAC;IACzC,CAAC;IAED;;;;OAIG;IACM,SAAS;QAChB,IAAI,CAAC,IAAI,CAAC,OAAO;YACf,IAAI,CAAC,OAAO,GAAG,mBAAmB,CAAC,SAAS,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QAC5D,OAAO,IAAI,CAAC,OAAO,CAAC;IACtB,CAAC;IAED;;;;OAIG;IACO,KAAK,CAAC,OAAO;QACrB,OAAO,mBAAmB,CAAC,UAAU,CAAC,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,MAAM,CAAC,CAAC;IAClE,CAAC;IAED;;;;OAIG;IACO,KAAK,CAAC,QAAQ;QACtB,OAAO,mBAAmB,CAAC,WAAW,CAAC,MAAM,IAAI,CAAC,OAAO,EAAE,EAAE,IAAI,CAAC,MAAM,CAAC,CAAC;IAC5E,CAAC;IAED;;;;;;;;;;;;;;;;;;;;;;;;;;;OA2BG;IACO,KAAK,CAAC,WAAW,CACzB,GAAW,EACX,MAAM,GAAG,IAAI,EACb,IAAY,EACZ,aAAsC,EACtC,sBAAsC;QAEtC,MAAM,GAAG,GAAG,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;QAC3C,MAAM,OAAO,GAAG,MAAM,IAAI,CAAC,OAAO,EAAE,CAAC;QACrC,IAAI,CAAC;YACH,MAAM,QAAQ,GAAG,MAAM,IAAI,CAAC,QAAQ,EAAE,CAAC;YACvC,GAAG,CAAC,OAAO,CACT,GAAG,MAAM,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,UAAU,oBAAoB,IAAI,CAAC,MAAM,CAAC,YAAY,IAAI,GAAG,EAAE,CACvF,CAAC;YACF,GAAG,CAAC,KAAK,CAAC,SAAS,IAAI,EAAE,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,QAAQ,EAAE,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,MAAM,EAAE,CAAC,CAAC;YAC1E,MAAM,MAAM,GAAG,MAAM,CAAC,CAAC,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC,CAAC,QAAQ,CAAC,QAAQ,CAAC;YAE5D,6DAA6D;YAC7D,sBAAsB,GAAG,sBAAsB,EAAE,MAAM;gBACrD,CAAC,CAAC,sBAAsB;gBACxB,CAAC,CAAC,SAAS,CAAC;YACd,MAAM,eAAe,GAAoB;gBACvC,SAAS,EAAE,IAAI,IAAI,EAAE;gBACrB,aAAa,EAAE,aAAa;gBAC5B,0EAA0E;aAC3E,CAAC;YAEF,OAAO,MAAM,MAAM,CAAC,IAAI,CAAC,QAAQ,EAAE,GAAG,EAAE,eAAe,CAAC,CAAC;QAC3D,CAAC;QAAC,OAAO,CAAM,EAAE,CAAC;YAChB,IAAI,CAAC,CAAC,IAAI,KAAK,EAAE,EAAE,CAAC;gBAClB,MAAM,IAAI,KAAK,CAAC,GAAG,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,OAAO,EAAE,CAAC,CAAC;YAC7C,CAAC;YACD,MAAM,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC;QAC3B,CAAC;gBAAS,CAAC;YACT,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,WAAW,IAAI,CAAC,MAAM,CAAC,KAAK,qBAAqB,CAAC,CAAC;YAClE,OAAO,CAAC,KAAK,EAAE,CAAC;QAClB,CAAC;IACH,CAAC;IAED;;;;;;OAMG;IACM,UAAU,CAAC,GAAmB,EAAE,MAAe;QACtD,OAAO,mBAAmB,CAAC,UAAU,CAAC,GAAG,EAAE,MAAM,CAAC,CAAC;IACrD,CAAC;IAED;;;;;;;;OAQG;IACH,KAAK,CAAC,iBAAiB,CACrB,GAAW,EACX,IAAY,EACZ,aAAsC,EACtC,sBAAsC;QAEtC,OAAO,IAAI,CAAC,WAAW,CACrB,GAAG,EACH,IAAI,EACJ,IAAI,EACJ,aAAa,EACb,sBAAsB,CACvB,CAAC;IACJ,CAAC;IAED;;;;;;;;OAQG;IACH,KAAK,CAAC,mBAAmB,CACvB,GAAW,EACX,IAAY,EACZ,aAAsC,EACtC,sBAAsC;QAEtC,OAAO,IAAI,CAAC,WAAW,CACrB,GAAG,EACH,KAAK,EACL,IAAI,EACJ,aAAa,EACb,sBAAsB,CACvB,CAAC;IACJ,CAAC;IAED;;;;OAIG;IACH,KAAK,CAAC,KAAK;QACT,IAAI,IAAI,CAAC,MAAM,EAAE,CAAC;YAChB,IAAI,CAAC,GAAG,CAAC,OAAO,CAAC,WAAW,IAAI,CAAC,MAAM,CAAC,KAAK,iBAAiB,CAAC,CAAC;YAChE,IAAI,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC;QACtB,CAAC;IACH,CAAC;IAED;;;;;;OAMG;IACH,MAAM,CAAC,WAAW,CAAC,OAAgB,EAAE,MAAkB;QACrD,MAAM,GAAG,GAAG,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;QAC3C,MAAM,OAAO,GAAG,IAAI,CAAC,UAAU,CAAC,OAAO,EAAE,MAAM,CAAC,OAAO,CAAC,CAAC;QACzD,IAAI,QAAkB,CAAC;QACvB,IAAI,CAAC;YACH,GAAG,CAAC,KAAK,CACP,wBAAwB,MAAM,CAAC,aAAa,aAAa,MAAM,CAAC,YAAY,iBAAiB,MAAM,CAAC,OAAO,EAAE,CAC9G,CAAC;YACF,QAAQ,GAAG,OAAO,CAAC,WAAW,CAAC,MAAM,CAAC,aAAa,EAAE,MAAM,CAAC,YAAY,CAAC,CAAC;QAC5E,CAAC;QAAC,OAAO,CAAM,EAAE,CAAC;YAChB,MAAM,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC;QAC3B,CAAC;QACD,OAAO,QAAQ,CAAC;IAClB,CAAC;IAED;;;;;;OAMG;IACH,MAAM,CAAC,UAAU,CAAC,OAAgB,EAAE,WAAmB;QACrD,MAAM,GAAG,GAAG,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;QAC1C,IAAI,OAAgB,CAAC;QACrB,IAAI,CAAC;YACH,GAAG,CAAC,KAAK,CAAC,yBAAyB,WAAW,EAAE,CAAC,CAAC;YAClD,OAAO,GAAG,OAAO,CAAC,UAAU,CAAC,WAAW,CAAC,CAAC;QAC5C,CAAC;QAAC,OAAO,CAAM,EAAE,CAAC;YAChB,MAAM,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC;QAC3B,CAAC;QAED,OAAO,OAAO,CAAC;IACjB,CAAC;IAED;;;;;;OAMG;IACH,MAAM,CAAC,KAAK,CAAC,UAAU,CAAC,MAAkB,EAAE,MAAe;QACzD,OAAO,CAAC,MAAM,IAAI,CAAC,aAAa,CAC9B,MAAM,IAAI,CAAC,MAAM,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC,EACxC,MAAM,CACP,CAAY,CAAC;IAChB,CAAC;IAED;;;;;OAKG;IACH,MAAM,CAAC,SAAS,CAAC,MAAkB;QACjC,MAAM,GAAG,GAAG,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;QACzC,GAAG,CAAC,KAAK,CAAC,sCAAsC,MAAM,CAAC,KAAK,EAAE,CAAC,CAAC;QAChE,MAAM,cAAc,GAAG,IAAI,CAAC,WAAW,CAAC,SAAS,CAC/C,OAAO,MAAM,CAAC,OAAO,KAAK,QAAQ;YAChC,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC;YAC7B,CAAC,CAAC,MAAM,CAAC,OAAO,CACnB,CAAC;QACF,GAAG,CAAC,KAAK,CAAC,qCAAqC,MAAM,CAAC,YAAY,EAAE,CAAC,CAAC;QACtE,OAAO,IAAI,gBAAM,CAAC,MAAM,CAAC,YAAY,EAAE,cAAc,CAAC,CAAC;IACzD,CAAC;IAED;;;;;;;;;;;;;;;;;;;;;;;OAuBG;IACH,MAAM,CAAC,KAAK,CAAC,aAAa,CAAC,MAAc,EAAE,MAAkB;QAC3D,MAAM,GAAG,GAAG,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;QAC7C,GAAG,CAAC,KAAK,CACP,gCAAgC,MAAM,CAAC,KAAK,UAAU,MAAM,CAAC,uBAAuB,EAAE,CACvF,CAAC;QACF,MAAM,QAAQ,GAAG,MAAM,IAAA,uBAAW,EAChC,MAAM,CAAC,KAAK,EACZ,MAAM,CAAC,uBAAuB,CAC/B,CAAC;QACF,GAAG,CAAC,KAAK,CAAC,8BAA8B,MAAM,CAAC,sBAAsB,EAAE,CAAC,CAAC;QAEzE,MAAM,MAAM,GAAG,MAAM,IAAA,qBAAS,EAAC,MAAM,CAAC,sBAAsB,CAAC,CAAC;QAE9D,MAAM,OAAO,GAAG;YACd,MAAM;YACN,QAAQ,EAAE,QAAQ;YAClB,MAAM,EAAE,MAAM;YACd,4CAA4C;YAC5C,eAAe,EAAE,GAAG,EAAE;gBACpB,OAAO,EAAE,QAAQ,EAAE,IAAI,CAAC,GAAG,EAAE,GAAG,IAAI,EAAE,CAAC,CAAC,YAAY;YACtD,CAAC;YACD,cAAc,EAAE,GAAG,EAAE;gBACnB,OAAO,EAAE,QAAQ,EAAE,IAAI,CAAC,GAAG,EAAE,GAAG,KAAK,EAAE,CAAC,CAAC,aAAa;YACxD,CAAC;YACD,aAAa,EAAE,GAAG,EAAE;gBAClB,OAAO,EAAE,QAAQ,EAAE,IAAI,CAAC,GAAG,EAAE,GAAG,IAAI,EAAE,CAAC,CAAC,YAAY;YACtD,CAAC;YACD,mBAAmB,EAAE,GAAG,EAAE;gBACxB,OAAO,EAAE,QAAQ,EAAE,IAAI,CAAC,GAAG,EAAE,GAAG,KAAK,EAAE,CAAC,CAAC,WAAW;YACtD,CAAC;SACgB,CAAC;QAEpB,GAAG,CAAC,KAAK,CAAC,iBAAiB,MAAM,CAAC,KAAK,EAAE,CAAC,CAAC;QAC3C,OAAO,IAAA,wBAAO,EAAC,OAAO,CAAC,CAAC;IAC1B,CAAC;IAED;;;;;;;;OAQG;IACM,QAAQ;QACf,OAAO,IAAI,2CAAoB,CAAC,IAAI,CAAC,SAAS,EAAE,CAAC,CAAC;IACpD,CAAC;IAED;;;;;;OAMG;IACO,MAAM,CAAU,UAAU,CAClC,GAAmB,EACnB,MAAe;QAEf,OAAO,KAAK,CAAC,UAAU,CAAC,GAAG,EAAE,MAAM,CAAC,CAAC;IACvC,CAAC;;AA1xBH,kDA2xBC;AArfW;IAFT,IAAA,eAAK,EAAC,IAAI,CAAC;IACZ,6DAA6D;;;;;gDAG5D;AAac;IAFd,IAAA,eAAK,EAAC,IAAI,CAAC;IACX,IAAA,YAAK,GAAE;;;;iDAgBP;AAWK;IAFL,IAAA,eAAK,EAAC,IAAI,CAAC;IACX,IAAA,YAAK,GAAE;;;;+CAYP;AAaK;IAFL,IAAA,eAAK,EAAC,IAAI,CAAC;IACX,IAAA,YAAK,GAAE;;;;iDAgBP;AAWK;IAFL,IAAA,eAAK,EAAC,IAAI,CAAC;IACX,IAAA,YAAK,GAAE;;;;iDAaP;AA6BK;IAFL,IAAA,eAAK,EAAC,IAAI,CAAC;IACZ,6DAA6D;;;;;8CAyC5D;AA2UH,mBAAmB,CAAC,UAAU,EAAE,CAAC;AACjC,cAAO,CAAC,UAAU,CAAC,yBAAa,CAAC,CAAC","sourcesContent":["import { CouchDBAdapter, type MangoQuery } from \"@decaf-ts/for-couchdb\";\nimport { Client } from \"@grpc/grpc-js\";\nimport * as grpc from \"@grpc/grpc-js\";\n\nimport {\n  type Constructor,\n  Model,\n  type Serializer,\n} from \"@decaf-ts/decorator-validation\";\nimport { debug, Logger, Logging } from \"@decaf-ts/logging\";\nimport { FabricFlags, PeerConfig } from \"../shared/types\";\nimport {\n  connect,\n  ConnectOptions,\n  Gateway,\n  Network,\n  ProposalOptions,\n  Contract as Contrakt,\n} from \"@hyperledger/fabric-gateway\";\nimport { getIdentity, getSigner } from \"./fabric-fs\";\nimport {\n  BaseError,\n  Context,\n  InternalError,\n  OperationKeys,\n  SerializationError,\n  BulkCrudOperationKeys,\n  modelToTransient,\n} from \"@decaf-ts/db-decorators\";\nimport {\n  Adapter,\n  Dispatch,\n  final,\n  PersistenceKeys,\n  Repository,\n} from \"@decaf-ts/core\";\nimport { FabricClientRepository } from \"./FabricClientRepository\";\nimport { FabricFlavour } from \"../shared/constants\";\nimport { ClientSerializer } from \"../shared/ClientSerializer\";\nimport { FabricClientDispatch } from \"./FabricClientDispatch\";\n\n/**\n * @description Adapter for interacting with Hyperledger Fabric networks\n * @summary The FabricAdapter extends CouchDBAdapter to provide a seamless interface for interacting with Hyperledger Fabric networks.\n * It handles connection management, transaction submission, and CRUD operations against Fabric chaincode.\n * @template PeerConfig - Configuration type for connecting to a Fabric peer\n * @template FabricFlags - Flags specific to Fabric operations\n * @template Context<FabricFlags> - Context type containing Fabric-specific flags\n * @param config - Configuration for connecting to a Fabric peer\n * @param alias - Optional alias for the adapter instance\n * @class FabricClientAdapter\n * @example\n * ```typescript\n * // Create a new FabricAdapter instance\n * const config: PeerConfig = {\n *   mspId: 'Org1MSP',\n *   peerEndpoint: 'localhost:7051',\n *   channelName: 'mychannel',\n *   chaincodeName: 'mycc',\n *   contractName: 'mycontract',\n *   tlsCertPath: '/path/to/tls/cert',\n *   certDirectoryPath: '/path/to/cert/dir',\n *   keyDirectoryPath: '/path/to/key/dir'\n * };\n *\n * const adapter = new FabricAdapter(config, 'org1-adapter');\n *\n * // Use the adapter to interact with the Fabric network\n * const result = await adapter.read('users', 'user1', mySerializer);\n * ```\n * @mermaid\n * sequenceDiagram\n *   participant Client\n *   participant FabricAdapter\n *   participant Gateway\n *   participant Network\n *   participant Contract\n *   participant Chaincode\n *\n *   Client->>FabricAdapter: create(tableName, id, model, transient, serializer)\n *   FabricAdapter->>FabricAdapter: submitTransaction(OperationKeys.CREATE, [serializedModel], transient)\n *   FabricAdapter->>Gateway: connect()\n *   Gateway->>Network: getNetwork(channelName)\n *   Network->>Contract: getContract(chaincodeName, contractName)\n *   FabricAdapter->>Contract: submit(api, proposalOptions)\n *   Contract->>Chaincode: invoke\n *   Chaincode-->>Contract: response\n *   Contract-->>FabricAdapter: result\n *   FabricAdapter->>FabricAdapter: decode(result)\n *   FabricAdapter->>FabricAdapter: serializer.deserialize(decodedResult)\n *   FabricAdapter-->>Client: deserializedResult\n */\nexport class FabricClientAdapter extends CouchDBAdapter<\n  PeerConfig,\n  Client,\n  FabricFlags,\n  Context<FabricFlags>\n> {\n  /**\n   * @description Static text decoder for converting Uint8Array to string\n   */\n  private static decoder = new TextDecoder(\"utf8\");\n\n  private static serializer = new ClientSerializer();\n\n  /**\n   * @description Static logger instance for the FabricAdapter class\n   */\n  private static log: Logger = Logging.for(FabricClientAdapter);\n\n  /**\n   * @description Gets the logger instance for this adapter\n   * @summary Returns the static logger instance for the FabricAdapter class\n   * @return {Logger} The logger instance\n   */\n  protected override get log(): Logger {\n    return FabricClientAdapter.log;\n  }\n\n  protected readonly serializer: Serializer<any> =\n    FabricClientAdapter.serializer;\n\n  /**\n   * @description Creates a new FabricAdapter instance\n   * @summary Initializes a new adapter for interacting with a Hyperledger Fabric network\n   * @param {PeerConfig} config - Configuration for connecting to a Fabric peer\n   * @param {string} [alias] - Optional alias for the adapter instance\n   */\n  constructor(config: PeerConfig, alias?: string) {\n    super(config, FabricFlavour, alias);\n  }\n\n  /**\n   * @description Decodes a Uint8Array to a string\n   * @summary Converts binary data received from Fabric to a string using UTF-8 encoding\n   * @param {Uint8Array} data - The binary data to decode\n   * @return {string} The decoded string\n   */\n  decode(data: Uint8Array): string {\n    return FabricClientAdapter.decoder.decode(data);\n  }\n\n  override repository<M extends Model<true | false>>(): Constructor<\n    Repository<\n      M,\n      MangoQuery,\n      Adapter<\n        PeerConfig,\n        Client,\n        MangoQuery,\n        FabricFlags,\n        Context<FabricFlags>\n      >,\n      FabricFlags,\n      Context<FabricFlags>\n    >\n  > {\n    return FabricClientRepository;\n  }\n\n  /**\n   * @description Creates multiple records in a single transaction\n   * @summary Submits a transaction to create multiple records in the Fabric ledger\n   * @param {string} tableName - The name of the table/collection\n   * @param {string[] | number[]} ids - Array of record identifiers\n   * @param {Array<Record<string, any>>} models - Array of record data\n   * @param {Record<string, any>} transient - Transient data for the transaction\n   * @return {Promise<Array<Record<string, any>>>} Promise resolving to the created records\n   */\n  override async createAll(\n    tableName: string,\n    ids: string[] | number[],\n    models: Record<string, any>[],\n    transient: Record<string, any>\n  ): Promise<Record<string, any>[]> {\n    const log = this.log.for(this.createAll);\n    if (ids.length !== models.length)\n      throw new InternalError(\n        `Ids and models must have the same length: ${ids.length} != ${models.length}`\n      );\n    log.info(`adding ${ids.length} entries to ${tableName} table`);\n    log.verbose(`pks: ${ids}`);\n    const result = await this.submitTransaction(\n      BulkCrudOperationKeys.CREATE_ALL,\n      [ids, models.map((m) => this.serializer.serialize(m, tableName))],\n      transient\n    );\n    try {\n      return JSON.parse(this.decode(result)).map((r: any) => JSON.parse(r));\n    } catch (e: unknown) {\n      throw new SerializationError(e as Error);\n    }\n  }\n\n  /**\n   * @description Reads multiple records in a single transaction\n   * @summary Submits a transaction to read multiple records from the Fabric ledger\n   * @param {string} tableName - The name of the table/collection\n   * @param {string[] | number[]} ids - Array of record identifiers to read\n   * @return {Promise<Array<Record<string, any>>>} Promise resolving to the retrieved records\n   */\n  override async readAll(\n    tableName: string,\n    ids: string[] | number[]\n  ): Promise<Record<string, any>[]> {\n    const log = this.log.for(this.readAll);\n    log.info(`reading ${ids.length} entries to ${tableName} table`);\n    log.verbose(`pks: ${ids}`);\n    const result = await this.submitTransaction(\n      BulkCrudOperationKeys.READ_ALL,\n      [ids]\n    );\n    try {\n      return JSON.parse(this.decode(result)).map((r: any) => JSON.parse(r));\n    } catch (e: unknown) {\n      throw new SerializationError(e as Error);\n    }\n  }\n\n  /**\n   * @description Updates multiple records in a single transaction\n   * @summary Submits a transaction to update multiple records in the Fabric ledger\n   * @param {string} tableName - The name of the table/collection\n   * @param {string[] | number[]} ids - Array of record identifiers\n   * @param {Array<Record<string, any>>} models - Array of updated record data\n   * @param {Record<string, any>} transient - Transient data for the transaction\n   * @return {Promise<Array<Record<string, any>>>} Promise resolving to the updated records\n   */\n  override async updateAll(\n    tableName: string,\n    ids: string[] | number[],\n    models: Record<string, any>[],\n    transient: Record<string, any>\n  ): Promise<Record<string, any>[]> {\n    const log = this.log.for(this.updateAll);\n    if (ids.length !== models.length)\n      throw new InternalError(\n        `Ids and models must have the same length: ${ids.length} != ${models.length}`\n      );\n    log.info(`updating ${ids.length} entries to ${tableName} table`);\n    log.verbose(`pks: ${ids}`);\n    const result = await this.submitTransaction(\n      BulkCrudOperationKeys.UPDATE_ALL,\n      [ids, models.map((m) => this.serializer.serialize(m, tableName))],\n      transient\n    );\n    try {\n      return JSON.parse(this.decode(result)).map((r: any) => JSON.parse(r));\n    } catch (e: unknown) {\n      throw new SerializationError(e as Error);\n    }\n  }\n\n  /**\n   * @description Deletes multiple records in a single transaction\n   * @summary Submits a transaction to delete multiple records from the Fabric ledger\n   * @param {string} tableName - The name of the table/collection\n   * @param {Array<string | number | bigint>} ids - Array of record identifiers to delete\n   * @param {Serializer<any>} serializer - Serializer for the model data\n   * @return {Promise<Array<Record<string, any>>>} Promise resolving to the deleted records\n   */\n  override async deleteAll(\n    tableName: string,\n    ids: (string | number | bigint)[]\n  ): Promise<Record<string, any>[]> {\n    const log = this.log.for(this.deleteAll);\n    log.info(`deleting ${ids.length} entries to ${tableName} table`);\n    log.verbose(`pks: ${ids}`);\n    const result = await this.submitTransaction(\n      BulkCrudOperationKeys.DELETE_ALL,\n      [ids]\n    );\n    try {\n      return JSON.parse(this.decode(result)).map((r: any) => JSON.parse(r));\n    } catch (e: unknown) {\n      throw new SerializationError(e as Error);\n    }\n  }\n\n  /**\n   * @description Prepares a model for persistence\n   * @summary Converts a model instance into a format suitable for database storage,\n   * handling column mapping and separating transient properties\n   * @template M - The model type\n   * @param {M} model - The model instance to prepare\n   * @param pk - The primary key property name\n   * @return The prepared data\n   */\n  override prepare<M extends Model>(\n    model: M,\n    pk: keyof M\n  ): {\n    record: Record<string, any>;\n    id: string;\n    transient?: Record<string, any>;\n  } {\n    const log = this.log.for(this.prepare);\n    const split = modelToTransient(model);\n    if ((model as any)[PersistenceKeys.METADATA]) {\n      log.silly(\n        `Passing along persistence metadata for ${(model as any)[PersistenceKeys.METADATA]}`\n      );\n      Object.defineProperty(split.model, PersistenceKeys.METADATA, {\n        enumerable: false,\n        writable: false,\n        configurable: true,\n        value: (model as any)[PersistenceKeys.METADATA],\n      });\n    }\n\n    return {\n      record: split.model,\n      id: model[pk] as string,\n      transient: split.transient,\n    };\n  }\n\n  /**\n   * @description Converts database data back into a model instance\n   * @summary Reconstructs a model instance from database data, handling column mapping\n   * and reattaching transient properties\n   * @template M - The model type\n   * @param obj - The database record\n   * @param {string|Constructor<M>} clazz - The model class or name\n   * @param pk - The primary key property name\n   * @param {string|number|bigint} id - The primary key value\n   * @param [transient] - Transient properties to reattach\n   * @return {M} The reconstructed model instance\n   */\n  override revert<M extends Model>(\n    obj: Record<string, any>,\n    clazz: string | Constructor<M>,\n    pk: keyof M,\n    id: string | number | bigint,\n    transient?: Record<string, any>\n  ): M {\n    const log = this.log.for(this.revert);\n    const ob: Record<string, any> = {};\n    ob[pk as string] = id;\n    const m = (\n      typeof clazz === \"string\" ? Model.build(ob, clazz) : new clazz(ob)\n    ) as M;\n    log.silly(`Rebuilding model ${m.constructor.name} id ${id}`);\n    const metadata = obj[PersistenceKeys.METADATA];\n    const result = Object.keys(m).reduce((accum: M, key) => {\n      (accum as Record<string, any>)[key] = obj[key];\n      return accum;\n    }, m);\n\n    if (transient) {\n      log.verbose(\n        `re-adding transient properties: ${Object.keys(transient).join(\", \")}`\n      );\n      Object.entries(transient).forEach(([key, val]) => {\n        if (key in result && (result as any)[key] !== undefined)\n          throw new InternalError(\n            `Transient property ${key} already exists on model ${m.constructor.name}. should be impossible`\n          );\n        result[key as keyof M] = val;\n      });\n    }\n\n    if (metadata) {\n      log.silly(\n        `Passing along ${this.flavour} persistence metadata for ${m.constructor.name} id ${id}: ${metadata}`\n      );\n      Object.defineProperty(result, PersistenceKeys.METADATA, {\n        enumerable: false,\n        configurable: false,\n        writable: false,\n        value: metadata,\n      });\n    }\n\n    return result;\n  }\n\n  /**\n   * @description Creates an index for a model\n   * @summary This method is not implemented for Fabric and will throw an error\n   * @template M - Type extending Model\n   * @param {Constructor<M>} models - The model constructor\n   * @return {Promise<void>} Promise that will throw an error\n   */\n  @debug(true)\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars\n  protected index<M>(models: Constructor<M>): Promise<void> {\n    throw new Error();\n  }\n\n  /**\n   * @description Creates a single record\n   * @summary Submits a transaction to create a record in the Fabric ledger\n   * @param {string} tableName - The name of the table/collection\n   * @param {string | number} id - The record identifier\n   * @param {Record<string, any>} model - The record data\n   * @param {Record<string, any>} transient - Transient data for the transaction\n   * @return {Promise<Record<string, any>>} Promise resolving to the created record\n   */\n  @debug(true)\n  @final()\n  override async create(\n    tableName: string,\n    id: string | number,\n    model: Record<string, any>,\n    transient: Record<string, any>\n  ): Promise<Record<string, any>> {\n    const log = this.log.for(this.create);\n    log.verbose(`adding entry to ${tableName} table`);\n    log.debug(`pk: ${id}`);\n    const result = await this.submitTransaction(\n      OperationKeys.CREATE,\n      [this.serializer.serialize(model, tableName)],\n      transient\n    );\n    return this.serializer.deserialize(this.decode(result));\n  }\n\n  /**\n   * @description Reads a single record\n   * @summary Evaluates a transaction to read a record from the Fabric ledger\n   * @param {string} tableName - The name of the table/collection\n   * @param {string | number} id - The record identifier\n   * @return {Promise<Record<string, any>>} Promise resolving to the retrieved record\n   */\n  @debug(true)\n  @final()\n  async read(\n    tableName: string,\n    id: string | number\n  ): Promise<Record<string, any>> {\n    const log = this.log.for(this.read);\n    log.verbose(`reading entry from ${tableName} table`);\n    log.debug(`pk: ${id}`);\n    const result = await this.evaluateTransaction(OperationKeys.READ, [\n      id.toString(),\n    ]);\n    return this.serializer.deserialize(this.decode(result));\n  }\n\n  /**\n   * @description Updates a single record\n   * @summary Submits a transaction to update a record in the Fabric ledger\n   * @param {string} tableName - The name of the table/collection\n   * @param {string | number} id - The record identifier\n   * @param {Record<string, any>} model - The updated record data\n   * @param {Record<string, any>} transient - Transient data for the transaction\n   * @return {Promise<Record<string, any>>} Promise resolving to the updated record\n   */\n  @debug(true)\n  @final()\n  async update(\n    tableName: string,\n    id: string | number,\n    model: Record<string, any>,\n    transient: Record<string, any>\n  ): Promise<Record<string, any>> {\n    const log = this.log.for(this.update);\n    log.verbose(`updating entry to ${tableName} table`);\n    log.debug(`pk: ${id}`);\n    const result = await this.submitTransaction(\n      OperationKeys.UPDATE,\n      [this.serializer.serialize(model, tableName)],\n      transient\n    );\n    return this.serializer.deserialize(this.decode(result));\n  }\n\n  /**\n   * @description Deletes a single record\n   * @summary Submits a transaction to delete a record from the Fabric ledger\n   * @param {string} tableName - The name of the table/collection\n   * @param {string | number} id - The record identifier to delete\n   * @return {Promise<Record<string, any>>} Promise resolving to the deleted record\n   */\n  @debug(true)\n  @final()\n  async delete(\n    tableName: string,\n    id: string | number\n  ): Promise<Record<string, any>> {\n    const log = this.log.for(this.delete);\n    log.verbose(`deleting entry from ${tableName} table`);\n    log.debug(`pk: ${id}`);\n    const result = await this.submitTransaction(OperationKeys.DELETE, [\n      tableName,\n      id,\n    ]);\n    return this.serializer.deserialize(this.decode(result));\n  }\n\n  /**\n   * @description Executes a raw query against the Fabric ledger\n   * @summary Evaluates a transaction to perform a query using Mango Query syntax\n   * @template V - The return type\n   * @param {MangoQuery} rawInput - The Mango Query to execute\n   * @param {boolean} process - Whether to process the result\n   * @return {Promise<V>} Promise resolving to the query result\n   * @mermaid\n   * sequenceDiagram\n   *   participant Client\n   *   participant FabricAdapter\n   *   participant Contract\n   *   participant Chaincode\n   *\n   *   Client->>FabricAdapter: raw(rawInput, process)\n   *   FabricAdapter->>FabricAdapter: JSON.stringify(rawInput)\n   *   FabricAdapter->>FabricAdapter: evaluateTransaction(\"query\", [input])\n   *   FabricAdapter->>Contract: evaluate(\"query\", proposalOptions)\n   *   Contract->>Chaincode: invoke\n   *   Chaincode-->>Contract: response\n   *   Contract-->>FabricAdapter: result\n   *   FabricAdapter->>FabricAdapter: JSON.parse(decode(result))\n   *   FabricAdapter->>FabricAdapter: Process result based on type\n   *   FabricAdapter-->>Client: processed result\n   */\n  @debug(true)\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars\n  async raw<V>(rawInput: MangoQuery, process: boolean): Promise<V> {\n    const log = this.log.for(this.raw);\n    log.info(`Performing raw  query on table`);\n    log.debug(`processing raw input for query: ${JSON.stringify(rawInput)}`);\n    let input: string;\n    try {\n      input = JSON.stringify(rawInput);\n    } catch (e: any) {\n      throw new SerializationError(\n        `Failed to process raw input for query: ${e}`\n      );\n    }\n    let transactionResult: any;\n    try {\n      transactionResult = await this.evaluateTransaction(\"query\", [input]);\n    } catch (e: unknown) {\n      throw this.parseError(e as Error);\n    }\n    let result: any;\n    try {\n      result = JSON.parse(this.decode(transactionResult));\n    } catch (e: any) {\n      throw new SerializationError(`Failed to process result: ${e}`);\n    }\n\n    const parseRecord = (record: Record<any, any>) => {\n      if (Model.isModel(record)) return Model.build(record);\n      return record;\n    };\n\n    if (Array.isArray(result)) {\n      if (!result.length) return result as V;\n      const el = result[0];\n      if (Model.isModel(el))\n        // if the first one is a model, all are models\n        return result.map((el) => Model.build(el)) as V;\n      return result as V;\n    }\n\n    return parseRecord(result as any) as V;\n  }\n\n  /**\n   * @description Gets or creates a gRPC client for the Fabric peer\n   * @summary Returns a cached client or creates a new one if none exists\n   * @return {Promise<Client>} Promise resolving to the gRPC client\n   */\n  override getClient(): Client {\n    if (!this._client)\n      this._client = FabricClientAdapter.getClient(this.config);\n    return this._client;\n  }\n\n  /**\n   * @description Gets a Gateway instance for the Fabric network\n   * @summary Creates a new Gateway instance using the current client\n   * @return {Promise<Gateway>} Promise resolving to the Gateway instance\n   */\n  protected async Gateway(): Promise<Gateway> {\n    return FabricClientAdapter.getGateway(this.config, this.client);\n  }\n\n  /**\n   * @description Gets a Contract instance for the Fabric chaincode\n   * @summary Creates a new Contract instance using the current Gateway\n   * @return {Promise<Contrakt>} Promise resolving to the Contract instance\n   */\n  protected async Contract(): Promise<Contrakt> {\n    return FabricClientAdapter.getContract(await this.Gateway(), this.config);\n  }\n\n  /**\n   * @description Executes a transaction on the Fabric network\n   * @summary Submits or evaluates a transaction on the Fabric chaincode\n   * @param {string} api - The chaincode function to call\n   * @param {boolean} submit - Whether to submit (true) or evaluate (false) the transaction\n   * @param {any[]} [args] - Arguments to pass to the chaincode function\n   * @param {Record<string, string>} [transientData] - Transient data for the transaction\n   * @param {Array<string>} [endorsingOrganizations] - Organizations that must endorse the transaction\n   * @return {Promise<Uint8Array>} Promise resolving to the transaction result\n   * @mermaid\n   * sequenceDiagram\n   *   participant FabricAdapter\n   *   participant Gateway\n   *   participant Contract\n   *   participant Chaincode\n   *\n   *   FabricAdapter->>Gateway: connect()\n   *   FabricAdapter->>Contract: getContract()\n   *   alt submit transaction\n   *     FabricAdapter->>Contract: submit(api, proposalOptions)\n   *   else evaluate transaction\n   *     FabricAdapter->>Contract: evaluate(api, proposalOptions)\n   *   end\n   *   Contract->>Chaincode: invoke\n   *   Chaincode-->>Contract: response\n   *   Contract-->>FabricAdapter: result\n   *   FabricAdapter->>Gateway: close()\n   */\n  protected async transaction(\n    api: string,\n    submit = true,\n    args?: any[],\n    transientData?: Record<string, string>,\n    endorsingOrganizations?: Array<string>\n  ): Promise<Uint8Array> {\n    const log = this.log.for(this.transaction);\n    const gateway = await this.Gateway();\n    try {\n      const contract = await this.Contract();\n      log.verbose(\n        `${submit ? \"Submit\" : \"Evaluate\"}ting transaction ${this.config.contractName}.${api}`\n      );\n      log.debug(`args: ${args?.map((a) => a.toString()).join(\"\\n\") || \"none\"}`);\n      const method = submit ? contract.submit : contract.evaluate;\n\n      // eslint-disable-next-line @typescript-eslint/no-unused-vars\n      endorsingOrganizations = endorsingOrganizations?.length\n        ? endorsingOrganizations\n        : undefined;\n      const proposalOptions: ProposalOptions = {\n        arguments: args || [],\n        transientData: transientData,\n        // ...(endorsingOrganizations && { endorsingOrganizations }) // mspId list\n      };\n\n      return await method.call(contract, api, proposalOptions);\n    } catch (e: any) {\n      if (e.code === 10) {\n        throw new Error(`${e.details[0].message}`);\n      }\n      throw this.parseError(e);\n    } finally {\n      this.log.debug(`Closing ${this.config.mspId} gateway connection`);\n      gateway.close();\n    }\n  }\n\n  /**\n   * @description Parses an error into a BaseError\n   * @summary Converts any error into a standardized BaseError\n   * @param {Error | string} err - The error to parse\n   * @param {string} [reason] - Optional reason for the error\n   * @return {BaseError} The parsed error\n   */\n  override parseError(err: Error | string, reason?: string): BaseError {\n    return FabricClientAdapter.parseError(err, reason);\n  }\n\n  /**\n   * @description Submits a transaction to the Fabric network\n   * @summary Executes a transaction that modifies the ledger state\n   * @param {string} api - The chaincode function to call\n   * @param {any[]} [args] - Arguments to pass to the chaincode function\n   * @param {Record<string, string>} [transientData] - Transient data for the transaction\n   * @param {Array<string>} [endorsingOrganizations] - Organizations that must endorse the transaction\n   * @return {Promise<Uint8Array>} Promise resolving to the transaction result\n   */\n  async submitTransaction(\n    api: string,\n    args?: any[],\n    transientData?: Record<string, string>,\n    endorsingOrganizations?: Array<string>\n  ): Promise<Uint8Array> {\n    return this.transaction(\n      api,\n      true,\n      args,\n      transientData,\n      endorsingOrganizations\n    );\n  }\n\n  /**\n   * @description Evaluates a transaction on the Fabric network\n   * @summary Executes a transaction that does not modify the ledger state\n   * @param {string} api - The chaincode function to call\n   * @param {any[]} [args] - Arguments to pass to the chaincode function\n   * @param {Record<string, string>} [transientData] - Transient data for the transaction\n   * @param {Array<string>} [endorsingOrganizations] - Organizations that must endorse the transaction\n   * @return {Promise<Uint8Array>} Promise resolving to the transaction result\n   */\n  async evaluateTransaction(\n    api: string,\n    args?: any[],\n    transientData?: Record<string, string>,\n    endorsingOrganizations?: Array<string>\n  ): Promise<Uint8Array> {\n    return this.transaction(\n      api,\n      false,\n      args,\n      transientData,\n      endorsingOrganizations\n    );\n  }\n\n  /**\n   * @description Closes the connection to the Fabric network\n   * @summary Closes the gRPC client if it exists\n   * @return {Promise<void>} Promise that resolves when the client is closed\n   */\n  async close(): Promise<void> {\n    if (this.client) {\n      this.log.verbose(`Closing ${this.config.mspId} gateway client`);\n      this.client.close();\n    }\n  }\n\n  /**\n   * @description Gets a Contract instance from a Gateway\n   * @summary Retrieves a chaincode contract from the specified network\n   * @param {Gateway} gateway - The Gateway instance\n   * @param {PeerConfig} config - The peer configuration\n   * @return {Contrakt} The Contract instance\n   */\n  static getContract(gateway: Gateway, config: PeerConfig): Contrakt {\n    const log = this.log.for(this.getContract);\n    const network = this.getNetwork(gateway, config.channel);\n    let contract: Contrakt;\n    try {\n      log.debug(\n        `Retrieving chaincode ${config.chaincodeName} contract ${config.contractName} from network ${config.channel}`\n      );\n      contract = network.getContract(config.chaincodeName, config.contractName);\n    } catch (e: any) {\n      throw this.parseError(e);\n    }\n    return contract;\n  }\n\n  /**\n   * @description Gets a Network instance from a Gateway\n   * @summary Connects to a specific channel on the Fabric network\n   * @param {Gateway} gateway - The Gateway instance\n   * @param {string} channelName - The name of the channel to connect to\n   * @return {Network} The Network instance\n   */\n  static getNetwork(gateway: Gateway, channelName: string): Network {\n    const log = this.log.for(this.getNetwork);\n    let network: Network;\n    try {\n      log.debug(`Connecting to channel ${channelName}`);\n      network = gateway.getNetwork(channelName);\n    } catch (e: any) {\n      throw this.parseError(e);\n    }\n\n    return network;\n  }\n\n  /**\n   * @description Gets a Gateway instance for connecting to the Fabric network\n   * @summary Creates a Gateway using the provided configuration and client\n   * @param {PeerConfig} config - The peer configuration\n   * @param {Client} [client] - Optional gRPC client, will be created if not provided\n   * @return {Promise<Gateway>} Promise resolving to the Gateway instance\n   */\n  static async getGateway(config: PeerConfig, client?: Client) {\n    return (await this.getConnection(\n      client || (await this.getClient(config)),\n      config\n    )) as Gateway;\n  }\n\n  /**\n   * @description Creates a gRPC client for connecting to a Fabric peer\n   * @summary Initializes a client with TLS credentials for secure communication\n   * @param {PeerConfig} config - The peer configuration\n   * @return {Client} Promise resolving to the gRPC client\n   */\n  static getClient(config: PeerConfig): Client {\n    const log = this.log.for(this.getClient);\n    log.debug(`generating TLS credentials for msp ${config.mspId}`);\n    const tlsCredentials = grpc.credentials.createSsl(\n      typeof config.tlsCert === \"string\"\n        ? Buffer.from(config.tlsCert)\n        : config.tlsCert\n    );\n    log.debug(`generating Gateway Client for url ${config.peerEndpoint}`);\n    return new Client(config.peerEndpoint, tlsCredentials);\n  }\n\n  /**\n   * @description Establishes a connection to the Fabric network\n   * @summary Creates a Gateway connection with identity and signer\n   * @param {Client} client - The gRPC client\n   * @param {PeerConfig} config - The peer configuration\n   * @return {Promise<Gateway>} Promise resolving to the connected Gateway\n   * @mermaid\n   * sequenceDiagram\n   *   participant Caller\n   *   participant FabricAdapter\n   *   participant Identity\n   *   participant Signer\n   *   participant Gateway\n   *\n   *   Caller->>FabricAdapter: getConnection(client, config)\n   *   FabricAdapter->>Identity: getIdentity(mspId, certDirectoryPath)\n   *   Identity-->>FabricAdapter: identity\n   *   FabricAdapter->>Signer: getSigner(keyDirectoryPath)\n   *   Signer-->>FabricAdapter: signer\n   *   FabricAdapter->>FabricAdapter: Create ConnectOptions\n   *   FabricAdapter->>Gateway: connect(options)\n   *   Gateway-->>FabricAdapter: gateway\n   *   FabricAdapter-->>Caller: gateway\n   */\n  static async getConnection(client: Client, config: PeerConfig) {\n    const log = this.log.for(this.getConnection);\n    log.debug(\n      `Retrieving Peer Identity for ${config.mspId} under ${config.certCertOrDirectoryPath}`\n    );\n    const identity = await getIdentity(\n      config.mspId,\n      config.certCertOrDirectoryPath\n    );\n    log.debug(`Retrieving signer key from ${config.keyCertOrDirectoryPath}`);\n\n    const signer = await getSigner(config.keyCertOrDirectoryPath);\n\n    const options = {\n      client,\n      identity: identity,\n      signer: signer,\n      // Default timeouts for different gRPC calls\n      evaluateOptions: () => {\n        return { deadline: Date.now() + 5000 }; // 5 seconds\n      },\n      endorseOptions: () => {\n        return { deadline: Date.now() + 15000 }; // 15 seconds\n      },\n      submitOptions: () => {\n        return { deadline: Date.now() + 5000 }; // 5 seconds\n      },\n      commitStatusOptions: () => {\n        return { deadline: Date.now() + 60000 }; // 1 minute\n      },\n    } as ConnectOptions;\n\n    log.debug(`Connecting to ${config.mspId}`);\n    return connect(options);\n  }\n\n  /**\n   * @description Creates a new Dispatch instance for the Fabric client.\n   * @summary This function is responsible for creating a new FabricClientDispatch instance that can be used to interact with the Fabric network.\n   * @returns {Dispatch} A new Dispatch instance configured for the Fabric client.\n   * @remarks The Dispatch instance is used to encapsulate the logic for interacting with the Fabric network, such as submitting transactions or querying data.\n   * @example\n   * const fabricDispatch = fabricClientAdapter.Dispatch();\n   * fabricDispatch.submitTransaction('createProduct', { name: 'Product A', price: 100 });\n   */\n  override Dispatch(): Dispatch {\n    return new FabricClientDispatch(this.getClient());\n  }\n\n  /**\n   * @description Parses an error into a BaseError\n   * @summary Converts any error into a standardized BaseError using the parent class implementation\n   * @param {Error | string} err - The error to parse\n   * @param {string} [reason] - Optional reason for the error\n   * @return {BaseError} The parsed error\n   */\n  protected static override parseError(\n    err: Error | string,\n    reason?: string\n  ): BaseError {\n    return super.parseError(err, reason);\n  }\n}\n\nFabricClientAdapter.decoration();\nAdapter.setCurrent(FabricFlavour);\n"]}