@trustvc/trustvc 2.4.2 → 2.5.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.
Files changed (44) hide show
  1. package/dist/cjs/token-registry-functions/utils.js +2 -2
  2. package/dist/cjs/utils/analytics/analytics.js +45 -0
  3. package/dist/cjs/utils/analytics/index.js +12 -0
  4. package/dist/cjs/utils/errorMessages/VerificationErrorMessages.js +105 -0
  5. package/dist/cjs/utils/errorMessages/index.js +22 -2
  6. package/dist/cjs/utils/fragment/index.js +49 -12
  7. package/dist/cjs/utils/gasStation/index.js +65 -13
  8. package/dist/cjs/utils/index.js +7 -0
  9. package/dist/cjs/utils/network/index.js +15 -9
  10. package/dist/cjs/utils/static/icons.js +13 -0
  11. package/dist/cjs/utils/supportedChains/index.js +183 -8
  12. package/dist/esm/token-registry-functions/utils.js +1 -1
  13. package/dist/esm/utils/analytics/analytics.js +39 -0
  14. package/dist/esm/utils/analytics/index.js +1 -0
  15. package/dist/esm/utils/errorMessages/VerificationErrorMessages.js +102 -0
  16. package/dist/esm/utils/errorMessages/index.js +1 -1
  17. package/dist/esm/utils/fragment/index.js +48 -10
  18. package/dist/esm/utils/gasStation/index.js +62 -1
  19. package/dist/esm/utils/index.js +1 -0
  20. package/dist/esm/utils/network/index.js +16 -1
  21. package/dist/esm/utils/static/icons.js +7 -0
  22. package/dist/esm/utils/supportedChains/index.js +184 -1
  23. package/dist/types/index.d.ts +5 -4
  24. package/dist/types/token-registry-functions/index.d.ts +3 -1
  25. package/dist/types/token-registry-functions/mint.d.ts +3 -1
  26. package/dist/types/token-registry-functions/ownerOf.d.ts +3 -1
  27. package/dist/types/token-registry-functions/rejectTransfers.d.ts +3 -1
  28. package/dist/types/token-registry-functions/returnToken.d.ts +3 -1
  29. package/dist/types/token-registry-functions/transfer.d.ts +3 -1
  30. package/dist/types/token-registry-functions/types.d.ts +3 -1
  31. package/dist/types/token-registry-functions/utils.d.ts +3 -1
  32. package/dist/types/token-registry-v5/typedContractMethod.d.ts +1 -4
  33. package/dist/types/utils/analytics/analytics.d.ts +17 -0
  34. package/dist/types/utils/analytics/index.d.ts +1 -0
  35. package/dist/types/utils/documents/index.d.ts +4 -1
  36. package/dist/types/utils/errorMessages/VerificationErrorMessages.d.ts +102 -0
  37. package/dist/types/utils/errorMessages/types.d.ts +1 -1
  38. package/dist/types/utils/fragment/index.d.ts +13 -2
  39. package/dist/types/utils/gasStation/index.d.ts +12 -1
  40. package/dist/types/utils/index.d.ts +6 -4
  41. package/dist/types/utils/network/index.d.ts +6 -1
  42. package/dist/types/utils/static/icons.d.ts +7 -0
  43. package/dist/types/utils/supportedChains/index.d.ts +38 -1
  44. package/package.json +5 -2
@@ -1,12 +1,187 @@
1
1
  'use strict';
2
2
 
3
- var supportedChains = require('@tradetrust-tt/tradetrust-utils/constants/supportedChains');
3
+ require('dotenv/config');
4
+ var gasStation = require('../gasStation');
5
+ var icons = require('../static/icons');
4
6
 
7
+ var CHAIN_ID = /* @__PURE__ */ ((CHAIN_ID2) => {
8
+ CHAIN_ID2["local"] = "1337";
9
+ CHAIN_ID2["mainnet"] = "1";
10
+ CHAIN_ID2["matic"] = "137";
11
+ CHAIN_ID2["amoy"] = "80002";
12
+ CHAIN_ID2["sepolia"] = "11155111";
13
+ CHAIN_ID2["xdc"] = "50";
14
+ CHAIN_ID2["xdcapothem"] = "51";
15
+ CHAIN_ID2["stabilitytestnet"] = "20180427";
16
+ CHAIN_ID2["stability"] = "101010";
17
+ CHAIN_ID2["astron"] = "1338";
18
+ CHAIN_ID2["astrontestnet"] = "21002";
19
+ return CHAIN_ID2;
20
+ })(CHAIN_ID || {});
21
+ const SUPPORTED_CHAINS = {
22
+ ["1337" /* local */]: {
23
+ id: "1337" /* local */,
24
+ label: "Local",
25
+ name: "local",
26
+ type: "development",
27
+ currency: "ETH",
28
+ iconImage: icons.iconEthereum,
29
+ explorerUrl: "https://localhost/explorer",
30
+ rpcUrl: "http://localhost:8545"
31
+ },
32
+ ["1" /* mainnet */]: {
33
+ id: "1" /* mainnet */,
34
+ label: "Mainnet",
35
+ name: "mainnet",
36
+ type: "production",
37
+ currency: "ETH",
38
+ iconImage: icons.iconEthereum,
39
+ explorerUrl: "https://etherscan.io",
40
+ rpcUrl: `https://mainnet.infura.io/v3/${process.env.INFURA_API_KEY}`
41
+ },
42
+ ["137" /* matic */]: {
43
+ id: "137" /* matic */,
44
+ label: "Polygon",
45
+ name: "matic",
46
+ type: "production",
47
+ currency: "MATIC",
48
+ iconImage: icons.iconPolygon,
49
+ explorerUrl: "https://polygonscan.com",
50
+ rpcUrl: `https://polygon-mainnet.infura.io/v3/${process.env.INFURA_API_KEY}`,
51
+ gasStation: gasStation.gasStation("https://gasstation.polygon.technology/v2"),
52
+ nativeCurrency: {
53
+ name: "MATIC",
54
+ symbol: "MATIC",
55
+ decimals: 18
56
+ }
57
+ },
58
+ ["80002" /* amoy */]: {
59
+ id: "80002" /* amoy */,
60
+ label: "Polygon Amoy",
61
+ name: "amoy",
62
+ type: "test",
63
+ currency: "MATIC",
64
+ iconImage: icons.iconPolygon,
65
+ explorerUrl: "https://www.oklink.com/amoy",
66
+ explorerApiUrl: `https://www.oklink.com/${process.env.OKLINK_API_KEY}`,
67
+ rpcUrl: `https://polygon-amoy.infura.io/v3/${process.env.INFURA_API_KEY}`,
68
+ gasStation: gasStation.gasStation("https://gasstation-testnet.polygon.technology/amoy"),
69
+ nativeCurrency: {
70
+ name: "MATIC",
71
+ symbol: "aMATIC",
72
+ decimals: 18
73
+ }
74
+ },
75
+ ["11155111" /* sepolia */]: {
76
+ id: "11155111" /* sepolia */,
77
+ label: "Sepolia",
78
+ name: "sepolia",
79
+ type: "test",
80
+ currency: "ETH",
81
+ iconImage: icons.iconEthereum,
82
+ explorerUrl: "https://sepolia.etherscan.io",
83
+ rpcUrl: `https://sepolia.infura.io/v3/${process.env.INFURA_API_KEY}`,
84
+ nativeCurrency: {
85
+ name: "ETH",
86
+ symbol: "sepETH",
87
+ decimals: 18
88
+ }
89
+ },
90
+ ["50" /* xdc */]: {
91
+ id: "50" /* xdc */,
92
+ label: "XDC Network",
93
+ name: "xdc",
94
+ type: "production",
95
+ currency: "XDC",
96
+ iconImage: icons.iconXDC,
97
+ explorerUrl: "https://xdcscan.io",
98
+ rpcUrl: "https://rpc.ankr.com/xdc",
99
+ nativeCurrency: {
100
+ name: "XDC",
101
+ symbol: "XDC",
102
+ decimals: 18
103
+ }
104
+ },
105
+ ["51" /* xdcapothem */]: {
106
+ id: "51" /* xdcapothem */,
107
+ label: "Apothem Network",
108
+ name: "xdcapothem",
109
+ type: "test",
110
+ currency: "XDC",
111
+ iconImage: icons.iconXDC,
112
+ explorerUrl: "https://apothem.xdcscan.io",
113
+ rpcUrl: "https://rpc.ankr.com/xdc_testnet",
114
+ nativeCurrency: {
115
+ name: "XDC",
116
+ symbol: "XDC",
117
+ decimals: 18
118
+ }
119
+ },
120
+ ["20180427" /* stabilitytestnet */]: {
121
+ id: "20180427" /* stabilitytestnet */,
122
+ label: "Stability Testnet Network",
123
+ name: "stabilitytestnet",
124
+ type: "test",
125
+ currency: "FREE",
126
+ iconImage: icons.iconStability,
127
+ explorerUrl: "https://stability-testnet.blockscout.com/",
128
+ rpcUrl: `https://rpc.testnet.stabilityprotocol.com/zgt/${process.env.STABILITY_TESTNET_API_KEY}`,
129
+ gasStation: gasStation.gasStation("https://rpc.testnet.stabilityprotocol.com/gas-station"),
130
+ nativeCurrency: {
131
+ name: "FREE",
132
+ symbol: "FREE",
133
+ decimals: 18
134
+ }
135
+ },
136
+ ["101010" /* stability */]: {
137
+ id: "101010" /* stability */,
138
+ label: "Stability Network",
139
+ name: "stability",
140
+ type: "production",
141
+ currency: "FREE",
142
+ iconImage: icons.iconStability,
143
+ explorerUrl: "https://stability.blockscout.com/",
144
+ rpcUrl: `https://rpc.stabilityprotocol.com/zgt/${process.env.STABILITY_API_KEY}`,
145
+ gasStation: gasStation.gasStation("https://rpc.stabilityprotocol.com/gas-station"),
146
+ nativeCurrency: {
147
+ name: "FREE",
148
+ symbol: "FREE",
149
+ decimals: 18
150
+ }
151
+ },
152
+ ["1338" /* astron */]: {
153
+ id: "1338" /* astron */,
154
+ label: "Astron Network",
155
+ name: "astron",
156
+ type: "production",
157
+ currency: "ASTRON",
158
+ iconImage: icons.iconAstron,
159
+ explorerUrl: "https://astronscanl2.bitfactory.cn/",
160
+ rpcUrl: `https://astronlayer2.bitfactory.cn/rpc/`,
161
+ gasStation: gasStation.gasStation("https://astronscanl2.bitfactory.cn/gas-station"),
162
+ nativeCurrency: {
163
+ name: "ASTRON",
164
+ symbol: "ASTRON",
165
+ decimals: 18
166
+ }
167
+ },
168
+ ["21002" /* astrontestnet */]: {
169
+ id: "21002" /* astrontestnet */,
170
+ label: "Astron Testnet Network",
171
+ name: "astrontestnet",
172
+ type: "test",
173
+ currency: "ASTRON",
174
+ iconImage: icons.iconAstron,
175
+ explorerUrl: "https://dev-astronscanl2.bitfactory.cn/",
176
+ rpcUrl: `https://dev-astronlayer2.bitfactory.cn/query/`,
177
+ gasStation: gasStation.gasStation("https://dev-astronscanl2.bitfactory.cn/gas-station"),
178
+ nativeCurrency: {
179
+ name: "ASTRONTEST",
180
+ symbol: "ASTRONTEST",
181
+ decimals: 18
182
+ }
183
+ }
184
+ };
5
185
 
6
-
7
- Object.keys(supportedChains).forEach(function (k) {
8
- if (k !== 'default' && !Object.prototype.hasOwnProperty.call(exports, k)) Object.defineProperty(exports, k, {
9
- enumerable: true,
10
- get: function () { return supportedChains[k]; }
11
- });
12
- });
186
+ exports.CHAIN_ID = CHAIN_ID;
187
+ exports.SUPPORTED_CHAINS = SUPPORTED_CHAINS;
@@ -1,5 +1,5 @@
1
1
  import { isV6EthersProvider } from '../utils/ethers';
2
- import { SUPPORTED_CHAINS } from '@tradetrust-tt/tradetrust-utils';
2
+ import { SUPPORTED_CHAINS } from '../utils';
3
3
 
4
4
  var __defProp = Object.defineProperty;
5
5
  var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
@@ -0,0 +1,39 @@
1
+ var __defProp = Object.defineProperty;
2
+ var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
3
+ const validateGtag = /* @__PURE__ */ __name(() => {
4
+ const isInit = typeof gtag === "function";
5
+ if (!isInit) console.warn("gtag is not initialised");
6
+ return isInit;
7
+ }, "validateGtag");
8
+ const validatePageViewEvent = /* @__PURE__ */ __name((gaEvent2) => {
9
+ const { action } = gaEvent2;
10
+ if (!action) console.error("Action is required");
11
+ if (action && typeof action !== "string") console.error("Action must be a string");
12
+ }, "validatePageViewEvent");
13
+ const gaPageView = /* @__PURE__ */ __name((gaEvent2, gaId) => {
14
+ if (!validateGtag()) return;
15
+ validatePageViewEvent(gaEvent2);
16
+ const { action } = gaEvent2;
17
+ gtag("event", action, {
18
+ send_to: gaId
19
+ });
20
+ }, "gaPageView");
21
+ const validateGaEvent = /* @__PURE__ */ __name((gaEvent2) => {
22
+ const { action, category, label, value } = gaEvent2;
23
+ if (!category) console.error("Category is required");
24
+ if (!action) console.error("Action is required");
25
+ if (label && typeof label !== "string") console.error("Label must be a string");
26
+ if (value && typeof value !== "number") console.error("Value must be a number");
27
+ }, "validateGaEvent");
28
+ const gaEvent = /* @__PURE__ */ __name((gaEvent2) => {
29
+ if (!validateGtag()) return;
30
+ validateGaEvent(gaEvent2);
31
+ const { action, category, label, value } = gaEvent2;
32
+ gtag("event", action, {
33
+ event_category: category,
34
+ event_label: label,
35
+ value
36
+ });
37
+ }, "gaEvent");
38
+
39
+ export { gaEvent, gaPageView, validateGaEvent, validateGtag, validatePageViewEvent };
@@ -0,0 +1 @@
1
+ export * from './analytics';
@@ -0,0 +1,102 @@
1
+ const TYPES = {
2
+ REVOKED: "REVOKED",
3
+ SUSPENDED: "SUSPENDED",
4
+ ISSUED: "ISSUED",
5
+ HASH: "HASH",
6
+ IDENTITY: "IDENTITY",
7
+ INVALID: "INVALID",
8
+ ADDRESS_INVALID: "ADDRESS_INVALID",
9
+ NETWORK_INVALID: "NETWORK_INVALID",
10
+ NETWORK_MISMATCH_MAINNET: "NETWORK_MISMATCH_MAINNET",
11
+ NETWORK_MISMATCH_TESTNET: "NETWORK_MISMATCH_TESTNET",
12
+ CONTRACT_NOT_FOUND: "CONTRACT_NOT_FOUND",
13
+ INVALID_ARGUMENT: "INVALID_ARGUMENT",
14
+ SERVER_ERROR: "SERVER_ERROR",
15
+ ETHERS_UNHANDLED_ERROR: "ETHERS_UNHANDLED_ERROR",
16
+ CLIENT_NETWORK_ERROR: "CLIENT_NETWORK_ERROR",
17
+ VERIFICATION_ERROR: "VERIFICATION_ERROR"
18
+ };
19
+ const MESSAGES = {
20
+ [TYPES.REVOKED]: {
21
+ failureTitle: "Document revoked",
22
+ successTitle: "Document has not been revoked",
23
+ failureMessage: "This document has been revoked by the issuing authority. Please contact them for more details."
24
+ },
25
+ [TYPES.SUSPENDED]: {
26
+ failureTitle: "Document suspended",
27
+ successTitle: "Document has not been suspended",
28
+ failureMessage: "This document has been suspended by the issuing authority. Please contact them for more details."
29
+ },
30
+ [TYPES.ISSUED]: {
31
+ failureTitle: "Document not issued",
32
+ successTitle: "Document has been issued",
33
+ failureMessage: "This document cannot be found. Please contact your issuing authority for help or issue the document before trying again."
34
+ },
35
+ [TYPES.HASH]: {
36
+ failureTitle: "Document has been tampered with",
37
+ successTitle: "Document has not been tampered with",
38
+ failureMessage: "The contents of this document are inaccurate and have been tampered with."
39
+ },
40
+ [TYPES.IDENTITY]: {
41
+ failureTitle: "Document issuer identity is invalid",
42
+ successTitle: "Document issuer has been identified",
43
+ failureMessage: "This document was issued by an invalid issuer."
44
+ },
45
+ [TYPES.INVALID]: {
46
+ failureTitle: "Document is invalid",
47
+ successTitle: "",
48
+ failureMessage: "This document is not valid. Please upload a valid document."
49
+ },
50
+ [TYPES.ADDRESS_INVALID]: {
51
+ failureTitle: "Document store or Token registry address is invalid",
52
+ successTitle: "",
53
+ failureMessage: "Please inform the issuer of this document that they have misconfigured their Document store or Token registry address."
54
+ },
55
+ [TYPES.NETWORK_INVALID]: {
56
+ failureTitle: "Document's network field is invalid",
57
+ successTitle: "",
58
+ failureMessage: "This document has an invalid network field. Please contact your issuing authority for help or re-issue the document with a valid network field before trying again."
59
+ },
60
+ [TYPES.NETWORK_MISMATCH_MAINNET]: {
61
+ failureTitle: "Document network mismatch on mainnet",
62
+ successTitle: "",
63
+ failureMessage: "This document was issued on the testnet, but you are currently using the mainnet environment. Please switch to the testnet environment to view this document correctly, or contact the issuing authority if you believe this is incorrect."
64
+ },
65
+ [TYPES.NETWORK_MISMATCH_TESTNET]: {
66
+ failureTitle: "Document network mismatch on testnet",
67
+ successTitle: "",
68
+ failureMessage: "This document was issued on the mainnet, but you are currently using the testnet environment. Please switch to the mainnet environment to view this document correctly, or contact the issuing authority if you believe this is incorrect."
69
+ },
70
+ [TYPES.CONTRACT_NOT_FOUND]: {
71
+ failureTitle: "Document store or Token registry address cannot be found",
72
+ successTitle: "",
73
+ failureMessage: "Please inform the issuer of this document that they have misconfigured their Document store or Token registry address."
74
+ },
75
+ [TYPES.INVALID_ARGUMENT]: {
76
+ failureTitle: "Document's merkle root is invalid",
77
+ successTitle: "",
78
+ failureMessage: "Please inform the issuer of this document that the merkle root is invalid, or it may have been tampered with."
79
+ },
80
+ [TYPES.SERVER_ERROR]: {
81
+ failureTitle: "Unable to connect to the blockchain network",
82
+ successTitle: "",
83
+ failureMessage: "We are unable to connect to the blockchain network, please try again later. If this issue persists, contact us using the feedback link below."
84
+ },
85
+ [TYPES.ETHERS_UNHANDLED_ERROR]: {
86
+ failureTitle: "Whoops! It's not you, it's us",
87
+ successTitle: "",
88
+ failureMessage: "We encountered an internal error and cannot determine the cause, please try again later. If this issue persists, contact us using the feedback link below."
89
+ },
90
+ [TYPES.CLIENT_NETWORK_ERROR]: {
91
+ failureTitle: "Whoops! There seems to be an error verifying the document",
92
+ successTitle: "",
93
+ failureMessage: "Please check your network and try again"
94
+ },
95
+ [TYPES.VERIFICATION_ERROR]: {
96
+ failureTitle: "Document Verification Failed",
97
+ successTitle: "",
98
+ failureMessage: "The document could not be verified at the moment. Please try again."
99
+ }
100
+ };
101
+
102
+ export { MESSAGES, TYPES };
@@ -1,4 +1,4 @@
1
- import { CONSTANTS } from '@tradetrust-tt/tradetrust-utils';
1
+ import * as CONSTANTS from './VerificationErrorMessages';
2
2
  export * from './types';
3
3
 
4
4
  const errorMessages = CONSTANTS;
@@ -1,10 +1,48 @@
1
- import { interpretFragments, CONSTANTS, errorMessageHandling as errorMessageHandling$1 } from '@tradetrust-tt/tradetrust-utils';
2
- export { interpretFragments } from '@tradetrust-tt/tradetrust-utils';
3
- import { utils } from '@tradetrust-tt/tt-verify';
1
+ import { utils, isValid, OpenAttestationEthereumDocumentStoreStatusCode } from '@tradetrust-tt/tt-verify';
4
2
  import { W3CCredentialStatusCode } from '../../verify/fragments/document-status/w3cCredentialStatus';
3
+ import { TYPES } from '../errorMessages/VerificationErrorMessages';
4
+ import { errorMessages } from '../errorMessages';
5
5
 
6
6
  var __defProp = Object.defineProperty;
7
7
  var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
8
+ const certificateRevokedOnDidIdentified = /* @__PURE__ */ __name((fragments) => {
9
+ const didSignedDocumentStatusFragment = utils.getOpenAttestationDidSignedDocumentStatusFragment(fragments);
10
+ return didSignedDocumentStatusFragment?.reason?.code === OpenAttestationEthereumDocumentStoreStatusCode.DOCUMENT_REVOKED;
11
+ }, "certificateRevokedOnDidIdentified");
12
+ const interpretFragments = /* @__PURE__ */ __name((fragments) => {
13
+ const hashValid = isValid(fragments, ["DOCUMENT_INTEGRITY"]);
14
+ const issuedValid = isValid(fragments, ["DOCUMENT_STATUS"]);
15
+ const identityValid = isValid(fragments, ["ISSUER_IDENTITY"]);
16
+ return { hashValid, issuedValid, identityValid };
17
+ }, "interpretFragments");
18
+ const OAErrorMessageHandling = /* @__PURE__ */ __name((fragments) => {
19
+ const { hashValid, issuedValid, identityValid } = interpretFragments(fragments);
20
+ const errors = [];
21
+ if (utils.isDocumentStoreAddressOrTokenRegistryAddressInvalid(fragments)) {
22
+ return [TYPES.ADDRESS_INVALID];
23
+ }
24
+ if (utils.contractNotFound(fragments)) {
25
+ return [TYPES.CONTRACT_NOT_FOUND];
26
+ }
27
+ if (utils.serverError(fragments)) {
28
+ return [TYPES.SERVER_ERROR];
29
+ }
30
+ if (!hashValid) errors.push(TYPES.HASH);
31
+ if (!identityValid) errors.push(TYPES.IDENTITY);
32
+ if (!issuedValid) {
33
+ if (utils.certificateRevoked(fragments) || certificateRevokedOnDidIdentified(fragments))
34
+ errors.push(TYPES.REVOKED);
35
+ else if (utils.invalidArgument(fragments)) {
36
+ errors.push(TYPES.INVALID_ARGUMENT);
37
+ } else if (utils.certificateNotIssued(fragments)) errors.push(TYPES.ISSUED);
38
+ else if (!hashValid && !identityValid) {
39
+ return [TYPES.INVALID];
40
+ } else {
41
+ return [TYPES.ETHERS_UNHANDLED_ERROR];
42
+ }
43
+ }
44
+ return errors;
45
+ }, "OAErrorMessageHandling");
8
46
  const getW3CCredentialStatusFragment = utils.getFragmentByName(
9
47
  "W3CCredentialStatus"
10
48
  );
@@ -25,23 +63,23 @@ const errorMessageHandling = /* @__PURE__ */ __name((fragments) => {
25
63
  if (isW3cFragments) {
26
64
  switch (true) {
27
65
  case w3cCredentialStatusRevoked(fragments):
28
- errors.push(CONSTANTS.TYPES.REVOKED);
66
+ errors.push(errorMessages.TYPES.REVOKED);
29
67
  break;
30
68
  case w3cCredentialStatusSuspended(fragments):
31
- errors.push(CONSTANTS.TYPES.SUSPENDED);
69
+ errors.push(errorMessages.TYPES.SUSPENDED);
32
70
  break;
33
71
  case !hashValid:
34
- errors.push(CONSTANTS.TYPES.HASH);
72
+ errors.push(errorMessages.TYPES.HASH);
35
73
  break;
36
74
  case !identityValid:
37
- errors.push(CONSTANTS.TYPES.IDENTITY);
75
+ errors.push(errorMessages.TYPES.IDENTITY);
38
76
  break;
39
77
  case !issuedValid:
40
- errors.push(CONSTANTS.TYPES.INVALID);
78
+ errors.push(errorMessages.TYPES.INVALID);
41
79
  break;
42
80
  }
43
81
  return errors;
44
- } else return errorMessageHandling$1(fragments);
82
+ } else return OAErrorMessageHandling(fragments);
45
83
  }, "errorMessageHandling");
46
84
 
47
- export { errorMessageHandling, w3cCredentialStatusRevoked, w3cCredentialStatusSuspended };
85
+ export { OAErrorMessageHandling, errorMessageHandling, interpretFragments, w3cCredentialStatusRevoked, w3cCredentialStatusSuspended };
@@ -1 +1,62 @@
1
- export { calculateMaxFee, gasStation, scaleBigNumber } from '@tradetrust-tt/tradetrust-utils';
1
+ import { BigNumber, ethers } from 'ethers';
2
+ import fetch from 'node-fetch';
3
+
4
+ var __defProp = Object.defineProperty;
5
+ var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
6
+ const gasStation = /* @__PURE__ */ __name((gasStationUrl) => async () => {
7
+ try {
8
+ if (!gasStationUrl) return void 0;
9
+ const res = await fetch(gasStationUrl);
10
+ const data = await res.json();
11
+ return {
12
+ maxPriorityFeePerGas: safeParseUnits(data.standard.maxPriorityFee.toString(), 9),
13
+ maxFeePerGas: safeParseUnits(data.standard.maxFee.toString(), 9)
14
+ };
15
+ } catch {
16
+ throw new Error("Failed to fetch gas station");
17
+ }
18
+ }, "gasStation");
19
+ const safeParseUnits = /* @__PURE__ */ __name((_value, decimals) => {
20
+ const value = String(_value);
21
+ if (!value.match(/^[0-9.]+$/)) {
22
+ throw new Error(`invalid gwei value: ${_value}`);
23
+ }
24
+ const comps = value.split(".");
25
+ if (comps.length === 1) {
26
+ comps.push("");
27
+ }
28
+ if (comps.length !== 2) {
29
+ throw new Error(`invalid gwei value: ${_value}`);
30
+ }
31
+ while (comps[1].length < decimals) {
32
+ comps[1] += "0";
33
+ }
34
+ if (comps[1].length > 9 && !comps[1].substring(9).match(/^0+$/)) {
35
+ comps[1] = BigNumber.from(comps[1].substring(0, 9)).add(BigNumber.from(1)).toString();
36
+ }
37
+ return ethers.utils.parseUnits(`${comps[0]}.${comps[1]}`, decimals);
38
+ }, "safeParseUnits");
39
+ const scaleBigNumber = /* @__PURE__ */ __name((wei, multiplier, precision = 2) => {
40
+ if (wei === null || typeof wei === "undefined") {
41
+ throw new Error("Wei not specified");
42
+ }
43
+ const padding = Math.pow(10, precision);
44
+ const newMultiplier = Math.round(padding * multiplier);
45
+ const newWei = wei.mul(newMultiplier).div(padding);
46
+ return newWei;
47
+ }, "scaleBigNumber");
48
+ const calculateMaxFee = /* @__PURE__ */ __name((maxFee, priorityFee, scale) => {
49
+ if (maxFee === null || typeof maxFee === "undefined") {
50
+ throw new Error("Max Fee not specified");
51
+ }
52
+ if (priorityFee === null || typeof priorityFee === "undefined") {
53
+ throw new Error("Priority Fee not specified");
54
+ }
55
+ if (scale === 1) {
56
+ return maxFee;
57
+ }
58
+ const priorityFeeChange = scaleBigNumber(priorityFee, scale).sub(priorityFee);
59
+ return maxFee.add(priorityFeeChange);
60
+ }, "calculateMaxFee");
61
+
62
+ export { calculateMaxFee, gasStation, scaleBigNumber };
@@ -6,3 +6,4 @@ export * from './errorMessages';
6
6
  export * from './documents';
7
7
  export * from './gasStation';
8
8
  export * from './aws-kms-signer';
9
+ export * from './analytics';
@@ -1 +1,16 @@
1
- export * from '@tradetrust-tt/tradetrust-utils/constants/network';
1
+ const networks = [
2
+ "local",
3
+ "mainnet",
4
+ "matic",
5
+ "maticmum",
6
+ "amoy",
7
+ "sepolia",
8
+ "xdc",
9
+ "xdcapothem",
10
+ "stabilitytestnet",
11
+ "stability",
12
+ "astron",
13
+ "astrontestnet"
14
+ ];
15
+
16
+ export { networks };
@@ -0,0 +1,7 @@
1
+ const iconEthereum = "";
2
+ const iconPolygon = "";
3
+ const iconXDC = "";
4
+ const iconStability = "";
5
+ const iconAstron = "";
6
+
7
+ export { iconAstron, iconEthereum, iconPolygon, iconStability, iconXDC };