@rosen-bridge/minimum-fee 0.1.13 → 1.0.0-1ad09374

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/README.md ADDED
@@ -0,0 +1,28 @@
1
+ # @rosen-bridge/minimum-fee
2
+
3
+ ## Table of contents
4
+
5
+ - [Introduction](#introduction)
6
+ - [Installation](#installation)
7
+
8
+ ## Introduction
9
+
10
+ `@rosen-bridge/minimum-fee` Typescript package to build and get minimum fee of the bridge for supported tokens from blockchain
11
+
12
+ ## Installation
13
+
14
+ npm:
15
+
16
+ ```sh
17
+ npm i @rosen-bridge/minimum-fee
18
+ ```
19
+
20
+ yarn:
21
+
22
+ ```sh
23
+ yarn add @rosen-bridge/minimum-fee
24
+ ```
25
+
26
+ #### Examples
27
+
28
+ **TODO**
@@ -0,0 +1,55 @@
1
+ import { ErgoBox } from 'ergo-lib-wasm-nodejs';
2
+ import { ChainMinimumFee, ErgoNetworkType, Fee } from './types';
3
+ import ergoExplorerClientFactory from '@rosen-clients/ergo-explorer';
4
+ import ergoNodeClientFactory from '@rosen-clients/ergo-node';
5
+ import { AbstractLogger } from '@rosen-bridge/logger-interface';
6
+ import { MinimumFeeBoxBuilder } from './MinimumFeeBoxBuilder';
7
+ export declare class MinimumFeeBox {
8
+ protected readonly BOX_FETCHING_PAGE_SIZE = 50;
9
+ protected logger: AbstractLogger;
10
+ protected box: ErgoBox;
11
+ protected tokenId: string;
12
+ protected minimumFeeNFT: string;
13
+ protected address: string;
14
+ protected explorerClient: ReturnType<typeof ergoExplorerClientFactory>;
15
+ protected nodeClient: ReturnType<typeof ergoNodeClientFactory>;
16
+ constructor(tokenId: string, minimumFeeNFT: string, address: string, networkType: ErgoNetworkType, networkUrl: string, logger?: AbstractLogger);
17
+ /**
18
+ * fetches the box from the blockchain
19
+ */
20
+ fetchBox: () => Promise<void>;
21
+ /**
22
+ * returns fetched box or throws approprite error if found more or none
23
+ * @param eligibleBoxes
24
+ */
25
+ protected selectEligibleBox: (eligibleBoxes: Array<ErgoBox>) => ErgoBox;
26
+ /**
27
+ * fetches box from the blockchain using explorer client
28
+ */
29
+ protected fetchBoxUsingExplorer: () => Promise<ErgoBox>;
30
+ /**
31
+ * fetches the box from the blockchain using node client
32
+ */
33
+ protected fetchBoxUsingNode: () => Promise<ErgoBox>;
34
+ /**
35
+ * returns fetched config box
36
+ */
37
+ getBox: () => ErgoBox;
38
+ /**
39
+ * gets corresponding config for two chains and height
40
+ * @param fromChain
41
+ * @param height blockchain height for fromChain
42
+ * @param toChain
43
+ */
44
+ getFee: (fromChain: string, height: number, toChain: string) => ChainMinimumFee;
45
+ /**
46
+ * extracts Fee config from box registers
47
+ */
48
+ protected extractFeeFromBox: () => Array<Fee>;
49
+ /**
50
+ * generates a MinimumFeeBoxBuilder using current box
51
+ * note that 'height' parameter of builder won't be set
52
+ */
53
+ toBuilder: () => MinimumFeeBoxBuilder;
54
+ }
55
+ //# sourceMappingURL=MinimumFeeBox.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"MinimumFeeBox.d.ts","sourceRoot":"","sources":["../../lib/MinimumFeeBox.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,sBAAsB,CAAC;AAC/C,OAAO,EAAE,eAAe,EAAE,eAAe,EAAE,GAAG,EAAE,MAAM,SAAS,CAAC;AAEhE,OAAO,yBAAyB,MAAM,8BAA8B,CAAC;AACrE,OAAO,qBAEN,MAAM,0BAA0B,CAAC;AAGlC,OAAO,EAAE,cAAc,EAAe,MAAM,gCAAgC,CAAC;AAC7E,OAAO,EAAE,oBAAoB,EAAE,MAAM,wBAAwB,CAAC;AAK9D,qBAAa,aAAa;IACxB,SAAS,CAAC,QAAQ,CAAC,sBAAsB,MAAM;IAC/C,SAAS,CAAC,MAAM,EAAE,cAAc,CAAC;IACjC,SAAS,CAAC,GAAG,EAAE,OAAO,CAAC;IACvB,SAAS,CAAC,OAAO,EAAE,MAAM,CAAC;IAC1B,SAAS,CAAC,aAAa,EAAE,MAAM,CAAC;IAChC,SAAS,CAAC,OAAO,EAAE,MAAM,CAAC;IAC1B,SAAS,CAAC,cAAc,EAAE,UAAU,CAAC,OAAO,yBAAyB,CAAC,CAAC;IACvE,SAAS,CAAC,UAAU,EAAE,UAAU,CAAC,OAAO,qBAAqB,CAAC,CAAC;gBAG7D,OAAO,EAAE,MAAM,EACf,aAAa,EAAE,MAAM,EACrB,OAAO,EAAE,MAAM,EACf,WAAW,EAAE,eAAe,EAC5B,UAAU,EAAE,MAAM,EAClB,MAAM,CAAC,EAAE,cAAc;IAWzB;;OAEG;IACH,QAAQ,QAAa,QAAQ,IAAI,CAAC,CAGhC;IAEF;;;OAGG;IACH,SAAS,CAAC,iBAAiB,kBAAmB,MAAM,OAAO,CAAC,KAAG,OAAO,CAyBpE;IAEF;;OAEG;IACH,SAAS,CAAC,qBAAqB,QAAa,QAAQ,OAAO,CAAC,CA+C1D;IAEF;;OAEG;IACH,SAAS,CAAC,iBAAiB,QAAa,QAAQ,OAAO,CAAC,CAyDtD;IAEF;;OAEG;IACH,MAAM,QAAO,OAAO,CAAa;IAEjC;;;;;OAKG;IACH,MAAM,cACO,MAAM,UACT,MAAM,WACL,MAAM,KACd,eAAe,CA4BhB;IAEF;;OAEG;IACH,SAAS,CAAC,iBAAiB,QAAO,MAAM,GAAG,CAAC,CAuD1C;IAEF;;;OAGG;IACH,SAAS,QAAO,oBAAoB,CAmBlC;CACH"}
@@ -0,0 +1,231 @@
1
+ import { ErgoBox } from 'ergo-lib-wasm-nodejs';
2
+ import { ChainMinimumFee, ErgoNetworkType } from './types';
3
+ import { FailedError, NotFoundError } from './errors';
4
+ import ergoExplorerClientFactory from '@rosen-clients/ergo-explorer';
5
+ import ergoNodeClientFactory from '@rosen-clients/ergo-node';
6
+ import JsonBigInt from '@rosen-bridge/json-bigint';
7
+ import handleApiError from './handleApiError';
8
+ import { DummyLogger } from '@rosen-bridge/logger-interface';
9
+ import { MinimumFeeBoxBuilder } from './MinimumFeeBoxBuilder';
10
+ import { MinimumFeeConfig } from './MinimumFeeConfig';
11
+ const ERGO_NATIVE_TOKEN = 'erg';
12
+ export class MinimumFeeBox {
13
+ BOX_FETCHING_PAGE_SIZE = 50;
14
+ logger;
15
+ box;
16
+ tokenId;
17
+ minimumFeeNFT;
18
+ address;
19
+ explorerClient;
20
+ nodeClient;
21
+ constructor(tokenId, minimumFeeNFT, address, networkType, networkUrl, logger) {
22
+ this.tokenId = tokenId;
23
+ this.minimumFeeNFT = minimumFeeNFT;
24
+ this.address = address;
25
+ if (networkType === ErgoNetworkType.explorer)
26
+ this.explorerClient = ergoExplorerClientFactory(networkUrl);
27
+ else
28
+ this.nodeClient = ergoNodeClientFactory(networkUrl);
29
+ this.logger = logger ? logger : new DummyLogger();
30
+ }
31
+ /**
32
+ * fetches the box from the blockchain
33
+ */
34
+ fetchBox = async () => {
35
+ if (this.explorerClient)
36
+ this.box = await this.fetchBoxUsingExplorer();
37
+ else
38
+ this.box = await this.fetchBoxUsingNode();
39
+ };
40
+ /**
41
+ * returns fetched box or throws approprite error if found more or none
42
+ * @param eligibleBoxes
43
+ */
44
+ selectEligibleBox = (eligibleBoxes) => {
45
+ this.logger.debug(`Found [${eligibleBoxes.length}] minimum-fee boxes: ${JsonBigInt.stringify(eligibleBoxes.map((box) => box.to_json()))}`);
46
+ if (eligibleBoxes.length === 0)
47
+ throw new NotFoundError(`Found no minimum-fee box for token [${this.tokenId}] and address [${this.address}]`);
48
+ else if (eligibleBoxes.length > 1)
49
+ throw new FailedError(`Found [${eligibleBoxes.length}] minimum-fee boxes for token [${this.tokenId}] and address [${this.address}]`);
50
+ else {
51
+ this.logger.debug(`Found minimum-fee box [${eligibleBoxes[0]
52
+ .box_id()
53
+ .to_str()}] for token [${this.tokenId}] and address [${this.address}]`);
54
+ return eligibleBoxes[0];
55
+ }
56
+ };
57
+ /**
58
+ * fetches box from the blockchain using explorer client
59
+ */
60
+ fetchBoxUsingExplorer = async () => {
61
+ const eligibleBoxes = [];
62
+ try {
63
+ let currentPage = 0;
64
+ let boxesPage = await this.explorerClient.v1.getApiV1BoxesUnspentBytokenidP1(this.minimumFeeNFT, {
65
+ offset: currentPage * this.BOX_FETCHING_PAGE_SIZE,
66
+ limit: this.BOX_FETCHING_PAGE_SIZE,
67
+ });
68
+ while (boxesPage.items?.length) {
69
+ this.logger.debug(`requested 'explorerClient.getApiV1BoxesUnspentBytokenidP1' for token [${this.minimumFeeNFT}]. res: ${JsonBigInt.stringify(boxesPage)}`);
70
+ eligibleBoxes.push(...boxesPage.items
71
+ .filter((box) => box.address === this.address && this.tokenId === ERGO_NATIVE_TOKEN
72
+ ? box.assets?.length === 1
73
+ : box.assets?.length === 2 &&
74
+ box.assets?.some((asset) => asset.tokenId === this.tokenId))
75
+ .map((box) => ErgoBox.from_json(JsonBigInt.stringify(box))));
76
+ currentPage++;
77
+ boxesPage =
78
+ await this.explorerClient.v1.getApiV1BoxesUnspentBytokenidP1(this.minimumFeeNFT, {
79
+ offset: currentPage * this.BOX_FETCHING_PAGE_SIZE,
80
+ limit: this.BOX_FETCHING_PAGE_SIZE,
81
+ });
82
+ }
83
+ }
84
+ catch (error) {
85
+ return handleApiError(error, 'Failed to get boxes by token id from Ergo Explorer:');
86
+ }
87
+ return this.selectEligibleBox(eligibleBoxes);
88
+ };
89
+ /**
90
+ * fetches the box from the blockchain using node client
91
+ */
92
+ fetchBoxUsingNode = async () => {
93
+ const eligibleBoxes = [];
94
+ try {
95
+ const boxHasConfigToken = (box) => box.assets?.some((asset) => asset.tokenId === this.minimumFeeNFT);
96
+ const boxHasAppropriateToken = (box) => this.tokenId === ERGO_NATIVE_TOKEN
97
+ ? box.assets?.length === 1
98
+ : box.assets?.length === 2 &&
99
+ box.assets?.some((asset) => asset.tokenId === this.tokenId);
100
+ let currentPage = 0;
101
+ let boxesPage = await this.nodeClient.getBoxesByAddressUnspent(this.address, {
102
+ offset: currentPage * this.BOX_FETCHING_PAGE_SIZE,
103
+ limit: this.BOX_FETCHING_PAGE_SIZE,
104
+ });
105
+ while (boxesPage.length !== 0) {
106
+ this.logger.debug(`requested 'nodeClient.getBoxesByAddressUnspent' for token [${this.minimumFeeNFT}]. res: ${JsonBigInt.stringify(boxesPage)}`);
107
+ eligibleBoxes.push(...boxesPage
108
+ .filter((box) => boxHasConfigToken(box) && boxHasAppropriateToken(box))
109
+ .map((box) => ErgoBox.from_json(JsonBigInt.stringify(box))));
110
+ currentPage++;
111
+ boxesPage = await this.nodeClient.getBoxesByAddressUnspent(this.address, {
112
+ offset: currentPage * this.BOX_FETCHING_PAGE_SIZE,
113
+ limit: this.BOX_FETCHING_PAGE_SIZE,
114
+ });
115
+ }
116
+ }
117
+ catch (error) {
118
+ const baseError = 'Failed to get boxes by token id from Ergo Node:';
119
+ handleApiError(error, baseError, {
120
+ handleRespondedState: (error) => {
121
+ if (error.response.status === 400)
122
+ return;
123
+ throw new FailedError(`${baseError} [${error.response.status}] ${error.response.data.reason}`);
124
+ },
125
+ });
126
+ }
127
+ return this.selectEligibleBox(eligibleBoxes);
128
+ };
129
+ /**
130
+ * returns fetched config box
131
+ */
132
+ getBox = () => this.box;
133
+ /**
134
+ * gets corresponding config for two chains and height
135
+ * @param fromChain
136
+ * @param height blockchain height for fromChain
137
+ * @param toChain
138
+ */
139
+ getFee = (fromChain, height, toChain) => {
140
+ if (!this.box)
141
+ throw Error(`Box is not fetched yet`);
142
+ const fees = this.extractFeeFromBox().reverse();
143
+ for (const fee of fees) {
144
+ if (!Object.hasOwn(fee.heights, fromChain))
145
+ throw new NotFoundError(`No fee found for chain [${fromChain}] in box [${this.box
146
+ .box_id()
147
+ .to_str()}]`);
148
+ if (fee.heights[fromChain] < height) {
149
+ const chainFee = fee.configs[toChain];
150
+ if (chainFee)
151
+ return new ChainMinimumFee(chainFee);
152
+ else
153
+ throw new Error(`Chain [${toChain}] is not supported at given height of fromChain [${height} of ${fromChain}] in box [${this.box
154
+ .box_id()
155
+ .to_str()}]`);
156
+ }
157
+ }
158
+ throw new NotFoundError(`Config does not support height [${height}] for chain [${fromChain}] in box [${this.box
159
+ .box_id()
160
+ .to_str()}]`);
161
+ };
162
+ /**
163
+ * extracts Fee config from box registers
164
+ */
165
+ extractFeeFromBox = () => {
166
+ const R4 = this.box.register_value(4);
167
+ const R5 = this.box.register_value(5);
168
+ const R6 = this.box.register_value(6);
169
+ const R7 = this.box.register_value(7);
170
+ const R8 = this.box.register_value(8);
171
+ const R9 = this.box.register_value(9);
172
+ if (!R4 || !R5 || !R6 || !R7 || !R8 || !R9)
173
+ throw Error(`Incomplete register data for minimum-fee config box [${this.box
174
+ .box_id()
175
+ .to_str()}]`);
176
+ const fees = [];
177
+ const chains = R4.to_coll_coll_byte().map((element) => Buffer.from(element).toString());
178
+ const heights = R5.to_js();
179
+ const bridgeFees = R6.to_js();
180
+ const networkFees = R7.to_js();
181
+ const rsnRatios = R8.to_js();
182
+ const feeRatios = R9.to_js();
183
+ for (let feeIdx = 0; feeIdx < heights.length; feeIdx++) {
184
+ const fee = {
185
+ heights: {},
186
+ configs: {},
187
+ };
188
+ for (let chainIdx = 0; chainIdx < chains.length; chainIdx++) {
189
+ const chain = chains[chainIdx];
190
+ if (heights[feeIdx][chainIdx] === -1)
191
+ continue;
192
+ fee.heights[chain] = heights[feeIdx][chainIdx];
193
+ if (bridgeFees[feeIdx][chainIdx] === '-1')
194
+ continue;
195
+ fee.configs[chain] = {
196
+ bridgeFee: BigInt(bridgeFees[feeIdx][chainIdx]),
197
+ networkFee: BigInt(networkFees[feeIdx][chainIdx]),
198
+ rsnRatio: BigInt(rsnRatios[feeIdx][chainIdx][0]),
199
+ rsnRatioDivisor: BigInt(rsnRatios[feeIdx][chainIdx][1]),
200
+ feeRatio: BigInt(feeRatios[feeIdx][chainIdx]),
201
+ };
202
+ }
203
+ fees.push(fee);
204
+ }
205
+ this.logger.debug(`Extracted fee config from box [${this.box
206
+ .box_id()
207
+ .to_str()}]: ${JsonBigInt.stringify(fees)}`);
208
+ return fees;
209
+ };
210
+ /**
211
+ * generates a MinimumFeeBoxBuilder using current box
212
+ * note that 'height' parameter of builder won't be set
213
+ */
214
+ toBuilder = () => {
215
+ const builder = new MinimumFeeBoxBuilder(this.minimumFeeNFT, this.address)
216
+ .setValue(BigInt(this.box.value().as_i64().to_str()))
217
+ .setToken(this.tokenId);
218
+ this.extractFeeFromBox().forEach((fee) => {
219
+ const chainFee = new MinimumFeeConfig();
220
+ Object.keys(fee.heights).forEach((chain) => {
221
+ if (Object.hasOwn(fee.configs, chain))
222
+ chainFee.setChainConfig(chain, fee.heights[chain], fee.configs[chain]);
223
+ else
224
+ chainFee.setChainConfig(chain, fee.heights[chain], undefined);
225
+ });
226
+ builder.addConfig(chainFee);
227
+ });
228
+ return builder;
229
+ };
230
+ }
231
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiTWluaW11bUZlZUJveC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL2xpYi9NaW5pbXVtRmVlQm94LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxPQUFPLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQztBQUMvQyxPQUFPLEVBQUUsZUFBZSxFQUFFLGVBQWUsRUFBTyxNQUFNLFNBQVMsQ0FBQztBQUNoRSxPQUFPLEVBQUUsV0FBVyxFQUFFLGFBQWEsRUFBRSxNQUFNLFVBQVUsQ0FBQztBQUN0RCxPQUFPLHlCQUF5QixNQUFNLDhCQUE4QixDQUFDO0FBQ3JFLE9BQU8scUJBRU4sTUFBTSwwQkFBMEIsQ0FBQztBQUNsQyxPQUFPLFVBQVUsTUFBTSwyQkFBMkIsQ0FBQztBQUNuRCxPQUFPLGNBQWMsTUFBTSxrQkFBa0IsQ0FBQztBQUM5QyxPQUFPLEVBQWtCLFdBQVcsRUFBRSxNQUFNLGdDQUFnQyxDQUFDO0FBQzdFLE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBQzlELE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLG9CQUFvQixDQUFDO0FBRXRELE1BQU0saUJBQWlCLEdBQUcsS0FBSyxDQUFDO0FBRWhDLE1BQU0sT0FBTyxhQUFhO0lBQ0wsc0JBQXNCLEdBQUcsRUFBRSxDQUFDO0lBQ3JDLE1BQU0sQ0FBaUI7SUFDdkIsR0FBRyxDQUFVO0lBQ2IsT0FBTyxDQUFTO0lBQ2hCLGFBQWEsQ0FBUztJQUN0QixPQUFPLENBQVM7SUFDaEIsY0FBYyxDQUErQztJQUM3RCxVQUFVLENBQTJDO0lBRS9ELFlBQ0UsT0FBZSxFQUNmLGFBQXFCLEVBQ3JCLE9BQWUsRUFDZixXQUE0QixFQUM1QixVQUFrQixFQUNsQixNQUF1QjtRQUV2QixJQUFJLENBQUMsT0FBTyxHQUFHLE9BQU8sQ0FBQztRQUN2QixJQUFJLENBQUMsYUFBYSxHQUFHLGFBQWEsQ0FBQztRQUNuQyxJQUFJLENBQUMsT0FBTyxHQUFHLE9B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b0JveCB9IGZyb20gJ2VyZ28tbGliLXdhc20tbm9kZWpzJztcbmltcG9ydCB7IENoYWluTWluaW11bUZlZSwgRXJnb05ldHdvcmtUeXBlLCBGZWUgfSBmcm9tICcuL3R5cGVzJztcbmltcG9ydCB7IEZhaWxlZEVycm9yLCBOb3RGb3VuZEVycm9yIH0gZnJvbSAnLi9lcnJvcnMnO1xuaW1wb3J0IGVyZ29FeHBsb3JlckNsaWVudEZhY3RvcnkgZnJvbSAnQHJvc2VuLWNsaWVudHMvZXJnby1leHBsb3Jlcic7XG5pbXBvcnQgZXJnb05vZGVDbGllbnRGYWN0b3J5LCB7XG4gIEluZGV4ZWRFcmdvQm94LFxufSBmcm9tICdAcm9zZW4tY2xpZW50cy9lcmdvLW5vZGUnO1xuaW1wb3J0IEpzb25CaWdJbnQgZnJvbSAnQHJvc2VuLWJyaWRnZS9qc29uLWJpZ2ludCc7XG5pbXBvcnQgaGFuZGxlQXBpRXJyb3IgZnJvbSAnLi9oYW5kbGVBcGlFcnJvcic7XG5pbXBvcnQgeyBBYnN0cmFjdExvZ2dlciwgRHVtbXlMb2dnZXIgfSBmcm9tICdAcm9zZW4tYnJpZGdlL2xvZ2dlci1pbnRlcmZhY2UnO1xuaW1wb3J0IHsgTWluaW11bUZlZUJveEJ1aWxkZXIgfSBmcm9tICcuL01pbmltdW1GZWVCb3hCdWlsZGVyJztcbmltcG9ydCB7IE1pbmltdW1GZWVDb25maWcgfSBmcm9tICcuL01pbmltdW1GZWVDb25maWcnO1xuXG5jb25zdCBFUkdPX05BVElWRV9UT0tFTiA9ICdlcmcnO1xuXG5leHBvcnQgY2xhc3MgTWluaW11bUZlZUJveCB7XG4gIHByb3RlY3RlZCByZWFkb25seSBCT1hfRkVUQ0hJTkdfUEFHRV9TSVpFID0gNTA7XG4gIHByb3RlY3RlZCBsb2dnZXI6IEFic3RyYWN0TG9nZ2VyO1xuICBwcm90ZWN0ZWQgYm94OiBFcmdvQm94O1xuICBwcm90ZWN0ZWQgdG9rZW5JZDogc3RyaW5nO1xuICBwcm90ZWN0ZWQgbWluaW11bUZlZU5GVDogc3RyaW5nO1xuICBwcm90ZWN0ZWQgYWRkcmVzczogc3RyaW5nO1xuICBwcm90ZWN0ZWQgZXhwbG9yZXJDbGllbnQ6IFJldHVyblR5cGU8dHlwZW9mIGVyZ29FeHBsb3JlckNsaWVudEZhY3Rvcnk+O1xuICBwcm90ZWN0ZWQgbm9kZUNsaWVudDogUmV0dXJuVHlwZTx0eXBlb2YgZXJnb05vZGVDbGllbnRGYWN0b3J5PjtcblxuICBjb25zdHJ1Y3RvcihcbiAgICB0b2tlbklkOiBzdHJpbmcsXG4gICAgbWluaW11bUZlZU5GVDogc3RyaW5nLFxuICAgIGFkZHJlc3M6IHN0cmluZyxcbiAgICBuZXR3b3JrVHlwZTogRXJnb05ldHdvcmtUeXBlLFxuICAgIG5ldHdvcmtVcmw6IHN0cmluZyxcbiAgICBsb2dnZXI/OiBBYnN0cmFjdExvZ2dlclxuICApIHtcbiAgICB0aGlzLnRva2VuSWQgPSB0b2tlbklkO1xuICAgIHRoaXMubWluaW11bUZlZU5GVCA9IG1pbmltdW1GZWVORlQ7XG4gICAgdGhpcy5hZGRyZXNzID0gYWRkcmVzcztcbiAgICBpZiAobmV0d29ya1R5cGUgPT09IEVyZ29OZXR3b3JrVHlwZS5leHBsb3JlcilcbiAgICAgIHRoaXMuZXhwbG9yZXJDbGllbnQgPSBlcmdvRXhwbG9yZXJDbGllbnRGYWN0b3J5KG5ldHdvcmtVcmwpO1xuICAgIGVsc2UgdGhpcy5ub2RlQ2xpZW50ID0gZXJnb05vZGVDbGllbnRGYWN0b3J5KG5ldHdvcmtVcmwpO1xuICAgIHRoaXMubG9nZ2VyID0gbG9nZ2VyID8gbG9nZ2VyIDogbmV3IER1bW15TG9nZ2VyKCk7XG4gIH1cblxuICAvKipcbiAgICogZmV0Y2hlcyB0aGUgYm94IGZyb20gdGhlIGJsb2NrY2hhaW5cbiAgICovXG4gIGZldGNoQm94ID0gYXN5bmMgKCk6IFByb21pc2U8dm9pZD4gPT4ge1xuICAgIGlmICh0aGlzLmV4cGxvcmVyQ2xpZW50KSB0aGlzLmJveCA9IGF3YWl0IHRoaXMuZmV0Y2hCb3hVc2luZ0V4cGxvcmVyKCk7XG4gICAgZWxzZSB0aGlzLmJveCA9IGF3YWl0IHRoaXMuZmV0Y2hCb3hVc2luZ05vZGUoKTtcbiAgfTtcblxuICAvKipcbiAgICogcmV0dXJucyBmZXRjaGVkIGJveCBvciB0aHJvd3MgYXBwcm9wcml0ZSBlcnJvciBpZiBmb3VuZCBtb3JlIG9yIG5vbmVcbiAgICogQHBhcmFtIGVsaWdpYmxlQm94ZXNcbiAgICovXG4gIHByb3RlY3RlZCBzZWxlY3RFbGlnaWJsZUJveCA9IChlbGlnaWJsZUJveGVzOiBBcnJheTxFcmdvQm94Pik6IEVyZ29Cb3ggPT4ge1xuICAgIHRoaXMubG9nZ2VyLmRlYnVnKFxuICAgICAgYEZvdW5kIFske1xuICAgICAgICBlbGlnaWJsZUJveGVzLmxlbmd0aFxuICAgICAgfV0gbWluaW11bS1mZWUgYm94ZXM6ICR7SnNvbkJpZ0ludC5zdHJpbmdpZnkoXG4gICAgICAgIGVsaWdpYmxlQm94ZXMubWFwKChib3gpID0+IGJveC50b19qc29uKCkpXG4gICAgICApfWBcbiAgICApO1xuXG4gICAgaWYgKGVsaWdpYmxlQm94ZXMubGVuZ3RoID09PSAwKVxuICAgICAgdGhyb3cgbmV3IE5vdEZvdW5kRXJyb3IoXG4gICAgICAgIGBGb3VuZCBubyBtaW5pbXVtLWZlZSBib3ggZm9yIHRva2VuIFske3RoaXMudG9rZW5JZH1dIGFuZCBhZGRyZXNzIFske3RoaXMuYWRkcmVzc31dYFxuICAgICAgKTtcbiAgICBlbHNlIGlmIChlbGlnaWJsZUJveGVzLmxlbmd0aCA+IDEpXG4gICAgICB0aHJvdyBuZXcgRmFpbGVkRXJyb3IoXG4gICAgICAgIGBGb3VuZCBbJHtlbGlnaWJsZUJveGVzLmxlbmd0aH1dIG1pbmltdW0tZmVlIGJveGVzIGZvciB0b2tlbiBbJHt0aGlzLnRva2VuSWR9XSBhbmQgYWRkcmVzcyBbJHt0aGlzLmFkZHJlc3N9XWBcbiAgICAgICk7XG4gICAgZWxzZSB7XG4gICAgICB0aGlzLmxvZ2dlci5kZWJ1ZyhcbiAgICAgICAgYEZvdW5kIG1pbmltdW0tZmVlIGJveCBbJHtlbGlnaWJsZUJveGVzWzBdXG4gICAgICAgICAgLmJveF9pZCgpXG4gICAgICAgICAgLnRvX3N0cigpfV0gZm9yIHRva2VuIFske3RoaXMudG9rZW5JZH1dIGFuZCBhZGRyZXNzIFske3RoaXMuYWRkcmVzc31dYFxuICAgICAgKTtcbiAgICAgIHJldHVybiBlbGlnaWJsZUJveGVzWzBdO1xuICAgIH1cbiAgfTtcblxuICAvKipcbiAgICogZmV0Y2hlcyBib3ggZnJvbSB0aGUgYmxvY2tjaGFpbiB1c2luZyBleHBsb3JlciBjbGllbnRcbiAgICovXG4gIHByb3RlY3RlZCBmZXRjaEJveFVzaW5nRXhwbG9yZXIgPSBhc3luYyAoKTogUHJvbWlzZTxFcmdvQm94PiA9PiB7XG4gICAgY29uc3QgZWxpZ2libGVCb3hlczogQXJyYXk8RXJnb0JveD4gPSBbXTtcbiAgICB0cnkge1xuICAgICAgbGV0IGN1cnJlbnRQYWdlID0gMDtcbiAgICAgIGxldCBib3hlc1BhZ2UgPVxuICAgICAgICBhd2FpdCB0aGlzLmV4cGxvcmVyQ2xpZW50LnYxLmdldEFwaVYxQm94ZXNVbnNwZW50Qnl0b2tlbmlkUDEoXG4gICAgICAgICAgdGhpcy5taW5pbXVtRmVlTkZULFxuICAgICAgICAgIHtcbiAgICAgICAgICAgIG9mZnNldDogY3VycmVudFBhZ2UgKiB0aGlzLkJPWF9GRVRDSElOR19QQUdFX1NJWkUsXG4gICAgICAgICAgICBsaW1pdDogdGhpcy5CT1hfRkVUQ0hJTkdfUEFHRV9TSVpFLFxuICAgICAgICAgIH1cbiAgICAgICAgKTtcbiAgICAgIHdoaWxlIChib3hlc1BhZ2UuaXRlbXM/Lmxlbmd0aCkge1xuICAgICAgICB0aGlzLmxvZ2dlci5kZWJ1ZyhcbiAgICAgICAgICBgcmVxdWVzdGVkICdleHBsb3JlckNsaWVudC5nZXRBcGlWMUJveGVzVW5zcGVudEJ5dG9rZW5pZFAxJyBmb3IgdG9rZW4gWyR7XG4gICAgICAgICAgICB0aGlzLm1pbmltdW1GZWVORlRcbiAgICAgICAgICB9XS4gcmVzOiAke0pzb25CaWdJbnQuc3RyaW5naWZ5KGJveGVzUGFnZSl9YFxuICAgICAgICApO1xuXG4gICAgICAgIGVsaWdpYmxlQm94ZXMucHVzaChcbiAgICAgICAgICAuLi5ib3hlc1BhZ2UuaXRlbXNcbiAgICAgICAgICAgIC5maWx0ZXIoKGJveCkgPT5cbiAgICAgICAgICAgICAgYm94LmFkZHJlc3MgPT09IHRoaXMuYWRkcmVzcyAmJiB0aGlzLnRva2VuSWQgPT09IEVSR09fTkFUSVZFX1RPS0VOXG4gICAgICAgICAgICAgICAgPyBib3guYXNzZXRzPy5sZW5ndGggPT09IDFcbiAgICAgICAgICAgICAgICA6IGJveC5hc3NldHM/Lmxlbmd0aCA9PT0gMiAmJlxuICAgICAgICAgICAgICAgICAgYm94LmFzc2V0cz8uc29tZSgoYXNzZXQpID0+IGFzc2V0LnRva2VuSWQgPT09IHRoaXMudG9rZW5JZClcbiAgICAgICAgICAgIClcbiAgICAgICAgICAgIC5tYXAoKGJveDogYW55KSA9PiBFcmdvQm94LmZyb21fanNvbihKc29uQmlnSW50LnN0cmluZ2lmeShib3gpKSlcbiAgICAgICAgKTtcbiAgICAgICAgY3VycmVudFBhZ2UrKztcbiAgICAgICAgYm94ZXNQYWdlID1cbiAgICAgICAgICBhd2FpdCB0aGlzLmV4cGxvcmVyQ2xpZW50LnYxLmdldEFwaVYxQm94ZXNVbnNwZW50Qnl0b2tlbmlkUDEoXG4gICAgICAgICAgICB0aGlzLm1pbmltdW1GZWVORlQsXG4gICAgICAgICAgICB7XG4gICAgICAgICAgICAgIG9mZnNldDogY3VycmVudFBhZ2UgKiB0aGlzLkJPWF9GRVRDSElOR19QQUdFX1NJWkUsXG4gICAgICAgICAgICAgIGxpbWl0OiB0aGlzLkJPWF9GRVRDSElOR19QQUdFX1NJWkUsXG4gICAgICAgICAgICB9XG4gICAgICAgICAgKTtcbiAgICAgIH1cbiAgICB9IGNhdGNoIChlcnJvcikge1xuICAgICAgcmV0dXJuIGhhbmRsZUFwaUVycm9yKFxuICAgICAgICBlcnJvcixcbiAgICAgICAgJ0ZhaWxlZCB0byBnZXQgYm94ZXMgYnkgdG9rZW4gaWQgZnJvbSBFcmdvIEV4cGxvcmVyOidcbiAgICAgICk7XG4gICAgfVxuXG4gICAgcmV0dXJuIHRoaXMuc2VsZWN0RWxpZ2libGVCb3goZWxpZ2libGVCb3hlcyk7XG4gIH07XG5cbiAgLyoqXG4gICAqIGZldGNoZXMgdGhlIGJveCBmcm9tIHRoZSBibG9ja2NoYWluIHVzaW5nIG5vZGUgY2xpZW50XG4gICAqL1xuICBwcm90ZWN0ZWQgZmV0Y2hCb3hVc2luZ05vZGUgPSBhc3luYyAoKTogUHJvbWlzZTxFcmdvQm94PiA9PiB7XG4gICAgY29uc3QgZWxpZ2libGVCb3hlczogQXJyYXk8RXJnb0JveD4gPSBbXTtcbiAgICB0cnkge1xuICAgICAgY29uc3QgYm94SGFzQ29uZmlnVG9rZW4gPSAoYm94OiBJbmRleGVkRXJnb0JveCkgPT5cbiAgICAgICAgYm94LmFzc2V0cz8uc29tZSgoYXNzZXQpID0+IGFzc2V0LnRva2VuSWQgPT09IHRoaXMubWluaW11bUZlZU5GVCk7XG4gICAgICBjb25zdCBib3hIYXNBcHByb3ByaWF0ZVRva2VuID0gKGJveDogSW5kZXhlZEVyZ29Cb3gpID0+XG4gICAgICAgIHRoaXMudG9rZW5JZCA9PT0gRVJHT19OQVRJVkVfVE9LRU5cbiAgICAgICAgICA/IGJveC5hc3NldHM/Lmxlbmd0aCA9PT0gMVxuICAgICAgICAgIDogYm94LmFzc2V0cz8ubGVuZ3RoID09PSAyICYmXG4gICAgICAgICAgICBib3guYXNzZXRzPy5zb21lKChhc3NldCkgPT4gYXNzZXQudG9rZW5JZCA9PT0gdGhpcy50b2tlbklkKTtcblxuICAgICAgbGV0IGN1cnJlbnRQYWdlID0gMDtcbiAgICAgIGxldCBib3hlc1BhZ2UgPSBhd2FpdCB0aGlzLm5vZGVDbGllbnQuZ2V0Qm94ZXNCeUFkZHJlc3NVbnNwZW50KFxuICAgICAgICB0aGlzLmFkZHJlc3MsXG4gICAgICAgIHtcbiAgICAgICAgICBvZmZzZXQ6IGN1cnJlbnRQYWdlICogdGhpcy5CT1hfRkVUQ0hJTkdfUEFHRV9TSVpFLFxuICAgICAgICAgIGxpbWl0OiB0aGlzLkJPWF9GRVRDSElOR19QQUdFX1NJWkUsXG4gICAgICAgIH1cbiAgICAgICk7XG4gICAgICB3aGlsZSAoYm94ZXNQYWdlLmxlbmd0aCAhPT0gMCkge1xuICAgICAgICB0aGlzLmxvZ2dlci5kZWJ1ZyhcbiAgICAgICAgICBgcmVxdWVzdGVkICdub2RlQ2xpZW50LmdldEJveGVzQnlBZGRyZXNzVW5zcGVudCcgZm9yIHRva2VuIFske1xuICAgICAgICAgICAgdGhpcy5taW5pbXVtRmVlTkZUXG4gICAgICAgICAgfV0uIHJlczogJHtKc29uQmlnSW50LnN0cmluZ2lmeShib3hlc1BhZ2UpfWBcbiAgICAgICAgKTtcblxuICAgICAgICBlbGlnaWJsZUJveGVzLnB1c2goXG4gICAgICAgICAgLi4uYm94ZXNQYWdlXG4gICAgICAgICAgICAuZmlsdGVyKFxuICAgICAgICAgICAgICAoYm94KSA9PiBib3hIYXNDb25maWdUb2tlbihib3gpICYmIGJveEhhc0FwcHJvcHJpYXRlVG9rZW4oYm94KVxuICAgICAgICAgICAgKVxuICAgICAgICAgICAgLm1hcCgoYm94OiBJbmRleGVkRXJnb0JveCkgPT5cbiAgICAgICAgICAgICAgRXJnb0JveC5mcm9tX2pzb24oSnNvbkJpZ0ludC5zdHJpbmdpZnkoYm94KSlcbiAgICAgICAgICAgIClcbiAgICAgICAgKTtcbiAgICAgICAgY3VycmVudFBhZ2UrKztcbiAgICAgICAgYm94ZXNQYWdlID0gYXdhaXQgdGhpcy5ub2RlQ2xpZW50LmdldEJveGVzQnlBZGRyZXNzVW5zcGVudChcbiAgICAgICAgICB0aGlzLmFkZHJlc3MsXG4gICAgICAgICAge1xuICAgICAgICAgICAgb2Zmc2V0OiBjdXJyZW50UGFnZSAqIHRoaXMuQk9YX0ZFVENISU5HX1BBR0VfU0laRSxcbiAgICAgICAgICAgIGxpbWl0OiB0aGlzLkJPWF9GRVRDSElOR19QQUdFX1NJWkUsXG4gICAgICAgICAgfVxuICAgICAgICApO1xuICAgICAgfVxuICAgIH0gY2F0Y2ggKGVycm9yKSB7XG4gICAgICBjb25zdCBiYXNlRXJyb3IgPSAnRmFpbGVkIHRvIGdldCBib3hlcyBieSB0b2tlbiBpZCBmcm9tIEVyZ28gTm9kZTonO1xuICAgICAgaGFuZGxlQXBpRXJyb3IoZXJyb3IsIGJhc2VFcnJvciwge1xuICAgICAgICBoYW5kbGVSZXNwb25kZWRTdGF0ZTogKGVycm9yKSA9PiB7XG4gICAgICAgICAgaWYgKGVycm9yLnJlc3BvbnNlLnN0YXR1cyA9PT0gNDAwKSByZXR1cm47XG4gICAgICAgICAgdGhyb3cgbmV3IEZhaWxlZEVycm9yKFxuICAgICAgICAgICAgYCR7YmFzZUVycm9yfSBbJHtlcnJvci5yZXNwb25zZS5zdGF0dXN9XSAke2Vycm9yLnJlc3BvbnNlLmRhdGEucmVhc29ufWBcbiAgICAgICAgICApO1xuICAgICAgICB9LFxuICAgICAgfSk7XG4gICAgfVxuXG4gICAgcmV0dXJuIHRoaXMuc2VsZWN0RWxpZ2libGVCb3goZWxpZ2libGVCb3hlcyk7XG4gIH07XG5cbiAgLyoqXG4gICAqIHJldHVybnMgZmV0Y2hlZCBjb25maWcgYm94XG4gICAqL1xuICBnZXRCb3ggPSAoKTogRXJnb0JveCA9PiB0aGlzLmJveDtcblxuICAvKipcbiAgICogZ2V0cyBjb3JyZXNwb25kaW5nIGNvbmZpZyBmb3IgdHdvIGNoYWlucyBhbmQgaGVpZ2h0XG4gICAqIEBwYXJhbSBmcm9tQ2hhaW5cbiAgICogQHBhcmFtIGhlaWdodCBibG9ja2NoYWluIGhlaWdodCBmb3IgZnJvbUNoYWluXG4gICAqIEBwYXJhbSB0b0NoYWluXG4gICAqL1xuICBnZXRGZWUgPSAoXG4gICAgZnJvbUNoYWluOiBzdHJpbmcsXG4gICAgaGVpZ2h0OiBudW1iZXIsXG4gICAgdG9DaGFpbjogc3RyaW5nXG4gICk6IENoYWluTWluaW11bUZlZSA9PiB7XG4gICAgaWYgKCF0aGlzLmJveCkgdGhyb3cgRXJyb3IoYEJveCBpcyBub3QgZmV0Y2hlZCB5ZXRgKTtcblxuICAgIGNvbnN0IGZlZXMgPSB0aGlzLmV4dHJhY3RGZWVGcm9tQm94KCkucmV2ZXJzZSgpO1xuICAgIGZvciAoY29uc3QgZmVlIG9mIGZlZXMpIHtcbiAgICAgIGlmICghT2JqZWN0Lmhhc093bihmZWUuaGVpZ2h0cywgZnJvbUNoYWluKSlcbiAgICAgICAgdGhyb3cgbmV3IE5vdEZvdW5kRXJyb3IoXG4gICAgICAgICAgYE5vIGZlZSBmb3VuZCBmb3IgY2hhaW4gWyR7ZnJvbUNoYWlufV0gaW4gYm94IFske3RoaXMuYm94XG4gICAgICAgICAgICAuYm94X2lkKClcbiAgICAgICAgICAgIC50b19zdHIoKX1dYFxuICAgICAgICApO1xuICAgICAgaWYgKGZlZS5oZWlnaHRzW2Zyb21DaGFpbl0gPCBoZWlnaHQpIHtcbiAgICAgICAgY29uc3QgY2hhaW5GZWUgPSBmZWUuY29uZmlnc1t0b0NoYWluXTtcbiAgICAgICAgaWYgKGNoYWluRmVlKSByZXR1cm4gbmV3IENoYWluTWluaW11bUZlZShjaGFpbkZlZSk7XG4gICAgICAgIGVsc2VcbiAgICAgICAgICB0aHJvdyBuZXcgRXJyb3IoXG4gICAgICAgICAgICBgQ2hhaW4gWyR7dG9DaGFpbn1dIGlzIG5vdCBzdXBwb3J0ZWQgYXQgZ2l2ZW4gaGVpZ2h0IG9mIGZyb21DaGFpbiBbJHtoZWlnaHR9IG9mICR7ZnJvbUNoYWlufV0gaW4gYm94IFske3RoaXMuYm94XG4gICAgICAgICAgICAgIC5ib3hfaWQoKVxuICAgICAgICAgICAgICAudG9fc3RyKCl9XWBcbiAgICAgICAgICApO1xuICAgICAgfVxuICAgIH1cblxuICAgIHRocm93IG5ldyBOb3RGb3VuZEVycm9yKFxuICAgICAgYENvbmZpZyBkb2VzIG5vdCBzdXBwb3J0IGhlaWdodCBbJHtoZWlnaHR9XSBmb3IgY2hhaW4gWyR7ZnJvbUNoYWlufV0gaW4gYm94IFske3RoaXMuYm94XG4gICAgICAgIC5ib3hfaWQoKVxuICAgICAgICAudG9fc3RyKCl9XWBcbiAgICApO1xuICB9O1xuXG4gIC8qKlxuICAgKiBleHRyYWN0cyBGZWUgY29uZmlnIGZyb20gYm94IHJlZ2lzdGVyc1xuICAgKi9cbiAgcHJvdGVjdGVkIGV4dHJhY3RGZWVGcm9tQm94ID0gKCk6IEFycmF5PEZlZT4gPT4ge1xuICAgIGNvbnN0IFI0ID0gdGhpcy5ib3gucmVnaXN0ZXJfdmFsdWUoNCk7XG4gICAgY29uc3QgUjUgPSB0aGlzLmJveC5yZWdpc3Rlcl92YWx1ZSg1KTtcbiAgICBjb25zdCBSNiA9IHRoaXMuYm94LnJlZ2lzdGVyX3ZhbHVlKDYpO1xuICAgIGNvbnN0IFI3ID0gdGhpcy5ib3gucmVnaXN0ZXJfdmFsdWUoNyk7XG4gICAgY29uc3QgUjggPSB0aGlzLmJveC5yZWdpc3Rlcl92YWx1ZSg4KTtcbiAgICBjb25zdCBSOSA9IHRoaXMuYm94LnJlZ2lzdGVyX3ZhbHVlKDkpO1xuXG4gICAgaWYgKCFSNCB8fCAhUjUgfHwgIVI2IHx8ICFSNyB8fCAhUjggfHwgIVI5KVxuICAgICAgdGhyb3cgRXJyb3IoXG4gICAgICAgIGBJbmNvbXBsZXRlIHJlZ2lzdGVyIGRhdGEgZm9yIG1pbmltdW0tZmVlIGNvbmZpZyBib3ggWyR7dGhpcy5ib3hcbiAgICAgICAgICAuYm94X2lkKClcbiAgICAgICAgICAudG9fc3RyKCl9XWBcbiAgICAgICk7XG5cbiAgICBjb25zdCBmZWVzOiBBcnJheTxGZWU+ID0gW107XG4gICAgY29uc3QgY2hhaW5zID0gUjQudG9fY29sbF9jb2xsX2J5dGUoKS5tYXAoKGVsZW1lbnQpID0+XG4gICAgICBCdWZmZXIuZnJvbShlbGVtZW50KS50b1N0cmluZygpXG4gICAgKTtcbiAgICBjb25zdCBoZWlnaHRzID0gUjUudG9fanMoKSBhcyBBcnJheTxBcnJheTxudW1iZXI+PjtcbiAgICBjb25zdCBicmlkZ2VGZWVzID0gUjYudG9fanMoKSBhcyBBcnJheTxBcnJheTxzdHJpbmc+PjtcbiAgICBjb25zdCBuZXR3b3JrRmVlcyA9IFI3LnRvX2pzKCkgYXMgQXJyYXk8QXJyYXk8c3RyaW5nPj47XG4gICAgY29uc3QgcnNuUmF0aW9zID0gUjgudG9fanMoKSBhcyBBcnJheTxBcnJheTxBcnJheTxzdHJpbmc+Pj47XG4gICAgY29uc3QgZmVlUmF0aW9zID0gUjkudG9fanMoKSBhcyBBcnJheTxBcnJheTxzdHJpbmc+PjtcblxuICAgIGZvciAobGV0IGZlZUlkeCA9IDA7IGZlZUlkeCA8IGhlaWdodHMubGVuZ3RoOyBmZWVJZHgrKykge1xuICAgICAgY29uc3QgZmVlOiBGZWUgPSB7XG4gICAgICAgIGhlaWdodHM6IHt9LFxuICAgICAgICBjb25maWdzOiB7fSxcbiAgICAgIH07XG4gICAgICBmb3IgKGxldCBjaGFpbklkeCA9IDA7IGNoYWluSWR4IDwgY2hhaW5zLmxlbmd0aDsgY2hhaW5JZHgrKykge1xuICAgICAgICBjb25zdCBjaGFpbiA9IGNoYWluc1tjaGFpbklkeF07XG5cbiAgICAgICAgaWYgKGhlaWdodHNbZmVlSWR4XVtjaGFpbklkeF0gPT09IC0xKSBjb250aW51ZTtcbiAgICAgICAgZmVlLmhlaWdodHNbY2hhaW5dID0gaGVpZ2h0c1tmZWVJZHhdW2NoYWluSWR4XTtcblxuICAgICAgICBpZiAoYnJpZGdlRmVlc1tmZWVJZHhdW2NoYWluSWR4XSA9PT0gJy0xJykgY29udGludWU7XG4gICAgICAgIGZlZS5jb25maWdzW2NoYWluXSA9IHtcbiAgICAgICAgICBicmlkZ2VGZWU6IEJpZ0ludChicmlkZ2VGZWVzW2ZlZUlkeF1bY2hhaW5JZHhdKSxcbiAgICAgICAgICBuZXR3b3JrRmVlOiBCaWdJbnQobmV0d29ya0ZlZXNbZmVlSWR4XVtjaGFpbklkeF0pLFxuICAgICAgICAgIHJzblJhdGlvOiBCaWdJbnQocnNuUmF0aW9zW2ZlZUlkeF1bY2hhaW5JZHhdWzBdKSxcbiAgICAgICAgICByc25SYXRpb0Rpdmlzb3I6IEJpZ0ludChyc25SYXRpb3NbZmVlSWR4XVtjaGFpbklkeF1bMV0pLFxuICAgICAgICAgIGZlZVJhdGlvOiBCaWdJbnQoZmVlUmF0aW9zW2ZlZUlkeF1bY2hhaW5JZHhdKSxcbiAgICAgICAgfTtcbiAgICAgIH1cbiAgICAgIGZlZXMucHVzaChmZWUpO1xuICAgIH1cblxuICAgIHRoaXMubG9nZ2VyLmRlYnVnKFxuICAgICAgYEV4dHJhY3RlZCBmZWUgY29uZmlnIGZyb20gYm94IFske3RoaXMuYm94XG4gICAgICAgIC5ib3hfaWQoKVxuICAgICAgICAudG9fc3RyKCl9XTogJHtKc29uQmlnSW50LnN0cmluZ2lmeShmZWVzKX1gXG4gICAgKTtcblxuICAgIHJldHVybiBmZWVzO1xuICB9O1xuXG4gIC8qKlxuICAgKiBnZW5lcmF0ZXMgYSBNaW5pbXVtRmVlQm94QnVpbGRlciB1c2luZyBjdXJyZW50IGJveFxuICAgKiAgbm90ZSB0aGF0ICdoZWlnaHQnIHBhcmFtZXRlciBvZiBidWlsZGVyIHdvbid0IGJlIHNldFxuICAgKi9cbiAgdG9CdWlsZGVyID0gKCk6IE1pbmltdW1GZWVCb3hCdWlsZGVyID0+IHtcbiAgICBjb25zdCBidWlsZGVyID0gbmV3IE1pbmltdW1GZWVCb3hCdWlsZGVyKHRoaXMubWluaW11bUZlZU5GVCwgdGhpcy5hZGRyZXNzKVxuICAgICAgLnNldFZhbHVlKEJpZ0ludCh0aGlzLmJveC52YWx1ZSgpLmFzX2k2NCgpLnRvX3N0cigpKSlcbiAgICAgIC5zZXRUb2tlbih0aGlzLnRva2VuSWQpO1xuXG4gICAgdGhpcy5leHRyYWN0RmVlRnJvbUJveCgpLmZvckVhY2goKGZlZSkgPT4ge1xuICAgICAgY29uc3QgY2hhaW5GZWUgPSBuZXcgTWluaW11bUZlZUNvbmZpZygpO1xuICAgICAgT2JqZWN0LmtleXMoZmVlLmhlaWdodHMpLmZvckVhY2goKGNoYWluKSA9PiB7XG4gICAgICAgIGlmIChPYmplY3QuaGFzT3duKGZlZS5jb25maWdzLCBjaGFpbikpXG4gICAgICAgICAgY2hhaW5GZWUuc2V0Q2hhaW5Db25maWcoXG4gICAgICAgICAgICBjaGFpbixcbiAgICAgICAgICAgIGZlZS5oZWlnaHRzW2NoYWluXSxcbiAgICAgICAgICAgIGZlZS5jb25maWdzW2NoYWluXVxuICAgICAgICAgICk7XG4gICAgICAgIGVsc2UgY2hhaW5GZWUuc2V0Q2hhaW5Db25maWcoY2hhaW4sIGZlZS5oZWlnaHRzW2NoYWluXSwgdW5kZWZpbmVkKTtcbiAgICAgIH0pO1xuICAgICAgYnVpbGRlci5hZGRDb25maWcoY2hhaW5GZWUpO1xuICAgIH0pO1xuICAgIHJldHVybiBidWlsZGVyO1xuICB9O1xufVxuIl19
@@ -0,0 +1,47 @@
1
+ import { BoxValue, ErgoBoxCandidate } from 'ergo-lib-wasm-nodejs';
2
+ import { MinimumFeeConfig } from './MinimumFeeConfig';
3
+ import { Fee } from './types';
4
+ export declare class MinimumFeeBoxBuilder {
5
+ protected fees: Array<Fee>;
6
+ protected boxValue: BoxValue;
7
+ protected boxheight: number;
8
+ protected tokenId: string;
9
+ protected minimumFeeNFT: string;
10
+ protected address: string;
11
+ constructor(minimumFeeNFT: string, address: string);
12
+ /**
13
+ * adds a feeConfig
14
+ * @param feeConfig
15
+ */
16
+ addConfig: (feeConfig: MinimumFeeConfig) => MinimumFeeBoxBuilder;
17
+ /**
18
+ * removes a config by index
19
+ * @param index
20
+ */
21
+ removeConfig: (index: number) => MinimumFeeBoxBuilder;
22
+ /**
23
+ * sets ErgoBox Erg value
24
+ * @param nanoErg
25
+ * @returns
26
+ */
27
+ setValue: (nanoErg: bigint) => MinimumFeeBoxBuilder;
28
+ /**
29
+ * sets ErgoBox creationheight
30
+ * @param currentHeight
31
+ */
32
+ setHeight: (currentHeight: number) => MinimumFeeBoxBuilder;
33
+ /**
34
+ * sets config token id
35
+ * @param tokenId
36
+ */
37
+ setToken: (tokenId: string) => MinimumFeeBoxBuilder;
38
+ /**
39
+ * validates some of specified configs
40
+ */
41
+ protected validate: () => void;
42
+ /**
43
+ * validates specified configs and builds ErgoBoxCandidate of config box using them
44
+ */
45
+ build: () => ErgoBoxCandidate;
46
+ }
47
+ //# sourceMappingURL=MinimumFeeBoxBuilder.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"MinimumFeeBoxBuilder.d.ts","sourceRoot":"","sources":["../../lib/MinimumFeeBoxBuilder.ts"],"names":[],"mappings":"AAAA,OAAO,EAEL,QAAQ,EAOR,gBAAgB,EACjB,MAAM,sBAAsB,CAAC;AAC9B,OAAO,EAAE,gBAAgB,EAAE,MAAM,oBAAoB,CAAC;AACtD,OAAO,EAAE,GAAG,EAAE,MAAM,SAAS,CAAC;AAK9B,qBAAa,oBAAoB;IAC/B,SAAS,CAAC,IAAI,EAAE,KAAK,CAAC,GAAG,CAAC,CAAC;IAC3B,SAAS,CAAC,QAAQ,EAAE,QAAQ,CAAC;IAC7B,SAAS,CAAC,SAAS,EAAE,MAAM,CAAC;IAC5B,SAAS,CAAC,OAAO,EAAE,MAAM,CAAC;IAC1B,SAAS,CAAC,aAAa,EAAE,MAAM,CAAC;IAChC,SAAS,CAAC,OAAO,EAAE,MAAM,CAAC;gBAEd,aAAa,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM;IAMlD;;;OAGG;IACH,SAAS,cAAe,gBAAgB,KAAG,oBAAoB,CAG7D;IAEF;;;OAGG;IACH,YAAY,UAAW,MAAM,KAAG,oBAAoB,CAGlD;IAEF;;;;OAIG;IACH,QAAQ,YAAa,MAAM,KAAG,oBAAoB,CAGhD;IAEF;;;OAGG;IACH,SAAS,kBAAmB,MAAM,KAAG,oBAAoB,CAGvD;IAEF;;;OAGG;IACH,QAAQ,YAAa,MAAM,KAAG,oBAAoB,CAGhD;IAEF;;OAEG;IACH,SAAS,CAAC,QAAQ,QAAO,IAAI,CA6B3B;IAEF;;OAEG;IACH,KAAK,QAAO,gBAAgB,CAmF1B;CACH"}
@@ -0,0 +1,149 @@
1
+ import { Address, BoxValue, Contract, ErgoBoxCandidateBuilder, I64, TokenAmount, TokenId, Constant, } from 'ergo-lib-wasm-nodejs';
2
+ import { InvalidConfig } from './errors';
3
+ const ERGO_NATIVE_TOKEN = 'erg';
4
+ export class MinimumFeeBoxBuilder {
5
+ fees;
6
+ boxValue;
7
+ boxheight;
8
+ tokenId;
9
+ minimumFeeNFT;
10
+ address;
11
+ constructor(minimumFeeNFT, address) {
12
+ this.fees = [];
13
+ this.minimumFeeNFT = minimumFeeNFT;
14
+ this.address = address;
15
+ }
16
+ /**
17
+ * adds a feeConfig
18
+ * @param feeConfig
19
+ */
20
+ addConfig = (feeConfig) => {
21
+ this.fees.push(feeConfig.getConfig());
22
+ return this;
23
+ };
24
+ /**
25
+ * removes a config by index
26
+ * @param index
27
+ */
28
+ removeConfig = (index) => {
29
+ this.fees.splice(index);
30
+ return this;
31
+ };
32
+ /**
33
+ * sets ErgoBox Erg value
34
+ * @param nanoErg
35
+ * @returns
36
+ */
37
+ setValue = (nanoErg) => {
38
+ this.boxValue = BoxValue.from_i64(I64.from_str(nanoErg.toString()));
39
+ return this;
40
+ };
41
+ /**
42
+ * sets ErgoBox creationheight
43
+ * @param currentHeight
44
+ */
45
+ setHeight = (currentHeight) => {
46
+ this.boxheight = currentHeight;
47
+ return this;
48
+ };
49
+ /**
50
+ * sets config token id
51
+ * @param tokenId
52
+ */
53
+ setToken = (tokenId) => {
54
+ this.tokenId = tokenId;
55
+ return this;
56
+ };
57
+ /**
58
+ * validates some of specified configs
59
+ */
60
+ validate = () => {
61
+ if (!this.boxValue)
62
+ throw new InvalidConfig(`Box value argument is not defined`);
63
+ if (!this.boxheight)
64
+ throw new InvalidConfig(`Box creation height argument is not defined`);
65
+ if (!this.tokenId)
66
+ throw new InvalidConfig(`Config token id is not defined`);
67
+ if (this.fees.length === 0)
68
+ throw new InvalidConfig(`No config added. Please add at least one config`);
69
+ for (let i = 0; i < this.fees.length - 1; i++) {
70
+ const chains = Object.keys(this.fees[0].heights);
71
+ chains.forEach((chain) => {
72
+ if (!this.fees[i + 1].heights[chain])
73
+ throw new InvalidConfig(`Expected chain [${chain}] at index [${i + 1}]`);
74
+ if (this.fees[i + 1].heights[chain] < this.fees[i].heights[chain])
75
+ throw new InvalidConfig(`All heights for a chain should be ascending. Heights of chain [${chain}] at indexes [${i},${i + 1}] are invalid [${this.fees[i + 1].heights[chain]} < ${this.fees[i].heights[chain]}]`);
76
+ });
77
+ }
78
+ };
79
+ /**
80
+ * validates specified configs and builds ErgoBoxCandidate of config box using them
81
+ */
82
+ build = () => {
83
+ this.validate();
84
+ // add box value, address and creation height
85
+ const boxBuilder = new ErgoBoxCandidateBuilder(this.boxValue, Contract.new(Address.from_base58(this.address).to_ergo_tree()), this.boxheight);
86
+ // add box tokens
87
+ boxBuilder.add_token(TokenId.from_str(this.minimumFeeNFT), TokenAmount.from_i64(I64.from_str('1')));
88
+ if (this.tokenId !== ERGO_NATIVE_TOKEN)
89
+ boxBuilder.add_token(TokenId.from_str(this.tokenId), TokenAmount.from_i64(I64.from_str('1')));
90
+ // generate register values
91
+ // extract chains
92
+ const chains = [];
93
+ this.fees.forEach((fee) => {
94
+ Object.keys(fee.heights).forEach((feeChain) => {
95
+ if (!chains.includes(feeChain))
96
+ chains.push(feeChain);
97
+ });
98
+ });
99
+ chains.sort();
100
+ // extract configs
101
+ const heights = [];
102
+ const brdigeFees = [];
103
+ const networkFees = [];
104
+ const rsnRatios = [];
105
+ const feeRatios = [];
106
+ this.fees.forEach((fee) => {
107
+ const heightsConfigs = [];
108
+ const brdigeFeesConfigs = [];
109
+ const networkFeesConfigs = [];
110
+ const rsnRatiosConfigs = [];
111
+ const feeRatiosConfigs = [];
112
+ chains.forEach((chain) => {
113
+ if (Object.hasOwn(fee.heights, chain))
114
+ heightsConfigs.push(fee.heights[chain]);
115
+ else
116
+ heightsConfigs.push(-1);
117
+ if (Object.hasOwn(fee.configs, chain)) {
118
+ brdigeFeesConfigs.push(fee.configs[chain].bridgeFee.toString());
119
+ networkFeesConfigs.push(fee.configs[chain].networkFee.toString());
120
+ rsnRatiosConfigs.push([
121
+ fee.configs[chain].rsnRatio.toString(),
122
+ fee.configs[chain].rsnRatioDivisor.toString(),
123
+ ]);
124
+ feeRatiosConfigs.push(fee.configs[chain].feeRatio.toString());
125
+ }
126
+ else {
127
+ brdigeFeesConfigs.push('-1');
128
+ networkFeesConfigs.push('-1');
129
+ rsnRatiosConfigs.push(['-1', '-1']);
130
+ feeRatiosConfigs.push('-1');
131
+ }
132
+ });
133
+ heights.push(heightsConfigs);
134
+ brdigeFees.push(brdigeFeesConfigs);
135
+ networkFees.push(networkFeesConfigs);
136
+ rsnRatios.push(rsnRatiosConfigs);
137
+ feeRatios.push(feeRatiosConfigs);
138
+ });
139
+ // add box registers
140
+ boxBuilder.set_register_value(4, Constant.from_coll_coll_byte(chains.map((chain) => Buffer.from(chain))));
141
+ boxBuilder.set_register_value(5, Constant.from_js(heights));
142
+ boxBuilder.set_register_value(6, Constant.from_js(brdigeFees));
143
+ boxBuilder.set_register_value(7, Constant.from_js(networkFees));
144
+ boxBuilder.set_register_value(8, Constant.from_js(rsnRatios));
145
+ boxBuilder.set_register_value(9, Constant.from_js(feeRatios));
146
+ return boxBuilder.build();
147
+ };
148
+ }
149
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiTWluaW11bUZlZUJveEJ1aWxkZXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9saWIvTWluaW11bUZlZUJveEJ1aWxkZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUNMLE9BQU8sRUFDUCxRQUFRLEVBQ1IsUUFBUSxFQUNSLHVCQUF1QixFQUN2QixHQUFHLEVBQ0gsV0FBVyxFQUNYLE9BQU8sRUFDUCxRQUFRLEdBRVQsTUFBTSxzQkFBc0IsQ0FBQztBQUc5QixPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sVUFBVSxDQUFDO0FBRXpDLE1BQU0saUJBQWlCLEdBQUcsS0FBSyxDQUFDO0FBRWhDLE1BQU0sT0FBTyxvQkFBb0I7SUFDckIsSUFBSSxDQUFhO0lBQ2pCLFFBQVEsQ0FBVztJQUNuQixTQUFTLENBQVM7SUFDbEIsT0FBTyxDQUFTO0lBQ2hCLGFBQWEsQ0FBUztJQUN0QixPQUFPLENBQVM7SUFFMUIsWUFBWSxhQUFxQixFQUFFLE9BQWU7UUFDaEQsSUFBSSxDQUFDLElBQUksR0FBRyxFQUFFLENBQUM7UUFDZixJQUFJLENBQUMsYUFBYSxHQUFHLGFBQWEsQ0FBQztRQUNuQyxJQUFJLENBQUMsT0FBTyxHQUFHLE9BQU8sQ0FBQztJQUN6QixDQUFDO0lBRUQ7OztPQUdHO0lBQ0gsU0FBUyxHQUFHLENBQUMsU0FBMkIsRUFBd0IsRUFBRTtRQUNoRSxJQUFJLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsU0FBUyxFQUFFLENBQUMsQ0FBQztRQUN0QyxPQUFPLElBQUksQ0FBQztJQUNkLENBQUMsQ0FBQztJQUVGOzs7T0FHRztJQUNILFlBQVksR0FBRyxDQUFDLEtBQWEsRUFBd0IsRUFBRTtRQUNyRCxJQUFJLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUN4QixPQUFPLElBQUksQ0FBQztJQUNkLENBQUMsQ0FBQztJQUVGOzs7O09BSUc7SUFDSCxRQUFRLEdBQUcs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LENBQUMsQ0FBQyxFQUFFLFFBQVEsQ0FBQyxPQUFPLENBQUMsU0FBUyxDQUFDLENBQUMsQ0FBQztRQUM5RCxVQUFVLENBQUMsa0JBQWtCLENBQUMsQ0FBQyxFQUFFLFFBQVEsQ0FBQyxPQUFPLENBQUMsU0FBUyxDQUFDLENBQUMsQ0FBQztRQUU5RCxPQUFPLFVBQVUsQ0FBQyxLQUFLLEVBQUUsQ0FBQztJQUM1QixDQUFDLENBQUM7Q0FDSCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gIEFkZHJlc3MsXG4gIEJveFZhbHVlLFxuICBDb250cmFjdCxcbiAgRXJnb0JveENhbmRpZGF0ZUJ1aWxkZXIsXG4gIEk2NCxcbiAgVG9rZW5BbW91bnQsXG4gIFRva2VuSWQsXG4gIENvbnN0YW50LFxuICBFcmdvQm94Q2FuZGlkYXRlLFxufSBmcm9tICdlcmdvLWxpYi13YXNtLW5vZGVqcyc7XG5pbXBvcnQgeyBNaW5pbXVtRmVlQ29uZmlnIH0gZnJvbSAnLi9NaW5pbXVtRmVlQ29uZmlnJztcbmltcG9ydCB7IEZlZSB9IGZyb20gJy4vdHlwZXMnO1xuaW1wb3J0IHsgSW52YWxpZENvbmZpZyB9IGZyb20gJy4vZXJyb3JzJztcblxuY29uc3QgRVJHT19OQVRJVkVfVE9LRU4gPSAnZXJnJztcblxuZXhwb3J0IGNsYXNzIE1pbmltdW1GZWVCb3hCdWlsZGVyIHtcbiAgcHJvdGVjdGVkIGZlZXM6IEFycmF5PEZlZT47XG4gIHByb3RlY3RlZCBib3hWYWx1ZTogQm94VmFsdWU7XG4gIHByb3RlY3RlZCBib3hoZWlnaHQ6IG51bWJlcjtcbiAgcHJvdGVjdGVkIHRva2VuSWQ6IHN0cmluZztcbiAgcHJvdGVjdGVkIG1pbmltdW1GZWVORlQ6IHN0cmluZztcbiAgcHJvdGVjdGVkIGFkZHJlc3M6IHN0cmluZztcblxuICBjb25zdHJ1Y3RvcihtaW5pbXVtRmVlTkZUOiBzdHJpbmcsIGFkZHJlc3M6IHN0cmluZykge1xuICAgIHRoaXMuZmVlcyA9IFtdO1xuICAgIHRoaXMubWluaW11bUZlZU5GVCA9IG1pbmltdW1GZWVORlQ7XG4gICAgdGhpcy5hZGRyZXNzID0gYWRkcmVzcztcbiAgfVxuXG4gIC8qKlxuICAgKiBhZGRzIGEgZmVlQ29uZmlnXG4gICAqIEBwYXJhbSBmZWVDb25maWdcbiAgICovXG4gIGFkZENvbmZpZyA9IChmZWVDb25maWc6IE1pbmltdW1GZWVDb25maWcpOiBNaW5pbXVtRmVlQm94QnVpbGRlciA9PiB7XG4gICAgdGhpcy5mZWVzLnB1c2goZmVlQ29uZmlnLmdldENvbmZpZygpKTtcbiAgICByZXR1cm4gdGhpcztcbiAgfTtcblxuICAvKipcbiAgICogcmVtb3ZlcyBhIGNvbmZpZyBieSBpbmRleFxuICAgKiBAcGFyYW0gaW5kZXhcbiAgICovXG4gIHJlbW92ZUNvbmZpZyA9IChpbmRleDogbnVtYmVyKTogTWluaW11bUZlZUJveEJ1aWxkZXIgPT4ge1xuICAgIHRoaXMuZmVlcy5zcGxpY2UoaW5kZXgpO1xuICAgIHJldHVybiB0aGlzO1xuICB9O1xuXG4gIC8qKlxuICAgKiBzZXRzIEVyZ29Cb3ggRXJnIHZhbHVlXG4gICAqIEBwYXJhbSBuYW5vRXJnXG4gICAqIEByZXR1cm5zXG4gICAqL1xuICBzZXRWYWx1ZSA9IChuYW5vRXJnOiBiaWdpbnQpOiBNaW5pbXVtRmVlQm94QnVpbGRlciA9PiB7XG4gICAgdGhpcy5ib3hWYWx1ZSA9IEJveFZhbHVlLmZyb21faTY0KEk2NC5mcm9tX3N0cihuYW5vRXJnLnRvU3RyaW5nKCkpKTtcbiAgICByZXR1cm4gdGhpcztcbiAgfTtcblxuICAvKipcbiAgICogc2V0cyBFcmdvQm94IGNyZWF0aW9uaGVpZ2h0XG4gICAqIEBwYXJhbSBjdXJyZW50SGVpZ2h0XG4gICAqL1xuICBzZXRIZWlnaHQgPSAoY3VycmVudEhlaWdodDogbnVtYmVyKTogTWluaW11bUZlZUJveEJ1aWxkZXIgPT4ge1xuICAgIHRoaXMuYm94aGVpZ2h0ID0gY3VycmVudEhlaWdodDtcbiAgICByZXR1cm4gdGhpcztcbiAgfTtcblxuICAvKipcbiAgICogc2V0cyBjb25maWcgdG9rZW4gaWRcbiAgICogQHBhcmFtIHRva2VuSWRcbiAgICovXG4gIHNldFRva2VuID0gKHRva2VuSWQ6IHN0cmluZyk6IE1pbmltdW1GZWVCb3hCdWlsZGVyID0+IHtcbiAgICB0aGlzLnRva2VuSWQgPSB0b2tlbklkO1xuICAgIHJldHVybiB0aGlzO1xuICB9O1xuXG4gIC8qKlxuICAgKiB2YWxpZGF0ZXMgc29tZSBvZiBzcGVjaWZpZWQgY29uZmlnc1xuICAgKi9cbiAgcHJvdGVjdGVkIHZhbGlkYXRlID0gKCk6IHZvaWQgPT4ge1xuICAgIGlmICghdGhpcy5ib3hWYWx1ZSlcbiAgICAgIHRocm93IG5ldyBJbnZhbGlkQ29uZmlnKGBCb3ggdmFsdWUgYXJndW1lbnQgaXMgbm90IGRlZmluZWRgKTtcbiAgICBpZiAoIXRoaXMuYm94aGVpZ2h0KVxuICAgICAgdGhyb3cgbmV3IEludmFsaWRDb25maWcoYEJveCBjcmVhdGlvbiBoZWlnaHQgYXJndW1lbnQgaXMgbm90IGRlZmluZWRgKTtcbiAgICBpZiAoIXRoaXMudG9rZW5JZClcbiAgICAgIHRocm93IG5ldyBJbnZhbGlkQ29uZmlnKGBDb25maWcgdG9rZW4gaWQgaXMgbm90IGRlZmluZWRgKTtcbiAgICBpZiAodGhpcy5mZWVzLmxlbmd0aCA9PT0gMClcbiAgICAgIHRocm93IG5ldyBJbnZhbGlkQ29uZmlnKFxuICAgICAgICBgTm8gY29uZmlnIGFkZGVkLiBQbGVhc2UgYWRkIGF0IGxlYXN0IG9uZSBjb25maWdgXG4gICAgICApO1xuXG4gICAgZm9yIChsZXQgaSA9IDA7IGkgPCB0aGlzLmZlZXMubGVuZ3RoIC0gMTsgaSsrKSB7XG4gICAgICBjb25zdCBjaGFpbnMgPSBPYmplY3Qua2V5cyh0aGlzLmZlZXNbMF0uaGVpZ2h0cyk7XG4gICAgICBjaGFpbnMuZm9yRWFjaCgoY2hhaW4pID0+IHtcbiAgICAgICAgaWYgKCF0aGlzLmZlZXNbaSArIDFdLmhlaWdodHNbY2hhaW5dKVxuICAgICAgICAgIHRocm93IG5ldyBJbnZhbGlkQ29uZmlnKFxuICAgICAgICAgICAgYEV4cGVjdGVkIGNoYWluIFske2NoYWlufV0gYXQgaW5kZXggWyR7aSArIDF9XWBcbiAgICAgICAgICApO1xuICAgICAgICBpZiAodGhpcy5mZWVzW2kgKyAxXS5oZWlnaHRzW2NoYWluXSA8IHRoaXMuZmVlc1tpXS5oZWlnaHRzW2NoYWluXSlcbiAgICAgICAgICB0aHJvdyBuZXcgSW52YWxpZENvbmZpZyhcbiAgICAgICAgICAgIGBBbGwgaGVpZ2h0cyBmb3IgYSBjaGFpbiBzaG91bGQgYmUgYXNjZW5kaW5nLiBIZWlnaHRzIG9mIGNoYWluIFske2NoYWlufV0gYXQgaW5kZXhlcyBbJHtpfSwke1xuICAgICAgICAgICAgICBpICsgMVxuICAgICAgICAgICAgfV0gYXJlIGludmFsaWQgWyR7dGhpcy5mZWVzW2kgKyAxXS5oZWlnaHRzW2NoYWluXX0gPCAke1xuICAgICAgICAgICAgICB0aGlzLmZlZXNbaV0uaGVpZ2h0c1tjaGFpbl1cbiAgICAgICAgICAgIH1dYFxuICAgICAgICAgICk7XG4gICAgICB9KTtcbiAgICB9XG4gIH07XG5cbiAgLyoqXG4gICAqIHZhbGlkYXRlcyBzcGVjaWZpZWQgY29uZmlncyBhbmQgYnVpbGRzIEVyZ29Cb3hDYW5kaWRhdGUgb2YgY29uZmlnIGJveCB1c2luZyB0aGVtXG4gICAqL1xuICBidWlsZCA9ICgpOiBFcmdvQm94Q2FuZGlkYXRlID0+IHtcbiAgICB0aGlzLnZhbGlkYXRlKCk7XG5cbiAgICAvLyBhZGQgYm94IHZhbHVlLCBhZGRyZXNzIGFuZCBjcmVhdGlvbiBoZWlnaHRcbiAgICBjb25zdCBib3hCdWlsZGVyID0gbmV3IEVyZ29Cb3hDYW5kaWRhdGVCdWlsZGVyKFxuICAgICAgdGhpcy5ib3hWYWx1ZSxcbiAgICAgIENvbnRyYWN0Lm5ldyhBZGRyZXNzLmZyb21fYmFzZTU4KHRoaXMuYWRkcmVzcykudG9fZXJnb190cmVlKCkpLFxuICAgICAgdGhpcy5ib3hoZWlnaHRcbiAgICApO1xuXG4gICAgLy8gYWRkIGJveCB0b2tlbnNcbiAgICBib3hCdWlsZGVyLmFkZF90b2tlbihcbiAgICAgIFRva2VuSWQuZnJvbV9zdHIodGhpcy5taW5pbXVtRmVlTkZUKSxcbiAgICAgIFRva2VuQW1vdW50LmZyb21faTY0KEk2NC5mcm9tX3N0cignMScpKVxuICAgICk7XG4gICAgaWYgKHRoaXMudG9rZW5JZCAhPT0gRVJHT19OQVRJVkVfVE9LRU4pXG4gICAgICBib3hCdWlsZGVyLmFkZF90b2tlbihcbiAgICAgICAgVG9rZW5JZC5mcm9tX3N0cih0aGlzLnRva2VuSWQpLFxuICAgICAgICBUb2tlbkFtb3VudC5mcm9tX2k2NChJNjQuZnJvbV9zdHIoJzEnKSlcbiAgICAgICk7XG5cbiAgICAvLyBnZW5lcmF0ZSByZWdpc3RlciB2YWx1ZXNcbiAgICAvLyAgZXh0cmFjdCBjaGFpbnNcbiAgICBjb25zdCBjaGFpbnM6IEFycmF5PHN0cmluZz4gPSBbXTtcbiAgICB0aGlzLmZlZXMuZm9yRWFjaCgoZmVlKSA9PiB7XG4gICAgICBPYmplY3Qua2V5cyhmZWUuaGVpZ2h0cykuZm9yRWFjaCgoZmVlQ2hhaW4pID0+IHtcbiAgICAgICAgaWYgKCFjaGFpbnMuaW5jbHVkZXMoZmVlQ2hhaW4pKSBjaGFpbnMucHVzaChmZWVDaGFpbik7XG4gICAgICB9KTtcbiAgICB9KTtcbiAgICBjaGFpbnMuc29ydCgpO1xuICAgIC8vICBleHRyYWN0IGNvbmZpZ3NcbiAgICBjb25zdCBoZWlnaHRzOiBBcnJheTxBcnJheTxudW1iZXI+PiA9IFtdO1xuICAgIGNvbnN0IGJyZGlnZUZlZXM6IEFycmF5PEFycmF5PHN0cmluZz4+ID0gW107XG4gICAgY29uc3QgbmV0d29ya0ZlZXM6IEFycmF5PEFycmF5PHN0cmluZz4+ID0gW107XG4gICAgY29uc3QgcnNuUmF0aW9zOiBBcnJheTxBcnJheTxBcnJheTxzdHJpbmc+Pj4gPSBbXTtcbiAgICBjb25zdCBmZWVSYXRpb3M6IEFycmF5PEFycmF5PHN0cmluZz4+ID0gW107XG4gICAgdGhpcy5mZWVzLmZvckVhY2goKGZlZSkgPT4ge1xuICAgICAgY29uc3QgaGVpZ2h0c0NvbmZpZ3M6IEFycmF5PG51bWJlcj4gPSBbXTtcbiAgICAgIGNvbnN0IGJyZGlnZUZlZXNDb25maWdzOiBBcnJheTxzdHJpbmc+ID0gW107XG4gICAgICBjb25zdCBuZXR3b3JrRmVlc0NvbmZpZ3M6IEFycmF5PHN0cmluZz4gPSBbXTtcbiAgICAgIGNvbnN0IHJzblJhdGlvc0NvbmZpZ3M6IEFycmF5PEFycmF5PHN0cmluZz4+ID0gW107XG4gICAgICBjb25zdCBmZWVSYXRpb3NDb25maWdzOiBBcnJheTxzdHJpbmc+ID0gW107XG5cbiAgICAgIGNoYWlucy5mb3JFYWNoKChjaGFpbikgPT4ge1xuICAgICAgICBpZiAoT2JqZWN0Lmhhc093bihmZWUuaGVpZ2h0cywgY2hhaW4pKVxuICAgICAgICAgIGhlaWdodHNDb25maWdzLnB1c2goZmVlLmhlaWdodHNbY2hhaW5dKTtcbiAgICAgICAgZWxzZSBoZWlnaHRzQ29uZmlncy5wdXNoKC0xKTtcblxuICAgICAgICBpZiAoT2JqZWN0Lmhhc093bihmZWUuY29uZmlncywgY2hhaW4pKSB7XG4gICAgICAgICAgYnJkaWdlRmVlc0NvbmZpZ3MucHVzaChmZWUuY29uZmlnc1tjaGFpbl0uYnJpZGdlRmVlLnRvU3RyaW5nKCkpO1xuICAgICAgICAgIG5ldHdvcmtGZWVzQ29uZmlncy5wdXNoKGZlZS5jb25maWdzW2NoYWluXS5uZXR3b3JrRmVlLnRvU3RyaW5nKCkpO1xuICAgICAgICAgIHJzblJhdGlvc0NvbmZpZ3MucHVzaChbXG4gICAgICAgICAgICBmZWUuY29uZmlnc1tjaGFpbl0ucnNuUmF0aW8udG9TdHJpbmcoKSxcbiAgICAgICAgICAgIGZlZS5jb25maWdzW2NoYWluXS5yc25SYXRpb0Rpdmlzb3IudG9TdHJpbmcoKSxcbiAgICAgICAgICBdKTtcbiAgICAgICAgICBmZWVSYXRpb3NDb25maWdzLnB1c2goZmVlLmNvbmZpZ3NbY2hhaW5dLmZlZVJhdGlvLnRvU3RyaW5nKCkpO1xuICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgIGJyZGlnZUZlZXNDb25maWdzLnB1c2goJy0xJyk7XG4gICAgICAgICAgbmV0d29ya0ZlZXNDb25maWdzLnB1c2goJy0xJyk7XG4gICAgICAgICAgcnNuUmF0aW9zQ29uZmlncy5wdXNoKFsnLTEnLCAnLTEnXSk7XG4gICAgICAgICAgZmVlUmF0aW9zQ29uZmlncy5wdXNoKCctMScpO1xuICAgICAgICB9XG4gICAgICB9KTtcblxuICAgICAgaGVpZ2h0cy5wdXNoKGhlaWdodHNDb25maWdzKTtcbiAgICAgIGJyZGlnZUZlZXMucHVzaChicmRpZ2VGZWVzQ29uZmlncyk7XG4gICAgICBuZXR3b3JrRmVlcy5wdXNoKG5ldHdvcmtGZWVzQ29uZmlncyk7XG4gICAgICByc25SYXRpb3MucHVzaChyc25SYXRpb3NDb25maWdzKTtcbiAgICAgIGZlZVJhdGlvcy5wdXNoKGZlZVJhdGlvc0NvbmZpZ3MpO1xuICAgIH0pO1xuXG4gICAgLy8gYWRkIGJveCByZWdpc3RlcnNcbiAgICBib3hCdWlsZGVyLnNldF9yZWdpc3Rlcl92YWx1ZShcbiAgICAgIDQsXG4gICAgICBDb25zdGFudC5mcm9tX2NvbGxfY29sbF9ieXRlKGNoYWlucy5tYXAoKGNoYWluKSA9PiBCdWZmZXIuZnJvbShjaGFpbikpKVxuICAgICk7XG4gICAgYm94QnVpbGRlci5zZXRfcmVnaXN0ZXJfdmFsdWUoNSwgQ29uc3RhbnQuZnJvbV9qcyhoZWlnaHRzKSk7XG4gICAgYm94QnVpbGRlci5zZXRfcmVnaXN0ZXJfdmFsdWUoNiwgQ29uc3RhbnQuZnJvbV9qcyhicmRpZ2VGZWVzKSk7XG4gICAgYm94QnVpbGRlci5zZXRfcmVnaXN0ZXJfdmFsdWUoNywgQ29uc3RhbnQuZnJvbV9qcyhuZXR3b3JrRmVlcykpO1xuICAgIGJveEJ1aWxkZXIuc2V0X3JlZ2lzdGVyX3ZhbHVlKDgsIENvbnN0YW50LmZyb21fanMocnNuUmF0aW9zKSk7XG4gICAgYm94QnVpbGRlci5zZXRfcmVnaXN0ZXJfdmFsdWUoOSwgQ29uc3RhbnQuZnJvbV9qcyhmZWVSYXRpb3MpKTtcblxuICAgIHJldHVybiBib3hCdWlsZGVyLmJ1aWxkKCk7XG4gIH07XG59XG4iXX0=
@@ -0,0 +1,22 @@
1
+ import { ChainFee, Fee } from './types';
2
+ export declare class MinimumFeeConfig {
3
+ protected fee: Fee;
4
+ constructor();
5
+ /**
6
+ * sets fee for a chain
7
+ * @param chain
8
+ * @param height
9
+ * @param chainFee
10
+ */
11
+ setChainConfig: (chain: string, height: number, chainFee: ChainFee | undefined) => MinimumFeeConfig;
12
+ /**
13
+ * removes fee for a chain
14
+ * @param chain
15
+ */
16
+ removeChainConfig: (chain: string) => MinimumFeeConfig;
17
+ /**
18
+ * returns generated fee
19
+ */
20
+ getConfig: () => Fee;
21
+ }
22
+ //# sourceMappingURL=MinimumFeeConfig.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"MinimumFeeConfig.d.ts","sourceRoot":"","sources":["../../lib/MinimumFeeConfig.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,GAAG,EAAE,MAAM,SAAS,CAAC;AAExC,qBAAa,gBAAgB;IAC3B,SAAS,CAAC,GAAG,EAAE,GAAG,CAAC;;IASnB;;;;;OAKG;IACH,cAAc,UACL,MAAM,UACL,MAAM,YACJ,QAAQ,GAAG,SAAS,KAC7B,gBAAgB,CAIjB;IAEF;;;OAGG;IACH,iBAAiB,UAAW,MAAM,KAAG,gBAAgB,CAInD;IAEF;;OAEG;IACH,SAAS,QAAO,GAAG,CAEjB;CACH"}