diff --git a/.github/workflows/build-all.yml b/.github/workflows/build-all.yml index 1229b7cc4..a4921e916 100644 --- a/.github/workflows/build-all.yml +++ b/.github/workflows/build-all.yml @@ -13,11 +13,11 @@ jobs: id: node-version run: | docker build -t enkrypt-build-container . - echo ::set-output name=NODE_VERSION::$(docker run --rm -v `pwd`:/home:rw enkrypt-build-container /bin/bash -c "node --version") + echo "NODE_VERSION=$(docker run --rm -v `pwd`:/home:rw enkrypt-build-container /bin/bash -c "node --version")" >> $GITHUB_OUTPUT - name: Get yarn cache directory path id: yarn-cache-dir-path - run: echo "::set-output name=dir::$(yarn config get cacheFolder)" + run: echo "dir=$(yarn config get cacheFolder)" >> $GITHUB_OUTPUT - name: Cache yarn modules uses: actions/cache@v3 diff --git a/.github/workflows/release.yml b/.github/workflows/release.yml index 1c9bba68f..1a35530d6 100644 --- a/.github/workflows/release.yml +++ b/.github/workflows/release.yml @@ -15,11 +15,11 @@ jobs: id: node-version run: | docker build -t enkrypt-build-container . - echo ::set-output name=NODE_VERSION::$(docker run --rm -v `pwd`:/home:rw enkrypt-build-container /bin/bash -c "node --version") + echo "NODE_VERSION=$(docker run --rm -v `pwd`:/home:rw enkrypt-build-container /bin/bash -c "node --version")" >> $GITHUB_OUTPUT - name: Get yarn cache directory path id: yarn-cache-dir-path - run: echo "::set-output name=dir::$(yarn config get cacheFolder)" + run: echo "dir=$(yarn config get cacheFolder)" >> $GITHUB_OUTPUT - name: Cache yarn modules uses: actions/cache@v3 @@ -35,7 +35,7 @@ jobs: - name: Get release tag id: get_release_tag - run: echo ::set-output name=VERSION::${GITHUB_REF/refs\/tags\//} + run: echo "VERSION=${GITHUB_REF/refs\/tags\//}" >> $GITHUB_OUTPUT - name: build env: diff --git a/packages/extension/package.json b/packages/extension/package.json index deeab24b8..fbb84bae1 100644 --- a/packages/extension/package.json +++ b/packages/extension/package.json @@ -1,6 +1,6 @@ { "name": "@enkryptcom/extension", - "version": "1.28.0", + "version": "1.29.0", "private": true, "scripts": { "zip": "cd dist; zip -r release.zip *;", diff --git a/packages/extension/src/libs/utils/accounts.ts b/packages/extension/src/libs/utils/accounts.ts index b0ee77cdf..0f008bd32 100644 --- a/packages/extension/src/libs/utils/accounts.ts +++ b/packages/extension/src/libs/utils/accounts.ts @@ -21,7 +21,7 @@ export const getAccountsByNetworkName = async ( const accounts = await keyring.getAccounts(network.signer); - return accounts.filter((account) => { + const filtered = accounts.filter((account) => { if (account.isHardware && account.HWOptions !== undefined) { // Polkadot and Kusama ledger apps only work for those networks if ( @@ -34,6 +34,15 @@ export const getAccountsByNetworkName = async ( return true; }); + return filtered.map((f) => { + if ( + network.signer.includes(SignerType.secp256k1btc) && + f.name === "Bitcoin Account 1" + ) { + f.name = f.name.replace("Bitcoin", network.name_long); + } + return f; + }); }; export { getOtherSigners }; diff --git a/packages/extension/src/providers/ethereum/libs/activity-handlers/providers/etherscan/configs.ts b/packages/extension/src/providers/ethereum/libs/activity-handlers/providers/etherscan/configs.ts index a92b32ec8..92fabf1c5 100644 --- a/packages/extension/src/providers/ethereum/libs/activity-handlers/providers/etherscan/configs.ts +++ b/packages/extension/src/providers/ethereum/libs/activity-handlers/providers/etherscan/configs.ts @@ -46,6 +46,7 @@ const NetworkEndpoints: Record = { [NetworkNames.MaticZK]: "https://api-zkevm.polygonscan.com/", [NetworkNames.Base]: "https://api.basescan.org/", [NetworkNames.Celo]: "https://explorer.celo.org/mainnet/", + [NetworkNames.Arthera]: "https://explorer-test.arthera.net/", }; export { NetworkEndpoints }; diff --git a/packages/extension/src/providers/ethereum/networks/aa.ts b/packages/extension/src/providers/ethereum/networks/aa.ts new file mode 100644 index 000000000..4f0dd16dd --- /dev/null +++ b/packages/extension/src/providers/ethereum/networks/aa.ts @@ -0,0 +1,24 @@ +import { NetworkNames } from "@enkryptcom/types"; +import { EvmNetwork, EvmNetworkOptions } from "../types/evm-network"; +import { EtherscanActivity } from "../libs/activity-handlers"; +import wrapActivityHandler from "@/libs/activity-state/wrap-activity-handler"; +import assetsInfoHandler from "@/providers/ethereum/libs/assets-handlers/assetinfo-mew"; + +const artheraOptions: EvmNetworkOptions = { + name: NetworkNames.Arthera, + name_long: "Arthera", + homePage: "https://arthera.net/", + blockExplorerTX: "https://explorer-test.arthera.net/tx/[[txHash]]", + blockExplorerAddr: "https://explorer-test.arthera.net/address/[[address]]", + chainID: "0x2803", + isTestNetwork: true, + currencyName: "AA", + currencyNameLong: "Arthera", + node: "wss://ws-test.arthera.net", + icon: require("./icons/aa.svg"), + activityHandler: wrapActivityHandler(EtherscanActivity), +}; + +const arthera = new EvmNetwork(artheraOptions); + +export default arthera; diff --git a/packages/extension/src/providers/ethereum/networks/icons/aa.svg b/packages/extension/src/providers/ethereum/networks/icons/aa.svg new file mode 100644 index 000000000..7b3782553 --- /dev/null +++ b/packages/extension/src/providers/ethereum/networks/icons/aa.svg @@ -0,0 +1,42 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/packages/extension/src/providers/ethereum/networks/index.ts b/packages/extension/src/providers/ethereum/networks/index.ts index a92613503..067492027 100644 --- a/packages/extension/src/providers/ethereum/networks/index.ts +++ b/packages/extension/src/providers/ethereum/networks/index.ts @@ -30,6 +30,7 @@ import sepoliaNode from "./sepolia"; import baseNode from "./base"; import celoNode from "./celo"; import shibNode from "./shib"; +import artheraNode from "./aa"; export default { goerli: goerliNode, @@ -73,4 +74,5 @@ export default { base: baseNode, celo: celoNode, shib: shibNode, + arthera: artheraNode, }; diff --git a/packages/extension/src/ui/action/views/accounts/components/rename-account-form.vue b/packages/extension/src/ui/action/views/accounts/components/rename-account-form.vue index b8b70caac..72db6de8b 100644 --- a/packages/extension/src/ui/action/views/accounts/components/rename-account-form.vue +++ b/packages/extension/src/ui/action/views/accounts/components/rename-account-form.vue @@ -8,7 +8,9 @@ class="rename-account-form__input" :class="{ focus: isFocus && isValidName, error: !isValidName }" > - + { // @ts-ignore it("it should return a quote", async () => { + const localAmount = toBN("100000000"); const web3eth = new Web3Eth(nodeURL); const rango = new Rango(web3eth, SupportedNetworkName.Ethereum); const init = rango.init(); await init; const quote = await rango.getQuote( { - amount, - fromAddress, - fromToken, + amount: localAmount, + fromAddress: "0x9ff58f4ffb29fa2266ab25e75e2a8b3503311656", // aave + fromToken: fromTokenWBTC, toToken, toAddress, }, @@ -39,13 +41,13 @@ describe("Rango Provider", () => { expect(quote?.quote.meta.walletIdentifier).to.be.eq( WalletIdentifier.enkrypt ); - expect(quote?.fromTokenAmount.toString()).to.be.eq(amount.toString()); + expect(quote?.fromTokenAmount.toString()).to.be.eq(localAmount.toString()); expect(quote?.toTokenAmount.gtn(0)).to.be.eq(true); const swap = await rango.getSwap(quote!.quote); expect(swap?.transactions.length).to.be.eq(2); - expect(swap?.transactions[0].to).to.be.eq(fromToken.address); - }).timeout(20000); + expect(swap?.transactions[0].to).to.be.eq(fromTokenWBTC.address); + }).timeout(25000); it("it should return cross chain swap", async () => { const web3eth = new Web3Eth(nodeURLMatic); @@ -72,5 +74,5 @@ describe("Rango Provider", () => { expect(quote?.additionalNativeFees.gtn(0)).to.be.eq(true); const swap = await rango.getSwap(quote!.quote); expect(swap?.transactions.length).to.be.eq(1); - }).timeout(20000); + }).timeout(25000); }); diff --git a/packages/swap/tests/swap.test.ts b/packages/swap/tests/swap.test.ts index 176f6dcea..85dc69ced 100644 --- a/packages/swap/tests/swap.test.ts +++ b/packages/swap/tests/swap.test.ts @@ -61,7 +61,7 @@ describe("Swap", () => { toToken, toAddress, }); - expect(quotes?.length).to.be.eq(4); + expect(quotes?.length).to.be.eq(3); const oneInceQuote = quotes.find( (q) => q.provider === ProviderName.oneInch ); @@ -72,12 +72,12 @@ describe("Swap", () => { (q) => q.provider === ProviderName.changelly ); const zeroxQuote = quotes.find((q) => q.provider === ProviderName.zerox); - const rangoQuote = quotes.find((q) => q.provider === ProviderName.rango); + // const rangoQuote = quotes.find((q) => q.provider === ProviderName.rango); expect(zeroxQuote).to.be.eq(undefined); expect(changellyQuote!.provider).to.be.eq(ProviderName.changelly); expect(oneInceQuote!.provider).to.be.eq(ProviderName.oneInch); expect(paraswapQuote!.provider).to.be.eq(ProviderName.paraswap); - expect(rangoQuote!.provider).to.be.eq(ProviderName.rango); + // expect(rangoQuote!.provider).to.be.eq(ProviderName.rango); const swapOneInch = await enkryptSwap.getSwap(oneInceQuote!.quote); expect(swapOneInch?.fromTokenAmount.toString()).to.be.eq(amount.toString()); expect(swapOneInch?.transactions.length).to.be.eq(2); @@ -105,11 +105,11 @@ describe("Swap", () => { (q) => q.provider === ProviderName.changelly ); const zeroxQuote = quotes.find((q) => q.provider === ProviderName.zerox); - const rangoQuote = quotes.find((q) => q.provider === ProviderName.rango); + // const rangoQuote = quotes.find((q) => q.provider === ProviderName.rango); expect(zeroxQuote!.provider).to.be.eq(ProviderName.zerox); expect(changellyQuote!.provider).to.be.eq(ProviderName.changelly); expect(oneInceQuote!.provider).to.be.eq(ProviderName.oneInch); expect(paraswapQuote!.provider).to.be.eq(ProviderName.paraswap); - expect(rangoQuote!.provider).to.be.eq(ProviderName.rango); + // expect(rangoQuote!.provider).to.be.eq(ProviderName.rango); }).timeout(10000); }); diff --git a/packages/types/src/networks.ts b/packages/types/src/networks.ts index 2e30e99b2..6a4ed8786 100644 --- a/packages/types/src/networks.ts +++ b/packages/types/src/networks.ts @@ -60,6 +60,7 @@ export enum NetworkNames { Celo = "CELO", Litecoin = "LTC", Dogecoin = "DOGE", + Arthera = "AA", } export enum CoingeckoPlatform {