@folks-finance/xchain-sdk 0.0.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +1 -0
- package/dist/chains/evm/common/constants/abi/ccip-data-adapter-abi.d.ts +796 -0
- package/dist/chains/evm/common/constants/abi/ccip-data-adapter-abi.js +614 -0
- package/dist/chains/evm/common/constants/abi/ccip-data-adapter-abi.js.map +1 -0
- package/dist/chains/evm/common/constants/abi/erc-20-abi.d.ts +235 -0
- package/dist/chains/evm/common/constants/abi/erc-20-abi.js +157 -0
- package/dist/chains/evm/common/constants/abi/erc-20-abi.js.map +1 -0
- package/dist/chains/evm/common/constants/abi/wormhole-data-adapter-abi.d.ts +807 -0
- package/dist/chains/evm/common/constants/abi/wormhole-data-adapter-abi.js +621 -0
- package/dist/chains/evm/common/constants/abi/wormhole-data-adapter-abi.js.map +1 -0
- package/dist/chains/evm/common/constants/chain.d.ts +2349 -0
- package/dist/chains/evm/common/constants/chain.js +45 -0
- package/dist/chains/evm/common/constants/chain.js.map +1 -0
- package/dist/chains/evm/common/constants/contract.d.ts +2 -0
- package/dist/chains/evm/common/constants/contract.js +6 -0
- package/dist/chains/evm/common/constants/contract.js.map +1 -0
- package/dist/chains/evm/common/constants/tokens.d.ts +6 -0
- package/dist/chains/evm/common/constants/tokens.js +33 -0
- package/dist/chains/evm/common/constants/tokens.js.map +1 -0
- package/dist/chains/evm/common/types/chain.d.ts +10 -0
- package/dist/chains/evm/common/types/chain.js +2 -0
- package/dist/chains/evm/common/types/chain.js.map +1 -0
- package/dist/chains/evm/common/types/contract.d.ts +8 -0
- package/dist/chains/evm/common/types/contract.js +2 -0
- package/dist/chains/evm/common/types/contract.js.map +1 -0
- package/dist/chains/evm/common/types/gmp.d.ts +14 -0
- package/dist/chains/evm/common/types/gmp.js +2 -0
- package/dist/chains/evm/common/types/gmp.js.map +1 -0
- package/dist/chains/evm/common/types/index.d.ts +3 -0
- package/dist/chains/evm/common/types/index.js +4 -0
- package/dist/chains/evm/common/types/index.js.map +1 -0
- package/dist/chains/evm/common/types/module.d.ts +66 -0
- package/dist/chains/evm/common/types/module.js +2 -0
- package/dist/chains/evm/common/types/module.js.map +1 -0
- package/dist/chains/evm/common/types/tokens.d.ts +28 -0
- package/dist/chains/evm/common/types/tokens.js +2 -0
- package/dist/chains/evm/common/types/tokens.js.map +1 -0
- package/dist/chains/evm/common/utils/chain.d.ts +6 -0
- package/dist/chains/evm/common/utils/chain.js +16 -0
- package/dist/chains/evm/common/utils/chain.js.map +1 -0
- package/dist/chains/evm/common/utils/contract.d.ts +6006 -0
- package/dist/chains/evm/common/utils/contract.js +54 -0
- package/dist/chains/evm/common/utils/contract.js.map +1 -0
- package/dist/chains/evm/common/utils/gmp.d.ts +4 -0
- package/dist/chains/evm/common/utils/gmp.js +13 -0
- package/dist/chains/evm/common/utils/gmp.js.map +1 -0
- package/dist/chains/evm/common/utils/message.d.ts +22 -0
- package/dist/chains/evm/common/utils/message.js +398 -0
- package/dist/chains/evm/common/utils/message.js.map +1 -0
- package/dist/chains/evm/common/utils/provider.d.ts +5 -0
- package/dist/chains/evm/common/utils/provider.js +24 -0
- package/dist/chains/evm/common/utils/provider.js.map +1 -0
- package/dist/chains/evm/common/utils/tokens.d.ts +10 -0
- package/dist/chains/evm/common/utils/tokens.js +37 -0
- package/dist/chains/evm/common/utils/tokens.js.map +1 -0
- package/dist/chains/evm/hub/constants/abi/account-manager-abi.d.ts +907 -0
- package/dist/chains/evm/hub/constants/abi/account-manager-abi.js +686 -0
- package/dist/chains/evm/hub/constants/abi/account-manager-abi.js.map +1 -0
- package/dist/chains/evm/hub/constants/abi/bridge-router-hub-abi.d.ts +969 -0
- package/dist/chains/evm/hub/constants/abi/bridge-router-hub-abi.js +764 -0
- package/dist/chains/evm/hub/constants/abi/bridge-router-hub-abi.js.map +1 -0
- package/dist/chains/evm/hub/constants/abi/hub-abi.d.ts +285 -0
- package/dist/chains/evm/hub/constants/abi/hub-abi.js +187 -0
- package/dist/chains/evm/hub/constants/abi/hub-abi.js.map +1 -0
- package/dist/chains/evm/hub/constants/abi/hub-pool-abi.d.ts +1742 -0
- package/dist/chains/evm/hub/constants/abi/hub-pool-abi.js +1346 -0
- package/dist/chains/evm/hub/constants/abi/hub-pool-abi.js.map +1 -0
- package/dist/chains/evm/hub/constants/abi/loan-manager-abi.d.ts +1559 -0
- package/dist/chains/evm/hub/constants/abi/loan-manager-abi.js +1040 -0
- package/dist/chains/evm/hub/constants/abi/loan-manager-abi.js.map +1 -0
- package/dist/chains/evm/hub/constants/abi/oracle-manager-abi.d.ts +495 -0
- package/dist/chains/evm/hub/constants/abi/oracle-manager-abi.js +389 -0
- package/dist/chains/evm/hub/constants/abi/oracle-manager-abi.js.map +1 -0
- package/dist/chains/evm/hub/constants/chain.d.ts +3 -0
- package/dist/chains/evm/hub/constants/chain.js +96 -0
- package/dist/chains/evm/hub/constants/chain.js.map +1 -0
- package/dist/chains/evm/hub/modules/folks-hub-account.d.ts +15 -0
- package/dist/chains/evm/hub/modules/folks-hub-account.js +98 -0
- package/dist/chains/evm/hub/modules/folks-hub-account.js.map +1 -0
- package/dist/chains/evm/hub/modules/folks-hub-gmp.d.ts +14 -0
- package/dist/chains/evm/hub/modules/folks-hub-gmp.js +57 -0
- package/dist/chains/evm/hub/modules/folks-hub-gmp.js.map +1 -0
- package/dist/chains/evm/hub/modules/folks-hub-loan.d.ts +25 -0
- package/dist/chains/evm/hub/modules/folks-hub-loan.js +397 -0
- package/dist/chains/evm/hub/modules/folks-hub-loan.js.map +1 -0
- package/dist/chains/evm/hub/modules/folks-hub-oracle.d.ts +5 -0
- package/dist/chains/evm/hub/modules/folks-hub-oracle.js +24 -0
- package/dist/chains/evm/hub/modules/folks-hub-oracle.js.map +1 -0
- package/dist/chains/evm/hub/modules/folks-hub-pool.d.ts +5 -0
- package/dist/chains/evm/hub/modules/folks-hub-pool.js +114 -0
- package/dist/chains/evm/hub/modules/folks-hub-pool.js.map +1 -0
- package/dist/chains/evm/hub/modules/index.d.ts +5 -0
- package/dist/chains/evm/hub/modules/index.js +6 -0
- package/dist/chains/evm/hub/modules/index.js.map +1 -0
- package/dist/chains/evm/hub/types/account.d.ts +23 -0
- package/dist/chains/evm/hub/types/account.js +2 -0
- package/dist/chains/evm/hub/types/account.js.map +1 -0
- package/dist/chains/evm/hub/types/chain.d.ts +15 -0
- package/dist/chains/evm/hub/types/chain.js +2 -0
- package/dist/chains/evm/hub/types/chain.js.map +1 -0
- package/dist/chains/evm/hub/types/loan.d.ts +126 -0
- package/dist/chains/evm/hub/types/loan.js +9 -0
- package/dist/chains/evm/hub/types/loan.js.map +1 -0
- package/dist/chains/evm/hub/types/oracle.d.ts +4 -0
- package/dist/chains/evm/hub/types/oracle.js +2 -0
- package/dist/chains/evm/hub/types/oracle.js.map +1 -0
- package/dist/chains/evm/hub/types/pool.d.ts +60 -0
- package/dist/chains/evm/hub/types/pool.js +2 -0
- package/dist/chains/evm/hub/types/pool.js.map +1 -0
- package/dist/chains/evm/hub/types/token.d.ts +9 -0
- package/dist/chains/evm/hub/types/token.js +2 -0
- package/dist/chains/evm/hub/types/token.js.map +1 -0
- package/dist/chains/evm/hub/utils/chain.d.ts +13 -0
- package/dist/chains/evm/hub/utils/chain.js +29 -0
- package/dist/chains/evm/hub/utils/chain.js.map +1 -0
- package/dist/chains/evm/hub/utils/contract.d.ts +17 -0
- package/dist/chains/evm/hub/utils/contract.js +52 -0
- package/dist/chains/evm/hub/utils/contract.js.map +1 -0
- package/dist/chains/evm/hub/utils/events.d.ts +24 -0
- package/dist/chains/evm/hub/utils/events.js +97 -0
- package/dist/chains/evm/hub/utils/events.js.map +1 -0
- package/dist/chains/evm/hub/utils/loan.d.ts +4 -0
- package/dist/chains/evm/hub/utils/loan.js +36 -0
- package/dist/chains/evm/hub/utils/loan.js.map +1 -0
- package/dist/chains/evm/spoke/constants/abi/bridge-router-spoke-abi.d.ts +951 -0
- package/dist/chains/evm/spoke/constants/abi/bridge-router-spoke-abi.js +754 -0
- package/dist/chains/evm/spoke/constants/abi/bridge-router-spoke-abi.js.map +1 -0
- package/dist/chains/evm/spoke/constants/abi/spoke-common-abi.d.ts +1101 -0
- package/dist/chains/evm/spoke/constants/abi/spoke-common-abi.js +710 -0
- package/dist/chains/evm/spoke/constants/abi/spoke-common-abi.js.map +1 -0
- package/dist/chains/evm/spoke/constants/abi/spoke-token-abi.d.ts +882 -0
- package/dist/chains/evm/spoke/constants/abi/spoke-token-abi.js +643 -0
- package/dist/chains/evm/spoke/constants/abi/spoke-token-abi.js.map +1 -0
- package/dist/chains/evm/spoke/modules/folks-evm-account.d.ts +18 -0
- package/dist/chains/evm/spoke/modules/folks-evm-account.js +119 -0
- package/dist/chains/evm/spoke/modules/folks-evm-account.js.map +1 -0
- package/dist/chains/evm/spoke/modules/folks-evm-gmp.d.ts +14 -0
- package/dist/chains/evm/spoke/modules/folks-evm-gmp.js +57 -0
- package/dist/chains/evm/spoke/modules/folks-evm-gmp.js.map +1 -0
- package/dist/chains/evm/spoke/modules/folks-evm-loan.d.ts +39 -0
- package/dist/chains/evm/spoke/modules/folks-evm-loan.js +396 -0
- package/dist/chains/evm/spoke/modules/folks-evm-loan.js.map +1 -0
- package/dist/chains/evm/spoke/modules/index.d.ts +3 -0
- package/dist/chains/evm/spoke/modules/index.js +4 -0
- package/dist/chains/evm/spoke/modules/index.js.map +1 -0
- package/dist/chains/evm/spoke/types/pool.d.ts +7 -0
- package/dist/chains/evm/spoke/types/pool.js +2 -0
- package/dist/chains/evm/spoke/types/pool.js.map +1 -0
- package/dist/chains/evm/spoke/utils/contract.d.ts +12 -0
- package/dist/chains/evm/spoke/utils/contract.js +28 -0
- package/dist/chains/evm/spoke/utils/contract.js.map +1 -0
- package/dist/common/constants/adapter.d.ts +4 -0
- package/dist/common/constants/adapter.js +5 -0
- package/dist/common/constants/adapter.js.map +1 -0
- package/dist/common/constants/bytes.d.ts +5 -0
- package/dist/common/constants/bytes.js +6 -0
- package/dist/common/constants/bytes.js.map +1 -0
- package/dist/common/constants/chain.d.ts +15 -0
- package/dist/common/constants/chain.js +152 -0
- package/dist/common/constants/chain.js.map +1 -0
- package/dist/common/constants/gmp.d.ts +4 -0
- package/dist/common/constants/gmp.js +32 -0
- package/dist/common/constants/gmp.js.map +1 -0
- package/dist/common/constants/lending.d.ts +1 -0
- package/dist/common/constants/lending.js +3 -0
- package/dist/common/constants/lending.js.map +1 -0
- package/dist/common/constants/message.d.ts +4 -0
- package/dist/common/constants/message.js +5 -0
- package/dist/common/constants/message.js.map +1 -0
- package/dist/common/constants/pool.d.ts +8 -0
- package/dist/common/constants/pool.js +10 -0
- package/dist/common/constants/pool.js.map +1 -0
- package/dist/common/constants/token.d.ts +2 -0
- package/dist/common/constants/token.js +3 -0
- package/dist/common/constants/token.js.map +1 -0
- package/dist/common/types/adapter.d.ts +30 -0
- package/dist/common/types/adapter.js +7 -0
- package/dist/common/types/adapter.js.map +1 -0
- package/dist/common/types/address.d.ts +9 -0
- package/dist/common/types/address.js +2 -0
- package/dist/common/types/address.js.map +1 -0
- package/dist/common/types/brand.d.ts +6 -0
- package/dist/common/types/brand.js +2 -0
- package/dist/common/types/brand.js.map +1 -0
- package/dist/common/types/chain.d.ts +29 -0
- package/dist/common/types/chain.js +10 -0
- package/dist/common/types/chain.js.map +1 -0
- package/dist/common/types/core.d.ts +28 -0
- package/dist/common/types/core.js +2 -0
- package/dist/common/types/core.js.map +1 -0
- package/dist/common/types/gmp.d.ts +17 -0
- package/dist/common/types/gmp.js +6 -0
- package/dist/common/types/gmp.js.map +1 -0
- package/dist/common/types/lending.d.ts +4 -0
- package/dist/common/types/lending.js +2 -0
- package/dist/common/types/lending.js.map +1 -0
- package/dist/common/types/message.d.ts +239 -0
- package/dist/common/types/message.js +33 -0
- package/dist/common/types/message.js.map +1 -0
- package/dist/common/types/module.d.ts +21 -0
- package/dist/common/types/module.js +6 -0
- package/dist/common/types/module.js.map +1 -0
- package/dist/common/types/token.d.ts +42 -0
- package/dist/common/types/token.js +15 -0
- package/dist/common/types/token.js.map +1 -0
- package/dist/common/utils/adapter.d.ts +11 -0
- package/dist/common/utils/adapter.js +63 -0
- package/dist/common/utils/adapter.js.map +1 -0
- package/dist/common/utils/address.d.ts +8 -0
- package/dist/common/utils/address.js +35 -0
- package/dist/common/utils/address.js.map +1 -0
- package/dist/common/utils/bytes.d.ts +9 -0
- package/dist/common/utils/bytes.js +34 -0
- package/dist/common/utils/bytes.js.map +1 -0
- package/dist/common/utils/chain.d.ts +19 -0
- package/dist/common/utils/chain.js +74 -0
- package/dist/common/utils/chain.js.map +1 -0
- package/dist/common/utils/formulae.d.ts +15 -0
- package/dist/common/utils/formulae.js +77 -0
- package/dist/common/utils/formulae.js.map +1 -0
- package/dist/common/utils/gmp.d.ts +4 -0
- package/dist/common/utils/gmp.js +14 -0
- package/dist/common/utils/gmp.js.map +1 -0
- package/dist/common/utils/math-lib.d.ts +9 -0
- package/dist/common/utils/math-lib.js +38 -0
- package/dist/common/utils/math-lib.js.map +1 -0
- package/dist/common/utils/messages.d.ts +7 -0
- package/dist/common/utils/messages.js +93 -0
- package/dist/common/utils/messages.js.map +1 -0
- package/dist/common/utils/token.d.ts +2 -0
- package/dist/common/utils/token.js +5 -0
- package/dist/common/utils/token.js.map +1 -0
- package/dist/index.d.ts +30 -0
- package/dist/index.js +38 -0
- package/dist/index.js.map +1 -0
- package/dist/utils/exhaustive-check.d.ts +1 -0
- package/dist/utils/exhaustive-check.js +4 -0
- package/dist/utils/exhaustive-check.js.map +1 -0
- package/dist/xchain/core/folks-core.d.ts +24 -0
- package/dist/xchain/core/folks-core.js +100 -0
- package/dist/xchain/core/folks-core.js.map +1 -0
- package/dist/xchain/modules/folks-account.d.ts +30 -0
- package/dist/xchain/modules/folks-account.js +205 -0
- package/dist/xchain/modules/folks-account.js.map +1 -0
- package/dist/xchain/modules/folks-gmp.d.ts +12 -0
- package/dist/xchain/modules/folks-gmp.js +53 -0
- package/dist/xchain/modules/folks-gmp.js.map +1 -0
- package/dist/xchain/modules/folks-loan.d.ts +68 -0
- package/dist/xchain/modules/folks-loan.js +598 -0
- package/dist/xchain/modules/folks-loan.js.map +1 -0
- package/dist/xchain/modules/folks-oracle.d.ts +4 -0
- package/dist/xchain/modules/folks-oracle.js +11 -0
- package/dist/xchain/modules/folks-oracle.js.map +1 -0
- package/dist/xchain/modules/folks-pool.d.ts +5 -0
- package/dist/xchain/modules/folks-pool.js +8 -0
- package/dist/xchain/modules/folks-pool.js.map +1 -0
- package/dist/xchain/modules/index.d.ts +5 -0
- package/dist/xchain/modules/index.js +6 -0
- package/dist/xchain/modules/index.js.map +1 -0
- package/package.json +79 -0
- package/src/chains/evm/common/constants/abi/ccip-data-adapter-abi.ts +613 -0
- package/src/chains/evm/common/constants/abi/erc-20-abi.ts +156 -0
- package/src/chains/evm/common/constants/abi/wormhole-data-adapter-abi.ts +620 -0
- package/src/chains/evm/common/constants/chain.ts +56 -0
- package/src/chains/evm/common/constants/contract.ts +7 -0
- package/src/chains/evm/common/constants/tokens.ts +39 -0
- package/src/chains/evm/common/types/chain.ts +23 -0
- package/src/chains/evm/common/types/contract.ts +7 -0
- package/src/chains/evm/common/types/gmp.ts +15 -0
- package/src/chains/evm/common/types/index.ts +3 -0
- package/src/chains/evm/common/types/module.ts +85 -0
- package/src/chains/evm/common/types/tokens.ts +31 -0
- package/src/chains/evm/common/utils/chain.ts +20 -0
- package/src/chains/evm/common/utils/contract.ts +84 -0
- package/src/chains/evm/common/utils/gmp.ts +24 -0
- package/src/chains/evm/common/utils/message.ts +496 -0
- package/src/chains/evm/common/utils/provider.ts +32 -0
- package/src/chains/evm/common/utils/tokens.ts +52 -0
- package/src/chains/evm/hub/constants/abi/account-manager-abi.ts +685 -0
- package/src/chains/evm/hub/constants/abi/bridge-router-hub-abi.ts +763 -0
- package/src/chains/evm/hub/constants/abi/hub-abi.ts +186 -0
- package/src/chains/evm/hub/constants/abi/hub-pool-abi.ts +1345 -0
- package/src/chains/evm/hub/constants/abi/loan-manager-abi.ts +1039 -0
- package/src/chains/evm/hub/constants/abi/oracle-manager-abi.ts +388 -0
- package/src/chains/evm/hub/constants/chain.ts +130 -0
- package/src/chains/evm/hub/modules/folks-hub-account.ts +137 -0
- package/src/chains/evm/hub/modules/folks-hub-gmp.ts +105 -0
- package/src/chains/evm/hub/modules/folks-hub-loan.ts +603 -0
- package/src/chains/evm/hub/modules/folks-hub-oracle.ts +38 -0
- package/src/chains/evm/hub/modules/folks-hub-pool.ts +171 -0
- package/src/chains/evm/hub/modules/index.ts +5 -0
- package/src/chains/evm/hub/types/account.ts +27 -0
- package/src/chains/evm/hub/types/chain.ts +16 -0
- package/src/chains/evm/hub/types/loan.ts +147 -0
- package/src/chains/evm/hub/types/oracle.ts +6 -0
- package/src/chains/evm/hub/types/pool.ts +66 -0
- package/src/chains/evm/hub/types/token.ts +10 -0
- package/src/chains/evm/hub/utils/chain.ts +41 -0
- package/src/chains/evm/hub/utils/contract.ts +98 -0
- package/src/chains/evm/hub/utils/events.ts +112 -0
- package/src/chains/evm/hub/utils/loan.ts +60 -0
- package/src/chains/evm/spoke/constants/abi/bridge-router-spoke-abi.ts +753 -0
- package/src/chains/evm/spoke/constants/abi/spoke-common-abi.ts +709 -0
- package/src/chains/evm/spoke/constants/abi/spoke-token-abi.ts +642 -0
- package/src/chains/evm/spoke/modules/folks-evm-account.ts +228 -0
- package/src/chains/evm/spoke/modules/folks-evm-gmp.ts +105 -0
- package/src/chains/evm/spoke/modules/folks-evm-loan.ts +721 -0
- package/src/chains/evm/spoke/modules/index.ts +3 -0
- package/src/chains/evm/spoke/types/pool.ts +7 -0
- package/src/chains/evm/spoke/utils/contract.ts +74 -0
- package/src/common/constants/adapter.ts +5 -0
- package/src/common/constants/bytes.ts +6 -0
- package/src/common/constants/chain.ts +227 -0
- package/src/common/constants/gmp.ts +38 -0
- package/src/common/constants/lending.ts +3 -0
- package/src/common/constants/message.ts +4 -0
- package/src/common/constants/pool.ts +11 -0
- package/src/common/constants/token.ts +3 -0
- package/src/common/types/adapter.ts +38 -0
- package/src/common/types/address.ts +11 -0
- package/src/common/types/brand.ts +3 -0
- package/src/common/types/chain.ts +35 -0
- package/src/common/types/core.ts +31 -0
- package/src/common/types/gmp.ts +22 -0
- package/src/common/types/lending.ts +5 -0
- package/src/common/types/message.ts +330 -0
- package/src/common/types/module.ts +42 -0
- package/src/common/types/token.ts +50 -0
- package/src/common/utils/adapter.ts +75 -0
- package/src/common/utils/address.ts +49 -0
- package/src/common/utils/bytes.ts +46 -0
- package/src/common/utils/chain.ts +103 -0
- package/src/common/utils/formulae.ts +124 -0
- package/src/common/utils/gmp.ts +16 -0
- package/src/common/utils/math-lib.ts +46 -0
- package/src/common/utils/messages.ts +192 -0
- package/src/common/utils/token.ts +7 -0
- package/src/index.ts +47 -0
- package/src/utils/exhaustive-check.ts +3 -0
- package/src/xchain/core/folks-core.ts +128 -0
- package/src/xchain/modules/folks-account.ts +385 -0
- package/src/xchain/modules/folks-gmp.ts +129 -0
- package/src/xchain/modules/folks-loan.ts +1175 -0
- package/src/xchain/modules/folks-oracle.ts +15 -0
- package/src/xchain/modules/folks-pool.ts +11 -0
- package/src/xchain/modules/index.ts +5 -0
|
@@ -0,0 +1,496 @@
|
|
|
1
|
+
import { concat, isHex } from "viem";
|
|
2
|
+
|
|
3
|
+
import { BYTES32_LENGTH, UINT16_LENGTH, UINT256_LENGTH, UINT8_LENGTH } from "../../../../common/constants/bytes.js";
|
|
4
|
+
import { FINALITY } from "../../../../common/constants/message.js";
|
|
5
|
+
import { ChainType } from "../../../../common/types/chain.js";
|
|
6
|
+
import { Action } from "../../../../common/types/message.js";
|
|
7
|
+
import { TokenType } from "../../../../common/types/token.js";
|
|
8
|
+
import { convertFromGenericAddress, isAccountId, isGenericAddress } from "../../../../common/utils/address.js";
|
|
9
|
+
import { convertBooleanToByte, convertNumberToBytes, getRandomBytes } from "../../../../common/utils/bytes.js";
|
|
10
|
+
import { exhaustiveCheck } from "../../../../utils/exhaustive-check.js";
|
|
11
|
+
|
|
12
|
+
import {
|
|
13
|
+
getCCIPDataAdapterContract as getCcipDataAdapterContract,
|
|
14
|
+
getWormholeDataAdapterContract,
|
|
15
|
+
} from "./contract.js";
|
|
16
|
+
import { encodeEvmPayloadWithMetadata } from "./gmp.js";
|
|
17
|
+
import { getBalanceOfStateOverride } from "./tokens.js";
|
|
18
|
+
|
|
19
|
+
import type { EvmAddress, GenericAddress } from "../../../../common/types/address.js";
|
|
20
|
+
import type { FolksChainId } from "../../../../common/types/chain.js";
|
|
21
|
+
import type { AccountId } from "../../../../common/types/lending.js";
|
|
22
|
+
import type {
|
|
23
|
+
MessageAdapters,
|
|
24
|
+
MessageBuilderParams,
|
|
25
|
+
MessageDataParams,
|
|
26
|
+
MessageParams,
|
|
27
|
+
MessageToSend,
|
|
28
|
+
OptionalFeeParams,
|
|
29
|
+
SendTokenExtraArgs,
|
|
30
|
+
} from "../../../../common/types/message.js";
|
|
31
|
+
import type { FolksTokenId, FolksSpokeTokenType, FolksHubTokenType } from "../../../../common/types/token.js";
|
|
32
|
+
import type { CCIPAny2EvmMessage } from "../types/gmp.js";
|
|
33
|
+
import type { Client, Hex, StateOverride } from "viem";
|
|
34
|
+
|
|
35
|
+
export const buildMessageParams = ({
|
|
36
|
+
adapters,
|
|
37
|
+
receiverValue = BigInt(0),
|
|
38
|
+
gasLimit = BigInt(0),
|
|
39
|
+
returnGasLimit = BigInt(0),
|
|
40
|
+
}: {
|
|
41
|
+
adapters: MessageAdapters;
|
|
42
|
+
receiverValue?: bigint;
|
|
43
|
+
gasLimit?: bigint;
|
|
44
|
+
returnGasLimit?: bigint;
|
|
45
|
+
}): MessageParams => ({
|
|
46
|
+
...adapters,
|
|
47
|
+
receiverValue,
|
|
48
|
+
gasLimit,
|
|
49
|
+
returnGasLimit,
|
|
50
|
+
});
|
|
51
|
+
|
|
52
|
+
export function buildMessagePayload(action: Action, accountId: AccountId, userAddr: GenericAddress, data: Hex): Hex {
|
|
53
|
+
if (!isAccountId(accountId)) throw Error("Unknown account id format");
|
|
54
|
+
if (!isGenericAddress(userAddr)) throw Error("Unknown user address format");
|
|
55
|
+
if (!isHex(data)) throw Error("Unknown data format");
|
|
56
|
+
|
|
57
|
+
return concat([convertNumberToBytes(action, UINT16_LENGTH), accountId, userAddr, data]);
|
|
58
|
+
}
|
|
59
|
+
|
|
60
|
+
export function extraArgsToBytes(tokenAddr: GenericAddress, recipientAddr: GenericAddress, amount: bigint): Hex {
|
|
61
|
+
if (!isGenericAddress(tokenAddr)) throw Error("Unknown token address format");
|
|
62
|
+
if (!isGenericAddress(recipientAddr)) throw Error("Unknown recipient address format");
|
|
63
|
+
|
|
64
|
+
return concat(["0x1b366e79", tokenAddr, recipientAddr, convertNumberToBytes(amount, UINT256_LENGTH)]);
|
|
65
|
+
}
|
|
66
|
+
|
|
67
|
+
export function buildSendTokenExtraArgsWhenRemoving(
|
|
68
|
+
spokeAddress: GenericAddress,
|
|
69
|
+
folksTokenType: FolksHubTokenType,
|
|
70
|
+
amount: bigint,
|
|
71
|
+
): Hex {
|
|
72
|
+
const { type } = folksTokenType;
|
|
73
|
+
switch (type) {
|
|
74
|
+
case TokenType.NATIVE:
|
|
75
|
+
case TokenType.ERC20:
|
|
76
|
+
return "0x";
|
|
77
|
+
default:
|
|
78
|
+
return extraArgsToBytes(folksTokenType.address, spokeAddress, amount);
|
|
79
|
+
}
|
|
80
|
+
}
|
|
81
|
+
|
|
82
|
+
export function buildSendTokenExtraArgsWhenAdding(
|
|
83
|
+
hubPoolAddress: GenericAddress,
|
|
84
|
+
folksTokenType: FolksSpokeTokenType,
|
|
85
|
+
amount: bigint,
|
|
86
|
+
): Hex {
|
|
87
|
+
const { type } = folksTokenType;
|
|
88
|
+
switch (type) {
|
|
89
|
+
case TokenType.NATIVE:
|
|
90
|
+
case TokenType.ERC20:
|
|
91
|
+
return "0x";
|
|
92
|
+
default:
|
|
93
|
+
return extraArgsToBytes(folksTokenType.address, hubPoolAddress, amount);
|
|
94
|
+
}
|
|
95
|
+
}
|
|
96
|
+
|
|
97
|
+
export function buildEvmMessageData(messageDataParams: MessageDataParams): Hex {
|
|
98
|
+
const { action, data } = messageDataParams;
|
|
99
|
+
switch (action) {
|
|
100
|
+
case Action.CreateAccount: {
|
|
101
|
+
return data.refAccountId;
|
|
102
|
+
}
|
|
103
|
+
case Action.InviteAddress: {
|
|
104
|
+
return concat([
|
|
105
|
+
convertNumberToBytes(data.folksChainIdToInvite, UINT16_LENGTH),
|
|
106
|
+
data.addressToInvite,
|
|
107
|
+
data.refAccountId,
|
|
108
|
+
]);
|
|
109
|
+
}
|
|
110
|
+
case Action.AcceptInviteAddress: {
|
|
111
|
+
return data;
|
|
112
|
+
}
|
|
113
|
+
case Action.UnregisterAddress: {
|
|
114
|
+
return convertNumberToBytes(data.folksChainIdToUnregister, UINT16_LENGTH);
|
|
115
|
+
}
|
|
116
|
+
case Action.AddDelegate: {
|
|
117
|
+
throw new Error("Not implemented yet: Action.AddDelegate case");
|
|
118
|
+
}
|
|
119
|
+
case Action.RemoveDelegate: {
|
|
120
|
+
throw new Error("Not implemented yet: Action.RemoveDelegate case");
|
|
121
|
+
}
|
|
122
|
+
case Action.CreateLoan: {
|
|
123
|
+
return concat([data.loanId, convertNumberToBytes(data.loanTypeId, UINT16_LENGTH), data.loanName]);
|
|
124
|
+
}
|
|
125
|
+
case Action.DeleteLoan: {
|
|
126
|
+
return data.loanId;
|
|
127
|
+
}
|
|
128
|
+
case Action.CreateLoanAndDeposit: {
|
|
129
|
+
return concat([
|
|
130
|
+
data.loanId,
|
|
131
|
+
convertNumberToBytes(data.poolId, UINT8_LENGTH),
|
|
132
|
+
convertNumberToBytes(data.amount, UINT256_LENGTH),
|
|
133
|
+
convertNumberToBytes(data.loanTypeId, UINT16_LENGTH),
|
|
134
|
+
data.loanName,
|
|
135
|
+
]);
|
|
136
|
+
}
|
|
137
|
+
case Action.Deposit: {
|
|
138
|
+
return concat([
|
|
139
|
+
data.loanId,
|
|
140
|
+
convertNumberToBytes(data.poolId, UINT8_LENGTH),
|
|
141
|
+
convertNumberToBytes(data.amount, UINT256_LENGTH),
|
|
142
|
+
]);
|
|
143
|
+
}
|
|
144
|
+
case Action.DepositFToken: {
|
|
145
|
+
throw new Error("Not implemented yet: Action.DepositFToken case");
|
|
146
|
+
}
|
|
147
|
+
case Action.Withdraw: {
|
|
148
|
+
return concat([
|
|
149
|
+
data.loanId,
|
|
150
|
+
convertNumberToBytes(data.poolId, UINT8_LENGTH),
|
|
151
|
+
convertNumberToBytes(data.receiverFolksChainId, UINT16_LENGTH),
|
|
152
|
+
convertNumberToBytes(data.amount, UINT256_LENGTH),
|
|
153
|
+
convertBooleanToByte(data.isFAmount),
|
|
154
|
+
]);
|
|
155
|
+
}
|
|
156
|
+
case Action.WithdrawFToken: {
|
|
157
|
+
throw new Error("Not implemented yet: Action.WithdrawFToken case");
|
|
158
|
+
}
|
|
159
|
+
case Action.Borrow: {
|
|
160
|
+
return concat([
|
|
161
|
+
data.loanId,
|
|
162
|
+
convertNumberToBytes(data.poolId, UINT8_LENGTH),
|
|
163
|
+
convertNumberToBytes(data.receiverFolksChainId, UINT16_LENGTH),
|
|
164
|
+
convertNumberToBytes(data.amount, UINT256_LENGTH),
|
|
165
|
+
convertNumberToBytes(data.maxStableRate, UINT256_LENGTH),
|
|
166
|
+
]);
|
|
167
|
+
}
|
|
168
|
+
case Action.Repay: {
|
|
169
|
+
return concat([
|
|
170
|
+
data.loanId,
|
|
171
|
+
convertNumberToBytes(data.poolId, UINT8_LENGTH),
|
|
172
|
+
convertNumberToBytes(data.amount, UINT256_LENGTH),
|
|
173
|
+
convertNumberToBytes(data.maxOverRepayment, UINT256_LENGTH),
|
|
174
|
+
]);
|
|
175
|
+
}
|
|
176
|
+
case Action.RepayWithCollateral: {
|
|
177
|
+
return concat([
|
|
178
|
+
data.loanId,
|
|
179
|
+
convertNumberToBytes(data.poolId, UINT8_LENGTH),
|
|
180
|
+
convertNumberToBytes(data.amount, UINT256_LENGTH),
|
|
181
|
+
]);
|
|
182
|
+
}
|
|
183
|
+
case Action.Liquidate: {
|
|
184
|
+
return concat([
|
|
185
|
+
data.violatorLoanId,
|
|
186
|
+
data.liquidatorLoanId,
|
|
187
|
+
convertNumberToBytes(data.colPoolId, UINT8_LENGTH),
|
|
188
|
+
convertNumberToBytes(data.borPoolId, UINT8_LENGTH),
|
|
189
|
+
convertNumberToBytes(data.repayingAmount, UINT256_LENGTH),
|
|
190
|
+
convertNumberToBytes(data.minSeizedAmount, UINT256_LENGTH),
|
|
191
|
+
]);
|
|
192
|
+
}
|
|
193
|
+
case Action.SwitchBorrowType: {
|
|
194
|
+
return concat([
|
|
195
|
+
data.loanId,
|
|
196
|
+
convertNumberToBytes(data.poolId, UINT8_LENGTH),
|
|
197
|
+
convertNumberToBytes(data.maxStableRate, UINT256_LENGTH),
|
|
198
|
+
]);
|
|
199
|
+
}
|
|
200
|
+
case Action.SendToken: {
|
|
201
|
+
return convertNumberToBytes(data.amount, UINT256_LENGTH);
|
|
202
|
+
}
|
|
203
|
+
default:
|
|
204
|
+
return exhaustiveCheck(action);
|
|
205
|
+
}
|
|
206
|
+
}
|
|
207
|
+
|
|
208
|
+
export function buildEvmMessageToSend(
|
|
209
|
+
messageToSendBuilderParams: MessageBuilderParams,
|
|
210
|
+
feeParams: OptionalFeeParams,
|
|
211
|
+
): MessageToSend {
|
|
212
|
+
const { userAddress, accountId, adapters, sender, destinationChainId, handler, action, extraArgs } =
|
|
213
|
+
messageToSendBuilderParams;
|
|
214
|
+
const data = buildEvmMessageData(messageToSendBuilderParams);
|
|
215
|
+
const params = buildMessageParams({ adapters, ...feeParams });
|
|
216
|
+
switch (action) {
|
|
217
|
+
case Action.CreateAccount: {
|
|
218
|
+
const message: MessageToSend = {
|
|
219
|
+
params,
|
|
220
|
+
sender,
|
|
221
|
+
destinationChainId,
|
|
222
|
+
handler,
|
|
223
|
+
payload: buildMessagePayload(Action.CreateAccount, accountId, userAddress, data),
|
|
224
|
+
finalityLevel: FINALITY.IMMEDIATE,
|
|
225
|
+
extraArgs,
|
|
226
|
+
};
|
|
227
|
+
return message;
|
|
228
|
+
}
|
|
229
|
+
case Action.InviteAddress: {
|
|
230
|
+
const message: MessageToSend = {
|
|
231
|
+
params,
|
|
232
|
+
sender,
|
|
233
|
+
destinationChainId,
|
|
234
|
+
handler,
|
|
235
|
+
payload: buildMessagePayload(Action.InviteAddress, accountId, userAddress, data),
|
|
236
|
+
finalityLevel: FINALITY.IMMEDIATE,
|
|
237
|
+
extraArgs: "0x",
|
|
238
|
+
};
|
|
239
|
+
return message;
|
|
240
|
+
}
|
|
241
|
+
case Action.AcceptInviteAddress: {
|
|
242
|
+
const message: MessageToSend = {
|
|
243
|
+
params,
|
|
244
|
+
sender,
|
|
245
|
+
destinationChainId,
|
|
246
|
+
handler,
|
|
247
|
+
payload: buildMessagePayload(Action.AcceptInviteAddress, accountId, userAddress, data),
|
|
248
|
+
finalityLevel: FINALITY.IMMEDIATE,
|
|
249
|
+
extraArgs,
|
|
250
|
+
};
|
|
251
|
+
return message;
|
|
252
|
+
}
|
|
253
|
+
case Action.UnregisterAddress: {
|
|
254
|
+
const message: MessageToSend = {
|
|
255
|
+
params,
|
|
256
|
+
sender,
|
|
257
|
+
destinationChainId,
|
|
258
|
+
handler,
|
|
259
|
+
payload: buildMessagePayload(Action.UnregisterAddress, accountId, userAddress, data),
|
|
260
|
+
finalityLevel: FINALITY.IMMEDIATE,
|
|
261
|
+
extraArgs,
|
|
262
|
+
};
|
|
263
|
+
return message;
|
|
264
|
+
}
|
|
265
|
+
case Action.AddDelegate: {
|
|
266
|
+
throw new Error("Not implemented yet: Action.AddDelegate case");
|
|
267
|
+
}
|
|
268
|
+
case Action.RemoveDelegate: {
|
|
269
|
+
throw new Error("Not implemented yet: Action.RemoveDelegate case");
|
|
270
|
+
}
|
|
271
|
+
case Action.CreateLoan: {
|
|
272
|
+
const message: MessageToSend = {
|
|
273
|
+
params,
|
|
274
|
+
sender,
|
|
275
|
+
destinationChainId,
|
|
276
|
+
handler,
|
|
277
|
+
payload: buildMessagePayload(Action.CreateLoan, accountId, userAddress, data),
|
|
278
|
+
finalityLevel: FINALITY.IMMEDIATE,
|
|
279
|
+
extraArgs,
|
|
280
|
+
};
|
|
281
|
+
return message;
|
|
282
|
+
}
|
|
283
|
+
case Action.DeleteLoan: {
|
|
284
|
+
const message: MessageToSend = {
|
|
285
|
+
params,
|
|
286
|
+
sender,
|
|
287
|
+
destinationChainId,
|
|
288
|
+
handler,
|
|
289
|
+
payload: buildMessagePayload(Action.DeleteLoan, accountId, userAddress, data),
|
|
290
|
+
finalityLevel: FINALITY.IMMEDIATE,
|
|
291
|
+
extraArgs,
|
|
292
|
+
};
|
|
293
|
+
return message;
|
|
294
|
+
}
|
|
295
|
+
case Action.CreateLoanAndDeposit: {
|
|
296
|
+
const message: MessageToSend = {
|
|
297
|
+
params,
|
|
298
|
+
sender,
|
|
299
|
+
destinationChainId,
|
|
300
|
+
handler,
|
|
301
|
+
payload: buildMessagePayload(Action.CreateLoanAndDeposit, accountId, userAddress, data),
|
|
302
|
+
finalityLevel: FINALITY.FINALISED,
|
|
303
|
+
extraArgs: buildSendTokenExtraArgsWhenAdding(extraArgs.recipient, extraArgs.token, extraArgs.amount),
|
|
304
|
+
};
|
|
305
|
+
return message;
|
|
306
|
+
}
|
|
307
|
+
case Action.Deposit: {
|
|
308
|
+
const message: MessageToSend = {
|
|
309
|
+
params,
|
|
310
|
+
sender,
|
|
311
|
+
destinationChainId,
|
|
312
|
+
handler,
|
|
313
|
+
payload: buildMessagePayload(Action.Deposit, accountId, userAddress, data),
|
|
314
|
+
finalityLevel: FINALITY.FINALISED,
|
|
315
|
+
extraArgs: buildSendTokenExtraArgsWhenAdding(extraArgs.recipient, extraArgs.token, extraArgs.amount),
|
|
316
|
+
};
|
|
317
|
+
return message;
|
|
318
|
+
}
|
|
319
|
+
case Action.DepositFToken: {
|
|
320
|
+
throw new Error("Not implemented yet: Action.DepositFToken case");
|
|
321
|
+
}
|
|
322
|
+
case Action.Withdraw: {
|
|
323
|
+
const message: MessageToSend = {
|
|
324
|
+
params,
|
|
325
|
+
sender,
|
|
326
|
+
destinationChainId,
|
|
327
|
+
handler,
|
|
328
|
+
payload: buildMessagePayload(Action.Withdraw, accountId, userAddress, data),
|
|
329
|
+
finalityLevel: FINALITY.IMMEDIATE,
|
|
330
|
+
extraArgs,
|
|
331
|
+
};
|
|
332
|
+
return message;
|
|
333
|
+
}
|
|
334
|
+
case Action.WithdrawFToken: {
|
|
335
|
+
throw new Error("Not implemented yet: Action.WithdrawFToken case");
|
|
336
|
+
}
|
|
337
|
+
case Action.Borrow: {
|
|
338
|
+
const message: MessageToSend = {
|
|
339
|
+
params,
|
|
340
|
+
sender,
|
|
341
|
+
destinationChainId,
|
|
342
|
+
handler,
|
|
343
|
+
payload: buildMessagePayload(Action.Borrow, accountId, userAddress, data),
|
|
344
|
+
finalityLevel: FINALITY.IMMEDIATE,
|
|
345
|
+
extraArgs,
|
|
346
|
+
};
|
|
347
|
+
return message;
|
|
348
|
+
}
|
|
349
|
+
case Action.Repay: {
|
|
350
|
+
const message: MessageToSend = {
|
|
351
|
+
params,
|
|
352
|
+
sender,
|
|
353
|
+
destinationChainId,
|
|
354
|
+
handler,
|
|
355
|
+
payload: buildMessagePayload(Action.Repay, accountId, userAddress, data),
|
|
356
|
+
finalityLevel: FINALITY.FINALISED,
|
|
357
|
+
extraArgs: buildSendTokenExtraArgsWhenAdding(extraArgs.recipient, extraArgs.token, extraArgs.amount),
|
|
358
|
+
};
|
|
359
|
+
return message;
|
|
360
|
+
}
|
|
361
|
+
case Action.RepayWithCollateral: {
|
|
362
|
+
const message: MessageToSend = {
|
|
363
|
+
params,
|
|
364
|
+
sender,
|
|
365
|
+
destinationChainId,
|
|
366
|
+
handler,
|
|
367
|
+
payload: buildMessagePayload(Action.RepayWithCollateral, accountId, userAddress, data),
|
|
368
|
+
finalityLevel: FINALITY.IMMEDIATE,
|
|
369
|
+
extraArgs,
|
|
370
|
+
};
|
|
371
|
+
return message;
|
|
372
|
+
}
|
|
373
|
+
case Action.Liquidate: {
|
|
374
|
+
throw new Error("No message to send for Action.Liquidate case");
|
|
375
|
+
}
|
|
376
|
+
case Action.SwitchBorrowType: {
|
|
377
|
+
const message: MessageToSend = {
|
|
378
|
+
params,
|
|
379
|
+
sender,
|
|
380
|
+
destinationChainId,
|
|
381
|
+
handler,
|
|
382
|
+
payload: buildMessagePayload(Action.SwitchBorrowType, accountId, userAddress, data),
|
|
383
|
+
finalityLevel: FINALITY.IMMEDIATE,
|
|
384
|
+
extraArgs,
|
|
385
|
+
};
|
|
386
|
+
return message;
|
|
387
|
+
}
|
|
388
|
+
case Action.SendToken: {
|
|
389
|
+
throw new Error("Not implemented yet: Action.SendToken case");
|
|
390
|
+
}
|
|
391
|
+
default:
|
|
392
|
+
return exhaustiveCheck(action);
|
|
393
|
+
}
|
|
394
|
+
}
|
|
395
|
+
|
|
396
|
+
export async function estimateEvmWormholeDataGasLimit(
|
|
397
|
+
provider: Client,
|
|
398
|
+
messageBuilderParams: MessageBuilderParams,
|
|
399
|
+
receiverValue: bigint,
|
|
400
|
+
returnGasLimit: bigint,
|
|
401
|
+
sourceWormholeChainId: number,
|
|
402
|
+
wormholeRelayer: EvmAddress,
|
|
403
|
+
wormholeDataAdapterAddress: GenericAddress,
|
|
404
|
+
sourceWormholeDataAdapterAddress: GenericAddress,
|
|
405
|
+
stateOverride: StateOverride,
|
|
406
|
+
) {
|
|
407
|
+
const messageId = getRandomBytes(BYTES32_LENGTH);
|
|
408
|
+
const wormholeDataAdapter = getWormholeDataAdapterContract(provider, wormholeDataAdapterAddress);
|
|
409
|
+
return await wormholeDataAdapter.estimateGas.receiveWormholeMessages(
|
|
410
|
+
[
|
|
411
|
+
encodeEvmPayloadWithMetadata(
|
|
412
|
+
messageBuilderParams.adapters.returnAdapterId,
|
|
413
|
+
returnGasLimit,
|
|
414
|
+
messageBuilderParams.sender,
|
|
415
|
+
messageBuilderParams.handler,
|
|
416
|
+
buildMessagePayload(
|
|
417
|
+
messageBuilderParams.action,
|
|
418
|
+
messageBuilderParams.accountId,
|
|
419
|
+
messageBuilderParams.userAddress,
|
|
420
|
+
buildEvmMessageData(messageBuilderParams),
|
|
421
|
+
),
|
|
422
|
+
),
|
|
423
|
+
[],
|
|
424
|
+
sourceWormholeDataAdapterAddress,
|
|
425
|
+
sourceWormholeChainId,
|
|
426
|
+
messageId,
|
|
427
|
+
],
|
|
428
|
+
{
|
|
429
|
+
value: receiverValue,
|
|
430
|
+
account: wormholeRelayer,
|
|
431
|
+
stateOverride: [{ address: wormholeRelayer, balance: receiverValue }, ...stateOverride],
|
|
432
|
+
},
|
|
433
|
+
);
|
|
434
|
+
}
|
|
435
|
+
|
|
436
|
+
export async function estimateEvmCcipDataGasLimit(
|
|
437
|
+
provider: Client,
|
|
438
|
+
messageBuilderParams: MessageBuilderParams,
|
|
439
|
+
returnGasLimit: bigint,
|
|
440
|
+
sourceCcipChainId: bigint,
|
|
441
|
+
ccipRouter: EvmAddress,
|
|
442
|
+
ccipDataAdapterAddress: GenericAddress,
|
|
443
|
+
sourceCcipDataAdapterAddress: GenericAddress,
|
|
444
|
+
) {
|
|
445
|
+
const messageId = getRandomBytes(BYTES32_LENGTH);
|
|
446
|
+
|
|
447
|
+
const ccipMessage: CCIPAny2EvmMessage = {
|
|
448
|
+
messageId,
|
|
449
|
+
sourceChainSelector: sourceCcipChainId,
|
|
450
|
+
sender: sourceCcipDataAdapterAddress,
|
|
451
|
+
data: encodeEvmPayloadWithMetadata(
|
|
452
|
+
messageBuilderParams.adapters.returnAdapterId,
|
|
453
|
+
returnGasLimit,
|
|
454
|
+
messageBuilderParams.sender,
|
|
455
|
+
messageBuilderParams.handler,
|
|
456
|
+
buildMessagePayload(
|
|
457
|
+
messageBuilderParams.action,
|
|
458
|
+
messageBuilderParams.accountId,
|
|
459
|
+
messageBuilderParams.userAddress,
|
|
460
|
+
buildEvmMessageData(messageBuilderParams),
|
|
461
|
+
),
|
|
462
|
+
),
|
|
463
|
+
destTokenAmounts: [],
|
|
464
|
+
};
|
|
465
|
+
|
|
466
|
+
const ccipDataAdapter = getCcipDataAdapterContract(provider, ccipDataAdapterAddress);
|
|
467
|
+
return await ccipDataAdapter.estimateGas.ccipReceive([ccipMessage], {
|
|
468
|
+
account: ccipRouter,
|
|
469
|
+
});
|
|
470
|
+
}
|
|
471
|
+
|
|
472
|
+
export function getSendTokenStateOverride(
|
|
473
|
+
folksChainId: FolksChainId,
|
|
474
|
+
folksTokenId: FolksTokenId,
|
|
475
|
+
extraArgs: SendTokenExtraArgs,
|
|
476
|
+
) {
|
|
477
|
+
const { amount, recipient, token } = extraArgs;
|
|
478
|
+
if (token.type === TokenType.CIRCLE || token.type === TokenType.ERC20) {
|
|
479
|
+
const erc20Address = convertFromGenericAddress(token.address, ChainType.EVM);
|
|
480
|
+
return getBalanceOfStateOverride([
|
|
481
|
+
{
|
|
482
|
+
erc20Address,
|
|
483
|
+
stateDiff: [
|
|
484
|
+
{
|
|
485
|
+
owner: convertFromGenericAddress(recipient, ChainType.EVM),
|
|
486
|
+
folksChainId,
|
|
487
|
+
folksTokenId,
|
|
488
|
+
tokenType: token.type,
|
|
489
|
+
amount: amount,
|
|
490
|
+
},
|
|
491
|
+
],
|
|
492
|
+
},
|
|
493
|
+
]);
|
|
494
|
+
}
|
|
495
|
+
return [];
|
|
496
|
+
}
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
import { createClient, fallback, http } from "viem";
|
|
2
|
+
|
|
3
|
+
import { CHAIN_VIEM, CHAIN_NODE, EVM_FOLKS_CHAIN_ID } from "../constants/chain.js";
|
|
4
|
+
|
|
5
|
+
import { isEvmChainId } from "./chain.js";
|
|
6
|
+
|
|
7
|
+
import type { FolksChainId } from "../../../../common/types/chain.js";
|
|
8
|
+
import type { EvmChainId } from "../types/chain.js";
|
|
9
|
+
import type { Client } from "viem";
|
|
10
|
+
|
|
11
|
+
export function initProviders(customProvider: Partial<Record<FolksChainId, Client>>): Record<FolksChainId, Client> {
|
|
12
|
+
return Object.fromEntries(
|
|
13
|
+
Object.values(EVM_FOLKS_CHAIN_ID).map((evmFolksChainId) => {
|
|
14
|
+
return [
|
|
15
|
+
evmFolksChainId,
|
|
16
|
+
customProvider[evmFolksChainId] ??
|
|
17
|
+
createClient({
|
|
18
|
+
chain: CHAIN_VIEM[evmFolksChainId],
|
|
19
|
+
transport: fallback(CHAIN_NODE[evmFolksChainId].map((url: string) => http(url))),
|
|
20
|
+
}),
|
|
21
|
+
];
|
|
22
|
+
}),
|
|
23
|
+
) as Record<FolksChainId, Client>;
|
|
24
|
+
}
|
|
25
|
+
|
|
26
|
+
export function getChainId(provider: Client): EvmChainId {
|
|
27
|
+
const chainId = provider.chain?.id;
|
|
28
|
+
if (chainId === undefined) throw new Error("EVM provider chain id is undefined");
|
|
29
|
+
if (!isEvmChainId(chainId)) throw new Error(`EVM provider chain id is not supported: ${chainId}`);
|
|
30
|
+
|
|
31
|
+
return chainId;
|
|
32
|
+
}
|
|
@@ -0,0 +1,52 @@
|
|
|
1
|
+
import { encodeAbiParameters } from "viem";
|
|
2
|
+
|
|
3
|
+
import { CONTRACT_SLOT } from "../constants/tokens.js";
|
|
4
|
+
|
|
5
|
+
import { getAllowanceSlotHash, getBalanceOfSlotHash } from "./contract.js";
|
|
6
|
+
|
|
7
|
+
import type { FolksTokenId } from "../../../../common/types/token.js";
|
|
8
|
+
import type { EvmFolksChainId } from "../types/chain.js";
|
|
9
|
+
import type { AllowanceStateOverride, BalanceOfStateOverride } from "../types/tokens.js";
|
|
10
|
+
import type { StateOverride } from "viem";
|
|
11
|
+
|
|
12
|
+
export function getContractSlot(folksChainId: EvmFolksChainId) {
|
|
13
|
+
const contractSlot = CONTRACT_SLOT[folksChainId];
|
|
14
|
+
if (!contractSlot) {
|
|
15
|
+
throw new Error(`Contract slot not found for folksChainId: ${folksChainId}`);
|
|
16
|
+
}
|
|
17
|
+
return contractSlot;
|
|
18
|
+
}
|
|
19
|
+
|
|
20
|
+
export function getFolksTokenContractSlot(folksChainId: EvmFolksChainId, folksTokenId: FolksTokenId) {
|
|
21
|
+
const contractSlot = getContractSlot(folksChainId);
|
|
22
|
+
|
|
23
|
+
const folksTokenContractSlot = contractSlot.erc20[folksTokenId];
|
|
24
|
+
if (!folksTokenContractSlot) {
|
|
25
|
+
throw new Error(`Contract slot not found for folksTokenId: ${folksTokenId}`);
|
|
26
|
+
}
|
|
27
|
+
return folksTokenContractSlot;
|
|
28
|
+
}
|
|
29
|
+
|
|
30
|
+
export function getAllowanceStateOverride(allowanceStatesOverride: Array<AllowanceStateOverride>): StateOverride {
|
|
31
|
+
return allowanceStatesOverride.map((aso) => ({
|
|
32
|
+
address: aso.erc20Address,
|
|
33
|
+
stateDiff: aso.stateDiff.map((sd) => ({
|
|
34
|
+
slot: getAllowanceSlotHash(
|
|
35
|
+
sd.owner,
|
|
36
|
+
sd.spender,
|
|
37
|
+
getFolksTokenContractSlot(sd.folksChainId, sd.folksTokenId).allowance,
|
|
38
|
+
),
|
|
39
|
+
value: encodeAbiParameters([{ type: "uint256" }], [sd.amount]),
|
|
40
|
+
})),
|
|
41
|
+
}));
|
|
42
|
+
}
|
|
43
|
+
|
|
44
|
+
export function getBalanceOfStateOverride(balanceOfStatesOverride: Array<BalanceOfStateOverride>): StateOverride {
|
|
45
|
+
return balanceOfStatesOverride.map((bso) => ({
|
|
46
|
+
address: bso.erc20Address,
|
|
47
|
+
stateDiff: bso.stateDiff.map((sd) => ({
|
|
48
|
+
slot: getBalanceOfSlotHash(sd.owner, getFolksTokenContractSlot(sd.folksChainId, sd.folksTokenId).balanceOf),
|
|
49
|
+
value: encodeAbiParameters([{ type: "uint256" }], [sd.amount]),
|
|
50
|
+
})),
|
|
51
|
+
}));
|
|
52
|
+
}
|