@autonomys/auto-utils 0.1.6-devnet-support → 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.
- package/dist/constants/network.d.ts +10 -0
- package/dist/constants/network.d.ts.map +1 -1
- package/dist/constants/network.js +29 -17
- package/dist/keyring.d.ts +3 -0
- package/dist/keyring.d.ts.map +1 -0
- package/dist/keyring.js +9 -0
- package/dist/types/parsing.d.ts +4 -0
- package/dist/types/parsing.d.ts.map +1 -0
- package/dist/types/parsing.js +2 -0
- package/dist/types/wallet.d.ts +4 -2
- package/dist/types/wallet.d.ts.map +1 -1
- package/dist/utils/signAndSendTx.d.ts +6 -1
- package/dist/utils/signAndSendTx.d.ts.map +1 -1
- package/dist/utils/signAndSendTx.js +29 -11
- package/package.json +3 -3
|
@@ -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,EAkF7B,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:
|
|
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: '
|
|
28
|
+
url: exports.ASTRAL_EXPLORER + 'gemini-3h/consensus/',
|
|
17
29
|
},
|
|
18
30
|
{
|
|
19
31
|
name: 'Subscan',
|
|
@@ -22,37 +34,37 @@ exports.networks = [
|
|
|
22
34
|
],
|
|
23
35
|
domains: [
|
|
24
36
|
{
|
|
25
|
-
id:
|
|
37
|
+
id: DomainId.AUTO_ID,
|
|
26
38
|
name: 'Autonomys - Auto-ID',
|
|
27
|
-
rpcUrls: ['wss://
|
|
39
|
+
rpcUrls: ['wss://autoid-0.gemini-3h.subspace.network/ws'],
|
|
28
40
|
},
|
|
29
41
|
{
|
|
30
|
-
id:
|
|
31
|
-
name: 'Autonomys -
|
|
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:
|
|
50
|
+
id: NetworkId.AUTONOMYS_DEVNET,
|
|
39
51
|
name: 'Autonomys - Devnet',
|
|
40
52
|
rpcUrls: ['ws://rpc.devnet.subspace.network/ws'],
|
|
41
53
|
explorer: [
|
|
42
54
|
{
|
|
43
55
|
name: 'Astral',
|
|
44
|
-
url: '
|
|
56
|
+
url: exports.ASTRAL_EXPLORER + '/devnet/consensus/',
|
|
45
57
|
},
|
|
46
58
|
],
|
|
47
59
|
domains: [
|
|
48
60
|
{
|
|
49
|
-
id:
|
|
61
|
+
id: DomainId.AUTO_ID,
|
|
50
62
|
name: 'Autonomys - Auto-ID',
|
|
51
63
|
rpcUrls: ['ws://autoid.devnet.subspace.network/ws'],
|
|
52
64
|
},
|
|
53
65
|
{
|
|
54
|
-
id:
|
|
55
|
-
name: 'Autonomys -
|
|
66
|
+
id: DomainId.NOVA,
|
|
67
|
+
name: 'Autonomys - Nova (EVM)',
|
|
56
68
|
rpcUrls: ['https:///nova.devnet.subspace.network/ws'],
|
|
57
69
|
},
|
|
58
70
|
],
|
|
@@ -60,24 +72,24 @@ exports.networks = [
|
|
|
60
72
|
isLocalhost: false,
|
|
61
73
|
},
|
|
62
74
|
{
|
|
63
|
-
id:
|
|
75
|
+
id: NetworkId.AUTONOMYS_LOCALHOST,
|
|
64
76
|
name: 'Autonomys - Localhost',
|
|
65
77
|
rpcUrls: ['ws://127.0.0.1:9944/ws'],
|
|
66
78
|
explorer: [
|
|
67
79
|
{
|
|
68
80
|
name: 'Astral',
|
|
69
|
-
url: '
|
|
81
|
+
url: exports.ASTRAL_EXPLORER + 'localhost/consensus/',
|
|
70
82
|
},
|
|
71
83
|
],
|
|
72
84
|
domains: [
|
|
73
85
|
{
|
|
74
|
-
id:
|
|
86
|
+
id: DomainId.AUTO_ID,
|
|
75
87
|
name: 'Autonomys - Auto-ID',
|
|
76
88
|
rpcUrls: ['ws://127.0.0.1:9945/ws'],
|
|
77
89
|
},
|
|
78
90
|
{
|
|
79
|
-
id:
|
|
80
|
-
name: 'Autonomys -
|
|
91
|
+
id: DomainId.NOVA,
|
|
92
|
+
name: 'Autonomys - Nova (EVM)',
|
|
81
93
|
rpcUrls: ['https:///127.0.0.1:9946/ws'],
|
|
82
94
|
},
|
|
83
95
|
],
|
|
@@ -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"}
|
package/dist/keyring.js
ADDED
|
@@ -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 @@
|
|
|
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"}
|
package/dist/types/wallet.d.ts
CHANGED
|
@@ -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
|
|
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;
|
|
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,
|
|
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
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
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
|
-
|
|
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.
|
|
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/
|
|
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": "
|
|
39
|
+
"gitHead": "c62ed7553ebb31c976f5be4932f3c7cde828a4ca"
|
|
40
40
|
}
|