dcf-xchain-thorchain-amm
v0.7.3
Published
module that exposes estimating & swappping cryptocurrency assets on thorchain
Downloads
21
Readme
@xchainjs/xchain-thorchain-amm
Modules
Thorchain AMM module
Installation
yarn add @xchainjs/xchain-thorchain-amm
Following peer dependencies have to be installed into your project. These are not included in @xchainjs/xchain-thorchain-amm
.
"dependencies": {
"@binance-chain/javascript-sdk": "^4.2.0",
"@cosmos-client/core": "0.46.1",
"@psf/bitcoincashjs-lib": "^4.0.2",
"@xchainjs/xchain-binance": "^5.6.6",
"@xchainjs/xchain-bitcoin": "^0.20.7",
"@xchainjs/xchain-bitcoincash": "^0.15.6",
"@xchainjs/xchain-client": "^0.13.5",
"@xchainjs/xchain-cosmos": "^0.20.6",
"@xchainjs/xchain-crypto": "^0.2.6",
"@xchainjs/xchain-doge": "^0.5.6",
"@xchainjs/xchain-ethereum": "^0.27.6",
"@xchainjs/xchain-evm": "^0.1.3",
"@xchainjs/xchain-avax": "^0.1.3",
"@xchainjs/xchain-litecoin": "^0.10.8",
"@xchainjs/xchain-midgard": "0.4.1",
"@xchainjs/xchain-thorchain": "^0.27.7",
"@xchainjs/xchain-thorchain-query": "^0.1.12",
"@xchainjs/xchain-thornode": "^0.1.5",
"@xchainjs/xchain-util": "^0.12.0",
"axios": "^0.25.0",
"axios-retry": "^3.2.5",
"bchaddrjs": "^0.5.2",
"bech32": "^2.0.0",
"bech32-buffer": "^0.2.0",
"bignumber.js": "^9.0.0",
"bitcoinjs-lib": "^5.2.0",
"coininfo": "^5.1.0",
"coinselect": "^3.1.12",
"ethers": "^5.6.6",
"wif": "^2.0.6"
}
For live examples
Do Swap: https://replit.com/@thorchain/doSwap-Single
Add Liquidity: https://replit.com/@thorchain/addLiquidity
Withdraw liquidity: https://replit.com/@thorchain/removeLiquidity
Add Savers & withdraw Savers: https://replit.com/@thorchain/saversTs#index.ts
Documentation
xchain-thorchain-amm
How thorchain-amm works
How to use thorchain-amm
Compiler options
tsconfig compiler options
{
"compilerOptions": {
"module":"commonjs",
"target": "es5",
"noEmitOnError": true,
"resolveJsonModule": true,
"esModuleInterop": true,
"lib": ["es6", "dom", "es2016", "es2017"]
}
}
Setting Headers for Nine Realms endpoints
If you plan on using the publically accessible endpoints provided by Nine Realms(listed below), ensure that you add a valid 'x-client-id' to all requests
- https://midgard.ninerealms.com
- https://haskoin.ninerealms.com (BTC/BCH/LTC)
- https://thornode.ninerealms.com
Setting environment variables
SNOWTRACE_API_KEY={YOUR_SNOWTRACE_API_KEY}
COVALENT_API_KEY={YOUR_COVALENT_API_KEY}
BLOCKCYPHER_API_KEY={YOUR_BLOCKCYPHER_API_KEY}
SOCHAIN_API_KEY={YOUR_SOCHAIN_API_KEY}
BSCSCAN_API_KEY={YOUR_BSCSCAN_API_KEY}
//Default config can access.
process.env.SNOWTRACE_API_KEY
process.env.COVALENT_API_KEY
process.env.BLOCKCYPHER_API_KEY
process.env.SOCHAIN_API_KEY
process.env.BSCSCAN_API_KEY
Example
import cosmosclient from '@cosmos-client/core'
import axios from 'axios'
import { register9Rheader } from '@xchainjs/xchain-util'
register9Rheader(axios)
register9Rheader(cosmosclient.config.globalAxios)
For a complete example please see this test