@bitgo-beta/abstract-cosmos 1.0.1-beta.3 → 1.0.1-beta.5
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/src/cosmosCoin.d.ts +63 -0
- package/dist/src/cosmosCoin.d.ts.map +1 -0
- package/dist/src/cosmosCoin.js +283 -0
- package/dist/src/index.d.ts +1 -0
- package/dist/src/index.d.ts.map +1 -1
- package/dist/src/index.js +4 -1
- package/dist/src/lib/transaction.d.ts.map +1 -1
- package/dist/src/lib/transaction.js +1 -8
- package/dist/src/lib/transactionBuilder.d.ts.map +1 -1
- package/dist/src/lib/transactionBuilder.js +1 -8
- package/dist/tsconfig.tsbuildinfo +250 -215
- package/package.json +8 -6
|
@@ -0,0 +1,63 @@
|
|
|
1
|
+
/// <reference types="node" />
|
|
2
|
+
import { BaseCoin, BitGoBase, KeyPair, MPCAlgorithm, ParsedTransaction, ParseTransactionOptions, SignedTransaction, SignTransactionOptions, VerifyAddressOptions, VerifyTransactionOptions } from '@bitgo-beta/sdk-core';
|
|
3
|
+
import { BaseCoin as StaticsBaseCoin, CoinFamily } from '@bitgo-beta/statics';
|
|
4
|
+
import { Hash } from 'crypto';
|
|
5
|
+
/**
|
|
6
|
+
* Cosmos accounts support memo Id based addresses
|
|
7
|
+
*/
|
|
8
|
+
interface AddressDetails {
|
|
9
|
+
address: string;
|
|
10
|
+
memoId?: string | undefined;
|
|
11
|
+
}
|
|
12
|
+
export declare class CosmosCoin extends BaseCoin {
|
|
13
|
+
protected readonly _staticsCoin: Readonly<StaticsBaseCoin>;
|
|
14
|
+
protected constructor(bitgo: BitGoBase, staticsCoin?: Readonly<StaticsBaseCoin>);
|
|
15
|
+
static createInstance(bitgo: BitGoBase, staticsCoin?: Readonly<StaticsBaseCoin>): BaseCoin;
|
|
16
|
+
/** @inheritDoc **/
|
|
17
|
+
getBaseFactor(): string | number;
|
|
18
|
+
/** @inheritDoc **/
|
|
19
|
+
getChain(): string;
|
|
20
|
+
/** @inheritDoc **/
|
|
21
|
+
getFamily(): CoinFamily;
|
|
22
|
+
/** @inheritDoc **/
|
|
23
|
+
getFullName(): string;
|
|
24
|
+
/** @inheritDoc */
|
|
25
|
+
supportsTss(): boolean;
|
|
26
|
+
/** @inheritDoc **/
|
|
27
|
+
getMPCAlgorithm(): MPCAlgorithm;
|
|
28
|
+
/** @inheritDoc **/
|
|
29
|
+
isValidPub(pub: string): boolean;
|
|
30
|
+
/** @inheritDoc **/
|
|
31
|
+
isValidPrv(prv: string): boolean;
|
|
32
|
+
verifyTransaction(params: VerifyTransactionOptions): Promise<boolean>;
|
|
33
|
+
isValidAddress(address: string): boolean;
|
|
34
|
+
signTransaction(params: SignTransactionOptions): Promise<SignedTransaction>;
|
|
35
|
+
/** @inheritDoc **/
|
|
36
|
+
parseTransaction(params: ParseTransactionOptions & {
|
|
37
|
+
txHex: string;
|
|
38
|
+
}): Promise<ParsedTransaction>;
|
|
39
|
+
/** @inheritDoc **/
|
|
40
|
+
generateKeyPair(seed?: Buffer): KeyPair;
|
|
41
|
+
getAddressFromPublicKey(pubKey: string): string;
|
|
42
|
+
/** @inheritDoc **/
|
|
43
|
+
isWalletAddress(params: VerifyAddressOptions): Promise<boolean>;
|
|
44
|
+
getHashFunction(): Hash;
|
|
45
|
+
/**
|
|
46
|
+
* Process address into address and memo id
|
|
47
|
+
*
|
|
48
|
+
* @param address the address
|
|
49
|
+
* @returns object containing address and memo id
|
|
50
|
+
*/
|
|
51
|
+
getAddressDetails(address: string): AddressDetails;
|
|
52
|
+
/**
|
|
53
|
+
* Return boolean indicating whether a memo id is valid
|
|
54
|
+
*
|
|
55
|
+
* @param memoId memo id
|
|
56
|
+
* @returns true if memo id is valid
|
|
57
|
+
*/
|
|
58
|
+
isValidMemoId(memoId: string): boolean;
|
|
59
|
+
private getKeyCombinedFromTssKeyShares;
|
|
60
|
+
private signRecoveryTSS;
|
|
61
|
+
}
|
|
62
|
+
export {};
|
|
63
|
+
//# sourceMappingURL=cosmosCoin.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"cosmosCoin.d.ts","sourceRoot":"","sources":["../../src/cosmosCoin.ts"],"names":[],"mappings":";AAAA,OAAO,EACL,QAAQ,EACR,SAAS,EAOT,OAAO,EACP,YAAY,EACZ,iBAAiB,EACjB,uBAAuB,EACvB,iBAAiB,EACjB,sBAAsB,EAEtB,oBAAoB,EACpB,wBAAwB,EACzB,MAAM,sBAAsB,CAAC;AAE9B,OAAO,EAAE,QAAQ,IAAI,eAAe,EAAE,UAAU,EAAE,MAAM,qBAAqB,CAAC;AAG9E,OAAO,EAAc,IAAI,EAAe,MAAM,QAAQ,CAAC;AAQvD;;GAEG;AACH,UAAU,cAAc;IACtB,OAAO,EAAE,MAAM,CAAC;IAChB,MAAM,CAAC,EAAE,MAAM,GAAG,SAAS,CAAC;CAC7B;AASD,qBAAa,UAAW,SAAQ,QAAQ;IACtC,SAAS,CAAC,QAAQ,CAAC,YAAY,EAAE,QAAQ,CAAC,eAAe,CAAC,CAAC;IAC3D,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,mBAAmB;IACnB,aAAa,IAAI,MAAM,GAAG,MAAM;IAIhC,mBAAmB;IACnB,QAAQ,IAAI,MAAM;IAIlB,mBAAmB;IACnB,SAAS,IAAI,UAAU;IAIvB,mBAAmB;IACnB,WAAW,IAAI,MAAM;IAIrB,kBAAkB;IAClB,WAAW,IAAI,OAAO;IAItB,mBAAmB;IACnB,eAAe,IAAI,YAAY;IAI/B,mBAAmB;IACnB,UAAU,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO;IAIhC,mBAAmB;IACnB,UAAU,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO;IAIhC,iBAAiB,CAAC,MAAM,EAAE,wBAAwB,GAAG,OAAO,CAAC,OAAO,CAAC;IAIrE,cAAc,CAAC,OAAO,EAAE,MAAM,GAAG,OAAO;IAIxC,eAAe,CAAC,MAAM,EAAE,sBAAsB,GAAG,OAAO,CAAC,iBAAiB,CAAC;IAI3E,mBAAmB;IACb,gBAAgB,CAAC,MAAM,EAAE,uBAAuB,GAAG;QAAE,KAAK,EAAE,MAAM,CAAA;KAAE,GAAG,OAAO,CAAC,iBAAiB,CAAC;IAgCvG,mBAAmB;IACnB,eAAe,CAAC,IAAI,CAAC,EAAE,MAAM,GAAG,OAAO;IAcvC,uBAAuB,CAAC,MAAM,EAAE,MAAM,GAAG,MAAM;IAI/C,mBAAmB;IACb,eAAe,CAAC,MAAM,EAAE,oBAAoB,GAAG,OAAO,CAAC,OAAO,CAAC;IAarE,eAAe,IAAI,IAAI;IAIvB;;;;;OAKG;IACH,iBAAiB,CAAC,OAAO,EAAE,MAAM,GAAG,cAAc;IA4ClD;;;;;OAKG;IACH,aAAa,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO;IAUtC,OAAO,CAAC,8BAA8B;YAiExB,eAAe;CAwF9B"}
|
|
@@ -0,0 +1,283 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.CosmosCoin = void 0;
|
|
4
|
+
const sdk_core_1 = require("@bitgo-beta/sdk-core");
|
|
5
|
+
const sdk_lib_mpc_1 = require("@bitgo-beta/sdk-lib-mpc");
|
|
6
|
+
const utxo_lib_1 = require("@bitgo-beta/utxo-lib");
|
|
7
|
+
const bignumber_js_1 = require("bignumber.js");
|
|
8
|
+
const crypto_1 = require("crypto");
|
|
9
|
+
const _ = require("lodash");
|
|
10
|
+
const utils_1 = require("./lib/utils");
|
|
11
|
+
const url = require("url");
|
|
12
|
+
const querystring = require("querystring");
|
|
13
|
+
const lib_1 = require("./lib");
|
|
14
|
+
const buffer_1 = require("buffer");
|
|
15
|
+
class CosmosCoin extends sdk_core_1.BaseCoin {
|
|
16
|
+
constructor(bitgo, staticsCoin) {
|
|
17
|
+
super(bitgo);
|
|
18
|
+
if (!staticsCoin) {
|
|
19
|
+
throw new Error('missing required constructor parameter staticsCoin');
|
|
20
|
+
}
|
|
21
|
+
this._staticsCoin = staticsCoin;
|
|
22
|
+
}
|
|
23
|
+
static createInstance(bitgo, staticsCoin) {
|
|
24
|
+
return new CosmosCoin(bitgo, staticsCoin);
|
|
25
|
+
}
|
|
26
|
+
/** @inheritDoc **/
|
|
27
|
+
getBaseFactor() {
|
|
28
|
+
return 1e6;
|
|
29
|
+
}
|
|
30
|
+
/** @inheritDoc **/
|
|
31
|
+
getChain() {
|
|
32
|
+
return this._staticsCoin.name;
|
|
33
|
+
}
|
|
34
|
+
/** @inheritDoc **/
|
|
35
|
+
getFamily() {
|
|
36
|
+
return this._staticsCoin.family;
|
|
37
|
+
}
|
|
38
|
+
/** @inheritDoc **/
|
|
39
|
+
getFullName() {
|
|
40
|
+
return this._staticsCoin.fullName;
|
|
41
|
+
}
|
|
42
|
+
/** @inheritDoc */
|
|
43
|
+
supportsTss() {
|
|
44
|
+
return true;
|
|
45
|
+
}
|
|
46
|
+
/** @inheritDoc **/
|
|
47
|
+
getMPCAlgorithm() {
|
|
48
|
+
return 'ecdsa';
|
|
49
|
+
}
|
|
50
|
+
/** @inheritDoc **/
|
|
51
|
+
isValidPub(pub) {
|
|
52
|
+
return utils_1.default.isValidPublicKey(pub);
|
|
53
|
+
}
|
|
54
|
+
/** @inheritDoc **/
|
|
55
|
+
isValidPrv(prv) {
|
|
56
|
+
return utils_1.default.isValidPrivateKey(prv);
|
|
57
|
+
}
|
|
58
|
+
verifyTransaction(params) {
|
|
59
|
+
throw new Error('Method not implemented.');
|
|
60
|
+
}
|
|
61
|
+
isValidAddress(address) {
|
|
62
|
+
throw new Error('Method not implemented.');
|
|
63
|
+
}
|
|
64
|
+
signTransaction(params) {
|
|
65
|
+
throw new Error('Method not implemented.');
|
|
66
|
+
}
|
|
67
|
+
/** @inheritDoc **/
|
|
68
|
+
async parseTransaction(params) {
|
|
69
|
+
const transactionExplanation = await this.explainTransaction({ txHex: params.txHex });
|
|
70
|
+
if (!transactionExplanation) {
|
|
71
|
+
throw new Error('Invalid transaction');
|
|
72
|
+
}
|
|
73
|
+
if (transactionExplanation.outputs.length <= 0) {
|
|
74
|
+
return {
|
|
75
|
+
inputs: [],
|
|
76
|
+
outputs: [],
|
|
77
|
+
};
|
|
78
|
+
}
|
|
79
|
+
const senderAddress = transactionExplanation.outputs[0].address;
|
|
80
|
+
const feeAmount = new bignumber_js_1.BigNumber(transactionExplanation.fee.fee === '' ? '0' : transactionExplanation.fee.fee);
|
|
81
|
+
const inputs = [
|
|
82
|
+
{
|
|
83
|
+
address: senderAddress,
|
|
84
|
+
amount: new bignumber_js_1.BigNumber(transactionExplanation.outputAmount).plus(feeAmount).toFixed(),
|
|
85
|
+
},
|
|
86
|
+
];
|
|
87
|
+
const outputs = transactionExplanation.outputs.map((output) => {
|
|
88
|
+
return {
|
|
89
|
+
address: output.address,
|
|
90
|
+
amount: new bignumber_js_1.BigNumber(output.amount).toFixed(),
|
|
91
|
+
};
|
|
92
|
+
});
|
|
93
|
+
return {
|
|
94
|
+
inputs,
|
|
95
|
+
outputs,
|
|
96
|
+
};
|
|
97
|
+
}
|
|
98
|
+
/** @inheritDoc **/
|
|
99
|
+
generateKeyPair(seed) {
|
|
100
|
+
if (!seed) {
|
|
101
|
+
// An extended private key has both a normal 256 bit private key and a 256
|
|
102
|
+
// bit chain code, both of which must be random. 512 bits is therefore the
|
|
103
|
+
// maximum entropy and gives us maximum security against cracking.
|
|
104
|
+
seed = crypto_1.randomBytes(512 / 8);
|
|
105
|
+
}
|
|
106
|
+
const extendedKey = utxo_lib_1.bip32.fromSeed(seed);
|
|
107
|
+
return {
|
|
108
|
+
pub: extendedKey.neutered().toBase58(),
|
|
109
|
+
prv: extendedKey.toBase58(),
|
|
110
|
+
};
|
|
111
|
+
}
|
|
112
|
+
getAddressFromPublicKey(pubKey) {
|
|
113
|
+
return new lib_1.CosmosKeyPair({ pub: pubKey }).getAddress();
|
|
114
|
+
}
|
|
115
|
+
/** @inheritDoc **/
|
|
116
|
+
async isWalletAddress(params) {
|
|
117
|
+
const addressDetails = this.getAddressDetails(params.address);
|
|
118
|
+
if (!this.isValidAddress(addressDetails.address)) {
|
|
119
|
+
throw new sdk_core_1.InvalidAddressError(`invalid address: ${addressDetails.address}`);
|
|
120
|
+
}
|
|
121
|
+
const rootAddress = params.coinSpecific.rootAddress;
|
|
122
|
+
if (addressDetails.address !== rootAddress) {
|
|
123
|
+
throw new sdk_core_1.UnexpectedAddressError(`address validation failure: ${addressDetails.address} vs ${rootAddress}`);
|
|
124
|
+
}
|
|
125
|
+
return true;
|
|
126
|
+
}
|
|
127
|
+
getHashFunction() {
|
|
128
|
+
return crypto_1.createHash('sha256');
|
|
129
|
+
}
|
|
130
|
+
/**
|
|
131
|
+
* Process address into address and memo id
|
|
132
|
+
*
|
|
133
|
+
* @param address the address
|
|
134
|
+
* @returns object containing address and memo id
|
|
135
|
+
*/
|
|
136
|
+
getAddressDetails(address) {
|
|
137
|
+
const destinationDetails = url.parse(address);
|
|
138
|
+
const destinationAddress = destinationDetails.pathname || '';
|
|
139
|
+
// address doesn't have a memo id
|
|
140
|
+
if (destinationDetails.pathname === address) {
|
|
141
|
+
return {
|
|
142
|
+
address: address,
|
|
143
|
+
memoId: undefined,
|
|
144
|
+
};
|
|
145
|
+
}
|
|
146
|
+
if (!destinationDetails.query) {
|
|
147
|
+
throw new sdk_core_1.InvalidAddressError(`invalid address: ${address}`);
|
|
148
|
+
}
|
|
149
|
+
const queryDetails = querystring.parse(destinationDetails.query);
|
|
150
|
+
if (!queryDetails.memoId) {
|
|
151
|
+
// if there are more properties, the query details need to contain the memo id property
|
|
152
|
+
throw new sdk_core_1.InvalidAddressError(`invalid address: ${address}`);
|
|
153
|
+
}
|
|
154
|
+
if (Array.isArray(queryDetails.memoId)) {
|
|
155
|
+
throw new sdk_core_1.InvalidAddressError(`memoId may only be given at most once, but found ${queryDetails.memoId.length} instances in address ${address}`);
|
|
156
|
+
}
|
|
157
|
+
if (Array.isArray(queryDetails.memoId) && queryDetails.memoId.length !== 1) {
|
|
158
|
+
// valid addresses can only contain one memo id
|
|
159
|
+
throw new sdk_core_1.InvalidAddressError(`invalid address '${address}', must contain exactly one memoId`);
|
|
160
|
+
}
|
|
161
|
+
const [memoId] = _.castArray(queryDetails.memoId) || undefined;
|
|
162
|
+
if (!this.isValidMemoId(memoId)) {
|
|
163
|
+
throw new sdk_core_1.InvalidMemoIdError(`invalid address: '${address}', memoId is not valid`);
|
|
164
|
+
}
|
|
165
|
+
return {
|
|
166
|
+
address: destinationAddress,
|
|
167
|
+
memoId,
|
|
168
|
+
};
|
|
169
|
+
}
|
|
170
|
+
/**
|
|
171
|
+
* Return boolean indicating whether a memo id is valid
|
|
172
|
+
*
|
|
173
|
+
* @param memoId memo id
|
|
174
|
+
* @returns true if memo id is valid
|
|
175
|
+
*/
|
|
176
|
+
isValidMemoId(memoId) {
|
|
177
|
+
let memoIdNumber;
|
|
178
|
+
try {
|
|
179
|
+
memoIdNumber = new bignumber_js_1.BigNumber(memoId);
|
|
180
|
+
}
|
|
181
|
+
catch (e) {
|
|
182
|
+
return false;
|
|
183
|
+
}
|
|
184
|
+
return memoIdNumber.gte(0);
|
|
185
|
+
}
|
|
186
|
+
getKeyCombinedFromTssKeyShares(userPublicOrPrivateKeyShare, backupPrivateOrPublicKeyShare, walletPassphrase) {
|
|
187
|
+
let backupPrv;
|
|
188
|
+
let userPrv;
|
|
189
|
+
try {
|
|
190
|
+
backupPrv = this.bitgo.decrypt({
|
|
191
|
+
input: backupPrivateOrPublicKeyShare,
|
|
192
|
+
password: walletPassphrase,
|
|
193
|
+
});
|
|
194
|
+
userPrv = this.bitgo.decrypt({
|
|
195
|
+
input: userPublicOrPrivateKeyShare,
|
|
196
|
+
password: walletPassphrase,
|
|
197
|
+
});
|
|
198
|
+
}
|
|
199
|
+
catch (e) {
|
|
200
|
+
throw new Error(`Error decrypting backup keychain: ${e.message}`);
|
|
201
|
+
}
|
|
202
|
+
const userSigningMaterial = JSON.parse(userPrv);
|
|
203
|
+
const backupSigningMaterial = JSON.parse(backupPrv);
|
|
204
|
+
if (!userSigningMaterial.backupNShare) {
|
|
205
|
+
throw new Error('Invalid user key - missing backupNShare');
|
|
206
|
+
}
|
|
207
|
+
if (!backupSigningMaterial.userNShare) {
|
|
208
|
+
throw new Error('Invalid backup key - missing userNShare');
|
|
209
|
+
}
|
|
210
|
+
const MPC = new sdk_core_1.Ecdsa();
|
|
211
|
+
const userKeyCombined = MPC.keyCombine(userSigningMaterial.pShare, [
|
|
212
|
+
userSigningMaterial.bitgoNShare,
|
|
213
|
+
userSigningMaterial.backupNShare,
|
|
214
|
+
]);
|
|
215
|
+
const userSigningKeyDerived = MPC.keyDerive(userSigningMaterial.pShare, [userSigningMaterial.bitgoNShare, userSigningMaterial.backupNShare], 'm/0');
|
|
216
|
+
const userKeyDerivedCombined = {
|
|
217
|
+
xShare: userSigningKeyDerived.xShare,
|
|
218
|
+
yShares: userKeyCombined.yShares,
|
|
219
|
+
};
|
|
220
|
+
const backupKeyCombined = MPC.keyCombine(backupSigningMaterial.pShare, [
|
|
221
|
+
userSigningKeyDerived.nShares[2],
|
|
222
|
+
backupSigningMaterial.bitgoNShare,
|
|
223
|
+
]);
|
|
224
|
+
if (userKeyDerivedCombined.xShare.y !== backupKeyCombined.xShare.y ||
|
|
225
|
+
userKeyDerivedCombined.xShare.chaincode !== backupKeyCombined.xShare.chaincode) {
|
|
226
|
+
throw new Error('Common keychains do not match');
|
|
227
|
+
}
|
|
228
|
+
return [userKeyDerivedCombined, backupKeyCombined];
|
|
229
|
+
}
|
|
230
|
+
// TODO(BG-78714): Reduce code duplication between this and eth.ts
|
|
231
|
+
async signRecoveryTSS(userKeyCombined, backupKeyCombined, txHex, { rangeProofChallenge, } = {}) {
|
|
232
|
+
const MPC = new sdk_core_1.Ecdsa();
|
|
233
|
+
const signerOneIndex = userKeyCombined.xShare.i;
|
|
234
|
+
const signerTwoIndex = backupKeyCombined.xShare.i;
|
|
235
|
+
// Since this is a user <> backup signing, we will reuse the same range proof challenge
|
|
236
|
+
rangeProofChallenge =
|
|
237
|
+
rangeProofChallenge !== null && rangeProofChallenge !== void 0 ? rangeProofChallenge : sdk_lib_mpc_1.EcdsaTypes.serializeNtildeWithProofs(await sdk_lib_mpc_1.EcdsaRangeProof.generateNtilde());
|
|
238
|
+
const userToBackupPaillierChallenge = await sdk_lib_mpc_1.EcdsaPaillierProof.generateP(sdk_core_1.hexToBigInt(userKeyCombined.yShares[signerTwoIndex].n));
|
|
239
|
+
const backupToUserPaillierChallenge = await sdk_lib_mpc_1.EcdsaPaillierProof.generateP(sdk_core_1.hexToBigInt(backupKeyCombined.yShares[signerOneIndex].n));
|
|
240
|
+
const userXShare = MPC.appendChallenge(userKeyCombined.xShare, rangeProofChallenge, sdk_lib_mpc_1.EcdsaTypes.serializePaillierChallenge({ p: userToBackupPaillierChallenge }));
|
|
241
|
+
const userYShare = MPC.appendChallenge(userKeyCombined.yShares[signerTwoIndex], rangeProofChallenge, sdk_lib_mpc_1.EcdsaTypes.serializePaillierChallenge({ p: backupToUserPaillierChallenge }));
|
|
242
|
+
const backupXShare = MPC.appendChallenge(backupKeyCombined.xShare, rangeProofChallenge, sdk_lib_mpc_1.EcdsaTypes.serializePaillierChallenge({ p: backupToUserPaillierChallenge }));
|
|
243
|
+
const backupYShare = MPC.appendChallenge(backupKeyCombined.yShares[signerOneIndex], rangeProofChallenge, sdk_lib_mpc_1.EcdsaTypes.serializePaillierChallenge({ p: userToBackupPaillierChallenge }));
|
|
244
|
+
const signShares = await MPC.signShare(userXShare, userYShare);
|
|
245
|
+
const signConvertS21 = await MPC.signConvertStep1({
|
|
246
|
+
xShare: backupXShare,
|
|
247
|
+
yShare: backupYShare,
|
|
248
|
+
kShare: signShares.kShare,
|
|
249
|
+
});
|
|
250
|
+
const signConvertS12 = await MPC.signConvertStep2({
|
|
251
|
+
aShare: signConvertS21.aShare,
|
|
252
|
+
wShare: signShares.wShare,
|
|
253
|
+
});
|
|
254
|
+
const signConvertS21_2 = await MPC.signConvertStep3({
|
|
255
|
+
muShare: signConvertS12.muShare,
|
|
256
|
+
bShare: signConvertS21.bShare,
|
|
257
|
+
});
|
|
258
|
+
const [signCombineOne, signCombineTwo] = [
|
|
259
|
+
MPC.signCombine({
|
|
260
|
+
gShare: signConvertS12.gShare,
|
|
261
|
+
signIndex: {
|
|
262
|
+
i: signConvertS12.muShare.i,
|
|
263
|
+
j: signConvertS12.muShare.j,
|
|
264
|
+
},
|
|
265
|
+
}),
|
|
266
|
+
MPC.signCombine({
|
|
267
|
+
gShare: signConvertS21_2.gShare,
|
|
268
|
+
signIndex: {
|
|
269
|
+
i: signConvertS21_2.signIndex.i,
|
|
270
|
+
j: signConvertS21_2.signIndex.j,
|
|
271
|
+
},
|
|
272
|
+
}),
|
|
273
|
+
];
|
|
274
|
+
const MESSAGE = buffer_1.Buffer.from(txHex, 'hex');
|
|
275
|
+
const [signA, signB] = [
|
|
276
|
+
MPC.sign(MESSAGE, signCombineOne.oShare, signCombineTwo.dShare, crypto_1.createHash('sha256')),
|
|
277
|
+
MPC.sign(MESSAGE, signCombineTwo.oShare, signCombineOne.dShare, crypto_1.createHash('sha256')),
|
|
278
|
+
];
|
|
279
|
+
return MPC.constructSignature([signA, signB]);
|
|
280
|
+
}
|
|
281
|
+
}
|
|
282
|
+
exports.CosmosCoin = CosmosCoin;
|
|
283
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cosmosCoin.js","sourceRoot":"","sources":["../../src/cosmosCoin.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  BaseCoin,\n  BitGoBase,\n  Ecdsa,\n  ECDSA,\n  ECDSAMethodTypes,\n  hexToBigInt,\n  InvalidAddressError,\n  InvalidMemoIdError,\n  KeyPair,\n  MPCAlgorithm,\n  ParsedTransaction,\n  ParseTransactionOptions,\n  SignedTransaction,\n  SignTransactionOptions,\n  UnexpectedAddressError,\n  VerifyAddressOptions,\n  VerifyTransactionOptions,\n} from '@bitgo-beta/sdk-core';\nimport { EcdsaPaillierProof, EcdsaRangeProof, EcdsaTypes } from '@bitgo-beta/sdk-lib-mpc';\nimport { BaseCoin as StaticsBaseCoin, CoinFamily } from '@bitgo-beta/statics';\nimport { bip32 } from '@bitgo-beta/utxo-lib';\nimport { BigNumber } from 'bignumber.js';\nimport { createHash, Hash, randomBytes } from 'crypto';\nimport * as _ from 'lodash';\nimport utils from './lib/utils';\nimport * as url from 'url';\nimport * as querystring from 'querystring';\nimport { CosmosKeyPair } from './lib';\nimport { Buffer } from 'buffer';\n\n/**\n * Cosmos accounts support memo Id based addresses\n */\ninterface AddressDetails {\n  address: string;\n  memoId?: string | undefined;\n}\n\n/**\n * Cosmos accounts support memo Id based addresses\n */\ninterface CosmosCoinSpecific {\n  rootAddress: string;\n}\n\nexport class CosmosCoin extends BaseCoin {\n  protected readonly _staticsCoin: Readonly<StaticsBaseCoin>;\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 CosmosCoin(bitgo, staticsCoin);\n  }\n\n  /** @inheritDoc **/\n  getBaseFactor(): string | number {\n    return 1e6;\n  }\n\n  /** @inheritDoc **/\n  getChain(): string {\n    return this._staticsCoin.name;\n  }\n\n  /** @inheritDoc **/\n  getFamily(): CoinFamily {\n    return this._staticsCoin.family;\n  }\n\n  /** @inheritDoc **/\n  getFullName(): string {\n    return this._staticsCoin.fullName;\n  }\n\n  /** @inheritDoc */\n  supportsTss(): boolean {\n    return true;\n  }\n\n  /** @inheritDoc **/\n  getMPCAlgorithm(): MPCAlgorithm {\n    return 'ecdsa';\n  }\n\n  /** @inheritDoc **/\n  isValidPub(pub: string): boolean {\n    return utils.isValidPublicKey(pub);\n  }\n\n  /** @inheritDoc **/\n  isValidPrv(prv: string): boolean {\n    return utils.isValidPrivateKey(prv);\n  }\n\n  verifyTransaction(params: VerifyTransactionOptions): Promise<boolean> {\n    throw new Error('Method not implemented.');\n  }\n\n  isValidAddress(address: string): boolean {\n    throw new Error('Method not implemented.');\n  }\n\n  signTransaction(params: SignTransactionOptions): Promise<SignedTransaction> {\n    throw new Error('Method not implemented.');\n  }\n\n  /** @inheritDoc **/\n  async parseTransaction(params: ParseTransactionOptions & { txHex: string }): Promise<ParsedTransaction> {\n    const transactionExplanation = await this.explainTransaction({ txHex: params.txHex });\n    if (!transactionExplanation) {\n      throw new Error('Invalid transaction');\n    }\n\n    if (transactionExplanation.outputs.length <= 0) {\n      return {\n        inputs: [],\n        outputs: [],\n      };\n    }\n    const senderAddress = transactionExplanation.outputs[0].address;\n    const feeAmount = new BigNumber(transactionExplanation.fee.fee === '' ? '0' : transactionExplanation.fee.fee);\n    const inputs = [\n      {\n        address: senderAddress,\n        amount: new BigNumber(transactionExplanation.outputAmount).plus(feeAmount).toFixed(),\n      },\n    ];\n    const outputs = transactionExplanation.outputs.map((output) => {\n      return {\n        address: output.address,\n        amount: new BigNumber(output.amount).toFixed(),\n      };\n    });\n    return {\n      inputs,\n      outputs,\n    };\n  }\n\n  /** @inheritDoc **/\n  generateKeyPair(seed?: Buffer): KeyPair {\n    if (!seed) {\n      // An extended private key has both a normal 256 bit private key and a 256\n      // bit chain code, both of which must be random. 512 bits is therefore the\n      // maximum entropy and gives us maximum security against cracking.\n      seed = randomBytes(512 / 8);\n    }\n    const extendedKey = bip32.fromSeed(seed);\n    return {\n      pub: extendedKey.neutered().toBase58(),\n      prv: extendedKey.toBase58(),\n    };\n  }\n\n  getAddressFromPublicKey(pubKey: string): string {\n    return new CosmosKeyPair({ pub: pubKey }).getAddress();\n  }\n\n  /** @inheritDoc **/\n  async isWalletAddress(params: VerifyAddressOptions): Promise<boolean> {\n    const addressDetails = this.getAddressDetails(params.address);\n\n    if (!this.isValidAddress(addressDetails.address)) {\n      throw new InvalidAddressError(`invalid address: ${addressDetails.address}`);\n    }\n    const rootAddress = (params.coinSpecific as CosmosCoinSpecific).rootAddress;\n    if (addressDetails.address !== rootAddress) {\n      throw new UnexpectedAddressError(`address validation failure: ${addressDetails.address} vs ${rootAddress}`);\n    }\n    return true;\n  }\n\n  getHashFunction(): Hash {\n    return createHash('sha256');\n  }\n\n  /**\n   * Process address into address and memo id\n   *\n   * @param address the address\n   * @returns object containing address and memo id\n   */\n  getAddressDetails(address: string): AddressDetails {\n    const destinationDetails = url.parse(address);\n    const destinationAddress = destinationDetails.pathname || '';\n\n    // address doesn't have a memo id\n    if (destinationDetails.pathname === address) {\n      return {\n        address: address,\n        memoId: undefined,\n      };\n    }\n\n    if (!destinationDetails.query) {\n      throw new InvalidAddressError(`invalid address: ${address}`);\n    }\n\n    const queryDetails = querystring.parse(destinationDetails.query);\n    if (!queryDetails.memoId) {\n      // if there are more properties, the query details need to contain the memo id property\n      throw new InvalidAddressError(`invalid address: ${address}`);\n    }\n\n    if (Array.isArray(queryDetails.memoId)) {\n      throw new InvalidAddressError(\n        `memoId may only be given at most once, but found ${queryDetails.memoId.length} instances in address ${address}`\n      );\n    }\n\n    if (Array.isArray(queryDetails.memoId) && queryDetails.memoId.length !== 1) {\n      // valid addresses can only contain one memo id\n      throw new InvalidAddressError(`invalid address '${address}', must contain exactly one memoId`);\n    }\n\n    const [memoId] = _.castArray(queryDetails.memoId) || undefined;\n    if (!this.isValidMemoId(memoId)) {\n      throw new InvalidMemoIdError(`invalid address: '${address}', memoId is not valid`);\n    }\n\n    return {\n      address: destinationAddress,\n      memoId,\n    };\n  }\n\n  /**\n   * Return boolean indicating whether a memo id is valid\n   *\n   * @param memoId memo id\n   * @returns true if memo id is valid\n   */\n  isValidMemoId(memoId: string): boolean {\n    let memoIdNumber;\n    try {\n      memoIdNumber = new BigNumber(memoId);\n    } catch (e) {\n      return false;\n    }\n    return memoIdNumber.gte(0);\n  }\n\n  private getKeyCombinedFromTssKeyShares(\n    userPublicOrPrivateKeyShare: string,\n    backupPrivateOrPublicKeyShare: string,\n    walletPassphrase?: string\n  ): [ECDSAMethodTypes.KeyCombined, ECDSAMethodTypes.KeyCombined] {\n    let backupPrv;\n    let userPrv;\n    try {\n      backupPrv = this.bitgo.decrypt({\n        input: backupPrivateOrPublicKeyShare,\n        password: walletPassphrase,\n      });\n      userPrv = this.bitgo.decrypt({\n        input: userPublicOrPrivateKeyShare,\n        password: walletPassphrase,\n      });\n    } catch (e) {\n      throw new Error(`Error decrypting backup keychain: ${e.message}`);\n    }\n\n    const userSigningMaterial = JSON.parse(userPrv) as ECDSAMethodTypes.SigningMaterial;\n    const backupSigningMaterial = JSON.parse(backupPrv) as ECDSAMethodTypes.SigningMaterial;\n\n    if (!userSigningMaterial.backupNShare) {\n      throw new Error('Invalid user key - missing backupNShare');\n    }\n\n    if (!backupSigningMaterial.userNShare) {\n      throw new Error('Invalid backup key - missing userNShare');\n    }\n\n    const MPC = new Ecdsa();\n\n    const userKeyCombined = MPC.keyCombine(userSigningMaterial.pShare, [\n      userSigningMaterial.bitgoNShare,\n      userSigningMaterial.backupNShare,\n    ]);\n\n    const userSigningKeyDerived = MPC.keyDerive(\n      userSigningMaterial.pShare,\n      [userSigningMaterial.bitgoNShare, userSigningMaterial.backupNShare],\n      'm/0'\n    );\n\n    const userKeyDerivedCombined = {\n      xShare: userSigningKeyDerived.xShare,\n      yShares: userKeyCombined.yShares,\n    };\n\n    const backupKeyCombined = MPC.keyCombine(backupSigningMaterial.pShare, [\n      userSigningKeyDerived.nShares[2],\n      backupSigningMaterial.bitgoNShare,\n    ]);\n\n    if (\n      userKeyDerivedCombined.xShare.y !== backupKeyCombined.xShare.y ||\n      userKeyDerivedCombined.xShare.chaincode !== backupKeyCombined.xShare.chaincode\n    ) {\n      throw new Error('Common keychains do not match');\n    }\n\n    return [userKeyDerivedCombined, backupKeyCombined];\n  }\n\n  // TODO(BG-78714): Reduce code duplication between this and eth.ts\n  private async signRecoveryTSS(\n    userKeyCombined: ECDSA.KeyCombined,\n    backupKeyCombined: ECDSA.KeyCombined,\n    txHex: string,\n    {\n      rangeProofChallenge,\n    }: {\n      rangeProofChallenge?: EcdsaTypes.SerializedNtilde;\n    } = {}\n  ): Promise<ECDSAMethodTypes.Signature> {\n    const MPC = new Ecdsa();\n    const signerOneIndex = userKeyCombined.xShare.i;\n    const signerTwoIndex = backupKeyCombined.xShare.i;\n\n    // Since this is a user <> backup signing, we will reuse the same range proof challenge\n    rangeProofChallenge =\n      rangeProofChallenge ?? EcdsaTypes.serializeNtildeWithProofs(await EcdsaRangeProof.generateNtilde());\n\n    const userToBackupPaillierChallenge = await EcdsaPaillierProof.generateP(\n      hexToBigInt(userKeyCombined.yShares[signerTwoIndex].n)\n    );\n    const backupToUserPaillierChallenge = await EcdsaPaillierProof.generateP(\n      hexToBigInt(backupKeyCombined.yShares[signerOneIndex].n)\n    );\n\n    const userXShare = MPC.appendChallenge(\n      userKeyCombined.xShare,\n      rangeProofChallenge,\n      EcdsaTypes.serializePaillierChallenge({ p: userToBackupPaillierChallenge })\n    );\n    const userYShare = MPC.appendChallenge(\n      userKeyCombined.yShares[signerTwoIndex],\n      rangeProofChallenge,\n      EcdsaTypes.serializePaillierChallenge({ p: backupToUserPaillierChallenge })\n    );\n    const backupXShare = MPC.appendChallenge(\n      backupKeyCombined.xShare,\n      rangeProofChallenge,\n      EcdsaTypes.serializePaillierChallenge({ p: backupToUserPaillierChallenge })\n    );\n    const backupYShare = MPC.appendChallenge(\n      backupKeyCombined.yShares[signerOneIndex],\n      rangeProofChallenge,\n      EcdsaTypes.serializePaillierChallenge({ p: userToBackupPaillierChallenge })\n    );\n\n    const signShares: ECDSA.SignShareRT = await MPC.signShare(userXShare, userYShare);\n\n    const signConvertS21 = await MPC.signConvertStep1({\n      xShare: backupXShare,\n      yShare: backupYShare, // YShare corresponding to the other participant signerOne\n      kShare: signShares.kShare,\n    });\n    const signConvertS12 = await MPC.signConvertStep2({\n      aShare: signConvertS21.aShare,\n      wShare: signShares.wShare,\n    });\n    const signConvertS21_2 = await MPC.signConvertStep3({\n      muShare: signConvertS12.muShare,\n      bShare: signConvertS21.bShare,\n    });\n\n    const [signCombineOne, signCombineTwo] = [\n      MPC.signCombine({\n        gShare: signConvertS12.gShare,\n        signIndex: {\n          i: signConvertS12.muShare.i,\n          j: signConvertS12.muShare.j,\n        },\n      }),\n      MPC.signCombine({\n        gShare: signConvertS21_2.gShare,\n        signIndex: {\n          i: signConvertS21_2.signIndex.i,\n          j: signConvertS21_2.signIndex.j,\n        },\n      }),\n    ];\n\n    const MESSAGE = Buffer.from(txHex, 'hex');\n\n    const [signA, signB] = [\n      MPC.sign(MESSAGE, signCombineOne.oShare, signCombineTwo.dShare, createHash('sha256')),\n      MPC.sign(MESSAGE, signCombineTwo.oShare, signCombineOne.dShare, createHash('sha256')),\n    ];\n\n    return MPC.constructSignature([signA, signB]);\n  }\n}\n"]}
|
package/dist/src/index.d.ts
CHANGED
package/dist/src/index.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,OAAO,CAAC"}
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,OAAO,CAAC;AACtB,OAAO,EAAE,UAAU,EAAE,MAAM,cAAc,CAAC"}
|
package/dist/src/index.js
CHANGED
|
@@ -10,5 +10,8 @@ var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
|
10
10
|
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
11
11
|
};
|
|
12
12
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
13
|
+
exports.CosmosCoin = void 0;
|
|
13
14
|
__exportStar(require("./lib"), exports);
|
|
14
|
-
|
|
15
|
+
var cosmosCoin_1 = require("./cosmosCoin");
|
|
16
|
+
Object.defineProperty(exports, "CosmosCoin", { enumerable: true, get: function () { return cosmosCoin_1.CosmosCoin; } });
|
|
17
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7OztBQUFBLHdDQUFzQjtBQUN0QiwyQ0FBMEM7QUFBakMsd0dBQUEsVUFBVSxPQUFBIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9saWInO1xuZXhwb3J0IHsgQ29zbW9zQ29pbiB9IGZyb20gJy4vY29zbW9zQ29pbic7XG4iXX0=
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"transaction.d.ts","sourceRoot":"","sources":["../../../src/lib/transaction.ts"],"names":[],"mappings":";AAAA,OAAO,EACL,OAAO,EACP,eAAe,EAKf,eAAe,EAChB,MAAM,sBAAsB,CAAC;AAC9B,OAAO,EAAE,QAAQ,IAAI,UAAU,EAAE,MAAM,qBAAqB,CAAC;AAO7D,OAAO,EACL,qBAAqB,EAGrB,sBAAsB,EACtB,MAAM,EAEP,MAAM,SAAS,CAAC;AAGjB,qBAAa,iBAAkB,SAAQ,eAAe;IACpD,SAAS,CAAC,sBAAsB,EAAE,qBAAqB,CAAC;IACxD,SAAS,CAAC,cAAc,EAAE,MAAM,CAAC;IACjC,SAAS,CAAC,QAAQ,EAAE,MAAM,CAAC;gBAEf,WAAW,EAAE,QAAQ,CAAC,UAAU,CAAC;
|
|
1
|
+
{"version":3,"file":"transaction.d.ts","sourceRoot":"","sources":["../../../src/lib/transaction.ts"],"names":[],"mappings":";AAAA,OAAO,EACL,OAAO,EACP,eAAe,EAKf,eAAe,EAChB,MAAM,sBAAsB,CAAC;AAC9B,OAAO,EAAE,QAAQ,IAAI,UAAU,EAAE,MAAM,qBAAqB,CAAC;AAO7D,OAAO,EACL,qBAAqB,EAGrB,sBAAsB,EACtB,MAAM,EAEP,MAAM,SAAS,CAAC;AAGjB,qBAAa,iBAAkB,SAAQ,eAAe;IACpD,SAAS,CAAC,sBAAsB,EAAE,qBAAqB,CAAC;IACxD,SAAS,CAAC,cAAc,EAAE,MAAM,CAAC;IACjC,SAAS,CAAC,QAAQ,EAAE,MAAM,CAAC;gBAEf,WAAW,EAAE,QAAQ,CAAC,UAAU,CAAC;IAI7C,IAAI,qBAAqB,IAAI,qBAAqB,CAEjD;IAED,IAAI,qBAAqB,CAAC,qBAAqB,EAAE,QAAQ,CAAC,qBAAqB,CAAC,EAE/E;IAED,IAAI,OAAO,IAAI,MAAM,CAEpB;IAED,IAAI,OAAO,CAAC,OAAO,EAAE,MAAM,EAE1B;IAED,IAAI,aAAa,IAAI,MAAM,CAE1B;IAED,IAAI,aAAa,CAAC,aAAa,EAAE,MAAM,EAEtC;IAED,mBAAmB;IACnB,IAAI,EAAE,IAAI,MAAM,CAOf;IAED,kBAAkB;IAClB,OAAO,CAAC,GAAG,EAAE,OAAO,GAAG,OAAO;IAI9B,kBAAkB;IAClB,iBAAiB,IAAI,MAAM;IAO3B,kBAAkB;IAClB,MAAM,IAAI,MAAM;IAoBhB;;;OAGG;IACH,YAAY,CAAC,SAAS,EAAE,MAAM;IAK9B,kBAAkB;IAClB,kBAAkB,IAAI,sBAAsB;IAkB5C;;;OAGG;IACH,IAAI,eAAe,CAAC,eAAe,EAAE,eAAe,EAEnD;IAED;;;OAGG;IACH,SAAS,IAAI,MAAM;IASnB,mBAAmB;IACnB,IAAI,eAAe,IAAI,MAAM,CAI5B;IAED;;;;;;OAMG;IACH,0BAA0B,CAAC,IAAI,EAAE,MAAM,EAAE,iBAAiB,EAAE,sBAAsB,GAAG,sBAAsB;IA+D3G,oBAAoB,IAAI,IAAI;CAsD7B"}
|
|
@@ -10,13 +10,6 @@ const utils_1 = require("./utils");
|
|
|
10
10
|
class CosmosTransaction extends sdk_core_1.BaseTransaction {
|
|
11
11
|
constructor(_coinConfig) {
|
|
12
12
|
super(_coinConfig);
|
|
13
|
-
this._cosmosLikeTransaction = {
|
|
14
|
-
sequence: 0,
|
|
15
|
-
sendMessages: [],
|
|
16
|
-
gasBudget: { gasLimit: 0, amount: [] },
|
|
17
|
-
};
|
|
18
|
-
this._accountNumber = 0;
|
|
19
|
-
this._chainId = '';
|
|
20
13
|
}
|
|
21
14
|
get cosmosLikeTransaction() {
|
|
22
15
|
return this._cosmosLikeTransaction;
|
|
@@ -251,4 +244,4 @@ class CosmosTransaction extends sdk_core_1.BaseTransaction {
|
|
|
251
244
|
}
|
|
252
245
|
}
|
|
253
246
|
exports.CosmosTransaction = CosmosTransaction;
|
|
254
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"transaction.js","sourceRoot":"","sources":["../../../src/lib/transaction.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  BaseKey,\n  BaseTransaction,\n  Entry,\n  InvalidTransactionError,\n  ParseTransactionError,\n  TransactionRecipient,\n  TransactionType,\n} from '@bitgo-beta/sdk-core';\nimport { BaseCoin as CoinConfig } from '@bitgo-beta/statics';\nimport { toBase64 } from '@cosmjs/encoding';\nimport { makeSignBytes } from '@cosmjs/proto-signing';\nimport { TxRaw } from 'cosmjs-types/cosmos/tx/v1beta1/tx';\n\nimport { UNAVAILABLE_TEXT } from './constants';\n\nimport {\n  CosmosLikeTransaction,\n  DelegateOrUndelegeteMessage,\n  SendMessage,\n  TransactionExplanation,\n  TxData,\n  WithdrawDelegatorRewardsMessage,\n} from './iface';\nimport utils from './utils';\n\nexport class CosmosTransaction extends BaseTransaction {\n  protected _cosmosLikeTransaction: CosmosLikeTransaction;\n  protected _accountNumber: number;\n  protected _chainId: string;\n\n  constructor(_coinConfig: Readonly<CoinConfig>) {\n    super(_coinConfig);\n    this._cosmosLikeTransaction = {\n      sequence: 0,\n      sendMessages: [],\n      gasBudget: { gasLimit: 0, amount: [] },\n    };\n    this._accountNumber = 0;\n    this._chainId = '';\n  }\n\n  get cosmosLikeTransaction(): CosmosLikeTransaction {\n    return this._cosmosLikeTransaction;\n  }\n\n  set cosmosLikeTransaction(cosmosLikeTransaction: Readonly<CosmosLikeTransaction>) {\n    this._cosmosLikeTransaction = cosmosLikeTransaction;\n  }\n\n  get chainId(): string {\n    return this._chainId;\n  }\n\n  set chainId(chainId: string) {\n    this._chainId = chainId;\n  }\n\n  get accountNumber(): number {\n    return this._accountNumber;\n  }\n\n  set accountNumber(accountNumber: number) {\n    this._accountNumber = accountNumber;\n  }\n\n  /** @inheritDoc **/\n  get id(): string {\n    if (this._id) {\n      return this._id;\n    } else if (this._cosmosLikeTransaction?.hash !== undefined) {\n      return this._cosmosLikeTransaction.hash;\n    }\n    return UNAVAILABLE_TEXT;\n  }\n\n  /** @inheritdoc */\n  canSign(key: BaseKey): boolean {\n    return true;\n  }\n\n  /** @inheritdoc */\n  toBroadcastFormat(): string {\n    if (!this._cosmosLikeTransaction) {\n      throw new InvalidTransactionError('Empty transaction');\n    }\n    return this.serialize();\n  }\n\n  /** @inheritdoc */\n  toJson(): TxData {\n    if (!this._cosmosLikeTransaction) {\n      throw new ParseTransactionError('Empty transaction');\n    }\n    const tx = this._cosmosLikeTransaction;\n    return {\n      id: this.id,\n      type: this._type,\n      sequence: tx.sequence,\n      sendMessages: tx.sendMessages,\n      gasBudget: tx.gasBudget,\n      publicKey: tx.publicKey,\n      signature: tx.signature,\n      accountNumber: this._accountNumber,\n      chainId: this._chainId,\n      hash: tx.hash,\n      memo: tx.memo,\n    };\n  }\n\n  /**\n   * Add a signature to the transaction\n   * @param {string} signature in hex format\n   */\n  addSignature(signature: string) {\n    this._signatures = [];\n    this._signatures.push(signature);\n  }\n\n  /** @inheritDoc */\n  explainTransaction(): TransactionExplanation {\n    const result = this.toJson();\n    const displayOrder = ['id', 'outputs', 'outputAmount', 'changeOutputs', 'changeAmount', 'fee', 'type'];\n    const outputs: TransactionRecipient[] = [];\n\n    const explanationResult: TransactionExplanation = {\n      displayOrder,\n      id: this.id,\n      outputs,\n      outputAmount: '0',\n      changeOutputs: [],\n      changeAmount: '0',\n      fee: { fee: this.cosmosLikeTransaction.gasBudget.amount[0].amount },\n      type: this.type,\n    };\n    return this.explainTransactionInternal(result, explanationResult);\n  }\n\n  /**\n   * Set the transaction type.\n   * @param {TransactionType} transactionType The transaction type to be set.\n   */\n  set transactionType(transactionType: TransactionType) {\n    this._type = transactionType;\n  }\n\n  /**\n   * Serialize the transaction to a JSON string\n   * @returns {string} serialized base64 encoded transaction\n   */\n  serialize(): string {\n    const txRaw = utils.createTxRawFromCosmosLikeTransaction(this.cosmosLikeTransaction);\n    if (this.cosmosLikeTransaction?.publicKey !== undefined && this._signatures.length > 0) {\n      const signedRawTx = utils.createSignedTxRaw(this.cosmosLikeTransaction.publicKey, this._signatures[0], txRaw);\n      return toBase64(TxRaw.encode(signedRawTx).finish());\n    }\n    return toBase64(TxRaw.encode(txRaw).finish());\n  }\n\n  /** @inheritdoc **/\n  get signablePayload(): Buffer {\n    return Buffer.from(\n      makeSignBytes(utils.createSignDoc(this.cosmosLikeTransaction, this._accountNumber, this._chainId))\n    );\n  }\n\n  /**\n   * Returns a complete explanation for a transfer transaction\n   * Currently only supports one message per transfer.\n   * @param {TxData} json The transaction data in json format\n   * @param {TransactionExplanation} explanationResult The transaction explanation to be completed\n   * @returns {TransactionExplanation}\n   */\n  explainTransactionInternal(json: TxData, explanationResult: TransactionExplanation): TransactionExplanation {\n    let outputs: TransactionRecipient[];\n    let message;\n    let outputAmount;\n    switch (json.type) {\n      case TransactionType.Send:\n        explanationResult.type = TransactionType.Send;\n        message = json.sendMessages[0].value as SendMessage;\n        outputAmount = message.amount[0].amount;\n        outputs = [\n          {\n            address: message.toAddress,\n            amount: outputAmount,\n          },\n        ];\n        break;\n      case TransactionType.StakingActivate:\n        explanationResult.type = TransactionType.StakingActivate;\n        message = json.sendMessages[0].value as DelegateOrUndelegeteMessage;\n        outputAmount = message.amount.amount;\n        outputs = [\n          {\n            address: message.validatorAddress,\n            amount: outputAmount,\n          },\n        ];\n        break;\n      case TransactionType.StakingDeactivate:\n        explanationResult.type = TransactionType.StakingDeactivate;\n        message = json.sendMessages[0].value as DelegateOrUndelegeteMessage;\n        outputAmount = message.amount.amount;\n        outputs = [\n          {\n            address: message.validatorAddress,\n            amount: outputAmount,\n          },\n        ];\n        break;\n      case TransactionType.StakingWithdraw:\n        explanationResult.type = TransactionType.StakingWithdraw;\n        message = json.sendMessages[0].value as WithdrawDelegatorRewardsMessage;\n        outputs = [\n          {\n            address: message.validatorAddress,\n            amount: UNAVAILABLE_TEXT,\n          },\n        ];\n        break;\n      default:\n        throw new InvalidTransactionError('Transaction type not supported');\n    }\n    if (json.memo) {\n      outputs.forEach((output) => {\n        output.memo = json.memo;\n      });\n    }\n    return {\n      ...explanationResult,\n      outputAmount,\n      outputs,\n    };\n  }\n\n  loadInputsAndOutputs(): void {\n    if (this.type === undefined || !this.cosmosLikeTransaction) {\n      throw new InvalidTransactionError('Transaction type or cosmosLikeTransaction is not set');\n    }\n\n    const outputs: Entry[] = [];\n    const inputs: Entry[] = [];\n    switch (this.type) {\n      case TransactionType.Send:\n        const message = this.cosmosLikeTransaction.sendMessages[0].value as SendMessage;\n        inputs.push({\n          address: message.fromAddress,\n          value: message.amount[0].amount,\n          coin: this._coinConfig.name,\n        });\n        outputs.push({\n          address: message.toAddress,\n          value: message.amount[0].amount,\n          coin: this._coinConfig.name,\n        });\n        break;\n      case TransactionType.StakingActivate:\n      case TransactionType.StakingDeactivate:\n        const delegateMessage = this.cosmosLikeTransaction.sendMessages[0].value as DelegateOrUndelegeteMessage;\n        inputs.push({\n          address: delegateMessage.delegatorAddress,\n          value: delegateMessage.amount.amount,\n          coin: this._coinConfig.name,\n        });\n        outputs.push({\n          address: delegateMessage.validatorAddress,\n          value: delegateMessage.amount.amount,\n          coin: this._coinConfig.name,\n        });\n        break;\n      case TransactionType.StakingWithdraw:\n        const withdrawMessage = this.cosmosLikeTransaction.sendMessages[0].value as WithdrawDelegatorRewardsMessage;\n        inputs.push({\n          address: withdrawMessage.delegatorAddress,\n          value: UNAVAILABLE_TEXT,\n          coin: this._coinConfig.name,\n        });\n        outputs.push({\n          address: withdrawMessage.validatorAddress,\n          value: UNAVAILABLE_TEXT,\n          coin: this._coinConfig.name,\n        });\n        break;\n      default:\n        throw new InvalidTransactionError('Transaction type not supported');\n    }\n    this._inputs = inputs;\n    this._outputs = outputs;\n  }\n}\n"]}
|
|
247
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"transaction.js","sourceRoot":"","sources":["../../../src/lib/transaction.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  BaseKey,\n  BaseTransaction,\n  Entry,\n  InvalidTransactionError,\n  ParseTransactionError,\n  TransactionRecipient,\n  TransactionType,\n} from '@bitgo-beta/sdk-core';\nimport { BaseCoin as CoinConfig } from '@bitgo-beta/statics';\nimport { toBase64 } from '@cosmjs/encoding';\nimport { makeSignBytes } from '@cosmjs/proto-signing';\nimport { TxRaw } from 'cosmjs-types/cosmos/tx/v1beta1/tx';\n\nimport { UNAVAILABLE_TEXT } from './constants';\n\nimport {\n  CosmosLikeTransaction,\n  DelegateOrUndelegeteMessage,\n  SendMessage,\n  TransactionExplanation,\n  TxData,\n  WithdrawDelegatorRewardsMessage,\n} from './iface';\nimport utils from './utils';\n\nexport class CosmosTransaction extends BaseTransaction {\n  protected _cosmosLikeTransaction: CosmosLikeTransaction;\n  protected _accountNumber: number;\n  protected _chainId: string;\n\n  constructor(_coinConfig: Readonly<CoinConfig>) {\n    super(_coinConfig);\n  }\n\n  get cosmosLikeTransaction(): CosmosLikeTransaction {\n    return this._cosmosLikeTransaction;\n  }\n\n  set cosmosLikeTransaction(cosmosLikeTransaction: Readonly<CosmosLikeTransaction>) {\n    this._cosmosLikeTransaction = cosmosLikeTransaction;\n  }\n\n  get chainId(): string {\n    return this._chainId;\n  }\n\n  set chainId(chainId: string) {\n    this._chainId = chainId;\n  }\n\n  get accountNumber(): number {\n    return this._accountNumber;\n  }\n\n  set accountNumber(accountNumber: number) {\n    this._accountNumber = accountNumber;\n  }\n\n  /** @inheritDoc **/\n  get id(): string {\n    if (this._id) {\n      return this._id;\n    } else if (this._cosmosLikeTransaction?.hash !== undefined) {\n      return this._cosmosLikeTransaction.hash;\n    }\n    return UNAVAILABLE_TEXT;\n  }\n\n  /** @inheritdoc */\n  canSign(key: BaseKey): boolean {\n    return true;\n  }\n\n  /** @inheritdoc */\n  toBroadcastFormat(): string {\n    if (!this._cosmosLikeTransaction) {\n      throw new InvalidTransactionError('Empty transaction');\n    }\n    return this.serialize();\n  }\n\n  /** @inheritdoc */\n  toJson(): TxData {\n    if (!this._cosmosLikeTransaction) {\n      throw new ParseTransactionError('Empty transaction');\n    }\n    const tx = this._cosmosLikeTransaction;\n    return {\n      id: this.id,\n      type: this._type,\n      sequence: tx.sequence,\n      sendMessages: tx.sendMessages,\n      gasBudget: tx.gasBudget,\n      publicKey: tx.publicKey,\n      signature: tx.signature,\n      accountNumber: this._accountNumber,\n      chainId: this._chainId,\n      hash: tx.hash,\n      memo: tx.memo,\n    };\n  }\n\n  /**\n   * Add a signature to the transaction\n   * @param {string} signature in hex format\n   */\n  addSignature(signature: string) {\n    this._signatures = [];\n    this._signatures.push(signature);\n  }\n\n  /** @inheritDoc */\n  explainTransaction(): TransactionExplanation {\n    const result = this.toJson();\n    const displayOrder = ['id', 'outputs', 'outputAmount', 'changeOutputs', 'changeAmount', 'fee', 'type'];\n    const outputs: TransactionRecipient[] = [];\n\n    const explanationResult: TransactionExplanation = {\n      displayOrder,\n      id: this.id,\n      outputs,\n      outputAmount: '0',\n      changeOutputs: [],\n      changeAmount: '0',\n      fee: { fee: this.cosmosLikeTransaction.gasBudget.amount[0].amount },\n      type: this.type,\n    };\n    return this.explainTransactionInternal(result, explanationResult);\n  }\n\n  /**\n   * Set the transaction type.\n   * @param {TransactionType} transactionType The transaction type to be set.\n   */\n  set transactionType(transactionType: TransactionType) {\n    this._type = transactionType;\n  }\n\n  /**\n   * Serialize the transaction to a JSON string\n   * @returns {string} serialized base64 encoded transaction\n   */\n  serialize(): string {\n    const txRaw = utils.createTxRawFromCosmosLikeTransaction(this.cosmosLikeTransaction);\n    if (this.cosmosLikeTransaction?.publicKey !== undefined && this._signatures.length > 0) {\n      const signedRawTx = utils.createSignedTxRaw(this.cosmosLikeTransaction.publicKey, this._signatures[0], txRaw);\n      return toBase64(TxRaw.encode(signedRawTx).finish());\n    }\n    return toBase64(TxRaw.encode(txRaw).finish());\n  }\n\n  /** @inheritdoc **/\n  get signablePayload(): Buffer {\n    return Buffer.from(\n      makeSignBytes(utils.createSignDoc(this.cosmosLikeTransaction, this._accountNumber, this._chainId))\n    );\n  }\n\n  /**\n   * Returns a complete explanation for a transfer transaction\n   * Currently only supports one message per transfer.\n   * @param {TxData} json The transaction data in json format\n   * @param {TransactionExplanation} explanationResult The transaction explanation to be completed\n   * @returns {TransactionExplanation}\n   */\n  explainTransactionInternal(json: TxData, explanationResult: TransactionExplanation): TransactionExplanation {\n    let outputs: TransactionRecipient[];\n    let message;\n    let outputAmount;\n    switch (json.type) {\n      case TransactionType.Send:\n        explanationResult.type = TransactionType.Send;\n        message = json.sendMessages[0].value as SendMessage;\n        outputAmount = message.amount[0].amount;\n        outputs = [\n          {\n            address: message.toAddress,\n            amount: outputAmount,\n          },\n        ];\n        break;\n      case TransactionType.StakingActivate:\n        explanationResult.type = TransactionType.StakingActivate;\n        message = json.sendMessages[0].value as DelegateOrUndelegeteMessage;\n        outputAmount = message.amount.amount;\n        outputs = [\n          {\n            address: message.validatorAddress,\n            amount: outputAmount,\n          },\n        ];\n        break;\n      case TransactionType.StakingDeactivate:\n        explanationResult.type = TransactionType.StakingDeactivate;\n        message = json.sendMessages[0].value as DelegateOrUndelegeteMessage;\n        outputAmount = message.amount.amount;\n        outputs = [\n          {\n            address: message.validatorAddress,\n            amount: outputAmount,\n          },\n        ];\n        break;\n      case TransactionType.StakingWithdraw:\n        explanationResult.type = TransactionType.StakingWithdraw;\n        message = json.sendMessages[0].value as WithdrawDelegatorRewardsMessage;\n        outputs = [\n          {\n            address: message.validatorAddress,\n            amount: UNAVAILABLE_TEXT,\n          },\n        ];\n        break;\n      default:\n        throw new InvalidTransactionError('Transaction type not supported');\n    }\n    if (json.memo) {\n      outputs.forEach((output) => {\n        output.memo = json.memo;\n      });\n    }\n    return {\n      ...explanationResult,\n      outputAmount,\n      outputs,\n    };\n  }\n\n  loadInputsAndOutputs(): void {\n    if (this.type === undefined || !this.cosmosLikeTransaction) {\n      throw new InvalidTransactionError('Transaction type or cosmosLikeTransaction is not set');\n    }\n\n    const outputs: Entry[] = [];\n    const inputs: Entry[] = [];\n    switch (this.type) {\n      case TransactionType.Send:\n        const message = this.cosmosLikeTransaction.sendMessages[0].value as SendMessage;\n        inputs.push({\n          address: message.fromAddress,\n          value: message.amount[0].amount,\n          coin: this._coinConfig.name,\n        });\n        outputs.push({\n          address: message.toAddress,\n          value: message.amount[0].amount,\n          coin: this._coinConfig.name,\n        });\n        break;\n      case TransactionType.StakingActivate:\n      case TransactionType.StakingDeactivate:\n        const delegateMessage = this.cosmosLikeTransaction.sendMessages[0].value as DelegateOrUndelegeteMessage;\n        inputs.push({\n          address: delegateMessage.delegatorAddress,\n          value: delegateMessage.amount.amount,\n          coin: this._coinConfig.name,\n        });\n        outputs.push({\n          address: delegateMessage.validatorAddress,\n          value: delegateMessage.amount.amount,\n          coin: this._coinConfig.name,\n        });\n        break;\n      case TransactionType.StakingWithdraw:\n        const withdrawMessage = this.cosmosLikeTransaction.sendMessages[0].value as WithdrawDelegatorRewardsMessage;\n        inputs.push({\n          address: withdrawMessage.delegatorAddress,\n          value: UNAVAILABLE_TEXT,\n          coin: this._coinConfig.name,\n        });\n        outputs.push({\n          address: withdrawMessage.validatorAddress,\n          value: UNAVAILABLE_TEXT,\n          coin: this._coinConfig.name,\n        });\n        break;\n      default:\n        throw new InvalidTransactionError('Transaction type not supported');\n    }\n    this._inputs = inputs;\n    this._outputs = outputs;\n  }\n}\n"]}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"transactionBuilder.d.ts","sourceRoot":"","sources":["../../../src/lib/transactionBuilder.ts"],"names":[],"mappings":";AAAA,OAAO,EACL,OAAO,EACP,sBAAsB,EAEtB,SAAS,IAAI,aAAa,EAE1B,eAAe,EAChB,MAAM,sBAAsB,CAAC;AAC9B,OAAO,EAAE,QAAQ,IAAI,UAAU,EAAE,MAAM,qBAAqB,CAAC;AAC7D,OAAO,SAAS,MAAM,cAAc,CAAC;AAErC,OAAO,EACL,2BAA2B,EAC3B,OAAO,EACP,WAAW,EACX,WAAW,EACX,+BAA+B,EAChC,MAAM,SAAS,CAAC;AACjB,OAAO,EAAE,aAAa,IAAI,OAAO,EAAE,MAAM,WAAW,CAAC;AACrD,OAAO,EAAE,iBAAiB,EAAE,MAAM,eAAe,CAAC;AAGlD,8BAAsB,wBAAyB,SAAQ,sBAAsB;IAC3E,SAAS,CAAC,YAAY,EAAE,iBAAiB,CAAC;IAC1C,SAAS,CAAC,SAAS,EAAE,MAAM,CAAC;IAC5B,SAAS,CAAC,SAAS,EAAE,WAAW,EAAE,CAAC;IACnC,SAAS,CAAC,UAAU,EAAE,OAAO,CAAC;IAC9B,SAAS,CAAC,cAAc,CAAC,EAAE,MAAM,CAAC;IAClC,SAAS,CAAC,UAAU,EAAE,MAAM,CAAC;IAC7B,SAAS,CAAC,QAAQ,CAAC,EAAE,MAAM,CAAC;IAC5B,SAAS,CAAC,UAAU,CAAC,EAAE,MAAM,CAAC;IAC9B,SAAS,CAAC,OAAO,EAAE,OAAO,CAAC;IAC3B,SAAS,CAAC,KAAK,CAAC,EAAE,MAAM,CAAC;gBAEb,WAAW,EAAE,QAAQ,CAAC,UAAU,CAAC;
|
|
1
|
+
{"version":3,"file":"transactionBuilder.d.ts","sourceRoot":"","sources":["../../../src/lib/transactionBuilder.ts"],"names":[],"mappings":";AAAA,OAAO,EACL,OAAO,EACP,sBAAsB,EAEtB,SAAS,IAAI,aAAa,EAE1B,eAAe,EAChB,MAAM,sBAAsB,CAAC;AAC9B,OAAO,EAAE,QAAQ,IAAI,UAAU,EAAE,MAAM,qBAAqB,CAAC;AAC7D,OAAO,SAAS,MAAM,cAAc,CAAC;AAErC,OAAO,EACL,2BAA2B,EAC3B,OAAO,EACP,WAAW,EACX,WAAW,EACX,+BAA+B,EAChC,MAAM,SAAS,CAAC;AACjB,OAAO,EAAE,aAAa,IAAI,OAAO,EAAE,MAAM,WAAW,CAAC;AACrD,OAAO,EAAE,iBAAiB,EAAE,MAAM,eAAe,CAAC;AAGlD,8BAAsB,wBAAyB,SAAQ,sBAAsB;IAC3E,SAAS,CAAC,YAAY,EAAE,iBAAiB,CAAC;IAC1C,SAAS,CAAC,SAAS,EAAE,MAAM,CAAC;IAC5B,SAAS,CAAC,SAAS,EAAE,WAAW,EAAE,CAAC;IACnC,SAAS,CAAC,UAAU,EAAE,OAAO,CAAC;IAC9B,SAAS,CAAC,cAAc,CAAC,EAAE,MAAM,CAAC;IAClC,SAAS,CAAC,UAAU,EAAE,MAAM,CAAC;IAC7B,SAAS,CAAC,QAAQ,CAAC,EAAE,MAAM,CAAC;IAC5B,SAAS,CAAC,UAAU,CAAC,EAAE,MAAM,CAAC;IAC9B,SAAS,CAAC,OAAO,EAAE,OAAO,CAAC;IAC3B,SAAS,CAAC,KAAK,CAAC,EAAE,MAAM,CAAC;gBAEb,WAAW,EAAE,QAAQ,CAAC,UAAU,CAAC;IAI7C;;OAEG;IACH,SAAS,CAAC,QAAQ,KAAK,eAAe,IAAI,eAAe,CAAC;IAE1D,kBAAkB;IAClB,SAAS,KAAK,WAAW,IAAI,iBAAiB,CAE7C;IAED,kBAAkB;IAClB,SAAS,KAAK,WAAW,CAAC,WAAW,EAAE,iBAAiB,EAEvD;IAED,kBAAkB;IAClB,YAAY,CAAC,SAAS,EAAE,aAAa,EAAE,SAAS,EAAE,MAAM,GAAG,IAAI;IAK/D;;;;OAIG;IACH,QAAQ,CAAC,QAAQ,EAAE,MAAM,GAAG,IAAI;IAMhC;;;;;;;;OAQG;IACH,QAAQ,CAAC,QAAQ,CAAC,QAAQ,EAAE,CAAC,WAAW,GAAG,2BAA2B,GAAG,+BAA+B,CAAC,EAAE,GAAG,IAAI;IAElH,SAAS,CAAC,SAAS,EAAE,MAAM,GAAG,SAAS,GAAG,IAAI;IAK9C,aAAa,CAAC,aAAa,EAAE,MAAM,GAAG,SAAS,GAAG,IAAI;IAKtD,OAAO,CAAC,OAAO,EAAE,MAAM,GAAG,SAAS,GAAG,IAAI;IAK1C,IAAI,CAAC,IAAI,EAAE,MAAM,GAAG,SAAS,GAAG,IAAI;IAKpC,kBAAkB;IAClB,SAAS,CAAC,kBAAkB,CAAC,GAAG,EAAE,OAAO,GAAG,iBAAiB;IAa7D,kBAAkB;IAClB,aAAa,CAAC,KAAK,EAAE,SAAS,GAAG,IAAI;IAMrC,kBAAkB;IAClB,WAAW,CAAC,GAAG,EAAE,OAAO,GAAG,IAAI;CAOhC"}
|
|
@@ -3,17 +3,10 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
3
3
|
exports.CosmosTransactionBuilder = void 0;
|
|
4
4
|
const sdk_core_1 = require("@bitgo-beta/sdk-core");
|
|
5
5
|
const keyPair_1 = require("./keyPair");
|
|
6
|
-
const transaction_1 = require("./transaction");
|
|
7
6
|
const utils_1 = require("./utils");
|
|
8
7
|
class CosmosTransactionBuilder extends sdk_core_1.BaseTransactionBuilder {
|
|
9
8
|
constructor(_coinConfig) {
|
|
10
9
|
super(_coinConfig);
|
|
11
|
-
this._transaction = new transaction_1.CosmosTransaction(_coinConfig);
|
|
12
|
-
this._sequence = 0;
|
|
13
|
-
this._messages = [];
|
|
14
|
-
this._gasBudget = { gasLimit: 0, amount: [] };
|
|
15
|
-
this._signature = Buffer.alloc(0);
|
|
16
|
-
this._signer = new keyPair_1.CosmosKeyPair();
|
|
17
10
|
}
|
|
18
11
|
/** @inheritdoc */
|
|
19
12
|
get transaction() {
|
|
@@ -84,4 +77,4 @@ class CosmosTransactionBuilder extends sdk_core_1.BaseTransactionBuilder {
|
|
|
84
77
|
}
|
|
85
78
|
}
|
|
86
79
|
exports.CosmosTransactionBuilder = CosmosTransactionBuilder;
|
|
87
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
80
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJhbnNhY3Rpb25CdWlsZGVyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2xpYi90cmFuc2FjdGlvbkJ1aWxkZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQUEsbURBTzhCO0FBVzlCLHVDQUFxRDtBQUVyRCxtQ0FBNEI7QUFFNUIsTUFBc0Isd0JBQXlCLFNBQVEsaUNBQXNCO0lBWTNFLFlBQVksV0FBaUM7UUFDM0MsS0FBSyxDQUFDLFdBQVcsQ0FBQyxDQUFDO0lBQ3JCLENBQUM7SUFPRCxrQkFBa0I7SUFDbEIsSUFBYyxXQUFXO1FBQ3ZCLE9BQU8sSUFBSSxDQUFDLFlBQVksQ0FBQztJQUMzQixDQUFDO0lBRUQsa0JBQWtCO0lBQ2xCLElBQWMsV0FBVyxDQUFDLFdBQThCO1FBQ3RELElBQUksQ0FBQyxZQUFZLEdBQUcsV0FBVyxDQUFDO0lBQ2xDLENBQUM7SUFFRCxrQkFBa0I7SUFDbEIsWUFBWSxDQUFDLFNBQXdCLEVBQUUsU0FBaUI7UUFDdEQsSUFBSSxDQUFDLFVBQVUsR0FBRyxTQUFTLENBQUM7UUFDNUIsSUFBSSxDQUFDLFVBQVUsR0FBRyxTQUFTLENBQUMsR0FBRyxDQUFDO0lBQ2xDLENBQUM7SUFFRDs7OztPQUlHO0lBQ0gsUUFBUSxDQUFDLFFBQWdCO1FBQ3ZCLGVBQUssQ0FBQyxnQkFBZ0IsQ0FBQyxRQUFRLENBQUMsQ0FBQztRQUNqQyxJQUFJLENBQUMsU0FBUyxHQUFHLFFBQVEsQ0FBQztRQUMxQixPQUFPLElBQUksQ0FBQztJQUNkLENBQUM7SUFhRCxTQUFTLENBQUMsU0FBNkI7UUFDckMsSUFBSSxDQUFDLFVBQVUsR0FBRyxTQUFTLENBQUM7UUFDNUIsT0FBTyxJQUFJLENBQUM7SUFDZCxDQUFDO0lBRUQsYUFBYSxDQUFDLGFBQWlDO1FBQzdDLElBQUksQ0FBQyxjQUFjLEdBQUcsYUFBYSxDQUFDO1FBQ3BDLE9BQU8sSUFBSSxDQUFDO0lBQ2QsQ0FBQztJQUVELE9BQU8sQ0FBQyxPQUEyQjtRQUNqQyxJQUFJLENBQUMsUUFBUSxHQUFHLE9BQU8sQ0FBQztRQUN4QixPQUFPLElBQUksQ0FBQztJQUNkLENBQUM7SUFFRCxJQUFJLENBQUMsSUFBd0I7UUFDM0IsSUFBSSxDQUFDLEtBQUssR0FBRyxJQUFJLENBQUM7UUFDbEIsT0FBTyxJQUFJLENBQUM7SUFDZCxDQUFDO0lBRUQsa0JBQWtCO0lBQ1Isa0JBQWtCLENBQUMsR0FBWTtRQUN2QyxJQUFJLENBQUMsV0FBVyxDQUFDLEdBQUcsQ0FBQyxDQUFDO1FBQ3RCLElBQUksSUFBSSxDQUFDLGNBQWMsS0FBSyxTQUFTLEVBQUU7WUFDckMsTUFBTSxJQUFJLHVCQUFZLENBQUMsMENBQTBDLENBQUMsQ0FBQztTQUNwRTtRQUNELElBQUksSUFBSSxDQUFDLFFBQVEsS0FBSyxTQUFTLEVBQUU7WUFDL0IsTUFBTSxJQUFJLHVCQUFZLENBQUMsb0NBQW9DLENBQUMsQ0FBQztTQUM5RDtRQUNELElBQUksQ0FBQyxPQUFPLEdBQUcsSUFBSSx1QkFBTyxDQUFDLEVBQUUsR0FBRyxFQUFFLEdBQUcsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxDQUFDO1FBQzdDLElBQUksQ0FBQyxVQUFVLEdBQUcsSUFBSSxDQUFDLE9BQU8sQ0FBQyxPQUFPLEVBQUUsQ0FBQyxHQUFHLENBQUM7UUFDN0MsT0FBTyxJQUFJLENBQUMsV0FBVyxDQUFDO0lBQzFCLENBQUM7SUFFRCxrQkFBa0I7SUFDbEIsYUFBYSxDQUFDLEtBQWdCO1FBQzVCLElBQUksS0FBSyxDQUFDLFVBQVUsQ0FBQyxDQUFDLENBQUMsRUFBRTtZQUN2QixNQUFNLElBQUksZ0NBQXFCLENBQUMsZ0NBQWdDLENBQUMsQ0FBQztTQUNuRTtJQUNILENBQUM7SUFFRCxrQkFBa0I7SUFDbEIsV0FBVyxDQUFDLEdBQVk7UUFDdEIsSUFBSTtZQUNGLElBQUksdUJBQU8sQ0FBQyxFQUFFLEdBQUcsRUFBRSxHQUFHLENBQUMsR0FBRyxFQUFFLENBQUMsQ0FBQztTQUMvQjtRQUFDLE1BQU07WUFDTixNQUFNLElBQUksZ0NBQXFCLENBQUMsdUJBQXVCLENBQUMsQ0FBQztTQUMxRDtJQUNILENBQUM7Q0FDRjtBQTVHRCw0REE0R0MiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICBCYXNlS2V5LFxuICBCYXNlVHJhbnNhY3Rpb25CdWlsZGVyLFxuICBCdWlsZFRyYW5zYWN0aW9uRXJyb3IsXG4gIFB1YmxpY0tleSBhcyBCYXNlUHVibGljS2V5LFxuICBTaWduaW5nRXJyb3IsXG4gIFRyYW5zYWN0aW9uVHlwZSxcbn0gZnJvbSAnQGJpdGdvLWJldGEvc2RrLWNvcmUnO1xuaW1wb3J0IHsgQmFzZUNvaW4gYXMgQ29pbkNvbmZpZyB9IGZyb20gJ0BiaXRnby1iZXRhL3N0YXRpY3MnO1xuaW1wb3J0IEJpZ051bWJlciBmcm9tICdiaWdudW1iZXIuanMnO1xuXG5pbXBvcnQge1xuICBEZWxlZ2F0ZU9yVW5kZWxlZ2V0ZU1lc3NhZ2UsXG4gIEZlZURhdGEsXG4gIE1lc3NhZ2VEYXRhLFxuICBTZW5kTWVzc2FnZSxcbiAgV2l0aGRyYXdEZWxlZ2F0b3JSZXdhcmRzTWVzc2FnZSxcbn0gZnJvbSAnLi9pZmFjZSc7XG5pbXBvcnQgeyBDb3Ntb3NLZXlQYWlyIGFzIEtleVBhaXIgfSBmcm9tICcuL2tleVBhaXInO1xuaW1wb3J0IHsgQ29zbW9zVHJhbnNhY3Rpb24gfSBmcm9tICcuL3RyYW5zYWN0aW9uJztcbmltcG9ydCB1dGlscyBmcm9tICcuL3V0aWxzJztcblxuZXhwb3J0IGFic3RyYWN0IGNsYXNzIENvc21vc1RyYW5zYWN0aW9uQnVpbGRlciBleHRlbmRzIEJhc2VUcmFuc2FjdGlvbkJ1aWxkZXIge1xuICBwcm90ZWN0ZWQgX3RyYW5zYWN0aW9uOiBDb3Ntb3NUcmFuc2FjdGlvbjtcbiAgcHJvdGVjdGVkIF9zZXF1ZW5jZTogbnVtYmVyO1xuICBwcm90ZWN0ZWQgX21lc3NhZ2VzOiBNZXNzYWdlRGF0YVtdO1xuICBwcm90ZWN0ZWQgX2dhc0J1ZGdldDogRmVlRGF0YTtcbiAgcHJvdGVjdGVkIF9hY2NvdW50TnVtYmVyPzogbnVtYmVyO1xuICBwcm90ZWN0ZWQgX3NpZ25hdHVyZTogQnVmZmVyO1xuICBwcm90ZWN0ZWQgX2NoYWluSWQ/OiBzdHJpbmc7XG4gIHByb3RlY3RlZCBfcHVibGljS2V5Pzogc3RyaW5nO1xuICBwcm90ZWN0ZWQgX3NpZ25lcjogS2V5UGFpcjtcbiAgcHJvdGVjdGVkIF9tZW1vPzogc3RyaW5nO1xuXG4gIGNvbnN0cnVjdG9yKF9jb2luQ29uZmlnOiBSZWFkb25seTxDb2luQ29uZmlnPikge1xuICAgIHN1cGVyKF9jb2luQ29uZmlnKTtcbiAgfVxuXG4gIC8qKlxuICAgKiBUaGUgdHJhbnNhY3Rpb24gdHlwZS5cbiAgICovXG4gIHByb3RlY3RlZCBhYnN0cmFjdCBnZXQgdHJhbnNhY3Rpb25UeXBlKCk6IFRyYW5zYWN0aW9uVHlwZTtcblxuICAvKiogQGluaGVyaXRkb2MgKi9cbiAgcHJvdGVjdGVkIGdldCB0cmFuc2FjdGlvbigpOiBDb3Ntb3NUcmFuc2FjdGlvbiB7XG4gICAgcmV0dXJuIHRoaXMuX3RyYW5zYWN0aW9uO1xuICB9XG5cbiAgLyoqIEBpbmhlcml0ZG9jICovXG4gIHByb3RlY3RlZCBzZXQgdHJhbnNhY3Rpb24odHJhbnNhY3Rpb246IENvc21vc1RyYW5zYWN0aW9uKSB7XG4gICAgdGhpcy5fdHJhbnNhY3Rpb24gPSB0cmFuc2FjdGlvbjtcbiAgfVxuXG4gIC8qKiBAaW5oZXJpdERvYyAqL1xuICBhZGRTaWduYXR1cmUocHVibGljS2V5OiBCYXNlUHVibGljS2V5LCBzaWduYXR1cmU6IEJ1ZmZlcik6IHZvaWQge1xuICAgIHRoaXMuX3NpZ25hdHVyZSA9IHNpZ25hdHVyZTtcbiAgICB0aGlzLl9wdWJsaWNLZXkgPSBwdWJsaWNLZXkucHViO1xuICB9XG5cbiAgLyoqXG4gICAqIFNldHMgc2VxdWVuY2Ugb2YgdGhpcyB0cmFuc2FjdGlvbi5cbiAgICogQHBhcmFtIHtudW1iZXJ9IHNlcXVlbmNlIC0gc2VxdWVuY2UgZGF0YSBmb3IgdHggc2lnbmVyXG4gICAqIEByZXR1cm5zIHtUcmFuc2FjdGlvbkJ1aWxkZXJ9IFRoaXMgdHJhbnNhY3Rpb24gYnVpbGRlclxuICAgKi9cbiAgc2VxdWVuY2Uoc2VxdWVuY2U6IG51bWJlcik6IHRoaXMge1xuICAgIHV0aWxzLnZhbGlkYXRlU2VxdWVuY2Uoc2VxdWVuY2UpO1xuICAgIHRoaXMuX3NlcXVlbmNlID0gc2VxdWVuY2U7XG4gICAgcmV0dXJuIHRoaXM7XG4gIH1cblxuICAvKipcbiAgICogU2V0cyBtZXNzYWdlcyB0byB0aGUgdHJhbnNhY3Rpb24gYm9keS4gTWVzc2FnZSB0eXBlIHdpbGwgYmUgZGlmZmVyZW50IGJhc2VkIG9uIHRoZSB0cmFuc2FjdGlvbiB0eXBlXG4gICAqIC0gRm9yIEBzZWUgVHJhbnNhY3Rpb25UeXBlLlN0YWtpbmdBY3RpdmF0ZSByZXF1aXJlZCB0eXBlIGlzIEBzZWUgRGVsZWdhdGVPclVuZGVsZWdldGVNZXNzYWdlXG4gICAqIC0gRm9yIEBzZWUgVHJhbnNhY3Rpb25UeXBlLlN0YWtpbmdEZWFjdGl2YXRlIHJlcXVpcmVkIHR5cGUgaXMgQHNlZSBEZWxlZ2F0ZU9yVW5kZWxlZ2V0ZU1lc3NhZ2VcbiAgICogLSBGb3IgQHNlZSBUcmFuc2FjdGlvblR5cGUuU2VuZCByZXF1aXJlZCB0eXBlIGlzIEBzZWUgU2VuZE1lc3NhZ2VcbiAgICogLSBGb3IgQHNlZSBUcmFuc2FjdGlvblR5cGUuU3Rha2luZ1dpdGhkcmF3IHJlcXVpcmVkIHR5cGUgaXMgQHNlZSBXaXRoZHJhd0RlbGVnYXRvclJld2FyZHNNZXNzYWdlXG4gICAqIEBwYXJhbSB7KFNlbmRNZXNzYWdlIHwgRGVsZWdhdGVPclVuZGVsZWdldGVNZXNzYWdlIHwgV2l0aGRyYXdEZWxlZ2F0b3JSZXdhcmRzTWVzc2FnZSlbXX0gbWVzc2FnZXNcbiAgICogQHJldHVybnMge1RyYW5zYWN0aW9uQnVpbGRlcn0gVGhpcyB0cmFuc2FjdGlvbiBidWlsZGVyXG4gICAqL1xuICBhYnN0cmFjdCBtZXNzYWdlcyhtZXNzYWdlczogKFNlbmRNZXNzYWdlIHwgRGVsZWdhdGVPclVuZGVsZWdldGVNZXNzYWdlIHwgV2l0aGRyYXdEZWxlZ2F0b3JSZXdhcmRzTWVzc2FnZSlbXSk6IHRoaXM7XG5cbiAgcHVibGljS2V5KHB1YmxpY0tleTogc3RyaW5nIHwgdW5kZWZpbmVkKTogdGhpcyB7XG4gICAgdGhpcy5fcHVibGljS2V5ID0gcHVibGljS2V5O1xuICAgIHJldHVybiB0aGlzO1xuICB9XG5cbiAgYWNjb3VudE51bWJlcihhY2NvdW50TnVtYmVyOiBudW1iZXIgfCB1bmRlZmluZWQpOiB0aGlzIHtcbiAgICB0aGlzLl9hY2NvdW50TnVtYmVyID0gYWNjb3VudE51bWJlcjtcbiAgICByZXR1cm4gdGhpcztcbiAgfVxuXG4gIGNoYWluSWQoY2hhaW5JZDogc3RyaW5nIHwgdW5kZWZpbmVkKTogdGhpcyB7XG4gICAgdGhpcy5fY2hhaW5JZCA9IGNoYWluSWQ7XG4gICAgcmV0dXJuIHRoaXM7XG4gIH1cblxuICBtZW1vKG1lbW86IHN0cmluZyB8IHVuZGVmaW5lZCk6IHRoaXMge1xuICAgIHRoaXMuX21lbW8gPSBtZW1vO1xuICAgIHJldHVybiB0aGlzO1xuICB9XG5cbiAgLyoqIEBpbmhlcml0ZG9jICovXG4gIHByb3RlY3RlZCBzaWduSW1wbGVtZW50YXRpb24oa2V5OiBCYXNlS2V5KTogQ29zbW9zVHJhbnNhY3Rpb24ge1xuICAgIHRoaXMudmFsaWRhdGVLZXkoa2V5KTtcbiAgICBpZiAodGhpcy5fYWNjb3VudE51bWJlciA9PT0gdW5kZWZpbmVkKSB7XG4gICAgICB0aHJvdyBuZXcgU2lnbmluZ0Vycm9yKCdhY2NvdW50TnVtYmVyIGlzIHJlcXVpcmVkIGJlZm9yZSBzaWduaW5nJyk7XG4gICAgfVxuICAgIGlmICh0aGlzLl9jaGFpbklkID09PSB1bmRlZmluZWQpIHtcbiAgICAgIHRocm93IG5ldyBTaWduaW5nRXJyb3IoJ2NoYWluSWQgaXMgcmVxdWlyZWQgYmVmb3JlIHNpZ25pbmcnKTtcbiAgICB9XG4gICAgdGhpcy5fc2lnbmVyID0gbmV3IEtleVBhaXIoeyBwcnY6IGtleS5rZXkgfSk7XG4gICAgdGhpcy5fcHVibGljS2V5ID0gdGhpcy5fc2lnbmVyLmdldEtleXMoKS5wdWI7XG4gICAgcmV0dXJuIHRoaXMudHJhbnNhY3Rpb247XG4gIH1cblxuICAvKiogQGluaGVyaXRkb2MgKi9cbiAgdmFsaWRhdGVWYWx1ZSh2YWx1ZTogQmlnTnVtYmVyKTogdm9pZCB7XG4gICAgaWYgKHZhbHVlLmlzTGVzc1RoYW4oMCkpIHtcbiAgICAgIHRocm93IG5ldyBCdWlsZFRyYW5zYWN0aW9uRXJyb3IoJ1ZhbHVlIGNhbm5vdCBiZSBsZXNzIHRoYW4gemVybycpO1xuICAgIH1cbiAgfVxuXG4gIC8qKiBAaW5oZXJpdGRvYyAqL1xuICB2YWxpZGF0ZUtleShrZXk6IEJhc2VLZXkpOiB2b2lkIHtcbiAgICB0cnkge1xuICAgICAgbmV3IEtleVBhaXIoeyBwcnY6IGtleS5rZXkgfSk7XG4gICAgfSBjYXRjaCB7XG4gICAgICB0aHJvdyBuZXcgQnVpbGRUcmFuc2FjdGlvbkVycm9yKGBLZXkgdmFsaWRhdGlvbiBmYWlsZWRgKTtcbiAgICB9XG4gIH1cbn1cbiJdfQ==
|