@bitgo-beta/sdk-coin-iota 1.0.1-beta.32 → 1.0.1-beta.321
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/README.md +1 -1
- package/dist/src/iota.d.ts +13 -2
- package/dist/src/iota.d.ts.map +1 -1
- package/dist/src/iota.js +142 -22
- package/dist/src/lib/constants.d.ts +10 -6
- package/dist/src/lib/constants.d.ts.map +1 -1
- package/dist/src/lib/constants.js +12 -8
- package/dist/src/lib/iface.d.ts +33 -1
- package/dist/src/lib/iface.d.ts.map +1 -1
- package/dist/src/lib/iface.js +1 -1
- package/dist/src/lib/index.d.ts +1 -0
- package/dist/src/lib/index.d.ts.map +1 -1
- package/dist/src/lib/index.js +4 -2
- package/dist/src/lib/transaction.d.ts +72 -5
- package/dist/src/lib/transaction.d.ts.map +1 -1
- package/dist/src/lib/transaction.js +270 -6
- package/dist/src/lib/transactionBuilder.d.ts +70 -9
- package/dist/src/lib/transactionBuilder.d.ts.map +1 -1
- package/dist/src/lib/transactionBuilder.js +155 -14
- package/dist/src/lib/transactionBuilderFactory.d.ts +15 -2
- package/dist/src/lib/transactionBuilderFactory.d.ts.map +1 -1
- package/dist/src/lib/transactionBuilderFactory.js +45 -5
- package/dist/src/lib/transferBuilder.d.ts +10 -2
- package/dist/src/lib/transferBuilder.d.ts.map +1 -1
- package/dist/src/lib/transferBuilder.js +45 -3
- package/dist/src/lib/transferTransaction.d.ts +28 -0
- package/dist/src/lib/transferTransaction.d.ts.map +1 -0
- package/dist/src/lib/transferTransaction.js +173 -0
- package/dist/src/lib/utils.d.ts +2 -0
- package/dist/src/lib/utils.d.ts.map +1 -1
- package/dist/src/lib/utils.js +28 -4
- package/dist/test/resources/iota.d.ts +35 -0
- package/dist/test/resources/iota.d.ts.map +1 -0
- package/dist/test/resources/iota.js +93 -0
- package/dist/test/unit/index.d.ts +2 -0
- package/dist/test/unit/index.d.ts.map +1 -0
- package/dist/test/unit/index.js +16 -0
- package/dist/test/unit/iota.d.ts +2 -0
- package/dist/test/unit/iota.d.ts.map +1 -0
- package/dist/test/unit/iota.js +603 -0
- package/dist/test/unit/keyPair.d.ts +2 -0
- package/dist/test/unit/keyPair.d.ts.map +1 -0
- package/dist/test/unit/keyPair.js +135 -0
- package/dist/test/unit/transactionBuilder/transactionBuilder.d.ts +2 -0
- package/dist/test/unit/transactionBuilder/transactionBuilder.d.ts.map +1 -0
- package/dist/test/unit/transactionBuilder/transactionBuilder.js +306 -0
- package/dist/test/unit/transactionBuilder/transactionBuilderFactory.d.ts +2 -0
- package/dist/test/unit/transactionBuilder/transactionBuilderFactory.d.ts.map +1 -0
- package/dist/test/unit/transactionBuilder/transactionBuilderFactory.js +243 -0
- package/dist/test/unit/transactionBuilder/transferBuilder.d.ts +2 -0
- package/dist/test/unit/transactionBuilder/transferBuilder.d.ts.map +1 -0
- package/dist/test/unit/transactionBuilder/transferBuilder.js +400 -0
- package/dist/test/unit/transferTransaction.d.ts +2 -0
- package/dist/test/unit/transferTransaction.d.ts.map +1 -0
- package/dist/test/unit/transferTransaction.js +465 -0
- package/dist/test/unit/utils.d.ts +2 -0
- package/dist/test/unit/utils.d.ts.map +1 -0
- package/dist/test/unit/utils.js +278 -0
- package/dist/tsconfig.tsbuildinfo +1 -0
- package/package.json +16 -10
- package/.eslintignore +0 -5
- package/.mocharc.yml +0 -8
- package/CHANGELOG.md +0 -0
package/README.md
CHANGED
|
@@ -36,4 +36,4 @@ const iota = sdk.coin('iota');
|
|
|
36
36
|
|
|
37
37
|
## Documentation
|
|
38
38
|
|
|
39
|
-
For detailed API documentation,
|
|
39
|
+
For detailed API documentation, view the BitGo [Developer Portal](https://developers.bitgo.com/reference/overview#/).
|
package/dist/src/iota.d.ts
CHANGED
|
@@ -1,5 +1,6 @@
|
|
|
1
|
-
import { AuditDecryptedKeyParams, BaseCoin, BitGoBase, KeyPair,
|
|
1
|
+
import { AuditDecryptedKeyParams, BaseCoin, BitGoBase, KeyPair, ParsedTransaction, SignTransactionOptions, SignedTransaction, VerifyTransactionOptions, MultisigType, MPCAlgorithm, TssVerifyAddressOptions, PopulatedIntent, PrebuildTransactionWithIntentOptions } from '@bitgo-beta/sdk-core';
|
|
2
2
|
import { BaseCoin as StaticsBaseCoin, CoinFamily } from '@bitgo-beta/statics';
|
|
3
|
+
import { ExplainTransactionOptions, IotaParseTransactionOptions, TransactionExplanation } from './lib/iface';
|
|
3
4
|
export declare class Iota extends BaseCoin {
|
|
4
5
|
protected readonly _staticsCoin: Readonly<StaticsBaseCoin>;
|
|
5
6
|
protected constructor(bitgo: BitGoBase, staticsCoin?: Readonly<StaticsBaseCoin>);
|
|
@@ -19,6 +20,10 @@ export declare class Iota extends BaseCoin {
|
|
|
19
20
|
* @returns true if the address is valid
|
|
20
21
|
*/
|
|
21
22
|
isValidAddress(address: string): boolean;
|
|
23
|
+
/**
|
|
24
|
+
* @inheritDoc
|
|
25
|
+
*/
|
|
26
|
+
explainTransaction(params: ExplainTransactionOptions): Promise<TransactionExplanation>;
|
|
22
27
|
/**
|
|
23
28
|
* Verifies that a transaction prebuild complies with the original intention
|
|
24
29
|
* @param params
|
|
@@ -33,7 +38,7 @@ export declare class Iota extends BaseCoin {
|
|
|
33
38
|
* Parse a transaction
|
|
34
39
|
* @param params
|
|
35
40
|
*/
|
|
36
|
-
parseTransaction(params:
|
|
41
|
+
parseTransaction(params: IotaParseTransactionOptions): Promise<ParsedTransaction>;
|
|
37
42
|
/**
|
|
38
43
|
* Generate a key pair
|
|
39
44
|
* @param seed Optional seed to generate key pair from
|
|
@@ -54,5 +59,11 @@ export declare class Iota extends BaseCoin {
|
|
|
54
59
|
* @param params
|
|
55
60
|
*/
|
|
56
61
|
auditDecryptedKey({ multiSigType, prv, publicKey }: AuditDecryptedKeyParams): void;
|
|
62
|
+
/** @inheritDoc */
|
|
63
|
+
getSignablePayload(serializedTx: string): Promise<Buffer>;
|
|
64
|
+
/** inherited doc */
|
|
65
|
+
setCoinSpecificFieldsInIntent(intent: PopulatedIntent, params: PrebuildTransactionWithIntentOptions): void;
|
|
66
|
+
private getTxBuilderFactory;
|
|
67
|
+
private rebuildTransaction;
|
|
57
68
|
}
|
|
58
69
|
//# sourceMappingURL=iota.d.ts.map
|
package/dist/src/iota.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"iota.d.ts","sourceRoot":"","sources":["../../src/iota.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,uBAAuB,EACvB,QAAQ,EACR,SAAS,EACT,OAAO,EACP,
|
|
1
|
+
{"version":3,"file":"iota.d.ts","sourceRoot":"","sources":["../../src/iota.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,uBAAuB,EACvB,QAAQ,EACR,SAAS,EACT,OAAO,EACP,iBAAiB,EACjB,sBAAsB,EACtB,iBAAiB,EACjB,wBAAwB,EACxB,YAAY,EAEZ,YAAY,EACZ,uBAAuB,EAEvB,eAAe,EACf,oCAAoC,EAGrC,MAAM,sBAAsB,CAAC;AAC9B,OAAO,EAAE,QAAQ,IAAI,eAAe,EAAE,UAAU,EAAS,MAAM,qBAAqB,CAAC;AAMrF,OAAO,EACL,yBAAyB,EACzB,2BAA2B,EAC3B,sBAAsB,EAEvB,MAAM,aAAa,CAAC;AAGrB,qBAAa,IAAK,SAAQ,QAAQ;IAChC,SAAS,CAAC,QAAQ,CAAC,YAAY,EAAE,QAAQ,CAAC,eAAe,CAAC,CAAC;IAE3D,SAAS,aAAa,KAAK,EAAE,SAAS,EAAE,WAAW,CAAC,EAAE,QAAQ,CAAC,eAAe,CAAC;IAU/E,MAAM,CAAC,cAAc,CAAC,KAAK,EAAE,SAAS,EAAE,WAAW,CAAC,EAAE,QAAQ,CAAC,eAAe,CAAC,GAAG,QAAQ;IAI1F,aAAa,IAAI,MAAM,GAAG,MAAM;IAIhC,QAAQ;IAIR,SAAS,IAAI,UAAU;IAIvB,WAAW;IAIX,kBAAkB;IAClB,WAAW,IAAI,OAAO;IAItB,oBAAoB;IACpB,sBAAsB,IAAI,YAAY;IAItC,eAAe,IAAI,YAAY;IAI/B;;;;OAIG;IACH,cAAc,CAAC,OAAO,EAAE,MAAM,GAAG,OAAO;IAKxC;;OAEG;IACG,kBAAkB,CAAC,MAAM,EAAE,yBAAyB,GAAG,OAAO,CAAC,sBAAsB,CAAC;IAY5F;;;OAGG;IACG,iBAAiB,CAAC,MAAM,EAAE,wBAAwB,GAAG,OAAO,CAAC,OAAO,CAAC;IAoC3E;;;OAGG;IACG,eAAe,CAAC,MAAM,EAAE,uBAAuB,GAAG,OAAO,CAAC,OAAO,CAAC;IAQxE;;;OAGG;IACG,gBAAgB,CAAC,MAAM,EAAE,2BAA2B,GAAG,OAAO,CAAC,iBAAiB,CAAC;IAwDvF;;;OAGG;IACH,eAAe,CAAC,IAAI,CAAC,EAAE,MAAM,GAAG,OAAO;IAYvC;;;OAGG;IACH,UAAU,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO;IAIhC;;;OAGG;IACG,eAAe,CAAC,MAAM,EAAE,sBAAsB,GAAG,OAAO,CAAC,iBAAiB,CAAC;IAIjF;;;OAGG;IACH,iBAAiB,CAAC,EAAE,YAAY,EAAE,GAAG,EAAE,SAAS,EAAE,EAAE,uBAAuB,GAAG,IAAI;IAOlF,kBAAkB;IACZ,kBAAkB,CAAC,YAAY,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC;IAK/D,oBAAoB;IACpB,6BAA6B,CAAC,MAAM,EAAE,eAAe,EAAE,MAAM,EAAE,oCAAoC,GAAG,IAAI;IAI1G,OAAO,CAAC,mBAAmB;YAIb,kBAAkB;CASjC"}
|
package/dist/src/iota.js
CHANGED
|
@@ -1,13 +1,50 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || (function () {
|
|
19
|
+
var ownKeys = function(o) {
|
|
20
|
+
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
21
|
+
var ar = [];
|
|
22
|
+
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
23
|
+
return ar;
|
|
24
|
+
};
|
|
25
|
+
return ownKeys(o);
|
|
26
|
+
};
|
|
27
|
+
return function (mod) {
|
|
28
|
+
if (mod && mod.__esModule) return mod;
|
|
29
|
+
var result = {};
|
|
30
|
+
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
31
|
+
__setModuleDefault(result, mod);
|
|
32
|
+
return result;
|
|
33
|
+
};
|
|
34
|
+
})();
|
|
2
35
|
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
36
|
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
37
|
};
|
|
5
38
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
39
|
exports.Iota = void 0;
|
|
7
40
|
const sdk_core_1 = require("@bitgo-beta/sdk-core");
|
|
41
|
+
const statics_1 = require("@bitgo-beta/statics");
|
|
8
42
|
const utils_1 = __importDefault(require("./lib/utils"));
|
|
9
43
|
const lib_1 = require("./lib");
|
|
10
44
|
const sdk_lib_mpc_1 = require("@bitgo-beta/sdk-lib-mpc");
|
|
45
|
+
const bignumber_js_1 = __importDefault(require("bignumber.js"));
|
|
46
|
+
const _ = __importStar(require("lodash"));
|
|
47
|
+
const transferTransaction_1 = require("./lib/transferTransaction");
|
|
11
48
|
class Iota extends sdk_core_1.BaseCoin {
|
|
12
49
|
constructor(bitgo, staticsCoin) {
|
|
13
50
|
super(bitgo);
|
|
@@ -51,12 +88,50 @@ class Iota extends sdk_core_1.BaseCoin {
|
|
|
51
88
|
// IOTA addresses are 64-character hex strings
|
|
52
89
|
return utils_1.default.isValidAddress(address);
|
|
53
90
|
}
|
|
91
|
+
/**
|
|
92
|
+
* @inheritDoc
|
|
93
|
+
*/
|
|
94
|
+
async explainTransaction(params) {
|
|
95
|
+
const rawTx = params.txHex;
|
|
96
|
+
if (!rawTx) {
|
|
97
|
+
throw new Error('missing required tx prebuild property txHex');
|
|
98
|
+
}
|
|
99
|
+
const transaction = await this.rebuildTransaction(rawTx);
|
|
100
|
+
if (!transaction) {
|
|
101
|
+
throw new Error('failed to explain transaction');
|
|
102
|
+
}
|
|
103
|
+
return transaction.explainTransaction();
|
|
104
|
+
}
|
|
54
105
|
/**
|
|
55
106
|
* Verifies that a transaction prebuild complies with the original intention
|
|
56
107
|
* @param params
|
|
57
108
|
*/
|
|
58
109
|
async verifyTransaction(params) {
|
|
59
|
-
|
|
110
|
+
const { txPrebuild: txPrebuild, txParams: txParams } = params;
|
|
111
|
+
const rawTx = txPrebuild.txHex;
|
|
112
|
+
if (!rawTx) {
|
|
113
|
+
throw new Error('missing required tx prebuild property txHex');
|
|
114
|
+
}
|
|
115
|
+
const transaction = await this.rebuildTransaction(rawTx);
|
|
116
|
+
if (!transaction) {
|
|
117
|
+
throw new Error('failed to verify transaction');
|
|
118
|
+
}
|
|
119
|
+
if (txParams.recipients !== undefined) {
|
|
120
|
+
if (!(transaction instanceof transferTransaction_1.TransferTransaction)) {
|
|
121
|
+
throw new Error('Tx not a transfer transaction');
|
|
122
|
+
}
|
|
123
|
+
const txData = transaction.toJson();
|
|
124
|
+
if (!txData.recipients) {
|
|
125
|
+
throw new Error('Tx recipients does not match with expected txParams recipients');
|
|
126
|
+
}
|
|
127
|
+
const normalizeRecipient = (recipient) => _.pick(recipient, ['address', 'amount', 'tokenName']);
|
|
128
|
+
const txDataRecipients = txData.recipients.map(normalizeRecipient);
|
|
129
|
+
const txParamsRecipients = txParams.recipients.map(normalizeRecipient);
|
|
130
|
+
const allRecipientsMatch = txParamsRecipients.every((expectedRecipient) => txDataRecipients.some((actualRecipient) => _.isEqual(expectedRecipient, actualRecipient)));
|
|
131
|
+
if (!allRecipientsMatch) {
|
|
132
|
+
throw new Error('Tx recipients does not match with expected txParams recipients');
|
|
133
|
+
}
|
|
134
|
+
}
|
|
60
135
|
return true;
|
|
61
136
|
}
|
|
62
137
|
/**
|
|
@@ -64,32 +139,55 @@ class Iota extends sdk_core_1.BaseCoin {
|
|
|
64
139
|
* @param params
|
|
65
140
|
*/
|
|
66
141
|
async isWalletAddress(params) {
|
|
67
|
-
|
|
68
|
-
if (!this.isValidAddress(address)) {
|
|
69
|
-
throw new sdk_core_1.InvalidAddressError(`invalid address: ${address}`);
|
|
70
|
-
}
|
|
71
|
-
if (!keychains) {
|
|
72
|
-
throw new Error('missing required param keychains');
|
|
73
|
-
}
|
|
74
|
-
for (const keychain of keychains) {
|
|
75
|
-
const MPC = await sdk_core_1.EDDSAMethods.getInitializedMpcInstance();
|
|
76
|
-
const commonKeychain = keychain.commonKeychain;
|
|
77
|
-
const derivationPath = 'm/' + index;
|
|
78
|
-
const derivedPublicKey = MPC.deriveUnhardened(commonKeychain, derivationPath).slice(0, 64);
|
|
79
|
-
const expectedAddress = utils_1.default.getAddressFromPublicKey(derivedPublicKey);
|
|
80
|
-
if (address !== expectedAddress) {
|
|
81
|
-
return false;
|
|
82
|
-
}
|
|
83
|
-
}
|
|
84
|
-
return true;
|
|
142
|
+
return (0, sdk_core_1.verifyEddsaTssWalletAddress)(params, (address) => this.isValidAddress(address), (publicKey) => utils_1.default.getAddressFromPublicKey(publicKey));
|
|
85
143
|
}
|
|
86
144
|
/**
|
|
87
145
|
* Parse a transaction
|
|
88
146
|
* @param params
|
|
89
147
|
*/
|
|
90
148
|
async parseTransaction(params) {
|
|
91
|
-
|
|
92
|
-
|
|
149
|
+
const transactionExplanation = await this.explainTransaction({ txHex: params.txHex });
|
|
150
|
+
if (!transactionExplanation) {
|
|
151
|
+
throw new Error('Invalid transaction');
|
|
152
|
+
}
|
|
153
|
+
let fee = new bignumber_js_1.default(0);
|
|
154
|
+
if (transactionExplanation.outputs.length <= 0) {
|
|
155
|
+
return {
|
|
156
|
+
inputs: [],
|
|
157
|
+
outputs: [],
|
|
158
|
+
fee,
|
|
159
|
+
};
|
|
160
|
+
}
|
|
161
|
+
const senderAddress = transactionExplanation.outputs[0].address;
|
|
162
|
+
if (transactionExplanation.fee.fee !== '') {
|
|
163
|
+
fee = new bignumber_js_1.default(transactionExplanation.fee.fee);
|
|
164
|
+
}
|
|
165
|
+
const outputAmount = transactionExplanation.sponsor
|
|
166
|
+
? new bignumber_js_1.default(transactionExplanation.outputAmount).toFixed()
|
|
167
|
+
: new bignumber_js_1.default(transactionExplanation.outputAmount).plus(fee).toFixed(); // assume 1 sender, who is also the fee payer
|
|
168
|
+
const inputs = [
|
|
169
|
+
{
|
|
170
|
+
address: senderAddress,
|
|
171
|
+
amount: outputAmount,
|
|
172
|
+
},
|
|
173
|
+
];
|
|
174
|
+
if (transactionExplanation.sponsor) {
|
|
175
|
+
inputs.push({
|
|
176
|
+
address: transactionExplanation.sponsor,
|
|
177
|
+
amount: fee.toFixed(),
|
|
178
|
+
});
|
|
179
|
+
}
|
|
180
|
+
const outputs = transactionExplanation.outputs.map((output) => {
|
|
181
|
+
return {
|
|
182
|
+
address: output.address,
|
|
183
|
+
amount: new bignumber_js_1.default(output.amount).toFixed(),
|
|
184
|
+
};
|
|
185
|
+
});
|
|
186
|
+
return {
|
|
187
|
+
inputs,
|
|
188
|
+
outputs,
|
|
189
|
+
fee,
|
|
190
|
+
};
|
|
93
191
|
}
|
|
94
192
|
/**
|
|
95
193
|
* Generate a key pair
|
|
@@ -130,6 +228,28 @@ class Iota extends sdk_core_1.BaseCoin {
|
|
|
130
228
|
}
|
|
131
229
|
(0, sdk_lib_mpc_1.auditEddsaPrivateKey)(prv, publicKey ?? '');
|
|
132
230
|
}
|
|
231
|
+
/** @inheritDoc */
|
|
232
|
+
async getSignablePayload(serializedTx) {
|
|
233
|
+
const rebuiltTransaction = await this.rebuildTransaction(serializedTx);
|
|
234
|
+
return rebuiltTransaction.signablePayload;
|
|
235
|
+
}
|
|
236
|
+
/** inherited doc */
|
|
237
|
+
setCoinSpecificFieldsInIntent(intent, params) {
|
|
238
|
+
intent.unspents = params.unspents;
|
|
239
|
+
}
|
|
240
|
+
getTxBuilderFactory() {
|
|
241
|
+
return new lib_1.TransactionBuilderFactory(statics_1.coins.get(this.getChain()));
|
|
242
|
+
}
|
|
243
|
+
async rebuildTransaction(txHex) {
|
|
244
|
+
const txBuilderFactory = this.getTxBuilderFactory();
|
|
245
|
+
try {
|
|
246
|
+
const txBuilder = txBuilderFactory.from(txHex);
|
|
247
|
+
return (await txBuilder.build());
|
|
248
|
+
}
|
|
249
|
+
catch (err) {
|
|
250
|
+
throw new Error(`Failed to rebuild transaction ${err.toString()}`);
|
|
251
|
+
}
|
|
252
|
+
}
|
|
133
253
|
}
|
|
134
254
|
exports.Iota = Iota;
|
|
135
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"iota.js","sourceRoot":"","sources":["../../src/iota.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  AuditDecryptedKeyParams,\n  BaseCoin,\n  BitGoBase,\n  KeyPair,\n  ParseTransactionOptions,\n  ParsedTransaction,\n  SignTransactionOptions,\n  SignedTransaction,\n  VerifyTransactionOptions,\n  MultisigType,\n  multisigTypes,\n  MPCAlgorithm,\n  InvalidAddressError,\n  EDDSAMethods,\n  TssVerifyAddressOptions,\n  MPCType,\n} from '@bitgo-beta/sdk-core';\nimport { BaseCoin as StaticsBaseCoin, CoinFamily } from '@bitgo-beta/statics';\nimport utils from './lib/utils';\nimport { KeyPair as IotaKeyPair } from './lib';\nimport { auditEddsaPrivateKey } from '@bitgo-beta/sdk-lib-mpc';\n\nexport class Iota extends BaseCoin {\n  protected readonly _staticsCoin: Readonly<StaticsBaseCoin>;\n\n  protected constructor(bitgo: BitGoBase, staticsCoin?: Readonly<StaticsBaseCoin>) {\n    super(bitgo);\n\n    if (!staticsCoin) {\n      throw new Error('missing required constructor parameter staticsCoin');\n    }\n\n    this._staticsCoin = staticsCoin;\n  }\n\n  static createInstance(bitgo: BitGoBase, staticsCoin?: Readonly<StaticsBaseCoin>): BaseCoin {\n    return new Iota(bitgo, staticsCoin);\n  }\n\n  getBaseFactor(): string | number {\n    return Math.pow(10, this._staticsCoin.decimalPlaces);\n  }\n\n  getChain() {\n    return this._staticsCoin.name;\n  }\n\n  getFamily(): CoinFamily {\n    return this._staticsCoin.family;\n  }\n\n  getFullName() {\n    return this._staticsCoin.fullName;\n  }\n\n  /** @inheritDoc */\n  supportsTss(): boolean {\n    return true;\n  }\n\n  /** inherited doc */\n  getDefaultMultisigType(): MultisigType {\n    return multisigTypes.tss;\n  }\n\n  getMPCAlgorithm(): MPCAlgorithm {\n    return MPCType.EDDSA;\n  }\n\n  /**\n   * Check if an address is valid\n   * @param address the address to be validated\n   * @returns true if the address is valid\n   */\n  isValidAddress(address: string): boolean {\n    // IOTA addresses are 64-character hex strings\n    return utils.isValidAddress(address);\n  }\n\n  /**\n   * Verifies that a transaction prebuild complies with the original intention\n   * @param params\n   */\n  async verifyTransaction(params: VerifyTransactionOptions): Promise<boolean> {\n    // TODO: Add IOTA-specific transaction verification logic\n    return true;\n  }\n\n  /**\n   * Check if an address belongs to a wallet\n   * @param params\n   */\n  async isWalletAddress(params: TssVerifyAddressOptions): Promise<boolean> {\n    const { keychains, address, index } = params;\n\n    if (!this.isValidAddress(address)) {\n      throw new InvalidAddressError(`invalid address: ${address}`);\n    }\n\n    if (!keychains) {\n      throw new Error('missing required param keychains');\n    }\n\n    for (const keychain of keychains) {\n      const MPC = await EDDSAMethods.getInitializedMpcInstance();\n      const commonKeychain = keychain.commonKeychain as string;\n\n      const derivationPath = 'm/' + index;\n      const derivedPublicKey = MPC.deriveUnhardened(commonKeychain, derivationPath).slice(0, 64);\n      const expectedAddress = utils.getAddressFromPublicKey(derivedPublicKey);\n\n      if (address !== expectedAddress) {\n        return false;\n      }\n    }\n    return true;\n  }\n\n  /**\n   * Parse a transaction\n   * @param params\n   */\n  async parseTransaction(params: ParseTransactionOptions): Promise<ParsedTransaction> {\n    // TODO: Add IOTA-specific transaction parsing logic\n    return {};\n  }\n\n  /**\n   * Generate a key pair\n   * @param seed Optional seed to generate key pair from\n   */\n  generateKeyPair(seed?: Buffer): KeyPair {\n    const keyPair = seed ? new IotaKeyPair({ seed }) : new IotaKeyPair();\n    const keys = keyPair.getKeys();\n    if (!keys.prv) {\n      throw new Error('Missing prv in key generation.');\n    }\n    return {\n      pub: keys.pub,\n      prv: keys.prv,\n    };\n  }\n\n  /**\n   * Check if a public key is valid\n   * @param pub Public key to check\n   */\n  isValidPub(pub: string): boolean {\n    return utils.isValidPublicKey(pub);\n  }\n\n  /**\n   * Sign a transaction\n   * @param params\n   */\n  async signTransaction(params: SignTransactionOptions): Promise<SignedTransaction> {\n    throw new Error('Method not implemented.');\n  }\n\n  /**\n   * Audit a decrypted private key to ensure it's valid\n   * @param params\n   */\n  auditDecryptedKey({ multiSigType, prv, publicKey }: AuditDecryptedKeyParams): void {\n    if (multiSigType !== multisigTypes.tss) {\n      throw new Error('Unsupported multiSigType');\n    }\n    auditEddsaPrivateKey(prv, publicKey ?? '');\n  }\n}\n"]}
|
|
255
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"iota.js","sourceRoot":"","sources":["../../src/iota.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  AuditDecryptedKeyParams,\n  BaseCoin,\n  BitGoBase,\n  KeyPair,\n  ParsedTransaction,\n  SignTransactionOptions,\n  SignedTransaction,\n  VerifyTransactionOptions,\n  MultisigType,\n  multisigTypes,\n  MPCAlgorithm,\n  TssVerifyAddressOptions,\n  MPCType,\n  PopulatedIntent,\n  PrebuildTransactionWithIntentOptions,\n  TransactionRecipient,\n  verifyEddsaTssWalletAddress,\n} from '@bitgo-beta/sdk-core';\nimport { BaseCoin as StaticsBaseCoin, CoinFamily, coins } from '@bitgo-beta/statics';\nimport utils from './lib/utils';\nimport { KeyPair as IotaKeyPair, Transaction, TransactionBuilderFactory } from './lib';\nimport { auditEddsaPrivateKey } from '@bitgo-beta/sdk-lib-mpc';\nimport BigNumber from 'bignumber.js';\nimport * as _ from 'lodash';\nimport {\n  ExplainTransactionOptions,\n  IotaParseTransactionOptions,\n  TransactionExplanation,\n  TransferTxData,\n} from './lib/iface';\nimport { TransferTransaction } from './lib/transferTransaction';\n\nexport class Iota extends BaseCoin {\n  protected readonly _staticsCoin: Readonly<StaticsBaseCoin>;\n\n  protected constructor(bitgo: BitGoBase, staticsCoin?: Readonly<StaticsBaseCoin>) {\n    super(bitgo);\n\n    if (!staticsCoin) {\n      throw new Error('missing required constructor parameter staticsCoin');\n    }\n\n    this._staticsCoin = staticsCoin;\n  }\n\n  static createInstance(bitgo: BitGoBase, staticsCoin?: Readonly<StaticsBaseCoin>): BaseCoin {\n    return new Iota(bitgo, staticsCoin);\n  }\n\n  getBaseFactor(): string | number {\n    return Math.pow(10, this._staticsCoin.decimalPlaces);\n  }\n\n  getChain() {\n    return this._staticsCoin.name;\n  }\n\n  getFamily(): CoinFamily {\n    return this._staticsCoin.family;\n  }\n\n  getFullName() {\n    return this._staticsCoin.fullName;\n  }\n\n  /** @inheritDoc */\n  supportsTss(): boolean {\n    return true;\n  }\n\n  /** inherited doc */\n  getDefaultMultisigType(): MultisigType {\n    return multisigTypes.tss;\n  }\n\n  getMPCAlgorithm(): MPCAlgorithm {\n    return MPCType.EDDSA;\n  }\n\n  /**\n   * Check if an address is valid\n   * @param address the address to be validated\n   * @returns true if the address is valid\n   */\n  isValidAddress(address: string): boolean {\n    // IOTA addresses are 64-character hex strings\n    return utils.isValidAddress(address);\n  }\n\n  /**\n   * @inheritDoc\n   */\n  async explainTransaction(params: ExplainTransactionOptions): Promise<TransactionExplanation> {\n    const rawTx = params.txHex;\n    if (!rawTx) {\n      throw new Error('missing required tx prebuild property txHex');\n    }\n    const transaction = await this.rebuildTransaction(rawTx);\n    if (!transaction) {\n      throw new Error('failed to explain transaction');\n    }\n    return transaction.explainTransaction();\n  }\n\n  /**\n   * Verifies that a transaction prebuild complies with the original intention\n   * @param params\n   */\n  async verifyTransaction(params: VerifyTransactionOptions): Promise<boolean> {\n    const { txPrebuild: txPrebuild, txParams: txParams } = params;\n    const rawTx = txPrebuild.txHex;\n    if (!rawTx) {\n      throw new Error('missing required tx prebuild property txHex');\n    }\n    const transaction = await this.rebuildTransaction(rawTx);\n    if (!transaction) {\n      throw new Error('failed to verify transaction');\n    }\n    if (txParams.recipients !== undefined) {\n      if (!(transaction instanceof TransferTransaction)) {\n        throw new Error('Tx not a transfer transaction');\n      }\n      const txData = transaction.toJson() as TransferTxData;\n\n      if (!txData.recipients) {\n        throw new Error('Tx recipients does not match with expected txParams recipients');\n      }\n\n      const normalizeRecipient = (recipient: TransactionRecipient) =>\n        _.pick(recipient, ['address', 'amount', 'tokenName']);\n      const txDataRecipients = txData.recipients.map(normalizeRecipient);\n      const txParamsRecipients = txParams.recipients.map(normalizeRecipient);\n\n      const allRecipientsMatch = txParamsRecipients.every((expectedRecipient) =>\n        txDataRecipients.some((actualRecipient) => _.isEqual(expectedRecipient, actualRecipient))\n      );\n\n      if (!allRecipientsMatch) {\n        throw new Error('Tx recipients does not match with expected txParams recipients');\n      }\n    }\n    return true;\n  }\n\n  /**\n   * Check if an address belongs to a wallet\n   * @param params\n   */\n  async isWalletAddress(params: TssVerifyAddressOptions): Promise<boolean> {\n    return verifyEddsaTssWalletAddress(\n      params,\n      (address) => this.isValidAddress(address),\n      (publicKey) => utils.getAddressFromPublicKey(publicKey)\n    );\n  }\n\n  /**\n   * Parse a transaction\n   * @param params\n   */\n  async parseTransaction(params: IotaParseTransactionOptions): Promise<ParsedTransaction> {\n    const transactionExplanation = await this.explainTransaction({ txHex: params.txHex });\n\n    if (!transactionExplanation) {\n      throw new Error('Invalid transaction');\n    }\n\n    let fee = new BigNumber(0);\n\n    if (transactionExplanation.outputs.length <= 0) {\n      return {\n        inputs: [],\n        outputs: [],\n        fee,\n      };\n    }\n\n    const senderAddress = transactionExplanation.outputs[0].address;\n    if (transactionExplanation.fee.fee !== '') {\n      fee = new BigNumber(transactionExplanation.fee.fee);\n    }\n\n    const outputAmount = transactionExplanation.sponsor\n      ? new BigNumber(transactionExplanation.outputAmount).toFixed()\n      : new BigNumber(transactionExplanation.outputAmount).plus(fee).toFixed(); // assume 1 sender, who is also the fee payer\n\n    const inputs = [\n      {\n        address: senderAddress,\n        amount: outputAmount,\n      },\n    ];\n    if (transactionExplanation.sponsor) {\n      inputs.push({\n        address: transactionExplanation.sponsor,\n        amount: fee.toFixed(),\n      });\n    }\n\n    const outputs: {\n      address: string;\n      amount: string;\n    }[] = transactionExplanation.outputs.map((output) => {\n      return {\n        address: output.address,\n        amount: new BigNumber(output.amount).toFixed(),\n      };\n    });\n\n    return {\n      inputs,\n      outputs,\n      fee,\n    };\n  }\n\n  /**\n   * Generate a key pair\n   * @param seed Optional seed to generate key pair from\n   */\n  generateKeyPair(seed?: Buffer): KeyPair {\n    const keyPair = seed ? new IotaKeyPair({ seed }) : new IotaKeyPair();\n    const keys = keyPair.getKeys();\n    if (!keys.prv) {\n      throw new Error('Missing prv in key generation.');\n    }\n    return {\n      pub: keys.pub,\n      prv: keys.prv,\n    };\n  }\n\n  /**\n   * Check if a public key is valid\n   * @param pub Public key to check\n   */\n  isValidPub(pub: string): boolean {\n    return utils.isValidPublicKey(pub);\n  }\n\n  /**\n   * Sign a transaction\n   * @param params\n   */\n  async signTransaction(params: SignTransactionOptions): Promise<SignedTransaction> {\n    throw new Error('Method not implemented.');\n  }\n\n  /**\n   * Audit a decrypted private key to ensure it's valid\n   * @param params\n   */\n  auditDecryptedKey({ multiSigType, prv, publicKey }: AuditDecryptedKeyParams): void {\n    if (multiSigType !== multisigTypes.tss) {\n      throw new Error('Unsupported multiSigType');\n    }\n    auditEddsaPrivateKey(prv, publicKey ?? '');\n  }\n\n  /** @inheritDoc */\n  async getSignablePayload(serializedTx: string): Promise<Buffer> {\n    const rebuiltTransaction = await this.rebuildTransaction(serializedTx);\n    return rebuiltTransaction.signablePayload;\n  }\n\n  /** inherited doc */\n  setCoinSpecificFieldsInIntent(intent: PopulatedIntent, params: PrebuildTransactionWithIntentOptions): void {\n    intent.unspents = params.unspents;\n  }\n\n  private getTxBuilderFactory(): TransactionBuilderFactory {\n    return new TransactionBuilderFactory(coins.get(this.getChain()));\n  }\n\n  private async rebuildTransaction(txHex: string): Promise<Transaction> {\n    const txBuilderFactory = this.getTxBuilderFactory();\n    try {\n      const txBuilder = txBuilderFactory.from(txHex);\n      return (await txBuilder.build()) as Transaction;\n    } catch (err) {\n      throw new Error(`Failed to rebuild transaction ${err.toString()}`);\n    }\n  }\n}\n"]}
|
|
@@ -1,8 +1,12 @@
|
|
|
1
1
|
export declare const IOTA_ADDRESS_LENGTH = 64;
|
|
2
|
-
export declare const
|
|
3
|
-
export declare const
|
|
4
|
-
export declare const IOTA_SIGNATURE_LENGTH =
|
|
5
|
-
export declare const
|
|
6
|
-
export declare const
|
|
7
|
-
export declare const
|
|
2
|
+
export declare const IOTA_TRANSACTION_DIGEST_LENGTH = 32;
|
|
3
|
+
export declare const IOTA_BLOCK_DIGEST_LENGTH = 32;
|
|
4
|
+
export declare const IOTA_SIGNATURE_LENGTH = 64;
|
|
5
|
+
export declare const IOTA_KEY_BYTES_LENGTH = 32;
|
|
6
|
+
export declare const MAX_INPUT_OBJECTS = 2048;
|
|
7
|
+
export declare const MAX_GAS_PAYMENT_OBJECTS = 256;
|
|
8
|
+
export declare const MAX_GAS_BUDGET = 50000000000;
|
|
9
|
+
export declare const MAX_GAS_PRICE = 100000;
|
|
10
|
+
export declare const MAX_RECIPIENTS = 256;
|
|
11
|
+
export declare const TRANSFER_TRANSACTION_COMMANDS: string[];
|
|
8
12
|
//# sourceMappingURL=constants.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"constants.d.ts","sourceRoot":"","sources":["../../../src/lib/constants.ts"],"names":[],"mappings":"AAAA,eAAO,MAAM,mBAAmB,KAAK,CAAC;AACtC,eAAO,MAAM,
|
|
1
|
+
{"version":3,"file":"constants.d.ts","sourceRoot":"","sources":["../../../src/lib/constants.ts"],"names":[],"mappings":"AAAA,eAAO,MAAM,mBAAmB,KAAK,CAAC;AACtC,eAAO,MAAM,8BAA8B,KAAK,CAAC;AACjD,eAAO,MAAM,wBAAwB,KAAK,CAAC;AAC3C,eAAO,MAAM,qBAAqB,KAAK,CAAC;AACxC,eAAO,MAAM,qBAAqB,KAAK,CAAC;AACxC,eAAO,MAAM,iBAAiB,OAAO,CAAC;AACtC,eAAO,MAAM,uBAAuB,MAAM,CAAC;AAC3C,eAAO,MAAM,cAAc,cAAc,CAAC;AAC1C,eAAO,MAAM,aAAa,SAAS,CAAC;AACpC,eAAO,MAAM,cAAc,MAAM,CAAC;AAClC,eAAO,MAAM,6BAA6B,UAAkD,CAAC"}
|
|
@@ -1,11 +1,15 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.
|
|
3
|
+
exports.TRANSFER_TRANSACTION_COMMANDS = exports.MAX_RECIPIENTS = exports.MAX_GAS_PRICE = exports.MAX_GAS_BUDGET = exports.MAX_GAS_PAYMENT_OBJECTS = exports.MAX_INPUT_OBJECTS = exports.IOTA_KEY_BYTES_LENGTH = exports.IOTA_SIGNATURE_LENGTH = exports.IOTA_BLOCK_DIGEST_LENGTH = exports.IOTA_TRANSACTION_DIGEST_LENGTH = exports.IOTA_ADDRESS_LENGTH = void 0;
|
|
4
4
|
exports.IOTA_ADDRESS_LENGTH = 64;
|
|
5
|
-
exports.
|
|
6
|
-
exports.
|
|
7
|
-
exports.IOTA_SIGNATURE_LENGTH =
|
|
8
|
-
exports.
|
|
9
|
-
exports.
|
|
10
|
-
exports.
|
|
11
|
-
|
|
5
|
+
exports.IOTA_TRANSACTION_DIGEST_LENGTH = 32;
|
|
6
|
+
exports.IOTA_BLOCK_DIGEST_LENGTH = 32;
|
|
7
|
+
exports.IOTA_SIGNATURE_LENGTH = 64;
|
|
8
|
+
exports.IOTA_KEY_BYTES_LENGTH = 32; // Ed25519 public key is 32 bytes
|
|
9
|
+
exports.MAX_INPUT_OBJECTS = 2048;
|
|
10
|
+
exports.MAX_GAS_PAYMENT_OBJECTS = 256;
|
|
11
|
+
exports.MAX_GAS_BUDGET = 50000000000;
|
|
12
|
+
exports.MAX_GAS_PRICE = 100000;
|
|
13
|
+
exports.MAX_RECIPIENTS = 256; // Maximum number of recipients in a transfer transaction
|
|
14
|
+
exports.TRANSFER_TRANSACTION_COMMANDS = ['SplitCoins', 'MergeCoins', 'TransferObjects'];
|
|
15
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uc3RhbnRzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2xpYi9jb25zdGFudHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQWEsUUFBQSxtQkFBbUIsR0FBRyxFQUFFLENBQUM7QUFDekIsUUFBQSw4QkFBOEIsR0FBRyxFQUFFLENBQUM7QUFDcEMsUUFBQSx3QkFBd0IsR0FBRyxFQUFFLENBQUM7QUFDOUIsUUFBQSxxQkFBcUIsR0FBRyxFQUFFLENBQUM7QUFDM0IsUUFBQSxxQkFBcUIsR0FBRyxFQUFFLENBQUMsQ0FBQyxpQ0FBaUM7QUFDN0QsUUFBQSxpQkFBaUIsR0FBRyxJQUFJLENBQUM7QUFDekIsUUFBQSx1QkFBdUIsR0FBRyxHQUFHLENBQUM7QUFDOUIsUUFBQSxjQUFjLEdBQUcsV0FBVyxDQUFDO0FBQzdCLFFBQUEsYUFBYSxHQUFHLE1BQU0sQ0FBQztBQUN2QixRQUFBLGNBQWMsR0FBRyxHQUFHLENBQUMsQ0FBQyx5REFBeUQ7QUFDL0UsUUFBQSw2QkFBNkIsR0FBRyxDQUFDLFlBQVksRUFBRSxZQUFZLEVBQUUsaUJBQWlCLENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBjb25zdCBJT1RBX0FERFJFU1NfTEVOR1RIID0gNjQ7XG5leHBvcnQgY29uc3QgSU9UQV9UUkFOU0FDVElPTl9ESUdFU1RfTEVOR1RIID0gMzI7XG5leHBvcnQgY29uc3QgSU9UQV9CTE9DS19ESUdFU1RfTEVOR1RIID0gMzI7XG5leHBvcnQgY29uc3QgSU9UQV9TSUdOQVRVUkVfTEVOR1RIID0gNjQ7XG5leHBvcnQgY29uc3QgSU9UQV9LRVlfQllURVNfTEVOR1RIID0gMzI7IC8vIEVkMjU1MTkgcHVibGljIGtleSBpcyAzMiBieXRlc1xuZXhwb3J0IGNvbnN0IE1BWF9JTlBVVF9PQkpFQ1RTID0gMjA0ODtcbmV4cG9ydCBjb25zdCBNQVhfR0FTX1BBWU1FTlRfT0JKRUNUUyA9IDI1NjtcbmV4cG9ydCBjb25zdCBNQVhfR0FTX0JVREdFVCA9IDUwMDAwMDAwMDAwO1xuZXhwb3J0IGNvbnN0IE1BWF9HQVNfUFJJQ0UgPSAxMDAwMDA7XG5leHBvcnQgY29uc3QgTUFYX1JFQ0lQSUVOVFMgPSAyNTY7IC8vIE1heGltdW0gbnVtYmVyIG9mIHJlY2lwaWVudHMgaW4gYSB0cmFuc2ZlciB0cmFuc2FjdGlvblxuZXhwb3J0IGNvbnN0IFRSQU5TRkVSX1RSQU5TQUNUSU9OX0NPTU1BTkRTID0gWydTcGxpdENvaW5zJywgJ01lcmdlQ29pbnMnLCAnVHJhbnNmZXJPYmplY3RzJ107XG4iXX0=
|
package/dist/src/lib/iface.d.ts
CHANGED
|
@@ -1,7 +1,39 @@
|
|
|
1
|
+
import { ParseTransactionOptions as BaseParseTransactionOptions, TransactionExplanation as BaseTransactionExplanation, TransactionRecipient, TransactionType as BitGoTransactionType, TransactionType } from '@bitgo-beta/sdk-core';
|
|
2
|
+
export interface TransactionExplanation extends BaseTransactionExplanation {
|
|
3
|
+
type: BitGoTransactionType;
|
|
4
|
+
sender: string;
|
|
5
|
+
sponsor?: string;
|
|
6
|
+
}
|
|
7
|
+
export type TransactionObjectInput = {
|
|
8
|
+
objectId: string;
|
|
9
|
+
version: string;
|
|
10
|
+
digest: string;
|
|
11
|
+
};
|
|
12
|
+
export type GasData = {
|
|
13
|
+
gasBudget?: number;
|
|
14
|
+
gasPrice?: number;
|
|
15
|
+
gasPaymentObjects?: TransactionObjectInput[];
|
|
16
|
+
};
|
|
1
17
|
/**
|
|
2
18
|
* The transaction data returned from the toJson() function of a transaction
|
|
3
19
|
*/
|
|
4
20
|
export interface TxData {
|
|
5
|
-
id
|
|
21
|
+
id?: string;
|
|
22
|
+
sender: string;
|
|
23
|
+
gasBudget?: number;
|
|
24
|
+
gasPrice?: number;
|
|
25
|
+
gasPaymentObjects?: TransactionObjectInput[];
|
|
26
|
+
gasSponsor?: string;
|
|
27
|
+
type: TransactionType;
|
|
28
|
+
}
|
|
29
|
+
export interface TransferTxData extends TxData {
|
|
30
|
+
recipients: TransactionRecipient[];
|
|
31
|
+
paymentObjects?: TransactionObjectInput[];
|
|
32
|
+
}
|
|
33
|
+
export interface ExplainTransactionOptions {
|
|
34
|
+
txHex: string;
|
|
35
|
+
}
|
|
36
|
+
export interface IotaParseTransactionOptions extends BaseParseTransactionOptions {
|
|
37
|
+
txHex: string;
|
|
6
38
|
}
|
|
7
39
|
//# sourceMappingURL=iface.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"iface.d.ts","sourceRoot":"","sources":["../../../src/lib/iface.ts"],"names":[],"mappings":"AAAA;;GAEG;AACH,MAAM,WAAW,MAAM;IACrB,EAAE,EAAE,MAAM,CAAC;
|
|
1
|
+
{"version":3,"file":"iface.d.ts","sourceRoot":"","sources":["../../../src/lib/iface.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,uBAAuB,IAAI,2BAA2B,EACtD,sBAAsB,IAAI,0BAA0B,EACpD,oBAAoB,EACpB,eAAe,IAAI,oBAAoB,EACvC,eAAe,EAChB,MAAM,sBAAsB,CAAC;AAE9B,MAAM,WAAW,sBAAuB,SAAQ,0BAA0B;IACxE,IAAI,EAAE,oBAAoB,CAAC;IAC3B,MAAM,EAAE,MAAM,CAAC;IACf,OAAO,CAAC,EAAE,MAAM,CAAC;CAClB;AAED,MAAM,MAAM,sBAAsB,GAAG;IACnC,QAAQ,EAAE,MAAM,CAAC;IACjB,OAAO,EAAE,MAAM,CAAC;IAChB,MAAM,EAAE,MAAM,CAAC;CAChB,CAAC;AAEF,MAAM,MAAM,OAAO,GAAG;IACpB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,iBAAiB,CAAC,EAAE,sBAAsB,EAAE,CAAC;CAC9C,CAAC;AAEF;;GAEG;AACH,MAAM,WAAW,MAAM;IACrB,EAAE,CAAC,EAAE,MAAM,CAAC;IACZ,MAAM,EAAE,MAAM,CAAC;IACf,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,iBAAiB,CAAC,EAAE,sBAAsB,EAAE,CAAC;IAC7C,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,IAAI,EAAE,eAAe,CAAC;CACvB;AAED,MAAM,WAAW,cAAe,SAAQ,MAAM;IAC5C,UAAU,EAAE,oBAAoB,EAAE,CAAC;IACnC,cAAc,CAAC,EAAE,sBAAsB,EAAE,CAAC;CAC3C;AAED,MAAM,WAAW,yBAAyB;IACxC,KAAK,EAAE,MAAM,CAAC;CACf;AAED,MAAM,WAAW,2BAA4B,SAAQ,2BAA2B;IAC9E,KAAK,EAAE,MAAM,CAAC;CACf"}
|
package/dist/src/lib/iface.js
CHANGED
|
@@ -1,3 +1,3 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaWZhY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvbGliL2lmYWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICBQYXJzZVRyYW5zYWN0aW9uT3B0aW9ucyBhcyBCYXNlUGFyc2VUcmFuc2FjdGlvbk9wdGlvbnMsXG4gIFRyYW5zYWN0aW9uRXhwbGFuYXRpb24gYXMgQmFzZVRyYW5zYWN0aW9uRXhwbGFuYXRpb24sXG4gIFRyYW5zYWN0aW9uUmVjaXBpZW50LFxuICBUcmFuc2FjdGlvblR5cGUgYXMgQml0R29UcmFuc2FjdGlvblR5cGUsXG4gIFRyYW5zYWN0aW9uVHlwZSxcbn0gZnJvbSAnQGJpdGdvLWJldGEvc2RrLWNvcmUnO1xuXG5leHBvcnQgaW50ZXJmYWNlIFRyYW5zYWN0aW9uRXhwbGFuYXRpb24gZXh0ZW5kcyBCYXNlVHJhbnNhY3Rpb25FeHBsYW5hdGlvbiB7XG4gIHR5cGU6IEJpdEdvVHJhbnNhY3Rpb25UeXBlO1xuICBzZW5kZXI6IHN0cmluZztcbiAgc3BvbnNvcj86IHN0cmluZztcbn1cblxuZXhwb3J0IHR5cGUgVHJhbnNhY3Rpb25PYmplY3RJbnB1dCA9IHtcbiAgb2JqZWN0SWQ6IHN0cmluZztcbiAgdmVyc2lvbjogc3RyaW5nO1xuICBkaWdlc3Q6IHN0cmluZztcbn07XG5cbmV4cG9ydCB0eXBlIEdhc0RhdGEgPSB7XG4gIGdhc0J1ZGdldD86IG51bWJlcjtcbiAgZ2FzUHJpY2U/OiBudW1iZXI7XG4gIGdhc1BheW1lbnRPYmplY3RzPzogVHJhbnNhY3Rpb25PYmplY3RJbnB1dFtdO1xufTtcblxuLyoqXG4gKiBUaGUgdHJhbnNhY3Rpb24gZGF0YSByZXR1cm5lZCBmcm9tIHRoZSB0b0pzb24oKSBmdW5jdGlvbiBvZiBhIHRyYW5zYWN0aW9uXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgVHhEYXRhIHtcbiAgaWQ/OiBzdHJpbmc7XG4gIHNlbmRlcjogc3RyaW5nO1xuICBnYXNCdWRnZXQ/OiBudW1iZXI7XG4gIGdhc1ByaWNlPzogbnVtYmVyO1xuICBnYXNQYXltZW50T2JqZWN0cz86IFRyYW5zYWN0aW9uT2JqZWN0SW5wdXRbXTtcbiAgZ2FzU3BvbnNvcj86IHN0cmluZztcbiAgdHlwZTogVHJhbnNhY3Rpb25UeXBlO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIFRyYW5zZmVyVHhEYXRhIGV4dGVuZHMgVHhEYXRhIHtcbiAgcmVjaXBpZW50czogVHJhbnNhY3Rpb25SZWNpcGllbnRbXTtcbiAgcGF5bWVudE9iamVjdHM/OiBUcmFuc2FjdGlvbk9iamVjdElucHV0W107XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgRXhwbGFpblRyYW5zYWN0aW9uT3B0aW9ucyB7XG4gIHR4SGV4OiBzdHJpbmc7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgSW90YVBhcnNlVHJhbnNhY3Rpb25PcHRpb25zIGV4dGVuZHMgQmFzZVBhcnNlVHJhbnNhY3Rpb25PcHRpb25zIHtcbiAgdHhIZXg6IHN0cmluZztcbn1cbiJdfQ==
|
package/dist/src/lib/index.d.ts
CHANGED
|
@@ -4,6 +4,7 @@ export { KeyPair } from './keyPair';
|
|
|
4
4
|
export { Transaction } from './transaction';
|
|
5
5
|
export { TransactionBuilder } from './transactionBuilder';
|
|
6
6
|
export { TransferBuilder } from './transferBuilder';
|
|
7
|
+
export { TransferTransaction } from './transferTransaction';
|
|
7
8
|
export { TransactionBuilderFactory } from './transactionBuilderFactory';
|
|
8
9
|
export { Interface, Utils };
|
|
9
10
|
//# sourceMappingURL=index.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/lib/index.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,SAAS,CAAC;AACjC,OAAO,KAAK,SAAS,MAAM,SAAS,CAAC;AAErC,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AACpC,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAC5C,OAAO,EAAE,kBAAkB,EAAE,MAAM,sBAAsB,CAAC;AAC1D,OAAO,EAAE,eAAe,EAAE,MAAM,mBAAmB,CAAC;AACpD,OAAO,EAAE,yBAAyB,EAAE,MAAM,6BAA6B,CAAC;AACxE,OAAO,EAAE,SAAS,EAAE,KAAK,EAAE,CAAC"}
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/lib/index.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,SAAS,CAAC;AACjC,OAAO,KAAK,SAAS,MAAM,SAAS,CAAC;AAErC,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AACpC,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAC5C,OAAO,EAAE,kBAAkB,EAAE,MAAM,sBAAsB,CAAC;AAC1D,OAAO,EAAE,eAAe,EAAE,MAAM,mBAAmB,CAAC;AACpD,OAAO,EAAE,mBAAmB,EAAE,MAAM,uBAAuB,CAAC;AAC5D,OAAO,EAAE,yBAAyB,EAAE,MAAM,6BAA6B,CAAC;AACxE,OAAO,EAAE,SAAS,EAAE,KAAK,EAAE,CAAC"}
|
package/dist/src/lib/index.js
CHANGED
|
@@ -33,7 +33,7 @@ var __importStar = (this && this.__importStar) || (function () {
|
|
|
33
33
|
};
|
|
34
34
|
})();
|
|
35
35
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
36
|
-
exports.Utils = exports.Interface = exports.TransactionBuilderFactory = exports.TransferBuilder = exports.TransactionBuilder = exports.Transaction = exports.KeyPair = void 0;
|
|
36
|
+
exports.Utils = exports.Interface = exports.TransactionBuilderFactory = exports.TransferTransaction = exports.TransferBuilder = exports.TransactionBuilder = exports.Transaction = exports.KeyPair = void 0;
|
|
37
37
|
const Utils = __importStar(require("./utils"));
|
|
38
38
|
exports.Utils = Utils;
|
|
39
39
|
const Interface = __importStar(require("./iface"));
|
|
@@ -46,6 +46,8 @@ var transactionBuilder_1 = require("./transactionBuilder");
|
|
|
46
46
|
Object.defineProperty(exports, "TransactionBuilder", { enumerable: true, get: function () { return transactionBuilder_1.TransactionBuilder; } });
|
|
47
47
|
var transferBuilder_1 = require("./transferBuilder");
|
|
48
48
|
Object.defineProperty(exports, "TransferBuilder", { enumerable: true, get: function () { return transferBuilder_1.TransferBuilder; } });
|
|
49
|
+
var transferTransaction_1 = require("./transferTransaction");
|
|
50
|
+
Object.defineProperty(exports, "TransferTransaction", { enumerable: true, get: function () { return transferTransaction_1.TransferTransaction; } });
|
|
49
51
|
var transactionBuilderFactory_1 = require("./transactionBuilderFactory");
|
|
50
52
|
Object.defineProperty(exports, "TransactionBuilderFactory", { enumerable: true, get: function () { return transactionBuilderFactory_1.TransactionBuilderFactory; } });
|
|
51
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
53
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvbGliL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQUFBLCtDQUFpQztBQVNiLHNCQUFLO0FBUnpCLG1EQUFxQztBQVE1Qiw4QkFBUztBQU5sQixxQ0FBb0M7QUFBM0Isa0dBQUEsT0FBTyxPQUFBO0FBQ2hCLDZDQUE0QztBQUFuQywwR0FBQSxXQUFXLE9BQUE7QUFDcEIsMkRBQTBEO0FBQWpELHdIQUFBLGtCQUFrQixPQUFBO0FBQzNCLHFEQUFvRDtBQUEzQyxrSEFBQSxlQUFlLE9BQUE7QUFDeEIsNkRBQTREO0FBQW5ELDBIQUFBLG1CQUFtQixPQUFBO0FBQzVCLHlFQUF3RTtBQUEvRCxzSUFBQSx5QkFBeUIsT0FBQSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCAqIGFzIFV0aWxzIGZyb20gJy4vdXRpbHMnO1xuaW1wb3J0ICogYXMgSW50ZXJmYWNlIGZyb20gJy4vaWZhY2UnO1xuXG5leHBvcnQgeyBLZXlQYWlyIH0gZnJvbSAnLi9rZXlQYWlyJztcbmV4cG9ydCB7IFRyYW5zYWN0aW9uIH0gZnJvbSAnLi90cmFuc2FjdGlvbic7XG5leHBvcnQgeyBUcmFuc2FjdGlvbkJ1aWxkZXIgfSBmcm9tICcuL3RyYW5zYWN0aW9uQnVpbGRlcic7XG5leHBvcnQgeyBUcmFuc2ZlckJ1aWxkZXIgfSBmcm9tICcuL3RyYW5zZmVyQnVpbGRlcic7XG5leHBvcnQgeyBUcmFuc2ZlclRyYW5zYWN0aW9uIH0gZnJvbSAnLi90cmFuc2ZlclRyYW5zYWN0aW9uJztcbmV4cG9ydCB7IFRyYW5zYWN0aW9uQnVpbGRlckZhY3RvcnkgfSBmcm9tICcuL3RyYW5zYWN0aW9uQnVpbGRlckZhY3RvcnknO1xuZXhwb3J0IHsgSW50ZXJmYWNlLCBVdGlscyB9O1xuIl19
|
|
@@ -1,8 +1,75 @@
|
|
|
1
|
-
import { BaseKey, BaseTransaction } from '@bitgo-beta/sdk-core';
|
|
2
|
-
import {
|
|
3
|
-
|
|
4
|
-
|
|
1
|
+
import { BaseKey, BaseTransaction, PublicKey, TransactionType } from '@bitgo-beta/sdk-core';
|
|
2
|
+
import { BaseCoin as CoinConfig } from '@bitgo-beta/statics';
|
|
3
|
+
import { Transaction as IotaTransaction } from '@iota/iota-sdk/transactions';
|
|
4
|
+
import { TxData, TransactionObjectInput, TransactionExplanation } from './iface';
|
|
5
|
+
export declare abstract class Transaction extends BaseTransaction {
|
|
6
|
+
static EMPTY_PUBLIC_KEY: Buffer<ArrayBuffer>;
|
|
7
|
+
static EMPTY_SIGNATURE: Buffer<ArrayBuffer>;
|
|
8
|
+
protected _rebuildRequired: boolean;
|
|
9
|
+
protected _type: TransactionType;
|
|
10
|
+
protected _iotaTransaction: IotaTransaction;
|
|
11
|
+
private _gasBudget?;
|
|
12
|
+
private _gasPaymentObjects?;
|
|
13
|
+
private _gasPrice?;
|
|
14
|
+
private _gasSponsor?;
|
|
15
|
+
private _sender;
|
|
16
|
+
private _signature?;
|
|
17
|
+
private _serializedSignature?;
|
|
18
|
+
private _gasSponsorSignature?;
|
|
19
|
+
private _serializedGasSponsorSignature?;
|
|
20
|
+
private _txDataBytes?;
|
|
21
|
+
private _isSimulateTx;
|
|
22
|
+
protected constructor(coinConfig: Readonly<CoinConfig>);
|
|
23
|
+
get gasBudget(): number | undefined;
|
|
24
|
+
set gasBudget(value: number | undefined);
|
|
25
|
+
get gasPaymentObjects(): TransactionObjectInput[] | undefined;
|
|
26
|
+
set gasPaymentObjects(value: TransactionObjectInput[] | undefined);
|
|
27
|
+
get gasPrice(): number | undefined;
|
|
28
|
+
set gasPrice(value: number | undefined);
|
|
29
|
+
get gasSponsor(): string | undefined;
|
|
30
|
+
set gasSponsor(value: string | undefined);
|
|
31
|
+
get sender(): string;
|
|
32
|
+
set sender(value: string);
|
|
33
|
+
get isSimulateTx(): boolean;
|
|
34
|
+
set isSimulateTx(value: boolean);
|
|
35
|
+
get signablePayload(): Buffer;
|
|
36
|
+
/** @inheritDoc **/
|
|
37
|
+
get id(): string;
|
|
38
|
+
addSignature(publicKey: PublicKey, signature: Buffer): void;
|
|
39
|
+
addGasSponsorSignature(publicKey: PublicKey, signature: Buffer): void;
|
|
40
|
+
canSign(_key: BaseKey): boolean;
|
|
41
|
+
getFee(): string | undefined;
|
|
42
|
+
get serializedGasSponsorSignature(): string | undefined;
|
|
43
|
+
get serializedSignature(): string | undefined;
|
|
44
|
+
serializeSignatures(): void;
|
|
45
|
+
toBroadcastFormat(): Promise<string>;
|
|
46
|
+
build(): Promise<Uint8Array<ArrayBufferLike>>;
|
|
5
47
|
toJson(): TxData;
|
|
6
|
-
|
|
48
|
+
parseFromJSON(txData: TxData): void;
|
|
49
|
+
parseFromBroadcastTx(tx: string | Uint8Array): void;
|
|
50
|
+
/**
|
|
51
|
+
* @inheritDoc
|
|
52
|
+
*/
|
|
53
|
+
explainTransaction(): any;
|
|
54
|
+
protected updateIsSimulateTx(): void;
|
|
55
|
+
protected abstract messageWithIntent(message: Uint8Array): Uint8Array;
|
|
56
|
+
protected abstract populateTxInputsAndCommands(): void;
|
|
57
|
+
protected abstract validateTxDataImplementation(): void;
|
|
58
|
+
/**
|
|
59
|
+
* Add the input and output entries for this transaction.
|
|
60
|
+
*/
|
|
61
|
+
abstract addInputsAndOutputs(): void;
|
|
62
|
+
/**
|
|
63
|
+
* Returns a complete explanation for a transfer transaction
|
|
64
|
+
* @param {TxData} json The transaction data in json format
|
|
65
|
+
* @param {TransactionExplanation} explanationResult The transaction explanation to be completed
|
|
66
|
+
* @returns {TransactionExplanation}
|
|
67
|
+
*/
|
|
68
|
+
protected abstract explainTransactionImplementation(json: TxData, explanationResult: TransactionExplanation): TransactionExplanation;
|
|
69
|
+
private buildDryRunTransaction;
|
|
70
|
+
private buildTransaction;
|
|
71
|
+
private populateTxData;
|
|
72
|
+
private serializeSignature;
|
|
73
|
+
private validateTxData;
|
|
7
74
|
}
|
|
8
75
|
//# sourceMappingURL=transaction.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"transaction.d.ts","sourceRoot":"","sources":["../../../src/lib/transaction.ts"],"names":[],"mappings":"AAAA,OAAO,
|
|
1
|
+
{"version":3,"file":"transaction.d.ts","sourceRoot":"","sources":["../../../src/lib/transaction.ts"],"names":[],"mappings":"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"}
|