@tonappchain/sdk 0.7.0-rc24-test-9 → 0.7.0-rc24-test-11
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/artifacts/dev/index.d.ts +9 -0
- package/dist/artifacts/dev/index.js +52 -0
- package/dist/artifacts/dev/tac/addresses.d.ts +4 -0
- package/dist/artifacts/dev/tac/addresses.js +8 -0
- package/dist/artifacts/dev/tac/artifacts.d.ts +330 -0
- package/dist/artifacts/dev/tac/artifacts.js +26 -0
- package/dist/artifacts/dev/tac/endpoints.d.ts +2 -0
- package/dist/artifacts/dev/tac/endpoints.js +5 -0
- package/dist/artifacts/dev/tac/index.d.ts +6 -0
- package/dist/artifacts/dev/tac/index.js +43 -0
- package/dist/artifacts/dev/tac/internal/artifacts/@openzeppelin/contracts/token/ERC721/IERC721.sol/IERC721.json +296 -0
- package/dist/artifacts/dev/tac/internal/artifacts/contracts/core/Structs.sol/IStructsInterface.json +1087 -0
- package/dist/artifacts/dev/tac/internal/artifacts/contracts/interfaces/ICrossChainLayer.sol/ICrossChainLayer.json +114 -0
- package/dist/artifacts/dev/tac/internal/artifacts/contracts/interfaces/ISettings.sol/ISettings.json +194 -0
- package/dist/artifacts/dev/tac/internal/artifacts/contracts/interfaces/ITokenUtils.sol/ITokenUtils.json +164 -0
- package/dist/artifacts/dev/tac/internal/artifacts/contracts/interfaces/tokens/ICrossChainLayerERC20.sol/ICrossChainLayerERC20.json +278 -0
- package/dist/artifacts/dev/tac/internal/artifacts/contracts/interfaces/tokens/ICrossChainLayerERC721.sol/ICrossChainLayerERC721.json +380 -0
- package/dist/artifacts/dev/tac/internal/artifacts/contracts/interfaces/tokens/IERC20WithDecimals.sol/IERC20WithDecimals.json +207 -0
- package/dist/artifacts/dev/tac/internal/artifacts/contracts/smart-account/interfaces/ISAFactory.sol/ISAFactory.json +103 -0
- package/dist/artifacts/dev/tac/internal/artifacts/contracts/smart-account/interfaces/ITacSmartAccount.sol/ITacSmartAccount.json +181 -0
- package/dist/artifacts/dev/tac/internal/scripts/utils/encoding.d.ts +4 -0
- package/dist/artifacts/dev/tac/internal/scripts/utils/encoding.js +18 -0
- package/dist/artifacts/dev/tac/internal/typechain-types/@openzeppelin/contracts/token/ERC721/IERC721.d.ts +199 -0
- package/dist/artifacts/dev/tac/internal/typechain-types/common.d.ts +50 -0
- package/dist/artifacts/dev/tac/internal/typechain-types/common.js +2 -0
- package/dist/artifacts/dev/tac/internal/typechain-types/contracts/core/Structs.sol/IStructsInterface.d.ts +356 -0
- package/dist/artifacts/dev/tac/internal/typechain-types/contracts/core/Structs.sol/IStructsInterface.js +2 -0
- package/dist/artifacts/dev/tac/internal/typechain-types/contracts/interfaces/ICrossChainLayer.d.ts +75 -0
- package/dist/artifacts/dev/tac/internal/typechain-types/contracts/interfaces/ICrossChainLayer.js +2 -0
- package/dist/artifacts/dev/tac/internal/typechain-types/contracts/interfaces/ISettings.d.ts +123 -0
- package/dist/artifacts/dev/tac/internal/typechain-types/contracts/interfaces/ISettings.js +2 -0
- package/dist/artifacts/dev/tac/internal/typechain-types/contracts/interfaces/ITokenUtils.d.ts +99 -0
- package/dist/artifacts/dev/tac/internal/typechain-types/contracts/interfaces/ITokenUtils.js +2 -0
- package/dist/artifacts/dev/tac/internal/typechain-types/contracts/interfaces/tokens/ICrossChainLayerERC20.d.ts +182 -0
- package/dist/artifacts/dev/tac/internal/typechain-types/contracts/interfaces/tokens/ICrossChainLayerERC20.js +2 -0
- package/dist/artifacts/dev/tac/internal/typechain-types/contracts/interfaces/tokens/ICrossChainLayerERC721.d.ts +244 -0
- package/dist/artifacts/dev/tac/internal/typechain-types/contracts/interfaces/tokens/ICrossChainLayerERC721.js +2 -0
- package/dist/artifacts/dev/tac/internal/typechain-types/contracts/interfaces/tokens/IERC20WithDecimals.d.ts +133 -0
- package/dist/artifacts/dev/tac/internal/typechain-types/contracts/interfaces/tokens/IERC20WithDecimals.js +2 -0
- package/dist/artifacts/dev/tac/internal/typechain-types/contracts/smart-account/interfaces/ISAFactory.d.ts +77 -0
- package/dist/artifacts/dev/tac/internal/typechain-types/contracts/smart-account/interfaces/ISAFactory.js +2 -0
- package/dist/artifacts/dev/tac/internal/typechain-types/contracts/smart-account/interfaces/ITacSmartAccount.d.ts +127 -0
- package/dist/artifacts/dev/tac/internal/typechain-types/contracts/smart-account/interfaces/ITacSmartAccount.js +2 -0
- package/dist/artifacts/dev/tac/multicall.d.ts +1 -0
- package/dist/artifacts/dev/tac/multicall.js +22 -0
- package/dist/artifacts/dev/tac/structs.d.ts +1 -0
- package/dist/artifacts/dev/tac/structs.js +2 -0
- package/dist/artifacts/dev/tac/utils.d.ts +1 -0
- package/dist/artifacts/dev/tac/utils.js +5 -0
- package/dist/artifacts/dev/tac/wrappers.d.ts +9 -0
- package/dist/artifacts/dev/tac/wrappers.js +2 -0
- package/dist/artifacts/dev/ton/addresses.d.ts +1 -0
- package/dist/artifacts/dev/ton/addresses.js +5 -0
- package/dist/artifacts/dev/ton/artifacts.d.ts +47 -0
- package/dist/artifacts/dev/ton/artifacts.js +26 -0
- package/dist/artifacts/dev/ton/endpoints.d.ts +3 -0
- package/dist/artifacts/dev/ton/endpoints.js +6 -0
- package/dist/artifacts/dev/ton/index.d.ts +3 -0
- package/dist/artifacts/dev/ton/index.js +40 -0
- package/dist/artifacts/dev/ton/internal/build/CrossChainLayer.compiled.json +1 -0
- package/dist/artifacts/dev/ton/internal/build/Executor.compiled.json +1 -0
- package/dist/artifacts/dev/ton/internal/build/JettonMinter.compiled.json +1 -0
- package/dist/artifacts/dev/ton/internal/build/JettonProxy.compiled.json +1 -0
- package/dist/artifacts/dev/ton/internal/build/JettonWallet.compiled.json +1 -0
- package/dist/artifacts/dev/ton/internal/build/NFTCollection.compiled.json +1 -0
- package/dist/artifacts/dev/ton/internal/build/NFTItem.compiled.json +1 -0
- package/dist/artifacts/dev/ton/internal/build/NFTProxy.compiled.json +1 -0
- package/dist/artifacts/dev/ton/internal/build/Settings.compiled.json +1 -0
- package/dist/artifacts/dev/ton/internal/wrappers/Constants.d.ts +56 -0
- package/dist/artifacts/dev/ton/internal/wrappers/Constants.js +62 -0
- package/dist/artifacts/dev/ton/internal/wrappers/CrossChainLayer.d.ts +164 -0
- package/dist/artifacts/dev/ton/internal/wrappers/CrossChainLayer.js +336 -0
- package/dist/artifacts/dev/ton/internal/wrappers/JettonMinter.d.ts +94 -0
- package/dist/artifacts/dev/ton/internal/wrappers/JettonMinter.js +202 -0
- package/dist/artifacts/dev/ton/internal/wrappers/JettonProxy.d.ts +80 -0
- package/dist/artifacts/dev/ton/internal/wrappers/JettonProxy.js +158 -0
- package/dist/{wrappers → artifacts/dev/ton/internal/wrappers}/JettonWallet.d.ts +52 -13
- package/dist/artifacts/dev/ton/internal/wrappers/JettonWallet.js +193 -0
- package/dist/artifacts/dev/ton/internal/wrappers/NFTCollection.d.ts +75 -0
- package/dist/artifacts/dev/ton/internal/wrappers/NFTCollection.js +151 -0
- package/dist/artifacts/dev/ton/internal/wrappers/NFTItem.d.ts +82 -0
- package/dist/artifacts/dev/ton/internal/wrappers/NFTItem.js +148 -0
- package/dist/artifacts/dev/ton/internal/wrappers/NFTProxy.d.ts +84 -0
- package/dist/artifacts/dev/ton/internal/wrappers/NFTProxy.js +157 -0
- package/dist/artifacts/dev/ton/internal/wrappers/Settings.d.ts +80 -0
- package/dist/artifacts/dev/ton/internal/wrappers/Settings.js +152 -0
- package/dist/artifacts/dev/ton/internal/wrappers/utils/GasUtils.d.ts +79 -0
- package/dist/artifacts/dev/ton/internal/wrappers/utils/GasUtils.js +291 -0
- package/dist/artifacts/dev/ton/internal/wrappers/utils/MerkleRoots.d.ts +7 -0
- package/dist/artifacts/dev/ton/internal/wrappers/utils/MerkleRoots.js +27 -0
- package/dist/artifacts/dev/ton/wrappers.d.ts +8 -0
- package/dist/artifacts/dev/ton/wrappers.js +27 -0
- package/dist/artifacts/index.d.ts +3 -0
- package/dist/artifacts/index.js +39 -0
- package/dist/artifacts/mainnet/index.d.ts +9 -0
- package/dist/artifacts/mainnet/index.js +52 -0
- package/dist/artifacts/mainnet/tac/addresses.d.ts +4 -0
- package/dist/artifacts/mainnet/tac/addresses.js +7 -0
- package/dist/artifacts/mainnet/tac/artifacts.d.ts +330 -0
- package/dist/artifacts/mainnet/tac/artifacts.js +26 -0
- package/dist/artifacts/mainnet/tac/endpoints.d.ts +2 -0
- package/dist/artifacts/mainnet/tac/endpoints.js +5 -0
- package/dist/artifacts/mainnet/tac/index.d.ts +6 -0
- package/dist/artifacts/mainnet/tac/index.js +43 -0
- package/dist/artifacts/mainnet/tac/internal/artifacts/@openzeppelin/contracts/token/ERC721/IERC721.sol/IERC721.json +296 -0
- package/dist/artifacts/mainnet/tac/internal/artifacts/contracts/core/Structs.sol/IStructsInterface.json +1087 -0
- package/dist/artifacts/mainnet/tac/internal/artifacts/contracts/interfaces/ICrossChainLayer.sol/ICrossChainLayer.json +114 -0
- package/dist/artifacts/mainnet/tac/internal/artifacts/contracts/interfaces/ISettings.sol/ISettings.json +194 -0
- package/dist/artifacts/mainnet/tac/internal/artifacts/contracts/interfaces/ITokenUtils.sol/ITokenUtils.json +164 -0
- package/dist/artifacts/mainnet/tac/internal/artifacts/contracts/interfaces/tokens/ICrossChainLayerERC20.sol/ICrossChainLayerERC20.json +278 -0
- package/dist/artifacts/mainnet/tac/internal/artifacts/contracts/interfaces/tokens/ICrossChainLayerERC721.sol/ICrossChainLayerERC721.json +380 -0
- package/dist/artifacts/mainnet/tac/internal/artifacts/contracts/interfaces/tokens/IERC20WithDecimals.sol/IERC20WithDecimals.json +207 -0
- package/dist/artifacts/mainnet/tac/internal/artifacts/contracts/smart-account/interfaces/ISAFactory.sol/ISAFactory.json +103 -0
- package/dist/artifacts/mainnet/tac/internal/artifacts/contracts/smart-account/interfaces/ITacSmartAccount.sol/ITacSmartAccount.json +181 -0
- package/dist/artifacts/mainnet/tac/internal/scripts/utils/encoding.d.ts +4 -0
- package/dist/artifacts/mainnet/tac/internal/scripts/utils/encoding.js +18 -0
- package/dist/artifacts/mainnet/tac/internal/typechain-types/@openzeppelin/contracts/token/ERC721/IERC721.d.ts +199 -0
- package/dist/artifacts/mainnet/tac/internal/typechain-types/@openzeppelin/contracts/token/ERC721/IERC721.js +2 -0
- package/dist/artifacts/mainnet/tac/internal/typechain-types/common.d.ts +50 -0
- package/dist/artifacts/mainnet/tac/internal/typechain-types/common.js +2 -0
- package/dist/artifacts/mainnet/tac/internal/typechain-types/contracts/core/Structs.sol/IStructsInterface.d.ts +356 -0
- package/dist/artifacts/mainnet/tac/internal/typechain-types/contracts/core/Structs.sol/IStructsInterface.js +2 -0
- package/dist/artifacts/mainnet/tac/internal/typechain-types/contracts/interfaces/ICrossChainLayer.d.ts +75 -0
- package/dist/artifacts/mainnet/tac/internal/typechain-types/contracts/interfaces/ICrossChainLayer.js +2 -0
- package/dist/artifacts/mainnet/tac/internal/typechain-types/contracts/interfaces/ISettings.d.ts +123 -0
- package/dist/artifacts/mainnet/tac/internal/typechain-types/contracts/interfaces/ISettings.js +2 -0
- package/dist/artifacts/mainnet/tac/internal/typechain-types/contracts/interfaces/ITokenUtils.d.ts +99 -0
- package/dist/artifacts/mainnet/tac/internal/typechain-types/contracts/interfaces/ITokenUtils.js +2 -0
- package/dist/artifacts/mainnet/tac/internal/typechain-types/contracts/interfaces/tokens/ICrossChainLayerERC20.d.ts +182 -0
- package/dist/artifacts/mainnet/tac/internal/typechain-types/contracts/interfaces/tokens/ICrossChainLayerERC20.js +2 -0
- package/dist/artifacts/mainnet/tac/internal/typechain-types/contracts/interfaces/tokens/ICrossChainLayerERC721.d.ts +244 -0
- package/dist/artifacts/mainnet/tac/internal/typechain-types/contracts/interfaces/tokens/ICrossChainLayerERC721.js +2 -0
- package/dist/artifacts/mainnet/tac/internal/typechain-types/contracts/interfaces/tokens/IERC20WithDecimals.d.ts +133 -0
- package/dist/artifacts/mainnet/tac/internal/typechain-types/contracts/interfaces/tokens/IERC20WithDecimals.js +2 -0
- package/dist/artifacts/mainnet/tac/internal/typechain-types/contracts/smart-account/interfaces/ISAFactory.d.ts +77 -0
- package/dist/artifacts/mainnet/tac/internal/typechain-types/contracts/smart-account/interfaces/ISAFactory.js +2 -0
- package/dist/artifacts/mainnet/tac/internal/typechain-types/contracts/smart-account/interfaces/ITacSmartAccount.d.ts +127 -0
- package/dist/artifacts/mainnet/tac/internal/typechain-types/contracts/smart-account/interfaces/ITacSmartAccount.js +2 -0
- package/dist/artifacts/mainnet/tac/multicall.d.ts +1 -0
- package/dist/artifacts/mainnet/tac/multicall.js +22 -0
- package/dist/artifacts/mainnet/tac/structs.d.ts +1 -0
- package/dist/artifacts/mainnet/tac/structs.js +2 -0
- package/dist/artifacts/mainnet/tac/utils.d.ts +1 -0
- package/dist/artifacts/mainnet/tac/utils.js +5 -0
- package/dist/artifacts/mainnet/tac/wrappers.d.ts +9 -0
- package/dist/artifacts/mainnet/tac/wrappers.js +2 -0
- package/dist/artifacts/mainnet/ton/addresses.d.ts +1 -0
- package/dist/artifacts/mainnet/ton/addresses.js +4 -0
- package/dist/artifacts/mainnet/ton/artifacts.d.ts +47 -0
- package/dist/artifacts/mainnet/ton/artifacts.js +26 -0
- package/dist/artifacts/mainnet/ton/endpoints.d.ts +3 -0
- package/dist/artifacts/mainnet/ton/endpoints.js +6 -0
- package/dist/artifacts/mainnet/ton/index.d.ts +3 -0
- package/dist/artifacts/mainnet/ton/index.js +40 -0
- package/dist/artifacts/mainnet/ton/internal/build/CrossChainLayer.compiled.json +1 -0
- package/dist/artifacts/mainnet/ton/internal/build/Executor.compiled.json +1 -0
- package/dist/artifacts/mainnet/ton/internal/build/JettonMinter.compiled.json +1 -0
- package/dist/artifacts/mainnet/ton/internal/build/JettonProxy.compiled.json +1 -0
- package/dist/artifacts/mainnet/ton/internal/build/JettonWallet.compiled.json +1 -0
- package/dist/artifacts/mainnet/ton/internal/build/NFTCollection.compiled.json +1 -0
- package/dist/artifacts/mainnet/ton/internal/build/NFTItem.compiled.json +1 -0
- package/dist/artifacts/mainnet/ton/internal/build/NFTProxy.compiled.json +1 -0
- package/dist/artifacts/mainnet/ton/internal/build/Settings.compiled.json +1 -0
- package/dist/artifacts/mainnet/ton/internal/wrappers/Constants.d.ts +56 -0
- package/dist/artifacts/mainnet/ton/internal/wrappers/Constants.js +62 -0
- package/dist/artifacts/mainnet/ton/internal/wrappers/CrossChainLayer.d.ts +164 -0
- package/dist/artifacts/mainnet/ton/internal/wrappers/CrossChainLayer.js +336 -0
- package/dist/artifacts/mainnet/ton/internal/wrappers/JettonMinter.d.ts +94 -0
- package/dist/artifacts/mainnet/ton/internal/wrappers/JettonMinter.js +202 -0
- package/dist/artifacts/mainnet/ton/internal/wrappers/JettonProxy.d.ts +80 -0
- package/dist/artifacts/mainnet/ton/internal/wrappers/JettonProxy.js +158 -0
- package/dist/artifacts/mainnet/ton/internal/wrappers/JettonWallet.d.ts +95 -0
- package/dist/artifacts/mainnet/ton/internal/wrappers/JettonWallet.js +193 -0
- package/dist/artifacts/mainnet/ton/internal/wrappers/NFTCollection.d.ts +75 -0
- package/dist/artifacts/mainnet/ton/internal/wrappers/NFTCollection.js +151 -0
- package/dist/artifacts/mainnet/ton/internal/wrappers/NFTItem.d.ts +82 -0
- package/dist/artifacts/mainnet/ton/internal/wrappers/NFTItem.js +148 -0
- package/dist/artifacts/mainnet/ton/internal/wrappers/NFTProxy.d.ts +84 -0
- package/dist/artifacts/mainnet/ton/internal/wrappers/NFTProxy.js +157 -0
- package/dist/artifacts/mainnet/ton/internal/wrappers/Settings.d.ts +80 -0
- package/dist/artifacts/mainnet/ton/internal/wrappers/Settings.js +152 -0
- package/dist/artifacts/mainnet/ton/internal/wrappers/utils/GasUtils.d.ts +79 -0
- package/dist/artifacts/mainnet/ton/internal/wrappers/utils/GasUtils.js +291 -0
- package/dist/artifacts/mainnet/ton/internal/wrappers/utils/MerkleRoots.d.ts +7 -0
- package/dist/artifacts/mainnet/ton/internal/wrappers/utils/MerkleRoots.js +27 -0
- package/dist/artifacts/mainnet/ton/wrappers.d.ts +8 -0
- package/dist/artifacts/mainnet/ton/wrappers.js +27 -0
- package/dist/artifacts/tacTypes.d.ts +13 -0
- package/dist/artifacts/tacTypes.js +2 -0
- package/dist/artifacts/testnet/index.d.ts +9 -0
- package/dist/artifacts/testnet/index.js +52 -0
- package/dist/artifacts/testnet/tac/addresses.d.ts +4 -0
- package/dist/artifacts/testnet/tac/addresses.js +7 -0
- package/dist/artifacts/testnet/tac/artifacts.d.ts +330 -0
- package/dist/artifacts/testnet/tac/artifacts.js +26 -0
- package/dist/artifacts/testnet/tac/endpoints.d.ts +2 -0
- package/dist/artifacts/testnet/tac/endpoints.js +5 -0
- package/dist/artifacts/testnet/tac/index.d.ts +6 -0
- package/dist/artifacts/testnet/tac/index.js +43 -0
- package/dist/artifacts/testnet/tac/internal/artifacts/@openzeppelin/contracts/token/ERC721/IERC721.sol/IERC721.json +296 -0
- package/dist/artifacts/testnet/tac/internal/artifacts/contracts/core/Structs.sol/IStructsInterface.json +1087 -0
- package/dist/artifacts/testnet/tac/internal/artifacts/contracts/interfaces/ICrossChainLayer.sol/ICrossChainLayer.json +114 -0
- package/dist/artifacts/testnet/tac/internal/artifacts/contracts/interfaces/ISettings.sol/ISettings.json +194 -0
- package/dist/artifacts/testnet/tac/internal/artifacts/contracts/interfaces/ITokenUtils.sol/ITokenUtils.json +164 -0
- package/dist/artifacts/testnet/tac/internal/artifacts/contracts/interfaces/tokens/ICrossChainLayerERC20.sol/ICrossChainLayerERC20.json +278 -0
- package/dist/artifacts/testnet/tac/internal/artifacts/contracts/interfaces/tokens/ICrossChainLayerERC721.sol/ICrossChainLayerERC721.json +380 -0
- package/dist/artifacts/testnet/tac/internal/artifacts/contracts/interfaces/tokens/IERC20WithDecimals.sol/IERC20WithDecimals.json +207 -0
- package/dist/artifacts/testnet/tac/internal/artifacts/contracts/smart-account/interfaces/ISAFactory.sol/ISAFactory.json +103 -0
- package/dist/artifacts/testnet/tac/internal/artifacts/contracts/smart-account/interfaces/ITacSmartAccount.sol/ITacSmartAccount.json +181 -0
- package/dist/artifacts/testnet/tac/internal/scripts/utils/encoding.d.ts +4 -0
- package/dist/artifacts/testnet/tac/internal/scripts/utils/encoding.js +18 -0
- package/dist/artifacts/testnet/tac/internal/typechain-types/@openzeppelin/contracts/token/ERC721/IERC721.d.ts +199 -0
- package/dist/artifacts/testnet/tac/internal/typechain-types/@openzeppelin/contracts/token/ERC721/IERC721.js +2 -0
- package/dist/artifacts/testnet/tac/internal/typechain-types/common.d.ts +50 -0
- package/dist/artifacts/testnet/tac/internal/typechain-types/common.js +2 -0
- package/dist/artifacts/testnet/tac/internal/typechain-types/contracts/core/Structs.sol/IStructsInterface.d.ts +356 -0
- package/dist/artifacts/testnet/tac/internal/typechain-types/contracts/core/Structs.sol/IStructsInterface.js +2 -0
- package/dist/artifacts/testnet/tac/internal/typechain-types/contracts/interfaces/ICrossChainLayer.d.ts +75 -0
- package/dist/artifacts/testnet/tac/internal/typechain-types/contracts/interfaces/ICrossChainLayer.js +2 -0
- package/dist/artifacts/testnet/tac/internal/typechain-types/contracts/interfaces/ISettings.d.ts +123 -0
- package/dist/artifacts/testnet/tac/internal/typechain-types/contracts/interfaces/ISettings.js +2 -0
- package/dist/artifacts/testnet/tac/internal/typechain-types/contracts/interfaces/ITokenUtils.d.ts +99 -0
- package/dist/artifacts/testnet/tac/internal/typechain-types/contracts/interfaces/ITokenUtils.js +2 -0
- package/dist/artifacts/testnet/tac/internal/typechain-types/contracts/interfaces/tokens/ICrossChainLayerERC20.d.ts +182 -0
- package/dist/artifacts/testnet/tac/internal/typechain-types/contracts/interfaces/tokens/ICrossChainLayerERC20.js +2 -0
- package/dist/artifacts/testnet/tac/internal/typechain-types/contracts/interfaces/tokens/ICrossChainLayerERC721.d.ts +244 -0
- package/dist/artifacts/testnet/tac/internal/typechain-types/contracts/interfaces/tokens/ICrossChainLayerERC721.js +2 -0
- package/dist/artifacts/testnet/tac/internal/typechain-types/contracts/interfaces/tokens/IERC20WithDecimals.d.ts +133 -0
- package/dist/artifacts/testnet/tac/internal/typechain-types/contracts/interfaces/tokens/IERC20WithDecimals.js +2 -0
- package/dist/artifacts/testnet/tac/internal/typechain-types/contracts/smart-account/interfaces/ISAFactory.d.ts +77 -0
- package/dist/artifacts/testnet/tac/internal/typechain-types/contracts/smart-account/interfaces/ISAFactory.js +2 -0
- package/dist/artifacts/testnet/tac/internal/typechain-types/contracts/smart-account/interfaces/ITacSmartAccount.d.ts +127 -0
- package/dist/artifacts/testnet/tac/internal/typechain-types/contracts/smart-account/interfaces/ITacSmartAccount.js +2 -0
- package/dist/artifacts/testnet/tac/multicall.d.ts +1 -0
- package/dist/artifacts/testnet/tac/multicall.js +22 -0
- package/dist/artifacts/testnet/tac/structs.d.ts +1 -0
- package/dist/artifacts/testnet/tac/structs.js +2 -0
- package/dist/artifacts/testnet/tac/utils.d.ts +1 -0
- package/dist/artifacts/testnet/tac/utils.js +5 -0
- package/dist/artifacts/testnet/tac/wrappers.d.ts +9 -0
- package/dist/artifacts/testnet/tac/wrappers.js +2 -0
- package/dist/artifacts/testnet/ton/addresses.d.ts +1 -0
- package/dist/artifacts/testnet/ton/addresses.js +4 -0
- package/dist/artifacts/testnet/ton/artifacts.d.ts +47 -0
- package/dist/artifacts/testnet/ton/artifacts.js +26 -0
- package/dist/artifacts/testnet/ton/endpoints.d.ts +3 -0
- package/dist/artifacts/testnet/ton/endpoints.js +6 -0
- package/dist/artifacts/testnet/ton/index.d.ts +3 -0
- package/dist/artifacts/testnet/ton/index.js +40 -0
- package/dist/artifacts/testnet/ton/internal/build/CrossChainLayer.compiled.json +1 -0
- package/dist/artifacts/testnet/ton/internal/build/Executor.compiled.json +1 -0
- package/dist/artifacts/testnet/ton/internal/build/JettonMinter.compiled.json +1 -0
- package/dist/artifacts/testnet/ton/internal/build/JettonProxy.compiled.json +1 -0
- package/dist/artifacts/testnet/ton/internal/build/JettonWallet.compiled.json +1 -0
- package/dist/artifacts/testnet/ton/internal/build/NFTCollection.compiled.json +1 -0
- package/dist/artifacts/testnet/ton/internal/build/NFTItem.compiled.json +1 -0
- package/dist/artifacts/testnet/ton/internal/build/NFTProxy.compiled.json +1 -0
- package/dist/artifacts/testnet/ton/internal/build/Settings.compiled.json +1 -0
- package/dist/artifacts/testnet/ton/internal/wrappers/Constants.d.ts +56 -0
- package/dist/artifacts/testnet/ton/internal/wrappers/Constants.js +62 -0
- package/dist/artifacts/testnet/ton/internal/wrappers/CrossChainLayer.d.ts +164 -0
- package/dist/artifacts/testnet/ton/internal/wrappers/CrossChainLayer.js +336 -0
- package/dist/artifacts/testnet/ton/internal/wrappers/JettonMinter.d.ts +94 -0
- package/dist/artifacts/testnet/ton/internal/wrappers/JettonMinter.js +202 -0
- package/dist/artifacts/testnet/ton/internal/wrappers/JettonProxy.d.ts +80 -0
- package/dist/artifacts/testnet/ton/internal/wrappers/JettonProxy.js +158 -0
- package/dist/artifacts/testnet/ton/internal/wrappers/JettonWallet.d.ts +95 -0
- package/dist/artifacts/testnet/ton/internal/wrappers/JettonWallet.js +193 -0
- package/dist/artifacts/testnet/ton/internal/wrappers/NFTCollection.d.ts +75 -0
- package/dist/artifacts/testnet/ton/internal/wrappers/NFTCollection.js +151 -0
- package/dist/artifacts/testnet/ton/internal/wrappers/NFTItem.d.ts +82 -0
- package/dist/artifacts/testnet/ton/internal/wrappers/NFTItem.js +148 -0
- package/dist/artifacts/testnet/ton/internal/wrappers/NFTProxy.d.ts +84 -0
- package/dist/artifacts/testnet/ton/internal/wrappers/NFTProxy.js +157 -0
- package/dist/artifacts/testnet/ton/internal/wrappers/Settings.d.ts +80 -0
- package/dist/artifacts/testnet/ton/internal/wrappers/Settings.js +152 -0
- package/dist/artifacts/testnet/ton/internal/wrappers/utils/GasUtils.d.ts +79 -0
- package/dist/artifacts/testnet/ton/internal/wrappers/utils/GasUtils.js +291 -0
- package/dist/artifacts/testnet/ton/internal/wrappers/utils/MerkleRoots.d.ts +7 -0
- package/dist/artifacts/testnet/ton/internal/wrappers/utils/MerkleRoots.js +27 -0
- package/dist/artifacts/testnet/ton/wrappers.d.ts +8 -0
- package/dist/artifacts/testnet/ton/wrappers.js +27 -0
- package/dist/artifacts/tonTypes.d.ts +20 -0
- package/dist/artifacts/tonTypes.js +2 -0
- package/dist/{adapters → src/adapters}/contractOpener.d.ts +2 -1
- package/dist/{adapters → src/adapters}/contractOpener.js +39 -6
- package/dist/src/adapters/index.d.ts +2 -0
- package/dist/src/adapters/index.js +18 -0
- package/dist/{adapters → src/adapters}/retryableContractOpener.d.ts +6 -3
- package/dist/{adapters → src/adapters}/retryableContractOpener.js +10 -11
- package/dist/src/agnosticSdk/AbiHandler.d.ts +23 -0
- package/dist/src/agnosticSdk/AbiHandler.js +105 -0
- package/dist/src/agnosticSdk/AgnosticSdk.d.ts +201 -0
- package/dist/src/agnosticSdk/AgnosticSdk.js +201 -0
- package/dist/src/agnosticSdk/AgnosticStructs.d.ts +108 -0
- package/dist/src/agnosticSdk/AgnosticStructs.js +23 -0
- package/dist/src/agnosticSdk/DebugHelpers.d.ts +88 -0
- package/dist/src/agnosticSdk/DebugHelpers.js +274 -0
- package/dist/src/agnosticSdk/HooksHandler.d.ts +43 -0
- package/dist/src/agnosticSdk/HooksHandler.js +102 -0
- package/dist/src/agnosticSdk/ReplacementHelper.d.ts +95 -0
- package/dist/src/agnosticSdk/ReplacementHelper.js +233 -0
- package/dist/{assets → src/assets}/AssetCache.d.ts +1 -1
- package/dist/{assets → src/assets}/AssetFactory.d.ts +2 -2
- package/dist/{assets → src/assets}/AssetFactory.js +1 -1
- package/dist/{assets → src/assets}/FT.d.ts +15 -17
- package/dist/{assets → src/assets}/FT.js +103 -56
- package/dist/{assets → src/assets}/NFT.d.ts +15 -16
- package/dist/{assets → src/assets}/NFT.js +62 -34
- package/dist/{assets → src/assets}/TON.d.ts +7 -13
- package/dist/{assets → src/assets}/TON.js +22 -20
- package/dist/src/errors/index.d.ts +2 -0
- package/dist/{errors → src/errors}/index.js +7 -2
- package/dist/{errors → src/errors}/instances.d.ts +8 -1
- package/dist/{errors → src/errors}/instances.js +22 -16
- package/dist/src/index.d.ts +21 -0
- package/dist/{index.js → src/index.js} +38 -18
- package/dist/src/interfaces/Asset.d.ts +78 -0
- package/dist/src/interfaces/Asset.js +2 -0
- package/dist/src/interfaces/ContractOpener.d.ts +21 -0
- package/dist/src/interfaces/ContractOpener.js +2 -0
- package/dist/src/interfaces/IConfiguration.d.ts +35 -0
- package/dist/src/interfaces/IConfiguration.js +2 -0
- package/dist/src/interfaces/IHttpClient.d.ts +16 -0
- package/dist/src/interfaces/IHttpClient.js +2 -0
- package/dist/src/interfaces/ILiteSequencerClient.d.ts +43 -0
- package/dist/src/interfaces/ILiteSequencerClient.js +2 -0
- package/dist/src/interfaces/ILiteSequencerClientFactory.d.ts +9 -0
- package/dist/src/interfaces/ILiteSequencerClientFactory.js +2 -0
- package/dist/src/interfaces/ILogger.d.ts +10 -0
- package/dist/src/interfaces/ILogger.js +2 -0
- package/dist/src/interfaces/IOperationTracker.d.ts +81 -0
- package/dist/src/interfaces/IOperationTracker.js +2 -0
- package/dist/src/interfaces/ISimulator.d.ts +18 -0
- package/dist/src/interfaces/ISimulator.js +2 -0
- package/dist/src/interfaces/ITACTransactionManager.d.ts +15 -0
- package/dist/src/interfaces/ITACTransactionManager.js +2 -0
- package/dist/src/interfaces/ITONTransactionManager.d.ts +21 -0
- package/dist/src/interfaces/ITONTransactionManager.js +2 -0
- package/dist/src/interfaces/ITacSDK.d.ts +185 -0
- package/dist/src/interfaces/ITacSDK.js +2 -0
- package/dist/src/interfaces/SenderAbstraction.d.ts +35 -0
- package/dist/src/interfaces/SenderAbstraction.js +2 -0
- package/dist/src/interfaces/WalletInstanse.d.ts +20 -0
- package/dist/src/interfaces/WalletInstanse.js +2 -0
- package/dist/src/interfaces/index.d.ts +14 -0
- package/dist/src/interfaces/index.js +30 -0
- package/dist/src/sdk/AxiosHttpClient.d.ts +12 -0
- package/dist/src/sdk/AxiosHttpClient.js +23 -0
- package/dist/{sdk → src/sdk}/Configuration.d.ts +6 -5
- package/dist/src/sdk/Configuration.js +189 -0
- package/dist/{sdk → src/sdk}/Consts.d.ts +3 -0
- package/dist/{sdk → src/sdk}/Consts.js +4 -1
- package/dist/src/sdk/LiteSequencerClient.d.ts +18 -0
- package/dist/{sdk → src/sdk}/LiteSequencerClient.js +70 -22
- package/dist/{sdk → src/sdk}/Logger.d.ts +1 -1
- package/dist/{sdk → src/sdk}/OperationTracker.d.ts +5 -13
- package/dist/{sdk → src/sdk}/OperationTracker.js +108 -16
- package/dist/src/sdk/Simulator.d.ts +11 -0
- package/dist/src/sdk/Simulator.js +70 -0
- package/dist/{sdk → src/sdk}/StartTracking.d.ts +1 -1
- package/dist/src/sdk/TACTransactionManager.d.ts +10 -0
- package/dist/src/sdk/TACTransactionManager.js +99 -0
- package/dist/src/sdk/TONTransactionManager.d.ts +17 -0
- package/dist/src/sdk/TONTransactionManager.js +210 -0
- package/dist/src/sdk/TacSdk.d.ts +44 -0
- package/dist/src/sdk/TacSdk.js +181 -0
- package/dist/{sdk → src/sdk}/TxFinalizer.d.ts +3 -2
- package/dist/{sdk → src/sdk}/TxFinalizer.js +8 -8
- package/dist/{sdk → src/sdk}/Utils.d.ts +12 -5
- package/dist/{sdk → src/sdk}/Utils.js +103 -12
- package/dist/{sdk → src/sdk}/Validator.d.ts +2 -2
- package/dist/{sdk → src/sdk}/Validator.js +6 -6
- package/dist/{sender → src/sender}/BatchSender.d.ts +1 -2
- package/dist/{sender → src/sender}/RawSender.d.ts +3 -3
- package/dist/{sender → src/sender}/SenderFactory.d.ts +1 -1
- package/dist/{sender → src/sender}/TonConnectSender.d.ts +2 -2
- package/dist/{sender → src/sender}/TonConnectSender.js +2 -2
- package/dist/{sender → src/sender}/index.d.ts +1 -1
- package/dist/{sender → src/sender}/index.js +1 -1
- package/dist/{structs → src/structs}/InternalStruct.d.ts +25 -7
- package/dist/{structs → src/structs}/Struct.d.ts +91 -60
- package/dist/{structs → src/structs}/Struct.js +7 -1
- package/dist/{wrappers → src/wrappers}/ContentUtils.js +0 -1
- package/dist/{wrappers → src/wrappers}/HighloadWalletV3.d.ts +2 -2
- package/package.json +1 -1
- package/dist/errors/index.d.ts +0 -2
- package/dist/index.d.ts +0 -19
- package/dist/sdk/Configuration.js +0 -92
- package/dist/sdk/LiteSequencerClient.d.ts +0 -13
- package/dist/sdk/Simulator.d.ts +0 -23
- package/dist/sdk/Simulator.js +0 -169
- package/dist/sdk/TacSdk.d.ts +0 -25
- package/dist/sdk/TacSdk.js +0 -104
- package/dist/sdk/TransactionManager.d.ts +0 -22
- package/dist/sdk/TransactionManager.js +0 -269
- package/dist/sender/SenderAbstraction.d.ts +0 -22
- package/dist/sender/SenderAbstraction.js +0 -5
- package/dist/structs/Services.d.ts +0 -41
- package/dist/wrappers/JettonMaster.d.ts +0 -24
- package/dist/wrappers/JettonMaster.js +0 -53
- package/dist/wrappers/JettonWallet.js +0 -124
- package/dist/wrappers/Settings.d.ts +0 -10
- package/dist/wrappers/Settings.js +0 -38
- /package/dist/{structs/Services.js → artifacts/dev/tac/internal/typechain-types/@openzeppelin/contracts/token/ERC721/IERC721.js} +0 -0
- /package/dist/{assets → src/assets}/AssetCache.js +0 -0
- /package/dist/{assets → src/assets}/index.d.ts +0 -0
- /package/dist/{assets → src/assets}/index.js +0 -0
- /package/dist/{errors → src/errors}/errors.d.ts +0 -0
- /package/dist/{errors → src/errors}/errors.js +0 -0
- /package/dist/{sdk → src/sdk}/Logger.js +0 -0
- /package/dist/{sdk → src/sdk}/StartTracking.js +0 -0
- /package/dist/{sender → src/sender}/BatchSender.js +0 -0
- /package/dist/{sender → src/sender}/RawSender.js +0 -0
- /package/dist/{sender → src/sender}/SenderFactory.js +0 -0
- /package/dist/{structs → src/structs}/InternalStruct.js +0 -0
- /package/dist/{wrappers → src/wrappers}/ContentUtils.d.ts +0 -0
- /package/dist/{wrappers → src/wrappers}/HighloadQueryId.d.ts +0 -0
- /package/dist/{wrappers → src/wrappers}/HighloadQueryId.js +0 -0
- /package/dist/{wrappers → src/wrappers}/HighloadWalletV3.js +0 -0
package/dist/sdk/Simulator.js
DELETED
|
@@ -1,169 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
-
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
-
};
|
|
5
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
-
exports.Simulator = exports.AxiosHttpClient = void 0;
|
|
7
|
-
const ton_1 = require("@ton/ton");
|
|
8
|
-
const axios_1 = __importDefault(require("axios"));
|
|
9
|
-
const errors_1 = require("../errors");
|
|
10
|
-
const Logger_1 = require("./Logger");
|
|
11
|
-
const Utils_1 = require("./Utils");
|
|
12
|
-
const Validator_1 = require("./Validator");
|
|
13
|
-
class AxiosHttpClient {
|
|
14
|
-
async post(url, data, config) {
|
|
15
|
-
return axios_1.default.post(url, data, config);
|
|
16
|
-
}
|
|
17
|
-
}
|
|
18
|
-
exports.AxiosHttpClient = AxiosHttpClient;
|
|
19
|
-
class Simulator {
|
|
20
|
-
constructor(config, logger = new Logger_1.NoopLogger(), httpClient = new AxiosHttpClient()) {
|
|
21
|
-
this.config = config;
|
|
22
|
-
this.logger = logger;
|
|
23
|
-
this.httpClient = httpClient;
|
|
24
|
-
}
|
|
25
|
-
async simulateTACMessage(req) {
|
|
26
|
-
Validator_1.Validator.validateTACSimulationRequest(req);
|
|
27
|
-
this.logger.debug('Simulating TAC message');
|
|
28
|
-
let lastError;
|
|
29
|
-
for (const endpoint of this.config.liteSequencerEndpoints) {
|
|
30
|
-
try {
|
|
31
|
-
const response = await this.httpClient.post(new URL('tac/simulator/simulate-message', endpoint).toString(), req, {
|
|
32
|
-
transformResponse: [Utils_1.toCamelCaseTransformer],
|
|
33
|
-
});
|
|
34
|
-
this.logger.debug('TAC message simulation success');
|
|
35
|
-
return response.data.response;
|
|
36
|
-
}
|
|
37
|
-
catch (error) {
|
|
38
|
-
this.logger.error(`Error while simulating with ${endpoint}: ${error}`);
|
|
39
|
-
lastError = error;
|
|
40
|
-
}
|
|
41
|
-
}
|
|
42
|
-
throw (0, errors_1.simulationError)(lastError);
|
|
43
|
-
}
|
|
44
|
-
async simulateTransactions(sender, txs) {
|
|
45
|
-
this.logger.debug(`Simulating ${txs.length} TAC messages`);
|
|
46
|
-
const results = [];
|
|
47
|
-
for (const tx of txs) {
|
|
48
|
-
const req = await this.buildTACSimulationRequest(sender, tx);
|
|
49
|
-
const result = await this.simulateTACMessage(req);
|
|
50
|
-
results.push(result);
|
|
51
|
-
}
|
|
52
|
-
return results;
|
|
53
|
-
}
|
|
54
|
-
async buildTACSimulationRequest(sender, tx) {
|
|
55
|
-
const { evmProxyMsg, assets = [], options = {} } = tx;
|
|
56
|
-
const { evmValidExecutors = this.config.TACParams.trustedTACExecutors, tvmValidExecutors = this.config.TACParams.trustedTONExecutors, } = options;
|
|
57
|
-
Validator_1.Validator.validateEVMAddresses(evmValidExecutors);
|
|
58
|
-
Validator_1.Validator.validateTVMAddresses(tvmValidExecutors);
|
|
59
|
-
const aggregatedData = await (0, Utils_1.aggregateTokens)(assets);
|
|
60
|
-
const transactionLinkerShardCount = aggregatedData.jettons.length == 0 ? 1 : aggregatedData.jettons.length;
|
|
61
|
-
const transactionLinker = (0, Utils_1.generateTransactionLinker)(sender.getSenderAddress(), transactionLinkerShardCount);
|
|
62
|
-
return {
|
|
63
|
-
tacCallParams: {
|
|
64
|
-
arguments: evmProxyMsg.encodedParameters ?? '0x',
|
|
65
|
-
methodName: (0, Utils_1.formatSolidityMethodName)(evmProxyMsg.methodName),
|
|
66
|
-
target: evmProxyMsg.evmTargetAddress,
|
|
67
|
-
},
|
|
68
|
-
evmValidExecutors: evmValidExecutors,
|
|
69
|
-
tvmValidExecutors: tvmValidExecutors,
|
|
70
|
-
extraData: '0x',
|
|
71
|
-
shardsKey: transactionLinker.shardsKey,
|
|
72
|
-
tonAssets: assets.map((asset) => ({
|
|
73
|
-
amount: asset.rawAmount.toString(),
|
|
74
|
-
tokenAddress: asset.address || '',
|
|
75
|
-
assetType: asset.type,
|
|
76
|
-
})),
|
|
77
|
-
tonCaller: transactionLinker.caller,
|
|
78
|
-
};
|
|
79
|
-
}
|
|
80
|
-
async getTVMExecutorFeeInfo(assets, feeSymbol) {
|
|
81
|
-
this.logger.debug('Getting TVM executor fee info');
|
|
82
|
-
const requestBody = {
|
|
83
|
-
tonAssets: assets.map((asset) => ({
|
|
84
|
-
amount: asset.rawAmount.toString(),
|
|
85
|
-
tokenAddress: asset.address || '',
|
|
86
|
-
assetType: asset.type,
|
|
87
|
-
})),
|
|
88
|
-
feeSymbol: feeSymbol,
|
|
89
|
-
};
|
|
90
|
-
let lastError;
|
|
91
|
-
for (const endpoint of this.config.liteSequencerEndpoints) {
|
|
92
|
-
try {
|
|
93
|
-
const response = await this.httpClient.post(`${endpoint}/ton/calculator/ton-executor-fee`, requestBody);
|
|
94
|
-
return response.data.response;
|
|
95
|
-
}
|
|
96
|
-
catch (error) {
|
|
97
|
-
this.logger.error(`Error while calculating tvm executor fee ${endpoint}: ${error}`);
|
|
98
|
-
lastError = error;
|
|
99
|
-
}
|
|
100
|
-
}
|
|
101
|
-
this.logger.error('Error while calculating tvm executor fee on all endpoints');
|
|
102
|
-
throw (0, errors_1.simulationError)(lastError);
|
|
103
|
-
}
|
|
104
|
-
async getFeeInfo(evmProxyMsg, transactionLinker, assets, allowSimulationError = false, isRoundTrip = true, evmValidExecutors = this.config.TACParams.trustedTACExecutors, tvmValidExecutors = this.config.TACParams.trustedTONExecutors) {
|
|
105
|
-
this.logger.debug('Getting fee info');
|
|
106
|
-
Validator_1.Validator.validateEVMAddress(evmProxyMsg.evmTargetAddress);
|
|
107
|
-
Validator_1.Validator.validateEVMAddresses(evmValidExecutors);
|
|
108
|
-
Validator_1.Validator.validateTVMAddresses(tvmValidExecutors);
|
|
109
|
-
const crossChainLayer = this.config.TONParams.contractOpener.open(this.config.artifacts.ton.wrappers.CrossChainLayer.createFromAddress(ton_1.Address.parse(this.config.TONParams.crossChainLayerAddress)));
|
|
110
|
-
const fullStateCCL = await crossChainLayer.getFullData();
|
|
111
|
-
this.logger.debug(`Full state CCL: ${(0, Utils_1.formatObjectForLogging)(fullStateCCL)}`);
|
|
112
|
-
const tacSimulationBody = {
|
|
113
|
-
tacCallParams: {
|
|
114
|
-
arguments: evmProxyMsg.encodedParameters ?? '0x',
|
|
115
|
-
methodName: (0, Utils_1.formatSolidityMethodName)(evmProxyMsg.methodName),
|
|
116
|
-
target: evmProxyMsg.evmTargetAddress,
|
|
117
|
-
},
|
|
118
|
-
evmValidExecutors: evmValidExecutors,
|
|
119
|
-
tvmValidExecutors: tvmValidExecutors,
|
|
120
|
-
extraData: '0x',
|
|
121
|
-
shardsKey: transactionLinker.shardsKey,
|
|
122
|
-
tonAssets: assets.map((asset) => ({
|
|
123
|
-
amount: asset.rawAmount.toString(),
|
|
124
|
-
tokenAddress: asset.address || '',
|
|
125
|
-
assetType: asset.type,
|
|
126
|
-
})),
|
|
127
|
-
tonCaller: transactionLinker.caller,
|
|
128
|
-
};
|
|
129
|
-
isRoundTrip = isRoundTrip ?? assets.length != 0;
|
|
130
|
-
this.logger.debug(`Is round trip: ${isRoundTrip}`);
|
|
131
|
-
const tacSimulationResult = await this.simulateTACMessage(tacSimulationBody);
|
|
132
|
-
this.logger.debug(`TAC simulation ${tacSimulationResult.simulationStatus ? 'success' : 'failed'}`);
|
|
133
|
-
const protocolFee = BigInt((0, ton_1.toNano)(fullStateCCL.tacProtocolFee)) +
|
|
134
|
-
BigInt(isRoundTrip) * BigInt((0, ton_1.toNano)(fullStateCCL.tonProtocolFee));
|
|
135
|
-
const feeParams = {
|
|
136
|
-
isRoundTrip: isRoundTrip,
|
|
137
|
-
gasLimit: !tacSimulationResult.simulationStatus ? 0n : tacSimulationResult.estimatedGas,
|
|
138
|
-
protocolFee: protocolFee,
|
|
139
|
-
evmExecutorFee: BigInt(tacSimulationResult.suggestedTacExecutionFee),
|
|
140
|
-
tvmExecutorFee: BigInt(tacSimulationResult.suggestedTonExecutionFee) * BigInt(isRoundTrip),
|
|
141
|
-
};
|
|
142
|
-
if (!tacSimulationResult.simulationStatus) {
|
|
143
|
-
if (allowSimulationError) {
|
|
144
|
-
this.logger.info('Force send is true, returning fee params');
|
|
145
|
-
return {
|
|
146
|
-
feeParams,
|
|
147
|
-
simulation: tacSimulationResult,
|
|
148
|
-
};
|
|
149
|
-
}
|
|
150
|
-
throw tacSimulationResult;
|
|
151
|
-
}
|
|
152
|
-
this.logger.debug(`Collected fee params: ${(0, Utils_1.formatObjectForLogging)(feeParams)}`);
|
|
153
|
-
return { feeParams, simulation: tacSimulationResult };
|
|
154
|
-
}
|
|
155
|
-
async getTransactionSimulationInfo(evmProxyMsg, sender, assets) {
|
|
156
|
-
this.logger.debug('Getting transaction simulation info');
|
|
157
|
-
Validator_1.Validator.validateEVMAddress(evmProxyMsg.evmTargetAddress);
|
|
158
|
-
const aggregatedData = await (0, Utils_1.aggregateTokens)(assets);
|
|
159
|
-
const transactionLinkerShardCount = aggregatedData.jettons.length == 0 ? 1 : aggregatedData.jettons.length;
|
|
160
|
-
this.logger.debug(`Transaction linker shard count: ${transactionLinkerShardCount}`);
|
|
161
|
-
const transactionLinker = (0, Utils_1.generateTransactionLinker)(sender.getSenderAddress(), transactionLinkerShardCount);
|
|
162
|
-
this.logger.debug(`Transaction linker: ${(0, Utils_1.formatObjectForLogging)(transactionLinker)}`);
|
|
163
|
-
return await this.getFeeInfo(evmProxyMsg, transactionLinker, assets ?? []);
|
|
164
|
-
}
|
|
165
|
-
async getSimulationInfoForTransaction(evmProxyMsg, transactionLinker, assets, allowSimulationError = false, isRoundTrip, evmValidExecutors, tvmValidExecutors) {
|
|
166
|
-
return await this.getFeeInfo(evmProxyMsg, transactionLinker, assets, allowSimulationError, isRoundTrip, evmValidExecutors, tvmValidExecutors);
|
|
167
|
-
}
|
|
168
|
-
}
|
|
169
|
-
exports.Simulator = Simulator;
|
package/dist/sdk/TacSdk.d.ts
DELETED
|
@@ -1,25 +0,0 @@
|
|
|
1
|
-
import { Wallet } from 'ethers';
|
|
2
|
-
import type { SenderAbstraction } from '../sender';
|
|
3
|
-
import { IConfiguration, ILogger } from '../structs/Services';
|
|
4
|
-
import { Asset, CrossChainTransactionOptions, CrosschainTx, EvmProxyMsg, ExecutionFeeEstimationResult, OperationIdsByShardsKey, SDKParams, SuggestedTONExecutorFee, TACSimulationRequest, TACSimulationResult, TransactionLinkerWithOperationId, WaitOptions } from '../structs/Struct';
|
|
5
|
-
export declare class TacSdk {
|
|
6
|
-
readonly config: IConfiguration;
|
|
7
|
-
private readonly simulator;
|
|
8
|
-
private readonly transactionManager;
|
|
9
|
-
private constructor();
|
|
10
|
-
static create(sdkParams: SDKParams, logger?: ILogger): Promise<TacSdk>;
|
|
11
|
-
closeConnections(): unknown;
|
|
12
|
-
get nativeTONAddress(): string;
|
|
13
|
-
nativeTACAddress(): Promise<string>;
|
|
14
|
-
get getTrustedTACExecutors(): string[];
|
|
15
|
-
get getTrustedTONExecutors(): string[];
|
|
16
|
-
getTransactionSimulationInfo(evmProxyMsg: EvmProxyMsg, sender: SenderAbstraction, assets?: Asset[]): Promise<ExecutionFeeEstimationResult>;
|
|
17
|
-
getTVMExecutorFeeInfo(assets: Asset[], feeSymbol: string): Promise<SuggestedTONExecutorFee>;
|
|
18
|
-
sendCrossChainTransaction(evmProxyMsg: EvmProxyMsg, sender: SenderAbstraction, assets?: Asset[], options?: CrossChainTransactionOptions, waitOptions?: WaitOptions<string>): Promise<TransactionLinkerWithOperationId>;
|
|
19
|
-
getTacSmartAccountAddress(tvmUserAddress: string, evmApplicationAddress: string): Promise<string>;
|
|
20
|
-
sendCrossChainTransactions(sender: SenderAbstraction, txs: CrosschainTx[], waitOptions?: WaitOptions<OperationIdsByShardsKey>): Promise<TransactionLinkerWithOperationId[]>;
|
|
21
|
-
bridgeTokensToTON(signer: Wallet, value: bigint, tonTarget: string, assets?: Asset[], tvmExecutorFee?: bigint): Promise<string>;
|
|
22
|
-
isContractDeployedOnTVM(address: string): Promise<boolean>;
|
|
23
|
-
simulateTACMessage(req: TACSimulationRequest): Promise<TACSimulationResult>;
|
|
24
|
-
simulateTransactions(sender: SenderAbstraction, txs: CrosschainTx[]): Promise<TACSimulationResult[]>;
|
|
25
|
-
}
|
package/dist/sdk/TacSdk.js
DELETED
|
@@ -1,104 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
-
if (k2 === undefined) k2 = k;
|
|
4
|
-
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
-
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
-
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
-
}
|
|
8
|
-
Object.defineProperty(o, k2, desc);
|
|
9
|
-
}) : (function(o, m, k, k2) {
|
|
10
|
-
if (k2 === undefined) k2 = k;
|
|
11
|
-
o[k2] = m[k];
|
|
12
|
-
}));
|
|
13
|
-
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
-
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
-
}) : function(o, v) {
|
|
16
|
-
o["default"] = v;
|
|
17
|
-
});
|
|
18
|
-
var __importStar = (this && this.__importStar) || (function () {
|
|
19
|
-
var ownKeys = function(o) {
|
|
20
|
-
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
21
|
-
var ar = [];
|
|
22
|
-
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
23
|
-
return ar;
|
|
24
|
-
};
|
|
25
|
-
return ownKeys(o);
|
|
26
|
-
};
|
|
27
|
-
return function (mod) {
|
|
28
|
-
if (mod && mod.__esModule) return mod;
|
|
29
|
-
var result = {};
|
|
30
|
-
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
31
|
-
__setModuleDefault(result, mod);
|
|
32
|
-
return result;
|
|
33
|
-
};
|
|
34
|
-
})();
|
|
35
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
36
|
-
exports.TacSdk = void 0;
|
|
37
|
-
const Struct_1 = require("../structs/Struct");
|
|
38
|
-
const Configuration_1 = require("./Configuration");
|
|
39
|
-
const Consts_1 = require("./Consts");
|
|
40
|
-
const Logger_1 = require("./Logger");
|
|
41
|
-
const OperationTracker_1 = require("./OperationTracker");
|
|
42
|
-
const Simulator_1 = require("./Simulator");
|
|
43
|
-
const TransactionManager_1 = require("./TransactionManager");
|
|
44
|
-
class TacSdk {
|
|
45
|
-
constructor(config, simulator, transactionManager) {
|
|
46
|
-
this.config = config;
|
|
47
|
-
this.simulator = simulator;
|
|
48
|
-
this.transactionManager = transactionManager;
|
|
49
|
-
}
|
|
50
|
-
static async create(sdkParams, logger = new Logger_1.NoopLogger()) {
|
|
51
|
-
const network = sdkParams.network;
|
|
52
|
-
const delay = sdkParams.delay ?? Consts_1.DEFAULT_DELAY;
|
|
53
|
-
const { testnet, mainnet } = await Promise.resolve().then(() => __importStar(require('@tonappchain/artifacts')));
|
|
54
|
-
const artifacts = network === Struct_1.Network.TESTNET ? testnet : mainnet;
|
|
55
|
-
const config = await Configuration_1.Configuration.create(network, artifacts, sdkParams.TONParams, sdkParams.TACParams, sdkParams.customLiteSequencerEndpoints, delay);
|
|
56
|
-
const simulator = new Simulator_1.Simulator(config, logger);
|
|
57
|
-
const operationTracker = new OperationTracker_1.OperationTracker(network, config.liteSequencerEndpoints);
|
|
58
|
-
const transactionManager = new TransactionManager_1.TransactionManager(config, simulator, operationTracker, logger);
|
|
59
|
-
return new TacSdk(config, simulator, transactionManager);
|
|
60
|
-
}
|
|
61
|
-
closeConnections() {
|
|
62
|
-
return this.config.closeConnections();
|
|
63
|
-
}
|
|
64
|
-
get nativeTONAddress() {
|
|
65
|
-
return this.config.nativeTONAddress;
|
|
66
|
-
}
|
|
67
|
-
async nativeTACAddress() {
|
|
68
|
-
return this.config.nativeTACAddress();
|
|
69
|
-
}
|
|
70
|
-
get getTrustedTACExecutors() {
|
|
71
|
-
return this.config.getTrustedTACExecutors;
|
|
72
|
-
}
|
|
73
|
-
get getTrustedTONExecutors() {
|
|
74
|
-
return this.config.getTrustedTONExecutors;
|
|
75
|
-
}
|
|
76
|
-
async getTransactionSimulationInfo(evmProxyMsg, sender, assets) {
|
|
77
|
-
return this.simulator.getTransactionSimulationInfo(evmProxyMsg, sender, assets);
|
|
78
|
-
}
|
|
79
|
-
async getTVMExecutorFeeInfo(assets, feeSymbol) {
|
|
80
|
-
return this.simulator.getTVMExecutorFeeInfo(assets, feeSymbol);
|
|
81
|
-
}
|
|
82
|
-
async sendCrossChainTransaction(evmProxyMsg, sender, assets, options, waitOptions) {
|
|
83
|
-
return this.transactionManager.sendCrossChainTransaction(evmProxyMsg, sender, assets, options, waitOptions);
|
|
84
|
-
}
|
|
85
|
-
async getTacSmartAccountAddress(tvmUserAddress, evmApplicationAddress) {
|
|
86
|
-
return await this.config.TACParams.smartAccountFactory.getSmartAccountForApplication(tvmUserAddress, evmApplicationAddress);
|
|
87
|
-
}
|
|
88
|
-
async sendCrossChainTransactions(sender, txs, waitOptions) {
|
|
89
|
-
return this.transactionManager.sendCrossChainTransactions(sender, txs, waitOptions);
|
|
90
|
-
}
|
|
91
|
-
async bridgeTokensToTON(signer, value, tonTarget, assets, tvmExecutorFee) {
|
|
92
|
-
return this.transactionManager.bridgeTokensToTON(signer, value, tonTarget, assets, tvmExecutorFee);
|
|
93
|
-
}
|
|
94
|
-
async isContractDeployedOnTVM(address) {
|
|
95
|
-
return this.config.isContractDeployedOnTVM(address);
|
|
96
|
-
}
|
|
97
|
-
async simulateTACMessage(req) {
|
|
98
|
-
return this.simulator.simulateTACMessage(req);
|
|
99
|
-
}
|
|
100
|
-
async simulateTransactions(sender, txs) {
|
|
101
|
-
return this.simulator.simulateTransactions(sender, txs);
|
|
102
|
-
}
|
|
103
|
-
}
|
|
104
|
-
exports.TacSdk = TacSdk;
|
|
@@ -1,22 +0,0 @@
|
|
|
1
|
-
import { Cell } from '@ton/ton';
|
|
2
|
-
import { Wallet } from 'ethers';
|
|
3
|
-
import type { SenderAbstraction } from '../sender';
|
|
4
|
-
import { IConfiguration, ILogger, IOperationTracker, ISimulator } from '../structs/Services';
|
|
5
|
-
import { Asset, CrossChainTransactionOptions, CrosschainTx, EvmProxyMsg, OperationIdsByShardsKey, TransactionLinker, TransactionLinkerWithOperationId, ValidExecutors, WaitOptions } from '../structs/Struct';
|
|
6
|
-
export declare class TransactionManager {
|
|
7
|
-
private readonly config;
|
|
8
|
-
private readonly simulator;
|
|
9
|
-
private readonly operationTracker;
|
|
10
|
-
private readonly logger;
|
|
11
|
-
private readonly evmDataCellBuilder;
|
|
12
|
-
constructor(config: IConfiguration, simulator: ISimulator, operationTracker: IOperationTracker, logger?: ILogger, options?: {
|
|
13
|
-
evmDataCellBuilder?: (transactionLinker: TransactionLinker, evmProxyMsg: EvmProxyMsg, validExecutors: ValidExecutors) => Cell;
|
|
14
|
-
});
|
|
15
|
-
private prepareCrossChainTransaction;
|
|
16
|
-
private generateCrossChainMessages;
|
|
17
|
-
sendCrossChainTransaction(evmProxyMsg: EvmProxyMsg, sender: SenderAbstraction, assets?: Asset[], options?: CrossChainTransactionOptions, waitOptions?: WaitOptions<string>): Promise<TransactionLinkerWithOperationId>;
|
|
18
|
-
sendCrossChainTransactions(sender: SenderAbstraction, txs: CrosschainTx[], waitOptions?: WaitOptions<OperationIdsByShardsKey>): Promise<TransactionLinkerWithOperationId[]>;
|
|
19
|
-
private prepareCrossChainTransactions;
|
|
20
|
-
private waitForOperationIds;
|
|
21
|
-
bridgeTokensToTON(signer: Wallet, value: bigint, tonTarget: string, assets?: Asset[], tvmExecutorFee?: bigint): Promise<string>;
|
|
22
|
-
}
|
|
@@ -1,269 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.TransactionManager = void 0;
|
|
4
|
-
const assets_1 = require("../assets");
|
|
5
|
-
const Struct_1 = require("../structs/Struct");
|
|
6
|
-
const Consts_1 = require("./Consts");
|
|
7
|
-
const Logger_1 = require("./Logger");
|
|
8
|
-
const Utils_1 = require("./Utils");
|
|
9
|
-
const Validator_1 = require("./Validator");
|
|
10
|
-
class TransactionManager {
|
|
11
|
-
constructor(config, simulator, operationTracker, logger = new Logger_1.NoopLogger(), options) {
|
|
12
|
-
this.config = config;
|
|
13
|
-
this.simulator = simulator;
|
|
14
|
-
this.operationTracker = operationTracker;
|
|
15
|
-
this.logger = logger;
|
|
16
|
-
this.evmDataCellBuilder = options?.evmDataCellBuilder ?? Utils_1.buildEvmDataCell;
|
|
17
|
-
}
|
|
18
|
-
async prepareCrossChainTransaction(evmProxyMsg, caller, assets, options) {
|
|
19
|
-
this.logger.debug('Preparing cross-chain transaction');
|
|
20
|
-
const { allowSimulationError = false, isRoundTrip = undefined, protocolFee = undefined, evmExecutorFee = undefined, tvmExecutorFee = undefined, } = options || {};
|
|
21
|
-
let { evmValidExecutors = [], tvmValidExecutors = [] } = options || {};
|
|
22
|
-
Validator_1.Validator.validateEVMAddress(evmProxyMsg.evmTargetAddress);
|
|
23
|
-
Validator_1.Validator.validateEVMAddresses(options?.evmValidExecutors);
|
|
24
|
-
Validator_1.Validator.validateTVMAddresses(options?.tvmValidExecutors);
|
|
25
|
-
const aggregatedData = await (0, Utils_1.aggregateTokens)(assets);
|
|
26
|
-
await Promise.all(aggregatedData.jettons.map((jetton) => jetton.checkCanBeTransferedBy(caller)));
|
|
27
|
-
await Promise.all(aggregatedData.nfts.map((nft) => nft.checkCanBeTransferedBy(caller)));
|
|
28
|
-
await aggregatedData.ton?.checkCanBeTransferedBy(caller);
|
|
29
|
-
const tokensLength = aggregatedData.jettons.length + aggregatedData.nfts.length;
|
|
30
|
-
this.logger.debug(`Tokens length: ${tokensLength}`);
|
|
31
|
-
const transactionLinkerShardCount = tokensLength == 0 ? 1 : tokensLength;
|
|
32
|
-
this.logger.debug(`Transaction linker shard count: ${transactionLinkerShardCount}`);
|
|
33
|
-
const transactionLinker = (0, Utils_1.generateTransactionLinker)(caller, transactionLinkerShardCount);
|
|
34
|
-
this.logger.debug(`Generated transaction linker: ${(0, Utils_1.formatObjectForLogging)(transactionLinker)}`);
|
|
35
|
-
if (evmValidExecutors.length == 0) {
|
|
36
|
-
evmValidExecutors = this.config.getTrustedTACExecutors;
|
|
37
|
-
}
|
|
38
|
-
if (tvmValidExecutors.length == 0) {
|
|
39
|
-
tvmValidExecutors = this.config.getTrustedTONExecutors;
|
|
40
|
-
}
|
|
41
|
-
const { feeParams } = await this.simulator.getSimulationInfoForTransaction(evmProxyMsg, transactionLinker, assets ?? [], allowSimulationError, isRoundTrip, evmValidExecutors, tvmValidExecutors);
|
|
42
|
-
if (evmProxyMsg.gasLimit == undefined) {
|
|
43
|
-
evmProxyMsg.gasLimit = feeParams.gasLimit;
|
|
44
|
-
}
|
|
45
|
-
if (evmExecutorFee != undefined) {
|
|
46
|
-
feeParams.evmExecutorFee = evmExecutorFee;
|
|
47
|
-
}
|
|
48
|
-
if (feeParams.isRoundTrip && tvmExecutorFee != undefined) {
|
|
49
|
-
feeParams.tvmExecutorFee = tvmExecutorFee;
|
|
50
|
-
}
|
|
51
|
-
if (protocolFee != undefined) {
|
|
52
|
-
feeParams.protocolFee = protocolFee;
|
|
53
|
-
}
|
|
54
|
-
this.logger.debug(`Resulting fee params: ${(0, Utils_1.formatObjectForLogging)(feeParams)}`);
|
|
55
|
-
const validExecutors = {
|
|
56
|
-
tac: evmValidExecutors,
|
|
57
|
-
ton: tvmValidExecutors,
|
|
58
|
-
};
|
|
59
|
-
this.logger.debug(`Valid executors: ${(0, Utils_1.formatObjectForLogging)(validExecutors)}`);
|
|
60
|
-
const evmData = this.evmDataCellBuilder(transactionLinker, evmProxyMsg, validExecutors);
|
|
61
|
-
const messages = await this.generateCrossChainMessages(caller, evmData, aggregatedData, feeParams);
|
|
62
|
-
const transaction = {
|
|
63
|
-
validUntil: +new Date() + 15 * 60 * 1000,
|
|
64
|
-
messages,
|
|
65
|
-
network: this.config.network,
|
|
66
|
-
};
|
|
67
|
-
this.logger.debug('Transaction prepared');
|
|
68
|
-
return { transaction, transactionLinker };
|
|
69
|
-
}
|
|
70
|
-
async generateCrossChainMessages(caller, evmData, aggregatedData, feeParams) {
|
|
71
|
-
this.logger.debug(`Generating cross-chain messages`);
|
|
72
|
-
const { jettons, nfts, ton = assets_1.TON.create(this.config) } = aggregatedData;
|
|
73
|
-
let crossChainTonAmount = ton.rawAmount;
|
|
74
|
-
let feeTonAmount = feeParams.protocolFee + feeParams.evmExecutorFee + feeParams.tvmExecutorFee;
|
|
75
|
-
this.logger.debug(`Crosschain ton amount: ${crossChainTonAmount}`);
|
|
76
|
-
this.logger.debug(`Fee ton amount: ${feeTonAmount}`);
|
|
77
|
-
if (jettons.length == 0 && nfts.length == 0) {
|
|
78
|
-
return [
|
|
79
|
-
{
|
|
80
|
-
address: this.config.TONParams.crossChainLayerAddress,
|
|
81
|
-
value: crossChainTonAmount + feeTonAmount + Consts_1.TRANSACTION_TON_AMOUNT,
|
|
82
|
-
payload: await ton.generatePayload({
|
|
83
|
-
excessReceiver: caller,
|
|
84
|
-
evmData,
|
|
85
|
-
feeParams,
|
|
86
|
-
}),
|
|
87
|
-
},
|
|
88
|
-
];
|
|
89
|
-
}
|
|
90
|
-
const messages = [];
|
|
91
|
-
let currentFeeParams = feeParams;
|
|
92
|
-
for (const jetton of aggregatedData.jettons) {
|
|
93
|
-
const payload = await jetton.generatePayload({
|
|
94
|
-
excessReceiver: caller,
|
|
95
|
-
evmData,
|
|
96
|
-
crossChainTonAmount,
|
|
97
|
-
forwardFeeTonAmount: feeTonAmount,
|
|
98
|
-
feeParams: currentFeeParams,
|
|
99
|
-
});
|
|
100
|
-
const jettonWalletAddress = await jetton.getUserWalletAddress(caller);
|
|
101
|
-
messages.push({
|
|
102
|
-
address: jettonWalletAddress,
|
|
103
|
-
value: crossChainTonAmount + feeTonAmount + Consts_1.TRANSACTION_TON_AMOUNT,
|
|
104
|
-
payload,
|
|
105
|
-
});
|
|
106
|
-
crossChainTonAmount = 0n;
|
|
107
|
-
feeTonAmount = 0n;
|
|
108
|
-
currentFeeParams = undefined;
|
|
109
|
-
}
|
|
110
|
-
for (const nft of aggregatedData.nfts) {
|
|
111
|
-
const payload = await nft.generatePayload({
|
|
112
|
-
excessReceiver: caller,
|
|
113
|
-
evmData,
|
|
114
|
-
crossChainTonAmount,
|
|
115
|
-
forwardFeeTonAmount: feeTonAmount,
|
|
116
|
-
feeParams: currentFeeParams,
|
|
117
|
-
});
|
|
118
|
-
messages.push({
|
|
119
|
-
address: nft.address,
|
|
120
|
-
value: crossChainTonAmount + feeTonAmount + Consts_1.TRANSACTION_TON_AMOUNT,
|
|
121
|
-
payload,
|
|
122
|
-
});
|
|
123
|
-
crossChainTonAmount = 0n;
|
|
124
|
-
feeTonAmount = 0n;
|
|
125
|
-
currentFeeParams = undefined;
|
|
126
|
-
}
|
|
127
|
-
this.logger.debug('Generating cross-chain messages success');
|
|
128
|
-
return messages;
|
|
129
|
-
}
|
|
130
|
-
async sendCrossChainTransaction(evmProxyMsg, sender, assets, options, waitOptions) {
|
|
131
|
-
const caller = sender.getSenderAddress();
|
|
132
|
-
this.logger.debug(`Caller: ${caller}`);
|
|
133
|
-
const { transaction, transactionLinker } = await this.prepareCrossChainTransaction(evmProxyMsg, caller, assets, options);
|
|
134
|
-
await assets_1.TON.checkBalance(sender, this.config, [transaction]);
|
|
135
|
-
this.logger.debug(`*****Sending transaction: ${(0, Utils_1.formatObjectForLogging)(transaction)}`);
|
|
136
|
-
const sendTransactionResult = await sender.sendShardTransaction(transaction, this.config.network, this.config.TONParams.contractOpener);
|
|
137
|
-
return waitOptions
|
|
138
|
-
? {
|
|
139
|
-
sendTransactionResult,
|
|
140
|
-
operationId: await this.operationTracker
|
|
141
|
-
.getOperationId(transactionLinker, {
|
|
142
|
-
...waitOptions,
|
|
143
|
-
successCheck: (operationId) => !!operationId,
|
|
144
|
-
logger: this.logger,
|
|
145
|
-
})
|
|
146
|
-
.catch((error) => {
|
|
147
|
-
this.logger.error(`Error while waiting for operation ID: ${error}`);
|
|
148
|
-
return undefined;
|
|
149
|
-
}),
|
|
150
|
-
...transactionLinker,
|
|
151
|
-
}
|
|
152
|
-
: { sendTransactionResult, ...transactionLinker };
|
|
153
|
-
}
|
|
154
|
-
async sendCrossChainTransactions(sender, txs, waitOptions) {
|
|
155
|
-
const caller = sender.getSenderAddress();
|
|
156
|
-
this.logger.debug(`Caller: ${caller}`);
|
|
157
|
-
this.logger.debug('Preparing multiple cross-chain transactions');
|
|
158
|
-
const { transactions, transactionLinkers } = await this.prepareCrossChainTransactions(txs, caller);
|
|
159
|
-
await assets_1.TON.checkBalance(sender, this.config, transactions);
|
|
160
|
-
this.logger.debug(`*****Sending transactions: ${(0, Utils_1.formatObjectForLogging)(transactions)}`);
|
|
161
|
-
await sender.sendShardTransactions(transactions, this.config.network, this.config.TONParams.contractOpener);
|
|
162
|
-
if (!waitOptions) {
|
|
163
|
-
return transactionLinkers;
|
|
164
|
-
}
|
|
165
|
-
return await this.waitForOperationIds(transactionLinkers, caller, waitOptions);
|
|
166
|
-
}
|
|
167
|
-
async prepareCrossChainTransactions(txs, caller) {
|
|
168
|
-
const transactions = [];
|
|
169
|
-
const transactionLinkers = [];
|
|
170
|
-
for (const { options, assets, evmProxyMsg } of txs) {
|
|
171
|
-
const { transaction, transactionLinker } = await this.prepareCrossChainTransaction(evmProxyMsg, caller, assets, options);
|
|
172
|
-
transactions.push(transaction);
|
|
173
|
-
transactionLinkers.push(transactionLinker);
|
|
174
|
-
}
|
|
175
|
-
return { transactions, transactionLinkers };
|
|
176
|
-
}
|
|
177
|
-
async waitForOperationIds(transactionLinkers, caller, waitOptions) {
|
|
178
|
-
this.logger.debug(`Waiting for operation IDs`);
|
|
179
|
-
try {
|
|
180
|
-
const operationIds = await this.operationTracker.getOperationIdsByShardsKeys(transactionLinkers.map((linker) => linker.shardsKey), caller, {
|
|
181
|
-
...waitOptions,
|
|
182
|
-
logger: this.logger,
|
|
183
|
-
successCheck: (operationIds) => Object.keys(operationIds).length == transactionLinkers.length &&
|
|
184
|
-
Object.values(operationIds).every((ids) => ids.operationIds.length > 0),
|
|
185
|
-
});
|
|
186
|
-
this.logger.debug(`Operation IDs: ${(0, Utils_1.formatObjectForLogging)(operationIds)}`);
|
|
187
|
-
return transactionLinkers.map((linker) => ({
|
|
188
|
-
...linker,
|
|
189
|
-
operationId: operationIds[linker.shardsKey].operationIds.at(0),
|
|
190
|
-
}));
|
|
191
|
-
}
|
|
192
|
-
catch (error) {
|
|
193
|
-
this.logger.error(`Error while waiting for operation IDs: ${error}`);
|
|
194
|
-
return transactionLinkers;
|
|
195
|
-
}
|
|
196
|
-
}
|
|
197
|
-
async bridgeTokensToTON(signer, value, tonTarget, assets, tvmExecutorFee) {
|
|
198
|
-
this.logger.debug('Bridging tokens to TON');
|
|
199
|
-
if (assets == undefined) {
|
|
200
|
-
assets = [];
|
|
201
|
-
}
|
|
202
|
-
const tonAssets = [...assets];
|
|
203
|
-
if (value > 0n) {
|
|
204
|
-
tonAssets.push(await (await assets_1.AssetFactory.from(this.config, {
|
|
205
|
-
address: await this.config.nativeTACAddress(),
|
|
206
|
-
tokenType: Struct_1.AssetType.FT,
|
|
207
|
-
})).withAmount({ rawAmount: value }));
|
|
208
|
-
}
|
|
209
|
-
Validator_1.Validator.validateTVMAddress(tonTarget);
|
|
210
|
-
const suggestedTONExecutorFee = await this.simulator.getTVMExecutorFeeInfo(tonAssets, Consts_1.TAC_SYMBOL);
|
|
211
|
-
this.logger.debug(`Suggested TON executor fee: ${(0, Utils_1.formatObjectForLogging)(suggestedTONExecutorFee)}`);
|
|
212
|
-
const crossChainLayerAddress = await this.config.TACParams.crossChainLayer.getAddress();
|
|
213
|
-
for (const asset of assets) {
|
|
214
|
-
const evmAddress = await asset.getEVMAddress();
|
|
215
|
-
if (asset.type == Struct_1.AssetType.FT) {
|
|
216
|
-
this.logger.debug(`Approving token ${evmAddress} for ${crossChainLayerAddress}`);
|
|
217
|
-
const tokenContract = this.config.artifacts.tac.wrappers.ERC20FactoryTAC.connect(evmAddress, this.config.TACParams.provider);
|
|
218
|
-
const tx = await tokenContract.connect(signer).approve(crossChainLayerAddress, asset.rawAmount);
|
|
219
|
-
await tx.wait();
|
|
220
|
-
this.logger.debug(`Approved ${evmAddress} for ${crossChainLayerAddress}`);
|
|
221
|
-
}
|
|
222
|
-
if (asset.type == Struct_1.AssetType.NFT) {
|
|
223
|
-
this.logger.debug(`Approving collection ${evmAddress} for ${crossChainLayerAddress}`);
|
|
224
|
-
const tokenContract = this.config.artifacts.tac.wrappers.ERC721FactoryTAC.connect(evmAddress, this.config.TACParams.provider);
|
|
225
|
-
const tx = await tokenContract
|
|
226
|
-
.connect(signer)
|
|
227
|
-
.approve(crossChainLayerAddress, asset.addresses.index);
|
|
228
|
-
await tx.wait();
|
|
229
|
-
this.logger.debug(`Approved ${asset.address} for ${crossChainLayerAddress}`);
|
|
230
|
-
}
|
|
231
|
-
}
|
|
232
|
-
const shardsKey = BigInt(Math.round(Math.random() * 1e18));
|
|
233
|
-
this.logger.debug(`Shards key: ${shardsKey}`);
|
|
234
|
-
const protocolFee = await this.config.TACParams.crossChainLayer.getProtocolFee();
|
|
235
|
-
this.logger.debug(`Protocol fee: ${protocolFee}`);
|
|
236
|
-
const outMessage = {
|
|
237
|
-
shardsKey: shardsKey,
|
|
238
|
-
tvmTarget: tonTarget,
|
|
239
|
-
tvmPayload: '',
|
|
240
|
-
tvmProtocolFee: protocolFee,
|
|
241
|
-
tvmExecutorFee: tvmExecutorFee ?? BigInt(suggestedTONExecutorFee.inTAC),
|
|
242
|
-
tvmValidExecutors: this.config.getTrustedTONExecutors,
|
|
243
|
-
toBridge: await Promise.all(assets
|
|
244
|
-
.filter((asset) => asset.type === Struct_1.AssetType.FT)
|
|
245
|
-
.map(async (asset) => ({
|
|
246
|
-
evmAddress: await asset.getEVMAddress(),
|
|
247
|
-
amount: asset.rawAmount,
|
|
248
|
-
}))),
|
|
249
|
-
toBridgeNFT: await Promise.all(assets
|
|
250
|
-
.filter((asset) => asset.type === Struct_1.AssetType.NFT)
|
|
251
|
-
.map(async (asset) => ({
|
|
252
|
-
evmAddress: await asset.getEVMAddress(),
|
|
253
|
-
amount: 1n,
|
|
254
|
-
tokenId: asset.addresses.index,
|
|
255
|
-
}))),
|
|
256
|
-
};
|
|
257
|
-
const encodedOutMessage = this.config.artifacts.tac.utils.encodeOutMessageV1(outMessage);
|
|
258
|
-
const outMsgVersion = 1n;
|
|
259
|
-
const totalValue = value + BigInt(outMessage.tvmProtocolFee) + BigInt(outMessage.tvmExecutorFee);
|
|
260
|
-
this.logger.debug(`Total value: ${totalValue}`);
|
|
261
|
-
const tx = await this.config.TACParams.crossChainLayer
|
|
262
|
-
.connect(signer)
|
|
263
|
-
.sendMessage(outMsgVersion, encodedOutMessage, { value: totalValue });
|
|
264
|
-
await tx.wait();
|
|
265
|
-
this.logger.debug(`Transaction hash: ${tx.hash}`);
|
|
266
|
-
return tx.hash;
|
|
267
|
-
}
|
|
268
|
-
}
|
|
269
|
-
exports.TransactionManager = TransactionManager;
|
|
@@ -1,22 +0,0 @@
|
|
|
1
|
-
import type { Contract, ContractProvider, MessageRelaxed, SendMode } from '@ton/ton';
|
|
2
|
-
import type { SendResult, ShardTransaction } from '../structs/InternalStruct';
|
|
3
|
-
import type { Asset, ContractOpener } from '../structs/Struct';
|
|
4
|
-
import { Network } from '../structs/Struct';
|
|
5
|
-
export declare const sleep: (ms: number) => Promise<unknown>;
|
|
6
|
-
export interface WalletInstance extends Contract {
|
|
7
|
-
getSeqno(provider: ContractProvider): Promise<number>;
|
|
8
|
-
sendTransfer(provider: ContractProvider, args: {
|
|
9
|
-
seqno: number;
|
|
10
|
-
secretKey: Buffer;
|
|
11
|
-
messages: MessageRelaxed[];
|
|
12
|
-
sendMode: SendMode;
|
|
13
|
-
timeout?: number;
|
|
14
|
-
}): Promise<void>;
|
|
15
|
-
}
|
|
16
|
-
export interface SenderAbstraction {
|
|
17
|
-
sendShardTransaction(shardTransaction: ShardTransaction, chain?: Network, contractOpener?: ContractOpener): Promise<SendResult>;
|
|
18
|
-
sendShardTransactions(shardTransactions: ShardTransaction[], chain?: Network, contractOpener?: ContractOpener): Promise<SendResult[]>;
|
|
19
|
-
getSenderAddress(): string;
|
|
20
|
-
getBalance(contractOpener: ContractOpener): Promise<bigint>;
|
|
21
|
-
getBalanceOf(asset: Asset): Promise<bigint>;
|
|
22
|
-
}
|
|
@@ -1,41 +0,0 @@
|
|
|
1
|
-
import { mainnet, testnet } from '@tonappchain/artifacts';
|
|
2
|
-
import type { SenderAbstraction } from '../sender';
|
|
3
|
-
import { InternalTACParams, InternalTONParams } from './InternalStruct';
|
|
4
|
-
import { Asset, CrosschainTx, EvmProxyMsg, ExecutionFeeEstimationResult, ExecutionStages, ExecutionStagesByOperationId, Network, OperationIdsByShardsKey, OperationType, SimplifiedStatuses, StatusInfo, StatusInfosByOperationId, SuggestedTONExecutorFee, TACSimulationRequest, TACSimulationResult, TransactionLinker, WaitOptions } from './Struct';
|
|
5
|
-
export interface IConfiguration {
|
|
6
|
-
readonly network: Network;
|
|
7
|
-
readonly artifacts: typeof testnet | typeof mainnet;
|
|
8
|
-
readonly TONParams: InternalTONParams;
|
|
9
|
-
readonly TACParams: InternalTACParams;
|
|
10
|
-
readonly liteSequencerEndpoints: string[];
|
|
11
|
-
readonly nativeTONAddress: string;
|
|
12
|
-
nativeTACAddress(): Promise<string>;
|
|
13
|
-
readonly getTrustedTACExecutors: string[];
|
|
14
|
-
readonly getTrustedTONExecutors: string[];
|
|
15
|
-
closeConnections(): unknown;
|
|
16
|
-
isContractDeployedOnTVM(address: string): Promise<boolean>;
|
|
17
|
-
}
|
|
18
|
-
export interface ILogger {
|
|
19
|
-
debug(...arg: unknown[]): void;
|
|
20
|
-
info(...arg: unknown[]): void;
|
|
21
|
-
warn(...arg: unknown[]): void;
|
|
22
|
-
error(...arg: unknown[]): void;
|
|
23
|
-
}
|
|
24
|
-
export interface ISimulator {
|
|
25
|
-
simulateTACMessage(req: TACSimulationRequest): Promise<TACSimulationResult>;
|
|
26
|
-
simulateTransactions(sender: SenderAbstraction, txs: CrosschainTx[]): Promise<TACSimulationResult[]>;
|
|
27
|
-
getTVMExecutorFeeInfo(assets: Asset[], feeSymbol: string): Promise<SuggestedTONExecutorFee>;
|
|
28
|
-
getTransactionSimulationInfo(evmProxyMsg: EvmProxyMsg, sender: SenderAbstraction, assets?: Asset[]): Promise<ExecutionFeeEstimationResult>;
|
|
29
|
-
getSimulationInfoForTransaction(evmProxyMsg: EvmProxyMsg, transactionLinker: TransactionLinker, assets: Asset[], allowSimulationError?: boolean, isRoundTrip?: boolean, evmValidExecutors?: string[], tvmValidExecutors?: string[]): Promise<ExecutionFeeEstimationResult>;
|
|
30
|
-
}
|
|
31
|
-
export interface IOperationTracker {
|
|
32
|
-
getOperationType(operationId: string, waitOptions?: WaitOptions<OperationType>): Promise<OperationType>;
|
|
33
|
-
getOperationId(transactionLinker: TransactionLinker, waitOptions?: WaitOptions<string>): Promise<string>;
|
|
34
|
-
getOperationIdByTransactionHash(transactionHash: string, waitOptions?: WaitOptions<string>): Promise<string>;
|
|
35
|
-
getOperationIdsByShardsKeys(shardsKeys: string[], caller: string, waitOptions?: WaitOptions<OperationIdsByShardsKey>, chunkSize?: number): Promise<OperationIdsByShardsKey>;
|
|
36
|
-
getStageProfiling(operationId: string, waitOptions?: WaitOptions<ExecutionStages>): Promise<ExecutionStages>;
|
|
37
|
-
getStageProfilings(operationIds: string[], waitOptions?: WaitOptions<ExecutionStagesByOperationId>, chunkSize?: number): Promise<ExecutionStagesByOperationId>;
|
|
38
|
-
getOperationStatuses(operationIds: string[], waitOptions?: WaitOptions<StatusInfosByOperationId>, chunkSize?: number): Promise<StatusInfosByOperationId>;
|
|
39
|
-
getOperationStatus(operationId: string, waitOptions?: WaitOptions<StatusInfo>): Promise<StatusInfo>;
|
|
40
|
-
getSimplifiedOperationStatus(transactionLinker: TransactionLinker): Promise<SimplifiedStatuses>;
|
|
41
|
-
}
|