diff --git a/.changeset/fast-months-sip.md b/.changeset/fast-months-sip.md new file mode 100644 index 000000000..37d377c0a --- /dev/null +++ b/.changeset/fast-months-sip.md @@ -0,0 +1,5 @@ +--- +'@xchainjs/xchain-aggregator': patch +--- + +Add `streamingQuantity` and `streamingInterval` to allow streaming swaps diff --git a/.changeset/rotten-toes-doubt.md b/.changeset/rotten-toes-doubt.md new file mode 100644 index 000000000..45a146a8a --- /dev/null +++ b/.changeset/rotten-toes-doubt.md @@ -0,0 +1,5 @@ +--- +'@xchainjs/xchain-cosmos': patch +--- + +Mintscan as explorer. diff --git a/examples/aggregator/.codesandbox/tasks.json b/examples/aggregator/.codesandbox/tasks.json new file mode 100644 index 000000000..fff1c37f8 --- /dev/null +++ b/examples/aggregator/.codesandbox/tasks.json @@ -0,0 +1,9 @@ +{ + // These tasks will run in order when initializing your CodeSandbox project. + "setupTasks": [ + { + "name": "Install Dependencies", + "command": "yarn install" + } + ] +} \ No newline at end of file diff --git a/examples/aggregator/.devcontainer/devcontainer.json b/examples/aggregator/.devcontainer/devcontainer.json new file mode 100644 index 000000000..9cef189a7 --- /dev/null +++ b/examples/aggregator/.devcontainer/devcontainer.json @@ -0,0 +1,4 @@ +{ + "name": "Devcontainer", + "image": "ghcr.io/codesandbox/devcontainers/typescript-node:latest" +} \ No newline at end of file diff --git a/examples/aggregator/CHANGELOG.md b/examples/aggregator/CHANGELOG.md new file mode 100644 index 000000000..9764cccd2 --- /dev/null +++ b/examples/aggregator/CHANGELOG.md @@ -0,0 +1 @@ +# xchainjs-aggregator diff --git a/examples/aggregator/README.md b/examples/aggregator/README.md new file mode 100644 index 000000000..bce644523 --- /dev/null +++ b/examples/aggregator/README.md @@ -0,0 +1,32 @@ +# Aggregator + +Aggregator examples to show different use cases + +## Examples + +### Swaps + +#### Estimate swap + +Check out how you should estimate a swap in this [example](https://github.com/xchainjs/xchainjs-lib/blob/master/examples/aggregator/swap-do.ts) or run it as + +```sh +yarn estimateSwap fromAsset toAsset amount decimals +``` + +#### Do swap + +Check out how you should do a swap between BTC and ETH in this [example](https://github.com/xchainjs/xchainjs-lib/blob/master/examples/aggregator/swap-estimate.ts) or run it as + + +```sh +yarn doSwap phrase amount +``` + +#### Get swap history + +Check out how you should get the swap history of several addresses in this [example](https://github.com/xchainjs/xchainjs-lib/blob/master/examples/aggregator/swap-history.ts) or run it as + +```sh +yarn swapHistory chain1:address1 chain2:address2 +``` diff --git a/examples/aggregator/package.json b/examples/aggregator/package.json new file mode 100644 index 000000000..3f856a7f0 --- /dev/null +++ b/examples/aggregator/package.json @@ -0,0 +1,26 @@ +{ + "name": "xchainjs-aggregator", + "private": true, + "version": "0.0.1", + "scripts": { + "swapHistory": "npx ts-node swap-history.ts", + "estimateSwap": "npx ts-node swap-estimate.ts", + "doSwap": "npx ts-node swap-do.ts", + "build": "tsc --noEmit" + }, + "description": "Examples using the Aggregator", + "main": "index.js", + "license": "MIT", + "dependencies": { + "@xchainjs/xchain-aggregator": "workspace:*", + "@xchainjs/xchain-bitcoin": "workspace:*", + "@xchainjs/xchain-ethereum": "workspace:*", + "@xchainjs/xchain-util": "workspace:*", + "@xchainjs/xchain-wallet": "workspace:*" + }, + "devDependencies": { + "@types/node": "20.11.28", + "ts-node": "10.9.2", + "typescript": "^5.0.4" + } +} diff --git a/examples/aggregator/swap-do.ts b/examples/aggregator/swap-do.ts new file mode 100644 index 000000000..84cc44f77 --- /dev/null +++ b/examples/aggregator/swap-do.ts @@ -0,0 +1,33 @@ +import { Aggregator } from '@xchainjs/xchain-aggregator' +import { AssetBTC, BTCChain, Client as BTCClient, defaultBTCParams } from '@xchainjs/xchain-bitcoin' +import { AssetETH, Client as ETHClient, ETHChain, defaultEthParams } from '@xchainjs/xchain-ethereum' +import { CryptoAmount, assetAmount, assetToBase } from '@xchainjs/xchain-util' +import { Wallet } from '@xchainjs/xchain-wallet' + +const main = async () => { + const phrase = process.argv[2] || '' + const amount = assetToBase(assetAmount(process.argv[4], Number(process.argv[5] || 8))) + + const wallet = new Wallet({ + BTCChain: new BTCClient({ ...defaultBTCParams, phrase }), + ETHChain: new ETHClient({ ...defaultEthParams, phrase }), + }) + + const aggregator = new Aggregator({ + wallet, + }) + + const txSubmited = await aggregator.doSwap({ + fromAsset: AssetBTC, + destinationAsset: AssetETH, + fromAddress: await wallet.getAddress(BTCChain), + destinationAddress: await wallet.getAddress(ETHChain), + amount: new CryptoAmount(amount, AssetBTC), + }) + + console.log(txSubmited) +} + +main() + .then(() => process.exit(0)) + .catch((err) => console.error(err)) diff --git a/examples/aggregator/swap-estimate.ts b/examples/aggregator/swap-estimate.ts new file mode 100644 index 000000000..b66eb0ebf --- /dev/null +++ b/examples/aggregator/swap-estimate.ts @@ -0,0 +1,28 @@ +import { Aggregator } from '@xchainjs/xchain-aggregator' +import { CryptoAmount, assetAmount, assetFromStringEx, assetToBase } from '@xchainjs/xchain-util' + +const main = async () => { + const fromAsset = assetFromStringEx(process.argv[2] || '') + const toAsset = assetFromStringEx(process.argv[3] || '') + const amount = assetToBase(assetAmount(process.argv[4], Number(process.argv[5] || 8))) + + const aggregator = new Aggregator() + + const quote = await aggregator.estimateSwap({ + fromAsset, + destinationAsset: toAsset, + amount: new CryptoAmount(amount, fromAsset), + }) + + console.log({ + canSwap: quote.canSwap, + protocol: quote.protocol, + expectedAmount: quote.expectedAmount.assetAmount.amount().toString(), + memo: quote.memo, + toAddress: quote.toAddress, + }) +} + +main() + .then(() => process.exit(0)) + .catch((err) => console.error(err)) diff --git a/examples/aggregator/swap-history.ts b/examples/aggregator/swap-history.ts new file mode 100644 index 000000000..3d4ee59fb --- /dev/null +++ b/examples/aggregator/swap-history.ts @@ -0,0 +1,39 @@ +import { Aggregator } from '@xchainjs/xchain-aggregator' +import { assetToString } from '@xchainjs/xchain-util' + +const main = async () => { + const chainAddress1 = process.argv[2] || '' + const chainAddress2 = process.argv[3] || '' + + const aggregator = new Aggregator() + + const swaps = await aggregator.getSwapHistory({ + chainAddresses: [ + { + chain: chainAddress1.split(':')[0], + address: chainAddress1.split(':')[1], + }, + { + chain: chainAddress2.split(':')[0], + address: chainAddress2.split(':')[1], + }, + ], + }) + + console.table( + swaps.swaps.map((swap) => { + return { + protocol: swap.protocol, + fromAsset: assetToString(swap.inboundTx.amount.asset), + toAsset: swap.outboundTx ? assetToString(swap.outboundTx.amount.asset) : undefined, + hash: swap.inboundTx.hash, + fromAmount: swap.inboundTx.amount.assetAmount.amount().toString(), + toAmount: swap.outboundTx ? swap.outboundTx.amount.assetAmount.amount().toString() : undefined, + } + }), + ) +} + +main() + .then(() => process.exit(0)) + .catch((err) => console.error(err)) diff --git a/examples/aggregator/tsconfig.json b/examples/aggregator/tsconfig.json new file mode 100644 index 000000000..7b9e0e966 --- /dev/null +++ b/examples/aggregator/tsconfig.json @@ -0,0 +1,15 @@ +{ + "compilerOptions": { + "module": "commonjs", + "target": "es5", + "noEmitOnError": true, + "resolveJsonModule": true, + "esModuleInterop": true, + "lib": [ + "es6", + "dom", + "es2016", + "es2017" + ] + } +} \ No newline at end of file diff --git a/examples/solana/README.md b/examples/solana/README.md index 194129678..02a160c9a 100644 --- a/examples/solana/README.md +++ b/examples/solana/README.md @@ -1,6 +1,6 @@ # Solana -Solana examples to show different use cases using the its client +Solana examples to show different use cases using its client ## Examples @@ -36,7 +36,7 @@ yarn address phrase index #### Prepare transaction -Check out how you should prepare a transaction to be signed in this [example](https://github.com/xchainjs/xchainjs-lib/blob/master/examples/solana/address.ts) or run it as +Check out how you should prepare a transaction to be signed in this [example](https://github.com/xchainjs/xchainjs-lib/blob/master/examples/solana/transaction-prepare.ts) or run it as ```sh yarn prepareTx sender recipient asset assetDecimals amount @@ -44,7 +44,7 @@ yarn prepareTx sender recipient asset assetDecimals amount #### Make transaction -Check out how you should make a Solana native asset transaction in this [example](https://github.com/xchainjs/xchainjs-lib/blob/master/examples/solana/address.ts) or run it as +Check out how you should make a Solana native asset transaction in this [example](https://github.com/xchainjs/xchainjs-lib/blob/master/examples/solana/transaction-transfer.ts) or run it as ```sh yarn transfer phrase recipient amount @@ -52,7 +52,7 @@ yarn transfer phrase recipient amount #### Make token transaction -Check out how you should make a Solana token transaction in this [example](https://github.com/xchainjs/xchainjs-lib/blob/master/examples/solana/address.ts) or run it as +Check out how you should make a Solana token transaction in this [example](https://github.com/xchainjs/xchainjs-lib/blob/master/examples/solana/transaction-transfer-token.ts) or run it as ```sh yarn transferToken phrase recipient asset assetDecimals amount diff --git a/examples/thorchain/.codesandbox/tasks.json b/examples/thorchain/.codesandbox/tasks.json new file mode 100644 index 000000000..fff1c37f8 --- /dev/null +++ b/examples/thorchain/.codesandbox/tasks.json @@ -0,0 +1,9 @@ +{ + // These tasks will run in order when initializing your CodeSandbox project. + "setupTasks": [ + { + "name": "Install Dependencies", + "command": "yarn install" + } + ] +} \ No newline at end of file diff --git a/examples/thorchain/.devcontainer/devcontainer.json b/examples/thorchain/.devcontainer/devcontainer.json new file mode 100644 index 000000000..9cef189a7 --- /dev/null +++ b/examples/thorchain/.devcontainer/devcontainer.json @@ -0,0 +1,4 @@ +{ + "name": "Devcontainer", + "image": "ghcr.io/codesandbox/devcontainers/typescript-node:latest" +} \ No newline at end of file diff --git a/examples/thorchain/CHANGELOG.md b/examples/thorchain/CHANGELOG.md new file mode 100644 index 000000000..2b30ca024 --- /dev/null +++ b/examples/thorchain/CHANGELOG.md @@ -0,0 +1,2 @@ +# xchainjs-thorchain + diff --git a/examples/thorchain/README.md b/examples/thorchain/README.md new file mode 100644 index 000000000..d3f724962 --- /dev/null +++ b/examples/thorchain/README.md @@ -0,0 +1,15 @@ +# Thorchain + +Thorchain examples to show different use cases using its client + +## Examples + +### Transactions + +#### Make transaction + +Check out how you should make a Thorchain native asset transaction in this [example](https://github.com/xchainjs/xchainjs-lib/blob/master/examples/thorchain/transaction-transfer.ts) or run it as + +```sh +yarn transfer phrase recipient amount +``` \ No newline at end of file diff --git a/examples/thorchain/package.json b/examples/thorchain/package.json new file mode 100644 index 000000000..3177a1fe4 --- /dev/null +++ b/examples/thorchain/package.json @@ -0,0 +1,21 @@ +{ + "name": "xchainjs-thorchain", + "private": true, + "version": "0.0.1", + "scripts": { + "transfer": "npx ts-node transaction-transfer.ts", + "build": "tsc --noEmit" + }, + "description": "Examples using Thorchain client", + "main": "index.js", + "license": "MIT", + "dependencies": { + "@xchainjs/xchain-thorchain": "workspace:*", + "@xchainjs/xchain-util": "workspace:*" + }, + "devDependencies": { + "@types/node": "20.11.28", + "ts-node": "10.9.2", + "typescript": "^5.0.4" + } +} diff --git a/examples/thorchain/transaction-transfer.ts b/examples/thorchain/transaction-transfer.ts new file mode 100644 index 000000000..dce0915bf --- /dev/null +++ b/examples/thorchain/transaction-transfer.ts @@ -0,0 +1,27 @@ +import { Client, defaultClientConfig } from '@xchainjs/xchain-thorchain' +import { assetAmount, assetToBase } from '@xchainjs/xchain-util' + +const main = async () => { + const phrase = `${process.argv[2]}` + const recipient = `${process.argv[3]}` + const amount = assetAmount(`${process.argv[4]}`, 8) + + const client = new Client({ + ...defaultClientConfig, + phrase, + }) + + const hash = await client.transfer({ + recipient, + amount: assetToBase(amount), + }) + + console.log({ + hash, + url: client.getExplorerTxUrl(hash), + }) +} + +main() + .then(() => process.exit(0)) + .catch((err) => console.error(err)) diff --git a/examples/thorchain/tsconfig.json b/examples/thorchain/tsconfig.json new file mode 100644 index 000000000..7b9e0e966 --- /dev/null +++ b/examples/thorchain/tsconfig.json @@ -0,0 +1,15 @@ +{ + "compilerOptions": { + "module": "commonjs", + "target": "es5", + "noEmitOnError": true, + "resolveJsonModule": true, + "esModuleInterop": true, + "lib": [ + "es6", + "dom", + "es2016", + "es2017" + ] + } +} \ No newline at end of file diff --git a/packages/xchain-aggregator/README.md b/packages/xchain-aggregator/README.md index 584b1c1dc..f2fdab76d 100644 --- a/packages/xchain-aggregator/README.md +++ b/packages/xchain-aggregator/README.md @@ -1,23 +1,75 @@ -# `@xchainjs/xchain-aggregator` +