diff --git a/CHANGELOG.md b/CHANGELOG.md index 2bd9cb40..39720b0e 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -1,5 +1,23 @@ # Changelog +## [0.4.0](https://github.com/paritytech/asset-transfer-api/compare/v0.3.1..v0.4.0) + +### Feat + +- feat: implement transfer all ([#434](https://github.com/paritytech/asset-transfer-api/pull/434))([cf960c5](https://github.com/paritytech/asset-transfer-api/commit/811eba83a37ad9cf54d486fb392a87567cf960c5)) +- feat: implement dryRunCall option ([#433](https://github.com/paritytech/asset-transfer-api/pull/433))([19dfab3](https://github.com/paritytech/asset-transfer-api/commit/9ea6e2015df610cc1be4654ee17f2a8a319dfab3)) + +### Chore + +- chore(yarn): bump yarn to 4.5.0 ([#436](https://github.com/paritytech/asset-transfer-api/pull/436))([bcb4335](https://github.com/paritytech/asset-transfer-api/commit/bb1f4d90ffaef0d6d9146b912a4e727b2bcb4335)) +- chore(registry): update registry dep ([#435](https://github.com/paritytech/asset-transfer-api/pull/435))([26b1466](https://github.com/paritytech/asset-transfer-api/commit/ed3efdb1fc39f45df9cec212270f3a90c26b1466)) +- chore(deps): update pjs ([#432](https://github.com/paritytech/asset-transfer-api/pull/432))([b9f19ca](https://github.com/paritytech/asset-transfer-api/commit/00b245fcc8612a930dcddda223b0a484fb9f19ca)) +- chore(deps): update pjs ([#426](https://github.com/paritytech/asset-transfer-api/pull/426))([bfb6edd](https://github.com/paritytech/asset-transfer-api/commit/1947f5d7dad21428d3d74637a45052f75bfb6edd)) + +### Docs + +- docs: Update Instructions on the Repo ([#428](https://github.com/paritytech/asset-transfer-api/pull/428))([ceeac5a](https://github.com/paritytech/asset-transfer-api/commit/d5bf1319b88bbb6d03e346fb5c0ff0b62ceeac5a)) + ## [0.3.1](https://github.com/paritytech/asset-transfer-api/compare/v0.3.0..v0.3.1) ### Fix diff --git a/docs/assets/navigation.js b/docs/assets/navigation.js index 4b51b023..fd68c8df 100644 --- a/docs/assets/navigation.js +++ b/docs/assets/navigation.js @@ -1 +1 @@ -window.navigationData = "data:application/octet-stream;base64,H4sIAAAAAAAAE42Tb2vCMBCHv0tey5wy3ea7/XEw2NgQXwxERkivNqxNSu4KyvC7L9NamzS2fdf2Hp78cndd/TKCLbEZe0AEWhquMAbzkEs2YDmnxFYyHRUp4NAnrhLKUov9SBWx2XjARCLTyIBis1UPrUi5rQW07eeMxnf79X5QHSC0QjKFIEt+Gp1JhGb0ANQvfS5fVazPQqkITMzFBWfJe+7JtG/euFCCpCWC9s5bTG+c1oAx2uDwkSPM/x+bfTkS3xXRqykVjXNVZGcp2LeA0sXdE9xR0i4HbIY8fO6V7FkaOPTPD3VUVGU/xDlCtXZmgx85YXDyR5uPtg19uV0AFim16UqkTeP/GW7Cg6e0hUjPfH1/O5qMa/an03pB9KJNximsbmBd3jZZP8ObFjw93Wbpbknd1uS6zO9AiY4u6Mpil2MBG2k7smsJ5iBdvi+RBRa5rqsTYdt6v/4DUimcANsFAAA=" \ No newline at end of file +window.navigationData = "data:application/octet-stream;base64,H4sIAAAAAAAAE42TUUvDMBDHv0uei3PDTe3b1AmCoow9CDIkpNc12CQld4UN2XcXt65r0qztW0l+/O6fu+vXLyPYEovZHBFoZbnGFOy8kCxiBaeMxUyZpMwBRz5xlZHKWcR+pE5YPImYyGSeWNAs/hqgFTlHDGm764wnd/v1PqoLCKORbCloXsgPa5REaEcPQMPSF/JFp+YslJrAplxccFa8557OhuZNSy1IGh22975iduO0Bqw1FkcPHGHx/9nuy5H4rolBTalpXOhSnaWgSxVQurhbwR0l7QrAdsjD8aBkT9LCoX9+qKOivvZDnCPUa2c3+F4QBid/tPlo19BX2yVgmVOXrkK6NP6f4SY8eCpbiPTM1/e34+mkYX88rRckz8YqTmF1C+vzdsmGGV6N4PnpNSt3S5q2NtdnfgPKTHJBV132OZawkUh21xHMQfp8n0IFFrmpaxJh23q//gNSKZwA2wUAAA==" \ No newline at end of file diff --git a/docs/assets/search.js b/docs/assets/search.js index 22e6f0a0..75b6ca3d 100644 --- a/docs/assets/search.js +++ b/docs/assets/search.js @@ -1 +1 @@ -window.searchData = "data:application/octet-stream;base64,H4sIAAAAAAAAE7WcW2/buBKA/4vzGqQRRYpK3rrbFijQ3Rbd7J4FiqBQbTrVqSz5SHKabtD/fkhKsmakoa3bPrWuORfONzMkLarPqzz7XqxuPz2vvsXpZnXLLldptFOr29XLolDlXR6lxVblL/fx6nJ1yBP9xS7bHBJVvOgOuPpa7hI9ap1E+hutdLX6edno9Vh4XnMt2dc8wNTlah/lKi0p/a0b7Jq3fqxzFZWqGWj/jNZlnKUTHbo4pXCYqz3FTt+TKN7ZwcVkb5GKhf2L07iMoyT+R31UD3FR5j+muklqWtjbrSrXX98o9TbdZlP97OhY2MONWmcb9fqpzOO0iNdTneyrWcDPNimzVPM5rEs94EOe7eJC9boGMeZk42AiaBvHPkaE4rRU+TZaO9TWw083C8pn0LauGT+aj0CrGmH6opIbbL4RdrlR7NX6d/PXKb4A4cUcWn+N4nSyR1B6uRhFW/X3eveXygvYz0dFqqtijnMBH1Qk20Nq1wvavWGlMzi327otf+xV0atU+68na7NtT6/iXOGlU6WHXaPj+O1pdys3ANG28t9l6ygZoPuiGXjCQitC2/rjR1Gq3V32IcqjISY74xew/FEl0Y8xphuBBWxXf44xfpRYwPovebx5UGOsHyVmWDfkhvNGo2dbHcwaD59tdzjnzvgZlq3zY0x3BebbHgoZD59vd3hidwXG2mbXN9ITbXPXa1i/O1vx2j4cMK5Bd029yfJdVJJGqq/mqf+1Wc7U5oSl3qh5Ru2CcjzSoYUSWu0Pm2f2N1V+zTa0rfq7eQa6G/r3+5K2Rg0cZzoQwm8L4vNn8/04UxdHoVPVQE7JsUGM0/8qkyK90+kYf64ILWMdvKqn5vAze1S57gT9U/QoPwktC/uZ15rvprK96mhY2L/+GWWUc+cPKWM869biRzB1ugjRiJGFDw7Qd08fVXFI2sYJDkSVoWbEyJ06DPVGFUMNXNRjT4X06LOrQvL4ISaPeJTB4+g5Jrd49Tlj8jh6jsmnk4dZyuzT+bPrMNOb3u7hHFQgMMfwzq5zQ60eR88xWT4NNWdHjjSFSrFpEvlDgdbevt3OyBmleTZxKVMDE7g7H4cL++hH8Z+4NL+Uvj9XuaQ3lIKFHXt1uoOdc+vVgKY20KlCpRtdxC83m3ysQ1h0CWe+q/jha/ku3sWjo4NFJzpzch853pGrQZvKnho4FedmaHsX0z+HjvPtqtU01ccz+6J9nmXbP+J/lnAW6vqX3B20DJL+Dl8OB1bDN6X2L5P4cXTkoOASjpT1uHfx/w7x5i77pkYHh1axhHMR3BDfTShYSsESjuVql5X6QFSo/FG97Boxx/kzWx7S28Fal5jCVqliTmgJ+cUj+6ZjY5HAnlC6xATWh6LMdn+vd+/TKTuBvvhEp9oDoj69Z3nx4peoUK/NX48uNc9qqgGfjwMGPrY5ji9ep4fuL7I9nXj06W1oz2Pyx9G36WOUxJu36f5QTrB+0ZEf5kpH00nPbAnP8KyRX9Azq/L3rHyTHdLNFNe6CpaP2ocoSWaF7ahgQd8qnXMC19OwoHd/1M/ltfYPefYYb9QkF2k1C/pp9wbFTC8pJctnoeuZ9JhEfHX2p4w5Hv52SMq4WbzmthpS2YI+W/37RKdW+meq94nV9qaYXE1n9C3oefPj6ZzaJ3Qsnw/EjZXxeTDgzsokH/XM3+40r53WMa3sexoWjaDem6VRgrdHo6KHFfwLe4nNJldFMQNtq2FB717FRfQlURu9+ZyYeD0Ni2ad3uzbzvBuP7l4KSUL+vhnWhz2+yzXSf06fYzzLDUZPsVRp6Ylu+EhLeOd+lVvZmY1RFLNolH9lmbfU/M4X28WDgV5a2RgVB2aJnp7f6mPghv1tLp9Xj3WrfZ2xa78qxutZxurZGOu1FcT0VaynaV4X3/3l95RaF16RDXkxfXq8tP1pS+u+E1wf3/5qZGwX9h/sMM81zAPDWP6k3fJr6+Ca46GMTTM158YNcxHw7j+5FPDOBom9CdODRNoWKA/CWpYgIZJ/SmgZirRsFB/kpS2EA3TUD6F1LAbHF4T7RtqnNfhYOLt0SQwCs+yIGF4mIbnu6bsYR6eibtHgvMwEs+E3vNJnZiKZ6Lvkfg8DMYzADySoIfZeIaBrmZqJMbjGQweydHDhJjh4JEoGUbELCISJutUi+HArsmRGBGzFUNXFmbEDAhGMmKYETMgGFlfDDNiBgQjGTHMiBkQjGTEMCNmQDCddezK8z08EjNiBgQjGTHMyDcgGMnIx4x8A4KRjHzMyDcgfJKR32lqBoTvUTnvY0a+bWx0A8SMfAPCJxn5mJFvQPgkIx8z8qWzhfiYkW9A+CRNHzPyDQifrDgfM+IGhE/S5JgRNyB8kibHjDhz5hLHjLhldEPNnXfWHu7sYBwz4nb9ITOEY0bcgOBkFXPMiBsQnMwQjhlxdx1xzIgbEJxeTzEjYUBweknFjIQBwckMEZiRMCA4mSECMxLuOhKYkTAgOJlLorNFsIzIXBKYkQicGSIwI2EZkT1EYEbCgBBkhgjMSBgQgswQgRkFBoQgMyTAjAIDQpDcA8woMCAEyT3AjAIDQtC7KcwoMCAEyT3AjAIDQpA0g85Ozm7lSJoBZhQYEIJkFGBGgQERkIwCzCgwIAKSUYAZSQMiIBlJzEgaEAHJSGJG0oAISEYSM5J2W0cykpiRNCACkpHEjKQBEZCMJGYkDYiAZCQ7G2674yYZScxI2k03yUhiRtKAkCQjiRmFBoQkGYWYUWhASJJRiBmFBoQkGYWYUWhASJJRiBmFBoQkGYWYUWhASPpsUjGyZ0h9eNQn/bfVWVKfBpsLKc+rz/UBU/fg+jz8vNI7mNvnn5crYf/82R4szSdjwr5n2MqGreiNWyK2L1S2UrKVCl1S5peUNCu31aG/ldW1exQOTko3Fw46LgP562qy3kAtmb1CBwIHVOlN4gAl3dALEHrhCuCXqFDV7wXKPkAF4iCQunfS4vZacfUzQSvpAdc9rwqD3hU6NJiXuO080PQZmL1LsnlPQkdv37yHCFi2GmSN4qwmtWmuCgJPQByYK4zVi/NHEvDFeRAXoMilxz56f1rvsrS6WQx4CMDDNZPq9WjVvh4N5IG4Uxqb9MHU+bVLqH3CBKbqgxQQVfj1ltelofr5Ndt31UigJnRVUv1z1zGT0aRBFgQu++YaibOIgAeBywP75rzW0m1FHBSgS7Sfb8BlFtahY/Wfrp7U/h8D+fENCcARYHQqqF4EIcVhMboVVI8feggkSHvpqp+4ej4QNc8HgDgwHrpysBGvHhoCejeAnqsD1cJkHgegaqSr6GoFcXWJA1gHC1jgqrlaeGceJib1w8/ePALYzNwErKZ9ffUASAMCwRkCuvU0vwhDDSCO0hVHcy0wqq4FghIAksIlmVTvPIP2ASrHc0XOSsG6xQsICL7vypvmyj3wF6xd3FW0u+bdNmAOzNN39Yld/cQ4zdKDfWJcrXv9bQjou9LlRJrpjmMVJPueBgkCGLoWG70DiuHjTCAOoiBdPad5EwU0ChBz7gpC8yoX2WlAp/JdE68SnNy+gV4hXcz3UR6V2d6+FwsyDvBjLtcr0bx6gxmwB9FirmBXskX95AYIw12Bq8OYu/nf49KsMd01msNFxj3no3yfGofLg6s92KvRhb0aDSQBb+HClattGeMNIgf5LVztrMkPEjQwLF39oVHQO5KAiPlDhPG+HKwIvqs0bIqU2Zf6FWhAG9hmbttWupuiDHBi7mhbWSLPQG0wd8zNJdW8uqTaO1wkx1uqYI0DagNX+iG13d0WqRWEKXBVVF49wNWLQELliARrZuiasPk/UuglzwN16blcqF9RiewrKiC/QY4IVzMx/5FN9+QEmpDnCmYjp+e8P94+A6UBskQ6bdv0oBLUA5XFnC7U4r0mCubtuRb7RrjXRj0AzHNVViPdT3APNBXP1cZKe3HPFTqQddKF/Hhkzx+K7pmdg2Lgrvk3ChL7qkJZvaoAUh8sJsIVBfPuHjALUpW7mkr5lNdvzoJeBiLuO0PW7YAemKXnKqxDdWVh3VxZ6POS8IcaVzs7tPdJFLxPAtSAnAtd62f1fk5Svb0FAgfmL1zAdXsgjwYMGGYu2HRv8UGd8+ZHMRLc/eVqH+seGad68Kf7nz//DwjH0UXwUAAA"; \ No newline at end of file +window.searchData = "data:application/octet-stream;base64,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"; \ No newline at end of file diff --git a/docs/classes/AssetTransferApi.AssetTransferApi.html b/docs/classes/AssetTransferApi.AssetTransferApi.html index f3797ef5..0a55dd6a 100644 --- a/docs/classes/AssetTransferApi.AssetTransferApi.html +++ b/docs/classes/AssetTransferApi.AssetTransferApi.html @@ -1,10 +1,11 @@ -
Decodes the hex of an extrinsic into a string readable format.
const decodedExt = assetsApi.decodeExtrinsic(tx, 'call');
console.log(JSON.parse(decodedExt));
the hex of an extrinsic tx
The format the tx is in
-Dry Run a call to determine its execution result
+const executionResult = await assetApi.dryRunCall(sendersAddr, tx, 'call');
console.log(executionResult.toJSON());
+
+address of the account sending the transaction
+a payload, call or submittable
+The format the tx is in
+Fetch estimated fee information for an extrinsic
const feeInfo = assetApi.fetchFeeInfo(tx, 'call');
console.log(feeInfo.toJSON());
a payload, call or submittable
The format the tx is in
-Errors that may be returned by the API.
-Errors that may be returned by the API.
+Not able to find the asset.
-The following option is disabled given the inputs.
-An issue has happened internally.
-The inputted address is invalid.
-The inputted asset is incorrect or invalid, and does not exist given the surrounding specs. +
The following option is disabled given the inputs.
+An issue has happened internally.
+The inputted address is invalid.
+The inputted asset is incorrect or invalid, and does not exist given the surrounding specs.
This exlcudes MultiLocation assets which are handled using InvalidMultiLocationAsset
.
The direction in which these assets are going to be sent is incorrect.
-An input or lack of input to any public facing function by the user is incorrect, and or invalid. +
The direction in which these assets are going to be sent is incorrect.
+An input or lack of input to any public facing function by the user is incorrect, and or invalid. This may include using options incorrectly.
-The inputted multilocation is incorrect.
-The following pallet does not support the method to be used.
-The xcm version is invalid.
-Multiple assets have been found for a single token symbol.
-The provided paysWithFeeOrigin asset has no liquidity pool.
-Not Implemented yet.
-The following pallet is not found.
-Not able to find the pertinent registry to gather certain information. This can refer to xcAssets.
-Did not find the correct call in the current runtime.
-The specName was not provided when injecting a new chain in the registry.
-The tokens were not provided when injecting a new chain in the registry.
-Did not find a known consensus system for bridge transaction.
-The provided JS environment is not supported, and the api will not run.
-The inputted multilocation is incorrect.
+The following pallet does not support the method to be used.
+The xcm version is invalid.
+Multiple assets have been found for a single token symbol.
+The provided paysWithFeeOrigin asset has no liquidity pool.
+Not Implemented yet.
+The following pallet is not found.
+Not able to find the pertinent registry to gather certain information. This can refer to xcAssets.
+Did not find the correct call in the current runtime.
+The specName was not provided when injecting a new chain in the registry.
+The tokens were not provided when injecting a new chain in the registry.
+Did not find a known consensus system for bridge transaction.
+The provided JS environment is not supported, and the api will not run.
+Represents all possible tx directions
-Represents all possible tx directions
+Local tx
-Parachain to Parachain.
-Parachain to Relay chain.
-Parachain to System parachain.
-Relay chain to an external GlobalConsensus
chain.
Relay chain to Parachain.
-Relay to System Parachain.
-System parachain to an external GlobalConsensus
chain.
System parachain to Parachain.
-System parachain to Relay chain.
-System parachain to System parachain chain.
-Parachain to Parachain.
+Parachain to Relay chain.
+Parachain to System parachain.
+Relay chain to an external GlobalConsensus
chain.
Relay chain to Parachain.
+Relay to System Parachain.
+System parachain to an external GlobalConsensus
chain.
System parachain to Parachain.
+System parachain to Relay chain.
+System parachain to System parachain chain.
+Construct a Polkadot-js ApiPromise, and retrieve the specName of the chain.
+Construct a Polkadot-js ApiPromise, and retrieve the specName of the chain.
import { constructApiPromise } from '@substrate/asset-transfer-api';
const { api, specName, safeXcmVersion } = constructApiPromise('wss://some_ws_url');
WebSocket Url to connect to.
ApiOptions
-// The AssetTransferApi exposes one method as of now called: `createTransferTransaction`
/**
* Create an XCM transaction to transfer Assets, or native tokens from one
* chain to another.
*
* @param destChainId ID of the destination (para) chain (‘0’ for Relaychain)
* @param destAddr Address of destination account
* @param assetIds Array of assetId's to be transferred
* @param amounts Array of the amounts of each token to transfer
* @param opts Options
*/
AssetTransferApi.createTransferTransaction(
destChainId: string,
destAddr: string,
assetIds: string[],
amounts: string[],
opts?: TransferArgsOpts<T>
)
-// AssetTransferApiOpts are the options for the `AssetTransferApi`
type AssetTransferApiOpts = {
/**
* The injectedRegistry allows you to add custom values to the predefined initialized registry.
* If you would like to see the registry you may visit https://github.com/paritytech/asset-transfer-api-registry/blob/main/registry.json
* When adding a new chain, the `specName` and `tokens` fields are mandatory.
*
* An example input of the registry would be:
* {
* polkadot: {
* '9876': {
* tokens: ['TST'],
* assetsInfo,
* specName: 'testing',
* }
* }
* }
*
* NOTE: It supports adding info for `polkadot`, `kusama`, `westend` and `rococo`.
*/
injectedRegistry?: RequireAtLeastOne<ChainInfoRegistry>;
/**
* The overrideRegistry option allows you to modify chain data already present in the registry,
* either overriding fields' values or adding new information. If the chain of which data is
* being overriden is not present in the registry, it will be treated as if it were
* and injectedRegistry and added following the same logic.
*
* If the chain is present in the registry, it will override only the fields
* present in the passed overrideRegistry, leaving the remaining as is.
*
* An example input for overrideRegistry would be:
* {
* westend: {
* '0': {
* tokens: ['WER'],
* }
* }
* }
*
* This would override the existing native token for the Westend Relay Chain
* to WER instead of WND.
*/
overrideRegistry?: RequireAtLeastOne<ChainInfoRegistry<InjectedChainInfoKeys>>;
/**
* RegistryTypes is a string and can either be 'CDN' or 'NPM'.
*
* CDN - The registry will be initialized with the up to date version given the CDN
* NPM - The registry will be initialized with the NPM version which is updated less frequently.
*/
registryType?: RegistryTypes;
};
+// AssetTransferApiOpts are the options for the `AssetTransferApi`
type AssetTransferApiOpts = {
/**
* The injectedRegistry allows you to add custom values to the predefined initialized registry.
* If you would like to see the registry you may visit https://github.com/paritytech/asset-transfer-api-registry/blob/main/docs/registry.json
* When adding a new chain, the `specName` and `tokens` fields are mandatory.
*
* An example input of the registry would be:
* {
* polkadot: {
* '9876': {
* tokens: ['TST'],
* assetsInfo,
* specName: 'testing',
* }
* }
* }
*
* NOTE: It supports adding info for `polkadot`, `kusama`, `westend` and `rococo`.
*/
injectedRegistry?: RequireAtLeastOne<ChainInfoRegistry>;
/**
* The overrideRegistry option allows you to modify chain data already present in the registry,
* either overriding fields' values or adding new information. If the chain of which data is
* being overriden is not present in the registry, it will be treated as if it were
* and injectedRegistry and added following the same logic.
*
* If the chain is present in the registry, it will override only the fields
* present in the passed overrideRegistry, leaving the remaining as is.
*
* An example input for overrideRegistry would be:
* {
* westend: {
* '0': {
* tokens: ['WER'],
* }
* }
* }
*
* This would override the existing native token for the Westend Relay Chain
* to WER instead of WND.
*/
overrideRegistry?: RequireAtLeastOne<ChainInfoRegistry<InjectedChainInfoKeys>>;
/**
* RegistryTypes is a string and can either be 'CDN' or 'NPM'.
*
* CDN - The registry will be initialized with the up to date version given the CDN
* NPM - The registry will be initialized with the NPM version which is updated less frequently.
*/
registryType?: RegistryTypes;
};
-// The TransferArgsOpts are options that give the possibility of adding certain customization to the transaction.
interface TransferArgsOpts<T extends Format> {
/**
* Option that specifies the format in which to return a transaction.
* It can either be a `payload`, `call`, or `submittable`.
*
* Note: A `submittable` will return a `SubmittableExtrinsic` polkadot-js type, whereas
* a `payload` will return a `GenericExtrinsicPayload` polkadot-js type and a `call` will return a hex. By default a `payload` will be returned if nothing is inputted.
*/
format?: T;
/**
* AssetId to pay fees on the current common good parachain.
* Polkadot AssetHub: default DOT
* Kusama AssetHub: default KSM
*/
paysWithFeeOrigin?: string;
/**
* AssetId to pay fees on the destination parachain.
*/
paysWithFeeDest?: string;
/**
* Option for applying a custom weightLimit.
* If not inputted it will default to `Unlimited`.
*/
weightLimit?: { refTime?: string, proofSize?: string };
/**
* Set the xcmVersion for message construction. If this is not present a supported version
* will be queried, and if there is no supported version a safe version will be queried.
*/
xcmVersion?: number;
/**
* For creating local asset transfers, this will allow for a `transferKeepAlive` as oppose
* to a `transfer`.
*/
keepAlive?: boolean;
/**
* Boolean to declare if this will transfer liquidity tokens.
* Default is false.
*/
transferLiquidToken?: boolean;
/**
* The XCM `TransferType` used to transfer assets.
* Provided to construct `transferAssetsUsingTypeAndThen` transactions.
*/
assetTransferType?: string;
/**
* The RemoteReserve location for an XCM transfer.
* Should be provided when specifying an `assetTransferType` of `RemoteReserve`.
*/
remoteReserveAssetTransferTypeLocation?: string;
/**
* The XCM `TransferType` used to pay fees for an XCM transfer.
* Provided to construct `transferAssetsUsingTypeAndThen` transactions.
*/
feesTransferType?: string;
/**
* The RemoteReserve location for an XCM transfers' fees.
* Should be provided when specfying a `feesTransferType` of `RemoteReserve`.
*/
remoteReserveFeesTransferTypeLocation?: string;
/**
* Optional custom XCM message to be executed on destination chain.
* Should be provided if a custom xcm message is needed after transfering assets.
* Defaults to `Xcm(vec![DepositAsset { assets: Wild(AllCounted(assets.len())), beneficiary }])`
*/
customXcmOnDest?: string;
}
+// The TransferArgsOpts are options that give the possibility of adding certain customization to the transaction.
interface TransferArgsOpts<T extends Format> {
/**
* Option that specifies the format in which to return a transaction.
* It can either be a `payload`, `call`, or `submittable`.
*
* Note: A `submittable` will return a `SubmittableExtrinsic` polkadot-js type, whereas
* a `payload` will return a `GenericExtrinsicPayload` polkadot-js type and a `call` will return a hex. By default a `payload` will be returned if nothing is inputted.
*/
format?: T;
/**
* AssetId to pay fees on the current common good parachain.
* Polkadot AssetHub: default DOT
* Kusama AssetHub: default KSM
*/
paysWithFeeOrigin?: string;
/**
* AssetId to pay fees on the destination parachain.
*/
paysWithFeeDest?: string;
/**
* Option for applying a custom weightLimit.
* If not inputted it will default to `Unlimited`.
*/
weightLimit?: { refTime?: string, proofSize?: string };
/**
* Set the xcmVersion for message construction. If this is not present a supported version
* will be queried, and if there is no supported version a safe version will be queried.
*/
xcmVersion?: number;
/**
* For creating local asset transfers, this will allow for a `transferKeepAlive` as oppose
* to a `transfer`.
*/
keepAlive?: boolean;
/**
* For creating local asset transfers, this will allow for a `transferAll` as opposed
* to a `transfer`.
*/
transferAll?: boolean;
/**
* Boolean to declare if this will transfer liquidity tokens.
* Default is false.
*/
transferLiquidToken?: boolean;
/**
* The XCM `TransferType` used to transfer assets.
* Provided to construct `transferAssetsUsingTypeAndThen` transactions.
*/
assetTransferType?: string;
/**
* The RemoteReserve location for an XCM transfer.
* Should be provided when specifying an `assetTransferType` of `RemoteReserve`.
*/
remoteReserveAssetTransferTypeLocation?: string;
/**
* The XCM `TransferType` used to pay fees for an XCM transfer.
* Provided to construct `transferAssetsUsingTypeAndThen` transactions.
*/
feesTransferType?: string;
/**
* The RemoteReserve location for an XCM transfers' fees.
* Should be provided when specfying a `feesTransferType` of `RemoteReserve`.
*/
remoteReserveFeesTransferTypeLocation?: string;
/**
* Optional custom XCM message to be executed on destination chain.
* Should be provided if a custom xcm message is needed after transfering assets.
* Defaults to `Xcm(vec![DepositAsset { assets: Wild(AllCounted(assets.len())), beneficiary }])`
*/
customXcmOnDest?: string;
/**
* Optionally allows for dry running the constructed tx in order get the estimated fees and execution result.
*/
dryRunCall?: boolean;
/**
* Optional assetId that will be used to pay for fees. Used with the `dryRunCall` option to determine fees in the specified asset.
*/
xcmFeeAsset?: string;
}
Teleport and Reserve Transfer via polkadotXcm pallet
The AssetTransferApi.createTransferTransaction
is able to infer what kind of transaction is necessary given the inputs. When sending cross chain transfers, the api does a lot of validation to ensure the inputs are valid, and the assets either exist or don't. This process is done through a registry which is maintained in a separate repo here. If the asset is not in the registry, it will then lookup if that asset exists on-chain and cache it if necessary. On-chain verification is not always possible in respect to the direction the asset is being sent and what the destination chain is since we only maintain one api connection. Therefore, if you would like to inject information into the registry, you can using the injectedRegistry
option for the AssetTransferApi
.
Transferring assets via xTokens pallet
If the transfer is being sent from a parachain that utilizes the xTokens
pallet, the API will detect that and construct the transaction that is necessary. It will construct one of three calls: transferMultiasset
, transferMultiassets
, or transferMultiassetWithFee
. This is only applicable when the intended transfer direction starts from a parachain. The xTokens
pallet can be found here.
@@ -153,4 +153,4 @@ Asset API used for common good parachains
Running Zombienet
From the root directory run ./<zombienet_binary_name> -p native spawn ./zombienet/<network_file>.toml | tee zombienet.log
Create an asset
From the root directory run yarn start:zombienet-post-script
. You can run this right after running your zombienet network.
E2E Testing
You can access the E2E tests and its documentation here.
-
Return value for constructApiPromise
Return value for constructApiPromise
Polkadot-js ApiPromise
-Chain name of the chain which the api is connected to.
-SafeXcmVersion for the chain which the api is connected too.
-SpecName of the chain which the api is connected to.
-Chain name of the chain which the api is connected to.
+SafeXcmVersion for the chain which the api is connected too.
+SpecName of the chain which the api is connected to.
+The TransferArgsOpts are the options passed into createTransferTransaction.
-The TransferArgsOpts are the options passed into createTransferTransaction.
+Optional
assetThe XCM TransferType
used to transfer assets.
Provided to construct transferAssetsUsingTypeAndThen
transactions.
Optional
customOptional custom XCM message to be executed on destination chain. +
Optional
customOptional custom XCM message to be executed on destination chain.
Should be provided if a custom xcm message is needed after transfering assets.
Defaults to Xcm(vec![DepositAsset { assets: Wild(AllCounted(assets.len())), beneficiary }])
Optional
feesThe XCM TransferType
used to pay fees for an XCM transfer.
+
Optional
dryOptionally allows for dry running the constructed tx in order get the estimated fees and execution result.
+Optional
feesThe XCM TransferType
used to pay fees for an XCM transfer.
Provided to construct transferAssetsUsingTypeAndThen
transactions.
Optional
formatOption that specifies the format in which to return a transaction. +
Optional
formatOption that specifies the format in which to return a transaction.
It can either be a payload
, call
, or submittable
.
Note: A submittable
will return a SubmittableExtrinsic
polkadot-js type, whereas
a payload
or call
will return a hex.
Optional
keepFor creating local asset transfers, this will allow for a transferKeepAlive
as oppose
+
Optional
keepFor creating local asset transfers, this will allow for a transferKeepAlive
as opposed
to a transfer
.
Optional
paysAssetId to pay fee's on the destination parachain.
-Optional
paysAssetId to pay fee's on the current common good parachain. +
Optional
paysAssetId to pay fee's on the destination parachain.
+Optional
paysAssetId to pay fee's on the current common good parachain. Polkadot AssetHub: default DOT Kusama AssetHub: default KSM
-Optional
remoteThe RemoteReserve location for an XCM transfer. +
Optional
remoteThe RemoteReserve location for an XCM transfer.
Should be provided when specifying an assetTransferType
of RemoteReserve
.
Optional
remoteThe RemoteReserve location for an XCM transfers' fees. +
Optional
remoteThe RemoteReserve location for an XCM transfers' fees.
Should be provided when specfying a feesTransferType
of RemoteReserve.
Optional
sendersThe SS58 Address the tx will be sent from. This is specifically used for the format payload
.
+
Optional
sendersThe SS58 Address the tx will be sent from. This is specifically used for the format payload
.
It is necessary because the payload
will need information such as the nonce
.
Optional
transferBoolean to declare if this will transfer liquidity tokens. +
Optional
transferFor creating local asset transfers, this will allow for a transferAll
call as opposed
+to a transfer
call.
Optional
transferBoolean to declare if this will transfer liquidity tokens. Default is false.
-Optional
weightOption for applying a custom weightLimit
.
+
Optional
weightOption for applying a custom weightLimit
.
If not inputted it will default to Unlimited
.
Optional
proofProvided when creating limited txs, represents the amount of storage in bytes that can be used by the tx
Optional
refProvided when creating limited txs, represents the allowed amount of computation time the tx can use
-Optional
xcmSet the xcmVersion for message construction. If this is not present a supported version +
Optional
xcmOptional assetId that will be used to pay for fees. Used with the dryRunCall
option to determine fees in the specified asset.
Optional
xcmSet the xcmVersion for message construction. If this is not present a supported version will be queried, and if there is no supported version a safe version will be queried.
-The TxResult is the result of constructing a transaction. +
The TxResult is the result of constructing a transaction. T extends Format in the context of the options passed in for the Format the user expects.
-The destination specName of the transaction
-The direction of the cross chain transfer.
-The format type the tx is ouputted in.
-The method used in the transaction.
-The origin specName of the transaction
-The constructed transaction.
-The xcm version that was used to construct the tx.
-The direction of the cross chain transfer.
+The format type the tx is ouputted in.
+Optional
forwardedList of forwarded xcms and the weights needed to execute them.
+Optional
localWeight needed to execute the local segment of a provided XCM.
+The method used in the transaction.
+The origin specName of the transaction
+The constructed transaction.
+Optional
xcmThe result of xcm execution.
+The xcm version that was used to construct the tx.
+Options that are appplied at initialization of the AssetTransferApi
.
Options that are appplied at initialization of the AssetTransferApi
.
Optional
chainChain name of the chain which the api is connected to.
Optional
injectedOption to inject chain information into the registry.
Optional
overrideOption to override the registry with the supplied chain information.
Optional
registryWhether or not to apply the registry from the npm package asset-transfer-api-registry
,
or the hosted CDN which updates frequently.
The Format types possible for a constructed transaction.
-The Format types possible for a constructed transaction.
+AssetTransferApi supports three formats to be returned:
+AssetTransferApi supports three formats to be returned:
ExtrinsicPayload
as a hex.Call
as a hex.SubmittableExtrinsic
.The types of local transactions the api can construct.
-The types of local transactions the api can construct.
+The Methods are the collections of methods the API will use to construct a transaction.
-The Methods are the collections of methods the API will use to construct a transaction.
+Types that the registry can be initialized as.
+Types that the registry can be initialized as.
CDN - The registry will be initialized with the up to date version given the CDN NPM - The registry will be initialized with the NPM version which is updated less frequently.
-The direction of the cross chain transfer. This only concerns XCM transactions.
-The direction of the cross chain transfer. This only concerns XCM transactions.
+
Holds open an api connection to a specified chain within the ApiPromise in order to help +
- Preparing search index...
- The search index is not available
@substrate/asset-transfer-api - v0.4.0Class AssetTransferApi
Holds open an api connection to a specified chain within the ApiPromise in order to help construct transactions for assets and estimating fees.
-Index
Methods
Index
Methods
Methods
claim Assets
Create a local claimAssets XCM transaction to retrieve trapped assets. This can be either locally on a systems parachain, on the relay chain or any chain that supports the pallet-xcm
@@ -14,7 +15,7 @@claimAssets
runtime call.amounts: string[]
Array of the amounts of each trapped asset to be claimed
beneficiary: string
Address of the account to receive the trapped assets
opts: TransferArgsOpts<T>
Options
-Returns Promise<TxResult<T>>
create Transfer Transaction
Create an asset transfer transaction. This can be either locally on a systems parachain or relay chain, +
Returns Promise<TxResult<T>>
create Transfer Transaction
Create an asset transfer transaction. This can be either locally on a systems parachain or relay chain, or between chains using xcm.
@@ -23,17 +24,23 @@assetIds: string[]
Array of assetId's to be transferred
amounts: string[]
Array of the amounts of each token to transfer
opts: TransferArgsOpts<T> = {}
Options
-Returns Promise<TxResult<T>>
decode Extrinsic
Decodes the hex of an extrinsic into a string readable format.
+Returns Promise<TxResult<T>>