diff --git a/.github/workflows/xcm-wss-endpoints-monitor.yml b/.github/workflows/xcm-wss-endpoints-monitor.yml new file mode 100644 index 00000000..7ce1b628 --- /dev/null +++ b/.github/workflows/xcm-wss-endpoints-monitor.yml @@ -0,0 +1,33 @@ +name: XCM WS endpoints monitor + +on: + workflow_dispatch: + schedule: + # Runs every 30 minutes + - cron: '*/30 * * * *' + +jobs: + run_script: + runs-on: ubuntu-latest + + steps: + - name: 🤘 checkout + uses: actions/checkout@v3 + + - name: ⚙️ Setup Node.js environment + uses: actions/setup-node@v3.0.0 + with: + node-version: 18.x + cache: 'npm' + + - name: Update npm + run: npm i -g npm@9 + + - name: ⬇️ install + run: npm ci --ignore-scripts + + - name: 🛠️ Build + run: npm run build + + - name: 💻 Run script + run: npx bun ./scripts/check-websockets.ts --slack-wh=${{ secrets.SLACK_WEBHOOK_URL }} diff --git a/examples/sdk-simple/package.json b/examples/sdk-simple/package.json index 8f4c0839..787bc6be 100644 --- a/examples/sdk-simple/package.json +++ b/examples/sdk-simple/package.json @@ -12,8 +12,8 @@ "author": "", "license": "MIT", "dependencies": { - "@moonbeam-network/xcm-config": "1.3.18", - "@moonbeam-network/xcm-sdk": "1.4.14", + "@moonbeam-network/xcm-config": "1.3.23", + "@moonbeam-network/xcm-sdk": "1.4.19", "@moonbeam-network/xcm-utils": "1.0.3" }, "devDependencies": { diff --git a/package-lock.json b/package-lock.json index 2492db84..677ffa93 100644 --- a/package-lock.json +++ b/package-lock.json @@ -20,6 +20,7 @@ "devDependencies": { "@changesets/changelog-github": "^0.4.8", "@changesets/cli": "^2.26.2", + "@slack/webhook": "^7.0.2", "@types/jest": "^29.5.3", "@typescript-eslint/eslint-plugin": "^5.59.8", "@typescript-eslint/parser": "^5.59.8", @@ -49,8 +50,8 @@ "version": "1.0.0", "license": "MIT", "dependencies": { - "@moonbeam-network/xcm-config": "1.3.18", - "@moonbeam-network/xcm-sdk": "1.4.14", + "@moonbeam-network/xcm-config": "1.3.23", + "@moonbeam-network/xcm-sdk": "1.4.19", "@moonbeam-network/xcm-utils": "1.0.3" }, "devDependencies": { @@ -5148,6 +5149,31 @@ "@sinonjs/commons": "^3.0.0" } }, + "node_modules/@slack/types": { + "version": "2.11.0", + "resolved": "https://registry.npmjs.org/@slack/types/-/types-2.11.0.tgz", + "integrity": "sha512-UlIrDWvuLaDly3QZhCPnwUSI/KYmV1N9LyhuH6EDKCRS1HWZhyTG3Ja46T3D0rYfqdltKYFXbJSSRPwZpwO0cQ==", + "dev": true, + "engines": { + "node": ">= 12.13.0", + "npm": ">= 6.12.0" + } + }, + "node_modules/@slack/webhook": { + "version": "7.0.2", + "resolved": "https://registry.npmjs.org/@slack/webhook/-/webhook-7.0.2.tgz", + "integrity": "sha512-dsrO/ow6a6+xkLm/lZKbUNTsFJlBc679tD+qwlVTztsQkDxPLH6odM7FKALz1IHa+KpLX8HKUIPV13a7y7z29w==", + "dev": true, + "dependencies": { + "@slack/types": "^2.9.0", + "@types/node": ">=18.0.0", + "axios": "^1.6.3" + }, + "engines": { + "node": ">= 18", + "npm": ">= 8.6.0" + } + }, "node_modules/@snowfork/snowbridge-types": { "version": "0.2.7", "resolved": "https://registry.npmjs.org/@snowfork/snowbridge-types/-/snowbridge-types-0.2.7.tgz", @@ -6578,8 +6604,7 @@ "node_modules/asynckit": { "version": "0.4.0", "resolved": "https://registry.npmjs.org/asynckit/-/asynckit-0.4.0.tgz", - "integrity": "sha512-Oei9OH4tRh0YqU3GxhX79dM/mwVgvbZJaSNaRk+bshkj0S5cfHcgYakreBjrHwatXKbz+IoIdYLxrKim2MjW0Q==", - "peer": true + "integrity": "sha512-Oei9OH4tRh0YqU3GxhX79dM/mwVgvbZJaSNaRk+bshkj0S5cfHcgYakreBjrHwatXKbz+IoIdYLxrKim2MjW0Q==" }, "node_modules/available-typed-arrays": { "version": "1.0.5", @@ -6593,6 +6618,31 @@ "url": "https://github.com/sponsors/ljharb" } }, + "node_modules/axios": { + "version": "1.6.5", + "resolved": "https://registry.npmjs.org/axios/-/axios-1.6.5.tgz", + "integrity": "sha512-Ii012v05KEVuUoFWmMW/UQv9aRIc3ZwkWDcM+h5Il8izZCtRVpDUfwpoFf7eOtajT3QiGR4yDUx7lPqHJULgbg==", + "dev": true, + "dependencies": { + "follow-redirects": "^1.15.4", + "form-data": "^4.0.0", + "proxy-from-env": "^1.1.0" + } + }, + "node_modules/axios/node_modules/form-data": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/form-data/-/form-data-4.0.0.tgz", + "integrity": "sha512-ETEklSGi5t0QMZuiXoA/Q6vcnxcLQP5vdugSpuAyi6SVGi2clPPp+xgEhuMaHC+zGgn31Kd235W35f7Hykkaww==", + "dev": true, + "dependencies": { + "asynckit": "^0.4.0", + "combined-stream": "^1.0.8", + "mime-types": "^2.1.12" + }, + "engines": { + "node": ">= 6" + } + }, "node_modules/babel-jest": { "version": "29.6.1", "resolved": "https://registry.npmjs.org/babel-jest/-/babel-jest-29.6.1.tgz", @@ -7360,7 +7410,6 @@ "version": "1.0.8", "resolved": "https://registry.npmjs.org/combined-stream/-/combined-stream-1.0.8.tgz", "integrity": "sha512-FQN4MRfuJeHf7cBbBMJFXhKSDq+2kAArBlmRBvcvFE5BB1HZKXtSFASDhdlz9zOYwxh8lDdnvmMOe/+5cdoEdg==", - "peer": true, "dependencies": { "delayed-stream": "~1.0.0" }, @@ -7625,7 +7674,6 @@ "version": "1.0.0", "resolved": "https://registry.npmjs.org/delayed-stream/-/delayed-stream-1.0.0.tgz", "integrity": "sha512-ZySD7Nf91aLB0RxL4KGrKHBXl7Eds1DAmEdcoVawXnLD7SDhpNgtuII2aAkg7a7QS41jxPSZ17p4VdGnMHk3MQ==", - "peer": true, "engines": { "node": ">=0.4.0" } @@ -8832,6 +8880,26 @@ "integrity": "sha512-5nqDSxl8nn5BSNxyR3n4I6eDmbolI6WT+QqR547RwxQapgjQBmtktdP+HTBb/a/zLsbzERTONyUB5pefh5TtjQ==", "dev": true }, + "node_modules/follow-redirects": { + "version": "1.15.5", + "resolved": "https://registry.npmjs.org/follow-redirects/-/follow-redirects-1.15.5.tgz", + "integrity": "sha512-vSFWUON1B+yAw1VN4xMfxgn5fTUiaOzAJCKBwIIgT/+7CuGy9+r+5gITvP62j3RmaD5Ph65UaERdOSRGUzZtgw==", + "dev": true, + "funding": [ + { + "type": "individual", + "url": "https://github.com/sponsors/RubenVerborgh" + } + ], + "engines": { + "node": ">=4.0" + }, + "peerDependenciesMeta": { + "debug": { + "optional": true + } + } + }, "node_modules/for-each": { "version": "0.3.3", "resolved": "https://registry.npmjs.org/for-each/-/for-each-0.3.3.tgz", @@ -12393,7 +12461,6 @@ "version": "1.52.0", "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.52.0.tgz", "integrity": "sha512-sPU4uV7dYlvtWJxwwxHD0PuihVNiE7TyAbQ5SWxDCB9mUYvOgroQOwYQQOKPJ8CIbE+1ETVlOoK1UC2nU3gYvg==", - "peer": true, "engines": { "node": ">= 0.6" } @@ -12402,7 +12469,6 @@ "version": "2.1.35", "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.35.tgz", "integrity": "sha512-ZDY+bPm5zTTF+YpCrAU9nK0UgICYPT0QtT1NZWFv4s++TNkcgVaT0g6+4R2uI4MjQjzysHB1zxuWL50hzaeXiw==", - "peer": true, "dependencies": { "mime-db": "1.52.0" }, @@ -14398,6 +14464,12 @@ "node": ">= 8" } }, + "node_modules/proxy-from-env": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/proxy-from-env/-/proxy-from-env-1.1.0.tgz", + "integrity": "sha512-D+zkORCbA9f1tdWRK0RaCR3GPv50cMxcrz4X8k5LTSUD1Dkw47mKJEZQNunItRTkWwgtaUSo1RVFRIG9ZXiFYg==", + "dev": true + }, "node_modules/pseudomap": { "version": "1.0.2", "resolved": "https://registry.npmjs.org/pseudomap/-/pseudomap-1.0.2.tgz", @@ -16976,10 +17048,10 @@ }, "packages/builder": { "name": "@moonbeam-network/xcm-builder", - "version": "1.0.10", + "version": "1.0.11", "license": "MIT", "dependencies": { - "@moonbeam-network/xcm-types": "1.0.1", + "@moonbeam-network/xcm-types": "1.0.2", "@moonbeam-network/xcm-utils": "1.0.3", "big.js": "^6.2.1", "type-fest": "^3.8.0" @@ -17004,11 +17076,11 @@ }, "packages/config": { "name": "@moonbeam-network/xcm-config", - "version": "1.3.18", + "version": "1.3.23", "license": "MIT", "dependencies": { - "@moonbeam-network/xcm-builder": "1.0.10", - "@moonbeam-network/xcm-types": "1.0.1" + "@moonbeam-network/xcm-builder": "1.0.11", + "@moonbeam-network/xcm-types": "1.0.2" }, "peerDependencies": { "@polkadot/types": "^10.10.1", @@ -17018,12 +17090,12 @@ }, "packages/sdk": { "name": "@moonbeam-network/xcm-sdk", - "version": "1.4.14", + "version": "1.4.19", "license": "MIT", "dependencies": { - "@moonbeam-network/xcm-builder": "1.0.10", - "@moonbeam-network/xcm-config": "1.3.18", - "@moonbeam-network/xcm-types": "1.0.1", + "@moonbeam-network/xcm-builder": "1.0.11", + "@moonbeam-network/xcm-config": "1.3.23", + "@moonbeam-network/xcm-types": "1.0.2", "@moonbeam-network/xcm-utils": "1.0.3", "big.js": "^6.2.1" }, @@ -17038,7 +17110,7 @@ }, "packages/types": { "name": "@moonbeam-network/xcm-types", - "version": "1.0.1", + "version": "1.0.2", "license": "MIT", "dependencies": { "@moonbeam-network/xcm-utils": "1.x", diff --git a/package.json b/package.json index 2a72cf45..1df6f46a 100644 --- a/package.json +++ b/package.json @@ -43,6 +43,7 @@ "devDependencies": { "@changesets/changelog-github": "^0.4.8", "@changesets/cli": "^2.26.2", + "@slack/webhook": "^7.0.2", "@types/jest": "^29.5.3", "@typescript-eslint/eslint-plugin": "^5.59.8", "@typescript-eslint/parser": "^5.59.8", diff --git a/packages/builder/CHANGELOG.md b/packages/builder/CHANGELOG.md index c5d3ec1d..b3373efb 100644 --- a/packages/builder/CHANGELOG.md +++ b/packages/builder/CHANGELOG.md @@ -1,5 +1,14 @@ # @moonbeam-network/xcm-builder +## 1.0.11 + +### Patch Changes + +- [#184](https://github.com/PureStake/xcm-sdk/pull/184) [`88b6322`](https://github.com/PureStake/xcm-sdk/commit/88b6322327b30baa0fb2bf55f99497e2944c95ef) Thanks [@mmaurello](https://github.com/mmaurello)! - Use unlimited weight in all transactions for the xTokens pallet + +- Updated dependencies [[`88b6322`](https://github.com/PureStake/xcm-sdk/commit/88b6322327b30baa0fb2bf55f99497e2944c95ef)]: + - @moonbeam-network/xcm-types@1.0.2 + ## 1.0.10 ### Patch Changes diff --git a/packages/builder/package.json b/packages/builder/package.json index 1ef3c9e2..ffd35037 100644 --- a/packages/builder/package.json +++ b/packages/builder/package.json @@ -1,6 +1,6 @@ { "name": "@moonbeam-network/xcm-builder", - "version": "1.0.10", + "version": "1.0.11", "description": "Moonbeam XCM builder", "scripts": { "build": "tsup", @@ -50,7 +50,7 @@ "types": "./build/index.d.ts", "main": "./build/index.cjs", "dependencies": { - "@moonbeam-network/xcm-types": "1.0.1", + "@moonbeam-network/xcm-types": "1.0.2", "@moonbeam-network/xcm-utils": "1.0.3", "big.js": "^6.2.1", "type-fest": "^3.8.0" diff --git a/packages/builder/src/extrinsic/pallets/xTokens/__snapshots__/xTokens.test.ts.snap b/packages/builder/src/extrinsic/pallets/xTokens/__snapshots__/xTokens.test.ts.snap index e388f1bd..00588e79 100644 --- a/packages/builder/src/extrinsic/pallets/xTokens/__snapshots__/xTokens.test.ts.snap +++ b/packages/builder/src/extrinsic/pallets/xTokens/__snapshots__/xTokens.test.ts.snap @@ -30,7 +30,7 @@ exports[`xTokens transfer should get correct arguments 1`] = ` "parents": 1, }, }, - 1000000000, + "Unlimited", ] `; @@ -85,7 +85,7 @@ exports[`xTokens transferMultiAsset parachain should get correct arguments 1`] = "parents": 1, }, }, - 1000000000, + "Unlimited", ] `; @@ -188,7 +188,7 @@ exports[`xTokens transferMultiAsset x2 should get correct arguments 1`] = ` "parents": 1, }, }, - 1000000000, + "Unlimited", ] `; diff --git a/packages/builder/src/extrinsic/pallets/xTokens/xTokens.ts b/packages/builder/src/extrinsic/pallets/xTokens/xTokens.ts index 5a55f22a..b05ec066 100644 --- a/packages/builder/src/extrinsic/pallets/xTokens/xTokens.ts +++ b/packages/builder/src/extrinsic/pallets/xTokens/xTokens.ts @@ -12,7 +12,7 @@ const pallet = 'xTokens'; export function xTokens() { return { transfer: (): ExtrinsicConfigBuilder => ({ - build: ({ address, amount, asset, destination, source }) => + build: ({ address, amount, asset, destination }) => new ExtrinsicConfig({ module: pallet, func: 'transfer', @@ -23,7 +23,7 @@ export function xTokens() { asset, amount, getDestination(version, address, destination), - getWeight(source.weight, func), + getWeight(), ]; }, }), @@ -55,7 +55,7 @@ export function xTokens() { }, }, getDestination(version, address, destination), - 'Unlimited', + getWeight(), ]; }, }), @@ -87,13 +87,13 @@ export function xTokens() { }, }, getDestination(version, address, destination), - 'Unlimited', + getWeight(), ]; }, }), }), X2: (): ExtrinsicConfigBuilder => ({ - build: ({ address, amount, asset, destination, source }) => + build: ({ address, amount, asset, destination }) => new ExtrinsicConfig({ module: pallet, func: funcName, @@ -124,7 +124,7 @@ export function xTokens() { }, }, getDestination(version, address, destination), - getWeight(source.weight, func), + getWeight(), ]; }, }), @@ -143,7 +143,7 @@ export function xTokens() { ], 1, getDestination(XcmVersion.v3, address, destination), - 'Unlimited', + getWeight(), ], }), }), diff --git a/packages/builder/src/extrinsic/pallets/xTokens/xTokens.utils.ts b/packages/builder/src/extrinsic/pallets/xTokens/xTokens.utils.ts index 2b44f740..1a6518af 100644 --- a/packages/builder/src/extrinsic/pallets/xTokens/xTokens.utils.ts +++ b/packages/builder/src/extrinsic/pallets/xTokens/xTokens.utils.ts @@ -1,34 +1,13 @@ import { AnyChain } from '@moonbeam-network/xcm-types'; -import { SubmittableExtrinsicFunction } from '@polkadot/api/types'; import { XcmVersion } from '../../ExtrinsicBuilder.interfaces'; import { getExtrinsicAccount } from '../../ExtrinsicBuilder.utils'; import { XTokensWeightLimit } from './xTokens.interfaces'; /** - * Workaround for weight parameter type change in xTokens pallet - * https://github.com/open-web3-stack/open-runtime-module-library/pull/841 + * It is safer to always use unlimited */ -export function getWeight( - weight: number, - func?: SubmittableExtrinsicFunction<'promise'>, -): XTokensWeightLimit { - const type = func?.meta.args.at(-1)?.type; - - if (!type) { - return weight; - } - - if (type.eq('XcmV2WeightLimit')) { - return { - Limited: weight, - }; - } - - if (type.eq('XcmV3WeightLimit')) { - return 'Unlimited'; - } - - return weight; +export function getWeight(): XTokensWeightLimit { + return 'Unlimited'; } export function getDestination( diff --git a/packages/config/CHANGELOG.md b/packages/config/CHANGELOG.md index be0d3e12..9d9157fe 100644 --- a/packages/config/CHANGELOG.md +++ b/packages/config/CHANGELOG.md @@ -1,5 +1,37 @@ # @moonbeam-network/xcm-config +## 1.3.23 + +### Patch Changes + +- [#188](https://github.com/PureStake/xcm-sdk/pull/188) [`1b09924`](https://github.com/PureStake/xcm-sdk/commit/1b0992493f5afac24e7cdbfd907303f7d450860c) Thanks [@mmaurello](https://github.com/mmaurello)! - Remove Litentry alphanet and change Parallel endpoint + +## 1.3.22 + +### Patch Changes + +- [#186](https://github.com/PureStake/xcm-sdk/pull/186) [`f72cf9b`](https://github.com/PureStake/xcm-sdk/commit/f72cf9b55e20c24294971a41ff7b3dc82d588126) Thanks [@albertov19](https://github.com/albertov19)! - Updated Calamari Endpoint + +## 1.3.21 + +### Patch Changes + +- Updated dependencies [[`88b6322`](https://github.com/PureStake/xcm-sdk/commit/88b6322327b30baa0fb2bf55f99497e2944c95ef)]: + - @moonbeam-network/xcm-builder@1.0.11 + - @moonbeam-network/xcm-types@1.0.2 + +## 1.3.20 + +### Patch Changes + +- [#182](https://github.com/PureStake/xcm-sdk/pull/182) [`6beaf73`](https://github.com/PureStake/xcm-sdk/commit/6beaf73e39d339f6221b7346758822f63bbf99e3) Thanks [@mmaurello](https://github.com/mmaurello)! - Remove equilibrium alphanet config + +## 1.3.19 + +### Patch Changes + +- [#180](https://github.com/PureStake/xcm-sdk/pull/180) [`b4d988f`](https://github.com/PureStake/xcm-sdk/commit/b4d988f5dc9d8c7dfd8067747234609e8701ef52) Thanks [@albertov19](https://github.com/albertov19)! - Updated Parallel WSS Endpoint + ## 1.3.18 ### Patch Changes diff --git a/packages/config/package.json b/packages/config/package.json index 51188dbc..a914d19d 100644 --- a/packages/config/package.json +++ b/packages/config/package.json @@ -1,6 +1,6 @@ { "name": "@moonbeam-network/xcm-config", - "version": "1.3.18", + "version": "1.3.23", "description": "All necessary configuration to transfer assets from Moonbeam, Moonriver, Moonbase to other parachains and back", "scripts": { "build": "tsup", @@ -50,8 +50,8 @@ "types": "./build/index.d.ts", "main": "./build/index.cjs", "dependencies": { - "@moonbeam-network/xcm-builder": "1.0.10", - "@moonbeam-network/xcm-types": "1.0.1" + "@moonbeam-network/xcm-builder": "1.0.11", + "@moonbeam-network/xcm-types": "1.0.2" }, "peerDependencies": { "@polkadot/types": "^10.10.1", diff --git a/packages/config/src/ConfigBuilder/ConfigBuilder.test.ts b/packages/config/src/ConfigBuilder/ConfigBuilder.test.ts index 94619cd1..c182b682 100644 --- a/packages/config/src/ConfigBuilder/ConfigBuilder.test.ts +++ b/packages/config/src/ConfigBuilder/ConfigBuilder.test.ts @@ -2,9 +2,9 @@ import { Ecosystem } from '@moonbeam-network/xcm-types'; import { ConfigService } from '../ConfigService'; import { dev } from '../assets'; -import { equilibriumAlphanet, moonbaseAlpha } from '../chains'; -import { equilibriumAlphanetConfig } from '../configs/equilibriumAlphanet'; +import { moonbaseAlpha, pendulumAlphanet } from '../chains'; import { moonbaseAlphaConfig } from '../configs/moonbaseAlpha'; +import { pendulumAlphanetConfig } from '../configs/pendulumAlphanet'; import { ConfigBuilder } from './ConfigBuilder'; describe('configBuilder', () => { @@ -13,7 +13,7 @@ describe('configBuilder', () => { .assets(Ecosystem.AlphanetRelay) .asset(dev) .source(moonbaseAlpha) - .destination(equilibriumAlphanet) + .destination(pendulumAlphanet) .build(); expect(config).toStrictEqual({ @@ -22,12 +22,12 @@ describe('configBuilder', () => { chain: moonbaseAlpha, config: moonbaseAlphaConfig.getAssetDestinationConfig( dev, - equilibriumAlphanet, + pendulumAlphanet, ), }, destination: { - chain: equilibriumAlphanet, - config: equilibriumAlphanetConfig.getAssetDestinationConfig( + chain: pendulumAlphanet, + config: pendulumAlphanetConfig.getAssetDestinationConfig( dev, moonbaseAlpha, ), @@ -41,7 +41,7 @@ describe('configBuilder', () => { .assets(Ecosystem.AlphanetRelay) .asset(dev) .source(moonbaseAlpha) - .destination(equilibriumAlphanet) + .destination(pendulumAlphanet) .build(); expect(config).toStrictEqual({ @@ -50,12 +50,12 @@ describe('configBuilder', () => { chain: moonbaseAlpha, config: moonbaseAlphaConfig.getAssetDestinationConfig( dev, - equilibriumAlphanet, + pendulumAlphanet, ), }, destination: { - chain: equilibriumAlphanet, - config: equilibriumAlphanetConfig.getAssetDestinationConfig( + chain: pendulumAlphanet, + config: pendulumAlphanetConfig.getAssetDestinationConfig( dev, moonbaseAlpha, ), diff --git a/packages/config/src/ConfigService/ConfigService.test.ts b/packages/config/src/ConfigService/ConfigService.test.ts index fc3e88e1..55ca9ecc 100644 --- a/packages/config/src/ConfigService/ConfigService.test.ts +++ b/packages/config/src/ConfigService/ConfigService.test.ts @@ -9,12 +9,7 @@ import { Parachain, } from '@moonbeam-network/xcm-types'; import { assetsList, dev, glmr, tt1, unit } from '../assets'; -import { - equilibriumAlphanet, - hydraDX, - moonbaseAlpha, - moonbeam, -} from '../chains'; +import { hydraDX, moonbaseAlpha, moonbeam, pendulumAlphanet } from '../chains'; import { ConfigService } from './ConfigService'; import { AssetConfig } from '../types/AssetConfig'; @@ -123,7 +118,7 @@ describe('config service', () => { ); expect(chains).toStrictEqual( - expect.arrayContaining([moonbaseAlpha, equilibriumAlphanet]), + expect.arrayContaining([moonbaseAlpha, pendulumAlphanet]), ); }); }); diff --git a/packages/config/src/chains.ts b/packages/config/src/chains.ts index 45ca7a7c..7773ba22 100644 --- a/packages/config/src/chains.ts +++ b/packages/config/src/chains.ts @@ -47,7 +47,6 @@ import { ring, rmrk, sdn, - soon, sub, teer, tt1, @@ -255,7 +254,7 @@ export const calamari = new Parachain({ name: 'Calamari', parachainId: 2084, ss58Format: 78, - ws: 'wss://ws.calamari.systems', + ws: 'wss://calamari.systems', }); export const centrifuge = new Parachain({ @@ -403,33 +402,6 @@ export const equilibrium = new Parachain({ ws: 'wss://node.pol.equilibrium.io', }); -export const equilibriumAlphanet = new Parachain({ - assetsData: [ - { - asset: dev, - decimals: 9, - id: 1_735_159_154, - }, - { - asset: eq, - id: 25_969, - }, - { - asset: eqd, - id: 6_648_164, - }, - ], - ecosystem: Ecosystem.AlphanetRelay, - genesisHash: - '0x0ba4508078664cfd04f00bf17892dd1a0764ce61d90857f76c6a2ea61f008247', - isTestChain: true, - key: 'equilibrium-alphanet', - name: 'EquilibriumAlphanet', - parachainId: 2011, - ss58Format: 68, - ws: 'wss://devnet.equilab.io/alphanet/collator/api/wss', -}); - export const hydraDX = new Parachain({ assetsData: [ { @@ -625,24 +597,6 @@ export const kusamaAssetHub = new Parachain({ ws: 'wss://kusama-asset-hub-rpc.polkadot.io', }); -export const litentryAlphanet = new Parachain({ - assetsData: [ - { - asset: lit, - id: 'SelfReserve', - }, - ], - ecosystem: Ecosystem.AlphanetRelay, - genesisHash: - '0x4decfd421755d9008781d00ce40ea4cf47ec24a3717a34ca995126fc4a78c4f8', - isTestChain: true, - key: 'litentry-alphanet', - name: 'Litentry Alphanet', - parachainId: 2106, - ss58Format: 131, - ws: 'wss://moonbase-parachain-sg-0.litentry.io', -}); - export const litmus = new Parachain({ assetsData: [ { @@ -696,24 +650,16 @@ export const moonbaseAlpha = new EvmParachain({ asset: atom, id: '244316754493307480955066032215622931381', }, - { - asset: auq, - id: '69536036667157951501899290870203586130', - }, + // { + // asset: auq, + // id: '69536036667157951501899290870203586130', + // }, { asset: dev, id: '0x0000000000000000000000000000000000000802', metadataId: 0, min: 0.01, }, - { - asset: eq, - id: '190590555344745888270686124937537713878', - }, - { - asset: eqd, - id: '187224307232923873519830480073807488153', - }, { asset: lit, id: '65216491554813189869575508812319036608', @@ -730,10 +676,6 @@ export const moonbaseAlpha = new EvmParachain({ asset: pica, id: '22417088946346045371238623691600461855', }, - { - asset: soon, - id: '205153165378836428058230526014907639736', - }, { asset: tt1, id: '156305701417244550631956600137082963628', @@ -1132,7 +1074,7 @@ export const parallel = new Parachain({ name: 'Parallel', parachainId: 2012, ss58Format: 172, - ws: 'wss://rpc.parallel.fi', + ws: 'wss://parallel-rpc.dwellir.com', }); export const parallelHeiko = new Parachain({ @@ -1459,7 +1401,6 @@ export const chainsList: AnyChain[] = [ darwiniaCrab, darwiniaPangoro, equilibrium, - equilibriumAlphanet, hydraDX, integritee, interlay, @@ -1467,7 +1408,6 @@ export const chainsList: AnyChain[] = [ khala, kintsugi, kusama, - litentryAlphanet, litmus, mangataKusama, moonbaseAlpha, diff --git a/packages/config/src/configs/equilibriumAlphanet.ts b/packages/config/src/configs/equilibriumAlphanet.ts deleted file mode 100644 index bc453de0..00000000 --- a/packages/config/src/configs/equilibriumAlphanet.ts +++ /dev/null @@ -1,56 +0,0 @@ -import { - BalanceBuilder, - ExtrinsicBuilder, - FeeBuilder, -} from '@moonbeam-network/xcm-builder'; -import { dev, eq, eqd } from '../assets'; -import { equilibriumAlphanet, moonbaseAlpha } from '../chains'; -import { AssetConfig } from '../types/AssetConfig'; -import { ChainConfig } from '../types/ChainConfig'; - -export const equilibriumAlphanetConfig = new ChainConfig({ - assets: [ - new AssetConfig({ - asset: eq, - balance: BalanceBuilder().substrate().system().accountEquilibrium(), - destination: moonbaseAlpha, - destinationFee: { - amount: FeeBuilder().assetManager().assetTypeUnitsPerSecond(), - asset: eq, - balance: BalanceBuilder().substrate().system().accountEquilibrium(), - }, - extrinsic: ExtrinsicBuilder().eqBalances().transferXcm(), - }), - new AssetConfig({ - asset: eqd, - balance: BalanceBuilder().substrate().system().accountEquilibrium(), - destination: moonbaseAlpha, - destinationFee: { - amount: FeeBuilder().assetManager().assetTypeUnitsPerSecond(), - asset: eq, - balance: BalanceBuilder().substrate().system().accountEquilibrium(), - }, - extrinsic: ExtrinsicBuilder().eqBalances().transferXcm(), - fee: { - asset: eq, - balance: BalanceBuilder().substrate().system().accountEquilibrium(), - }, - }), - new AssetConfig({ - asset: dev, - balance: BalanceBuilder().substrate().system().accountEquilibrium(), - destination: moonbaseAlpha, - destinationFee: { - amount: 0.00005, - asset: dev, - balance: BalanceBuilder().substrate().system().accountEquilibrium(), - }, - extrinsic: ExtrinsicBuilder().eqBalances().transferXcm(), - fee: { - asset: eq, - balance: BalanceBuilder().substrate().system().accountEquilibrium(), - }, - }), - ], - chain: equilibriumAlphanet, -}); diff --git a/packages/config/src/configs/index.ts b/packages/config/src/configs/index.ts index 1a09e5d9..5d250cab 100644 --- a/packages/config/src/configs/index.ts +++ b/packages/config/src/configs/index.ts @@ -13,7 +13,6 @@ import { darwiniaConfig } from './darwinia'; import { darwiniaCrabConfig } from './darwiniaCrab'; import { darwiniaPangoroConfig } from './darwiniaPangoro'; import { equilibriumConfig } from './equilibrium'; -import { equilibriumAlphanetConfig } from './equilibriumAlphanet'; import { hydraDxConfig } from './hydraDX'; import { integriteeConfig } from './integritee'; import { interlayConfig } from './interlay'; @@ -22,7 +21,6 @@ import { khalaConfig } from './khala'; import { kintsugiConfig } from './kintsugi'; import { kusamaConfig } from './kusama'; import { kusamaAssetHubConfig } from './kusamaAssetHub'; -import { litentryAlphanetConfig } from './litentryAlphanet'; import { litmusConfig } from './litmus'; import { mangataKusamaConfig } from './mangataKusama'; import { moonbaseAlphaConfig } from './moonbaseAlpha'; @@ -61,7 +59,6 @@ export const chainsConfigList: ChainConfig[] = [ darwiniaConfig, darwiniaCrabConfig, darwiniaPangoroConfig, - equilibriumAlphanetConfig, equilibriumConfig, hydraDxConfig, integriteeConfig, @@ -70,7 +67,6 @@ export const chainsConfigList: ChainConfig[] = [ khalaConfig, kintsugiConfig, kusamaConfig, - litentryAlphanetConfig, litmusConfig, mangataKusamaConfig, moonbaseAlphaConfig, diff --git a/packages/config/src/configs/litentryAlphanet.ts b/packages/config/src/configs/litentryAlphanet.ts deleted file mode 100644 index 9d76b5a0..00000000 --- a/packages/config/src/configs/litentryAlphanet.ts +++ /dev/null @@ -1,26 +0,0 @@ -import { - BalanceBuilder, - ExtrinsicBuilder, - FeeBuilder, -} from '@moonbeam-network/xcm-builder'; -import { lit } from '../assets'; -import { litentryAlphanet, moonbaseAlpha } from '../chains'; -import { AssetConfig } from '../types/AssetConfig'; -import { ChainConfig } from '../types/ChainConfig'; - -export const litentryAlphanetConfig = new ChainConfig({ - assets: [ - new AssetConfig({ - asset: lit, - balance: BalanceBuilder().substrate().system().account(), - destination: moonbaseAlpha, - destinationFee: { - amount: FeeBuilder().assetManager().assetTypeUnitsPerSecond(), - asset: lit, - balance: BalanceBuilder().substrate().system().account(), - }, - extrinsic: ExtrinsicBuilder().xTokens().transfer(), - }), - ], - chain: litentryAlphanet, -}); diff --git a/packages/config/src/configs/moonbaseAlpha.ts b/packages/config/src/configs/moonbaseAlpha.ts index dea9b312..b362fd1c 100644 --- a/packages/config/src/configs/moonbaseAlpha.ts +++ b/packages/config/src/configs/moonbaseAlpha.ts @@ -4,9 +4,6 @@ import { ampe, atom, dev, - eq, - eqd, - lit, otp, paring, pica, @@ -18,8 +15,6 @@ import { alphanetAssetHub, alphanetRelay, darwiniaPangoro, - equilibriumAlphanet, - litentryAlphanet, moonbaseAlpha, moonbaseBeta, originTrailAlphanet, @@ -32,17 +27,6 @@ import { ChainConfig } from '../types/ChainConfig'; export const moonbaseAlphaConfig = new ChainConfig({ assets: [ - new AssetConfig({ - asset: dev, - balance: BalanceBuilder().substrate().system().account(), - contract: ContractBuilder().Xtokens().transfer(), - destination: equilibriumAlphanet, - destinationFee: { - amount: 4, - asset: dev, - balance: BalanceBuilder().substrate().system().account(), - }, - }), new AssetConfig({ asset: dev, balance: BalanceBuilder().substrate().system().account(), @@ -132,51 +116,6 @@ export const moonbaseAlphaConfig = new ChainConfig({ balance: BalanceBuilder().substrate().system().account(), }, }), - new AssetConfig({ - asset: eq, - balance: BalanceBuilder().substrate().assets().account(), - contract: ContractBuilder().Xtokens().transfer(), - destination: equilibriumAlphanet, - destinationFee: { - amount: 14, - asset: eq, - balance: BalanceBuilder().substrate().assets().account(), - }, - fee: { - asset: dev, - balance: BalanceBuilder().substrate().system().account(), - }, - }), - new AssetConfig({ - asset: eqd, - balance: BalanceBuilder().substrate().assets().account(), - contract: ContractBuilder().Xtokens().transfer(), - destination: equilibriumAlphanet, - destinationFee: { - amount: 4, - asset: eqd, - balance: BalanceBuilder().substrate().assets().account(), - }, - fee: { - asset: dev, - balance: BalanceBuilder().substrate().system().account(), - }, - }), - new AssetConfig({ - asset: lit, - balance: BalanceBuilder().substrate().assets().account(), - contract: ContractBuilder().Xtokens().transfer(), - destination: litentryAlphanet, - destinationFee: { - amount: 0.032, - asset: lit, - balance: BalanceBuilder().substrate().assets().account(), - }, - fee: { - asset: dev, - balance: BalanceBuilder().substrate().system().account(), - }, - }), new AssetConfig({ asset: otp, balance: BalanceBuilder().substrate().assets().account(), diff --git a/packages/sdk/CHANGELOG.md b/packages/sdk/CHANGELOG.md index 1b9134ff..68728ac5 100644 --- a/packages/sdk/CHANGELOG.md +++ b/packages/sdk/CHANGELOG.md @@ -1,5 +1,44 @@ # @moonbeam-network/xcm-sdk +## 1.4.19 + +### Patch Changes + +- Updated dependencies [[`1b09924`](https://github.com/PureStake/xcm-sdk/commit/1b0992493f5afac24e7cdbfd907303f7d450860c)]: + - @moonbeam-network/xcm-config@1.3.23 + +## 1.4.18 + +### Patch Changes + +- Updated dependencies [[`f72cf9b`](https://github.com/PureStake/xcm-sdk/commit/f72cf9b55e20c24294971a41ff7b3dc82d588126)]: + - @moonbeam-network/xcm-config@1.3.22 + +## 1.4.17 + +### Patch Changes + +- Updated dependencies [[`88b6322`](https://github.com/PureStake/xcm-sdk/commit/88b6322327b30baa0fb2bf55f99497e2944c95ef)]: + - @moonbeam-network/xcm-builder@1.0.11 + - @moonbeam-network/xcm-types@1.0.2 + - @moonbeam-network/xcm-config@1.3.21 + +## 1.4.16 + +### Patch Changes + +- [#182](https://github.com/PureStake/xcm-sdk/pull/182) [`6beaf73`](https://github.com/PureStake/xcm-sdk/commit/6beaf73e39d339f6221b7346758822f63bbf99e3) Thanks [@mmaurello](https://github.com/mmaurello)! - Remove equilibrium alphanet config + +- Updated dependencies [[`6beaf73`](https://github.com/PureStake/xcm-sdk/commit/6beaf73e39d339f6221b7346758822f63bbf99e3)]: + - @moonbeam-network/xcm-config@1.3.20 + +## 1.4.15 + +### Patch Changes + +- Updated dependencies [[`b4d988f`](https://github.com/PureStake/xcm-sdk/commit/b4d988f5dc9d8c7dfd8067747234609e8701ef52)]: + - @moonbeam-network/xcm-config@1.3.19 + ## 1.4.14 ### Patch Changes diff --git a/packages/sdk/package.json b/packages/sdk/package.json index 64dc15f7..a7982619 100644 --- a/packages/sdk/package.json +++ b/packages/sdk/package.json @@ -1,6 +1,6 @@ { "name": "@moonbeam-network/xcm-sdk", - "version": "1.4.14", + "version": "1.4.19", "description": "The Moonbeam XCM SDK enables developers to easily deposit and withdraw assets to Moonbeam/Moonriver from the relay chain and other parachains in the Polkadot/Kusama ecosystem", "scripts": { "build": "tsup", @@ -51,9 +51,9 @@ "types": "./build/index.d.ts", "main": "./build/index.cjs", "dependencies": { - "@moonbeam-network/xcm-builder": "1.0.10", - "@moonbeam-network/xcm-config": "1.3.18", - "@moonbeam-network/xcm-types": "1.0.1", + "@moonbeam-network/xcm-builder": "1.0.11", + "@moonbeam-network/xcm-config": "1.3.23", + "@moonbeam-network/xcm-types": "1.0.2", "@moonbeam-network/xcm-utils": "1.0.3", "big.js": "^6.2.1" }, diff --git a/packages/sdk/src/polkadot/PolkadotService.ts b/packages/sdk/src/polkadot/PolkadotService.ts index 4f374355..f45c1420 100644 --- a/packages/sdk/src/polkadot/PolkadotService.ts +++ b/packages/sdk/src/polkadot/PolkadotService.ts @@ -9,7 +9,6 @@ import { darwiniaPangoro, eq, equilibrium, - equilibriumAlphanet, paring, } from '@moonbeam-network/xcm-config'; import { @@ -74,10 +73,7 @@ export class PolkadotService { // TODO: Remove this once Equilibrium is updated // or find better way if issue appears on other chains - if ( - key === 'token' && - [equilibriumAlphanet.key, equilibrium.key].includes(this.chain.key) - ) { + if (key === 'token' && [equilibrium.key].includes(this.chain.key)) { return eq; } diff --git a/packages/types/CHANGELOG.md b/packages/types/CHANGELOG.md index 0eff6272..60b50754 100644 --- a/packages/types/CHANGELOG.md +++ b/packages/types/CHANGELOG.md @@ -1,5 +1,11 @@ # @moonbeam-network/xcm-types +## 1.0.2 + +### Patch Changes + +- [#184](https://github.com/PureStake/xcm-sdk/pull/184) [`88b6322`](https://github.com/PureStake/xcm-sdk/commit/88b6322327b30baa0fb2bf55f99497e2944c95ef) Thanks [@mmaurello](https://github.com/mmaurello)! - Use unlimited weight in all transactions for the xTokens pallet + ## 1.0.1 ### Patch Changes diff --git a/packages/types/package.json b/packages/types/package.json index 2bb5476e..162a3401 100644 --- a/packages/types/package.json +++ b/packages/types/package.json @@ -1,6 +1,6 @@ { "name": "@moonbeam-network/xcm-types", - "version": "1.0.1", + "version": "1.0.2", "description": "Moonbeam XCM Types", "scripts": { "build": "tsup", diff --git a/packages/types/src/chain/parachain/Parachain.ts b/packages/types/src/chain/parachain/Parachain.ts index b7f57950..03cb14ae 100644 --- a/packages/types/src/chain/parachain/Parachain.ts +++ b/packages/types/src/chain/parachain/Parachain.ts @@ -23,7 +23,7 @@ export class Parachain extends Chain { readonly ss58Format: number; - readonly weight: number; + readonly weight: number | undefined; readonly ws: string; @@ -46,7 +46,7 @@ export class Parachain extends Chain { this.genesisHash = genesisHash; this.parachainId = parachainId; this.ss58Format = ss58Format; - this.weight = weight ?? 1_000_000_000; + this.weight = weight; this.ws = ws; } diff --git a/scripts/check-websockets.ts b/scripts/check-websockets.ts new file mode 100644 index 00000000..9023cbe2 --- /dev/null +++ b/scripts/check-websockets.ts @@ -0,0 +1,100 @@ +/* eslint-disable import/no-extraneous-dependencies */ +/* eslint-disable no-console */ +import { chainsList } from '@moonbeam-network/xcm-config'; +import { IncomingWebhook } from '@slack/webhook'; +import WebSocket from 'ws'; + +function procesArgs() { + const args = process.argv; + const incudeTestChains = args.some((arg) => arg === '--include-test-chains'); + const slackWebhookArg = args.find((arg) => arg.startsWith('--slack-wh=')); + const webhookUrl = slackWebhookArg ? slackWebhookArg.split('=')[1] : ''; + return { incudeTestChains, webhookUrl }; +} + +async function checkWebSocketEndpoints( + endpoints: ChainEndpoint[], +): Promise<{ endpoint: ChainEndpoint; isAlive: boolean }[]> { + async function checkIsWebSocketAlive({ + chainKey, + ws: endpoint, + }: ChainEndpoint): Promise { + return new Promise((resolve) => { + const ws = new WebSocket(endpoint); + + let isAlive = false; + + ws.on('error', (error) => { + console.error( + `WebSocket ${chainKey} connection to ${endpoint} failed. Error: ${error.message}`, + ); + resolve(false); + }); + + ws.on('open', () => { + console.log( + `WebSocket ${chainKey} connection to ${endpoint} successful.`, + ); + isAlive = true; + ws.terminate(); + }); + + ws.on('close', () => { + resolve(isAlive); + }); + }); + } + + return Promise.all( + endpoints.map(async (endpoint) => { + const isAlive = await checkIsWebSocketAlive(endpoint); + + return { endpoint, isAlive }; + }), + ); +} + +const { incudeTestChains, webhookUrl } = procesArgs(); + +const webhook = new IncomingWebhook(webhookUrl); + +interface ChainEndpoint { + chainKey: string; + ws: string; +} + +const filteredChainList = incudeTestChains + ? chainsList + : chainsList.filter((chain) => !chain.isTestChain); + +const websocketEndpoints = filteredChainList.map(({ key, ws }) => ({ + chainKey: key, + ws, +})); + +if (incudeTestChains) { + console.log('Checking the endpoints of all chains, including test chains...'); +} + +checkWebSocketEndpoints(websocketEndpoints).then(async (results) => { + let output = ''; + + results.forEach(({ isAlive, endpoint: { chainKey, ws } }) => { + if (!isAlive) { + output += `\n${chainKey}: \`${ws}\`,`; + } + }); + + if (output) { + const text = `The following websocket endpoints from the XCM integrations in the dapp are not working, please review them: ${output}`; + + console.log(text); + if (webhookUrl) { + await webhook.send({ + text, + }); + } else { + console.warn('Slack webhook not detected, notification not sent'); + } + } +});