@cardano-sdk/util-dev 0.1.8 → 0.2.0
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/dist/assetId.d.ts +5 -4
- package/dist/assetId.d.ts.map +1 -1
- package/dist/assetId.js +4 -3
- package/dist/assetId.js.map +1 -1
- package/dist/createStubStakePoolSearchProvider.js +5 -4
- package/dist/createStubStakePoolSearchProvider.js.map +1 -1
- package/dist/index.d.ts +1 -0
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +2 -1
- package/dist/index.js.map +1 -1
- package/dist/selectionConstraints.d.ts.map +1 -1
- package/dist/selectionConstraints.js +1 -1
- package/dist/selectionConstraints.js.map +1 -1
- package/dist/txTestUtil.d.ts +9 -0
- package/dist/txTestUtil.d.ts.map +1 -0
- package/dist/txTestUtil.js +13 -0
- package/dist/txTestUtil.js.map +1 -0
- package/package.json +3 -3
package/dist/assetId.d.ts
CHANGED
|
@@ -1,5 +1,6 @@
|
|
|
1
|
-
|
|
2
|
-
export declare const
|
|
3
|
-
export declare const
|
|
4
|
-
export declare const
|
|
1
|
+
import { Cardano } from '@cardano-sdk/core';
|
|
2
|
+
export declare const TSLA: Cardano.AssetId;
|
|
3
|
+
export declare const PXL: Cardano.AssetId;
|
|
4
|
+
export declare const Unit: Cardano.AssetId;
|
|
5
|
+
export declare const All: Cardano.AssetId[];
|
|
5
6
|
//# sourceMappingURL=assetId.d.ts.map
|
package/dist/assetId.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"assetId.d.ts","sourceRoot":"","sources":["../src/assetId.ts"],"names":[],"mappings":"AAAA,eAAO,MAAM,IAAI,
|
|
1
|
+
{"version":3,"file":"assetId.d.ts","sourceRoot":"","sources":["../src/assetId.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,mBAAmB,CAAC;AAE5C,eAAO,MAAM,IAAI,iBAAsF,CAAC;AACxG,eAAO,MAAM,GAAG,iBAAoF,CAAC;AACrG,eAAO,MAAM,IAAI,iBAAsF,CAAC;AAExG,eAAO,MAAM,GAAG,mBAAoB,CAAC"}
|
package/dist/assetId.js
CHANGED
|
@@ -1,8 +1,9 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.All = exports.Unit = exports.PXL = exports.TSLA = void 0;
|
|
4
|
-
|
|
5
|
-
exports.
|
|
6
|
-
exports.
|
|
4
|
+
const core_1 = require("@cardano-sdk/core");
|
|
5
|
+
exports.TSLA = core_1.Cardano.AssetId('659f2917fb63f12b33667463ee575eeac1845bbc736b9c0bbc40ba8254534c41');
|
|
6
|
+
exports.PXL = core_1.Cardano.AssetId('1ec85dcee27f2d90ec1f9a1e4ce74a667dc9be8b184463223f9c960150584c');
|
|
7
|
+
exports.Unit = core_1.Cardano.AssetId('a5425bd7bc4182325188af2340415827a73f845846c165d9e14c5aed556e6974');
|
|
7
8
|
exports.All = [exports.TSLA, exports.PXL, exports.Unit];
|
|
8
9
|
//# sourceMappingURL=assetId.js.map
|
package/dist/assetId.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"assetId.js","sourceRoot":"","sources":["../src/assetId.ts"],"names":[],"mappings":";;;
|
|
1
|
+
{"version":3,"file":"assetId.js","sourceRoot":"","sources":["../src/assetId.ts"],"names":[],"mappings":";;;AAAA,4CAA4C;AAE/B,QAAA,IAAI,GAAG,cAAO,CAAC,OAAO,CAAC,kEAAkE,CAAC,CAAC;AAC3F,QAAA,GAAG,GAAG,cAAO,CAAC,OAAO,CAAC,gEAAgE,CAAC,CAAC;AACxF,QAAA,IAAI,GAAG,cAAO,CAAC,OAAO,CAAC,kEAAkE,CAAC,CAAC;AAE3F,QAAA,GAAG,GAAG,CAAC,YAAI,EAAE,WAAG,EAAE,YAAI,CAAC,CAAC"}
|
|
@@ -4,11 +4,12 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
|
4
4
|
};
|
|
5
5
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
6
|
exports.createStubStakePoolSearchProvider = exports.somePartialStakePools = void 0;
|
|
7
|
+
const core_1 = require("@cardano-sdk/core");
|
|
7
8
|
const delay_1 = __importDefault(require("delay"));
|
|
8
9
|
exports.somePartialStakePools = [
|
|
9
10
|
{
|
|
10
|
-
hexId: 'cf12a9dcaacdc09778616d60502011a88ed4542c482f2ddd08d8ac5a',
|
|
11
|
-
id: 'pool1euf2nh92ehqfw7rpd4s9qgq34z8dg4pvfqhjmhggmzk95gcd402',
|
|
11
|
+
hexId: core_1.Cardano.PoolIdHex('cf12a9dcaacdc09778616d60502011a88ed4542c482f2ddd08d8ac5a'),
|
|
12
|
+
id: core_1.Cardano.PoolId('pool1euf2nh92ehqfw7rpd4s9qgq34z8dg4pvfqhjmhggmzk95gcd402'),
|
|
12
13
|
metadata: {
|
|
13
14
|
description: 'Keiths Pi test pool',
|
|
14
15
|
homepage: '',
|
|
@@ -17,8 +18,8 @@ exports.somePartialStakePools = [
|
|
|
17
18
|
}
|
|
18
19
|
},
|
|
19
20
|
{
|
|
20
|
-
hexId: '4a2e3b7f4a78ff1452b91329a7673c77c98ca96dece7b55c37869502',
|
|
21
|
-
id: 'pool1fghrkl620rl3g54ezv56weeuwlyce2tdannm2hphs62syf3vyyh',
|
|
21
|
+
hexId: core_1.Cardano.PoolIdHex('4a2e3b7f4a78ff1452b91329a7673c77c98ca96dece7b55c37869502'),
|
|
22
|
+
id: core_1.Cardano.PoolId('pool1fghrkl620rl3g54ezv56weeuwlyce2tdannm2hphs62syf3vyyh'),
|
|
22
23
|
metadata: {
|
|
23
24
|
description: 'VEGAS TestNet(2) ADA Pool',
|
|
24
25
|
homepage: 'https://www.ada.vegas',
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"createStubStakePoolSearchProvider.js","sourceRoot":"","sources":["../src/createStubStakePoolSearchProvider.ts"],"names":[],"mappings":";;;;;;
|
|
1
|
+
{"version":3,"file":"createStubStakePoolSearchProvider.js","sourceRoot":"","sources":["../src/createStubStakePoolSearchProvider.ts"],"names":[],"mappings":";;;;;;AAAA,4CAAqE;AACrE,kDAA0B;AAEb,QAAA,qBAAqB,GAAwB;IACxD;QACE,KAAK,EAAE,cAAO,CAAC,SAAS,CAAC,0DAA0D,CAAC;QACpF,EAAE,EAAE,cAAO,CAAC,MAAM,CAAC,0DAA0D,CAAC;QAC9E,QAAQ,EAAE;YACR,WAAW,EAAE,qBAAqB;YAClC,QAAQ,EAAE,EAAE;YACZ,IAAI,EAAE,eAAe;YACrB,MAAM,EAAE,MAAM;SACf;KACF;IACD;QACE,KAAK,EAAE,cAAO,CAAC,SAAS,CAAC,0DAA0D,CAAC;QACpF,EAAE,EAAE,cAAO,CAAC,MAAM,CAAC,0DAA0D,CAAC;QAC9E,QAAQ,EAAE;YACR,WAAW,EAAE,2BAA2B;YACxC,QAAQ,EAAE,uBAAuB;YACjC,IAAI,EAAE,WAAW;YACjB,MAAM,EAAE,OAAO;SAChB;KACF;CACqB,CAAC;AAKlB,MAAM,iCAAiC,GAAG,CAC/C,aAAkC,6BAAqB,EACvD,OAAgB,EACS,EAAE,CAAC,CAAC;IAC7B,eAAe,EAAE,KAAK,EAAE,SAAS,EAAE,EAAE;QACnC,IAAI,OAAO;YAAE,MAAM,eAAK,CAAC,OAAO,CAAC,CAAC;QAClC,OAAO,UAAU,CAAC,MAAM,CAAC,CAAC,EAAE,EAAE,EAAE,QAAQ,EAAE,EAAE,EAAE,CAC5C,SAAS,CAAC,IAAI,CACZ,CAAC,QAAQ,EAAE,EAAE,CAAC,EAAE,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,QAAQ,EAAE,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,QAAQ,EAAE,MAAM,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAChH,CACF,CAAC;IACJ,CAAC;CACF,CAAC,CAAC;AAZU,QAAA,iCAAiC,qCAY3C"}
|
package/dist/index.d.ts
CHANGED
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
export * as AssetId from './assetId';
|
|
2
2
|
export * as CslTestUtil from './cslTestUtil';
|
|
3
|
+
export * as TxTestUtil from './txTestUtil';
|
|
3
4
|
export * as SelectionConstraints from './selectionConstraints';
|
|
4
5
|
export * from './util';
|
|
5
6
|
export * from './createStubStakePoolSearchProvider';
|
package/dist/index.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,OAAO,MAAM,WAAW,CAAC;AACrC,OAAO,KAAK,WAAW,MAAM,eAAe,CAAC;AAC7C,OAAO,KAAK,oBAAoB,MAAM,wBAAwB,CAAC;AAC/D,cAAc,QAAQ,CAAC;AACvB,cAAc,qCAAqC,CAAC"}
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,OAAO,MAAM,WAAW,CAAC;AACrC,OAAO,KAAK,WAAW,MAAM,eAAe,CAAC;AAC7C,OAAO,KAAK,UAAU,MAAM,cAAc,CAAC;AAC3C,OAAO,KAAK,oBAAoB,MAAM,wBAAwB,CAAC;AAC/D,cAAc,QAAQ,CAAC;AACvB,cAAc,qCAAqC,CAAC"}
|
package/dist/index.js
CHANGED
|
@@ -22,9 +22,10 @@ var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
|
22
22
|
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
23
23
|
};
|
|
24
24
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
25
|
-
exports.SelectionConstraints = exports.CslTestUtil = exports.AssetId = void 0;
|
|
25
|
+
exports.SelectionConstraints = exports.TxTestUtil = exports.CslTestUtil = exports.AssetId = void 0;
|
|
26
26
|
exports.AssetId = __importStar(require("./assetId"));
|
|
27
27
|
exports.CslTestUtil = __importStar(require("./cslTestUtil"));
|
|
28
|
+
exports.TxTestUtil = __importStar(require("./txTestUtil"));
|
|
28
29
|
exports.SelectionConstraints = __importStar(require("./selectionConstraints"));
|
|
29
30
|
__exportStar(require("./util"), exports);
|
|
30
31
|
__exportStar(require("./createStubStakePoolSearchProvider"), exports);
|
package/dist/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;AAAA,qDAAqC;AACrC,6DAA6C;AAC7C,+EAA+D;AAC/D,yCAAuB;AACvB,sEAAoD"}
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;AAAA,qDAAqC;AACrC,6DAA6C;AAC7C,2DAA2C;AAC3C,+EAA+D;AAC/D,yCAAuB;AACvB,sEAAoD"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"selectionConstraints.d.ts","sourceRoot":"","sources":["../src/selectionConstraints.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,oBAAoB,EAAE,MAAM,mBAAmB,CAAC;AAEzD,MAAM,WAAW,wBAAwB;IACvC,mBAAmB,EAAE,MAAM,CAAC;IAC5B,WAAW,EAAE,MAAM,CAAC;IACpB,kBAAkB,EAAE,MAAM,CAAC;IAC3B,cAAc,EAAE,MAAM,CAAC;CACxB;AAED,eAAO,MAAM,mBAAmB,EAAE,wBAKjC,CAAC;AAEF,eAAO,MAAM,4BAA4B,gBAAiB,wBAAwB,KAAG,
|
|
1
|
+
{"version":3,"file":"selectionConstraints.d.ts","sourceRoot":"","sources":["../src/selectionConstraints.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,oBAAoB,EAAE,MAAM,mBAAmB,CAAC;AAEzD,MAAM,WAAW,wBAAwB;IACvC,mBAAmB,EAAE,MAAM,CAAC;IAC5B,WAAW,EAAE,MAAM,CAAC;IACpB,kBAAkB,EAAE,MAAM,CAAC;IAC3B,cAAc,EAAE,MAAM,CAAC;CACxB;AAED,eAAO,MAAM,mBAAmB,EAAE,wBAKjC,CAAC;AAEF,eAAO,MAAM,4BAA4B,gBAAiB,wBAAwB,KAAG,oBAKnF,CAAC;AAEH,eAAO,MAAM,cAAc,sBAAoD,CAAC"}
|
|
@@ -11,7 +11,7 @@ const mockConstraintsToConstraints = (constraints) => ({
|
|
|
11
11
|
computeMinimumCoinQuantity: () => constraints.minimumCoinQuantity,
|
|
12
12
|
computeMinimumCost: async () => constraints.minimumCost,
|
|
13
13
|
computeSelectionLimit: async () => constraints.selectionLimit,
|
|
14
|
-
tokenBundleSizeExceedsLimit: (
|
|
14
|
+
tokenBundleSizeExceedsLimit: (assets) => (assets?.size || 0) > constraints.maxTokenBundleSize
|
|
15
15
|
});
|
|
16
16
|
exports.mockConstraintsToConstraints = mockConstraintsToConstraints;
|
|
17
17
|
exports.NO_CONSTRAINTS = exports.mockConstraintsToConstraints(exports.MOCK_NO_CONSTRAINTS);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"selectionConstraints.js","sourceRoot":"","sources":["../src/selectionConstraints.ts"],"names":[],"mappings":";;;AAUa,QAAA,mBAAmB,GAA6B;IAC3D,kBAAkB,EAAE,MAAM,CAAC,iBAAiB;IAC5C,mBAAmB,EAAE,EAAE;IACvB,WAAW,EAAE,EAAE;IACf,cAAc,EAAE,MAAM,CAAC,iBAAiB;CACzC,CAAC;AAEK,MAAM,4BAA4B,GAAG,CAAC,WAAqC,EAAwB,EAAE,CAAC,CAAC;IAC5G,0BAA0B,EAAE,GAAG,EAAE,CAAC,WAAW,CAAC,mBAAmB;IACjE,kBAAkB,EAAE,KAAK,IAAI,EAAE,CAAC,WAAW,CAAC,WAAW;IACvD,qBAAqB,EAAE,KAAK,IAAI,EAAE,CAAC,WAAW,CAAC,cAAc;IAC7D,2BAA2B,EAAE,CAAC,
|
|
1
|
+
{"version":3,"file":"selectionConstraints.js","sourceRoot":"","sources":["../src/selectionConstraints.ts"],"names":[],"mappings":";;;AAUa,QAAA,mBAAmB,GAA6B;IAC3D,kBAAkB,EAAE,MAAM,CAAC,iBAAiB;IAC5C,mBAAmB,EAAE,EAAE;IACvB,WAAW,EAAE,EAAE;IACf,cAAc,EAAE,MAAM,CAAC,iBAAiB;CACzC,CAAC;AAEK,MAAM,4BAA4B,GAAG,CAAC,WAAqC,EAAwB,EAAE,CAAC,CAAC;IAC5G,0BAA0B,EAAE,GAAG,EAAE,CAAC,WAAW,CAAC,mBAAmB;IACjE,kBAAkB,EAAE,KAAK,IAAI,EAAE,CAAC,WAAW,CAAC,WAAW;IACvD,qBAAqB,EAAE,KAAK,IAAI,EAAE,CAAC,WAAW,CAAC,cAAc;IAC7D,2BAA2B,EAAE,CAAC,MAAyB,EAAE,EAAE,CAAC,CAAC,MAAM,EAAE,IAAI,IAAI,CAAC,CAAC,GAAG,WAAW,CAAC,kBAAkB;CACjH,CAAC,CAAC;AALU,QAAA,4BAA4B,gCAKtC;AAEU,QAAA,cAAc,GAAG,oCAA4B,CAAC,2BAAmB,CAAC,CAAC"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { Cardano } from '@cardano-sdk/core';
|
|
2
|
+
export declare const createTxInput: (txId?: Cardano.TransactionId, address?: Cardano.Address, index?: number) => {
|
|
3
|
+
address: Cardano.Address;
|
|
4
|
+
index: number;
|
|
5
|
+
txId: Cardano.TransactionId;
|
|
6
|
+
};
|
|
7
|
+
export declare const createUnspentTxOutput: (value: Cardano.Value, address?: Cardano.Address) => Cardano.Utxo;
|
|
8
|
+
export declare const createOutput: (value: Cardano.Value, address?: Cardano.Address) => Cardano.TxOut;
|
|
9
|
+
//# sourceMappingURL=txTestUtil.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"txTestUtil.d.ts","sourceRoot":"","sources":["../src/txTestUtil.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,mBAAmB,CAAC;AAE5C,eAAO,MAAM,aAAa;;;;CAOtB,CAAC;AAEL,eAAO,MAAM,qBAAqB,UACzB,QAAQ,KAAK,4CAEkC,CAAC;AAEzD,eAAO,MAAM,YAAY,UAChB,QAAQ,KAAK,gCAEnB,QAAQ,KAA6B,CAAC"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.createOutput = exports.createUnspentTxOutput = exports.createTxInput = void 0;
|
|
4
|
+
const core_1 = require("@cardano-sdk/core");
|
|
5
|
+
exports.createTxInput = (() => {
|
|
6
|
+
let defaultIndex = 0;
|
|
7
|
+
return (txId = core_1.Cardano.TransactionId('6804edf9712d2b619edb6ac86861fe93a730693183a262b165fcc1ba1bc99cad'), address = core_1.Cardano.Address('addr1vy36kffjf87vzkuyqc5g0ys3fe3pez5zvqg9r5z9q9kfrkg2cs093'), index = defaultIndex++) => ({ address, index, txId });
|
|
8
|
+
})();
|
|
9
|
+
const createUnspentTxOutput = (value, address = core_1.Cardano.Address('addr1vy36kffjf87vzkuyqc5g0ys3fe3pez5zvqg9r5z9q9kfrkg2cs093')) => [exports.createTxInput(), { address, value }];
|
|
10
|
+
exports.createUnspentTxOutput = createUnspentTxOutput;
|
|
11
|
+
const createOutput = (value, address = core_1.Cardano.Address('addr1vyeljkh3vr4h9s3lyxe7g2meushk3m4nwyzdgtlg96e6mrgg8fnle')) => ({ address, value });
|
|
12
|
+
exports.createOutput = createOutput;
|
|
13
|
+
//# sourceMappingURL=txTestUtil.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"txTestUtil.js","sourceRoot":"","sources":["../src/txTestUtil.ts"],"names":[],"mappings":";;;AAAA,4CAA4C;AAE/B,QAAA,aAAa,GAAG,CAAC,GAAG,EAAE;IACjC,IAAI,YAAY,GAAG,CAAC,CAAC;IACrB,OAAO,CACL,IAAI,GAAG,cAAO,CAAC,aAAa,CAAC,kEAAkE,CAAC,EAChG,OAAO,GAAG,cAAO,CAAC,OAAO,CAAC,4DAA4D,CAAC,EACvF,KAAK,GAAG,YAAY,EAAE,EACtB,EAAE,CAAC,CAAC,EAAE,OAAO,EAAE,KAAK,EAAE,IAAI,EAAE,CAAC,CAAC;AAClC,CAAC,CAAC,EAAE,CAAC;AAEE,MAAM,qBAAqB,GAAG,CACnC,KAAoB,EACpB,OAAO,GAAG,cAAO,CAAC,OAAO,CAAC,4DAA4D,CAAC,EACzE,EAAE,CAAC,CAAC,qBAAa,EAAE,EAAE,EAAE,OAAO,EAAE,KAAK,EAAE,CAAC,CAAC;AAH5C,QAAA,qBAAqB,yBAGuB;AAElD,MAAM,YAAY,GAAG,CAC1B,KAAoB,EACpB,OAAO,GAAG,cAAO,CAAC,OAAO,CAAC,4DAA4D,CAAC,EACxE,EAAE,CAAC,CAAC,EAAE,OAAO,EAAE,KAAK,EAAE,CAAC,CAAC;AAH5B,QAAA,YAAY,gBAGgB"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@cardano-sdk/util-dev",
|
|
3
|
-
"version": "0.
|
|
3
|
+
"version": "0.2.0",
|
|
4
4
|
"description": "Utilities for tests in other packages",
|
|
5
5
|
"engines": {
|
|
6
6
|
"node": "^14"
|
|
@@ -22,10 +22,10 @@
|
|
|
22
22
|
"test:debug": "DEBUG=true yarn test"
|
|
23
23
|
},
|
|
24
24
|
"devDependencies": {
|
|
25
|
-
"@cardano-sdk/cip2": " 0.
|
|
25
|
+
"@cardano-sdk/cip2": " 0.2.0"
|
|
26
26
|
},
|
|
27
27
|
"dependencies": {
|
|
28
|
-
"@cardano-sdk/core": " 0.
|
|
28
|
+
"@cardano-sdk/core": " 0.2.0",
|
|
29
29
|
"delay": "^5.0.0"
|
|
30
30
|
},
|
|
31
31
|
"files": [
|