@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,62 @@
1
+ import { BulkCrudOperationKeys, OperationKeys } from "@decaf-ts/db-decorators";
2
+ import { EventIds, ObserverHandler } from "@decaf-ts/core";
3
+ import { Logger } from "@decaf-ts/logging";
4
+ import { Context } from "fabric-contract-api";
5
+ /**
6
+ * @description Observer handler for Fabric chaincode events
7
+ * @summary Emits events on the Fabric ledger when repository operations occur
8
+ * @class FabricContractRepositoryObservableHandler
9
+ * @extends {ObserverHandler}
10
+ * @example
11
+ * ```typescript
12
+ * // In a Fabric chaincode contract
13
+ * import { FabricContractRepositoryObservableHandler } from '@decaf-ts/for-fabric';
14
+ *
15
+ * // Create a handler with default supported events
16
+ * const handler = new FabricContractRepositoryObservableHandler();
17
+ *
18
+ * // Emit an event
19
+ * await handler.updateObservers(
20
+ * logger,
21
+ * 'assets',
22
+ * OperationKeys.CREATE,
23
+ * 'asset1',
24
+ * context
25
+ * );
26
+ * ```
27
+ * @mermaid
28
+ * sequenceDiagram
29
+ * participant Repository
30
+ * participant ObservableHandler
31
+ * participant Stub
32
+ * participant Ledger
33
+ *
34
+ * Repository->>ObservableHandler: updateObservers(log, table, event, id, ctx)
35
+ * ObservableHandler->>ObservableHandler: Check if event is supported
36
+ * ObservableHandler->>ObservableHandler: generateFabricEventName(table, event, owner)
37
+ * ObservableHandler->>Stub: setEvent(eventName, payload)
38
+ * Stub->>Ledger: Record event
39
+ */
40
+ export declare class FabricContractRepositoryObservableHandler extends ObserverHandler {
41
+ private supportedEvents;
42
+ /**
43
+ * @description Creates a new FabricContractRepositoryObservableHandler instance
44
+ * @summary Initializes the handler with a list of supported events
45
+ * @param {Array<OperationKeys | BulkCrudOperationKeys | string>} [supportedEvents] - Events that will trigger Fabric events
46
+ */
47
+ constructor(supportedEvents?: (OperationKeys | BulkCrudOperationKeys | string)[]);
48
+ /**
49
+ * @description Updates observers by emitting Fabric events
50
+ * @summary Emits events on the Fabric ledger for supported event types
51
+ * @param {Logger} log - Logger instance for debugging
52
+ * @param {string} table - The table/collection name
53
+ * @param {OperationKeys | BulkCrudOperationKeys | string} event - The event type
54
+ * @param {EventIds} id - The event identifier
55
+ * @param {FabricContractContext} ctx - The Fabric contract context
56
+ * @param {string} [owner] - Optional owner identifier for the event
57
+ * @param {object | string | undefined} [owner] - Optional payload for the event
58
+ *
59
+ * @return {Promise<void>} Promise that resolves when the event is emitted
60
+ */
61
+ updateObservers(log: Logger, table: string, event: OperationKeys | BulkCrudOperationKeys | string, id: EventIds, ctx: Context, owner?: string, payload?: object | string | undefined): Promise<void>;
62
+ }
@@ -0,0 +1,139 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.FabricContractSequence = void 0;
4
+ const db_decorators_1 = require("@decaf-ts/db-decorators");
5
+ const core_1 = require("@decaf-ts/core");
6
+ const errors_1 = require("./../shared/errors.cjs");
7
+ const PrivateSequence_1 = require("./PrivateSequence.cjs");
8
+ const decorators_1 = require("./../shared/decorators.cjs");
9
+ /**
10
+ * @description Abstract implementation of a Sequence for Fabric contracts
11
+ * @summary Provides the basic functionality for sequences backed by the FabricContractRepository storing values in CouchDB-like state, including current, next and range operations.
12
+ * @param {SequenceOptions} options - Sequence configuration such as name, type, startWith and incrementBy
13
+ * @return {void}
14
+ * @class FabricContractSequence
15
+ * @example
16
+ * const seq = new FabricContractDBSequence({ name: 'orderSeq', type: 'Number', incrementBy: 1, startWith: 1 }, adapter);
17
+ * const next = await seq.next(ctx); // 1
18
+ * const [a,b,c] = await seq.range(3, ctx); // [2,3,4]
19
+ * @mermaid
20
+ * sequenceDiagram
21
+ * participant App
22
+ * participant Sequence
23
+ * participant Repo
24
+ * App->>Sequence: next(ctx)
25
+ * Sequence->>Repo: read(name, ctx)
26
+ * Repo-->>Sequence: current
27
+ * Sequence->>Repo: update(current+inc)
28
+ * Repo-->>Sequence: saved
29
+ * Sequence-->>App: next value
30
+ */
31
+ class FabricContractSequence extends core_1.Sequence {
32
+ constructor(options, adapter, collections) {
33
+ super(options);
34
+ for (const collection of collections || []) {
35
+ (0, decorators_1.privateData)(collection)(PrivateSequence_1.CustomizableSequence);
36
+ }
37
+ this.repo = core_1.Repository.forModel(PrivateSequence_1.CustomizableSequence, adapter.alias);
38
+ }
39
+ /**
40
+ * @summary Retrieves the current value for the sequence
41
+ * @protected
42
+ */
43
+ async current(ctx) {
44
+ if (!ctx)
45
+ throw new errors_1.MissingContextError("Context is required");
46
+ const { name, startWith } = this.options;
47
+ try {
48
+ const sequence = await this.repo.read(name, ctx);
49
+ return this.parse(sequence.current);
50
+ }
51
+ catch (e) {
52
+ if (e instanceof db_decorators_1.NotFoundError) {
53
+ if (typeof startWith === "undefined")
54
+ throw new db_decorators_1.InternalError("Starting value is not defined for a non existing sequence");
55
+ try {
56
+ return this.parse(startWith);
57
+ }
58
+ catch (e) {
59
+ throw new db_decorators_1.InternalError(`Failed to parse initial value for sequence ${startWith}: ${e}`);
60
+ }
61
+ }
62
+ throw new db_decorators_1.InternalError(`Failed to retrieve current value for sequence ${name}: ${e}`);
63
+ }
64
+ }
65
+ /**
66
+ * @summary Parses the {@link Sequence} value
67
+ *
68
+ * @protected
69
+ * @param value
70
+ */
71
+ parse(value) {
72
+ return core_1.Sequence.parseValue(this.options.type, value);
73
+ }
74
+ /**
75
+ * @summary increments the sequence
76
+ * @description Sequence specific implementation
77
+ *
78
+ * @param {string | number | bigint} current
79
+ * @param count
80
+ * @protected
81
+ */
82
+ async increment(current, count, ctx) {
83
+ if (!ctx)
84
+ throw new errors_1.MissingContextError("Context is required");
85
+ const { type, incrementBy, name } = this.options;
86
+ let next;
87
+ const toIncrementBy = count || incrementBy;
88
+ if (toIncrementBy % incrementBy !== 0)
89
+ throw new db_decorators_1.InternalError(`Value to increment does not consider the incrementBy setting: ${incrementBy}`);
90
+ switch (type) {
91
+ case "Number":
92
+ next = this.parse(current) + toIncrementBy;
93
+ break;
94
+ case "BigInt":
95
+ next = this.parse(current) + BigInt(toIncrementBy);
96
+ break;
97
+ default:
98
+ throw new db_decorators_1.InternalError("Should never happen");
99
+ }
100
+ let seq;
101
+ try {
102
+ seq = await this.repo.update(new PrivateSequence_1.CustomizableSequence({ id: name, current: next }), ctx);
103
+ }
104
+ catch (e) {
105
+ if (!(e instanceof db_decorators_1.NotFoundError))
106
+ throw e;
107
+ seq = await this.repo.create(new PrivateSequence_1.CustomizableSequence({ id: name, current: next }), ctx);
108
+ }
109
+ return seq.current;
110
+ }
111
+ /**
112
+ * @summary Generates the next value in th sequence
113
+ * @description calls {@link Sequence#parse} on the current value
114
+ * followed by {@link Sequence#increment}
115
+ *
116
+ */
117
+ async next(ctx) {
118
+ if (!ctx)
119
+ throw new errors_1.MissingContextError("Context is required");
120
+ const current = await this.current(ctx);
121
+ return this.increment(current, undefined, ctx);
122
+ }
123
+ async range(count, ctx) {
124
+ if (!ctx)
125
+ throw new errors_1.MissingContextError("Context is required");
126
+ const current = (await this.current(ctx));
127
+ const incrementBy = this.parse(this.options.incrementBy);
128
+ const next = await this.increment(current, this.parse(count) * incrementBy, ctx);
129
+ const range = [];
130
+ for (let i = 1; i <= count; i++) {
131
+ range.push(current + incrementBy * this.parse(i));
132
+ }
133
+ if (range[range.length - 1] !== next)
134
+ throw new db_decorators_1.InternalError("Miscalculation of range");
135
+ return range;
136
+ }
137
+ }
138
+ exports.FabricContractSequence = FabricContractSequence;
139
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"FabricContractSequence.js","sourceRoot":"","sources":["../../src/contracts/FabricContractSequence.ts"],"names":[],"mappings":";;;AAAA,2DAKiC;AACjC,yCAAgF;AAIhF,mDAAuD;AACvD,2DAAyD;AACzD,2DAAmD;AAEnD;;;;;;;;;;;;;;;;;;;;;GAqBG;AACH,MAAa,sBAAuB,SAAQ,eAAQ;IAGlD,YACE,OAAwB,EACxB,OAAgD,EAChD,WAAsB;QAEtB,KAAK,CAAC,OAAO,CAAC,CAAC;QAEf,KAAK,MAAM,UAAU,IAAI,WAAW,IAAI,EAAE,EAAE,CAAC;YAC3C,IAAA,wBAAW,EAAC,UAAU,CAAC,CAAC,sCAAoB,CAAC,CAAC;QAChD,CAAC;QAED,IAAI,CAAC,IAAI,GAAG,iBAAU,CAAC,QAAQ,CAAC,sCAAoB,EAAE,OAAO,CAAC,KAAK,CAAC,CAAC;IACvE,CAAC;IAED;;;OAGG;IACH,KAAK,CAAC,OAAO,CACX,GAA8B;QAE9B,IAAI,CAAC,GAAG;YAAE,MAAM,IAAI,4BAAmB,CAAC,qBAAqB,CAAC,CAAC;QAC/D,MAAM,EAAE,IAAI,EAAE,SAAS,EAAE,GAAG,IAAI,CAAC,OAAO,CAAC;QACzC,IAAI,CAAC;YACH,MAAM,QAAQ,GAAyB,MAAM,IAAI,CAAC,IAAI,CAAC,IAAI,CACzD,IAAc,EACd,GAAG,CACJ,CAAC;YACF,OAAO,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,OAA0B,CAAC,CAAC;QACzD,CAAC;QAAC,OAAO,CAAM,EAAE,CAAC;YAChB,IAAI,CAAC,YAAY,6BAAa,EAAE,CAAC;gBAC/B,IAAI,OAAO,SAAS,KAAK,WAAW;oBAClC,MAAM,IAAI,6BAAa,CACrB,2DAA2D,CAC5D,CAAC;gBACJ,IAAI,CAAC;oBACH,OAAO,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC;gBAC/B,CAAC;gBAAC,OAAO,CAAU,EAAE,CAAC;oBACpB,MAAM,IAAI,6BAAa,CACrB,8CAA8C,SAAS,KAAK,CAAC,EAAE,CAChE,CAAC;gBACJ,CAAC;YACH,CAAC;YACD,MAAM,IAAI,6BAAa,CACrB,iDAAiD,IAAI,KAAK,CAAC,EAAE,CAC9D,CAAC;QACJ,CAAC;IACH,CAAC;IAED;;;;;OAKG;IACK,KAAK,CAAC,KAA+B;QAC3C,OAAO,eAAQ,CAAC,UAAU,CAAC,IAAI,CAAC,OAAO,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC;IACvD,CAAC;IAED;;;;;;;OAOG;IACK,KAAK,CAAC,SAAS,CACrB,OAAiC,EACjC,KAAc,EACd,GAA2B;QAE3B,IAAI,CAAC,GAAG;YAAE,MAAM,IAAI,4BAAmB,CAAC,qBAAqB,CAAC,CAAC;QAC/D,MAAM,EAAE,IAAI,EAAE,WAAW,EAAE,IAAI,EAAE,GAAG,IAAI,CAAC,OAAO,CAAC;QACjD,IAAI,IAA8B,CAAC;QACnC,MAAM,aAAa,GAAG,KAAK,IAAI,WAAW,CAAC;QAC3C,IAAI,aAAa,GAAG,WAAW,KAAK,CAAC;YACnC,MAAM,IAAI,6BAAa,CACrB,iEAAiE,WAAW,EAAE,CAC/E,CAAC;QACJ,QAAQ,IAAI,EAAE,CAAC;YACb,KAAK,QAAQ;gBACX,IAAI,GAAI,IAAI,CAAC,KAAK,CAAC,OAAO,CAAY,GAAG,aAAa,CAAC;gBACvD,MAAM;YACR,KAAK,QAAQ;gBACX,IAAI,GAAI,IAAI,CAAC,KAAK,CAAC,OAAO,CAAY,GAAG,MAAM,CAAC,aAAa,CAAC,CAAC;gBAC/D,MAAM;YACR;gBACE,MAAM,IAAI,6BAAa,CAAC,qBAAqB,CAAC,CAAC;QACnD,CAAC;QACD,IAAI,GAAyB,CAAC;QAC9B,IAAI,CAAC;YACH,GAAG,GAAG,MAAM,IAAI,CAAC,IAAI,CAAC,MAAM,CAC1B,IAAI,sCAAoB,CAAC,EAAE,EAAE,EAAE,IAAI,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC,EACrD,GAAG,CACJ,CAAC;QACJ,CAAC;QAAC,OAAO,CAAM,EAAE,CAAC;YAChB,IAAI,CAAC,CAAC,CAAC,YAAY,6BAAa,CAAC;gBAAE,MAAM,CAAC,CAAC;YAC3C,GAAG,GAAG,MAAM,IAAI,CAAC,IAAI,CAAC,MAAM,CAC1B,IAAI,sCAAoB,CAAC,EAAE,EAAE,EAAE,IAAI,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC,EACrD,GAAG,CACJ,CAAC;QACJ,CAAC;QAED,OAAO,GAAG,CAAC,OAAmC,CAAC;IACjD,CAAC;IAED;;;;;OAKG;IACH,KAAK,CAAC,IAAI,CAAC,GAA2B;QACpC,IAAI,CAAC,GAAG;YAAE,MAAM,IAAI,4BAAmB,CAAC,qBAAqB,CAAC,CAAC;QAC/D,MAAM,OAAO,GAAG,MAAM,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC;QACxC,OAAO,IAAI,CAAC,SAAS,CAAC,OAAO,EAAE,SAAS,EAAE,GAAG,CAAC,CAAC;IACjD,CAAC;IAED,KAAK,CAAC,KAAK,CACT,KAAa,EACb,GAA2B;QAE3B,IAAI,CAAC,GAAG;YAAE,MAAM,IAAI,4BAAmB,CAAC,qBAAqB,CAAC,CAAC;QAC/D,MAAM,OAAO,GAAG,CAAC,MAAM,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,CAAW,CAAC;QACpD,MAAM,WAAW,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,OAAO,CAAC,WAAW,CAAW,CAAC;QACnE,MAAM,IAAI,GAA6B,MAAM,IAAI,CAAC,SAAS,CACzD,OAAO,EACN,IAAI,CAAC,KAAK,CAAC,KAAK,CAAY,GAAG,WAAW,EAC3C,GAAG,CACJ,CAAC;QACF,MAAM,KAAK,GAAiC,EAAE,CAAC;QAC/C,KAAK,IAAI,CAAC,GAAW,CAAC,EAAE,CAAC,IAAI,KAAK,EAAE,CAAC,EAAE,EAAE,CAAC;YACxC,KAAK,CAAC,IAAI,CAAC,OAAO,GAAG,WAAW,GAAI,IAAI,CAAC,KAAK,CAAC,CAAC,CAAY,CAAC,CAAC;QAChE,CAAC;QACD,IAAI,KAAK,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC,KAAK,IAAI;YAClC,MAAM,IAAI,6BAAa,CAAC,yBAAyB,CAAC,CAAC;QACrD,OAAO,KAAK,CAAC;IACf,CAAC;CACF;AA9ID,wDA8IC","sourcesContent":["import {\n  Context,\n  InternalError,\n  NotFoundError,\n  RepositoryFlags,\n} from \"@decaf-ts/db-decorators\";\nimport { Adapter, Repository, Sequence, SequenceOptions } from \"@decaf-ts/core\";\nimport { MangoQuery } from \"@decaf-ts/for-couchdb\";\nimport { FabricContractContext } from \"./ContractContext\";\nimport { FabricContractRepository } from \"./FabricContractRepository\";\nimport { MissingContextError } from \"../shared/errors\";\nimport { CustomizableSequence } from \"./PrivateSequence\";\nimport { privateData } from \"../shared/decorators\";\n\n/**\n * @description Abstract implementation of a Sequence for Fabric contracts\n * @summary Provides the basic functionality for sequences backed by the FabricContractRepository storing values in CouchDB-like state, including current, next and range operations.\n * @param {SequenceOptions} options - Sequence configuration such as name, type, startWith and incrementBy\n * @return {void}\n * @class FabricContractSequence\n * @example\n * const seq = new FabricContractDBSequence({ name: 'orderSeq', type: 'Number', incrementBy: 1, startWith: 1 }, adapter);\n * const next = await seq.next(ctx); // 1\n * const [a,b,c] = await seq.range(3, ctx); // [2,3,4]\n * @mermaid\n * sequenceDiagram\n *   participant App\n *   participant Sequence\n *   participant Repo\n *   App->>Sequence: next(ctx)\n *   Sequence->>Repo: read(name, ctx)\n *   Repo-->>Sequence: current\n *   Sequence->>Repo: update(current+inc)\n *   Repo-->>Sequence: saved\n *   Sequence-->>App: next value\n */\nexport class FabricContractSequence extends Sequence {\n  protected repo: FabricContractRepository<CustomizableSequence>;\n\n  constructor(\n    options: SequenceOptions,\n    adapter: Adapter<any, any, MangoQuery, any, any>,\n    collections?: string[]\n  ) {\n    super(options);\n\n    for (const collection of collections || []) {\n      privateData(collection)(CustomizableSequence);\n    }\n\n    this.repo = Repository.forModel(CustomizableSequence, adapter.alias);\n  }\n\n  /**\n   * @summary Retrieves the current value for the sequence\n   * @protected\n   */\n  async current(\n    ctx?: Context<RepositoryFlags>\n  ): Promise<string | number | bigint> {\n    if (!ctx) throw new MissingContextError(\"Context is required\");\n    const { name, startWith } = this.options;\n    try {\n      const sequence: CustomizableSequence = await this.repo.read(\n        name as string,\n        ctx\n      );\n      return this.parse(sequence.current as string | number);\n    } catch (e: any) {\n      if (e instanceof NotFoundError) {\n        if (typeof startWith === \"undefined\")\n          throw new InternalError(\n            \"Starting value is not defined for a non existing sequence\"\n          );\n        try {\n          return this.parse(startWith);\n        } catch (e: unknown) {\n          throw new InternalError(\n            `Failed to parse initial value for sequence ${startWith}: ${e}`\n          );\n        }\n      }\n      throw new InternalError(\n        `Failed to retrieve current value for sequence ${name}: ${e}`\n      );\n    }\n  }\n\n  /**\n   * @summary Parses the {@link Sequence} value\n   *\n   * @protected\n   * @param value\n   */\n  private parse(value: string | number | bigint): string | number | bigint {\n    return Sequence.parseValue(this.options.type, value);\n  }\n\n  /**\n   * @summary increments the sequence\n   * @description Sequence specific implementation\n   *\n   * @param {string | number | bigint} current\n   * @param count\n   * @protected\n   */\n  private async increment(\n    current: string | number | bigint,\n    count?: number,\n    ctx?: FabricContractContext\n  ): Promise<string | number | bigint> {\n    if (!ctx) throw new MissingContextError(\"Context is required\");\n    const { type, incrementBy, name } = this.options;\n    let next: string | number | bigint;\n    const toIncrementBy = count || incrementBy;\n    if (toIncrementBy % incrementBy !== 0)\n      throw new InternalError(\n        `Value to increment does not consider the incrementBy setting: ${incrementBy}`\n      );\n    switch (type) {\n      case \"Number\":\n        next = (this.parse(current) as number) + toIncrementBy;\n        break;\n      case \"BigInt\":\n        next = (this.parse(current) as bigint) + BigInt(toIncrementBy);\n        break;\n      default:\n        throw new InternalError(\"Should never happen\");\n    }\n    let seq: CustomizableSequence;\n    try {\n      seq = await this.repo.update(\n        new CustomizableSequence({ id: name, current: next }),\n        ctx\n      );\n    } catch (e: any) {\n      if (!(e instanceof NotFoundError)) throw e;\n      seq = await this.repo.create(\n        new CustomizableSequence({ id: name, current: next }),\n        ctx\n      );\n    }\n\n    return seq.current as string | number | bigint;\n  }\n\n  /**\n   * @summary Generates the next value in th sequence\n   * @description calls {@link Sequence#parse} on the current value\n   * followed by {@link Sequence#increment}\n   *\n   */\n  async next(ctx?: FabricContractContext): Promise<number | string | bigint> {\n    if (!ctx) throw new MissingContextError(\"Context is required\");\n    const current = await this.current(ctx);\n    return this.increment(current, undefined, ctx);\n  }\n\n  async range(\n    count: number,\n    ctx?: FabricContractContext\n  ): Promise<(number | string | bigint)[]> {\n    if (!ctx) throw new MissingContextError(\"Context is required\");\n    const current = (await this.current(ctx)) as number;\n    const incrementBy = this.parse(this.options.incrementBy) as number;\n    const next: string | number | bigint = await this.increment(\n      current,\n      (this.parse(count) as number) * incrementBy,\n      ctx\n    );\n    const range: (number | string | bigint)[] = [];\n    for (let i: number = 1; i <= count; i++) {\n      range.push(current + incrementBy * (this.parse(i) as number));\n    }\n    if (range[range.length - 1] !== next)\n      throw new InternalError(\"Miscalculation of range\");\n    return range;\n  }\n}\n"]}
@@ -0,0 +1,61 @@
1
+ import { Context, RepositoryFlags } from "@decaf-ts/db-decorators";
2
+ import { Adapter, Sequence, SequenceOptions } from "@decaf-ts/core";
3
+ import { MangoQuery } from "@decaf-ts/for-couchdb";
4
+ import { FabricContractContext } from "./ContractContext";
5
+ import { FabricContractRepository } from "./FabricContractRepository";
6
+ import { CustomizableSequence } from "./PrivateSequence";
7
+ /**
8
+ * @description Abstract implementation of a Sequence for Fabric contracts
9
+ * @summary Provides the basic functionality for sequences backed by the FabricContractRepository storing values in CouchDB-like state, including current, next and range operations.
10
+ * @param {SequenceOptions} options - Sequence configuration such as name, type, startWith and incrementBy
11
+ * @return {void}
12
+ * @class FabricContractSequence
13
+ * @example
14
+ * const seq = new FabricContractDBSequence({ name: 'orderSeq', type: 'Number', incrementBy: 1, startWith: 1 }, adapter);
15
+ * const next = await seq.next(ctx); // 1
16
+ * const [a,b,c] = await seq.range(3, ctx); // [2,3,4]
17
+ * @mermaid
18
+ * sequenceDiagram
19
+ * participant App
20
+ * participant Sequence
21
+ * participant Repo
22
+ * App->>Sequence: next(ctx)
23
+ * Sequence->>Repo: read(name, ctx)
24
+ * Repo-->>Sequence: current
25
+ * Sequence->>Repo: update(current+inc)
26
+ * Repo-->>Sequence: saved
27
+ * Sequence-->>App: next value
28
+ */
29
+ export declare class FabricContractSequence extends Sequence {
30
+ protected repo: FabricContractRepository<CustomizableSequence>;
31
+ constructor(options: SequenceOptions, adapter: Adapter<any, any, MangoQuery, any, any>, collections?: string[]);
32
+ /**
33
+ * @summary Retrieves the current value for the sequence
34
+ * @protected
35
+ */
36
+ current(ctx?: Context<RepositoryFlags>): Promise<string | number | bigint>;
37
+ /**
38
+ * @summary Parses the {@link Sequence} value
39
+ *
40
+ * @protected
41
+ * @param value
42
+ */
43
+ private parse;
44
+ /**
45
+ * @summary increments the sequence
46
+ * @description Sequence specific implementation
47
+ *
48
+ * @param {string | number | bigint} current
49
+ * @param count
50
+ * @protected
51
+ */
52
+ private increment;
53
+ /**
54
+ * @summary Generates the next value in th sequence
55
+ * @description calls {@link Sequence#parse} on the current value
56
+ * followed by {@link Sequence#increment}
57
+ *
58
+ */
59
+ next(ctx?: FabricContractContext): Promise<number | string | bigint>;
60
+ range(count: number, ctx?: FabricContractContext): Promise<(number | string | bigint)[]>;
61
+ }
@@ -0,0 +1,119 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.FabricStatement = void 0;
4
+ const for_couchdb_1 = require("@decaf-ts/for-couchdb");
5
+ const db_decorators_1 = require("@decaf-ts/db-decorators");
6
+ const core_1 = require("@decaf-ts/core");
7
+ /**
8
+ * @description Statement wrapper for executing Mango queries within Fabric contracts
9
+ * @summary Bridges CouchDB-style queries to Fabric via the FabricContractAdapter, handling identity and primary key projection when needed.
10
+ * @template M - Model type this statement operates on
11
+ * @template R - Result type returned by the statement
12
+ * @param {FabricContractAdapter} adapter - The Fabric contract adapter used for raw execution
13
+ * @param {FabricContractContext} ctx - The Fabric contract context carrying stub and identity
14
+ * @return {void}
15
+ * @class FabricStatement
16
+ * @example
17
+ * const stmt = new FabricStatement<MyModel, MyModel[]>(adapter, ctx);
18
+ * const result = await stmt.raw<MyModel[]>({ selector: { type: 'MyModel' } });
19
+ * @mermaid
20
+ * sequenceDiagram
21
+ * participant App
22
+ * participant Statement
23
+ * participant Adapter
24
+ * participant Ledger
25
+ * App->>Statement: raw({ selector })
26
+ * Statement->>Adapter: adapter.raw(mango, true, ctx)
27
+ * Adapter->>Ledger: Evaluate query
28
+ * Adapter-->>Statement: rows
29
+ * Statement-->>App: models
30
+ */
31
+ class FabricStatement extends for_couchdb_1.CouchDBStatement {
32
+ constructor(adapter, ctx) {
33
+ super(adapter);
34
+ this.ctx = ctx;
35
+ }
36
+ async raw(rawInput) {
37
+ const results = await this.adapter.raw(rawInput, true, this.ctx);
38
+ const pkDef = (0, db_decorators_1.findPrimaryKey)(new this.fromSelector());
39
+ const pkAttr = pkDef.id;
40
+ const type = pkDef.props.type;
41
+ if (!this.selectSelector)
42
+ return results.map((r) => this.processRecord(r, pkAttr, type));
43
+ return results;
44
+ }
45
+ build() {
46
+ const selectors = {};
47
+ selectors[for_couchdb_1.CouchDBKeys.TABLE] = {};
48
+ selectors[for_couchdb_1.CouchDBKeys.TABLE] = core_1.Repository.table(this.fromSelector);
49
+ const query = { selector: selectors };
50
+ if (this.selectSelector)
51
+ query.fields = this.selectSelector;
52
+ if (this.whereCondition) {
53
+ const condition = this.parseCondition(core_1.Condition.and(this.whereCondition, core_1.Condition.attribute(for_couchdb_1.CouchDBKeys.TABLE).eq(query.selector[for_couchdb_1.CouchDBKeys.TABLE]))).selector;
54
+ const selectorKeys = Object.keys(condition);
55
+ if (selectorKeys.length === 1 &&
56
+ Object.values(for_couchdb_1.CouchDBGroupOperator).indexOf(selectorKeys[0]) !== -1)
57
+ switch (selectorKeys[0]) {
58
+ case for_couchdb_1.CouchDBGroupOperator.AND:
59
+ condition[for_couchdb_1.CouchDBGroupOperator.AND] = [
60
+ ...Object.values(condition[for_couchdb_1.CouchDBGroupOperator.AND]).reduce((accum, val) => {
61
+ const keys = Object.keys(val);
62
+ if (keys.length !== 1)
63
+ throw new Error("Too many keys in query selector. should be one");
64
+ const k = keys[0];
65
+ if (k === for_couchdb_1.CouchDBGroupOperator.AND)
66
+ accum.push(...val[k]);
67
+ else
68
+ accum.push(val);
69
+ return accum;
70
+ }, []),
71
+ ];
72
+ query.selector = condition;
73
+ break;
74
+ case for_couchdb_1.CouchDBGroupOperator.OR: {
75
+ const s = {};
76
+ s[for_couchdb_1.CouchDBGroupOperator.AND] = [
77
+ condition,
78
+ ...Object.entries(query.selector).map(([key, val]) => {
79
+ const result = {};
80
+ result[key] = val;
81
+ return result;
82
+ }),
83
+ ];
84
+ query.selector = s;
85
+ break;
86
+ }
87
+ default:
88
+ throw new Error("This should be impossible");
89
+ }
90
+ else {
91
+ Object.entries(condition).forEach(([key, val]) => {
92
+ if (query.selector[key])
93
+ console.warn(`A ${key} query param is about to be overridden: ${query.selector[key]} by ${val}`);
94
+ query.selector[key] = val;
95
+ });
96
+ }
97
+ }
98
+ if (this.orderBySelector) {
99
+ query.sort = query.sort || [];
100
+ query.selector = query.selector || {};
101
+ const [selector, value] = this.orderBySelector;
102
+ const rec = {};
103
+ rec[selector] = value;
104
+ query.sort.push(rec);
105
+ if (!query.selector[selector]) {
106
+ query.selector[selector] = {};
107
+ query.selector[selector][for_couchdb_1.CouchDBOperator.BIGGER] =
108
+ null;
109
+ }
110
+ }
111
+ if (this.limitSelector)
112
+ query.limit = this.limitSelector;
113
+ if (this.offsetSelector)
114
+ query.skip = this.offsetSelector;
115
+ return query;
116
+ }
117
+ }
118
+ exports.FabricStatement = FabricStatement;
119
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"FabricContractStatement.js","sourceRoot":"","sources":["../../src/contracts/FabricContractStatement.ts"],"names":[],"mappings":"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","sourcesContent":["import { Model } from \"@decaf-ts/decorator-validation\";\nimport {\n  CouchDBAdapter,\n  CouchDBGroupOperator,\n  CouchDBKeys,\n  CouchDBOperator,\n  CouchDBStatement,\n  MangoOperator,\n  MangoQuery,\n  MangoSelector,\n} from \"@decaf-ts/for-couchdb\";\nimport { FabricContractAdapter } from \"./ContractAdapter\";\nimport { findPrimaryKey } from \"@decaf-ts/db-decorators\";\nimport { FabricContractContext } from \"./ContractContext\";\nimport { Condition, OrderDirection, Repository } from \"@decaf-ts/core\";\n\n/**\n * @description Statement wrapper for executing Mango queries within Fabric contracts\n * @summary Bridges CouchDB-style queries to Fabric via the FabricContractAdapter, handling identity and primary key projection when needed.\n * @template M - Model type this statement operates on\n * @template R - Result type returned by the statement\n * @param {FabricContractAdapter} adapter - The Fabric contract adapter used for raw execution\n * @param {FabricContractContext} ctx - The Fabric contract context carrying stub and identity\n * @return {void}\n * @class FabricStatement\n * @example\n * const stmt = new FabricStatement<MyModel, MyModel[]>(adapter, ctx);\n * const result = await stmt.raw<MyModel[]>({ selector: { type: 'MyModel' } });\n * @mermaid\n * sequenceDiagram\n *   participant App\n *   participant Statement\n *   participant Adapter\n *   participant Ledger\n *   App->>Statement: raw({ selector })\n *   Statement->>Adapter: adapter.raw(mango, true, ctx)\n *   Adapter->>Ledger: Evaluate query\n *   Adapter-->>Statement: rows\n *   Statement-->>App: models\n */\nexport class FabricStatement<M extends Model, R> extends CouchDBStatement<\n  M,\n  R\n> {\n  constructor(\n    adapter: FabricContractAdapter,\n    private readonly ctx: FabricContractContext\n  ) {\n    super(adapter as unknown as CouchDBAdapter<any, any, any, any>);\n  }\n\n  override async raw<R>(rawInput: MangoQuery): Promise<R> {\n    const results: any[] = await this.adapter.raw(rawInput, true, this.ctx);\n\n    const pkDef = findPrimaryKey(new this.fromSelector());\n    const pkAttr = pkDef.id;\n    const type = pkDef.props.type;\n\n    if (!this.selectSelector)\n      return results.map((r) => this.processRecord(r, pkAttr, type)) as R;\n    return results as R;\n  }\n\n  override build(): MangoQuery {\n    const selectors: MangoSelector = {};\n    selectors[CouchDBKeys.TABLE] = {};\n    selectors[CouchDBKeys.TABLE] = Repository.table(this.fromSelector);\n    const query: MangoQuery = { selector: selectors };\n    if (this.selectSelector) query.fields = this.selectSelector as string[];\n\n    if (this.whereCondition) {\n      const condition: MangoSelector = this.parseCondition(\n        Condition.and(\n          this.whereCondition,\n          Condition.attribute<M>(CouchDBKeys.TABLE as keyof M).eq(\n            query.selector[CouchDBKeys.TABLE]\n          )\n        )\n      ).selector;\n      const selectorKeys = Object.keys(condition) as MangoOperator[];\n      if (\n        selectorKeys.length === 1 &&\n        Object.values(CouchDBGroupOperator).indexOf(selectorKeys[0]) !== -1\n      )\n        switch (selectorKeys[0]) {\n          case CouchDBGroupOperator.AND:\n            condition[CouchDBGroupOperator.AND] = [\n              ...Object.values(\n                condition[CouchDBGroupOperator.AND] as MangoSelector\n              ).reduce((accum: MangoSelector[], val: any) => {\n                const keys = Object.keys(val);\n                if (keys.length !== 1)\n                  throw new Error(\n                    \"Too many keys in query selector. should be one\"\n                  );\n                const k = keys[0];\n                if (k === CouchDBGroupOperator.AND)\n                  accum.push(...(val[k] as any[]));\n                else accum.push(val);\n                return accum;\n              }, []),\n            ];\n            query.selector = condition;\n            break;\n          case CouchDBGroupOperator.OR: {\n            const s: Record<any, any> = {};\n            s[CouchDBGroupOperator.AND] = [\n              condition,\n              ...Object.entries(query.selector).map(([key, val]) => {\n                const result: Record<any, any> = {};\n                result[key] = val;\n                return result;\n              }),\n            ];\n            query.selector = s;\n            break;\n          }\n          default:\n            throw new Error(\"This should be impossible\");\n        }\n      else {\n        Object.entries(condition).forEach(([key, val]) => {\n          if (query.selector[key])\n            console.warn(\n              `A ${key} query param is about to be overridden: ${query.selector[key]} by ${val}`\n            );\n          query.selector[key] = val;\n        });\n      }\n    }\n\n    if (this.orderBySelector) {\n      query.sort = query.sort || [];\n      query.selector = query.selector || ({} as MangoSelector);\n      const [selector, value] = this.orderBySelector as [\n        string,\n        OrderDirection,\n      ];\n      const rec: any = {};\n      rec[selector] = value;\n      (query.sort as any[]).push(rec as any);\n      if (!query.selector[selector]) {\n        query.selector[selector] = {} as MangoSelector;\n        (query.selector[selector] as MangoSelector)[CouchDBOperator.BIGGER] =\n          null;\n      }\n    }\n\n    if (this.limitSelector) query.limit = this.limitSelector;\n\n    if (this.offsetSelector) query.skip = this.offsetSelector;\n\n    return query;\n  }\n}\n"]}
@@ -0,0 +1,34 @@
1
+ import { Model } from "@decaf-ts/decorator-validation";
2
+ import { CouchDBStatement, MangoQuery } from "@decaf-ts/for-couchdb";
3
+ import { FabricContractAdapter } from "./ContractAdapter";
4
+ import { FabricContractContext } from "./ContractContext";
5
+ /**
6
+ * @description Statement wrapper for executing Mango queries within Fabric contracts
7
+ * @summary Bridges CouchDB-style queries to Fabric via the FabricContractAdapter, handling identity and primary key projection when needed.
8
+ * @template M - Model type this statement operates on
9
+ * @template R - Result type returned by the statement
10
+ * @param {FabricContractAdapter} adapter - The Fabric contract adapter used for raw execution
11
+ * @param {FabricContractContext} ctx - The Fabric contract context carrying stub and identity
12
+ * @return {void}
13
+ * @class FabricStatement
14
+ * @example
15
+ * const stmt = new FabricStatement<MyModel, MyModel[]>(adapter, ctx);
16
+ * const result = await stmt.raw<MyModel[]>({ selector: { type: 'MyModel' } });
17
+ * @mermaid
18
+ * sequenceDiagram
19
+ * participant App
20
+ * participant Statement
21
+ * participant Adapter
22
+ * participant Ledger
23
+ * App->>Statement: raw({ selector })
24
+ * Statement->>Adapter: adapter.raw(mango, true, ctx)
25
+ * Adapter->>Ledger: Evaluate query
26
+ * Adapter-->>Statement: rows
27
+ * Statement-->>App: models
28
+ */
29
+ export declare class FabricStatement<M extends Model, R> extends CouchDBStatement<M, R> {
30
+ private readonly ctx;
31
+ constructor(adapter: FabricContractAdapter, ctx: FabricContractContext);
32
+ raw<R>(rawInput: MangoQuery): Promise<R>;
33
+ build(): MangoQuery;
34
+ }
@@ -0,0 +1,36 @@
1
+ "use strict";
2
+ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
3
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
4
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
5
+ else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
6
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
7
+ };
8
+ var __metadata = (this && this.__metadata) || function (k, v) {
9
+ if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
10
+ };
11
+ Object.defineProperty(exports, "__esModule", { value: true });
12
+ exports.CustomizableSequence = void 0;
13
+ const core_1 = require("@decaf-ts/core");
14
+ const decorator_validation_1 = require("@decaf-ts/decorator-validation");
15
+ const for_couchdb_1 = require("@decaf-ts/for-couchdb");
16
+ let CustomizableSequence = class CustomizableSequence extends core_1.BaseModel {
17
+ constructor(seq) {
18
+ super(seq);
19
+ }
20
+ };
21
+ exports.CustomizableSequence = CustomizableSequence;
22
+ __decorate([
23
+ (0, core_1.pk)(),
24
+ __metadata("design:type", String)
25
+ ], CustomizableSequence.prototype, "id", void 0);
26
+ __decorate([
27
+ (0, decorator_validation_1.required)(),
28
+ (0, core_1.index)(),
29
+ __metadata("design:type", Object)
30
+ ], CustomizableSequence.prototype, "current", void 0);
31
+ exports.CustomizableSequence = CustomizableSequence = __decorate([
32
+ (0, core_1.table)(for_couchdb_1.CouchDBKeys.SEQUENCE),
33
+ (0, decorator_validation_1.model)(),
34
+ __metadata("design:paramtypes", [Object])
35
+ ], CustomizableSequence);
36
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiUHJpdmF0ZVNlcXVlbmNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2NvbnRyYWN0cy9Qcml2YXRlU2VxdWVuY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7O0FBQUEseUNBQTZEO0FBQzdELHlFQUFnRjtBQUNoRix1REFBb0Q7QUFJN0MsSUFBTSxvQkFBb0IsR0FBMUIsTUFBTSxvQkFBcUIsU0FBUSxnQkFBUztJQWdCakQsWUFBWSxHQUFvQztRQUM5QyxLQUFLLENBQUMsR0FBRyxDQUFDLENBQUM7SUFDYixDQUFDO0NBQ0YsQ0FBQTtBQW5CWSxvREFBb0I7QUFNL0I7SUFEQyxJQUFBLFNBQUUsR0FBRTs7Z0RBQ087QUFRWjtJQUZDLElBQUEsK0JBQVEsR0FBRTtJQUNWLElBQUEsWUFBSyxHQUFFOztxREFDa0I7K0JBZGYsb0JBQW9CO0lBRmhDLElBQUEsWUFBSyxFQUFDLHlCQUFXLENBQUMsUUFBUSxDQUFDO0lBQzNCLElBQUEsNEJBQUssR0FBRTs7R0FDSyxvQkFBb0IsQ0FtQmhDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQmFzZU1vZGVsLCBpbmRleCwgcGssIHRhYmxlIH0gZnJvbSBcIkBkZWNhZi10cy9jb3JlXCI7XG5pbXBvcnQgeyBtb2RlbCwgdHlwZSBNb2RlbEFyZywgcmVxdWlyZWQgfSBmcm9tIFwiQGRlY2FmLXRzL2RlY29yYXRvci12YWxpZGF0aW9uXCI7XG5pbXBvcnQgeyBDb3VjaERCS2V5cyB9IGZyb20gXCJAZGVjYWYtdHMvZm9yLWNvdWNoZGJcIjtcblxuQHRhYmxlKENvdWNoREJLZXlzLlNFUVVFTkNFKVxuQG1vZGVsKClcbmV4cG9ydCBjbGFzcyBDdXN0b21pemFibGVTZXF1ZW5jZSBleHRlbmRzIEJhc2VNb2RlbCB7XG4gIC8qKlxuICAgKiBAZGVzY3JpcHRpb24gVGhlIHVuaXF1ZSBpZGVudGlmaWVyIGZvciB0aGUgc2VxdWVuY2VcbiAgICogQHN1bW1hcnkgUHJpbWFyeSBrZXkgZm9yIHRoZSBzZXF1ZW5jZSByZWNvcmRcbiAgICovXG4gIEBwaygpXG4gIGlkITogc3RyaW5nO1xuXG4gIC8qKlxuICAgKiBAZGVzY3JpcHRpb24gVGhlIGN1cnJlbnQgdmFsdWUgb2YgdGhlIHNlcXVlbmNlXG4gICAqIEBzdW1tYXJ5IEN1cnJlbnQgc2VxdWVuY2UgdmFsdWUgdGhhdCBjYW4gYmUgaW5jcmVtZW50ZWRcbiAgICovXG4gIEByZXF1aXJlZCgpXG4gIEBpbmRleCgpXG4gIGN1cnJlbnQhOiBzdHJpbmcgfCBudW1iZXI7XG5cbiAgY29uc3RydWN0b3Ioc2VxPzogTW9kZWxBcmc8Q3VzdG9taXphYmxlU2VxdWVuY2U+KSB7XG4gICAgc3VwZXIoc2VxKTtcbiAgfVxufVxuIl19
@@ -0,0 +1,15 @@
1
+ import { BaseModel } from "@decaf-ts/core";
2
+ import { type ModelArg } from "@decaf-ts/decorator-validation";
3
+ export declare class CustomizableSequence extends BaseModel {
4
+ /**
5
+ * @description The unique identifier for the sequence
6
+ * @summary Primary key for the sequence record
7
+ */
8
+ id: string;
9
+ /**
10
+ * @description The current value of the sequence
11
+ * @summary Current sequence value that can be incremented
12
+ */
13
+ current: string | number;
14
+ constructor(seq?: ModelArg<CustomizableSequence>);
15
+ }