@hinkal/common 0.0.113 → 0.0.114
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/API/API.js +58 -0
- package/API/HinkalPointsCalls.js +38 -0
- package/API/callBeefyGraphAPI.js +37 -0
- package/API/callCurveAPI.js +156 -0
- package/API/callMonitor.js +30 -0
- package/API/callOdosAPI.js +44 -0
- package/API/callOneInchAPI.js +37 -0
- package/API/callRelayer.js +32 -0
- package/API/checkRisk.js +30 -0
- package/API/dataServerCalls.js +32 -0
- package/API/fetchCommitmentsCache.js +31 -0
- package/API/fetchNullifiers.js +30 -0
- package/API/getAxelarGasEstimate.js +37 -0
- package/API/getCoingeckoPrice.js +27 -0
- package/API/getConnextReceiveFee.js +30 -0
- package/API/getGasEstimates.js +38 -0
- package/API/getRelayerURL.js +32 -0
- package/API/getServerURL.js +67 -0
- package/API/getTokenPrice.js +41 -0
- package/API/kycCalls.js +32 -0
- package/API/passwordCalls.js +36 -0
- package/API/referralProgramCalls.js +58 -0
- package/API/relayCalls.js +30 -0
- package/API/restoreSnapshots.js +32 -0
- package/API/rewardsPointsCalls.js +40 -0
- package/API/userVerifyTransactions.js +45 -0
- package/assets/{snarkjsWorkerLauncher-fuD5h_j0.js → snarkjsWorkerLauncher-CaBCnle3.js} +283 -257
- package/assets/snarkjsWorkerLogic-BAbiO5gj.js +17935 -0
- package/assets/snarkjsWorkerLogic-wHJfYCfg.js +15636 -0
- package/assets/{utxoWorkerLogic-CtFLQiAX.js → utxoWorkerLogic-BGFm-Zl2.js} +2 -2
- package/assets/{zkProofWorkerLauncher-J3Ts5_Ba.js → zkProofWorkerLauncher-BteYxRBn.js} +1 -1
- package/assets/{zkProofWorkerLogic-CPNuu61R.js → zkProofWorkerLogic-DiLbAhAo.js} +8354 -8298
- package/constants/assets.constants.js +16 -0
- package/constants/axelar.constants.js +55 -0
- package/constants/backend.constants.js +18 -0
- package/constants/beefy.registry.js +24 -0
- package/constants/chains.constants.js +204 -0
- package/constants/coingecko.constants.js +53 -0
- package/constants/contracts.constants.js +276 -0
- package/constants/crvCvx.registry.js +636 -0
- package/constants/crvDynamic.registry.js +24 -0
- package/constants/deploy-data/deploy-data-arbMainnet.json.js +7415 -0
- package/constants/deploy-data/deploy-data-avalanche.json.js +7411 -0
- package/constants/deploy-data/deploy-data-axelar1.json.js +4329 -0
- package/constants/deploy-data/deploy-data-axelar2.json.js +4329 -0
- package/constants/deploy-data/deploy-data-base.json.js +8425 -0
- package/constants/deploy-data/deploy-data-blast.json.js +9600 -0
- package/constants/deploy-data/deploy-data-bnbMainnet.json.js +6877 -0
- package/constants/deploy-data/deploy-data-ethMainnet.json.js +11427 -0
- package/constants/deploy-data/deploy-data-localhost.json.js +13283 -0
- package/constants/deploy-data/deploy-data-optimism.json.js +7417 -0
- package/constants/deploy-data/deploy-data-polygon.json.js +7439 -0
- package/constants/fees.constants.js +57 -0
- package/constants/kyc.constants.js +118 -0
- package/constants/lido.constants.js +13 -0
- package/constants/pendle.registry.js +253 -0
- package/constants/protocol.constants.js +26 -0
- package/constants/reorg-depths.constants.js +15 -0
- package/constants/rewards.constants.js +27 -0
- package/constants/server.constants.js +157 -0
- package/constants/token-data/ERC20Registry.js +85 -0
- package/constants/token-data/arbMainnetRegistry.json.js +946 -0
- package/constants/token-data/arbMainnetRegistryFixed.json.js +856 -0
- package/constants/token-data/avalancheRegistry.json.js +591 -0
- package/constants/token-data/avalancheRegistryFixed.json.js +591 -0
- package/constants/token-data/baseRegistry.json.js +490 -0
- package/constants/token-data/baseRegistryFixed.json.js +463 -0
- package/constants/token-data/blastRegistry.json.js +137 -0
- package/constants/token-data/blastRegistryFixed.json.js +137 -0
- package/constants/token-data/bnbMainnetRegistry.json.js +973 -0
- package/constants/token-data/bnbMainnetRegistryFixed.json.js +973 -0
- package/constants/token-data/coingeckoRegistry.json.js +115623 -0
- package/constants/token-data/ethMainnetRegistry.json.js +2700 -0
- package/constants/token-data/ethMainnetRegistryFixed.json.js +2251 -0
- package/constants/token-data/index.js +6 -0
- package/constants/token-data/localhostRegistry.json.js +2768 -0
- package/constants/token-data/optimismRegistry.json.js +1455 -0
- package/constants/token-data/optimismRegistryFixed.json.js +1392 -0
- package/constants/token-data/polygonRegistry.json.js +1327 -0
- package/constants/token-data/polygonRegistryFixed.json.js +1255 -0
- package/constants/token-data/popularTokens.constants.js +14 -0
- package/constants/token-data/tokenPricing.consts.js +8 -0
- package/constants/vite.constants.js +29 -0
- package/crypto/babyJub.js +15 -0
- package/crypto/poseidon.js +26 -0
- package/crypto/preProcessing.js +9 -0
- package/data-structures/Hinkal/Hinkal.js +299 -0
- package/data-structures/Hinkal/hinkalActionBeefy.js +101 -0
- package/data-structures/Hinkal/hinkalActionConvex.js +83 -0
- package/data-structures/Hinkal/hinkalActionCurve.js +112 -0
- package/data-structures/Hinkal/hinkalActionLidoEth.js +91 -0
- package/data-structures/Hinkal/hinkalActionPendle.js +140 -0
- package/data-structures/Hinkal/hinkalActionPendleLP.js +96 -0
- package/data-structures/Hinkal/hinkalActionStake.js +138 -0
- package/data-structures/Hinkal/hinkalActionVolatile.js +112 -0
- package/data-structures/Hinkal/hinkalDeposit.js +95 -0
- package/data-structures/Hinkal/hinkalGetZkMeProvider.js +47 -0
- package/data-structures/Hinkal/hinkalPrivateWallet.js +66 -0
- package/data-structures/Hinkal/hinkalSwap.js +98 -0
- package/data-structures/Hinkal/hinkalTransfer.js +5 -0
- package/data-structures/Hinkal/hinkalWithdraw.js +91 -0
- package/data-structures/Hinkal/resetMerkleTrees.js +49 -0
- package/data-structures/MultiThreadedUtxoUtils/MultiThreadedUtxoUtils.js +83 -0
- package/data-structures/ValueCache/ValueCache.js +25 -0
- package/data-structures/crypto-keys/decodeUTXO.js +40 -0
- package/data-structures/crypto-keys/encryptDecryptUtxo.js +41 -0
- package/data-structures/crypto-keys/keyUtils.js +10 -0
- package/data-structures/crypto-keys/keys.js +90 -0
- package/data-structures/custom-token-registry/CustomTokenRegistry.js +33 -0
- package/data-structures/event-service/AbstractAccessTokenSnapshotService.js +131 -0
- package/data-structures/event-service/AbstractCommitmentsSnapshotService.js +132 -0
- package/data-structures/event-service/AbstractEventService.js +118 -0
- package/data-structures/event-service/AbstractNullifierSnapshotService.js +59 -0
- package/data-structures/event-service/AbstractSnapshotService.js +35 -0
- package/data-structures/merkle-tree/MerkleTree.js +177 -0
- package/data-structures/merkle-tree/MerkleTreeIncompleteError.js +8 -0
- package/data-structures/snapshot/ClientAccessTokenSnapshotService.js +48 -0
- package/data-structures/snapshot/ClientCommitmentsSnapshotService.js +47 -0
- package/data-structures/snapshot/ClientNullifierSnapshotService.js +44 -0
- package/data-structures/token-price-fetcher/TokenChecker.js +29 -0
- package/data-structures/token-price-fetcher/TokenPriceFetcher.js +218 -0
- package/data-structures/transactions-manager/TransactionsManager.js +194 -0
- package/data-structures/transactions-manager/history/getBeefyData.js +68 -0
- package/data-structures/transactions-manager/history/getConvexData.js +57 -0
- package/data-structures/transactions-manager/history/getCurveData.js +97 -0
- package/data-structures/transactions-manager/history/getDepositData.js +36 -0
- package/data-structures/transactions-manager/history/getLidoData.js +44 -0
- package/data-structures/transactions-manager/history/getPendleData.js +59 -0
- package/data-structures/transactions-manager/history/getSwapData.js +43 -0
- package/data-structures/transactions-manager/history/getTxDetails.js +74 -0
- package/data-structures/transactions-manager/history/getVolatileData.js +75 -0
- package/data-structures/transactions-manager/history/history.types.js +62 -0
- package/data-structures/transactions-manager/history/history.utils.js +8 -0
- package/data-structures/utxo/Utxo.js +134 -0
- package/data-structures/volatile-helper/VolatileHelper.js +181 -0
- package/error-handling/customErrors/ErrorWithAmount.js +9 -0
- package/error-handling/customErrors/FeeOverTransactionValueError.js +9 -0
- package/error-handling/customErrors/customErrors.helpers.js +21 -0
- package/error-handling/error-codes.constants.js +184 -0
- package/error-handling/get-error.message.js +53 -0
- package/error-handling/handleErrorRestore.js +35 -0
- package/error-handling/logError.js +7 -0
- package/error-handling/types.js +4 -0
- package/externalABIs/BUSD.js +519 -0
- package/externalABIs/BabPassport.json.js +24 -0
- package/externalABIs/BeefyRouterAbi.json.js +1022 -0
- package/externalABIs/BeefyStrategyAbi.json.js +1423 -0
- package/externalABIs/BeefyVaultAbi.json.js +570 -0
- package/externalABIs/BeefyZapAbi.json.js +208 -0
- package/externalABIs/BeefyZapOneInchAbi.json.js +340 -0
- package/externalABIs/ConvexBoosterAbi.json.js +674 -0
- package/externalABIs/ConvexBoosterAbiMainnet.json.js +1002 -0
- package/externalABIs/ConvexRewardPoolAbi.json.js +883 -0
- package/externalABIs/CurveReadingWrapperAbi.json.js +1422 -0
- package/externalABIs/CurveWrappedMainPool.json.js +1136 -0
- package/externalABIs/CurveZap.json.js +262 -0
- package/externalABIs/CvxCrvUtilities.json.js +264 -0
- package/externalABIs/DAI.js +334 -0
- package/externalABIs/ERC20.json.js +291 -0
- package/externalABIs/GalxePassport.json.js +41 -0
- package/externalABIs/IQuoterV2.json.js +205 -0
- package/externalABIs/ISwapRouter.json.js +568 -0
- package/externalABIs/IUniswapV3Factory.json.js +201 -0
- package/externalABIs/IUniswapV3Pool.json.js +999 -0
- package/externalABIs/LidoStEthAbi.json.js +1603 -0
- package/externalABIs/LidoStMaticAbi.json.js +1764 -0
- package/externalABIs/LidoStakeManagerAbi.json.js +2082 -0
- package/externalABIs/LidoWithdrawalQueueERC721Abi.json.js +2030 -0
- package/externalABIs/LidoWstEthAbi.json.js +480 -0
- package/externalABIs/OptimismGasPriceOracle.json.js +206 -0
- package/externalABIs/PendleRouterAbi.json.js +173 -0
- package/externalABIs/PoLidoNftAbi.json.js +701 -0
- package/externalABIs/SanctionsList.js +89 -0
- package/externalABIs/USDC.js +721 -0
- package/externalABIs/USDR.js +346 -0
- package/externalABIs/USDR3CRV.js +542 -0
- package/externalABIs/USDT.js +393 -0
- package/externalABIs/UniswapV2PoolAbi.json.js +80 -0
- package/externalABIs/WETH.js +156 -0
- package/externalABIs/amToken.js +350 -0
- package/externalABIs/transactionsProver.json.js +39 -0
- package/functions/kyc/authentoHelper.js +42 -0
- package/functions/kyc/passportHelper.js +39 -0
- package/functions/kyc/zkMeHelper.js +56 -0
- package/functions/pre-transaction/getFlatFees.js +203 -0
- package/functions/pre-transaction/interaction-to-action.js +57 -0
- package/functions/pre-transaction/outputUtxoProcessing.js +45 -0
- package/functions/pre-transaction/process-gas-estimates.js +57 -0
- package/functions/pre-transaction/processAmountChanges.js +229 -0
- package/functions/private-wallet/emporium.helpers.js +19 -0
- package/functions/private-wallet/opProducer.js +24 -0
- package/functions/protocols/convex.protocols.js +41 -0
- package/functions/protocols/curve.protocols.js +45 -0
- package/functions/protocols/pendle.helpers.js +108 -0
- package/functions/snarkjs/common.snarkjs.js +96 -0
- package/functions/snarkjs/constant.js +211 -0
- package/functions/snarkjs/constructEmporiumProof.js +105 -0
- package/functions/snarkjs/constructGeneralZkProof.js +129 -0
- package/functions/snarkjs/generateCircomData.js +60 -0
- package/functions/snarkjs/generateZkProof.js +18 -0
- package/functions/snarkjs/getZKFiles.js +30 -0
- package/functions/staking/index.js +40 -0
- package/functions/utils/amounts.utils.js +70 -0
- package/functions/utils/axelar.utils.js +38 -0
- package/functions/utils/cacheFunctions.js +67 -0
- package/functions/utils/caseInsensitive.utils.js +6 -0
- package/functions/utils/convertIntegrationProviderToExternalActionId.js +16 -0
- package/functions/utils/create-provider.js +5 -0
- package/functions/utils/enum.utils.js +14 -0
- package/functions/utils/erc20tokenFunctions.js +20 -0
- package/functions/utils/evmNetworkFunctions.js +29 -0
- package/functions/utils/external-action.utils.js +61 -0
- package/functions/utils/getDataFromTransaction.js +105 -0
- package/functions/utils/memoize.utils.js +14 -0
- package/functions/utils/nickname.utils.js +7 -0
- package/functions/utils/process.utils.js +4 -0
- package/functions/utils/reloadPage.js +4 -0
- package/functions/utils/requireEnv.js +7 -0
- package/functions/utils/resolve-sync.utils.js +22 -0
- package/functions/utils/serialize.utils.js +4 -0
- package/functions/utils/string.utils.js +14 -0
- package/functions/utils/time.utils.js +8 -0
- package/functions/utils/userAgent.js +15 -0
- package/functions/utils/volatile-patcher.utils.js +40 -0
- package/functions/web3/etherFunctions.js +41 -0
- package/functions/web3/events/balanceChangedHandler.js +10 -0
- package/functions/web3/events/getInputUtxoAndBalance.js +72 -0
- package/functions/web3/events/getShieldedBalance.js +107 -0
- package/functions/web3/events/web3RetrieveEvents.js +9 -0
- package/functions/web3/functionCalls/accessTokenCalls.js +48 -0
- package/functions/web3/functionCalls/approveToken.js +153 -0
- package/functions/web3/functionCalls/estimateGasRelayer.js +18 -0
- package/functions/web3/functionCalls/transactCallDirect.js +60 -0
- package/functions/web3/functionCalls/transactCallRelayer.js +42 -0
- package/functions/web3/odosAPI.js +65 -0
- package/functions/web3/oneInchAPI.js +61 -0
- package/functions/web3/runContractFunction.js +95 -0
- package/functions/web3/uniswapAPI.js +97 -0
- package/index.js +642 -455
- package/package.json +2 -2
- package/types/beefy.types.js +21 -0
- package/types/circom-data.types.js +22 -0
- package/types/curve.types.js +25 -0
- package/types/ethereum-network.types.js +4 -0
- package/types/external-action.types.js +4 -0
- package/types/hinkal.stake.types.js +4 -0
- package/types/hinkal.types.js +15 -0
- package/types/kyc.types.js +13 -0
- package/types/pendle.types.js +15 -0
- package/types/rewards.types.js +27 -0
- package/types/slippage.types.js +15 -0
- package/types/time.types.js +58 -0
- package/types/token.types.js +4 -0
- package/types/transactions.types.js +36 -0
- package/webworker/performTaskWithWorker.js +62 -0
- package/webworker/snarkjsWorker/snarkjsWorker.types.js +4 -0
- package/{snarkjsWorkerLogic-CVna_BW9.mjs → webworker/snarkjsWorker/snarkjsWorkerLogic.js} +1 -1
- package/webworker/utxoWorker/utxoWorker.types.js +4 -0
- package/webworker/utxoWorker/utxoWorkerLogic.js +70 -0
- package/webworker/worker.registry.js +4 -0
- package/webworker/workerFactory.js +42 -0
- package/{workerProxy-BDj498Ht.mjs → webworker/workerProxy.js} +1 -1
- package/webworker/zkProofWorker/zkProofWorker.types.js +4 -0
- package/webworker/zkProofWorker/zkProofWorkerLogic.js +66 -0
- package/assets/snarkjsWorkerLogic-B6N4z_eM.js +0 -12136
- package/assets/snarkjsWorkerLogic-Fv0M38Mc.js +0 -12087
- package/index-DXElTGy9.mjs +0 -254449
- package/utxoWorkerLogic-B1Hh-bq4.mjs +0 -64
- package/zkProofWorkerLogic-D9rxuuiK.mjs +0 -60
|
@@ -0,0 +1,105 @@
|
|
|
1
|
+
import { BigNumber as m } from "ethers";
|
|
2
|
+
import "../../constants/chains.constants.js";
|
|
3
|
+
import "../../types/circom-data.types.js";
|
|
4
|
+
import "../../types/transactions.types.js";
|
|
5
|
+
import "../../types/curve.types.js";
|
|
6
|
+
import "circomlibjs";
|
|
7
|
+
import "../../data-structures/crypto-keys/keys.js";
|
|
8
|
+
import "axios";
|
|
9
|
+
import { abiDecodeUtxo as g } from "../../data-structures/crypto-keys/decodeUTXO.js";
|
|
10
|
+
import "../../data-structures/crypto-keys/encryptDecryptUtxo.js";
|
|
11
|
+
import "../web3/events/getShieldedBalance.js";
|
|
12
|
+
import "../../webworker/workerFactory.js";
|
|
13
|
+
import "./external-action.utils.js";
|
|
14
|
+
import "../../data-structures/custom-token-registry/CustomTokenRegistry.js";
|
|
15
|
+
import "./convertIntegrationProviderToExternalActionId.js";
|
|
16
|
+
import "../../constants/coingecko.constants.js";
|
|
17
|
+
import "../../constants/vite.constants.js";
|
|
18
|
+
import "./userAgent.js";
|
|
19
|
+
import "../../constants/reorg-depths.constants.js";
|
|
20
|
+
import "../../constants/kyc.constants.js";
|
|
21
|
+
import "../../data-structures/volatile-helper/VolatileHelper.js";
|
|
22
|
+
import "libsodium-wrappers";
|
|
23
|
+
import { getHinkalParameters as x } from "../../constants/contracts.constants.js";
|
|
24
|
+
import "../../constants/axelar.constants.js";
|
|
25
|
+
import "../../constants/rewards.constants.js";
|
|
26
|
+
const G = (e, r) => {
|
|
27
|
+
const n = e.parseTransaction({ data: r }), { circomData: t } = n.args, {
|
|
28
|
+
extraRandomization: o,
|
|
29
|
+
stealthAddress: i,
|
|
30
|
+
H0: u,
|
|
31
|
+
H1: s
|
|
32
|
+
} = t.stealthAddressStructure;
|
|
33
|
+
return {
|
|
34
|
+
erc20TokenAddresses: t.erc20TokenAddresses,
|
|
35
|
+
amountChanges: t.amountChanges,
|
|
36
|
+
flatFees: t.flatFees,
|
|
37
|
+
externalActionId: t.externalActionId,
|
|
38
|
+
externalActionMetadata: t.externalActionMetadata,
|
|
39
|
+
encryptedOutputs: t.encryptedOutputs.map((d) => d[0]),
|
|
40
|
+
hookData: t.hookData,
|
|
41
|
+
stealthAddressStructure: {
|
|
42
|
+
extraRandomization: o.toBigInt(),
|
|
43
|
+
stealthAddress: i.toBigInt(),
|
|
44
|
+
H0: u.toBigInt(),
|
|
45
|
+
H1: s.toBigInt()
|
|
46
|
+
}
|
|
47
|
+
};
|
|
48
|
+
}, J = (e, r) => {
|
|
49
|
+
const { transactMethodId: n, transactWithExternalActionMethodId: t, NewCommitment: o, NewCommitmentTopic: i, hinkalInterface: u } = x(e), s = [];
|
|
50
|
+
for (let a = 0; a < r.length; a += 1) {
|
|
51
|
+
s.push(r[a]), s[a].utxosArray = [];
|
|
52
|
+
const { methodId: d } = s[a];
|
|
53
|
+
s[a].logs.forEach((c, S) => {
|
|
54
|
+
if (d !== n && d !== t || c.topics[0] !== i)
|
|
55
|
+
return;
|
|
56
|
+
const p = u.decodeEventLog(o, c.data);
|
|
57
|
+
if (p.index.toBigInt() < 0n) {
|
|
58
|
+
const { amount: l, erc20TokenAddress: h, timeStamp: A, tokenId: I } = g(p.encryptedOutput);
|
|
59
|
+
s[a].utxosArray?.push({ amount: l, erc20TokenAddress: h, timeStamp: A, tokenId: I });
|
|
60
|
+
}
|
|
61
|
+
});
|
|
62
|
+
}
|
|
63
|
+
return s;
|
|
64
|
+
}, K = (e) => ({
|
|
65
|
+
...e,
|
|
66
|
+
utxosArray: e.utxosArray?.map((r) => ({ ...r, amount: BigInt(r.amount) })),
|
|
67
|
+
decodedInput: {
|
|
68
|
+
...e.decodedInput,
|
|
69
|
+
amountChanges: e.decodedInput.amountChanges.map(m.from),
|
|
70
|
+
flatFees: e.decodedInput.flatFees.map(m.from),
|
|
71
|
+
externalActionId: m.from(e.decodedInput.externalActionId),
|
|
72
|
+
stealthAddressStructure: {
|
|
73
|
+
...e.decodedInput.stealthAddressStructure,
|
|
74
|
+
extraRandomization: BigInt(e.decodedInput.stealthAddressStructure.extraRandomization),
|
|
75
|
+
stealthAddress: BigInt(e.decodedInput.stealthAddressStructure.stealthAddress),
|
|
76
|
+
H0: BigInt(e.decodedInput.stealthAddressStructure.H0),
|
|
77
|
+
H1: BigInt(e.decodedInput.stealthAddressStructure.H1)
|
|
78
|
+
}
|
|
79
|
+
}
|
|
80
|
+
}), Q = (e) => e.map((n) => {
|
|
81
|
+
const { decodedInput: t } = n;
|
|
82
|
+
return {
|
|
83
|
+
...n,
|
|
84
|
+
input: "",
|
|
85
|
+
decodedInput: {
|
|
86
|
+
...t,
|
|
87
|
+
amountChanges: t.amountChanges.map((o) => o.toString()),
|
|
88
|
+
flatFees: t.flatFees.map((o) => o.toString()),
|
|
89
|
+
externalActionId: t.externalActionId.toString(),
|
|
90
|
+
stealthAddressStructure: {
|
|
91
|
+
...t.stealthAddressStructure,
|
|
92
|
+
extraRandomization: String(t.stealthAddressStructure.extraRandomization),
|
|
93
|
+
stealthAddress: String(t.stealthAddressStructure.stealthAddress),
|
|
94
|
+
H0: String(t.stealthAddressStructure.H0),
|
|
95
|
+
H1: String(t.stealthAddressStructure.H1)
|
|
96
|
+
}
|
|
97
|
+
}
|
|
98
|
+
};
|
|
99
|
+
});
|
|
100
|
+
export {
|
|
101
|
+
G as decodeTxInput,
|
|
102
|
+
J as decodeTxLogs,
|
|
103
|
+
K as deserializeDecodedTxs,
|
|
104
|
+
Q as serializeDecodedTxs
|
|
105
|
+
};
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { CustomJSONStringify as c } from "./serialize.utils.js";
|
|
2
|
+
const u = (o) => {
|
|
3
|
+
const t = /* @__PURE__ */ new Map();
|
|
4
|
+
return (...n) => {
|
|
5
|
+
const e = c(n);
|
|
6
|
+
if (t.has(e))
|
|
7
|
+
return t.get(e);
|
|
8
|
+
const r = o(...n);
|
|
9
|
+
return t.set(e, r), r;
|
|
10
|
+
};
|
|
11
|
+
};
|
|
12
|
+
export {
|
|
13
|
+
u as memoizeFunc
|
|
14
|
+
};
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
const c = (t) => t.reduce((e, n) => e.then(() => n()), Promise.resolve()), h = (t, e, n) => {
|
|
2
|
+
const s = [];
|
|
3
|
+
if (n) {
|
|
4
|
+
let o = t;
|
|
5
|
+
for (; o <= e; ) {
|
|
6
|
+
const r = Math.min(o + n - 1, e);
|
|
7
|
+
s.push({
|
|
8
|
+
from: o,
|
|
9
|
+
to: r
|
|
10
|
+
}), o = r + 1;
|
|
11
|
+
}
|
|
12
|
+
} else
|
|
13
|
+
s.push({
|
|
14
|
+
from: t,
|
|
15
|
+
to: e
|
|
16
|
+
});
|
|
17
|
+
return s;
|
|
18
|
+
};
|
|
19
|
+
export {
|
|
20
|
+
h as getSequence,
|
|
21
|
+
c as resolveSync
|
|
22
|
+
};
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
function e(t) {
|
|
2
|
+
return t?.toLowerCase().split(" ").map((r) => r.charAt(0).toUpperCase() + r.substring(1)).join(" ");
|
|
3
|
+
}
|
|
4
|
+
function n(t) {
|
|
5
|
+
return t.charAt(0).toUpperCase() + t.slice(1);
|
|
6
|
+
}
|
|
7
|
+
function i(t) {
|
|
8
|
+
return !t || t === null || Array.isArray(t) && t.length === 0 ? !0 : Object.keys(t).length === 0 && t.constructor === Object;
|
|
9
|
+
}
|
|
10
|
+
export {
|
|
11
|
+
n as capitalizeFirstLetter,
|
|
12
|
+
i as isNullOrEmpty,
|
|
13
|
+
e as toTitleCase
|
|
14
|
+
};
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { UAParser as s } from "ua-parser-js";
|
|
2
|
+
const a = new s(), n = ["17"], u = () => {
|
|
3
|
+
const { name: e, version: r } = a.getBrowser(), t = r?.substring(0, 2);
|
|
4
|
+
return !(e === "Safari" && t && !n.includes(t));
|
|
5
|
+
}, o = {
|
|
6
|
+
mpcVault: "MPCVault - Multisig Wallet",
|
|
7
|
+
utila: "UtilaWallet"
|
|
8
|
+
}, i = (e) => {
|
|
9
|
+
const r = e?.session?.peer?.metadata?.name;
|
|
10
|
+
return !Object.values(o).includes(r);
|
|
11
|
+
};
|
|
12
|
+
export {
|
|
13
|
+
u as browserSupported,
|
|
14
|
+
i as walletSupported
|
|
15
|
+
};
|
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
import { getERC20Registry as p } from "../../constants/token-data/ERC20Registry.js";
|
|
2
|
+
import "../../constants/chains.constants.js";
|
|
3
|
+
import "../../types/circom-data.types.js";
|
|
4
|
+
import "../../types/transactions.types.js";
|
|
5
|
+
import "../../types/curve.types.js";
|
|
6
|
+
import "ethers";
|
|
7
|
+
import "circomlibjs";
|
|
8
|
+
import "../../data-structures/crypto-keys/keys.js";
|
|
9
|
+
import "axios";
|
|
10
|
+
import "../../data-structures/crypto-keys/encryptDecryptUtxo.js";
|
|
11
|
+
import "../web3/events/getShieldedBalance.js";
|
|
12
|
+
import "../../webworker/workerFactory.js";
|
|
13
|
+
import "./external-action.utils.js";
|
|
14
|
+
import { customTokenRegistry as s } from "../../data-structures/custom-token-registry/CustomTokenRegistry.js";
|
|
15
|
+
import "./convertIntegrationProviderToExternalActionId.js";
|
|
16
|
+
import "../../constants/coingecko.constants.js";
|
|
17
|
+
import "../../constants/vite.constants.js";
|
|
18
|
+
import "./userAgent.js";
|
|
19
|
+
import "../../constants/reorg-depths.constants.js";
|
|
20
|
+
import "../../constants/kyc.constants.js";
|
|
21
|
+
import { VolatileHelper as e } from "../../data-structures/volatile-helper/VolatileHelper.js";
|
|
22
|
+
import "libsodium-wrappers";
|
|
23
|
+
import "../../constants/contracts.constants.js";
|
|
24
|
+
import "../../constants/axelar.constants.js";
|
|
25
|
+
import "../../constants/rewards.constants.js";
|
|
26
|
+
const m = { chains: [] }, v = async (r) => {
|
|
27
|
+
let o = [...p(r), ...s.getCustomTokens(r)];
|
|
28
|
+
m.chains.includes(r) || (o = await Promise.all(
|
|
29
|
+
o.map(async (t) => {
|
|
30
|
+
if (t.isVolatile) {
|
|
31
|
+
const i = await e.getShareTokenAddress(r, t.erc20TokenAddress);
|
|
32
|
+
i && (t.sharedAddress = i);
|
|
33
|
+
}
|
|
34
|
+
return t;
|
|
35
|
+
})
|
|
36
|
+
), m.chains.push(r));
|
|
37
|
+
};
|
|
38
|
+
export {
|
|
39
|
+
v as patchRegistry
|
|
40
|
+
};
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
import { ethers as i, BigNumber as a } from "ethers";
|
|
2
|
+
import { transactionErrorCodes as c } from "../../error-handling/error-codes.constants.js";
|
|
3
|
+
const h = (t) => i.utils.parseEther(t).toBigInt(), P = (t) => i.BigNumber.from(i.utils.randomBytes(t)).toBigInt(), f = (t, n) => i.utils.formatUnits(n, t.decimals), m = (t, n) => {
|
|
4
|
+
const r = 10 ** (18 - t.decimals);
|
|
5
|
+
try {
|
|
6
|
+
return i.utils.parseUnits(n).div(a.from(r.toString())).toBigInt();
|
|
7
|
+
} catch {
|
|
8
|
+
throw new Error(c.DECIMALS_LIMIT);
|
|
9
|
+
}
|
|
10
|
+
}, g = (t) => {
|
|
11
|
+
const n = t.toFixed(30), [r, e] = n.split("."), s = e ? e.length : 0, o = `${r}${e || ""}`;
|
|
12
|
+
return [BigInt(o), s];
|
|
13
|
+
}, v = (t, n) => {
|
|
14
|
+
try {
|
|
15
|
+
return m(t, n);
|
|
16
|
+
} catch {
|
|
17
|
+
return BigInt(0);
|
|
18
|
+
}
|
|
19
|
+
}, u = (t, n, r) => {
|
|
20
|
+
const e = i.utils.formatUnits(t, n.decimals), s = BigInt(10 ** (18 - r));
|
|
21
|
+
try {
|
|
22
|
+
const o = i.utils.parseUnits(e).div(a.from(s.toString())).toBigInt();
|
|
23
|
+
return i.utils.formatUnits(o, r);
|
|
24
|
+
} catch {
|
|
25
|
+
throw new Error(c.DECIMALS_LIMIT);
|
|
26
|
+
}
|
|
27
|
+
}, D = (t, n, r, e) => {
|
|
28
|
+
const [s, o] = g(r);
|
|
29
|
+
return { totalValueDollarsBigInt: n * s / BigInt(10 ** (t.decimals - e)) / BigInt(10 ** o), precision: e };
|
|
30
|
+
}, E = (t, n) => !t || !n ? "0" : u(n ?? 0n, t, t.decimals).toString() ?? "0";
|
|
31
|
+
export {
|
|
32
|
+
D as calculateDollarValue,
|
|
33
|
+
h as ethToWei,
|
|
34
|
+
f as getAmountInToken,
|
|
35
|
+
m as getAmountInWei,
|
|
36
|
+
v as getAmountInWeiOrZero,
|
|
37
|
+
u as getAmountWithPrecision,
|
|
38
|
+
E as getAmountWithPrecisionOrZero,
|
|
39
|
+
P as randomBigInt,
|
|
40
|
+
g as toBigIntWithDecimals
|
|
41
|
+
};
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import "../../../types/circom-data.types.js";
|
|
2
|
+
import { EventType as e } from "../../../types/hinkal.types.js";
|
|
3
|
+
import "../../../types/transactions.types.js";
|
|
4
|
+
import "../../../types/curve.types.js";
|
|
5
|
+
const p = () => {
|
|
6
|
+
document.dispatchEvent(new Event(e.BalanceChange));
|
|
7
|
+
};
|
|
8
|
+
export {
|
|
9
|
+
p as balanceChangedHandler
|
|
10
|
+
};
|
|
@@ -0,0 +1,72 @@
|
|
|
1
|
+
import { Utxo as C } from "../../../data-structures/utxo/Utxo.js";
|
|
2
|
+
import "../../../types/circom-data.types.js";
|
|
3
|
+
import { ContractType as m } from "../../../types/ethereum-network.types.js";
|
|
4
|
+
import "../../../types/transactions.types.js";
|
|
5
|
+
import "../../../types/curve.types.js";
|
|
6
|
+
import { getHinkalCache as O, setHinkalCache as P } from "../../utils/cacheFunctions.js";
|
|
7
|
+
const b = async (e, r, u, n, i = 0) => (await e.utxoUtils.buildBatchProcess(r, u)).reduce((s, t) => n && i !== 0 ? t.erc20TokenAddress.toLowerCase() === n.toLowerCase() && t.tokenId === i ? [...s, t] : s : n ? t.erc20TokenAddress.toLowerCase() === n.toLowerCase() ? [...s, t] : s : [...s, t], []), I = async (e, r, u, n, i, a, s, t = 0) => {
|
|
8
|
+
const o = await e.utxoUtils.batchFilterUtxosWithNullifier(r, u);
|
|
9
|
+
if (s) {
|
|
10
|
+
for (o.sort((l, c) => l.amount <= c.amount ? 1 : -1); o.length < n || o.length > n && o.length < 6; )
|
|
11
|
+
o.push(new C({ amount: 0n, erc20TokenAddress: s, shieldedPrivateKey: a, tokenId: t }));
|
|
12
|
+
if (i)
|
|
13
|
+
for (; o.length > 6; )
|
|
14
|
+
o.splice(o.length - 1);
|
|
15
|
+
}
|
|
16
|
+
return {
|
|
17
|
+
inputUtxos: o
|
|
18
|
+
};
|
|
19
|
+
}, B = async ({
|
|
20
|
+
hinkal: e,
|
|
21
|
+
erc20TokenAddress: r = void 0,
|
|
22
|
+
minInput: u = 2,
|
|
23
|
+
sliceIfMore6: n = !0,
|
|
24
|
+
tokenId: i = 0
|
|
25
|
+
}) => {
|
|
26
|
+
if (!e.getCurrentChainId || !e.getSelectedNetwork())
|
|
27
|
+
return { inputUtxos: [] };
|
|
28
|
+
const { encryptedOutputs: a, nullifiers: s, userKeys: t } = e, o = Array.from(a), l = e.getCurrentChainId(), c = e.getContract(m.HinkalContract).address, y = t.getShieldedPublicKey(), U = t.getShieldedPrivateKey();
|
|
29
|
+
let p = [], f = [], { encryptedOutputs: g, lastOutput: d } = O(
|
|
30
|
+
l,
|
|
31
|
+
y,
|
|
32
|
+
c
|
|
33
|
+
), h = o.findIndex((x) => x.value === d);
|
|
34
|
+
if (h > -1 || g.length === 0) {
|
|
35
|
+
h += 1;
|
|
36
|
+
const x = o.slice(h);
|
|
37
|
+
({ lastOutput: d, additionalEncryptedOutputs: f } = await e.utxoUtils.batchProcess(
|
|
38
|
+
x,
|
|
39
|
+
d,
|
|
40
|
+
t
|
|
41
|
+
)), p = [...g, ...f], P(
|
|
42
|
+
{
|
|
43
|
+
lastOutput: d,
|
|
44
|
+
encryptedOutputs: p
|
|
45
|
+
},
|
|
46
|
+
l,
|
|
47
|
+
y,
|
|
48
|
+
c
|
|
49
|
+
);
|
|
50
|
+
}
|
|
51
|
+
const w = await b(
|
|
52
|
+
e,
|
|
53
|
+
p,
|
|
54
|
+
t,
|
|
55
|
+
r,
|
|
56
|
+
i
|
|
57
|
+
);
|
|
58
|
+
return await I(
|
|
59
|
+
e,
|
|
60
|
+
w,
|
|
61
|
+
s,
|
|
62
|
+
u,
|
|
63
|
+
n,
|
|
64
|
+
U,
|
|
65
|
+
r,
|
|
66
|
+
i
|
|
67
|
+
);
|
|
68
|
+
};
|
|
69
|
+
export {
|
|
70
|
+
B as getInputUtxoAndBalance,
|
|
71
|
+
b as getInputUtxosFromEncryptedOutputs
|
|
72
|
+
};
|
|
@@ -0,0 +1,107 @@
|
|
|
1
|
+
import { Mutex as A } from "async-mutex";
|
|
2
|
+
import { getERC20Registry as w } from "../../../constants/token-data/ERC20Registry.js";
|
|
3
|
+
import { Utxo as k } from "../../../data-structures/utxo/Utxo.js";
|
|
4
|
+
import { customTokenRegistry as I } from "../../../data-structures/custom-token-registry/CustomTokenRegistry.js";
|
|
5
|
+
import { getInputUtxoAndBalance as T } from "./getInputUtxoAndBalance.js";
|
|
6
|
+
import { getAmountWithPrecision as U } from "../etherFunctions.js";
|
|
7
|
+
import { ErrorWithAmount as P } from "../../../error-handling/customErrors/ErrorWithAmount.js";
|
|
8
|
+
import "axios";
|
|
9
|
+
import "../../../constants/chains.constants.js";
|
|
10
|
+
import "../../../types/circom-data.types.js";
|
|
11
|
+
import "../../../types/transactions.types.js";
|
|
12
|
+
import "../../../types/curve.types.js";
|
|
13
|
+
import "ethers";
|
|
14
|
+
import "../../../webworker/workerFactory.js";
|
|
15
|
+
import "../../../data-structures/crypto-keys/keys.js";
|
|
16
|
+
import "../../../data-structures/crypto-keys/encryptDecryptUtxo.js";
|
|
17
|
+
import "../../utils/external-action.utils.js";
|
|
18
|
+
import "../../../constants/coingecko.constants.js";
|
|
19
|
+
import "../../../constants/vite.constants.js";
|
|
20
|
+
import { caseInsensitiveEqual as h } from "../../utils/caseInsensitive.utils.js";
|
|
21
|
+
import "libsodium-wrappers";
|
|
22
|
+
import "circomlibjs";
|
|
23
|
+
import "../../../constants/reorg-depths.constants.js";
|
|
24
|
+
import "../../../constants/kyc.constants.js";
|
|
25
|
+
import { VolatileHelper as b } from "../../../data-structures/volatile-helper/VolatileHelper.js";
|
|
26
|
+
import "../../../constants/contracts.constants.js";
|
|
27
|
+
import "../../../constants/axelar.constants.js";
|
|
28
|
+
import "../../../constants/rewards.constants.js";
|
|
29
|
+
import { getERC20Token as x } from "../../utils/erc20tokenFunctions.js";
|
|
30
|
+
import "../../utils/convertIntegrationProviderToExternalActionId.js";
|
|
31
|
+
import "../../utils/userAgent.js";
|
|
32
|
+
import { patchRegistry as S } from "../../utils/volatile-patcher.utils.js";
|
|
33
|
+
const C = new A(), at = async (a) => {
|
|
34
|
+
const s = await C.acquire(), { inputUtxos: m } = await T({ hinkal: a, sliceIfMore6: !1 }), r = a.getCurrentChainId(), l = [...w(r), ...I.getCustomTokens(r)];
|
|
35
|
+
await S(r);
|
|
36
|
+
const f = l.map((t) => ({
|
|
37
|
+
token: t,
|
|
38
|
+
balance: m.reduce((e, n) => {
|
|
39
|
+
const o = t.isVolatile ? t.sharedAddress : t.erc20TokenAddress;
|
|
40
|
+
return h(o, n.erc20TokenAddress) ? e + n.amount : e;
|
|
41
|
+
}, 0n),
|
|
42
|
+
timestamp: m.filter(
|
|
43
|
+
(e) => h(e.erc20TokenAddress, t.erc20TokenAddress)
|
|
44
|
+
)[0]?.timeStamp,
|
|
45
|
+
nfts: m.filter(
|
|
46
|
+
(e) => h(e.erc20TokenAddress, t.erc20TokenAddress) && e.tokenId !== 0
|
|
47
|
+
).map((e) => ({ tokenId: e.tokenId, timestamp: e.timeStamp }))
|
|
48
|
+
})), u = await Promise.all(
|
|
49
|
+
f.map(async (t) => {
|
|
50
|
+
if (!t.token.isVolatile)
|
|
51
|
+
return t;
|
|
52
|
+
t.token?.sharedAddress || console.log("VolatileToken must have a corresponding sharedAddress");
|
|
53
|
+
let e = 0n;
|
|
54
|
+
return t.balance > 0n && (e = await b.getVolatileTokenBalance(
|
|
55
|
+
r,
|
|
56
|
+
t.token.sharedAddress,
|
|
57
|
+
t.balance
|
|
58
|
+
)), {
|
|
59
|
+
...t,
|
|
60
|
+
balance: BigInt(e)
|
|
61
|
+
};
|
|
62
|
+
})
|
|
63
|
+
);
|
|
64
|
+
return s(), u;
|
|
65
|
+
}, mt = async (a, s, m, r = 6, l = s.map(() => 0), f = !1) => {
|
|
66
|
+
const { userKeys: u } = a, t = [], e = [];
|
|
67
|
+
let n = 0;
|
|
68
|
+
for (let o = 0; o < s.length; o += 1)
|
|
69
|
+
if (f === !1) {
|
|
70
|
+
const { inputUtxos: i } = await T({
|
|
71
|
+
hinkal: a,
|
|
72
|
+
erc20TokenAddress: s[o],
|
|
73
|
+
tokenId: l[o],
|
|
74
|
+
sliceIfMore6: !1
|
|
75
|
+
});
|
|
76
|
+
n = Math.max(i.length, n), e.push(i);
|
|
77
|
+
} else
|
|
78
|
+
e.push([]);
|
|
79
|
+
return console.log({ maxUtxoNum: n }), n === 2 ? e : (e.forEach((o, i) => {
|
|
80
|
+
if (o.length > r) {
|
|
81
|
+
const d = o.slice(0, r), p = d.reduce((c, g) => c + g.amount, 0n);
|
|
82
|
+
if (m[i] < 0n && p < -m[i]) {
|
|
83
|
+
const c = x(s[i], a.getCurrentChainId()), g = Number(U(p, c, 2)), y = `Unfortunately your transaction did not go through due to UTXOs limitations.
|
|
84
|
+
Please try again with ${c.symbol}`;
|
|
85
|
+
throw new P(g, y);
|
|
86
|
+
}
|
|
87
|
+
t.push(d);
|
|
88
|
+
} else if (o.length <= r) {
|
|
89
|
+
const d = [...o];
|
|
90
|
+
let p = r - o.length;
|
|
91
|
+
for (; p > 0; )
|
|
92
|
+
p -= 1, d.push(
|
|
93
|
+
new k({
|
|
94
|
+
amount: 0n,
|
|
95
|
+
erc20TokenAddress: s[i],
|
|
96
|
+
shieldedPrivateKey: u.getShieldedPrivateKey(),
|
|
97
|
+
tokenId: l[i]
|
|
98
|
+
})
|
|
99
|
+
);
|
|
100
|
+
t.push(d);
|
|
101
|
+
}
|
|
102
|
+
}), t);
|
|
103
|
+
};
|
|
104
|
+
export {
|
|
105
|
+
mt as addPaddingToUtxos,
|
|
106
|
+
at as getShieldedBalance
|
|
107
|
+
};
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
const i = async (e, s, ...n) => {
|
|
2
|
+
if (!e.filters?.[s])
|
|
3
|
+
throw new Error("Contract Event not found");
|
|
4
|
+
return await e.queryFilter(e.filters?.[s](...n), 39561411);
|
|
5
|
+
}, o = async (e, s) => (await i(e, "NewTransaction")).map((t) => t.args[1] === s && BigInt(t.args[2]) >= 0n ? new Date(t.args[0] * 1e3) : /* @__PURE__ */ new Date(0)).filter((t) => t.getTime() !== 0);
|
|
6
|
+
export {
|
|
7
|
+
o as getDepositEvents,
|
|
8
|
+
i as retrieveEvents
|
|
9
|
+
};
|
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
import { networkRegistry as a } from "../../../constants/chains.constants.js";
|
|
2
|
+
import "../../../types/circom-data.types.js";
|
|
3
|
+
import { ContractType as c } from "../../../types/ethereum-network.types.js";
|
|
4
|
+
import "../../../types/transactions.types.js";
|
|
5
|
+
import "../../../types/curve.types.js";
|
|
6
|
+
import { ethToWei as m } from "../etherFunctions.js";
|
|
7
|
+
import "ethers";
|
|
8
|
+
import "circomlibjs";
|
|
9
|
+
import "../../../data-structures/crypto-keys/keys.js";
|
|
10
|
+
import "axios";
|
|
11
|
+
import "../../../data-structures/crypto-keys/encryptDecryptUtxo.js";
|
|
12
|
+
import "../events/getShieldedBalance.js";
|
|
13
|
+
import "../../../webworker/workerFactory.js";
|
|
14
|
+
import "../../utils/external-action.utils.js";
|
|
15
|
+
import "../../../data-structures/custom-token-registry/CustomTokenRegistry.js";
|
|
16
|
+
import "../../utils/convertIntegrationProviderToExternalActionId.js";
|
|
17
|
+
import "../../../constants/coingecko.constants.js";
|
|
18
|
+
import "../../../constants/vite.constants.js";
|
|
19
|
+
import "../../utils/userAgent.js";
|
|
20
|
+
import "../../../constants/reorg-depths.constants.js";
|
|
21
|
+
import "../../../constants/kyc.constants.js";
|
|
22
|
+
import "../../../data-structures/volatile-helper/VolatileHelper.js";
|
|
23
|
+
import "libsodium-wrappers";
|
|
24
|
+
import "../../../constants/contracts.constants.js";
|
|
25
|
+
import "../../../constants/axelar.constants.js";
|
|
26
|
+
import "../../../constants/rewards.constants.js";
|
|
27
|
+
const J = async (t) => (await t.getContractWithFetcher(c.CrossChainAccessTokenContract).functions.hasToken(t.userKeys.getAccessKey()))[0], L = async (t, e) => {
|
|
28
|
+
const o = t.getContractWithSigner(c.CrossChainAccessTokenContract), s = a[t.getCurrentChainId()].accessTokenMintingFee ?? "0", n = {
|
|
29
|
+
value: m(s)
|
|
30
|
+
};
|
|
31
|
+
return await o.addToken(e, n);
|
|
32
|
+
}, N = async (t, e, o) => {
|
|
33
|
+
const s = t.getContractWithSigner(c.CrossChainAccessTokenContract), i = a[t.getCurrentChainId()].accessTokenMintingFee ?? "0", n = m(i), r = o.reduce(
|
|
34
|
+
(T, u) => T + u.messageFee,
|
|
35
|
+
0n
|
|
36
|
+
), p = {
|
|
37
|
+
chains: o,
|
|
38
|
+
totalMessageFees: r
|
|
39
|
+
}, C = {
|
|
40
|
+
value: n + r
|
|
41
|
+
};
|
|
42
|
+
return await s.addTokenCrossChain(e, p, C);
|
|
43
|
+
};
|
|
44
|
+
export {
|
|
45
|
+
J as checkHinkalAccessToken,
|
|
46
|
+
L as mintAccessToken,
|
|
47
|
+
N as mintTokenCrossChain
|
|
48
|
+
};
|