@rosen-bridge/minimum-fee 0.1.12 → 0.1.13-672ee610

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,38 @@
1
+ import { ErgoBox } from 'ergo-lib-wasm-nodejs';
2
+ import { ErgoNetworkType } 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
+ export declare class MinimumFeeBox {
7
+ protected readonly BOX_FETCHING_PAGE_SIZE = 50;
8
+ protected logger: AbstractLogger;
9
+ protected box: ErgoBox;
10
+ protected tokenId: string;
11
+ protected minimumFeeNFT: string;
12
+ protected address: string;
13
+ protected explorerClient: ReturnType<typeof ergoExplorerClientFactory>;
14
+ protected nodeClient: ReturnType<typeof ergoNodeClientFactory>;
15
+ constructor(tokenId: string, minimumFeeNFT: string, address: string, networkType: ErgoNetworkType, networkUrl: string, logger?: AbstractLogger);
16
+ /**
17
+ * fetches the box from the blockchain
18
+ */
19
+ fetchBox: () => Promise<void>;
20
+ /**
21
+ * returns fetched box or throws approprite error if found more or none
22
+ * @param eligibleBoxes
23
+ */
24
+ protected selectEligibleBox: (eligibleBoxes: Array<ErgoBox>) => ErgoBox;
25
+ /**
26
+ * fetches box from the blockchain using explorer client
27
+ */
28
+ protected fetchBoxUsingExplorer: () => Promise<ErgoBox>;
29
+ /**
30
+ * fetches the box from the blockchain using node client
31
+ */
32
+ protected fetchBoxUsingNode: () => Promise<ErgoBox>;
33
+ /**
34
+ * returns fetched config box
35
+ */
36
+ getBox: () => ErgoBox;
37
+ }
38
+ //# 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,MAAM,SAAS,CAAC;AAE1C,OAAO,yBAAyB,MAAM,8BAA8B,CAAC;AACrE,OAAO,qBAEN,MAAM,0BAA0B,CAAC;AAGlC,OAAO,EAAE,cAAc,EAAe,MAAM,gCAAgC,CAAC;AAI7E,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;CAClC"}
@@ -0,0 +1,132 @@
1
+ import { ErgoBox } from 'ergo-lib-wasm-nodejs';
2
+ import { 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
+ const ERGO_NATIVE_TOKEN = 'erg';
10
+ export class MinimumFeeBox {
11
+ BOX_FETCHING_PAGE_SIZE = 50;
12
+ logger;
13
+ box;
14
+ tokenId;
15
+ minimumFeeNFT;
16
+ address;
17
+ explorerClient;
18
+ nodeClient;
19
+ constructor(tokenId, minimumFeeNFT, address, networkType, networkUrl, logger) {
20
+ this.tokenId = tokenId;
21
+ this.minimumFeeNFT = minimumFeeNFT;
22
+ this.address = address;
23
+ if (networkType === ErgoNetworkType.explorer)
24
+ this.explorerClient = ergoExplorerClientFactory(networkUrl);
25
+ else
26
+ this.nodeClient = ergoNodeClientFactory(networkUrl);
27
+ this.logger = logger ? logger : new DummyLogger();
28
+ }
29
+ /**
30
+ * fetches the box from the blockchain
31
+ */
32
+ fetchBox = async () => {
33
+ if (this.explorerClient)
34
+ this.box = await this.fetchBoxUsingExplorer();
35
+ else
36
+ this.box = await this.fetchBoxUsingNode();
37
+ };
38
+ /**
39
+ * returns fetched box or throws approprite error if found more or none
40
+ * @param eligibleBoxes
41
+ */
42
+ selectEligibleBox = (eligibleBoxes) => {
43
+ this.logger.debug(`Found [${eligibleBoxes.length}] minimum-fee boxes: ${JsonBigInt.stringify(eligibleBoxes.map((box) => box.to_json()))}`);
44
+ if (eligibleBoxes.length === 0)
45
+ throw new NotFoundError(`Found no minimum-fee box for token [${this.tokenId}] and address [${this.address}]`);
46
+ else if (eligibleBoxes.length > 1)
47
+ throw new FailedError(`Found [${eligibleBoxes.length}] minimum-fee boxes for token [${this.tokenId}] and address [${this.address}]`);
48
+ else {
49
+ this.logger.debug(`Found minimum-fee box [${eligibleBoxes[0]
50
+ .box_id()
51
+ .to_str()}] for token [${this.tokenId}] and address [${this.address}]`);
52
+ return eligibleBoxes[0];
53
+ }
54
+ };
55
+ /**
56
+ * fetches box from the blockchain using explorer client
57
+ */
58
+ fetchBoxUsingExplorer = async () => {
59
+ const eligibleBoxes = [];
60
+ try {
61
+ let currentPage = 0;
62
+ let boxesPage = await this.explorerClient.v1.getApiV1BoxesUnspentBytokenidP1(this.minimumFeeNFT, {
63
+ offset: currentPage * this.BOX_FETCHING_PAGE_SIZE,
64
+ limit: this.BOX_FETCHING_PAGE_SIZE,
65
+ });
66
+ while (boxesPage.items?.length) {
67
+ this.logger.debug(`requested 'explorerClient.getApiV1BoxesUnspentBytokenidP1' for token [${this.minimumFeeNFT}]. res: ${JsonBigInt.stringify(boxesPage)}`);
68
+ eligibleBoxes.push(...boxesPage.items
69
+ .filter((box) => box.address === this.address && this.tokenId === ERGO_NATIVE_TOKEN
70
+ ? box.assets?.length === 1
71
+ : box.assets?.length === 2 &&
72
+ box.assets?.some((asset) => asset.tokenId === this.tokenId))
73
+ .map((box) => ErgoBox.from_json(JsonBigInt.stringify(box))));
74
+ currentPage++;
75
+ boxesPage =
76
+ await this.explorerClient.v1.getApiV1BoxesUnspentBytokenidP1(this.minimumFeeNFT, {
77
+ offset: currentPage * this.BOX_FETCHING_PAGE_SIZE,
78
+ limit: this.BOX_FETCHING_PAGE_SIZE,
79
+ });
80
+ }
81
+ }
82
+ catch (error) {
83
+ return handleApiError(error, 'Failed to get boxes by token id from Ergo Explorer:');
84
+ }
85
+ return this.selectEligibleBox(eligibleBoxes);
86
+ };
87
+ /**
88
+ * fetches the box from the blockchain using node client
89
+ */
90
+ fetchBoxUsingNode = async () => {
91
+ const eligibleBoxes = [];
92
+ try {
93
+ const boxHasConfigToken = (box) => box.assets?.some((asset) => asset.tokenId === this.minimumFeeNFT);
94
+ const boxHasAppropriateToken = (box) => this.tokenId === ERGO_NATIVE_TOKEN
95
+ ? box.assets?.length === 1
96
+ : box.assets?.length === 2 &&
97
+ box.assets?.some((asset) => asset.tokenId === this.tokenId);
98
+ let currentPage = 0;
99
+ let boxesPage = await this.nodeClient.getBoxesByAddressUnspent(this.address, {
100
+ offset: currentPage * this.BOX_FETCHING_PAGE_SIZE,
101
+ limit: this.BOX_FETCHING_PAGE_SIZE,
102
+ });
103
+ while (boxesPage.length !== 0) {
104
+ this.logger.debug(`requested 'nodeClient.getBoxesByAddressUnspent' for token [${this.minimumFeeNFT}]. res: ${JsonBigInt.stringify(boxesPage)}`);
105
+ eligibleBoxes.push(...boxesPage
106
+ .filter((box) => boxHasConfigToken(box) && boxHasAppropriateToken(box))
107
+ .map((box) => ErgoBox.from_json(JsonBigInt.stringify(box))));
108
+ currentPage++;
109
+ boxesPage = await this.nodeClient.getBoxesByAddressUnspent(this.address, {
110
+ offset: currentPage * this.BOX_FETCHING_PAGE_SIZE,
111
+ limit: this.BOX_FETCHING_PAGE_SIZE,
112
+ });
113
+ }
114
+ }
115
+ catch (error) {
116
+ const baseError = 'Failed to get boxes by token id from Ergo Node:';
117
+ handleApiError(error, baseError, {
118
+ handleRespondedState: (error) => {
119
+ if (error.response.status === 400)
120
+ return;
121
+ throw new FailedError(`${baseError} [${error.response.status}] ${error.response.data.reason}`);
122
+ },
123
+ });
124
+ }
125
+ return this.selectEligibleBox(eligibleBoxes);
126
+ };
127
+ /**
128
+ * returns fetched config box
129
+ */
130
+ getBox = () => this.box;
131
+ }
132
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"MinimumFeeBox.js","sourceRoot":"","sources":["../../lib/MinimumFeeBox.ts"],"names":[],"mappings":"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","sourcesContent":["import { ErgoBox } from 'ergo-lib-wasm-nodejs';\nimport { ErgoNetworkType } from './types';\nimport { FailedError, NotFoundError } from './errors';\nimport ergoExplorerClientFactory from '@rosen-clients/ergo-explorer';\nimport ergoNodeClientFactory, {\n  IndexedErgoBox,\n} from '@rosen-clients/ergo-node';\nimport JsonBigInt from '@rosen-bridge/json-bigint';\nimport handleApiError from './handleApiError';\nimport { AbstractLogger, DummyLogger } from '@rosen-bridge/logger-interface';\n\nconst ERGO_NATIVE_TOKEN = 'erg';\n\nexport class MinimumFeeBox {\n  protected readonly BOX_FETCHING_PAGE_SIZE = 50;\n  protected logger: AbstractLogger;\n  protected box: ErgoBox;\n  protected tokenId: string;\n  protected minimumFeeNFT: string;\n  protected address: string;\n  protected explorerClient: ReturnType<typeof ergoExplorerClientFactory>;\n  protected nodeClient: ReturnType<typeof ergoNodeClientFactory>;\n\n  constructor(\n    tokenId: string,\n    minimumFeeNFT: string,\n    address: string,\n    networkType: ErgoNetworkType,\n    networkUrl: string,\n    logger?: AbstractLogger\n  ) {\n    this.tokenId = tokenId;\n    this.minimumFeeNFT = minimumFeeNFT;\n    this.address = address;\n    if (networkType === ErgoNetworkType.explorer)\n      this.explorerClient = ergoExplorerClientFactory(networkUrl);\n    else this.nodeClient = ergoNodeClientFactory(networkUrl);\n    this.logger = logger ? logger : new DummyLogger();\n  }\n\n  /**\n   * fetches the box from the blockchain\n   */\n  fetchBox = async (): Promise<void> => {\n    if (this.explorerClient) this.box = await this.fetchBoxUsingExplorer();\n    else this.box = await this.fetchBoxUsingNode();\n  };\n\n  /**\n   * returns fetched box or throws approprite error if found more or none\n   * @param eligibleBoxes\n   */\n  protected selectEligibleBox = (eligibleBoxes: Array<ErgoBox>): ErgoBox => {\n    this.logger.debug(\n      `Found [${\n        eligibleBoxes.length\n      }] minimum-fee boxes: ${JsonBigInt.stringify(\n        eligibleBoxes.map((box) => box.to_json())\n      )}`\n    );\n\n    if (eligibleBoxes.length === 0)\n      throw new NotFoundError(\n        `Found no minimum-fee box for token [${this.tokenId}] and address [${this.address}]`\n      );\n    else if (eligibleBoxes.length > 1)\n      throw new FailedError(\n        `Found [${eligibleBoxes.length}] minimum-fee boxes for token [${this.tokenId}] and address [${this.address}]`\n      );\n    else {\n      this.logger.debug(\n        `Found minimum-fee box [${eligibleBoxes[0]\n          .box_id()\n          .to_str()}] for token [${this.tokenId}] and address [${this.address}]`\n      );\n      return eligibleBoxes[0];\n    }\n  };\n\n  /**\n   * fetches box from the blockchain using explorer client\n   */\n  protected fetchBoxUsingExplorer = async (): Promise<ErgoBox> => {\n    const eligibleBoxes: Array<ErgoBox> = [];\n    try {\n      let currentPage = 0;\n      let boxesPage =\n        await this.explorerClient.v1.getApiV1BoxesUnspentBytokenidP1(\n          this.minimumFeeNFT,\n          {\n            offset: currentPage * this.BOX_FETCHING_PAGE_SIZE,\n            limit: this.BOX_FETCHING_PAGE_SIZE,\n          }\n        );\n      while (boxesPage.items?.length) {\n        this.logger.debug(\n          `requested 'explorerClient.getApiV1BoxesUnspentBytokenidP1' for token [${\n            this.minimumFeeNFT\n          }]. res: ${JsonBigInt.stringify(boxesPage)}`\n        );\n\n        eligibleBoxes.push(\n          ...boxesPage.items\n            .filter((box) =>\n              box.address === this.address && this.tokenId === ERGO_NATIVE_TOKEN\n                ? box.assets?.length === 1\n                : box.assets?.length === 2 &&\n                  box.assets?.some((asset) => asset.tokenId === this.tokenId)\n            )\n            .map((box: any) => ErgoBox.from_json(JsonBigInt.stringify(box)))\n        );\n        currentPage++;\n        boxesPage =\n          await this.explorerClient.v1.getApiV1BoxesUnspentBytokenidP1(\n            this.minimumFeeNFT,\n            {\n              offset: currentPage * this.BOX_FETCHING_PAGE_SIZE,\n              limit: this.BOX_FETCHING_PAGE_SIZE,\n            }\n          );\n      }\n    } catch (error) {\n      return handleApiError(\n        error,\n        'Failed to get boxes by token id from Ergo Explorer:'\n      );\n    }\n\n    return this.selectEligibleBox(eligibleBoxes);\n  };\n\n  /**\n   * fetches the box from the blockchain using node client\n   */\n  protected fetchBoxUsingNode = async (): Promise<ErgoBox> => {\n    const eligibleBoxes: Array<ErgoBox> = [];\n    try {\n      const boxHasConfigToken = (box: IndexedErgoBox) =>\n        box.assets?.some((asset) => asset.tokenId === this.minimumFeeNFT);\n      const boxHasAppropriateToken = (box: IndexedErgoBox) =>\n        this.tokenId === ERGO_NATIVE_TOKEN\n          ? box.assets?.length === 1\n          : box.assets?.length === 2 &&\n            box.assets?.some((asset) => asset.tokenId === this.tokenId);\n\n      let currentPage = 0;\n      let boxesPage = await this.nodeClient.getBoxesByAddressUnspent(\n        this.address,\n        {\n          offset: currentPage * this.BOX_FETCHING_PAGE_SIZE,\n          limit: this.BOX_FETCHING_PAGE_SIZE,\n        }\n      );\n      while (boxesPage.length !== 0) {\n        this.logger.debug(\n          `requested 'nodeClient.getBoxesByAddressUnspent' for token [${\n            this.minimumFeeNFT\n          }]. res: ${JsonBigInt.stringify(boxesPage)}`\n        );\n\n        eligibleBoxes.push(\n          ...boxesPage\n            .filter(\n              (box) => boxHasConfigToken(box) && boxHasAppropriateToken(box)\n            )\n            .map((box: IndexedErgoBox) =>\n              ErgoBox.from_json(JsonBigInt.stringify(box))\n            )\n        );\n        currentPage++;\n        boxesPage = await this.nodeClient.getBoxesByAddressUnspent(\n          this.address,\n          {\n            offset: currentPage * this.BOX_FETCHING_PAGE_SIZE,\n            limit: this.BOX_FETCHING_PAGE_SIZE,\n          }\n        );\n      }\n    } catch (error) {\n      const baseError = 'Failed to get boxes by token id from Ergo Node:';\n      handleApiError(error, baseError, {\n        handleRespondedState: (error) => {\n          if (error.response.status === 400) return;\n          throw new FailedError(\n            `${baseError} [${error.response.status}] ${error.response.data.reason}`\n          );\n        },\n      });\n    }\n\n    return this.selectEligibleBox(eligibleBoxes);\n  };\n\n  /**\n   * returns fetched config box\n   */\n  getBox = (): ErgoBox => this.box;\n}\n"]}
@@ -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);
119
+ networkFeesConfigs.push(fee.configs[chain].networkFee);
120
+ rsnRatiosConfigs.push([
121
+ fee.configs[chain].rsnRatio,
122
+ fee.configs[chain].rsnRatioDivisor,
123
+ ]);
124
+ feeRatiosConfigs.push(fee.configs[chain].feeRatio);
125
+ }
126
+ else {
127
+ brdigeFeesConfigs.push(-1n);
128
+ networkFeesConfigs.push(-1n);
129
+ rsnRatiosConfigs.push([-1n, -1n]);
130
+ feeRatiosConfigs.push(-1n);
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,{"version":3,"file":"MinimumFeeBoxBuilder.js","sourceRoot":"","sources":["../../lib/MinimumFeeBoxBuilder.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Address,\n  BoxValue,\n  Contract,\n  ErgoBoxCandidateBuilder,\n  I64,\n  TokenAmount,\n  TokenId,\n  Constant,\n  ErgoBoxCandidate,\n} from 'ergo-lib-wasm-nodejs';\nimport { MinimumFeeConfig } from './MinimumFeeConfig';\nimport { Fee } from './types';\nimport { InvalidConfig } from './errors';\n\nconst ERGO_NATIVE_TOKEN = 'erg';\n\nexport class MinimumFeeBoxBuilder {\n  protected fees: Array<Fee>;\n  protected boxValue: BoxValue;\n  protected boxheight: number;\n  protected tokenId: string;\n  protected minimumFeeNFT: string;\n  protected address: string;\n\n  constructor(minimumFeeNFT: string, address: string) {\n    this.fees = [];\n    this.minimumFeeNFT = minimumFeeNFT;\n    this.address = address;\n  }\n\n  /**\n   * adds a feeConfig\n   * @param feeConfig\n   */\n  addConfig = (feeConfig: MinimumFeeConfig): MinimumFeeBoxBuilder => {\n    this.fees.push(feeConfig.getConfig());\n    return this;\n  };\n\n  /**\n   * removes a config by index\n   * @param index\n   */\n  removeConfig = (index: number): MinimumFeeBoxBuilder => {\n    this.fees.splice(index);\n    return this;\n  };\n\n  /**\n   * sets ErgoBox Erg value\n   * @param nanoErg\n   * @returns\n   */\n  setValue = (nanoErg: bigint): MinimumFeeBoxBuilder => {\n    this.boxValue = BoxValue.from_i64(I64.from_str(nanoErg.toString()));\n    return this;\n  };\n\n  /**\n   * sets ErgoBox creationheight\n   * @param currentHeight\n   */\n  setHeight = (currentHeight: number): MinimumFeeBoxBuilder => {\n    this.boxheight = currentHeight;\n    return this;\n  };\n\n  /**\n   * sets config token id\n   * @param tokenId\n   */\n  setToken = (tokenId: string): MinimumFeeBoxBuilder => {\n    this.tokenId = tokenId;\n    return this;\n  };\n\n  /**\n   * validates some of specified configs\n   */\n  protected validate = (): void => {\n    if (!this.boxValue)\n      throw new InvalidConfig(`Box value argument is not defined`);\n    if (!this.boxheight)\n      throw new InvalidConfig(`Box creation height argument is not defined`);\n    if (!this.tokenId)\n      throw new InvalidConfig(`Config token id is not defined`);\n    if (this.fees.length === 0)\n      throw new InvalidConfig(\n        `No config added. Please add at least one config`\n      );\n\n    for (let i = 0; i < this.fees.length - 1; i++) {\n      const chains = Object.keys(this.fees[0].heights);\n      chains.forEach((chain) => {\n        if (!this.fees[i + 1].heights[chain])\n          throw new InvalidConfig(\n            `Expected chain [${chain}] at index [${i + 1}]`\n          );\n        if (this.fees[i + 1].heights[chain] < this.fees[i].heights[chain])\n          throw new InvalidConfig(\n            `All heights for a chain should be ascending. Heights of chain [${chain}] at indexes [${i},${\n              i + 1\n            }] are invalid [${this.fees[i + 1].heights[chain]} < ${\n              this.fees[i].heights[chain]\n            }]`\n          );\n      });\n    }\n  };\n\n  /**\n   * validates specified configs and builds ErgoBoxCandidate of config box using them\n   */\n  build = (): ErgoBoxCandidate => {\n    this.validate();\n\n    // add box value, address and creation height\n    const boxBuilder = new ErgoBoxCandidateBuilder(\n      this.boxValue,\n      Contract.new(Address.from_base58(this.address).to_ergo_tree()),\n      this.boxheight\n    );\n\n    // add box tokens\n    boxBuilder.add_token(\n      TokenId.from_str(this.minimumFeeNFT),\n      TokenAmount.from_i64(I64.from_str('1'))\n    );\n    if (this.tokenId !== ERGO_NATIVE_TOKEN)\n      boxBuilder.add_token(\n        TokenId.from_str(this.tokenId),\n        TokenAmount.from_i64(I64.from_str('1'))\n      );\n\n    // generate register values\n    //  extract chains\n    const chains: Array<string> = [];\n    this.fees.forEach((fee) => {\n      Object.keys(fee.heights).forEach((feeChain) => {\n        if (!chains.includes(feeChain)) chains.push(feeChain);\n      });\n    });\n    chains.sort();\n    //  extract configs\n    const heights: Array<Array<number>> = [];\n    const brdigeFees: Array<Array<bigint>> = [];\n    const networkFees: Array<Array<bigint>> = [];\n    const rsnRatios: Array<Array<Array<bigint>>> = [];\n    const feeRatios: Array<Array<bigint>> = [];\n    this.fees.forEach((fee) => {\n      const heightsConfigs: Array<number> = [];\n      const brdigeFeesConfigs: Array<bigint> = [];\n      const networkFeesConfigs: Array<bigint> = [];\n      const rsnRatiosConfigs: Array<Array<bigint>> = [];\n      const feeRatiosConfigs: Array<bigint> = [];\n\n      chains.forEach((chain) => {\n        if (Object.hasOwn(fee.heights, chain))\n          heightsConfigs.push(fee.heights[chain]);\n        else heightsConfigs.push(-1);\n\n        if (Object.hasOwn(fee.configs, chain)) {\n          brdigeFeesConfigs.push(fee.configs[chain].bridgeFee);\n          networkFeesConfigs.push(fee.configs[chain].networkFee);\n          rsnRatiosConfigs.push([\n            fee.configs[chain].rsnRatio,\n            fee.configs[chain].rsnRatioDivisor,\n          ]);\n          feeRatiosConfigs.push(fee.configs[chain].feeRatio);\n        } else {\n          brdigeFeesConfigs.push(-1n);\n          networkFeesConfigs.push(-1n);\n          rsnRatiosConfigs.push([-1n, -1n]);\n          feeRatiosConfigs.push(-1n);\n        }\n      });\n\n      heights.push(heightsConfigs);\n      brdigeFees.push(brdigeFeesConfigs);\n      networkFees.push(networkFeesConfigs);\n      rsnRatios.push(rsnRatiosConfigs);\n      feeRatios.push(feeRatiosConfigs);\n    });\n\n    // add box registers\n    boxBuilder.set_register_value(\n      4,\n      Constant.from_coll_coll_byte(chains.map((chain) => Buffer.from(chain)))\n    );\n    boxBuilder.set_register_value(5, Constant.from_js(heights));\n    boxBuilder.set_register_value(6, Constant.from_js(brdigeFees));\n    boxBuilder.set_register_value(7, Constant.from_js(networkFees));\n    boxBuilder.set_register_value(8, Constant.from_js(rsnRatios));\n    boxBuilder.set_register_value(9, Constant.from_js(feeRatios));\n\n    return boxBuilder.build();\n  };\n}\n"]}
@@ -0,0 +1,23 @@
1
+ import { ChainFee, Fee } from './types';
2
+ export declare class MinimumFeeConfig {
3
+ protected fee: Fee;
4
+ readonly feeRatioDivisor: bigint;
5
+ constructor();
6
+ /**
7
+ * sets fee for a chain
8
+ * @param chain
9
+ * @param height
10
+ * @param chainFee
11
+ */
12
+ setChainConfig: (chain: string, height: number, chainFee: ChainFee | undefined) => MinimumFeeConfig;
13
+ /**
14
+ * removes fee for a chain
15
+ * @param chain
16
+ */
17
+ removeChainConfig: (chain: string) => MinimumFeeConfig;
18
+ /**
19
+ * returns generated fee
20
+ */
21
+ getConfig: () => Fee;
22
+ }
23
+ //# 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;IACnB,QAAQ,CAAC,eAAe,EAAE,MAAM,CAAU;;IAS1C;;;;;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"}
@@ -0,0 +1,38 @@
1
+ export class MinimumFeeConfig {
2
+ fee;
3
+ feeRatioDivisor = 10000n;
4
+ constructor() {
5
+ this.fee = {
6
+ heights: {},
7
+ configs: {},
8
+ };
9
+ }
10
+ /**
11
+ * sets fee for a chain
12
+ * @param chain
13
+ * @param height
14
+ * @param chainFee
15
+ */
16
+ setChainConfig = (chain, height, chainFee) => {
17
+ this.fee.heights[chain] = height;
18
+ if (chainFee)
19
+ this.fee.configs[chain] = chainFee;
20
+ return this;
21
+ };
22
+ /**
23
+ * removes fee for a chain
24
+ * @param chain
25
+ */
26
+ removeChainConfig = (chain) => {
27
+ delete this.fee.heights[chain];
28
+ delete this.fee.configs[chain];
29
+ return this;
30
+ };
31
+ /**
32
+ * returns generated fee
33
+ */
34
+ getConfig = () => {
35
+ return this.fee;
36
+ };
37
+ }
38
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiTWluaW11bUZlZUNvbmZpZy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL2xpYi9NaW5pbXVtRmVlQ29uZmlnLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUVBLE1BQU0sT0FBTyxnQkFBZ0I7SUFDakIsR0FBRyxDQUFNO0lBQ1YsZUFBZSxHQUFXLE1BQU0sQ0FBQztJQUUxQztRQUNFLElBQUksQ0FBQyxHQUFHLEdBQUc7WUFDVCxPQUFPLEVBQUUsRUFBRTtZQUNYLE9BQU8sRUFBRSxFQUFFO1NBQ1osQ0FBQztJQUNKLENBQUM7SUFFRDs7Ozs7T0FLRztJQUNILGNBQWMsR0FBRyxDQUNmLEtBQWEsRUFDYixNQUFjLEVBQ2QsUUFBOEIsRUFDWixFQUFFO1FBQ3BCLElBQUksQ0FBQyxHQUFHLENBQUMsT0FBTyxDQUFDLEtBQUssQ0FBQyxHQUFHLE1BQU0sQ0FBQztRQUNqQyxJQUFJLFFBQVE7WUFBRSxJQUFJLENBQUMsR0FBRyxDQUFDLE9BQU8sQ0FBQyxLQUFLLENBQUMsR0FBRyxRQUFRLENBQUM7UUFDakQsT0FBTyxJQUFJLENBQUM7SUFDZCxDQUFDLENBQUM7SUFFRjs7O09BR0c7SUFDSCxpQkFBaUIsR0FBRyxDQUFDLEtBQWEsRUFBb0IsRUFBRTtRQUN0RCxPQUFPLElBQUksQ0FBQyxHQUFHLENBQUMsT0FBTyxDQUFDLEtBQUssQ0FBQyxDQUFDO1FBQy9CLE9BQU8sSUFBSSxDQUFDLEdBQUcsQ0FBQyxPQUFPLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDL0IsT0FBTyxJQUFJLENBQUM7SUFDZCxDQUFDLENBQUM7SUFFRjs7T0FFRztJQUNILFNBQVMsR0FBRyxHQUFRLEVBQUU7UUFDcEIsT0FBTyxJQUFJLENBQUMsR0FBRyxDQUFDO0lBQ2xCLENBQUMsQ0FBQztDQUNIIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ2hhaW5GZWUsIEZlZSB9IGZyb20gJy4vdHlwZXMnO1xuXG5leHBvcnQgY2xhc3MgTWluaW11bUZlZUNvbmZpZyB7XG4gIHByb3RlY3RlZCBmZWU6IEZlZTtcbiAgcmVhZG9ubHkgZmVlUmF0aW9EaXZpc29yOiBiaWdpbnQgPSAxMDAwMG47XG5cbiAgY29uc3RydWN0b3IoKSB7XG4gICAgdGhpcy5mZWUgPSB7XG4gICAgICBoZWlnaHRzOiB7fSxcbiAgICAgIGNvbmZpZ3M6IHt9LFxuICAgIH07XG4gIH1cblxuICAvKipcbiAgICogc2V0cyBmZWUgZm9yIGEgY2hhaW5cbiAgICogQHBhcmFtIGNoYWluXG4gICAqIEBwYXJhbSBoZWlnaHRcbiAgICogQHBhcmFtIGNoYWluRmVlXG4gICAqL1xuICBzZXRDaGFpbkNvbmZpZyA9IChcbiAgICBjaGFpbjogc3RyaW5nLFxuICAgIGhlaWdodDogbnVtYmVyLFxuICAgIGNoYWluRmVlOiBDaGFpbkZlZSB8IHVuZGVmaW5lZFxuICApOiBNaW5pbXVtRmVlQ29uZmlnID0+IHtcbiAgICB0aGlzLmZlZS5oZWlnaHRzW2NoYWluXSA9IGhlaWdodDtcbiAgICBpZiAoY2hhaW5GZWUpIHRoaXMuZmVlLmNvbmZpZ3NbY2hhaW5dID0gY2hhaW5GZWU7XG4gICAgcmV0dXJuIHRoaXM7XG4gIH07XG5cbiAgLyoqXG4gICAqIHJlbW92ZXMgZmVlIGZvciBhIGNoYWluXG4gICAqIEBwYXJhbSBjaGFpblxuICAgKi9cbiAgcmVtb3ZlQ2hhaW5Db25maWcgPSAoY2hhaW46IHN0cmluZyk6IE1pbmltdW1GZWVDb25maWcgPT4ge1xuICAgIGRlbGV0ZSB0aGlzLmZlZS5oZWlnaHRzW2NoYWluXTtcbiAgICBkZWxldGUgdGhpcy5mZWUuY29uZmlnc1tjaGFpbl07XG4gICAgcmV0dXJuIHRoaXM7XG4gIH07XG5cbiAgLyoqXG4gICAqIHJldHVybnMgZ2VuZXJhdGVkIGZlZVxuICAgKi9cbiAgZ2V0Q29uZmlnID0gKCk6IEZlZSA9PiB7XG4gICAgcmV0dXJuIHRoaXMuZmVlO1xuICB9O1xufVxuIl19
@@ -0,0 +1,16 @@
1
+ export declare class InvalidConfig extends Error {
2
+ constructor(msg: string);
3
+ }
4
+ export declare class FailedError extends Error {
5
+ constructor(msg: string);
6
+ }
7
+ export declare class NetworkError extends Error {
8
+ constructor(msg: string);
9
+ }
10
+ export declare class UnexpectedApiError extends Error {
11
+ constructor(msg: string);
12
+ }
13
+ export declare class NotFoundError extends Error {
14
+ constructor(msg: string);
15
+ }
16
+ //# sourceMappingURL=errors.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"errors.d.ts","sourceRoot":"","sources":["../../lib/errors.ts"],"names":[],"mappings":"AAAA,qBAAa,aAAc,SAAQ,KAAK;gBAC1B,GAAG,EAAE,MAAM;CAGxB;AAED,qBAAa,WAAY,SAAQ,KAAK;gBACxB,GAAG,EAAE,MAAM;CAGxB;AAED,qBAAa,YAAa,SAAQ,KAAK;gBACzB,GAAG,EAAE,MAAM;CAGxB;AAED,qBAAa,kBAAmB,SAAQ,KAAK;gBAC/B,GAAG,EAAE,MAAM;CAGxB;AAED,qBAAa,aAAc,SAAQ,KAAK;gBAC1B,GAAG,EAAE,MAAM;CAGxB"}
@@ -0,0 +1,26 @@
1
+ export class InvalidConfig extends Error {
2
+ constructor(msg) {
3
+ super('InvalidConfig: ' + msg);
4
+ }
5
+ }
6
+ export class FailedError extends Error {
7
+ constructor(msg) {
8
+ super('FailedError: ' + msg);
9
+ }
10
+ }
11
+ export class NetworkError extends Error {
12
+ constructor(msg) {
13
+ super('NetworkError: ' + msg);
14
+ }
15
+ }
16
+ export class UnexpectedApiError extends Error {
17
+ constructor(msg) {
18
+ super('UnexpectedApiError: ' + msg);
19
+ }
20
+ }
21
+ export class NotFoundError extends Error {
22
+ constructor(msg) {
23
+ super('NotFoundError: ' + msg);
24
+ }
25
+ }
26
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXJyb3JzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vbGliL2Vycm9ycy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxNQUFNLE9BQU8sYUFBYyxTQUFRLEtBQUs7SUFDdEMsWUFBWSxHQUFXO1FBQ3JCLEtBQUssQ0FBQyxpQkFBaUIsR0FBRyxHQUFHLENBQUMsQ0FBQztJQUNqQyxDQUFDO0NBQ0Y7QUFFRCxNQUFNLE9BQU8sV0FBWSxTQUFRLEtBQUs7SUFDcEMsWUFBWSxHQUFXO1FBQ3JCLEtBQUssQ0FBQyxlQUFlLEdBQUcsR0FBRyxDQUFDLENBQUM7SUFDL0IsQ0FBQztDQUNGO0FBRUQsTUFBTSxPQUFPLFlBQWEsU0FBUSxLQUFLO0lBQ3JDLFlBQVksR0FBVztRQUNyQixLQUFLLENBQUMsZ0JBQWdCLEdBQUcsR0FBRyxDQUFDLENBQUM7SUFDaEMsQ0FBQztDQUNGO0FBRUQsTUFBTSxPQUFPLGtCQUFtQixTQUFRLEtBQUs7SUFDM0MsWUFBWSxHQUFXO1FBQ3JCLEtBQUssQ0FBQyxzQkFBc0IsR0FBRyxHQUFHLENBQUMsQ0FBQztJQUN0QyxDQUFDO0NBQ0Y7QUFFRCxNQUFNLE9BQU8sYUFBYyxTQUFRLEtBQUs7SUFDdEMsWUFBWSxHQUFXO1FBQ3JCLEtBQUssQ0FBQyxpQkFBaUIsR0FBRyxHQUFHLENBQUMsQ0FBQztJQUNqQyxDQUFDO0NBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgY2xhc3MgSW52YWxpZENvbmZpZyBleHRlbmRzIEVycm9yIHtcbiAgY29uc3RydWN0b3IobXNnOiBzdHJpbmcpIHtcbiAgICBzdXBlcignSW52YWxpZENvbmZpZzogJyArIG1zZyk7XG4gIH1cbn1cblxuZXhwb3J0IGNsYXNzIEZhaWxlZEVycm9yIGV4dGVuZHMgRXJyb3Ige1xuICBjb25zdHJ1Y3Rvcihtc2c6IHN0cmluZykge1xuICAgIHN1cGVyKCdGYWlsZWRFcnJvcjogJyArIG1zZyk7XG4gIH1cbn1cblxuZXhwb3J0IGNsYXNzIE5ldHdvcmtFcnJvciBleHRlbmRzIEVycm9yIHtcbiAgY29uc3RydWN0b3IobXNnOiBzdHJpbmcpIHtcbiAgICBzdXBlcignTmV0d29ya0Vycm9yOiAnICsgbXNnKTtcbiAgfVxufVxuXG5leHBvcnQgY2xhc3MgVW5leHBlY3RlZEFwaUVycm9yIGV4dGVuZHMgRXJyb3Ige1xuICBjb25zdHJ1Y3Rvcihtc2c6IHN0cmluZykge1xuICAgIHN1cGVyKCdVbmV4cGVjdGVkQXBpRXJyb3I6ICcgKyBtc2cpO1xuICB9XG59XG5cbmV4cG9ydCBjbGFzcyBOb3RGb3VuZEVycm9yIGV4dGVuZHMgRXJyb3Ige1xuICBjb25zdHJ1Y3Rvcihtc2c6IHN0cmluZykge1xuICAgIHN1cGVyKCdOb3RGb3VuZEVycm9yOiAnICsgbXNnKTtcbiAgfVxufVxuIl19
@@ -0,0 +1,18 @@
1
+ interface ErrorHandler<HandlerReturnType> {
2
+ (error: any): HandlerReturnType;
3
+ }
4
+ /**
5
+ * handle an axios api error, considering different kinds of events which may
6
+ * cause it
7
+ * @param error the error object
8
+ * @param baseMessage string to prepend the actual error message
9
+ * @param overrideHandlers an object for overriding how different kinds of error
10
+ * are handled
11
+ */
12
+ declare const handleApiError: <RespondedStateHandlerReturnType = never, NotRespondedStateHandlerReturnType = never, UnknownStateHandlerReturnType = never>(error: any, baseMessage: string, overrideHandlers?: {
13
+ handleRespondedState?: ErrorHandler<RespondedStateHandlerReturnType> | undefined;
14
+ handleNotRespondedState?: ErrorHandler<NotRespondedStateHandlerReturnType> | undefined;
15
+ handleUnknownState?: ErrorHandler<UnknownStateHandlerReturnType> | undefined;
16
+ } | undefined) => RespondedStateHandlerReturnType | NotRespondedStateHandlerReturnType | UnknownStateHandlerReturnType;
17
+ export default handleApiError;
18
+ //# sourceMappingURL=handleApiError.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"handleApiError.d.ts","sourceRoot":"","sources":["../../lib/handleApiError.ts"],"names":[],"mappings":"AAEA,UAAU,YAAY,CAAC,iBAAiB;IACtC,CAAC,KAAK,EAAE,GAAG,GAAG,iBAAiB,CAAC;CACjC;AAED;;;;;;;GAOG;AACH,QAAA,MAAM,cAAc,sIAKX,GAAG,eACG,MAAM;;;;sHAoCpB,CAAC;AAEF,eAAe,cAAc,CAAC"}