@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,730 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.FabricContractAdapter = void 0;
4
+ exports.createdByOnFabricCreateUpdate = createdByOnFabricCreateUpdate;
5
+ exports.pkFabricOnCreate = pkFabricOnCreate;
6
+ const for_couchdb_1 = require("@decaf-ts/for-couchdb");
7
+ const decorator_validation_1 = require("@decaf-ts/decorator-validation");
8
+ const ContractContext_1 = require("./ContractContext.cjs");
9
+ const db_decorators_1 = require("@decaf-ts/db-decorators");
10
+ const fabric_contract_api_1 = require("fabric-contract-api");
11
+ const logging_1 = require("@decaf-ts/logging");
12
+ const core_1 = require("@decaf-ts/core");
13
+ const FabricContractRepository_1 = require("./FabricContractRepository.cjs");
14
+ const FabricContractStatement_1 = require("./FabricContractStatement.cjs");
15
+ const FabricContractSequence_1 = require("./FabricContractSequence.cjs");
16
+ const errors_1 = require("./../shared/errors.cjs");
17
+ const constants_1 = require("./../shared/constants.cjs");
18
+ const SimpleDeterministicSerializer_1 = require("./../shared/SimpleDeterministicSerializer.cjs");
19
+ const FabricConstruction_1 = require("./FabricConstruction.cjs");
20
+ const reflection_1 = require("@decaf-ts/reflection");
21
+ /**
22
+ * @description Sets the creator or updater field in a model based on the user in the context
23
+ * @summary Callback function used in decorators to automatically set the created_by or updated_by fields
24
+ * with the username from the context when a document is created or updated
25
+ * @template M - Type extending Model
26
+ * @template R - Type extending NanoRepository<M>
27
+ * @template V - Type extending RelationsMetadata
28
+ * @param {R} this - The repository instance
29
+ * @param {FabricContractContext} context - The operation context containing user information
30
+ * @param {V} data - The relation metadata
31
+ * @param {string} key - The property key to set with the username
32
+ * @param {M} model - The model instance being created or updated
33
+ * @return {Promise<void>} A promise that resolves when the operation is complete
34
+ * @function createdByOnFabricCreateUpdate
35
+ * @memberOf module:fabric.contracts
36
+ * @mermaid
37
+ * sequenceDiagram
38
+ * participant F as createdByOnNanoCreateUpdate
39
+ * participant C as Context
40
+ * participant M as Model
41
+ * F->>C: get("user")
42
+ * C-->>F: user object
43
+ * F->>M: set key to user.name
44
+ * Note over F: If no user in context
45
+ * F-->>F: throw UnsupportedError
46
+ */
47
+ async function createdByOnFabricCreateUpdate(context, data, key, model) {
48
+ try {
49
+ const user = context.get("clientIdentity");
50
+ model[key] = user.getID();
51
+ // eslint-disable-next-line @typescript-eslint/no-unused-vars
52
+ }
53
+ catch (e) {
54
+ throw new core_1.UnsupportedError("No User found in context. Please provide a user in the context");
55
+ }
56
+ }
57
+ /**
58
+ * @description Primary key auto-assignment callback for Fabric models
59
+ * @summary Generates and assigns a primary key value to the specified model property using a Fabric-backed sequence when the model is created. If the sequence name is not provided in options, it is derived from the model via sequenceNameForModel. The assigned key is defined as non-writable and enumerable.
60
+ * @template M - Type extending Model for the target instance
61
+ * @template R - Type extending FabricContractRepository for repository context
62
+ * @template V - Type extending SequenceOptions to configure sequence behavior
63
+ * @template F - Type extending FabricContractFlags for contextual flags
64
+ * @param {R} this - The repository instance invoking the callback
65
+ * @param {FabricContractContext} context - Fabric contract context containing invocation metadata
66
+ * @param {V} data - Sequence options used to configure or locate the sequence
67
+ * @param {string} key - The primary key property name to assign on the model
68
+ * @param {M} model - The model instance to receive the generated primary key
69
+ * @return {Promise<void>} Resolves when the key is assigned or when no action is required
70
+ * @function pkFabricOnCreate
71
+ * @memberOf module:for-fabric.contracts
72
+ * @mermaid
73
+ * sequenceDiagram
74
+ * participant R as Repository
75
+ * participant C as Context<F>
76
+ * participant S as FabricContractDBSequence
77
+ * participant M as Model
78
+ * R->>R: derive sequence name if missing
79
+ * R->>S: adapter.Sequence(options)
80
+ * S-->>R: sequence instance
81
+ * R->>S: next(context)
82
+ * S-->>R: next value
83
+ * R->>M: define non-writable primary key
84
+ */
85
+ async function pkFabricOnCreate(context, data, key, model) {
86
+ if (!data.type || model[key]) {
87
+ return;
88
+ }
89
+ const setPrimaryKeyValue = function (target, propertyKey, value) {
90
+ Object.defineProperty(target, propertyKey, {
91
+ enumerable: true,
92
+ writable: false,
93
+ configurable: true,
94
+ value: value,
95
+ });
96
+ };
97
+ if (!data.name)
98
+ data.name = (0, core_1.sequenceNameForModel)(model, "pk");
99
+ let sequence;
100
+ try {
101
+ sequence = (await this.adapter.Sequence(data));
102
+ }
103
+ catch (e) {
104
+ throw new db_decorators_1.InternalError(`Failed to instantiate Sequence ${data.name}: ${e}`);
105
+ }
106
+ const next = await sequence.next(context);
107
+ setPrimaryKeyValue(model, key, next);
108
+ }
109
+ /**
110
+ * @description Adapter for Hyperledger Fabric chaincode state database operations
111
+ * @summary Provides a CouchDB-like interface for interacting with the Fabric state database from within a chaincode contract
112
+ * @template void - No configuration needed for contract adapter
113
+ * @template FabricContractFlags - Flags specific to Fabric contract operations
114
+ * @template FabricContractContext - Context type for Fabric contract operations
115
+ * @class FabricContractAdapter
116
+ * @example
117
+ * ```typescript
118
+ * // In a Fabric chaincode contract class
119
+ * import { FabricContractAdapter } from '@decaf-ts/for-fabric';
120
+ *
121
+ * export class MyContract extends Contract {
122
+ * private adapter = new FabricContractAdapter();
123
+ *
124
+ * @Transaction()
125
+ * async createAsset(ctx: Context, id: string, data: string): Promise<void> {
126
+ * const model = { id, data, timestamp: Date.now() };
127
+ * await this.adapter.create('assets', id, model, {}, { stub: ctx.stub });
128
+ * }
129
+ * }
130
+ * ```
131
+ * @mermaid
132
+ * sequenceDiagram
133
+ * participant Contract
134
+ * participant FabricContractAdapter
135
+ * participant Stub
136
+ * participant StateDB
137
+ *
138
+ * Contract->>FabricContractAdapter: create(tableName, id, model, transient, ctx)
139
+ * FabricContractAdapter->>FabricContractAdapter: Serialize model to JSON
140
+ * FabricContractAdapter->>Stub: putState(id, serializedData)
141
+ * Stub->>StateDB: Write data
142
+ * StateDB-->>Stub: Success
143
+ * Stub-->>FabricContractAdapter: Success
144
+ * FabricContractAdapter-->>Contract: model
145
+ */
146
+ class FabricContractAdapter extends for_couchdb_1.CouchDBAdapter {
147
+ getClient() {
148
+ throw new core_1.UnsupportedError("Client is not supported in Fabric contracts");
149
+ }
150
+ /**
151
+ * @description Text decoder for converting binary data to strings
152
+ */
153
+ static { this.textDecoder = new TextDecoder("utf8"); }
154
+ static { this.serializer = new SimpleDeterministicSerializer_1.SimpleDeterministicSerializer(); }
155
+ /**
156
+ * @description Creates a logger for a specific chaincode context
157
+ * @summary Returns a ContractLogger instance configured for the current context
158
+ * @param {Ctx} ctx - The Fabric chaincode context
159
+ * @return {ContractLogger} The logger instance
160
+ */
161
+ logFor(ctx) {
162
+ return logging_1.Logging.for(FabricContractAdapter, {}, ctx);
163
+ }
164
+ /**
165
+ * @description Gets the repository constructor for this adapter
166
+ * @summary Returns the FabricContractRepository constructor for creating repositories
167
+ * @template M - Type extending Model
168
+ * @return {Constructor<Repository<M, MangoQuery, FabricContractAdapter, FabricContractFlags, FabricContractContext>>} The repository constructor
169
+ */
170
+ repository() {
171
+ return FabricContractRepository_1.FabricContractRepository;
172
+ }
173
+ /**
174
+ * @description Creates a new FabricContractAdapter instance
175
+ * @summary Initializes an adapter for interacting with the Fabric state database
176
+ * @param {void} scope - Not used in this adapter
177
+ * @param {string} [alias] - Optional alias for the adapter instance
178
+ */
179
+ constructor(scope, alias) {
180
+ super(scope, constants_1.FabricFlavour, alias);
181
+ /**
182
+ * @description Context constructor for this adapter
183
+ * @summary Overrides the base Context constructor with FabricContractContext
184
+ */
185
+ this.Context = ContractContext_1.FabricContractContext;
186
+ }
187
+ for(config, ...args) {
188
+ return super.for(config, ...args);
189
+ }
190
+ /**
191
+ * @description Creates a record in the state database
192
+ * @summary Serializes a model and stores it in the Fabric state database
193
+ * @param {string} tableName - The name of the table/collection
194
+ * @param {string | number} id - The record identifier
195
+ * @param {Record<string, any>} model - The record data
196
+ * @param {Record<string, any>} transient - Transient data (not used in this implementation)
197
+ * @param {...any[]} args - Additional arguments, including the chaincode stub and logger
198
+ * @return {Promise<Record<string, any>>} Promise resolving to the created record
199
+ */
200
+ async create(tableName, id, model, ...args) {
201
+ const { stub, logger } = args.pop();
202
+ const log = logger.for(this.create);
203
+ try {
204
+ log.info(`adding entry to ${tableName} table with pk ${id}`);
205
+ model = await this.putState(stub, id.toString(), model);
206
+ }
207
+ catch (e) {
208
+ throw this.parseError(e);
209
+ }
210
+ return model;
211
+ }
212
+ /**
213
+ * @description Reads a record from the state database
214
+ * @summary Retrieves and deserializes a record from the Fabric state database
215
+ * @param {string} tableName - The name of the table/collection
216
+ * @param {string | number} id - The record identifier
217
+ * @param {...any[]} args - Additional arguments, including the chaincode stub and logger
218
+ * @return {Promise<Record<string, any>>} Promise resolving to the retrieved record
219
+ */
220
+ async read(tableName, id, ...args) {
221
+ const { stub, logger } = args.pop();
222
+ const log = logger.for(this.read);
223
+ let model;
224
+ try {
225
+ const results = await this.readState(stub, tableName, id.toString());
226
+ if (results.length < 1) {
227
+ log.debug(`No record found for id ${id} in ${tableName} table`);
228
+ throw new db_decorators_1.NotFoundError(`No record found for id ${id} in ${tableName} table`);
229
+ }
230
+ else if (results.length < 2) {
231
+ log.debug(`No record found for id ${id} in ${tableName} table`);
232
+ model = results.pop();
233
+ }
234
+ else {
235
+ model = this.mergeModels(results);
236
+ }
237
+ }
238
+ catch (e) {
239
+ throw this.parseError(e);
240
+ }
241
+ return model;
242
+ }
243
+ /**
244
+ * @description Updates a record in the state database
245
+ * @summary Serializes a model and updates it in the Fabric state database
246
+ * @param {string} tableName - The name of the table/collection
247
+ * @param {string | number} id - The record identifier
248
+ * @param {Record<string, any>} model - The updated record data
249
+ * @param {Record<string, any>} transient - Transient data (not used in this implementation)
250
+ * @param {...any[]} args - Additional arguments, including the chaincode stub and logger
251
+ * @return {Promise<Record<string, any>>} Promise resolving to the updated record
252
+ */
253
+ async update(tableName, id, model, ...args) {
254
+ const { stub, logger } = args.pop();
255
+ const log = logger.for(this.update);
256
+ try {
257
+ log.info(`updating entry to ${tableName} table with pk ${id}`);
258
+ model = await this.putState(stub, id.toString(), model);
259
+ }
260
+ catch (e) {
261
+ throw this.parseError(e);
262
+ }
263
+ return model;
264
+ }
265
+ /**
266
+ * @description Deletes a record from the state database
267
+ * @summary Retrieves a record and then removes it from the Fabric state database
268
+ * @param {string} tableName - The name of the table/collection
269
+ * @param {string | number} id - The record identifier to delete
270
+ * @param {...any[]} args - Additional arguments, including the chaincode stub and logger
271
+ * @return {Promise<Record<string, any>>} Promise resolving to the deleted record
272
+ */
273
+ async delete(tableName, id, ...args) {
274
+ const ctx = args.pop();
275
+ const { stub, logger } = ctx;
276
+ const log = logger.for(this.delete);
277
+ args.push(ctx);
278
+ let model;
279
+ try {
280
+ model = await this.read(tableName, id, ...args);
281
+ log.verbose(`deleting entry with pk ${id} from ${tableName} table`);
282
+ this.deleteState(stub, tableName, id.toString());
283
+ }
284
+ catch (e) {
285
+ throw this.parseError(e);
286
+ }
287
+ return model;
288
+ }
289
+ async deleteState(stub, tableName, id,
290
+ // eslint-disable-next-line @typescript-eslint/no-unused-vars
291
+ ...args) {
292
+ const composedKey = stub.createCompositeKey(tableName, [String(id)]);
293
+ await stub.deleteState(composedKey);
294
+ }
295
+ async putState(stub, id, model,
296
+ // eslint-disable-next-line @typescript-eslint/no-unused-vars
297
+ ...args) {
298
+ let data;
299
+ try {
300
+ data = Buffer.from(FabricContractAdapter.serializer.serialize(model));
301
+ }
302
+ catch (e) {
303
+ throw new db_decorators_1.SerializationError(`Failed to serialize record with id ${id}: ${e}`);
304
+ }
305
+ await stub.putState(id.toString(), data);
306
+ return model;
307
+ }
308
+ async readState(stub, tableName, id,
309
+ // eslint-disable-next-line @typescript-eslint/no-unused-vars
310
+ ...args) {
311
+ const composedKey = stub.createCompositeKey(tableName, [String(id)]);
312
+ const results = [];
313
+ let res = await stub.getState(composedKey);
314
+ if (res.toString() === "")
315
+ throw new db_decorators_1.NotFoundError(`Record with id ${id} not found`);
316
+ try {
317
+ res = FabricContractAdapter.serializer.deserialize(res.toString()
318
+ // model.constructor.name
319
+ );
320
+ }
321
+ catch (e) {
322
+ throw new db_decorators_1.SerializationError(`Failed to parse record: ${e}`);
323
+ }
324
+ results.push(res);
325
+ return results;
326
+ }
327
+ async queryResult(stub, rawInput,
328
+ // eslint-disable-next-line @typescript-eslint/no-unused-vars
329
+ ...args) {
330
+ return (await stub.getQueryResult(JSON.stringify(rawInput)));
331
+ }
332
+ async queryResultPaginated(stub, rawInput, limit = 250, skip,
333
+ // eslint-disable-next-line @typescript-eslint/no-unused-vars
334
+ ...args) {
335
+ return (await stub.getQueryResultWithPagination(JSON.stringify(rawInput), limit, skip?.toString()));
336
+ }
337
+ mergeModels(results) {
338
+ const extract = (model) => Object.entries(model).reduce((accum, [key, val]) => {
339
+ if (typeof val !== "undefined")
340
+ accum[key] = val;
341
+ return accum;
342
+ }, {});
343
+ let finalModel = results.pop();
344
+ for (const res of results) {
345
+ finalModel = Object.assign({}, extract(finalModel), extract(res));
346
+ }
347
+ return finalModel;
348
+ }
349
+ /**
350
+ * @description Decodes binary data to string
351
+ * @summary Converts a Uint8Array to a string using UTF-8 encoding
352
+ * @param {Uint8Array} buffer - The binary data to decode
353
+ * @return {string} The decoded string
354
+ */
355
+ decode(buffer) {
356
+ return FabricContractAdapter.textDecoder.decode(buffer);
357
+ }
358
+ /**
359
+ * @description Creates operation flags for Fabric contract operations
360
+ * @summary Merges default flags with Fabric-specific context information
361
+ * @template M - Type extending Model
362
+ * @param {OperationKeys} operation - The operation being performed
363
+ * @param {Constructor<M>} model - The model constructor
364
+ * @param {Partial<FabricContractFlags>} flags - Partial flags to merge with defaults
365
+ * @param {Ctx} ctx - The Fabric chaincode context
366
+ * @return {FabricContractFlags} The merged flags
367
+ */
368
+ async flags(operation, model, flags, ctx, ...args) {
369
+ return Object.assign(await super.flags(operation, model, flags, ...args), {
370
+ stub: ctx.stub,
371
+ identity: ctx.clientIdentity,
372
+ logger: this.logFor(ctx),
373
+ });
374
+ }
375
+ /**
376
+ * @description Creates an index for a model
377
+ * @summary This method is not implemented for Fabric contracts and returns a resolved promise
378
+ * @template M - Type extending Model
379
+ * @param {Constructor<M>} models - The model constructor
380
+ * @return {Promise<void>} Promise that resolves immediately
381
+ */
382
+ // eslint-disable-next-line @typescript-eslint/no-unused-vars
383
+ index(models) {
384
+ return Promise.resolve(undefined);
385
+ }
386
+ /**
387
+ * @description Processes results from a state query iterator
388
+ * @summary Iterates through query results and converts them to a structured format
389
+ * @param {Logger} log - Logger instance for debugging
390
+ * @param {Iterators.StateQueryIterator} iterator - The state query iterator
391
+ * @param {boolean} [isHistory=false] - Whether this is a history query
392
+ * @return {Promise<any[]>} Promise resolving to an array of processed results
393
+ * @mermaid
394
+ * sequenceDiagram
395
+ * participant Caller
396
+ * participant ResultIterator
397
+ * participant Iterator
398
+ *
399
+ * Caller->>ResultIterator: resultIterator(log, iterator, isHistory)
400
+ * loop Until done
401
+ * ResultIterator->>Iterator: next()
402
+ * Iterator-->>ResultIterator: { value, done }
403
+ * alt Has value
404
+ * ResultIterator->>ResultIterator: Process value based on isHistory
405
+ * ResultIterator->>ResultIterator: Add to results array
406
+ * end
407
+ * end
408
+ * ResultIterator->>Iterator: close()
409
+ * ResultIterator-->>Caller: allResults
410
+ */
411
+ async resultIterator(log, iterator, isHistory = false) {
412
+ const allResults = [];
413
+ let res = await iterator.next();
414
+ while (!res.done) {
415
+ if (res.value && res.value.value.toString()) {
416
+ let jsonRes = {};
417
+ log.debug(res.value.value.toString("utf8"));
418
+ if (isHistory /* && isHistory === true*/) {
419
+ jsonRes.TxId = res.value.txId;
420
+ jsonRes.Timestamp = res.value.timestamp;
421
+ try {
422
+ jsonRes.Value = JSON.parse(res.value.value.toString("utf8"));
423
+ }
424
+ catch (err) {
425
+ log.error(err);
426
+ jsonRes.Value = res.value.value.toString("utf8");
427
+ }
428
+ }
429
+ else {
430
+ try {
431
+ jsonRes = JSON.parse(res.value.value.toString("utf8"));
432
+ }
433
+ catch (err) {
434
+ log.error(err);
435
+ jsonRes = res.value.value.toString("utf8");
436
+ }
437
+ }
438
+ allResults.push(jsonRes);
439
+ }
440
+ res = await iterator.next();
441
+ }
442
+ log.debug(`Closing iterator after ${allResults.length} results`);
443
+ iterator.close(); // purposely not await. let iterator close on its own
444
+ return allResults;
445
+ }
446
+ /**
447
+ * @description Executes a raw query against the state database
448
+ * @summary Performs a rich query using CouchDB syntax against the Fabric state database
449
+ * @template R - The return type
450
+ * @param {MangoQuery} rawInput - The Mango Query to execute
451
+ * @param {boolean} docsOnly - Whether to return only documents (not used in this implementation)
452
+ * @param {...any[]} args - Additional arguments, including the chaincode stub and logger
453
+ * @return {Promise<R>} Promise resolving to the query results
454
+ * @mermaid
455
+ * sequenceDiagram
456
+ * participant Caller
457
+ * participant FabricContractAdapter
458
+ * participant Stub
459
+ * participant StateDB
460
+ *
461
+ * Caller->>FabricContractAdapter: raw(rawInput, docsOnly, ctx)
462
+ * FabricContractAdapter->>FabricContractAdapter: Extract limit and skip
463
+ * alt With pagination
464
+ * FabricContractAdapter->>Stub: getQueryResultWithPagination(query, limit, skip)
465
+ * else Without pagination
466
+ * FabricContractAdapter->>Stub: getQueryResult(query)
467
+ * end
468
+ * Stub->>StateDB: Execute query
469
+ * StateDB-->>Stub: Iterator
470
+ * Stub-->>FabricContractAdapter: Iterator
471
+ * FabricContractAdapter->>FabricContractAdapter: resultIterator(log, iterator)
472
+ * FabricContractAdapter-->>Caller: results
473
+ */
474
+ async raw(rawInput, docsOnly, ...args) {
475
+ const { stub, logger } = args.pop();
476
+ const log = logger.for(this.raw);
477
+ const { skip, limit } = rawInput;
478
+ let iterator;
479
+ if (limit || skip) {
480
+ delete rawInput["limit"];
481
+ delete rawInput["skip"];
482
+ log.debug(`Retrieving paginated iterator: limit: ${limit}/ skip: ${skip}`);
483
+ const response = (await this.queryResultPaginated(stub, rawInput, limit || 250, skip?.toString()));
484
+ iterator = response.iterator;
485
+ }
486
+ else {
487
+ log.debug("Retrieving iterator");
488
+ iterator = (await this.queryResult(stub, rawInput));
489
+ }
490
+ log.debug("Iterator acquired");
491
+ const results = (await this.resultIterator(log, iterator));
492
+ log.debug(`returning {0} results`, `${Array.isArray(results) ? results.length : 1}`);
493
+ return results;
494
+ }
495
+ Statement(ctx) {
496
+ if (!ctx) {
497
+ throw new errors_1.MissingContextError("Context is required");
498
+ }
499
+ return new FabricContractStatement_1.FabricStatement(this, ctx);
500
+ }
501
+ async Sequence(options) {
502
+ return new FabricContractSequence_1.FabricContractSequence(options, this);
503
+ }
504
+ async createAll(tableName, id, model, ...args) {
505
+ if (id.length !== model.length)
506
+ throw new db_decorators_1.InternalError("Ids and models must have the same length");
507
+ const { logger } = args[args.length - 1];
508
+ const log = logger.for(this.createAll);
509
+ log.info(`Creating ${id.length} entries ${tableName} table`);
510
+ log.debug(`pks: ${id}`);
511
+ return Promise.all(id.map(async (i, index) => {
512
+ return this.create(tableName, i, model[index], ...args);
513
+ }));
514
+ }
515
+ async updateAll(tableName, id, model, ...args) {
516
+ if (id.length !== model.length)
517
+ throw new db_decorators_1.InternalError("Ids and models must have the same length");
518
+ const { logger } = args[args.length - 1];
519
+ const log = logger.for(this.createAll);
520
+ log.info(`Updating ${id.length} entries ${tableName} table`);
521
+ log.debug(`pks: ${id}`);
522
+ return Promise.all(id.map(async (i, index) => {
523
+ return this.update(tableName, i, model[index], ...args);
524
+ }));
525
+ }
526
+ /**
527
+ *
528
+ * @param model
529
+ * @param {string} pk
530
+ * @param args
531
+ */
532
+ prepare(model, pk, ...args) {
533
+ const { stub, logger } = args.pop();
534
+ const tableName = args.shift();
535
+ const log = logger.for(this.prepare);
536
+ const split = (0, db_decorators_1.modelToTransient)(model);
537
+ const result = Object.entries(split.model).reduce((accum, [key, val]) => {
538
+ if (typeof val === "undefined")
539
+ return accum;
540
+ const mappedProp = core_1.Repository.column(model, key);
541
+ if (this.isReserved(mappedProp))
542
+ throw new db_decorators_1.InternalError(`Property name ${mappedProp} is reserved`);
543
+ accum[mappedProp] = val;
544
+ return accum;
545
+ }, {});
546
+ if (model[core_1.PersistenceKeys.METADATA]) {
547
+ log.silly(`Passing along persistence metadata for ${model[core_1.PersistenceKeys.METADATA]}`);
548
+ Object.defineProperty(result, core_1.PersistenceKeys.METADATA, {
549
+ enumerable: false,
550
+ writable: false,
551
+ configurable: true,
552
+ value: model[core_1.PersistenceKeys.METADATA],
553
+ });
554
+ }
555
+ log.info(`Preparing record for ${tableName} table with pk ${model[pk]}`);
556
+ return {
557
+ record: result,
558
+ id: stub.createCompositeKey(tableName, [String(model[pk])]),
559
+ transient: split.transient,
560
+ };
561
+ }
562
+ revert(obj, clazz, pk, id, transient) {
563
+ const log = this.log.for(this.revert);
564
+ const ob = {};
565
+ ob[pk] = id;
566
+ const m = (typeof clazz === "string" ? decorator_validation_1.Model.build(ob, clazz) : new clazz(ob));
567
+ log.silly(`Rebuilding model ${m.constructor.name} id ${id}`);
568
+ const metadata = obj[core_1.PersistenceKeys.METADATA];
569
+ const result = Object.keys(m).reduce((accum, key) => {
570
+ accum[key] = obj[core_1.Repository.column(accum, key)];
571
+ return accum;
572
+ }, m);
573
+ if (transient) {
574
+ log.verbose(`re-adding transient properties: ${Object.keys(transient).join(", ")}`);
575
+ Object.entries(transient).forEach(([key, val]) => {
576
+ if (key in result && result[key] !== undefined)
577
+ throw new db_decorators_1.InternalError(`Transient property ${key} already exists on model ${m.constructor.name}. should be impossible`);
578
+ result[key] = val;
579
+ });
580
+ }
581
+ if (metadata) {
582
+ log.silly(`Passing along ${this.flavour} persistence metadata for ${m.constructor.name} id ${id}: ${metadata}`);
583
+ Object.defineProperty(result, core_1.PersistenceKeys.METADATA, {
584
+ enumerable: false,
585
+ configurable: false,
586
+ writable: false,
587
+ value: metadata,
588
+ });
589
+ }
590
+ return result;
591
+ }
592
+ createPrefix(tableName, id, model, ...args) {
593
+ const ctx = args.pop();
594
+ const record = {};
595
+ record[for_couchdb_1.CouchDBKeys.TABLE] = tableName;
596
+ // record[CouchDBKeys.ID] = this.generateId(tableName, id);
597
+ Object.assign(record, model);
598
+ return [tableName, id, record, ctx];
599
+ }
600
+ updatePrefix(tableName, id, model, ...args) {
601
+ const ctx = args.pop();
602
+ const record = {};
603
+ record[for_couchdb_1.CouchDBKeys.TABLE] = tableName;
604
+ // record[CouchDBKeys.ID] = this.generateId(tableName, id);
605
+ Object.assign(record, model);
606
+ return [tableName, id, record, ctx];
607
+ }
608
+ createAllPrefix(tableName, ids, models, ...args) {
609
+ if (ids.length !== models.length)
610
+ throw new db_decorators_1.InternalError("Ids and models must have the same length");
611
+ const ctx = args.pop();
612
+ const records = ids.map((id, count) => {
613
+ const record = {};
614
+ record[for_couchdb_1.CouchDBKeys.TABLE] = tableName;
615
+ // record[CouchDBKeys.ID] = this.generateId(tableName, id);
616
+ Object.assign(record, models[count]);
617
+ return record;
618
+ });
619
+ return [tableName, ids, records, ctx];
620
+ }
621
+ updateAllPrefix(tableName, ids, models, ...args) {
622
+ if (ids.length !== models.length)
623
+ throw new db_decorators_1.InternalError("Ids and models must have the same length");
624
+ const ctx = args.pop();
625
+ const records = ids.map((id, count) => {
626
+ const record = {};
627
+ record[for_couchdb_1.CouchDBKeys.TABLE] = tableName;
628
+ Object.assign(record, models[count]);
629
+ return record;
630
+ });
631
+ return [tableName, ids, records, ctx];
632
+ }
633
+ /**
634
+ * @description Static method for decoration overrides
635
+ * @summary Overrides/extends decaf decoration with Fabric-specific functionality
636
+ * @static
637
+ * @override
638
+ * @return {void}
639
+ */
640
+ static decoration() {
641
+ super.decoration();
642
+ const createdByKey = core_1.Repository.key(core_1.PersistenceKeys.CREATED_BY);
643
+ const updatedByKey = core_1.Repository.key(core_1.PersistenceKeys.UPDATED_BY);
644
+ decorator_validation_1.Decoration.flavouredAs(constants_1.FabricFlavour)
645
+ .for(createdByKey)
646
+ .define((0, db_decorators_1.onCreate)(createdByOnFabricCreateUpdate), (0, decorator_validation_1.propMetadata)(createdByKey, {}))
647
+ .apply();
648
+ decorator_validation_1.Decoration.flavouredAs(constants_1.FabricFlavour)
649
+ .for(updatedByKey)
650
+ .define((0, db_decorators_1.onCreateUpdate)(createdByOnFabricCreateUpdate), (0, decorator_validation_1.propMetadata)(updatedByKey, {}))
651
+ .apply();
652
+ const pkKey = core_1.Repository.key(db_decorators_1.DBKeys.ID);
653
+ decorator_validation_1.Decoration.flavouredAs(constants_1.FabricFlavour)
654
+ .for(pkKey)
655
+ .define((0, core_1.index)([core_1.OrderDirection.ASC, core_1.OrderDirection.DSC]), (0, decorator_validation_1.required)(), (0, db_decorators_1.readonly)(),
656
+ // type([String.name, Number.name, BigInt.name]),
657
+ (0, decorator_validation_1.propMetadata)(pkKey, core_1.NumericSequence), (0, db_decorators_1.onCreate)(pkFabricOnCreate, core_1.NumericSequence))
658
+ .apply();
659
+ const columnKey = core_1.Adapter.key(core_1.PersistenceKeys.COLUMN);
660
+ decorator_validation_1.Decoration.flavouredAs(constants_1.FabricFlavour)
661
+ .for(columnKey)
662
+ .extend((0, fabric_contract_api_1.Property)())
663
+ .apply();
664
+ const tableKey = core_1.Adapter.key(core_1.PersistenceKeys.TABLE);
665
+ decorator_validation_1.Decoration.flavouredAs(constants_1.FabricFlavour)
666
+ .for(tableKey)
667
+ .extend(function table(obj) {
668
+ // const chain: any[] = [];
669
+ // let current = obj;
670
+ // do {
671
+ // chain.push(current);
672
+ // console.log(`Found class: ${current}`);
673
+ // } while (current && current !== Object.prototype);
674
+ // do {
675
+ // current = chain.pop();
676
+ // console.log(`Applying @Object() to class: ${current}`);
677
+ // //TODO: THIS IS NOT WORKING AND THROWS ERROR
678
+ // // FabricObject()(current);
679
+ // } while (chain.length > 1);
680
+ return (0, fabric_contract_api_1.Object)()(obj);
681
+ })
682
+ .apply();
683
+ const oneToOnekey = core_1.Repository.key(core_1.PersistenceKeys.ONE_TO_ONE);
684
+ function oneToOneDec(clazz, cascade, populate, joinColumnOpts, fk) {
685
+ const meta = {
686
+ class: clazz.name ? clazz.name : clazz,
687
+ cascade: cascade,
688
+ populate: populate,
689
+ };
690
+ if (joinColumnOpts)
691
+ meta.joinTable = joinColumnOpts;
692
+ if (fk)
693
+ meta.name = fk;
694
+ return (0, reflection_1.apply)((0, decorator_validation_1.prop)(core_1.PersistenceKeys.RELATIONS), (0, decorator_validation_1.type)([
695
+ clazz.name ? clazz.name : clazz,
696
+ String.name,
697
+ Number.name,
698
+ BigInt.name,
699
+ ]), (0, db_decorators_1.onCreate)(FabricConstruction_1.oneToOneOnCreate, meta), (0, db_decorators_1.onUpdate)(FabricConstruction_1.oneToOneOnUpdate, meta), (0, db_decorators_1.onDelete)(FabricConstruction_1.oneToOneOnDelete, meta), (0, db_decorators_1.afterAny)(FabricConstruction_1.populate, meta), (0, decorator_validation_1.propMetadata)(oneToOnekey, meta));
700
+ }
701
+ decorator_validation_1.Decoration.flavouredAs(constants_1.FabricFlavour)
702
+ .for(oneToOnekey)
703
+ .define({
704
+ decorator: oneToOneDec,
705
+ })
706
+ .apply();
707
+ const oneToManyKey = core_1.Repository.key(core_1.PersistenceKeys.ONE_TO_MANY);
708
+ function oneToManyDec(clazz, cascade, populate, joinTableOpts, fk) {
709
+ const metadata = {
710
+ class: clazz.name ? clazz.name : clazz,
711
+ cascade: cascade,
712
+ populate: populate,
713
+ };
714
+ if (joinTableOpts)
715
+ metadata.joinTable = joinTableOpts;
716
+ if (fk)
717
+ metadata.name = fk;
718
+ return (0, reflection_1.apply)((0, decorator_validation_1.prop)(core_1.PersistenceKeys.RELATIONS), (0, decorator_validation_1.list)([clazz, String, Number, BigInt]), (0, db_decorators_1.onCreate)(FabricConstruction_1.oneToManyOnCreate, metadata), (0, db_decorators_1.onUpdate)(core_1.oneToManyOnUpdate, metadata), (0, db_decorators_1.onDelete)(FabricConstruction_1.oneToManyOnDelete, metadata), (0, db_decorators_1.afterAny)(FabricConstruction_1.populate, metadata), (0, decorator_validation_1.propMetadata)(oneToManyKey, metadata));
719
+ }
720
+ decorator_validation_1.Decoration.for(oneToManyKey)
721
+ .define({
722
+ decorator: oneToManyDec,
723
+ })
724
+ .apply();
725
+ }
726
+ }
727
+ exports.FabricContractAdapter = FabricContractAdapter;
728
+ FabricContractAdapter.decoration();
729
+ core_1.Adapter.setCurrent(constants_1.FabricFlavour);
730
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ContractAdapter.js","sourceRoot":"","sources":["../../src/contracts/ContractAdapter.ts"],"names":[],"mappings":";;;AAqGA,sEAoBC;AA8BD,4CAwCC;AA/LD,uDAAgF;AAChF,yEASwC;AAExC,2DAA0D;AAC1D,2DAciC;AACjC,6DAI6B;AAC7B,+CAAoD;AAEpD,yCAiBwB;AACxB,6EAAsE;AAOtE,2EAA4D;AAC5D,yEAAkE;AAClE,mDAAuD;AACvD,yDAAoD;AACpD,iGAAwF;AACxF,iEAO8B;AAC9B,qDAA6C;AAE7C;;;;;;;;;;;;;;;;;;;;;;;;;GAyBG;AACI,KAAK,UAAU,6BAA6B,CAMjD,OAAqC,EACrC,IAAO,EACP,GAAY,EACZ,KAAQ;IAER,IAAI,CAAC;QACH,MAAM,IAAI,GAAG,OAAO,CAAC,GAAG,CAAC,gBAAgB,CAAmB,CAAC;QAC7D,KAAK,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC,KAAK,EAAmB,CAAC;QAC3C,6DAA6D;IAC/D,CAAC;IAAC,OAAO,CAAU,EAAE,CAAC;QACpB,MAAM,IAAI,uBAAgB,CACxB,gEAAgE,CACjE,CAAC;IACJ,CAAC;AACH,CAAC;AAED;;;;;;;;;;;;;;;;;;;;;;;;;;;GA2BG;AACI,KAAK,UAAU,gBAAgB,CAOpC,OAAmB,EACnB,IAAO,EACP,GAAY,EACZ,KAAQ;IAER,IAAI,CAAC,IAAI,CAAC,IAAI,IAAI,KAAK,CAAC,GAAG,CAAC,EAAE,CAAC;QAC7B,OAAO;IACT,CAAC;IAED,MAAM,kBAAkB,GAAG,UACzB,MAAS,EACT,WAAmB,EACnB,KAA+B;QAE/B,MAAM,CAAC,cAAc,CAAC,MAAM,EAAE,WAAW,EAAE;YACzC,UAAU,EAAE,IAAI;YAChB,QAAQ,EAAE,KAAK;YACf,YAAY,EAAE,IAAI;YAClB,KAAK,EAAE,KAAK;SACb,CAAC,CAAC;IACL,CAAC,CAAC;IACF,IAAI,CAAC,IAAI,CAAC,IAAI;QAAE,IAAI,CAAC,IAAI,GAAG,IAAA,2BAAoB,EAAC,KAAK,EAAE,IAAI,CAAC,CAAC;IAC9D,IAAI,QAAgC,CAAC;IACrC,IAAI,CAAC;QACH,QAAQ,GAAG,CAAC,MAAM,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAC,CAA2B,CAAC;IAC3E,CAAC;IAAC,OAAO,CAAM,EAAE,CAAC;QAChB,MAAM,IAAI,6BAAa,CACrB,kCAAkC,IAAI,CAAC,IAAI,KAAK,CAAC,EAAE,CACpD,CAAC;IACJ,CAAC;IAED,MAAM,IAAI,GAAG,MAAM,QAAQ,CAAC,IAAI,CAAC,OAAgC,CAAC,CAAC;IACnE,kBAAkB,CAAC,KAAK,EAAE,GAAa,EAAE,IAAI,CAAC,CAAC;AACjD,CAAC;AAED;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAoCG;AACH,MAAa,qBAAsB,SAAQ,4BAK1C;IACoB,SAAS;QAC1B,MAAM,IAAI,uBAAgB,CAAC,6CAA6C,CAAC,CAAC;IAC5E,CAAC;IACD;;OAEG;aACY,gBAAW,GAAG,IAAI,WAAW,CAAC,MAAM,CAAC,AAA1B,CAA2B;aAE3B,eAAU,GAAG,IAAI,6DAA6B,EAAE,AAAtC,CAAuC;IAE3E;;;;;OAKG;IACI,MAAM,CAAC,GAAQ;QACpB,OAAO,iBAAO,CAAC,GAAG,CAAC,qBAAqB,EAAE,EAAE,EAAE,GAAG,CAAmB,CAAC;IACvE,CAAC;IAQD;;;;;OAKG;IACM,UAAU;QASjB,OAAO,mDAAwB,CAAC;IAClC,CAAC;IAED;;;;;OAKG;IACH,YAAY,KAAW,EAAE,KAAc;QACrC,KAAK,CAAC,KAAK,EAAE,yBAAa,EAAE,KAAK,CAAC,CAAC;QA/BrC;;;WAGG;QACM,YAAO,GAAG,uCAAqB,CAAC;IA4BzC,CAAC;IAEQ,GAAG,CAAC,MAAoB,EAAE,GAAG,IAAS;QAC7C,OAAO,KAAK,CAAC,GAAG,CAAC,MAAM,EAAE,GAAG,IAAI,CAAC,CAAC;IACpC,CAAC;IAED;;;;;;;;;OASG;IACM,KAAK,CAAC,MAAM,CACnB,SAAiB,EACjB,EAAmB,EACnB,KAA0B,EAC1B,GAAG,IAAW;QAEd,MAAM,EAAE,IAAI,EAAE,MAAM,EAAE,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;QACpC,MAAM,GAAG,GAAG,MAAM,CAAC,GAAG,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QAEpC,IAAI,CAAC;YACH,GAAG,CAAC,IAAI,CAAC,mBAAmB,SAAS,kBAAkB,EAAE,EAAE,CAAC,CAAC;YAC7D,KAAK,GAAG,MAAM,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,EAAE,CAAC,QAAQ,EAAE,EAAE,KAAK,CAAC,CAAC;QAC1D,CAAC;QAAC,OAAO,CAAU,EAAE,CAAC;YACpB,MAAM,IAAI,CAAC,UAAU,CAAC,CAAU,CAAC,CAAC;QACpC,CAAC;QAED,OAAO,KAAK,CAAC;IACf,CAAC;IAED;;;;;;;OAOG;IACM,KAAK,CAAC,IAAI,CACjB,SAAiB,EACjB,EAAmB,EACnB,GAAG,IAAW;QAEd,MAAM,EAAE,IAAI,EAAE,MAAM,EAAE,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;QACpC,MAAM,GAAG,GAAG,MAAM,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAElC,IAAI,KAA0B,CAAC;QAC/B,IAAI,CAAC;YACH,MAAM,OAAO,GAAG,MAAM,IAAI,CAAC,SAAS,CAAC,IAAI,EAAE,SAAS,EAAE,EAAE,CAAC,QAAQ,EAAE,CAAC,CAAC;YAErE,IAAI,OAAO,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;gBACvB,GAAG,CAAC,KAAK,CAAC,0BAA0B,EAAE,OAAO,SAAS,QAAQ,CAAC,CAAC;gBAChE,MAAM,IAAI,6BAAa,CACrB,0BAA0B,EAAE,OAAO,SAAS,QAAQ,CACrD,CAAC;YACJ,CAAC;iBAAM,IAAI,OAAO,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;gBAC9B,GAAG,CAAC,KAAK,CAAC,0BAA0B,EAAE,OAAO,SAAS,QAAQ,CAAC,CAAC;gBAChE,KAAK,GAAG,OAAO,CAAC,GAAG,EAAyB,CAAC;YAC/C,CAAC;iBAAM,CAAC;gBACN,KAAK,GAAG,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC;YACpC,CAAC;QACH,CAAC;QAAC,OAAO,CAAU,EAAE,CAAC;YACpB,MAAM,IAAI,CAAC,UAAU,CAAC,CAAU,CAAC,CAAC;QACpC,CAAC;QAED,OAAO,KAAK,CAAC;IACf,CAAC;IAED;;;;;;;;;OASG;IACM,KAAK,CAAC,MAAM,CACnB,SAAiB,EACjB,EAAmB,EACnB,KAA0B,EAC1B,GAAG,IAAW;QAEd,MAAM,EAAE,IAAI,EAAE,MAAM,EAAE,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;QACpC,MAAM,GAAG,GAAG,MAAM,CAAC,GAAG,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QAEpC,IAAI,CAAC;YACH,GAAG,CAAC,IAAI,CAAC,qBAAqB,SAAS,kBAAkB,EAAE,EAAE,CAAC,CAAC;YAC/D,KAAK,GAAG,MAAM,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,EAAE,CAAC,QAAQ,EAAE,EAAE,KAAK,CAAC,CAAC;QAC1D,CAAC;QAAC,OAAO,CAAU,EAAE,CAAC;YACpB,MAAM,IAAI,CAAC,UAAU,CAAC,CAAU,CAAC,CAAC;QACpC,CAAC;QAED,OAAO,KAAK,CAAC;IACf,CAAC;IAED;;;;;;;OAOG;IACH,KAAK,CAAC,MAAM,CACV,SAAiB,EACjB,EAAmB,EACnB,GAAG,IAAW;QAEd,MAAM,GAAG,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;QACvB,MAAM,EAAE,IAAI,EAAE,MAAM,EAAE,GAAG,GAAG,CAAC;QAC7B,MAAM,GAAG,GAAG,MAAM,CAAC,GAAG,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QAEpC,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;QAEf,IAAI,KAA0B,CAAC;QAC/B,IAAI,CAAC;YACH,KAAK,GAAG,MAAM,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE,EAAE,EAAE,GAAG,IAAI,CAAC,CAAC;YAChD,GAAG,CAAC,OAAO,CAAC,0BAA0B,EAAE,SAAS,SAAS,QAAQ,CAAC,CAAC;YACpE,IAAI,CAAC,WAAW,CAAC,IAAI,EAAE,SAAS,EAAE,EAAE,CAAC,QAAQ,EAAE,CAAC,CAAC;QACnD,CAAC;QAAC,OAAO,CAAU,EAAE,CAAC;YACpB,MAAM,IAAI,CAAC,UAAU,CAAC,CAAU,CAAC,CAAC;QACpC,CAAC;QAED,OAAO,KAAK,CAAC;IACf,CAAC;IAES,KAAK,CAAC,WAAW,CACzB,IAAmB,EACnB,SAAiB,EACjB,EAAU;IACV,6DAA6D;IAC7D,GAAG,IAAW;QAEd,MAAM,WAAW,GAAG,IAAI,CAAC,kBAAkB,CAAC,SAAS,EAAE,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACrE,MAAM,IAAI,CAAC,WAAW,CAAC,WAAW,CAAC,CAAC;IACtC,CAAC;IAES,KAAK,CAAC,QAAQ,CACtB,IAAmB,EACnB,EAAU,EACV,KAA0B;IAC1B,6DAA6D;IAC7D,GAAG,IAAW;QAEd,IAAI,IAAY,CAAC;QAEjB,IAAI,CAAC;YACH,IAAI,GAAG,MAAM,CAAC,IAAI,CAChB,qBAAqB,CAAC,UAAU,CAAC,SAAS,CAAC,KAAc,CAAC,CAC3D,CAAC;QACJ,CAAC;QAAC,OAAO,CAAU,EAAE,CAAC;YACpB,MAAM,IAAI,kCAAkB,CAC1B,sCAAsC,EAAE,KAAK,CAAC,EAAE,CACjD,CAAC;QACJ,CAAC;QACD,MAAM,IAAI,CAAC,QAAQ,CAAC,EAAE,CAAC,QAAQ,EAAE,EAAE,IAAI,CAAC,CAAC;QAEzC,OAAO,KAAK,CAAC;IACf,CAAC;IAES,KAAK,CAAC,SAAS,CACvB,IAAmB,EACnB,SAAiB,EACjB,EAAU;IACV,6DAA6D;IAC7D,GAAG,IAAW;QAEd,MAAM,WAAW,GAAG,IAAI,CAAC,kBAAkB,CAAC,SAAS,EAAE,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACrE,MAAM,OAAO,GAAU,EAAE,CAAC;QAE1B,IAAI,GAAG,GAAiC,MAAM,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,CAAC;QAEzE,IAAI,GAAG,CAAC,QAAQ,EAAE,KAAK,EAAE;YACvB,MAAM,IAAI,6BAAa,CAAC,kBAAkB,EAAE,YAAY,CAAC,CAAC;QAE5D,IAAI,CAAC;YACH,GAAG,GAAG,qBAAqB,CAAC,UAAU,CAAC,WAAW,CAChD,GAAG,CAAC,QAAQ,EAAE;YACd,yBAAyB;aAC1B,CAAC;QACJ,CAAC;QAAC,OAAO,CAAU,EAAE,CAAC;YACpB,MAAM,IAAI,kCAAkB,CAAC,2BAA2B,CAAC,EAAE,CAAC,CAAC;QAC/D,CAAC;QAED,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;QAElB,OAAO,OAAO,CAAC;IACjB,CAAC;IAES,KAAK,CAAC,WAAW,CACzB,IAAmB,EACnB,QAAa;IACb,6DAA6D;IAC7D,GAAG,IAAW;QAEd,OAAO,CAAC,MAAM,IAAI,CAAC,cAAc,CAC/B,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,CACzB,CAAiC,CAAC;IACrC,CAAC;IAES,KAAK,CAAC,oBAAoB,CAClC,IAAmB,EACnB,QAAa,EACb,QAAgB,GAAG,EACnB,IAAa;IACb,6DAA6D;IAC7D,GAAG,IAAW;QAEd,OAAO,CAAC,MAAM,IAAI,CAAC,4BAA4B,CAC7C,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,EACxB,KAAK,EACL,IAAI,EAAE,QAAQ,EAAE,CACjB,CAAqD,CAAC;IACzD,CAAC;IAES,WAAW,CAAC,OAA8B;QAClD,MAAM,OAAO,GAAG,CAAC,KAA0B,EAAE,EAAE,CAC7C,MAAM,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,MAAM,CAAC,CAAC,KAA0B,EAAE,CAAC,GAAG,EAAE,GAAG,CAAC,EAAE,EAAE;YACtE,IAAI,OAAO,GAAG,KAAK,WAAW;gBAAE,KAAK,CAAC,GAAG,CAAC,GAAG,GAAG,CAAC;YACjD,OAAO,KAAK,CAAC;QACf,CAAC,EAAE,EAAE,CAAC,CAAC;QAET,IAAI,UAAU,GAAwB,OAAO,CAAC,GAAG,EAAyB,CAAC;QAE3E,KAAK,MAAM,GAAG,IAAI,OAAO,EAAE,CAAC;YAC1B,UAAU,GAAG,MAAM,CAAC,MAAM,CAAC,EAAE,EAAE,OAAO,CAAC,UAAU,CAAC,EAAE,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC;QACpE,CAAC;QAED,OAAO,UAAU,CAAC;IACpB,CAAC;IAED;;;;;OAKG;IACO,MAAM,CAAC,MAAkB;QACjC,OAAO,qBAAqB,CAAC,WAAW,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;IAC1D,CAAC;IAED;;;;;;;;;OASG;IACgB,KAAK,CAAC,KAAK,CAC5B,SAAwB,EACxB,KAAqB,EACrB,KAAmC,EACnC,GAAQ,EACR,GAAG,IAAW;QAEd,OAAO,MAAM,CAAC,MAAM,CAAC,MAAM,KAAK,CAAC,KAAK,CAAC,SAAS,EAAE,KAAK,EAAE,KAAK,EAAE,GAAG,IAAI,CAAC,EAAE;YACxE,IAAI,EAAE,GAAG,CAAC,IAAI;YACd,QAAQ,EAAE,GAAG,CAAC,cAAc;YAC5B,MAAM,EAAE,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC;SACzB,CAAC,CAAC;IACL,CAAC;IAED;;;;;;OAMG;IACH,6DAA6D;IACnD,KAAK,CAAI,MAAsB;QACvC,OAAO,OAAO,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC;IACpC,CAAC;IAED;;;;;;;;;;;;;;;;;;;;;;;;OAwBG;IACO,KAAK,CAAC,cAAc,CAC5B,GAAW,EACX,QAAsC,EACtC,SAAS,GAAG,KAAK;QAEjB,MAAM,UAAU,GAAG,EAAE,CAAC;QACtB,IAAI,GAAG,GAAkC,MAAM,QAAQ,CAAC,IAAI,EAAE,CAAC;QAC/D,OAAO,CAAC,GAAG,CAAC,IAAI,EAAE,CAAC;YACjB,IAAI,GAAG,CAAC,KAAK,IAAI,GAAG,CAAC,KAAK,CAAC,KAAK,CAAC,QAAQ,EAAE,EAAE,CAAC;gBAC5C,IAAI,OAAO,GAAQ,EAAE,CAAC;gBACtB,GAAG,CAAC,KAAK,CAAC,GAAG,CAAC,KAAK,CAAC,KAAK,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC,CAAC;gBAC5C,IAAI,SAAS,CAAC,0BAA0B,EAAE,CAAC;oBACzC,OAAO,CAAC,IAAI,GAAG,GAAG,CAAC,KAAK,CAAC,IAAI,CAAC;oBAC9B,OAAO,CAAC,SAAS,GAAG,GAAG,CAAC,KAAK,CAAC,SAAS,CAAC;oBACxC,IAAI,CAAC;wBACH,OAAO,CAAC,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,KAAK,CAAC,KAAK,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC,CAAC;oBAC/D,CAAC;oBAAC,OAAO,GAAQ,EAAE,CAAC;wBAClB,GAAG,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;wBACf,OAAO,CAAC,KAAK,GAAG,GAAG,CAAC,KAAK,CAAC,KAAK,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC;oBACnD,CAAC;gBACH,CAAC;qBAAM,CAAC;oBACN,IAAI,CAAC;wBACH,OAAO,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,KAAK,CAAC,KAAK,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC,CAAC;oBACzD,CAAC;oBAAC,OAAO,GAAQ,EAAE,CAAC;wBAClB,GAAG,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;wBACf,OAAO,GAAG,GAAG,CAAC,KAAK,CAAC,KAAK,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC;oBAC7C,CAAC;gBACH,CAAC;gBACD,UAAU,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;YAC3B,CAAC;YACD,GAAG,GAAG,MAAM,QAAQ,CAAC,IAAI,EAAE,CAAC;QAC9B,CAAC;QACD,GAAG,CAAC,KAAK,CAAC,0BAA0B,UAAU,CAAC,MAAM,UAAU,CAAC,CAAC;QACjE,QAAQ,CAAC,KAAK,EAAE,CAAC,CAAC,qDAAqD;QACvE,OAAO,UAAU,CAAC;IACpB,CAAC;IAED;;;;;;;;;;;;;;;;;;;;;;;;;;;OA2BG;IACH,KAAK,CAAC,GAAG,CACP,QAAoB,EACpB,QAAiB,EACjB,GAAG,IAAW;QAEd,MAAM,EAAE,IAAI,EAAE,MAAM,EAAE,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;QACpC,MAAM,GAAG,GAAG,MAAM,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;QACjC,MAAM,EAAE,IAAI,EAAE,KAAK,EAAE,GAAG,QAAQ,CAAC;QACjC,IAAI,QAAsC,CAAC;QAC3C,IAAI,KAAK,IAAI,IAAI,EAAE,CAAC;YAClB,OAAO,QAAQ,CAAC,OAAO,CAAC,CAAC;YACzB,OAAO,QAAQ,CAAC,MAAM,CAAC,CAAC;YACxB,GAAG,CAAC,KAAK,CACP,yCAAyC,KAAK,WAAW,IAAI,EAAE,CAChE,CAAC;YACF,MAAM,QAAQ,GACZ,CAAC,MAAM,IAAI,CAAC,oBAAoB,CAC9B,IAAI,EACJ,QAAQ,EACR,KAAK,IAAI,GAAG,EACX,IAAY,EAAE,QAAQ,EAAE,CAC1B,CAAqD,CAAC;YACzD,QAAQ,GAAG,QAAQ,CAAC,QAAQ,CAAC;QAC/B,CAAC;aAAM,CAAC;YACN,GAAG,CAAC,KAAK,CAAC,qBAAqB,CAAC,CAAC;YACjC,QAAQ,GAAG,CAAC,MAAM,IAAI,CAAC,WAAW,CAChC,IAAI,EACJ,QAAQ,CACT,CAAiC,CAAC;QACrC,CAAC;QACD,GAAG,CAAC,KAAK,CAAC,mBAAmB,CAAC,CAAC;QAE/B,MAAM,OAAO,GAAG,CAAC,MAAM,IAAI,CAAC,cAAc,CAAC,GAAG,EAAE,QAAQ,CAAC,CAAM,CAAC;QAChE,GAAG,CAAC,KAAK,CACP,uBAAuB,EACvB,GAAG,KAAK,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,EAAE,CACjD,CAAC;QACF,OAAO,OAAO,CAAC;IACjB,CAAC;IAEQ,SAAS,CAChB,GAA2B;QAE3B,IAAI,CAAC,GAAG,EAAE,CAAC;YACT,MAAM,IAAI,4BAAmB,CAAC,qBAAqB,CAAC,CAAC;QACvD,CAAC;QACD,OAAO,IAAI,yCAAe,CAAC,IAAI,EAAE,GAAG,CAAC,CAAC;IACxC,CAAC;IAEQ,KAAK,CAAC,QAAQ,CAAC,OAAwB;QAC9C,OAAO,IAAI,+CAAsB,CAAC,OAAO,EAAE,IAAI,CAAC,CAAC;IACnD,CAAC;IAEQ,KAAK,CAAC,SAAS,CACtB,SAAiB,EACjB,EAAuB,EACvB,KAA4B,EAC5B,GAAG,IAAW;QAEd,IAAI,EAAE,CAAC,MAAM,KAAK,KAAK,CAAC,MAAM;YAC5B,MAAM,IAAI,6BAAa,CAAC,0CAA0C,CAAC,CAAC;QAEtE,MAAM,EAAE,MAAM,EAAE,GAAG,IAAI,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC,CAA0B,CAAC;QAClE,MAAM,GAAG,GAAG,MAAM,CAAC,GAAG,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;QACvC,GAAG,CAAC,IAAI,CAAC,YAAY,EAAE,CAAC,MAAM,YAAY,SAAS,QAAQ,CAAC,CAAC;QAC7D,GAAG,CAAC,KAAK,CAAC,QAAQ,EAAE,EAAE,CAAC,CAAC;QAExB,OAAO,OAAO,CAAC,GAAG,CAChB,EAAE,CAAC,GAAG,CAAC,KAAK,EAAE,CAAC,EAAE,KAAK,EAAE,EAAE;YACxB,OAAO,IAAI,CAAC,MAAM,CAAC,SAAS,EAAE,CAAC,EAAE,KAAK,CAAC,KAAK,CAAC,EAAE,GAAG,IAAI,CAAC,CAAC;QAC1D,CAAC,CAAC,CACH,CAAC;IACJ,CAAC;IAEQ,KAAK,CAAC,SAAS,CACtB,SAAiB,EACjB,EAAuB,EACvB,KAA4B,EAC5B,GAAG,IAAW;QAEd,IAAI,EAAE,CAAC,MAAM,KAAK,KAAK,CAAC,MAAM;YAC5B,MAAM,IAAI,6BAAa,CAAC,0CAA0C,CAAC,CAAC;QAEtE,MAAM,EAAE,MAAM,EAAE,GAAG,IAAI,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC,CAA0B,CAAC;QAElE,MAAM,GAAG,GAAG,MAAM,CAAC,GAAG,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;QACvC,GAAG,CAAC,IAAI,CAAC,YAAY,EAAE,CAAC,MAAM,YAAY,SAAS,QAAQ,CAAC,CAAC;QAC7D,GAAG,CAAC,KAAK,CAAC,QAAQ,EAAE,EAAE,CAAC,CAAC;QAExB,OAAO,OAAO,CAAC,GAAG,CAChB,EAAE,CAAC,GAAG,CAAC,KAAK,EAAE,CAAC,EAAE,KAAK,EAAE,EAAE;YACxB,OAAO,IAAI,CAAC,MAAM,CAAC,SAAS,EAAE,CAAC,EAAE,KAAK,CAAC,KAAK,CAAC,EAAE,GAAG,IAAI,CAAC,CAAC;QAC1D,CAAC,CAAC,CACH,CAAC;IACJ,CAAC;IAED;;;;;OAKG;IACM,OAAO,CACd,KAAQ,EACR,EAAW,EACX,GAAG,IAAW;QAMd,MAAM,EAAE,IAAI,EAAE,MAAM,EAAE,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;QACpC,MAAM,SAAS,GAAG,IAAI,CAAC,KAAK,EAAE,CAAC;QAC/B,MAAM,GAAG,GAAG,MAAM,CAAC,GAAG,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QAErC,MAAM,KAAK,GAAG,IAAA,gCAAgB,EAAC,KAAK,CAAC,CAAC;QACtC,MAAM,MAAM,GAAG,MAAM,CAAC,OAAO,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,MAAM,CAC/C,CAAC,KAA0B,EAAE,CAAC,GAAG,EAAE,GAAG,CAAC,EAAE,EAAE;YACzC,IAAI,OAAO,GAAG,KAAK,WAAW;gBAAE,OAAO,KAAK,CAAC;YAC7C,MAAM,UAAU,GAAG,iBAAU,CAAC,MAAM,CAAC,KAAK,EAAE,GAAG,CAAC,CAAC;YACjD,IAAI,IAAI,CAAC,UAAU,CAAC,UAAU,CAAC;gBAC7B,MAAM,IAAI,6BAAa,CAAC,iBAAiB,UAAU,cAAc,CAAC,CAAC;YACrE,KAAK,CAAC,UAAU,CAAC,GAAG,GAAG,CAAC;YACxB,OAAO,KAAK,CAAC;QACf,CAAC,EACD,EAAE,CACH,CAAC;QACF,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,MAAM,EAAE,sBAAe,CAAC,QAAQ,EAAE;gBACtD,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,GAAG,CAAC,IAAI,CAAC,wBAAwB,SAAS,kBAAkB,KAAK,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC;QAEzE,OAAO;YACL,MAAM,EAAE,MAAM;YACd,EAAE,EAAE,IAAI,CAAC,kBAAkB,CAAC,SAAS,EAAE,CAAC,MAAM,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;YAC3D,SAAS,EAAE,KAAK,CAAC,SAAS;SAC3B,CAAC;IACJ,CAAC;IAEQ,MAAM,CACb,GAAwB,EACxB,KAA8B,EAC9B,EAAW,EACX,EAAmB,EACnB,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,iBAAU,CAAC,MAAM,CAAC,KAAK,EAAE,GAAG,CAAC,CAAC,CAAC;YACzE,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;IAEQ,YAAY,CACnB,SAAiB,EACjB,EAAmB,EACnB,KAA0B,EAC1B,GAAG,IAAW;QAEd,MAAM,GAAG,GAA0B,IAAI,CAAC,GAAG,EAAE,CAAC;QAC9C,MAAM,MAAM,GAAwB,EAAE,CAAC;QACvC,MAAM,CAAC,yBAAW,CAAC,KAAK,CAAC,GAAG,SAAS,CAAC;QACtC,2DAA2D;QAC3D,MAAM,CAAC,MAAM,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC;QAC7B,OAAO,CAAC,SAAS,EAAE,EAAE,EAAE,MAAM,EAAE,GAAG,CAAC,CAAC;IACtC,CAAC;IAEQ,YAAY,CACnB,SAAiB,EACjB,EAAmB,EACnB,KAA0B,EAC1B,GAAG,IAAW;QAEd,MAAM,GAAG,GAA0B,IAAI,CAAC,GAAG,EAAE,CAAC;QAC9C,MAAM,MAAM,GAAwB,EAAE,CAAC;QACvC,MAAM,CAAC,yBAAW,CAAC,KAAK,CAAC,GAAG,SAAS,CAAC;QACtC,2DAA2D;QAC3D,MAAM,CAAC,MAAM,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC;QAC7B,OAAO,CAAC,SAAS,EAAE,EAAE,EAAE,MAAM,EAAE,GAAG,CAAC,CAAC;IACtC,CAAC;IAEkB,eAAe,CAChC,SAAiB,EACjB,GAAwB,EACxB,MAA6B,EAC7B,GAAG,IAAW;QAEd,IAAI,GAAG,CAAC,MAAM,KAAK,MAAM,CAAC,MAAM;YAC9B,MAAM,IAAI,6BAAa,CAAC,0CAA0C,CAAC,CAAC;QAEtE,MAAM,GAAG,GAA0B,IAAI,CAAC,GAAG,EAAE,CAAC;QAE9C,MAAM,OAAO,GAAG,GAAG,CAAC,GAAG,CAAC,CAAC,EAAE,EAAE,KAAK,EAAE,EAAE;YACpC,MAAM,MAAM,GAAwB,EAAE,CAAC;YACvC,MAAM,CAAC,yBAAW,CAAC,KAAK,CAAC,GAAG,SAAS,CAAC;YACtC,2DAA2D;YAC3D,MAAM,CAAC,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC;YACrC,OAAO,MAAM,CAAC;QAChB,CAAC,CAAC,CAAC;QACH,OAAO,CAAC,SAAS,EAAE,GAAG,EAAE,OAAO,EAAE,GAAU,CAAC,CAAC;IAC/C,CAAC;IAEkB,eAAe,CAChC,SAAiB,EACjB,GAAwB,EACxB,MAA6B,EAC7B,GAAG,IAAW;QAEd,IAAI,GAAG,CAAC,MAAM,KAAK,MAAM,CAAC,MAAM;YAC9B,MAAM,IAAI,6BAAa,CAAC,0CAA0C,CAAC,CAAC;QAEtE,MAAM,GAAG,GAA0B,IAAI,CAAC,GAAG,EAAE,CAAC;QAE9C,MAAM,OAAO,GAAG,GAAG,CAAC,GAAG,CAAC,CAAC,EAAE,EAAE,KAAK,EAAE,EAAE;YACpC,MAAM,MAAM,GAAwB,EAAE,CAAC;YACvC,MAAM,CAAC,yBAAW,CAAC,KAAK,CAAC,GAAG,SAAS,CAAC;YACtC,MAAM,CAAC,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC;YACrC,OAAO,MAAM,CAAC;QAChB,CAAC,CAAC,CAAC;QACH,OAAO,CAAC,SAAS,EAAE,GAAG,EAAE,OAAO,EAAE,GAAU,CAAC,CAAC;IAC/C,CAAC;IAED;;;;;;OAMG;IACH,MAAM,CAAU,UAAU;QACxB,KAAK,CAAC,UAAU,EAAE,CAAC;QACnB,MAAM,YAAY,GAAG,iBAAU,CAAC,GAAG,CAAC,sBAAe,CAAC,UAAU,CAAC,CAAC;QAChE,MAAM,YAAY,GAAG,iBAAU,CAAC,GAAG,CAAC,sBAAe,CAAC,UAAU,CAAC,CAAC;QAChE,iCAAU,CAAC,WAAW,CAAC,yBAAa,CAAC;aAClC,GAAG,CAAC,YAAY,CAAC;aACjB,MAAM,CACL,IAAA,wBAAQ,EAAC,6BAA6B,CAAC,EACvC,IAAA,mCAAY,EAAC,YAAY,EAAE,EAAE,CAAC,CAC/B;aACA,KAAK,EAAE,CAAC;QAEX,iCAAU,CAAC,WAAW,CAAC,yBAAa,CAAC;aAClC,GAAG,CAAC,YAAY,CAAC;aACjB,MAAM,CACL,IAAA,8BAAc,EAAC,6BAA6B,CAAC,EAC7C,IAAA,mCAAY,EAAC,YAAY,EAAE,EAAE,CAAC,CAC/B;aACA,KAAK,EAAE,CAAC;QAEX,MAAM,KAAK,GAAG,iBAAU,CAAC,GAAG,CAAC,sBAAM,CAAC,EAAE,CAAC,CAAC;QACxC,iCAAU,CAAC,WAAW,CAAC,yBAAa,CAAC;aAClC,GAAG,CAAC,KAAK,CAAC;aACV,MAAM,CACL,IAAA,YAAK,EAAC,CAAC,qBAAc,CAAC,GAAG,EAAE,qBAAc,CAAC,GAAG,CAAC,CAAC,EAC/C,IAAA,+BAAQ,GAAE,EACV,IAAA,wBAAQ,GAAE;QACV,iDAAiD;QACjD,IAAA,mCAAY,EAAC,KAAK,EAAE,sBAAe,CAAC,EACpC,IAAA,wBAAQ,EAAC,gBAAgB,EAAE,sBAAe,CAAC,CAC5C;aACA,KAAK,EAAE,CAAC;QAEX,MAAM,SAAS,GAAG,cAAO,CAAC,GAAG,CAAC,sBAAe,CAAC,MAAM,CAAC,CAAC;QACtD,iCAAU,CAAC,WAAW,CAAC,yBAAa,CAAC;aAClC,GAAG,CAAC,SAAS,CAAC;aACd,MAAM,CAAC,IAAA,8BAAc,GAAE,CAAC;aACxB,KAAK,EAAE,CAAC;QAEX,MAAM,QAAQ,GAAG,cAAO,CAAC,GAAG,CAAC,sBAAe,CAAC,KAAK,CAAC,CAAC;QACpD,iCAAU,CAAC,WAAW,CAAC,yBAAa,CAAC;aAClC,GAAG,CAAC,QAAQ,CAAC;aACb,MAAM,CAAC,SAAS,KAAK,CAAC,GAAQ;YAC7B,2BAA2B;YAE3B,qBAAqB;YAErB,OAAO;YACP,yBAAyB;YACzB,4CAA4C;YAC5C,qDAAqD;YAErD,OAAO;YACP,2BAA2B;YAC3B,4DAA4D;YAC5D,iDAAiD;YACjD,gCAAgC;YAChC,8BAA8B;YAE9B,OAAO,IAAA,4BAAY,GAAE,CAAC,GAAG,CAAC,CAAC;QAC7B,CAAC,CAAC;aACD,KAAK,EAAE,CAAC;QAEX,MAAM,WAAW,GAAG,iBAAU,CAAC,GAAG,CAAC,sBAAe,CAAC,UAAU,CAAC,CAAC;QAE/D,SAAS,WAAW,CAClB,KAA8C,EAC9C,OAAwB,EACxB,QAAiB,EACjB,cAAkC,EAClC,EAAW;YAEX,MAAM,IAAI,GAAsB;gBAC9B,KAAK,EAAE,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAE,KAAa;gBAC/C,OAAO,EAAE,OAAO;gBAChB,QAAQ,EAAE,QAAQ;aACnB,CAAC;YACF,IAAI,cAAc;gBAAE,IAAI,CAAC,SAAS,GAAG,cAAc,CAAC;YACpD,IAAI,EAAE;gBAAE,IAAI,CAAC,IAAI,GAAG,EAAE,CAAC;YACvB,OAAO,IAAA,kBAAK,EACV,IAAA,2BAAI,EAAC,sBAAe,CAAC,SAAS,CAAC,EAC/B,IAAA,2BAAI,EAAC;gBACH,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAE,KAAa;gBACxC,MAAM,CAAC,IAAI;gBACX,MAAM,CAAC,IAAI;gBACX,MAAM,CAAC,IAAI;aACZ,CAAC,EACF,IAAA,wBAAQ,EAAC,qCAAgB,EAAE,IAAI,CAAC,EAChC,IAAA,wBAAQ,EAAC,qCAAgB,EAAE,IAAI,CAAC,EAChC,IAAA,wBAAQ,EAAC,qCAAgB,EAAE,IAAI,CAAC,EAChC,IAAA,wBAAQ,EAAC,6BAAG,EAAE,IAAI,CAAC,EACnB,IAAA,mCAAY,EAAC,WAAW,EAAE,IAAI,CAAC,CAChC,CAAC;QACJ,CAAC;QAED,iCAAU,CAAC,WAAW,CAAC,yBAAa,CAAC;aAClC,GAAG,CAAC,WAAW,CAAC;aAChB,MAAM,CAAC;YACN,SAAS,EAAE,WAAW;SACvB,CAAC;aACD,KAAK,EAAE,CAAC;QAEX,MAAM,YAAY,GAAG,iBAAU,CAAC,GAAG,CAAC,sBAAe,CAAC,WAAW,CAAC,CAAC;QAEjE,SAAS,YAAY,CACnB,KAA8C,EAC9C,OAAwB,EACxB,QAAiB,EACjB,aAAkE,EAClE,EAAW;YAEX,MAAM,QAAQ,GAAsB;gBAClC,KAAK,EAAE,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAE,KAAa;gBAC/C,OAAO,EAAE,OAAO;gBAChB,QAAQ,EAAE,QAAQ;aACnB,CAAC;YACF,IAAI,aAAa;gBAAE,QAAQ,CAAC,SAAS,GAAG,aAAa,CAAC;YACtD,IAAI,EAAE;gBAAE,QAAQ,CAAC,IAAI,GAAG,EAAE,CAAC;YAC3B,OAAO,IAAA,kBAAK,EACV,IAAA,2BAAI,EAAC,sBAAe,CAAC,SAAS,CAAC,EAC/B,IAAA,2BAAI,EAAC,CAAC,KAAuB,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,CAAC,CAAC,EACvD,IAAA,wBAAQ,EAAC,sCAAiB,EAAE,QAAQ,CAAC,EACrC,IAAA,wBAAQ,EAAC,wBAAiB,EAAE,QAAQ,CAAC,EACrC,IAAA,wBAAQ,EAAC,sCAAiB,EAAE,QAAQ,CAAC,EACrC,IAAA,wBAAQ,EAAC,6BAAG,EAAE,QAAQ,CAAC,EACvB,IAAA,mCAAY,EAAC,YAAY,EAAE,QAAQ,CAAC,CACrC,CAAC;QACJ,CAAC;QAED,iCAAU,CAAC,GAAG,CAAC,YAAY,CAAC;aACzB,MAAM,CAAC;YACN,SAAS,EAAE,YAAY;SACxB,CAAC;aACD,KAAK,EAAE,CAAC;IACb,CAAC;;AAt0BH,sDAu0BC;AAED,qBAAqB,CAAC,UAAU,EAAE,CAAC;AACnC,cAAO,CAAC,UAAU,CAAC,yBAAa,CAAC,CAAC","sourcesContent":["import { CouchDBAdapter, CouchDBKeys, MangoQuery } from \"@decaf-ts/for-couchdb\";\nimport {\n  Constructor,\n  Decoration,\n  list,\n  Model,\n  prop,\n  propMetadata,\n  required,\n  type,\n} from \"@decaf-ts/decorator-validation\";\nimport { FabricContractFlags } from \"./types\";\nimport { FabricContractContext } from \"./ContractContext\";\nimport {\n  afterAny,\n  Context,\n  DBKeys,\n  InternalError,\n  modelToTransient,\n  NotFoundError,\n  onCreate,\n  onCreateUpdate,\n  onDelete,\n  onUpdate,\n  OperationKeys,\n  readonly,\n  SerializationError,\n} from \"@decaf-ts/db-decorators\";\nimport {\n  Context as Ctx,\n  Object as FabricObject,\n  Property as FabricProperty,\n} from \"fabric-contract-api\";\nimport { Logger, Logging } from \"@decaf-ts/logging\";\nimport { ContractLogger } from \"./logging\";\nimport {\n  OrderDirection,\n  PersistenceKeys,\n  RelationsMetadata,\n  Repository,\n  Sequence,\n  sequenceNameForModel,\n  SequenceOptions,\n  UnsupportedError,\n  index,\n  NumericSequence,\n  Adapter,\n  CascadeMetadata,\n  JoinColumnOptions,\n  oneToManyOnUpdate,\n  JoinTableOptions,\n  JoinTableMultipleColumnsOptions,\n} from \"@decaf-ts/core\";\nimport { FabricContractRepository } from \"./FabricContractRepository\";\nimport {\n  ChaincodeStub,\n  ClientIdentity,\n  Iterators,\n  StateQueryResponse,\n} from \"fabric-shim-api\";\nimport { FabricStatement } from \"./FabricContractStatement\";\nimport { FabricContractSequence } from \"./FabricContractSequence\";\nimport { MissingContextError } from \"../shared/errors\";\nimport { FabricFlavour } from \"../shared/constants\";\nimport { SimpleDeterministicSerializer } from \"../shared/SimpleDeterministicSerializer\";\nimport {\n  oneToManyOnCreate,\n  oneToManyOnDelete,\n  oneToOneOnCreate,\n  oneToOneOnDelete,\n  oneToOneOnUpdate,\n  populate as pop,\n} from \"./FabricConstruction\";\nimport { apply } from \"@decaf-ts/reflection\";\n\n/**\n * @description Sets the creator or updater field in a model based on the user in the context\n * @summary Callback function used in decorators to automatically set the created_by or updated_by fields\n * with the username from the context when a document is created or updated\n * @template M - Type extending Model\n * @template R - Type extending NanoRepository<M>\n * @template V - Type extending RelationsMetadata\n * @param {R} this - The repository instance\n * @param {FabricContractContext} context - The operation context containing user information\n * @param {V} data - The relation metadata\n * @param {string} key - The property key to set with the username\n * @param {M} model - The model instance being created or updated\n * @return {Promise<void>} A promise that resolves when the operation is complete\n * @function createdByOnFabricCreateUpdate\n * @memberOf module:fabric.contracts\n * @mermaid\n * sequenceDiagram\n *   participant F as createdByOnNanoCreateUpdate\n *   participant C as Context\n *   participant M as Model\n *   F->>C: get(\"user\")\n *   C-->>F: user object\n *   F->>M: set key to user.name\n *   Note over F: If no user in context\n *   F-->>F: throw UnsupportedError\n */\nexport async function createdByOnFabricCreateUpdate<\n  M extends Model,\n  R extends FabricContractRepository<M>,\n  V extends RelationsMetadata,\n>(\n  this: R,\n  context: Context<FabricContractFlags>,\n  data: V,\n  key: keyof M,\n  model: M\n): Promise<void> {\n  try {\n    const user = context.get(\"clientIdentity\") as ClientIdentity;\n    model[key] = user.getID() as M[typeof key];\n    // eslint-disable-next-line @typescript-eslint/no-unused-vars\n  } catch (e: unknown) {\n    throw new UnsupportedError(\n      \"No User found in context. Please provide a user in the context\"\n    );\n  }\n}\n\n/**\n * @description Primary key auto-assignment callback for Fabric models\n * @summary Generates and assigns a primary key value to the specified model property using a Fabric-backed sequence when the model is created. If the sequence name is not provided in options, it is derived from the model via sequenceNameForModel. The assigned key is defined as non-writable and enumerable.\n * @template M - Type extending Model for the target instance\n * @template R - Type extending FabricContractRepository for repository context\n * @template V - Type extending SequenceOptions to configure sequence behavior\n * @template F - Type extending FabricContractFlags for contextual flags\n * @param {R} this - The repository instance invoking the callback\n * @param {FabricContractContext} context - Fabric contract context containing invocation metadata\n * @param {V} data - Sequence options used to configure or locate the sequence\n * @param {string} key - The primary key property name to assign on the model\n * @param {M} model - The model instance to receive the generated primary key\n * @return {Promise<void>} Resolves when the key is assigned or when no action is required\n * @function pkFabricOnCreate\n * @memberOf module:for-fabric.contracts\n * @mermaid\n * sequenceDiagram\n *   participant R as Repository\n *   participant C as Context<F>\n *   participant S as FabricContractDBSequence\n *   participant M as Model\n *   R->>R: derive sequence name if missing\n *   R->>S: adapter.Sequence(options)\n *   S-->>R: sequence instance\n *   R->>S: next(context)\n *   S-->>R: next value\n *   R->>M: define non-writable primary key\n */\nexport async function pkFabricOnCreate<\n  M extends Model,\n  R extends FabricContractRepository<M>,\n  V extends SequenceOptions,\n  F extends FabricContractFlags,\n>(\n  this: R,\n  context: Context<F>,\n  data: V,\n  key: keyof M,\n  model: M\n): Promise<void> {\n  if (!data.type || model[key]) {\n    return;\n  }\n\n  const setPrimaryKeyValue = function <M extends Model>(\n    target: M,\n    propertyKey: string,\n    value: string | number | bigint\n  ) {\n    Object.defineProperty(target, propertyKey, {\n      enumerable: true,\n      writable: false,\n      configurable: true,\n      value: value,\n    });\n  };\n  if (!data.name) data.name = sequenceNameForModel(model, \"pk\");\n  let sequence: FabricContractSequence;\n  try {\n    sequence = (await this.adapter.Sequence(data)) as FabricContractSequence;\n  } catch (e: any) {\n    throw new InternalError(\n      `Failed to instantiate Sequence ${data.name}: ${e}`\n    );\n  }\n\n  const next = await sequence.next(context as FabricContractContext);\n  setPrimaryKeyValue(model, key as string, next);\n}\n\n/**\n * @description Adapter for Hyperledger Fabric chaincode state database operations\n * @summary Provides a CouchDB-like interface for interacting with the Fabric state database from within a chaincode contract\n * @template void - No configuration needed for contract adapter\n * @template FabricContractFlags - Flags specific to Fabric contract operations\n * @template FabricContractContext - Context type for Fabric contract operations\n * @class FabricContractAdapter\n * @example\n * ```typescript\n * // In a Fabric chaincode contract class\n * import { FabricContractAdapter } from '@decaf-ts/for-fabric';\n *\n * export class MyContract extends Contract {\n *   private adapter = new FabricContractAdapter();\n *\n *   @Transaction()\n *   async createAsset(ctx: Context, id: string, data: string): Promise<void> {\n *     const model = { id, data, timestamp: Date.now() };\n *     await this.adapter.create('assets', id, model, {}, { stub: ctx.stub });\n *   }\n * }\n * ```\n * @mermaid\n * sequenceDiagram\n *   participant Contract\n *   participant FabricContractAdapter\n *   participant Stub\n *   participant StateDB\n *\n *   Contract->>FabricContractAdapter: create(tableName, id, model, transient, ctx)\n *   FabricContractAdapter->>FabricContractAdapter: Serialize model to JSON\n *   FabricContractAdapter->>Stub: putState(id, serializedData)\n *   Stub->>StateDB: Write data\n *   StateDB-->>Stub: Success\n *   Stub-->>FabricContractAdapter: Success\n *   FabricContractAdapter-->>Contract: model\n */\nexport class FabricContractAdapter extends CouchDBAdapter<\n  any,\n  void,\n  FabricContractFlags,\n  FabricContractContext\n> {\n  protected override getClient(): void {\n    throw new UnsupportedError(\"Client is not supported in Fabric contracts\");\n  }\n  /**\n   * @description Text decoder for converting binary data to strings\n   */\n  private static textDecoder = new TextDecoder(\"utf8\");\n\n  protected static readonly serializer = new SimpleDeterministicSerializer();\n\n  /**\n   * @description Creates a logger for a specific chaincode context\n   * @summary Returns a ContractLogger instance configured for the current context\n   * @param {Ctx} ctx - The Fabric chaincode context\n   * @return {ContractLogger} The logger instance\n   */\n  public logFor(ctx: Ctx): ContractLogger {\n    return Logging.for(FabricContractAdapter, {}, ctx) as ContractLogger;\n  }\n\n  /**\n   * @description Context constructor for this adapter\n   * @summary Overrides the base Context constructor with FabricContractContext\n   */\n  override Context = FabricContractContext;\n\n  /**\n   * @description Gets the repository constructor for this adapter\n   * @summary Returns the FabricContractRepository constructor for creating repositories\n   * @template M - Type extending Model\n   * @return {Constructor<Repository<M, MangoQuery, FabricContractAdapter, FabricContractFlags, FabricContractContext>>} The repository constructor\n   */\n  override repository<M extends Model>(): Constructor<\n    Repository<\n      M,\n      MangoQuery,\n      Adapter<any, any, MangoQuery, FabricContractFlags, FabricContractContext>,\n      FabricContractFlags,\n      FabricContractContext\n    >\n  > {\n    return FabricContractRepository;\n  }\n\n  /**\n   * @description Creates a new FabricContractAdapter instance\n   * @summary Initializes an adapter for interacting with the Fabric state database\n   * @param {void} scope - Not used in this adapter\n   * @param {string} [alias] - Optional alias for the adapter instance\n   */\n  constructor(scope: void, alias?: string) {\n    super(scope, FabricFlavour, alias);\n  }\n\n  override for(config: Partial<any>, ...args: any): typeof this {\n    return super.for(config, ...args);\n  }\n\n  /**\n   * @description Creates a record in the state database\n   * @summary Serializes a model and stores it in the Fabric state database\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 (not used in this implementation)\n   * @param {...any[]} args - Additional arguments, including the chaincode stub and logger\n   * @return {Promise<Record<string, any>>} Promise resolving to the created record\n   */\n  override async create(\n    tableName: string,\n    id: string | number,\n    model: Record<string, any>,\n    ...args: any[]\n  ): Promise<Record<string, any>> {\n    const { stub, logger } = args.pop();\n    const log = logger.for(this.create);\n\n    try {\n      log.info(`adding entry to ${tableName} table with pk ${id}`);\n      model = await this.putState(stub, id.toString(), model);\n    } catch (e: unknown) {\n      throw this.parseError(e as Error);\n    }\n\n    return model;\n  }\n\n  /**\n   * @description Reads a record from the state database\n   * @summary Retrieves and deserializes a record from the Fabric state database\n   * @param {string} tableName - The name of the table/collection\n   * @param {string | number} id - The record identifier\n   * @param {...any[]} args - Additional arguments, including the chaincode stub and logger\n   * @return {Promise<Record<string, any>>} Promise resolving to the retrieved record\n   */\n  override async read(\n    tableName: string,\n    id: string | number,\n    ...args: any[]\n  ): Promise<Record<string, any>> {\n    const { stub, logger } = args.pop();\n    const log = logger.for(this.read);\n\n    let model: Record<string, any>;\n    try {\n      const results = await this.readState(stub, tableName, id.toString());\n\n      if (results.length < 1) {\n        log.debug(`No record found for id ${id} in ${tableName} table`);\n        throw new NotFoundError(\n          `No record found for id ${id} in ${tableName} table`\n        );\n      } else if (results.length < 2) {\n        log.debug(`No record found for id ${id} in ${tableName} table`);\n        model = results.pop() as Record<string, any>;\n      } else {\n        model = this.mergeModels(results);\n      }\n    } catch (e: unknown) {\n      throw this.parseError(e as Error);\n    }\n\n    return model;\n  }\n\n  /**\n   * @description Updates a record in the state database\n   * @summary Serializes a model and updates it in the Fabric state database\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 (not used in this implementation)\n   * @param {...any[]} args - Additional arguments, including the chaincode stub and logger\n   * @return {Promise<Record<string, any>>} Promise resolving to the updated record\n   */\n  override async update(\n    tableName: string,\n    id: string | number,\n    model: Record<string, any>,\n    ...args: any[]\n  ): Promise<Record<string, any>> {\n    const { stub, logger } = args.pop();\n    const log = logger.for(this.update);\n\n    try {\n      log.info(`updating entry to ${tableName} table with pk ${id}`);\n      model = await this.putState(stub, id.toString(), model);\n    } catch (e: unknown) {\n      throw this.parseError(e as Error);\n    }\n\n    return model;\n  }\n\n  /**\n   * @description Deletes a record from the state database\n   * @summary Retrieves a record and then removes it from the Fabric state database\n   * @param {string} tableName - The name of the table/collection\n   * @param {string | number} id - The record identifier to delete\n   * @param {...any[]} args - Additional arguments, including the chaincode stub and logger\n   * @return {Promise<Record<string, any>>} Promise resolving to the deleted record\n   */\n  async delete(\n    tableName: string,\n    id: string | number,\n    ...args: any[]\n  ): Promise<Record<string, any>> {\n    const ctx = args.pop();\n    const { stub, logger } = ctx;\n    const log = logger.for(this.delete);\n\n    args.push(ctx);\n\n    let model: Record<string, any>;\n    try {\n      model = await this.read(tableName, id, ...args);\n      log.verbose(`deleting entry with pk ${id} from ${tableName} table`);\n      this.deleteState(stub, tableName, id.toString());\n    } catch (e: unknown) {\n      throw this.parseError(e as Error);\n    }\n\n    return model;\n  }\n\n  protected async deleteState(\n    stub: ChaincodeStub,\n    tableName: string,\n    id: string,\n    // eslint-disable-next-line @typescript-eslint/no-unused-vars\n    ...args: any[]\n  ) {\n    const composedKey = stub.createCompositeKey(tableName, [String(id)]);\n    await stub.deleteState(composedKey);\n  }\n\n  protected async putState(\n    stub: ChaincodeStub,\n    id: string,\n    model: Record<string, any>,\n    // eslint-disable-next-line @typescript-eslint/no-unused-vars\n    ...args: any[]\n  ) {\n    let data: Buffer;\n\n    try {\n      data = Buffer.from(\n        FabricContractAdapter.serializer.serialize(model as Model)\n      );\n    } catch (e: unknown) {\n      throw new SerializationError(\n        `Failed to serialize record with id ${id}: ${e}`\n      );\n    }\n    await stub.putState(id.toString(), data);\n\n    return model;\n  }\n\n  protected async readState(\n    stub: ChaincodeStub,\n    tableName: string,\n    id: string,\n    // eslint-disable-next-line @typescript-eslint/no-unused-vars\n    ...args: any[]\n  ) {\n    const composedKey = stub.createCompositeKey(tableName, [String(id)]);\n    const results: any[] = [];\n\n    let res: Buffer | Record<string, any> = await stub.getState(composedKey);\n\n    if (res.toString() === \"\")\n      throw new NotFoundError(`Record with id ${id} not found`);\n\n    try {\n      res = FabricContractAdapter.serializer.deserialize(\n        res.toString()\n        // model.constructor.name\n      );\n    } catch (e: unknown) {\n      throw new SerializationError(`Failed to parse record: ${e}`);\n    }\n\n    results.push(res);\n\n    return results;\n  }\n\n  protected async queryResult(\n    stub: ChaincodeStub,\n    rawInput: any,\n    // eslint-disable-next-line @typescript-eslint/no-unused-vars\n    ...args: any[]\n  ): Promise<Iterators.StateQueryIterator> {\n    return (await stub.getQueryResult(\n      JSON.stringify(rawInput)\n    )) as Iterators.StateQueryIterator;\n  }\n\n  protected async queryResultPaginated(\n    stub: ChaincodeStub,\n    rawInput: any,\n    limit: number = 250,\n    skip?: number,\n    // eslint-disable-next-line @typescript-eslint/no-unused-vars\n    ...args: any[]\n  ): Promise<StateQueryResponse<Iterators.StateQueryIterator>> {\n    return (await stub.getQueryResultWithPagination(\n      JSON.stringify(rawInput),\n      limit,\n      skip?.toString()\n    )) as StateQueryResponse<Iterators.StateQueryIterator>;\n  }\n\n  protected mergeModels(results: Record<string, any>[]): Record<string, any> {\n    const extract = (model: Record<string, any>) =>\n      Object.entries(model).reduce((accum: Record<string, any>, [key, val]) => {\n        if (typeof val !== \"undefined\") accum[key] = val;\n        return accum;\n      }, {});\n\n    let finalModel: Record<string, any> = results.pop() as Record<string, any>;\n\n    for (const res of results) {\n      finalModel = Object.assign({}, extract(finalModel), extract(res));\n    }\n\n    return finalModel;\n  }\n\n  /**\n   * @description Decodes binary data to string\n   * @summary Converts a Uint8Array to a string using UTF-8 encoding\n   * @param {Uint8Array} buffer - The binary data to decode\n   * @return {string} The decoded string\n   */\n  protected decode(buffer: Uint8Array) {\n    return FabricContractAdapter.textDecoder.decode(buffer);\n  }\n\n  /**\n   * @description Creates operation flags for Fabric contract operations\n   * @summary Merges default flags with Fabric-specific context information\n   * @template M - Type extending Model\n   * @param {OperationKeys} operation - The operation being performed\n   * @param {Constructor<M>} model - The model constructor\n   * @param {Partial<FabricContractFlags>} flags - Partial flags to merge with defaults\n   * @param {Ctx} ctx - The Fabric chaincode context\n   * @return {FabricContractFlags} The merged flags\n   */\n  protected override async flags<M extends Model>(\n    operation: OperationKeys,\n    model: Constructor<M>,\n    flags: Partial<FabricContractFlags>,\n    ctx: Ctx,\n    ...args: any[]\n  ): Promise<FabricContractFlags> {\n    return Object.assign(await super.flags(operation, model, flags, ...args), {\n      stub: ctx.stub,\n      identity: ctx.clientIdentity,\n      logger: this.logFor(ctx),\n    });\n  }\n\n  /**\n   * @description Creates an index for a model\n   * @summary This method is not implemented for Fabric contracts and returns a resolved promise\n   * @template M - Type extending Model\n   * @param {Constructor<M>} models - The model constructor\n   * @return {Promise<void>} Promise that resolves immediately\n   */\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars\n  protected index<M>(models: Constructor<M>): Promise<void> {\n    return Promise.resolve(undefined);\n  }\n\n  /**\n   * @description Processes results from a state query iterator\n   * @summary Iterates through query results and converts them to a structured format\n   * @param {Logger} log - Logger instance for debugging\n   * @param {Iterators.StateQueryIterator} iterator - The state query iterator\n   * @param {boolean} [isHistory=false] - Whether this is a history query\n   * @return {Promise<any[]>} Promise resolving to an array of processed results\n   * @mermaid\n   * sequenceDiagram\n   *   participant Caller\n   *   participant ResultIterator\n   *   participant Iterator\n   *\n   *   Caller->>ResultIterator: resultIterator(log, iterator, isHistory)\n   *   loop Until done\n   *     ResultIterator->>Iterator: next()\n   *     Iterator-->>ResultIterator: { value, done }\n   *     alt Has value\n   *       ResultIterator->>ResultIterator: Process value based on isHistory\n   *       ResultIterator->>ResultIterator: Add to results array\n   *     end\n   *   end\n   *   ResultIterator->>Iterator: close()\n   *   ResultIterator-->>Caller: allResults\n   */\n  protected async resultIterator(\n    log: Logger,\n    iterator: Iterators.StateQueryIterator,\n    isHistory = false\n  ) {\n    const allResults = [];\n    let res: { value: any; done: boolean } = await iterator.next();\n    while (!res.done) {\n      if (res.value && res.value.value.toString()) {\n        let jsonRes: any = {};\n        log.debug(res.value.value.toString(\"utf8\"));\n        if (isHistory /* && isHistory === true*/) {\n          jsonRes.TxId = res.value.txId;\n          jsonRes.Timestamp = res.value.timestamp;\n          try {\n            jsonRes.Value = JSON.parse(res.value.value.toString(\"utf8\"));\n          } catch (err: any) {\n            log.error(err);\n            jsonRes.Value = res.value.value.toString(\"utf8\");\n          }\n        } else {\n          try {\n            jsonRes = JSON.parse(res.value.value.toString(\"utf8\"));\n          } catch (err: any) {\n            log.error(err);\n            jsonRes = res.value.value.toString(\"utf8\");\n          }\n        }\n        allResults.push(jsonRes);\n      }\n      res = await iterator.next();\n    }\n    log.debug(`Closing iterator after ${allResults.length} results`);\n    iterator.close(); // purposely not await. let iterator close on its own\n    return allResults;\n  }\n\n  /**\n   * @description Executes a raw query against the state database\n   * @summary Performs a rich query using CouchDB syntax against the Fabric state database\n   * @template R - The return type\n   * @param {MangoQuery} rawInput - The Mango Query to execute\n   * @param {boolean} docsOnly - Whether to return only documents (not used in this implementation)\n   * @param {...any[]} args - Additional arguments, including the chaincode stub and logger\n   * @return {Promise<R>} Promise resolving to the query results\n   * @mermaid\n   * sequenceDiagram\n   *   participant Caller\n   *   participant FabricContractAdapter\n   *   participant Stub\n   *   participant StateDB\n   *\n   *   Caller->>FabricContractAdapter: raw(rawInput, docsOnly, ctx)\n   *   FabricContractAdapter->>FabricContractAdapter: Extract limit and skip\n   *   alt With pagination\n   *     FabricContractAdapter->>Stub: getQueryResultWithPagination(query, limit, skip)\n   *   else Without pagination\n   *     FabricContractAdapter->>Stub: getQueryResult(query)\n   *   end\n   *   Stub->>StateDB: Execute query\n   *   StateDB-->>Stub: Iterator\n   *   Stub-->>FabricContractAdapter: Iterator\n   *   FabricContractAdapter->>FabricContractAdapter: resultIterator(log, iterator)\n   *   FabricContractAdapter-->>Caller: results\n   */\n  async raw<R>(\n    rawInput: MangoQuery,\n    docsOnly: boolean,\n    ...args: any[]\n  ): Promise<R> {\n    const { stub, logger } = args.pop();\n    const log = logger.for(this.raw);\n    const { skip, limit } = rawInput;\n    let iterator: Iterators.StateQueryIterator;\n    if (limit || skip) {\n      delete rawInput[\"limit\"];\n      delete rawInput[\"skip\"];\n      log.debug(\n        `Retrieving paginated iterator: limit: ${limit}/ skip: ${skip}`\n      );\n      const response: StateQueryResponse<Iterators.StateQueryIterator> =\n        (await this.queryResultPaginated(\n          stub,\n          rawInput,\n          limit || 250,\n          (skip as any)?.toString()\n        )) as StateQueryResponse<Iterators.StateQueryIterator>;\n      iterator = response.iterator;\n    } else {\n      log.debug(\"Retrieving iterator\");\n      iterator = (await this.queryResult(\n        stub,\n        rawInput\n      )) as Iterators.StateQueryIterator;\n    }\n    log.debug(\"Iterator acquired\");\n\n    const results = (await this.resultIterator(log, iterator)) as R;\n    log.debug(\n      `returning {0} results`,\n      `${Array.isArray(results) ? results.length : 1}`\n    );\n    return results;\n  }\n\n  override Statement<M extends Model>(\n    ctx?: FabricContractContext\n  ): FabricStatement<M, any> {\n    if (!ctx) {\n      throw new MissingContextError(\"Context is required\");\n    }\n    return new FabricStatement(this, ctx);\n  }\n\n  override async Sequence(options: SequenceOptions): Promise<Sequence> {\n    return new FabricContractSequence(options, this);\n  }\n\n  override async createAll(\n    tableName: string,\n    id: (string | number)[],\n    model: Record<string, any>[],\n    ...args: any[]\n  ): Promise<Record<string, any>[]> {\n    if (id.length !== model.length)\n      throw new InternalError(\"Ids and models must have the same length\");\n\n    const { logger } = args[args.length - 1] as FabricContractContext;\n    const log = logger.for(this.createAll);\n    log.info(`Creating ${id.length} entries ${tableName} table`);\n    log.debug(`pks: ${id}`);\n\n    return Promise.all(\n      id.map(async (i, index) => {\n        return this.create(tableName, i, model[index], ...args);\n      })\n    );\n  }\n\n  override async updateAll(\n    tableName: string,\n    id: string[] | number[],\n    model: Record<string, any>[],\n    ...args: any[]\n  ): Promise<Record<string, any>[]> {\n    if (id.length !== model.length)\n      throw new InternalError(\"Ids and models must have the same length\");\n\n    const { logger } = args[args.length - 1] as FabricContractContext;\n\n    const log = logger.for(this.createAll);\n    log.info(`Updating ${id.length} entries ${tableName} table`);\n    log.debug(`pks: ${id}`);\n\n    return Promise.all(\n      id.map(async (i, index) => {\n        return this.update(tableName, i, model[index], ...args);\n      })\n    );\n  }\n\n  /**\n   *\n   * @param model\n   * @param {string} pk\n   * @param args\n   */\n  override prepare<M extends Model>(\n    model: M,\n    pk: keyof M,\n    ...args: any[]\n  ): {\n    record: Record<string, any>;\n    id: string;\n    transient?: Record<string, any>;\n  } {\n    const { stub, logger } = args.pop();\n    const tableName = args.shift();\n    const log = logger.for(this.prepare);\n\n    const split = modelToTransient(model);\n    const result = Object.entries(split.model).reduce(\n      (accum: Record<string, any>, [key, val]) => {\n        if (typeof val === \"undefined\") return accum;\n        const mappedProp = Repository.column(model, key);\n        if (this.isReserved(mappedProp))\n          throw new InternalError(`Property name ${mappedProp} is reserved`);\n        accum[mappedProp] = val;\n        return accum;\n      },\n      {}\n    );\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(result, PersistenceKeys.METADATA, {\n        enumerable: false,\n        writable: false,\n        configurable: true,\n        value: (model as any)[PersistenceKeys.METADATA],\n      });\n    }\n\n    log.info(`Preparing record for ${tableName} table with pk ${model[pk]}`);\n\n    return {\n      record: result,\n      id: stub.createCompositeKey(tableName, [String(model[pk])]),\n      transient: split.transient,\n    };\n  }\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,\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[Repository.column(accum, 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  override createPrefix(\n    tableName: string,\n    id: string | number,\n    model: Record<string, any>,\n    ...args: any[]\n  ) {\n    const ctx: FabricContractContext = args.pop();\n    const record: Record<string, any> = {};\n    record[CouchDBKeys.TABLE] = tableName;\n    // record[CouchDBKeys.ID] = this.generateId(tableName, id);\n    Object.assign(record, model);\n    return [tableName, id, record, ctx];\n  }\n\n  override updatePrefix(\n    tableName: string,\n    id: string | number,\n    model: Record<string, any>,\n    ...args: any[]\n  ): (string | number | Record<string, any>)[] {\n    const ctx: FabricContractContext = args.pop();\n    const record: Record<string, any> = {};\n    record[CouchDBKeys.TABLE] = tableName;\n    // record[CouchDBKeys.ID] = this.generateId(tableName, id);\n    Object.assign(record, model);\n    return [tableName, id, record, ctx];\n  }\n\n  protected override createAllPrefix(\n    tableName: string,\n    ids: string[] | number[],\n    models: Record<string, any>[],\n    ...args: any[]\n  ): (string | string[] | number[] | Record<string, any>[])[] {\n    if (ids.length !== models.length)\n      throw new InternalError(\"Ids and models must have the same length\");\n\n    const ctx: FabricContractContext = args.pop();\n\n    const records = ids.map((id, count) => {\n      const record: Record<string, any> = {};\n      record[CouchDBKeys.TABLE] = tableName;\n      // record[CouchDBKeys.ID] = this.generateId(tableName, id);\n      Object.assign(record, models[count]);\n      return record;\n    });\n    return [tableName, ids, records, ctx as any];\n  }\n\n  protected override updateAllPrefix(\n    tableName: string,\n    ids: string[] | number[],\n    models: Record<string, any>[],\n    ...args: any[]\n  ) {\n    if (ids.length !== models.length)\n      throw new InternalError(\"Ids and models must have the same length\");\n\n    const ctx: FabricContractContext = args.pop();\n\n    const records = ids.map((id, count) => {\n      const record: Record<string, any> = {};\n      record[CouchDBKeys.TABLE] = tableName;\n      Object.assign(record, models[count]);\n      return record;\n    });\n    return [tableName, ids, records, ctx as any];\n  }\n\n  /**\n   * @description Static method for decoration overrides\n   * @summary Overrides/extends decaf decoration with Fabric-specific functionality\n   * @static\n   * @override\n   * @return {void}\n   */\n  static override decoration(): void {\n    super.decoration();\n    const createdByKey = Repository.key(PersistenceKeys.CREATED_BY);\n    const updatedByKey = Repository.key(PersistenceKeys.UPDATED_BY);\n    Decoration.flavouredAs(FabricFlavour)\n      .for(createdByKey)\n      .define(\n        onCreate(createdByOnFabricCreateUpdate),\n        propMetadata(createdByKey, {})\n      )\n      .apply();\n\n    Decoration.flavouredAs(FabricFlavour)\n      .for(updatedByKey)\n      .define(\n        onCreateUpdate(createdByOnFabricCreateUpdate),\n        propMetadata(updatedByKey, {})\n      )\n      .apply();\n\n    const pkKey = Repository.key(DBKeys.ID);\n    Decoration.flavouredAs(FabricFlavour)\n      .for(pkKey)\n      .define(\n        index([OrderDirection.ASC, OrderDirection.DSC]),\n        required(),\n        readonly(),\n        // type([String.name, Number.name, BigInt.name]),\n        propMetadata(pkKey, NumericSequence),\n        onCreate(pkFabricOnCreate, NumericSequence)\n      )\n      .apply();\n\n    const columnKey = Adapter.key(PersistenceKeys.COLUMN);\n    Decoration.flavouredAs(FabricFlavour)\n      .for(columnKey)\n      .extend(FabricProperty())\n      .apply();\n\n    const tableKey = Adapter.key(PersistenceKeys.TABLE);\n    Decoration.flavouredAs(FabricFlavour)\n      .for(tableKey)\n      .extend(function table(obj: any) {\n        // const chain: any[] = [];\n\n        // let current = obj;\n\n        // do {\n        //   chain.push(current);\n        //   console.log(`Found class: ${current}`);\n        // } while (current && current !== Object.prototype);\n\n        // do {\n        //   current = chain.pop();\n        //   console.log(`Applying @Object() to class: ${current}`);\n        //   //TODO: THIS IS NOT WORKING AND THROWS ERROR\n        //   // FabricObject()(current);\n        // } while (chain.length > 1);\n\n        return FabricObject()(obj);\n      })\n      .apply();\n\n    const oneToOnekey = Repository.key(PersistenceKeys.ONE_TO_ONE);\n\n    function oneToOneDec<M extends Model>(\n      clazz: Constructor<M> | (() => Constructor<M>),\n      cascade: CascadeMetadata,\n      populate: boolean,\n      joinColumnOpts?: JoinColumnOptions,\n      fk?: string\n    ) {\n      const meta: RelationsMetadata = {\n        class: clazz.name ? clazz.name : (clazz as any),\n        cascade: cascade,\n        populate: populate,\n      };\n      if (joinColumnOpts) meta.joinTable = joinColumnOpts;\n      if (fk) meta.name = fk;\n      return apply(\n        prop(PersistenceKeys.RELATIONS),\n        type([\n          clazz.name ? clazz.name : (clazz as any),\n          String.name,\n          Number.name,\n          BigInt.name,\n        ]),\n        onCreate(oneToOneOnCreate, meta),\n        onUpdate(oneToOneOnUpdate, meta),\n        onDelete(oneToOneOnDelete, meta),\n        afterAny(pop, meta),\n        propMetadata(oneToOnekey, meta)\n      );\n    }\n\n    Decoration.flavouredAs(FabricFlavour)\n      .for(oneToOnekey)\n      .define({\n        decorator: oneToOneDec,\n      })\n      .apply();\n\n    const oneToManyKey = Repository.key(PersistenceKeys.ONE_TO_MANY);\n\n    function oneToManyDec<M extends Model>(\n      clazz: Constructor<M> | (() => Constructor<M>),\n      cascade: CascadeMetadata,\n      populate: boolean,\n      joinTableOpts?: JoinTableOptions | JoinTableMultipleColumnsOptions,\n      fk?: string\n    ) {\n      const metadata: RelationsMetadata = {\n        class: clazz.name ? clazz.name : (clazz as any),\n        cascade: cascade,\n        populate: populate,\n      };\n      if (joinTableOpts) metadata.joinTable = joinTableOpts;\n      if (fk) metadata.name = fk;\n      return apply(\n        prop(PersistenceKeys.RELATIONS),\n        list([clazz as Constructor<M>, String, Number, BigInt]),\n        onCreate(oneToManyOnCreate, metadata),\n        onUpdate(oneToManyOnUpdate, metadata),\n        onDelete(oneToManyOnDelete, metadata),\n        afterAny(pop, metadata),\n        propMetadata(oneToManyKey, metadata)\n      );\n    }\n\n    Decoration.for(oneToManyKey)\n      .define({\n        decorator: oneToManyDec,\n      })\n      .apply();\n  }\n}\n\nFabricContractAdapter.decoration();\nAdapter.setCurrent(FabricFlavour);\n"]}