@autonomys/auto-utils 0.1.6 → 0.1.7

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1,4 +1,14 @@
1
1
  import type { Network } from '../types/network';
2
+ export declare enum NetworkId {
3
+ AUTONOMYS_GEMINI_3H = "autonomys-gemini-3h",
4
+ AUTONOMYS_DEVNET = "autonomys-devnet",
5
+ AUTONOMYS_LOCALHOST = "autonomys-localhost"
6
+ }
7
+ export declare enum DomainId {
8
+ AUTO_ID = "auto-id",
9
+ NOVA = "nova"
10
+ }
11
+ export declare const ASTRAL_EXPLORER = "https://explorer.subspace.network/";
2
12
  export declare const networks: Network[];
3
13
  export declare const defaultNetwork: Network;
4
14
  //# sourceMappingURL=network.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"network.d.ts","sourceRoot":"","sources":["../../src/constants/network.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,kBAAkB,CAAA;AAE/C,eAAO,MAAM,QAAQ,EAAE,OAAO,EAyD7B,CAAA;AAED,eAAO,MAAM,cAAc,SAAc,CAAA"}
1
+ {"version":3,"file":"network.d.ts","sourceRoot":"","sources":["../../src/constants/network.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,kBAAkB,CAAA;AAE/C,oBAAY,SAAS;IACnB,mBAAmB,wBAAwB;IAC3C,gBAAgB,qBAAqB;IACrC,mBAAmB,wBAAwB;CAC5C;AAED,oBAAY,QAAQ;IAClB,OAAO,YAAY;IACnB,IAAI,SAAS;CACd;AAED,eAAO,MAAM,eAAe,uCAAuC,CAAA;AAEnE,eAAO,MAAM,QAAQ,EAAE,OAAO,EAkF7B,CAAA;AAED,eAAO,MAAM,cAAc,SAAc,CAAA"}
@@ -1,10 +1,22 @@
1
1
  "use strict";
2
2
  // file: src/constants/network.ts
3
3
  Object.defineProperty(exports, "__esModule", { value: true });
4
- exports.defaultNetwork = exports.networks = void 0;
4
+ exports.defaultNetwork = exports.networks = exports.ASTRAL_EXPLORER = exports.DomainId = exports.NetworkId = void 0;
5
+ var NetworkId;
6
+ (function (NetworkId) {
7
+ NetworkId["AUTONOMYS_GEMINI_3H"] = "autonomys-gemini-3h";
8
+ NetworkId["AUTONOMYS_DEVNET"] = "autonomys-devnet";
9
+ NetworkId["AUTONOMYS_LOCALHOST"] = "autonomys-localhost";
10
+ })(NetworkId || (exports.NetworkId = NetworkId = {}));
11
+ var DomainId;
12
+ (function (DomainId) {
13
+ DomainId["AUTO_ID"] = "auto-id";
14
+ DomainId["NOVA"] = "nova";
15
+ })(DomainId || (exports.DomainId = DomainId = {}));
16
+ exports.ASTRAL_EXPLORER = 'https://explorer.subspace.network/';
5
17
  exports.networks = [
6
18
  {
7
- id: 'autonomys-gemini-3h',
19
+ id: NetworkId.AUTONOMYS_GEMINI_3H,
8
20
  name: 'Autonomys Testnet - Gemini 3H',
9
21
  rpcUrls: [
10
22
  'wss://rpc-0.gemini-3h.subspace.network/ws',
@@ -13,7 +25,7 @@ exports.networks = [
13
25
  explorer: [
14
26
  {
15
27
  name: 'Astral',
16
- url: 'https://explorer.subspace.network/gemini-3h/consensus/',
28
+ url: exports.ASTRAL_EXPLORER + 'gemini-3h/consensus/',
17
29
  },
18
30
  {
19
31
  name: 'Subscan',
@@ -22,37 +34,62 @@ exports.networks = [
22
34
  ],
23
35
  domains: [
24
36
  {
25
- id: 'auto-id', // Placeholder
37
+ id: DomainId.AUTO_ID,
26
38
  name: 'Autonomys - Auto-ID',
27
- rpcUrls: ['wss://rpc.auto-id.subspace.network/ws'],
39
+ rpcUrls: ['wss://autoid-0.gemini-3h.subspace.network/ws'],
28
40
  },
29
41
  {
30
- id: 'auto-evm', // Placeholder
31
- name: 'Autonomys - Auto-EVM (Nova)',
42
+ id: DomainId.NOVA,
43
+ name: 'Autonomys - Nova (EVM)',
32
44
  rpcUrls: ['https://nova-0.gemini-3h.subspace.network/ws'],
33
45
  },
34
46
  ],
35
47
  isTestnet: true,
36
48
  },
37
49
  {
38
- id: 'autonomys-localhost',
50
+ id: NetworkId.AUTONOMYS_DEVNET,
51
+ name: 'Autonomys - Devnet',
52
+ rpcUrls: ['ws://rpc.devnet.subspace.network/ws'],
53
+ explorer: [
54
+ {
55
+ name: 'Astral',
56
+ url: exports.ASTRAL_EXPLORER + '/devnet/consensus/',
57
+ },
58
+ ],
59
+ domains: [
60
+ {
61
+ id: DomainId.AUTO_ID,
62
+ name: 'Autonomys - Auto-ID',
63
+ rpcUrls: ['ws://autoid.devnet.subspace.network/ws'],
64
+ },
65
+ {
66
+ id: DomainId.NOVA,
67
+ name: 'Autonomys - Nova (EVM)',
68
+ rpcUrls: ['https:///nova.devnet.subspace.network/ws'],
69
+ },
70
+ ],
71
+ isTestnet: true,
72
+ isLocalhost: false,
73
+ },
74
+ {
75
+ id: NetworkId.AUTONOMYS_LOCALHOST,
39
76
  name: 'Autonomys - Localhost',
40
77
  rpcUrls: ['ws://127.0.0.1:9944/ws'],
41
78
  explorer: [
42
79
  {
43
80
  name: 'Astral',
44
- url: 'https://explorer.subspace.network/localhost/consensus/',
81
+ url: exports.ASTRAL_EXPLORER + 'localhost/consensus/',
45
82
  },
46
83
  ],
47
84
  domains: [
48
85
  {
49
- id: 'auto-id', // Placeholder
86
+ id: DomainId.AUTO_ID,
50
87
  name: 'Autonomys - Auto-ID',
51
88
  rpcUrls: ['ws://127.0.0.1:9945/ws'],
52
89
  },
53
90
  {
54
- id: 'auto-evm', // Placeholder
55
- name: 'Autonomys - Auto-EVM (Nova)',
91
+ id: DomainId.NOVA,
92
+ name: 'Autonomys - Nova (EVM)',
56
93
  rpcUrls: ['https:///127.0.0.1:9946/ws'],
57
94
  },
58
95
  ],
@@ -0,0 +1,3 @@
1
+ import Keyring from '@polkadot/keyring';
2
+ export { Keyring };
3
+ //# sourceMappingURL=keyring.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"keyring.d.ts","sourceRoot":"","sources":["../src/keyring.ts"],"names":[],"mappings":"AAEA,OAAO,OAAO,MAAM,mBAAmB,CAAA;AAEvC,OAAO,EAAE,OAAO,EAAE,CAAA"}
@@ -0,0 +1,9 @@
1
+ "use strict";
2
+ // file: src/keyring.ts
3
+ var __importDefault = (this && this.__importDefault) || function (mod) {
4
+ return (mod && mod.__esModule) ? mod : { "default": mod };
5
+ };
6
+ Object.defineProperty(exports, "__esModule", { value: true });
7
+ exports.Keyring = void 0;
8
+ const keyring_1 = __importDefault(require("@polkadot/keyring"));
9
+ exports.Keyring = keyring_1.default;
@@ -0,0 +1,4 @@
1
+ import type { StorageKey } from '@polkadot/types';
2
+ import type { AnyTuple, Codec } from '@polkadot/types-codec/types';
3
+ export { AnyTuple, Codec, StorageKey };
4
+ //# sourceMappingURL=parsing.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"parsing.d.ts","sourceRoot":"","sources":["../../src/types/parsing.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAA;AACjD,OAAO,KAAK,EAAE,QAAQ,EAAE,KAAK,EAAE,MAAM,6BAA6B,CAAA;AAElE,OAAO,EAAE,QAAQ,EAAE,KAAK,EAAE,UAAU,EAAE,CAAA"}
@@ -0,0 +1,2 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
@@ -1,5 +1,5 @@
1
1
  import type { ApiPromise } from '@polkadot/api';
2
- import type { AddressOrPair, Signer, SignerResult } from '@polkadot/api/types';
2
+ import type { AddressOrPair, ApiDecoration, Signer, SignerResult } from '@polkadot/api/types';
3
3
  import type { InjectedAccountWithMeta } from '@polkadot/extension-inject/types';
4
4
  import type { KeyringPair } from '@polkadot/keyring/types';
5
5
  import type { DomainParams, NetworkParams } from './network';
@@ -29,5 +29,7 @@ export type WalletActivated = {
29
29
  accounts: InjectedAccountWithMeta[] & KeyringPair[];
30
30
  address: string;
31
31
  };
32
- export type { AddressOrPair, ApiPromise, InjectedAccountWithMeta, KeyringPair, Signer, SignerResult, };
32
+ export type ApiAtBlockHash = ApiDecoration<'promise'>;
33
+ export type Api = ApiPromise | ApiAtBlockHash;
34
+ export type { AddressOrPair, ApiDecoration, ApiPromise, InjectedAccountWithMeta, KeyringPair, Signer, SignerResult, };
33
35
  //# sourceMappingURL=wallet.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"wallet.d.ts","sourceRoot":"","sources":["../../src/types/wallet.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,eAAe,CAAA;AAC/C,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,EAAE,YAAY,EAAE,MAAM,qBAAqB,CAAA;AAC9E,OAAO,KAAK,EAAE,uBAAuB,EAAE,MAAM,kCAAkC,CAAA;AAC/E,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,yBAAyB,CAAA;AAC1D,OAAO,KAAK,EAAE,YAAY,EAAE,aAAa,EAAE,MAAM,WAAW,CAAA;AAE5D,MAAM,MAAM,QAAQ,GAAG;IACrB,QAAQ,EAAE,MAAM,CAAA;CACjB,CAAA;AAED,MAAM,MAAM,GAAG,GAAG;IAChB,GAAG,EAAE,MAAM,CAAA;CACZ,CAAA;AAED,MAAM,MAAM,sBAAsB,GAAG;IACnC,OAAO,CAAC,EAAE,MAAM,CAAA;IAChB,GAAG,CAAC,EAAE,UAAU,CAAA;CACjB,CAAA;AAED,MAAM,MAAM,aAAa,GAAG,QAAQ,GAAG,GAAG,CAAA;AAE1C,MAAM,MAAM,MAAM,GAAG;IACnB,WAAW,CAAC,EAAE,WAAW,CAAA;IACzB,eAAe,CAAC,EAAE,uBAAuB,CAAA;IACzC,OAAO,EAAE,MAAM,CAAA;IACf,aAAa,EAAE,MAAM,CAAA;CACtB,CAAA;AAED,MAAM,WAAW,eAAgB,SAAQ,MAAM;IAC7C,QAAQ,EAAE,MAAM,CAAA;CACjB;AAED,MAAM,MAAM,oBAAoB,GAAG,CAAC,aAAa,GAAG,YAAY,CAAC,GAC/D,aAAa,GACb,sBAAsB,CAAA;AAExB,MAAM,MAAM,eAAe,GAAG;IAC5B,GAAG,EAAE,UAAU,CAAA;IACf,QAAQ,EAAE,uBAAuB,EAAE,GAAG,WAAW,EAAE,CAAA;IACnD,OAAO,EAAE,MAAM,CAAA;CAChB,CAAA;AAED,YAAY,EACV,aAAa,EACb,UAAU,EACV,uBAAuB,EACvB,WAAW,EACX,MAAM,EACN,YAAY,GACb,CAAA"}
1
+ {"version":3,"file":"wallet.d.ts","sourceRoot":"","sources":["../../src/types/wallet.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,eAAe,CAAA;AAC/C,OAAO,KAAK,EAAE,aAAa,EAAE,aAAa,EAAE,MAAM,EAAE,YAAY,EAAE,MAAM,qBAAqB,CAAA;AAC7F,OAAO,KAAK,EAAE,uBAAuB,EAAE,MAAM,kCAAkC,CAAA;AAC/E,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,yBAAyB,CAAA;AAC1D,OAAO,KAAK,EAAE,YAAY,EAAE,aAAa,EAAE,MAAM,WAAW,CAAA;AAE5D,MAAM,MAAM,QAAQ,GAAG;IACrB,QAAQ,EAAE,MAAM,CAAA;CACjB,CAAA;AAED,MAAM,MAAM,GAAG,GAAG;IAChB,GAAG,EAAE,MAAM,CAAA;CACZ,CAAA;AAED,MAAM,MAAM,sBAAsB,GAAG;IACnC,OAAO,CAAC,EAAE,MAAM,CAAA;IAChB,GAAG,CAAC,EAAE,UAAU,CAAA;CACjB,CAAA;AAED,MAAM,MAAM,aAAa,GAAG,QAAQ,GAAG,GAAG,CAAA;AAE1C,MAAM,MAAM,MAAM,GAAG;IACnB,WAAW,CAAC,EAAE,WAAW,CAAA;IACzB,eAAe,CAAC,EAAE,uBAAuB,CAAA;IACzC,OAAO,EAAE,MAAM,CAAA;IACf,aAAa,EAAE,MAAM,CAAA;CACtB,CAAA;AAED,MAAM,WAAW,eAAgB,SAAQ,MAAM;IAC7C,QAAQ,EAAE,MAAM,CAAA;CACjB;AAED,MAAM,MAAM,oBAAoB,GAAG,CAAC,aAAa,GAAG,YAAY,CAAC,GAC/D,aAAa,GACb,sBAAsB,CAAA;AAExB,MAAM,MAAM,eAAe,GAAG;IAC5B,GAAG,EAAE,UAAU,CAAA;IACf,QAAQ,EAAE,uBAAuB,EAAE,GAAG,WAAW,EAAE,CAAA;IACnD,OAAO,EAAE,MAAM,CAAA;CAChB,CAAA;AAED,MAAM,MAAM,cAAc,GAAG,aAAa,CAAC,SAAS,CAAC,CAAA;AAErD,MAAM,MAAM,GAAG,GAAG,UAAU,GAAG,cAAc,CAAA;AAE7C,YAAY,EACV,aAAa,EACb,aAAa,EACb,UAAU,EACV,uBAAuB,EACvB,WAAW,EACX,MAAM,EACN,YAAY,GACb,CAAA"}
@@ -1,3 +1,8 @@
1
+ import type { SubmittableResult } from '@polkadot/api';
2
+ import { KeyringPair } from '@polkadot/keyring/types';
1
3
  import type { AddressOrPair, Events, ISubmittableResult, SignerOptions, SubmittableExtrinsic, TransactionSignedAndSend } from '../types';
2
- export declare const signAndSendTx: (sender: AddressOrPair, tx: SubmittableExtrinsic<'promise', ISubmittableResult>, options?: Partial<SignerOptions>, eventsExpected?: Events, log?: boolean) => Promise<TransactionSignedAndSend>;
4
+ export declare const signAndSendTx: <TError>(sender: AddressOrPair | KeyringPair, tx: SubmittableExtrinsic<'promise', ISubmittableResult>, options?: Partial<SignerOptions>, eventsExpected?: Events, log?: boolean, mapErrorCodeToEnum?: (errorCode: string) => TError | undefined) => Promise<TransactionSignedAndSend & {
5
+ receipt: SubmittableResult;
6
+ identifier?: string | null;
7
+ }>;
3
8
  //# sourceMappingURL=signAndSendTx.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"signAndSendTx.d.ts","sourceRoot":"","sources":["../../src/utils/signAndSendTx.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EACV,aAAa,EACb,MAAM,EAEN,kBAAkB,EAClB,aAAa,EACb,oBAAoB,EACpB,wBAAwB,EACzB,MAAM,UAAU,CAAA;AAKjB,eAAO,MAAM,aAAa,WAChB,aAAa,MACjB,qBAAqB,SAAS,EAAE,kBAAkB,CAAC,YAC9C,QAAQ,aAAa,CAAC,mBACf,MAAM,QACjB,OAAO,KACX,QAAQ,wBAAwB,CAgClC,CAAA"}
1
+ {"version":3,"file":"signAndSendTx.d.ts","sourceRoot":"","sources":["../../src/utils/signAndSendTx.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAc,iBAAiB,EAAE,MAAM,eAAe,CAAA;AAClE,OAAO,EAAE,WAAW,EAAE,MAAM,yBAAyB,CAAA;AACrD,OAAO,KAAK,EACV,aAAa,EACb,MAAM,EAEN,kBAAkB,EAClB,aAAa,EACb,oBAAoB,EACpB,wBAAwB,EACzB,MAAM,UAAU,CAAA;AAKjB,eAAO,MAAM,aAAa,mBAChB,aAAa,GAAG,WAAW,MAC/B,qBAAqB,SAAS,EAAE,kBAAkB,CAAC,YAC9C,QAAQ,aAAa,CAAC,mBACf,MAAM,QACjB,OAAO,uBACS,CAAC,SAAS,EAAE,MAAM,KAAK,MAAM,GAAG,SAAS,KAC7D,QACD,wBAAwB,GAAG;IAAE,OAAO,EAAE,iBAAiB,CAAC;IAAC,UAAU,CAAC,EAAE,MAAM,GAAG,IAAI,CAAA;CAAE,CAyDtF,CAAA"}
@@ -14,28 +14,46 @@ exports.signAndSendTx = void 0;
14
14
  const detectTxSuccess_1 = require("./detectTxSuccess");
15
15
  const events_1 = require("./events");
16
16
  const validateEvents_1 = require("./validateEvents");
17
- const signAndSendTx = (sender_1, tx_1, ...args_1) => __awaiter(void 0, [sender_1, tx_1, ...args_1], void 0, function* (sender, tx, options = {}, eventsExpected = events_1.expectSuccessfulTxEvent, log = false) {
17
+ const signAndSendTx = (sender_1, tx_1, ...args_1) => __awaiter(void 0, [sender_1, tx_1, ...args_1], void 0, function* (sender, tx, options = {}, eventsExpected = events_1.expectSuccessfulTxEvent, log = false, mapErrorCodeToEnum) {
18
18
  let success = false;
19
19
  let txHashHex = undefined;
20
20
  let blockHash = undefined;
21
21
  let eventsValidated = { expected: [], found: [] };
22
- yield new Promise((resolve, reject) => {
23
- tx.signAndSend(sender, options, ({ events, status, txHash }) => {
24
- if (status.isInBlock) {
25
- txHashHex = txHash.toHex();
26
- blockHash = status.asInBlock.toHex();
22
+ let identifier = null;
23
+ const receipt = yield new Promise((resolve, reject) => {
24
+ tx.signAndSend(sender, options, (result) => __awaiter(void 0, void 0, void 0, function* () {
25
+ const { events = [], status, dispatchError } = result;
26
+ if (status.isInBlock || status.isFinalized) {
27
+ txHashHex = result.txHash.toHex();
28
+ blockHash = status.isInBlock ? status.asInBlock.toHex() : status.asFinalized.toHex();
27
29
  if (log)
28
30
  console.log('Successful tx', txHashHex, 'in block', blockHash);
29
31
  success = (0, detectTxSuccess_1.detectTxSuccess)(events);
30
32
  if (eventsExpected.length > 0) {
31
33
  const _events = (0, validateEvents_1.validateEvents)(events, eventsExpected, txHashHex, blockHash, log);
32
34
  if (_events.expected.length === 0)
33
- resolve();
35
+ resolve(result);
34
36
  else
35
37
  reject(new Error('Events not found'));
36
38
  }
37
- else
38
- resolve();
39
+ else {
40
+ try {
41
+ events.forEach(({ event: { section, method, data } }) => {
42
+ if (section === 'system' && method === 'ExtrinsicFailed') {
43
+ const dispatchErrorJson = JSON.parse(dispatchError.toString());
44
+ const errorEnum = mapErrorCodeToEnum === null || mapErrorCodeToEnum === void 0 ? void 0 : mapErrorCodeToEnum(dispatchErrorJson.module.error);
45
+ reject(new Error(`Extrinsic failed: ${errorEnum} in block #${blockHash} with error: ${dispatchErrorJson}`));
46
+ }
47
+ if (section === 'autoId' && method === 'NewAutoIdRegistered') {
48
+ identifier = data[0].toString();
49
+ }
50
+ });
51
+ resolve(result);
52
+ }
53
+ catch (err) {
54
+ reject(new Error(`Failed to retrieve block information: ${err.message}`));
55
+ }
56
+ }
39
57
  }
40
58
  else if (status.isRetracted ||
41
59
  status.isFinalityTimeout ||
@@ -45,8 +63,8 @@ const signAndSendTx = (sender_1, tx_1, ...args_1) => __awaiter(void 0, [sender_1
45
63
  console.error('Transaction failed');
46
64
  reject(new Error('Transaction failed'));
47
65
  }
48
- });
66
+ }));
49
67
  });
50
- return { success, txHash: txHashHex, blockHash, events: eventsValidated };
68
+ return { success, txHash: txHashHex, blockHash, events: eventsValidated, receipt, identifier };
51
69
  });
52
70
  exports.signAndSendTx = signAndSendTx;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@autonomys/auto-utils",
3
- "version": "0.1.6",
3
+ "version": "0.1.7",
4
4
  "main": "dist/index.js",
5
5
  "scripts": {
6
6
  "build": "tsc",
@@ -27,7 +27,7 @@
27
27
  },
28
28
  "repository": {
29
29
  "type": "git",
30
- "url": "https://github.com/subspace/auto-sdk"
30
+ "url": "https://github.com/autonomys/auto-sdk"
31
31
  },
32
32
  "author": {
33
33
  "name": "Autonomys",
@@ -36,5 +36,5 @@
36
36
  "browser": {
37
37
  "fs": false
38
38
  },
39
- "gitHead": "eb9ee6dc6987a47bebb38c9ed073c4b99440a920"
39
+ "gitHead": "c62ed7553ebb31c976f5be4932f3c7cde828a4ca"
40
40
  }