@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.
- package/LICENSE.md +22 -0
- package/README.md +647 -0
- package/dist/for-fabric.cjs +6223 -0
- package/dist/for-fabric.esm.cjs +6180 -0
- package/lib/client/FabricClientAdapter.cjs +760 -0
- package/lib/client/FabricClientAdapter.d.ts +381 -0
- package/lib/client/FabricClientDispatch.cjs +186 -0
- package/lib/client/FabricClientDispatch.d.ts +125 -0
- package/lib/client/FabricClientRepository.cjs +131 -0
- package/lib/client/FabricClientRepository.d.ts +100 -0
- package/lib/client/erc20/erc20ClientRepository.cjs +343 -0
- package/lib/client/erc20/erc20ClientRepository.d.ts +254 -0
- package/lib/client/fabric-fs.cjs +234 -0
- package/lib/client/fabric-fs.d.ts +92 -0
- package/lib/client/index.cjs +30 -0
- package/lib/client/index.d.ts +13 -0
- package/lib/client/logging.cjs +102 -0
- package/lib/client/logging.d.ts +60 -0
- package/lib/client/services/LoggedService.cjs +47 -0
- package/lib/client/services/LoggedService.d.ts +42 -0
- package/lib/client/services/constants.cjs +3 -0
- package/lib/client/services/constants.d.ts +15 -0
- package/lib/client/services/enrollementService.cjs +344 -0
- package/lib/client/services/enrollementService.d.ts +176 -0
- package/lib/client/services/index.cjs +18 -0
- package/lib/client/services/index.d.ts +1 -0
- package/lib/contracts/ContractAdapter.cjs +730 -0
- package/lib/contracts/ContractAdapter.d.ts +296 -0
- package/lib/contracts/ContractContext.cjs +85 -0
- package/lib/contracts/ContractContext.d.ts +64 -0
- package/lib/contracts/ContractPrivateDataAdapter.cjs +281 -0
- package/lib/contracts/ContractPrivateDataAdapter.d.ts +74 -0
- package/lib/contracts/FabricConstruction.cjs +441 -0
- package/lib/contracts/FabricConstruction.d.ts +304 -0
- package/lib/contracts/FabricContractRepository.cjs +306 -0
- package/lib/contracts/FabricContractRepository.d.ts +162 -0
- package/lib/contracts/FabricContractRepositoryObservableHandler.cjs +85 -0
- package/lib/contracts/FabricContractRepositoryObservableHandler.d.ts +62 -0
- package/lib/contracts/FabricContractSequence.cjs +139 -0
- package/lib/contracts/FabricContractSequence.d.ts +61 -0
- package/lib/contracts/FabricContractStatement.cjs +119 -0
- package/lib/contracts/FabricContractStatement.d.ts +34 -0
- package/lib/contracts/PrivateSequence.cjs +36 -0
- package/lib/contracts/PrivateSequence.d.ts +15 -0
- package/lib/contracts/crud/crud-contract.cjs +257 -0
- package/lib/contracts/crud/crud-contract.d.ts +168 -0
- package/lib/contracts/crud/index.cjs +19 -0
- package/lib/contracts/crud/index.d.ts +2 -0
- package/lib/contracts/crud/serialized-crud-contract.cjs +172 -0
- package/lib/contracts/crud/serialized-crud-contract.d.ts +37 -0
- package/lib/contracts/erc20/erc20contract.cjs +569 -0
- package/lib/contracts/erc20/erc20contract.d.ts +151 -0
- package/lib/contracts/erc20/index.cjs +21 -0
- package/lib/contracts/erc20/index.d.ts +2 -0
- package/lib/contracts/erc20/models.cjs +209 -0
- package/lib/contracts/erc20/models.d.ts +114 -0
- package/lib/contracts/index.cjs +32 -0
- package/lib/contracts/index.d.ts +15 -0
- package/lib/contracts/logging.cjs +96 -0
- package/lib/contracts/logging.d.ts +49 -0
- package/lib/contracts/private-data.cjs +121 -0
- package/lib/contracts/private-data.d.ts +16 -0
- package/lib/contracts/types.cjs +3 -0
- package/lib/contracts/types.d.ts +26 -0
- package/lib/esm/client/FabricClientAdapter.d.ts +381 -0
- package/lib/esm/client/FabricClientAdapter.js +723 -0
- package/lib/esm/client/FabricClientDispatch.d.ts +125 -0
- package/lib/esm/client/FabricClientDispatch.js +182 -0
- package/lib/esm/client/FabricClientRepository.d.ts +100 -0
- package/lib/esm/client/FabricClientRepository.js +127 -0
- package/lib/esm/client/erc20/erc20ClientRepository.d.ts +254 -0
- package/lib/esm/client/erc20/erc20ClientRepository.js +339 -0
- package/lib/esm/client/fabric-fs.d.ts +92 -0
- package/lib/esm/client/fabric-fs.js +191 -0
- package/lib/esm/client/index.d.ts +13 -0
- package/lib/esm/client/index.js +14 -0
- package/lib/esm/client/logging.d.ts +60 -0
- package/lib/esm/client/logging.js +98 -0
- package/lib/esm/client/services/LoggedService.d.ts +42 -0
- package/lib/esm/client/services/LoggedService.js +43 -0
- package/lib/esm/client/services/constants.d.ts +15 -0
- package/lib/esm/client/services/constants.js +2 -0
- package/lib/esm/client/services/enrollementService.d.ts +176 -0
- package/lib/esm/client/services/enrollementService.js +337 -0
- package/lib/esm/client/services/index.d.ts +1 -0
- package/lib/esm/client/services/index.js +2 -0
- package/lib/esm/contracts/ContractAdapter.d.ts +296 -0
- package/lib/esm/contracts/ContractAdapter.js +724 -0
- package/lib/esm/contracts/ContractContext.d.ts +64 -0
- package/lib/esm/contracts/ContractContext.js +81 -0
- package/lib/esm/contracts/ContractPrivateDataAdapter.d.ts +74 -0
- package/lib/esm/contracts/ContractPrivateDataAdapter.js +277 -0
- package/lib/esm/contracts/FabricConstruction.d.ts +304 -0
- package/lib/esm/contracts/FabricConstruction.js +433 -0
- package/lib/esm/contracts/FabricContractRepository.d.ts +162 -0
- package/lib/esm/contracts/FabricContractRepository.js +302 -0
- package/lib/esm/contracts/FabricContractRepositoryObservableHandler.d.ts +62 -0
- package/lib/esm/contracts/FabricContractRepositoryObservableHandler.js +81 -0
- package/lib/esm/contracts/FabricContractSequence.d.ts +61 -0
- package/lib/esm/contracts/FabricContractSequence.js +135 -0
- package/lib/esm/contracts/FabricContractStatement.d.ts +34 -0
- package/lib/esm/contracts/FabricContractStatement.js +115 -0
- package/lib/esm/contracts/PrivateSequence.d.ts +15 -0
- package/lib/esm/contracts/PrivateSequence.js +33 -0
- package/lib/esm/contracts/crud/crud-contract.d.ts +168 -0
- package/lib/esm/contracts/crud/crud-contract.js +253 -0
- package/lib/esm/contracts/crud/index.d.ts +2 -0
- package/lib/esm/contracts/crud/index.js +3 -0
- package/lib/esm/contracts/crud/serialized-crud-contract.d.ts +37 -0
- package/lib/esm/contracts/crud/serialized-crud-contract.js +168 -0
- package/lib/esm/contracts/erc20/erc20contract.d.ts +151 -0
- package/lib/esm/contracts/erc20/erc20contract.js +565 -0
- package/lib/esm/contracts/erc20/index.d.ts +2 -0
- package/lib/esm/contracts/erc20/index.js +4 -0
- package/lib/esm/contracts/erc20/models.d.ts +114 -0
- package/lib/esm/contracts/erc20/models.js +206 -0
- package/lib/esm/contracts/index.d.ts +15 -0
- package/lib/esm/contracts/index.js +16 -0
- package/lib/esm/contracts/logging.d.ts +49 -0
- package/lib/esm/contracts/logging.js +92 -0
- package/lib/esm/contracts/private-data.d.ts +16 -0
- package/lib/esm/contracts/private-data.js +113 -0
- package/lib/esm/contracts/types.d.ts +26 -0
- package/lib/esm/contracts/types.js +2 -0
- package/lib/esm/index.d.ts +8 -0
- package/lib/esm/index.js +9 -0
- package/lib/esm/shared/ClientSerializer.d.ts +52 -0
- package/lib/esm/shared/ClientSerializer.js +80 -0
- package/lib/esm/shared/DeterministicSerializer.d.ts +40 -0
- package/lib/esm/shared/DeterministicSerializer.js +50 -0
- package/lib/esm/shared/SimpleDeterministicSerializer.d.ts +7 -0
- package/lib/esm/shared/SimpleDeterministicSerializer.js +42 -0
- package/lib/esm/shared/constants.d.ts +39 -0
- package/lib/esm/shared/constants.js +42 -0
- package/lib/esm/shared/crypto.d.ts +107 -0
- package/lib/esm/shared/crypto.js +331 -0
- package/lib/esm/shared/decorators.d.ts +24 -0
- package/lib/esm/shared/decorators.js +98 -0
- package/lib/esm/shared/erc20/erc20-constants.d.ts +25 -0
- package/lib/esm/shared/erc20/erc20-constants.js +27 -0
- package/lib/esm/shared/errors.d.ts +116 -0
- package/lib/esm/shared/errors.js +132 -0
- package/lib/esm/shared/events.d.ts +39 -0
- package/lib/esm/shared/events.js +47 -0
- package/lib/esm/shared/fabric-types.d.ts +33 -0
- package/lib/esm/shared/fabric-types.js +2 -0
- package/lib/esm/shared/index.d.ts +13 -0
- package/lib/esm/shared/index.js +14 -0
- package/lib/esm/shared/interfaces/Checkable.d.ts +21 -0
- package/lib/esm/shared/interfaces/Checkable.js +2 -0
- package/lib/esm/shared/math.d.ts +34 -0
- package/lib/esm/shared/math.js +61 -0
- package/lib/esm/shared/model/Identity.d.ts +42 -0
- package/lib/esm/shared/model/Identity.js +78 -0
- package/lib/esm/shared/model/IdentityCredentials.d.ts +41 -0
- package/lib/esm/shared/model/IdentityCredentials.js +74 -0
- package/lib/esm/shared/model/index.d.ts +1 -0
- package/lib/esm/shared/model/index.js +2 -0
- package/lib/esm/shared/model/utils.d.ts +60 -0
- package/lib/esm/shared/model/utils.js +108 -0
- package/lib/esm/shared/types.d.ts +79 -0
- package/lib/esm/shared/types.js +2 -0
- package/lib/esm/shared/utils.d.ts +55 -0
- package/lib/esm/shared/utils.js +148 -0
- package/lib/index.cjs +25 -0
- package/lib/index.d.ts +8 -0
- package/lib/shared/ClientSerializer.cjs +84 -0
- package/lib/shared/ClientSerializer.d.ts +52 -0
- package/lib/shared/DeterministicSerializer.cjs +54 -0
- package/lib/shared/DeterministicSerializer.d.ts +40 -0
- package/lib/shared/SimpleDeterministicSerializer.cjs +46 -0
- package/lib/shared/SimpleDeterministicSerializer.d.ts +7 -0
- package/lib/shared/constants.cjs +45 -0
- package/lib/shared/constants.d.ts +39 -0
- package/lib/shared/crypto.cjs +369 -0
- package/lib/shared/crypto.d.ts +107 -0
- package/lib/shared/decorators.cjs +105 -0
- package/lib/shared/decorators.d.ts +24 -0
- package/lib/shared/erc20/erc20-constants.cjs +30 -0
- package/lib/shared/erc20/erc20-constants.d.ts +25 -0
- package/lib/shared/errors.cjs +142 -0
- package/lib/shared/errors.d.ts +116 -0
- package/lib/shared/events.cjs +51 -0
- package/lib/shared/events.d.ts +39 -0
- package/lib/shared/fabric-types.cjs +4 -0
- package/lib/shared/fabric-types.d.ts +33 -0
- package/lib/shared/index.cjs +30 -0
- package/lib/shared/index.d.ts +13 -0
- package/lib/shared/interfaces/Checkable.cjs +3 -0
- package/lib/shared/interfaces/Checkable.d.ts +21 -0
- package/lib/shared/math.cjs +66 -0
- package/lib/shared/math.d.ts +34 -0
- package/lib/shared/model/Identity.cjs +81 -0
- package/lib/shared/model/Identity.d.ts +42 -0
- package/lib/shared/model/IdentityCredentials.cjs +77 -0
- package/lib/shared/model/IdentityCredentials.d.ts +41 -0
- package/lib/shared/model/index.cjs +18 -0
- package/lib/shared/model/index.d.ts +1 -0
- package/lib/shared/model/utils.cjs +114 -0
- package/lib/shared/model/utils.d.ts +60 -0
- package/lib/shared/types.cjs +3 -0
- package/lib/shared/types.d.ts +79 -0
- package/lib/shared/utils.cjs +185 -0
- package/lib/shared/utils.d.ts +55 -0
- package/package.json +166 -0
|
@@ -0,0 +1,281 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.FabricContractPrivateDataAdapter = void 0;
|
|
4
|
+
const ContractAdapter_1 = require("./ContractAdapter.cjs");
|
|
5
|
+
const db_decorators_1 = require("@decaf-ts/db-decorators");
|
|
6
|
+
const private_data_1 = require("./private-data.cjs");
|
|
7
|
+
const errors_1 = require("./../shared/errors.cjs");
|
|
8
|
+
const FabricContractSequence_1 = require("./FabricContractSequence.cjs");
|
|
9
|
+
const for_couchdb_1 = require("@decaf-ts/for-couchdb");
|
|
10
|
+
class FabricContractPrivateDataAdapter extends ContractAdapter_1.FabricContractAdapter {
|
|
11
|
+
/**
|
|
12
|
+
* @description Creates a new FabricContractAdapter instance
|
|
13
|
+
* @summary Initializes an adapter for interacting with the Fabric state database
|
|
14
|
+
* @param {void} scope - Not used in this adapter
|
|
15
|
+
* @param {string} [alias] - Optional alias for the adapter instance
|
|
16
|
+
*/
|
|
17
|
+
constructor(scope, alias, collections) {
|
|
18
|
+
super(scope, alias);
|
|
19
|
+
this.collections = collections;
|
|
20
|
+
this.collections = collections || [];
|
|
21
|
+
}
|
|
22
|
+
async Sequence(options) {
|
|
23
|
+
return new FabricContractSequence_1.FabricContractSequence(options, this, this.collections);
|
|
24
|
+
}
|
|
25
|
+
/**
|
|
26
|
+
* @description Reads a record from the state database
|
|
27
|
+
* @summary Retrieves and deserializes a record from the Fabric state database
|
|
28
|
+
* @param {string} tableName - The name of the table/collection
|
|
29
|
+
* @param {string | number} id - The record identifier
|
|
30
|
+
* @param {...any[]} args - Additional arguments, including the chaincode stub and logger
|
|
31
|
+
* @return {Promise<Record<string, any>>} Promise resolving to the retrieved record
|
|
32
|
+
*/
|
|
33
|
+
async read(tableName, id, instance, ...args) {
|
|
34
|
+
const { stub, logger } = args.pop();
|
|
35
|
+
const log = logger.for(this.read);
|
|
36
|
+
let model;
|
|
37
|
+
try {
|
|
38
|
+
const results = await this.readState(stub, tableName, id.toString(), instance);
|
|
39
|
+
if (results.length < 1) {
|
|
40
|
+
log.debug(`No record found for id ${id} in ${tableName} table`);
|
|
41
|
+
throw new db_decorators_1.NotFoundError(`No record found for id ${id} in ${tableName} table`);
|
|
42
|
+
}
|
|
43
|
+
else if (results.length < 2) {
|
|
44
|
+
log.debug(`No record found for id ${id} in ${tableName} table`);
|
|
45
|
+
model = results.pop();
|
|
46
|
+
}
|
|
47
|
+
else {
|
|
48
|
+
model = this.mergeModels(results);
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
catch (e) {
|
|
52
|
+
throw this.parseError(e);
|
|
53
|
+
}
|
|
54
|
+
return model;
|
|
55
|
+
}
|
|
56
|
+
/**
|
|
57
|
+
* @description Deletes a record from the state database
|
|
58
|
+
* @summary Retrieves a record and then removes it from the Fabric state database
|
|
59
|
+
* @param {string} tableName - The name of the table/collection
|
|
60
|
+
* @param {string | number} id - The record identifier to delete
|
|
61
|
+
* @param {...any[]} args - Additional arguments, including the chaincode stub and logger
|
|
62
|
+
* @return {Promise<Record<string, any>>} Promise resolving to the deleted record
|
|
63
|
+
*/
|
|
64
|
+
async delete(tableName, id, instance, ...args) {
|
|
65
|
+
const ctx = args.pop();
|
|
66
|
+
const { stub, logger } = ctx;
|
|
67
|
+
const log = logger.for(this.delete);
|
|
68
|
+
args.push(ctx);
|
|
69
|
+
let model;
|
|
70
|
+
try {
|
|
71
|
+
model = await this.read(tableName, id, instance, ...args);
|
|
72
|
+
log.verbose(`deleting entry with pk ${id} from ${tableName} table`);
|
|
73
|
+
this.deleteState(stub, tableName, id.toString(), instance);
|
|
74
|
+
}
|
|
75
|
+
catch (e) {
|
|
76
|
+
throw this.parseError(e);
|
|
77
|
+
}
|
|
78
|
+
return model;
|
|
79
|
+
}
|
|
80
|
+
prepare(model, pk, ...args) {
|
|
81
|
+
const { stub, logger } = args.pop();
|
|
82
|
+
const tableName = args.shift();
|
|
83
|
+
const log = logger.for(this.prepare);
|
|
84
|
+
const split = (0, private_data_1.processModel)(this, model);
|
|
85
|
+
// if ((model as any)[PersistenceKeys.METADATA]) {
|
|
86
|
+
// log.silly(
|
|
87
|
+
// `Passing along persistence metadata for ${(model as any)[PersistenceKeys.METADATA]}`
|
|
88
|
+
// );
|
|
89
|
+
// Object.defineProperty(split.result, PersistenceKeys.METADATA, {
|
|
90
|
+
// enumerable: false,
|
|
91
|
+
// writable: false,
|
|
92
|
+
// configurable: true,
|
|
93
|
+
// value: (model as any)[PersistenceKeys.METADATA],
|
|
94
|
+
// });
|
|
95
|
+
// }
|
|
96
|
+
log.info(`Preparing record for ${tableName} table with pk ${model[pk]}`);
|
|
97
|
+
return {
|
|
98
|
+
record: split.privateData,
|
|
99
|
+
id: stub.createCompositeKey(tableName, [String(model[pk])]),
|
|
100
|
+
transient: split.transient,
|
|
101
|
+
};
|
|
102
|
+
}
|
|
103
|
+
updatePrefix(tableName, id, model, ...args) {
|
|
104
|
+
const ctx = args.pop();
|
|
105
|
+
const collections = Object.keys(model);
|
|
106
|
+
for (const collection of collections) {
|
|
107
|
+
model[collection][for_couchdb_1.CouchDBKeys.TABLE] = tableName;
|
|
108
|
+
}
|
|
109
|
+
const record = model;
|
|
110
|
+
return [tableName, id, record, ctx];
|
|
111
|
+
}
|
|
112
|
+
async putState(stub, id, model,
|
|
113
|
+
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
|
114
|
+
...args) {
|
|
115
|
+
const collections = Object.keys(model);
|
|
116
|
+
let res = {};
|
|
117
|
+
let data;
|
|
118
|
+
for (const collection of collections) {
|
|
119
|
+
res = model[collection];
|
|
120
|
+
try {
|
|
121
|
+
data = Buffer.from(ContractAdapter_1.FabricContractAdapter.serializer.serialize(model[collection]));
|
|
122
|
+
}
|
|
123
|
+
catch (e) {
|
|
124
|
+
throw new db_decorators_1.SerializationError(`Failed to serialize record with id ${id}: ${e}`);
|
|
125
|
+
}
|
|
126
|
+
await stub.putPrivateData(collection, id.toString(), data);
|
|
127
|
+
}
|
|
128
|
+
return res;
|
|
129
|
+
}
|
|
130
|
+
async readState(stub, tableName, id, instance,
|
|
131
|
+
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
|
132
|
+
...args) {
|
|
133
|
+
const composedKey = stub.createCompositeKey(tableName, [String(id)]);
|
|
134
|
+
const model = (0, private_data_1.modelToPrivate)(instance);
|
|
135
|
+
const collections = Object.keys(model.private);
|
|
136
|
+
const results = [];
|
|
137
|
+
for (const collection of collections) {
|
|
138
|
+
try {
|
|
139
|
+
let res = await stub.getPrivateData(collection, composedKey);
|
|
140
|
+
if (res.toString() === "") {
|
|
141
|
+
throw new db_decorators_1.NotFoundError(`Entry with id ${id} doesn't exist...`);
|
|
142
|
+
}
|
|
143
|
+
try {
|
|
144
|
+
res = ContractAdapter_1.FabricContractAdapter.serializer.deserialize(res.toString()
|
|
145
|
+
// model.constructor.name
|
|
146
|
+
);
|
|
147
|
+
}
|
|
148
|
+
catch (e) {
|
|
149
|
+
throw new db_decorators_1.SerializationError(`Failed to parse private data: ${e}`);
|
|
150
|
+
}
|
|
151
|
+
results.push(res);
|
|
152
|
+
}
|
|
153
|
+
catch (e) {
|
|
154
|
+
if (private_data_1.MISSING_PRIVATE_DATA_REGEX.test(e.message))
|
|
155
|
+
throw new errors_1.UnauthorizedPrivateDataAccess(e);
|
|
156
|
+
throw e;
|
|
157
|
+
}
|
|
158
|
+
}
|
|
159
|
+
return results;
|
|
160
|
+
}
|
|
161
|
+
async deleteState(stub, tableName, id, instance,
|
|
162
|
+
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
|
163
|
+
...args) {
|
|
164
|
+
const composedKey = stub.createCompositeKey(tableName, [String(id)]);
|
|
165
|
+
const model = (0, private_data_1.modelToPrivate)(instance);
|
|
166
|
+
const collections = Object.keys(model.private);
|
|
167
|
+
for (const collection of collections) {
|
|
168
|
+
await stub.deletePrivateData(collection, composedKey);
|
|
169
|
+
}
|
|
170
|
+
}
|
|
171
|
+
async queryResult(stub, rawInput, instance) {
|
|
172
|
+
const privateData = (0, private_data_1.modelToPrivate)(instance).private;
|
|
173
|
+
const collection = Object.keys(privateData)[0] || "";
|
|
174
|
+
const result = (await stub.getPrivateDataQueryResult(collection, JSON.stringify(rawInput)));
|
|
175
|
+
const iterator = result.iterator;
|
|
176
|
+
return iterator;
|
|
177
|
+
}
|
|
178
|
+
async queryResultPaginated(stub, rawInput, limit = 250, skip = undefined, instance) {
|
|
179
|
+
const privateData = (0, private_data_1.modelToPrivate)(instance).private;
|
|
180
|
+
const collection = Object.keys(privateData)[0] || "";
|
|
181
|
+
const iterator = await stub.getPrivateDataQueryResult(collection, JSON.stringify(rawInput));
|
|
182
|
+
const results = [];
|
|
183
|
+
let count = 0;
|
|
184
|
+
let reachedBookmark = skip ? false : true;
|
|
185
|
+
let lastKey = null;
|
|
186
|
+
while (true) {
|
|
187
|
+
const res = await iterator.next();
|
|
188
|
+
if (res.value && res.value.value.toString()) {
|
|
189
|
+
const recordKey = res.value.key;
|
|
190
|
+
const recordValue = res.value.value.toString("utf8");
|
|
191
|
+
// If we have a skip, skip until we reach it
|
|
192
|
+
if (!reachedBookmark) {
|
|
193
|
+
if (recordKey === skip?.toString()) {
|
|
194
|
+
reachedBookmark = true;
|
|
195
|
+
}
|
|
196
|
+
continue;
|
|
197
|
+
}
|
|
198
|
+
results.push({ Key: recordKey, Record: JSON.parse(recordValue) });
|
|
199
|
+
lastKey = recordKey;
|
|
200
|
+
count++;
|
|
201
|
+
if (count >= limit) {
|
|
202
|
+
await iterator.close();
|
|
203
|
+
return {
|
|
204
|
+
iterator: results,
|
|
205
|
+
metadata: {
|
|
206
|
+
fetchedRecordsCount: results.length,
|
|
207
|
+
bookmark: lastKey,
|
|
208
|
+
},
|
|
209
|
+
};
|
|
210
|
+
}
|
|
211
|
+
}
|
|
212
|
+
if (res.done) {
|
|
213
|
+
await iterator.close();
|
|
214
|
+
return {
|
|
215
|
+
iterator: results,
|
|
216
|
+
metadata: {
|
|
217
|
+
fetchedRecordsCount: results.length,
|
|
218
|
+
bookmark: "",
|
|
219
|
+
},
|
|
220
|
+
};
|
|
221
|
+
}
|
|
222
|
+
}
|
|
223
|
+
// return (await stub.getQueryResultWithPagination(
|
|
224
|
+
// JSON.stringify(rawInput),
|
|
225
|
+
// limit,
|
|
226
|
+
// skip?.toString()
|
|
227
|
+
// )) as StateQueryResponse<Iterators.StateQueryIterator>;
|
|
228
|
+
}
|
|
229
|
+
/**
|
|
230
|
+
* @description Executes a raw query against the state database
|
|
231
|
+
* @summary Performs a rich query using CouchDB syntax against the Fabric state database
|
|
232
|
+
* @template R - The return type
|
|
233
|
+
* @param {MangoQuery} rawInput - The Mango Query to execute
|
|
234
|
+
* @param {boolean} docsOnly - Whether to return only documents (not used in this implementation)
|
|
235
|
+
* @param {...any[]} args - Additional arguments, including the chaincode stub and logger
|
|
236
|
+
* @return {Promise<R>} Promise resolving to the query results
|
|
237
|
+
* @mermaid
|
|
238
|
+
* sequenceDiagram
|
|
239
|
+
* participant Caller
|
|
240
|
+
* participant FabricContractAdapter
|
|
241
|
+
* participant Stub
|
|
242
|
+
* participant StateDB
|
|
243
|
+
*
|
|
244
|
+
* Caller->>FabricContractAdapter: raw(rawInput, docsOnly, ctx)
|
|
245
|
+
* FabricContractAdapter->>FabricContractAdapter: Extract limit and skip
|
|
246
|
+
* alt With pagination
|
|
247
|
+
* FabricContractAdapter->>Stub: getQueryResultWithPagination(query, limit, skip)
|
|
248
|
+
* else Without pagination
|
|
249
|
+
* FabricContractAdapter->>Stub: getQueryResult(query)
|
|
250
|
+
* end
|
|
251
|
+
* Stub->>StateDB: Execute query
|
|
252
|
+
* StateDB-->>Stub: Iterator
|
|
253
|
+
* Stub-->>FabricContractAdapter: Iterator
|
|
254
|
+
* FabricContractAdapter->>FabricContractAdapter: resultIterator(log, iterator)
|
|
255
|
+
* FabricContractAdapter-->>Caller: results
|
|
256
|
+
*/
|
|
257
|
+
async raw(rawInput, docsOnly, ...args) {
|
|
258
|
+
const { stub, logger } = args.pop();
|
|
259
|
+
const log = logger.for(this.raw);
|
|
260
|
+
const { skip, limit } = rawInput;
|
|
261
|
+
const instance = args.shift();
|
|
262
|
+
let iterator;
|
|
263
|
+
if (limit || skip) {
|
|
264
|
+
delete rawInput["limit"];
|
|
265
|
+
delete rawInput["skip"];
|
|
266
|
+
log.debug(`Retrieving paginated iterator: limit: ${limit}/ skip: ${skip}`);
|
|
267
|
+
const response = (await this.queryResultPaginated(stub, rawInput, limit || 250, skip?.toString(), instance));
|
|
268
|
+
iterator = response.iterator;
|
|
269
|
+
}
|
|
270
|
+
else {
|
|
271
|
+
log.debug("Retrieving iterator");
|
|
272
|
+
iterator = (await this.queryResult(stub, rawInput, instance));
|
|
273
|
+
}
|
|
274
|
+
log.debug("Iterator acquired");
|
|
275
|
+
const results = (await this.resultIterator(log, iterator));
|
|
276
|
+
log.debug(`returning {0} results`, `${Array.isArray(results) ? results.length : 1}`);
|
|
277
|
+
return results;
|
|
278
|
+
}
|
|
279
|
+
}
|
|
280
|
+
exports.FabricContractPrivateDataAdapter = FabricContractPrivateDataAdapter;
|
|
281
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ContractPrivateDataAdapter.js","sourceRoot":"","sources":["../../src/contracts/ContractPrivateDataAdapter.ts"],"names":[],"mappings":"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","sourcesContent":["import { ChaincodeStub, Iterators, StateQueryResponse } from \"fabric-shim\";\nimport { FabricContractAdapter } from \"./ContractAdapter\";\nimport {\n  BaseError,\n  NotFoundError,\n  SerializationError,\n} from \"@decaf-ts/db-decorators\";\nimport { Model } from \"@decaf-ts/decorator-validation\";\nimport {\n  MISSING_PRIVATE_DATA_REGEX,\n  modelToPrivate,\n  processModel,\n} from \"./private-data\";\nimport { UnauthorizedPrivateDataAccess } from \"../shared/errors\";\nimport { FabricContractSequence } from \"./FabricContractSequence\";\nimport { Sequence, SequenceOptions } from \"@decaf-ts/core\";\nimport { FabricContractContext } from \"./ContractContext\";\nimport { CouchDBKeys, MangoQuery } from \"@decaf-ts/for-couchdb\";\n\nexport class FabricContractPrivateDataAdapter extends FabricContractAdapter {\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(\n    scope: void,\n    alias?: string,\n    private readonly collections?: string[]\n  ) {\n    super(scope, alias);\n    this.collections = collections || [];\n  }\n\n  override async Sequence(options: SequenceOptions): Promise<Sequence> {\n    return new FabricContractSequence(options, this, this.collections);\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    instance: any,\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(\n        stub,\n        tableName,\n        id.toString(),\n        instance\n      );\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 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  override async delete(\n    tableName: string,\n    id: string | number,\n    instance: any,\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, instance, ...args);\n      log.verbose(`deleting entry with pk ${id} from ${tableName} table`);\n      this.deleteState(stub, tableName, id.toString(), instance);\n    } catch (e: unknown) {\n      throw this.parseError(e as Error);\n    }\n\n    return model;\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 = processModel(this, model);\n    // if ((model as any)[PersistenceKeys.METADATA]) {\n    //   log.silly(\n    //     `Passing along persistence metadata for ${(model as any)[PersistenceKeys.METADATA]}`\n    //   );\n    //   Object.defineProperty(split.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: split.privateData as Record<string, any>,\n      id: stub.createCompositeKey(tableName, [String(model[pk])]),\n      transient: split.transient,\n    };\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 collections = Object.keys(model);\n\n    for (const collection of collections) {\n      model[collection][CouchDBKeys.TABLE] = tableName;\n    }\n\n    const record: Record<string, any> = model;\n\n    return [tableName, id, record, ctx];\n  }\n  override 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    const collections = Object.keys(model);\n    let res: Record<string, any> = {};\n    let data: Buffer;\n\n    for (const collection of collections) {\n      res = model![collection];\n      try {\n        data = Buffer.from(\n          FabricContractAdapter.serializer.serialize(\n            model![collection] as Model\n          )\n        );\n      } catch (e: unknown) {\n        throw new SerializationError(\n          `Failed to serialize record with id ${id}: ${e}`\n        );\n      }\n      await stub.putPrivateData(collection, id.toString(), data);\n    }\n\n    return res;\n  }\n\n  override async readState(\n    stub: ChaincodeStub,\n    tableName: string,\n    id: string,\n    instance: any,\n    // eslint-disable-next-line @typescript-eslint/no-unused-vars\n    ...args: any[]\n  ) {\n    const composedKey = stub.createCompositeKey(tableName, [String(id)]);\n    const model = modelToPrivate(instance);\n    const collections = Object.keys(model.private!);\n    const results: any[] = [];\n\n    for (const collection of collections) {\n      try {\n        let res: Buffer | Record<string, any> = await stub.getPrivateData(\n          collection,\n          composedKey\n        );\n        if (res.toString() === \"\") {\n          throw new NotFoundError(`Entry with id ${id} doesn't exist...`);\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 private data: ${e}`);\n        }\n        results.push(res);\n      } catch (e: unknown) {\n        if (MISSING_PRIVATE_DATA_REGEX.test((e as BaseError).message))\n          throw new UnauthorizedPrivateDataAccess(e as BaseError);\n        throw e;\n      }\n    }\n\n    return results;\n  }\n\n  override async deleteState(\n    stub: ChaincodeStub,\n    tableName: string,\n    id: string,\n    instance: any,\n    // eslint-disable-next-line @typescript-eslint/no-unused-vars\n    ...args: any[]\n  ) {\n    const composedKey = stub.createCompositeKey(tableName, [String(id)]);\n    const model = modelToPrivate(instance);\n    const collections = Object.keys(model.private!);\n\n    for (const collection of collections) {\n      await stub.deletePrivateData(collection, composedKey);\n    }\n  }\n\n  override async queryResult(\n    stub: ChaincodeStub,\n    rawInput: any,\n    instance: any\n  ): Promise<Iterators.StateQueryIterator> {\n    const privateData = modelToPrivate(instance).private!;\n    const collection = Object.keys(privateData)[0] || \"\";\n\n    const result = (await stub.getPrivateDataQueryResult(\n      collection,\n      JSON.stringify(rawInput)\n    )) as any;\n\n    const iterator = result.iterator as Iterators.StateQueryIterator;\n\n    return iterator;\n  }\n\n  override async queryResultPaginated(\n    stub: ChaincodeStub,\n    rawInput: any,\n    limit: number = 250,\n    skip: number | undefined = undefined,\n    instance: any\n  ): Promise<StateQueryResponse<Iterators.StateQueryIterator>> {\n    const privateData = modelToPrivate(instance).private!;\n    const collection = Object.keys(privateData)[0] || \"\";\n\n    const iterator = await stub.getPrivateDataQueryResult(\n      collection,\n      JSON.stringify(rawInput)\n    );\n\n    const results: any[] = [];\n    let count = 0;\n    let reachedBookmark = skip ? false : true;\n    let lastKey: string | null = null;\n\n    while (true) {\n      const res = await iterator.next();\n\n      if (res.value && res.value.value.toString()) {\n        const recordKey = res.value.key;\n        const recordValue = (res.value.value as any).toString(\"utf8\");\n\n        // If we have a skip, skip until we reach it\n        if (!reachedBookmark) {\n          if (recordKey === skip?.toString()) {\n            reachedBookmark = true;\n          }\n          continue;\n        }\n\n        results.push({ Key: recordKey, Record: JSON.parse(recordValue) });\n        lastKey = recordKey;\n        count++;\n\n        if (count >= limit) {\n          await iterator.close();\n          return {\n            iterator: results as unknown as Iterators.StateQueryIterator,\n            metadata: {\n              fetchedRecordsCount: results.length,\n              bookmark: lastKey,\n            },\n          };\n        }\n      }\n\n      if (res.done) {\n        await iterator.close();\n        return {\n          iterator: results as unknown as Iterators.StateQueryIterator,\n          metadata: {\n            fetchedRecordsCount: results.length,\n            bookmark: \"\",\n          },\n        };\n      }\n    }\n    // return (await stub.getQueryResultWithPagination(\n    //   JSON.stringify(rawInput),\n    //   limit,\n    //   skip?.toString()\n    // )) as StateQueryResponse<Iterators.StateQueryIterator>;\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  override 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    const instance = args.shift();\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          instance\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        instance\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"]}
|
|
@@ -0,0 +1,74 @@
|
|
|
1
|
+
import { ChaincodeStub, Iterators, StateQueryResponse } from "fabric-shim";
|
|
2
|
+
import { FabricContractAdapter } from "./ContractAdapter";
|
|
3
|
+
import { Model } from "@decaf-ts/decorator-validation";
|
|
4
|
+
import { Sequence, SequenceOptions } from "@decaf-ts/core";
|
|
5
|
+
import { MangoQuery } from "@decaf-ts/for-couchdb";
|
|
6
|
+
export declare class FabricContractPrivateDataAdapter extends FabricContractAdapter {
|
|
7
|
+
private readonly collections?;
|
|
8
|
+
/**
|
|
9
|
+
* @description Creates a new FabricContractAdapter instance
|
|
10
|
+
* @summary Initializes an adapter for interacting with the Fabric state database
|
|
11
|
+
* @param {void} scope - Not used in this adapter
|
|
12
|
+
* @param {string} [alias] - Optional alias for the adapter instance
|
|
13
|
+
*/
|
|
14
|
+
constructor(scope: void, alias?: string, collections?: string[] | undefined);
|
|
15
|
+
Sequence(options: SequenceOptions): Promise<Sequence>;
|
|
16
|
+
/**
|
|
17
|
+
* @description Reads a record from the state database
|
|
18
|
+
* @summary Retrieves and deserializes a record from the Fabric state database
|
|
19
|
+
* @param {string} tableName - The name of the table/collection
|
|
20
|
+
* @param {string | number} id - The record identifier
|
|
21
|
+
* @param {...any[]} args - Additional arguments, including the chaincode stub and logger
|
|
22
|
+
* @return {Promise<Record<string, any>>} Promise resolving to the retrieved record
|
|
23
|
+
*/
|
|
24
|
+
read(tableName: string, id: string | number, instance: any, ...args: any[]): Promise<Record<string, any>>;
|
|
25
|
+
/**
|
|
26
|
+
* @description Deletes a record from the state database
|
|
27
|
+
* @summary Retrieves a record and then removes it from the Fabric state database
|
|
28
|
+
* @param {string} tableName - The name of the table/collection
|
|
29
|
+
* @param {string | number} id - The record identifier to delete
|
|
30
|
+
* @param {...any[]} args - Additional arguments, including the chaincode stub and logger
|
|
31
|
+
* @return {Promise<Record<string, any>>} Promise resolving to the deleted record
|
|
32
|
+
*/
|
|
33
|
+
delete(tableName: string, id: string | number, instance: any, ...args: any[]): Promise<Record<string, any>>;
|
|
34
|
+
prepare<M extends Model>(model: M, pk: keyof M, ...args: any[]): {
|
|
35
|
+
record: Record<string, any>;
|
|
36
|
+
id: string;
|
|
37
|
+
transient?: Record<string, any>;
|
|
38
|
+
};
|
|
39
|
+
updatePrefix(tableName: string, id: string | number, model: Record<string, any>, ...args: any[]): (string | number | Record<string, any>)[];
|
|
40
|
+
putState(stub: ChaincodeStub, id: string, model: Record<string, any>, ...args: any[]): Promise<Record<string, any>>;
|
|
41
|
+
readState(stub: ChaincodeStub, tableName: string, id: string, instance: any, ...args: any[]): Promise<any[]>;
|
|
42
|
+
deleteState(stub: ChaincodeStub, tableName: string, id: string, instance: any, ...args: any[]): Promise<void>;
|
|
43
|
+
queryResult(stub: ChaincodeStub, rawInput: any, instance: any): Promise<Iterators.StateQueryIterator>;
|
|
44
|
+
queryResultPaginated(stub: ChaincodeStub, rawInput: any, limit: number | undefined, skip: number | undefined, instance: any): Promise<StateQueryResponse<Iterators.StateQueryIterator>>;
|
|
45
|
+
/**
|
|
46
|
+
* @description Executes a raw query against the state database
|
|
47
|
+
* @summary Performs a rich query using CouchDB syntax against the Fabric state database
|
|
48
|
+
* @template R - The return type
|
|
49
|
+
* @param {MangoQuery} rawInput - The Mango Query to execute
|
|
50
|
+
* @param {boolean} docsOnly - Whether to return only documents (not used in this implementation)
|
|
51
|
+
* @param {...any[]} args - Additional arguments, including the chaincode stub and logger
|
|
52
|
+
* @return {Promise<R>} Promise resolving to the query results
|
|
53
|
+
* @mermaid
|
|
54
|
+
* sequenceDiagram
|
|
55
|
+
* participant Caller
|
|
56
|
+
* participant FabricContractAdapter
|
|
57
|
+
* participant Stub
|
|
58
|
+
* participant StateDB
|
|
59
|
+
*
|
|
60
|
+
* Caller->>FabricContractAdapter: raw(rawInput, docsOnly, ctx)
|
|
61
|
+
* FabricContractAdapter->>FabricContractAdapter: Extract limit and skip
|
|
62
|
+
* alt With pagination
|
|
63
|
+
* FabricContractAdapter->>Stub: getQueryResultWithPagination(query, limit, skip)
|
|
64
|
+
* else Without pagination
|
|
65
|
+
* FabricContractAdapter->>Stub: getQueryResult(query)
|
|
66
|
+
* end
|
|
67
|
+
* Stub->>StateDB: Execute query
|
|
68
|
+
* StateDB-->>Stub: Iterator
|
|
69
|
+
* Stub-->>FabricContractAdapter: Iterator
|
|
70
|
+
* FabricContractAdapter->>FabricContractAdapter: resultIterator(log, iterator)
|
|
71
|
+
* FabricContractAdapter-->>Caller: results
|
|
72
|
+
*/
|
|
73
|
+
raw<R>(rawInput: MangoQuery, docsOnly: boolean, ...args: any[]): Promise<R>;
|
|
74
|
+
}
|