@bitgo-beta/sdk-coin-xtz 1.4.3-alpha.401 → 1.4.3-alpha.403
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/index.d.ts +5 -0
- package/dist/src/index.d.ts.map +1 -0
- package/dist/src/index.js +44 -0
- package/dist/src/lib/address.d.ts +8 -0
- package/dist/src/lib/address.d.ts.map +1 -0
- package/dist/src/lib/address.js +10 -0
- package/dist/src/lib/iface.d.ts +148 -0
- package/dist/src/lib/iface.d.ts.map +1 -0
- package/dist/src/lib/iface.js +3 -0
- package/dist/src/lib/index.d.ts +10 -0
- package/dist/src/lib/index.d.ts.map +1 -0
- package/dist/src/lib/index.js +51 -0
- package/dist/src/lib/keyPair.d.ts +40 -0
- package/dist/src/lib/keyPair.d.ts.map +1 -0
- package/dist/src/lib/keyPair.js +149 -0
- package/dist/src/lib/multisigUtils.d.ts +134 -0
- package/dist/src/lib/multisigUtils.d.ts.map +1 -0
- package/dist/src/lib/multisigUtils.js +1193 -0
- package/dist/src/lib/transaction.d.ts +119 -0
- package/dist/src/lib/transaction.d.ts.map +1 -0
- package/dist/src/lib/transaction.js +329 -0
- package/dist/src/lib/transactionBuilder.d.ts +171 -0
- package/dist/src/lib/transactionBuilder.d.ts.map +1 -0
- package/dist/src/lib/transactionBuilder.js +453 -0
- package/dist/src/lib/transferBuilder.d.ts +24 -0
- package/dist/src/lib/transferBuilder.d.ts.map +1 -0
- package/dist/src/lib/transferBuilder.js +64 -0
- package/dist/src/lib/utils.d.ts +280 -0
- package/dist/src/lib/utils.d.ts.map +1 -0
- package/dist/src/lib/utils.js +492 -0
- package/dist/src/register.d.ts +3 -0
- package/dist/src/register.d.ts.map +1 -0
- package/dist/src/register.js +11 -0
- package/dist/src/txtz.d.ts +13 -0
- package/dist/src/txtz.d.ts.map +1 -0
- package/dist/src/txtz.js +14 -0
- package/dist/src/xtz.d.ts +125 -0
- package/dist/src/xtz.d.ts.map +1 -0
- package/dist/src/xtz.js +409 -0
- package/dist/test/fixtures.d.ts +571 -0
- package/dist/test/fixtures.d.ts.map +1 -0
- package/dist/test/fixtures.js +656 -0
- package/dist/test/resources.d.ts +451 -0
- package/dist/test/resources.d.ts.map +1 -0
- package/dist/test/resources.js +349 -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 +142 -0
- package/dist/test/unit/offlineTransactionBuilder.d.ts +2 -0
- package/dist/test/unit/offlineTransactionBuilder.d.ts.map +1 -0
- package/dist/test/unit/offlineTransactionBuilder.js +291 -0
- package/dist/test/unit/transaction.d.ts +2 -0
- package/dist/test/unit/transaction.d.ts.map +1 -0
- package/dist/test/unit/transaction.js +98 -0
- package/dist/test/unit/transactionBuilder.d.ts +2 -0
- package/dist/test/unit/transactionBuilder.d.ts.map +1 -0
- package/dist/test/unit/transactionBuilder.js +656 -0
- package/dist/test/unit/transferBuilder.d.ts +2 -0
- package/dist/test/unit/transferBuilder.d.ts.map +1 -0
- package/dist/test/unit/transferBuilder.js +82 -0
- package/dist/test/unit/util.d.ts +2 -0
- package/dist/test/unit/util.d.ts.map +1 -0
- package/dist/test/unit/util.js +198 -0
- package/dist/test/unit/xtz.d.ts +2 -0
- package/dist/test/unit/xtz.d.ts.map +1 -0
- package/dist/test/unit/xtz.js +192 -0
- package/dist/tsconfig.tsbuildinfo +1 -0
- package/package.json +10 -7
- package/.eslintignore +0 -5
- package/.mocharc.yml +0 -8
- package/CHANGELOG.md +0 -784
|
@@ -0,0 +1,119 @@
|
|
|
1
|
+
import { BaseKey, BaseTransaction } from '@bitgo-beta/sdk-core';
|
|
2
|
+
import { BaseCoin as CoinConfig } from '@bitgo-beta/statics';
|
|
3
|
+
import { IndexedSignature, ParsedTransaction } from './iface';
|
|
4
|
+
import { KeyPair } from './keyPair';
|
|
5
|
+
/**
|
|
6
|
+
* Tezos transaction model.
|
|
7
|
+
*/
|
|
8
|
+
export declare class Transaction extends BaseTransaction {
|
|
9
|
+
private _parsedTransaction?;
|
|
10
|
+
private _encodedTransaction?;
|
|
11
|
+
private _source;
|
|
12
|
+
private _delegate?;
|
|
13
|
+
private _forwarderDestination?;
|
|
14
|
+
private _publicKeyToReveal?;
|
|
15
|
+
private _owners;
|
|
16
|
+
/**
|
|
17
|
+
* Public constructor.
|
|
18
|
+
*
|
|
19
|
+
* @param {Readonly<CoinConfig>} coinConfig
|
|
20
|
+
*/
|
|
21
|
+
constructor(coinConfig: Readonly<CoinConfig>);
|
|
22
|
+
/**
|
|
23
|
+
* Initialize the transaction fields based on another serialized transaction.
|
|
24
|
+
*
|
|
25
|
+
* @param serializedTransaction Transaction in broadcast format.
|
|
26
|
+
*/
|
|
27
|
+
initFromSerializedTransaction(serializedTransaction: string): Promise<void>;
|
|
28
|
+
/**
|
|
29
|
+
* Initialize the transaction fields based on another parsed transaction.
|
|
30
|
+
*
|
|
31
|
+
* @param {ParsedTransaction} parsedTransaction A Tezos transaction object
|
|
32
|
+
* @param {string} transactionId The transaction id of the parsedTransaction if it is signed
|
|
33
|
+
*/
|
|
34
|
+
initFromParsedTransaction(parsedTransaction: ParsedTransaction, transactionId?: string): Promise<void>;
|
|
35
|
+
/**
|
|
36
|
+
* Record the most important fields from an origination operation.
|
|
37
|
+
*
|
|
38
|
+
* @param {Operation} operation An operation object from a Tezos transaction
|
|
39
|
+
* @param {number} index The origination operation index in the transaction. Used to calculate the
|
|
40
|
+
* originated address
|
|
41
|
+
*/
|
|
42
|
+
private recordOriginationOpFields;
|
|
43
|
+
/**
|
|
44
|
+
* Record the most important fields from a reveal operation.
|
|
45
|
+
*
|
|
46
|
+
* @param {RevealOp} operation A reveal operation object from a Tezos transaction
|
|
47
|
+
*/
|
|
48
|
+
private recordRevealOpFields;
|
|
49
|
+
/**
|
|
50
|
+
* Record the most important fields for a Transaction operation.
|
|
51
|
+
*
|
|
52
|
+
* @param {TransactionOp} operation A transaction object from a Tezos operation
|
|
53
|
+
*/
|
|
54
|
+
private recordTransactionOpFields;
|
|
55
|
+
/**
|
|
56
|
+
* Sign the transaction with the provided key. It does not check if the signer is allowed to sign
|
|
57
|
+
* it or not.
|
|
58
|
+
*
|
|
59
|
+
* @param {KeyPair} keyPair The key to sign the transaction with
|
|
60
|
+
*/
|
|
61
|
+
sign(keyPair: KeyPair): Promise<void>;
|
|
62
|
+
/**
|
|
63
|
+
* Update the list of signatures for a multisig transaction operation.
|
|
64
|
+
*
|
|
65
|
+
* @param {IndexedSignature[]} signatures List of signatures and the index they should be put on
|
|
66
|
+
* in the multisig transfer
|
|
67
|
+
* @param {number} index The transfer index to add the signatures to
|
|
68
|
+
*/
|
|
69
|
+
addTransferSignature(signatures: IndexedSignature[], index: number): Promise<void>;
|
|
70
|
+
/** @inheritdoc */
|
|
71
|
+
canSign(key: BaseKey): boolean;
|
|
72
|
+
/** @inheritdoc */
|
|
73
|
+
toJson(): ParsedTransaction;
|
|
74
|
+
/** @inheritdoc */
|
|
75
|
+
toBroadcastFormat(): string;
|
|
76
|
+
/**
|
|
77
|
+
* Get the transaction source if it is available.
|
|
78
|
+
*
|
|
79
|
+
* @returns {string} Source of the transaction
|
|
80
|
+
*/
|
|
81
|
+
get source(): string;
|
|
82
|
+
/**
|
|
83
|
+
* Get the transaction delegation address if it is available.
|
|
84
|
+
*
|
|
85
|
+
* @returns {string} transaction delegation address
|
|
86
|
+
*/
|
|
87
|
+
get delegate(): string | undefined;
|
|
88
|
+
/**
|
|
89
|
+
* Get the public key revealed by the transaction if it exists
|
|
90
|
+
*
|
|
91
|
+
* @returns {string} public key
|
|
92
|
+
*/
|
|
93
|
+
get publicKeyToReveal(): string | undefined;
|
|
94
|
+
/**
|
|
95
|
+
* Get the destination of an address initialization transaction if it exists
|
|
96
|
+
*
|
|
97
|
+
* @returns {string} forwarder destination
|
|
98
|
+
*/
|
|
99
|
+
get forwarderDestination(): string | undefined;
|
|
100
|
+
get owners(): string[];
|
|
101
|
+
/**
|
|
102
|
+
* Get the signatures for the given multisig transfer,
|
|
103
|
+
*
|
|
104
|
+
* @param {number} transferIndex The transfer script index in the Tezos transaction
|
|
105
|
+
* @returns {IndexedSignature[]} A list of signatures with their index inside the multisig transfer
|
|
106
|
+
* script
|
|
107
|
+
*/
|
|
108
|
+
getTransferSignatures(transferIndex?: number): IndexedSignature[];
|
|
109
|
+
/**
|
|
110
|
+
* Get the list of index per tezos transaction type. This is useful to locate specific operations
|
|
111
|
+
* within the transaction and verify or sign them.
|
|
112
|
+
*
|
|
113
|
+
* @returns {{[p: string]: number[]}} List of indexes where the key is the transaction kind
|
|
114
|
+
*/
|
|
115
|
+
getIndexesByTransactionType(): {
|
|
116
|
+
[kind: string]: number[];
|
|
117
|
+
};
|
|
118
|
+
}
|
|
119
|
+
//# sourceMappingURL=transaction.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"transaction.d.ts","sourceRoot":"","sources":["../../../src/lib/transaction.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,OAAO,EACP,eAAe,EAIhB,MAAM,sBAAsB,CAAC;AAC9B,OAAO,EAAE,QAAQ,IAAI,UAAU,EAAE,MAAM,qBAAqB,CAAC;AAG7D,OAAO,EAAE,gBAAgB,EAAiB,iBAAiB,EAA2B,MAAM,SAAS,CAAC;AACtG,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAUpC;;GAEG;AACH,qBAAa,WAAY,SAAQ,eAAe;IAC9C,OAAO,CAAC,kBAAkB,CAAC,CAAoB;IAC/C,OAAO,CAAC,mBAAmB,CAAC,CAAS;IACrC,OAAO,CAAC,OAAO,CAAS;IACxB,OAAO,CAAC,SAAS,CAAC,CAAS;IAC3B,OAAO,CAAC,qBAAqB,CAAC,CAAS;IACvC,OAAO,CAAC,kBAAkB,CAAC,CAAS;IACpC,OAAO,CAAC,OAAO,CAAW;IAE1B;;;;OAIG;gBACS,UAAU,EAAE,QAAQ,CAAC,UAAU,CAAC;IAK5C;;;;OAIG;IACG,6BAA6B,CAAC,qBAAqB,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAoBjF;;;;;OAKG;IACG,yBAAyB,CAAC,iBAAiB,EAAE,iBAAiB,EAAE,aAAa,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAwC5G;;;;;;OAMG;YACW,yBAAyB;IAwBvC;;;;OAIG;IACH,OAAO,CAAC,oBAAoB;IAU5B;;;;OAIG;IACH,OAAO,CAAC,yBAAyB;IA6BjC;;;;;OAKG;IACG,IAAI,CAAC,OAAO,EAAE,OAAO,GAAG,OAAO,CAAC,IAAI,CAAC;IAmB3C;;;;;;OAMG;IACG,oBAAoB,CAAC,UAAU,EAAE,gBAAgB,EAAE,EAAE,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAQxF,kBAAkB;IAClB,OAAO,CAAC,GAAG,EAAE,OAAO,GAAG,OAAO;IAK9B,kBAAkB;IAClB,MAAM,IAAI,iBAAiB;IAO3B,kBAAkB;IAClB,iBAAiB,IAAI,MAAM;IAO3B;;;;OAIG;IACH,IAAI,MAAM,IAAI,MAAM,CAKnB;IAED;;;;OAIG;IACH,IAAI,QAAQ,IAAI,MAAM,GAAG,SAAS,CAEjC;IAED;;;;OAIG;IACH,IAAI,iBAAiB,IAAI,MAAM,GAAG,SAAS,CAE1C;IAED;;;;OAIG;IACH,IAAI,oBAAoB,IAAI,MAAM,GAAG,SAAS,CAE7C;IAED,IAAI,MAAM,IAAI,MAAM,EAAE,CAErB;IAED;;;;;;OAMG;IACH,qBAAqB,CAAC,aAAa,SAAI,GAAG,gBAAgB,EAAE;IAO5D;;;;;OAKG;IACH,2BAA2B,IAAI;QAAE,CAAC,IAAI,EAAE,MAAM,GAAG,MAAM,EAAE,CAAA;KAAE;CAW5D"}
|
|
@@ -0,0 +1,329 @@
|
|
|
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
|
+
})();
|
|
35
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
36
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
37
|
+
};
|
|
38
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
39
|
+
exports.Transaction = void 0;
|
|
40
|
+
const sdk_core_1 = require("@bitgo-beta/sdk-core");
|
|
41
|
+
const local_forging_1 = require("@taquito/local-forging");
|
|
42
|
+
const bignumber_js_1 = __importDefault(require("bignumber.js"));
|
|
43
|
+
const multisigUtils_1 = require("./multisigUtils");
|
|
44
|
+
const Utils = __importStar(require("./utils"));
|
|
45
|
+
/**
|
|
46
|
+
* Tezos transaction model.
|
|
47
|
+
*/
|
|
48
|
+
class Transaction extends sdk_core_1.BaseTransaction {
|
|
49
|
+
/**
|
|
50
|
+
* Public constructor.
|
|
51
|
+
*
|
|
52
|
+
* @param {Readonly<CoinConfig>} coinConfig
|
|
53
|
+
*/
|
|
54
|
+
constructor(coinConfig) {
|
|
55
|
+
super(coinConfig);
|
|
56
|
+
this._owners = [];
|
|
57
|
+
}
|
|
58
|
+
/**
|
|
59
|
+
* Initialize the transaction fields based on another serialized transaction.
|
|
60
|
+
*
|
|
61
|
+
* @param serializedTransaction Transaction in broadcast format.
|
|
62
|
+
*/
|
|
63
|
+
async initFromSerializedTransaction(serializedTransaction) {
|
|
64
|
+
this._encodedTransaction = serializedTransaction;
|
|
65
|
+
try {
|
|
66
|
+
const parsedTransaction = await local_forging_1.localForger.parse(serializedTransaction);
|
|
67
|
+
await this.initFromParsedTransaction(parsedTransaction);
|
|
68
|
+
}
|
|
69
|
+
catch (e) {
|
|
70
|
+
// If it throws, it is possible the serialized transaction is signed, which is not supported
|
|
71
|
+
// by local-forging. Try extracting the last 64 bytes and parse it again.
|
|
72
|
+
const unsignedSerializedTransaction = serializedTransaction.slice(0, -128);
|
|
73
|
+
const signature = serializedTransaction.slice(-128);
|
|
74
|
+
if (Utils.isValidSignature(signature)) {
|
|
75
|
+
throw new sdk_core_1.ParseTransactionError('Invalid transaction');
|
|
76
|
+
}
|
|
77
|
+
// TODO: encode the signature and save it in _signature
|
|
78
|
+
const parsedTransaction = await local_forging_1.localForger.parse(unsignedSerializedTransaction);
|
|
79
|
+
const transactionId = await Utils.calculateTransactionId(serializedTransaction);
|
|
80
|
+
await this.initFromParsedTransaction(parsedTransaction, transactionId);
|
|
81
|
+
}
|
|
82
|
+
}
|
|
83
|
+
/**
|
|
84
|
+
* Initialize the transaction fields based on another parsed transaction.
|
|
85
|
+
*
|
|
86
|
+
* @param {ParsedTransaction} parsedTransaction A Tezos transaction object
|
|
87
|
+
* @param {string} transactionId The transaction id of the parsedTransaction if it is signed
|
|
88
|
+
*/
|
|
89
|
+
async initFromParsedTransaction(parsedTransaction, transactionId) {
|
|
90
|
+
if (!this._encodedTransaction) {
|
|
91
|
+
this._encodedTransaction = await local_forging_1.localForger.forge(parsedTransaction);
|
|
92
|
+
}
|
|
93
|
+
if (transactionId) {
|
|
94
|
+
// If the transaction id is passed, save it and clean up the entries since they will be
|
|
95
|
+
// recalculated
|
|
96
|
+
this._id = transactionId;
|
|
97
|
+
this._inputs = [];
|
|
98
|
+
this._outputs = [];
|
|
99
|
+
}
|
|
100
|
+
else {
|
|
101
|
+
this._id = '';
|
|
102
|
+
}
|
|
103
|
+
this._parsedTransaction = parsedTransaction;
|
|
104
|
+
let operationIndex = 0;
|
|
105
|
+
for (const operation of parsedTransaction.contents) {
|
|
106
|
+
if (this._source && this._source !== operation.source) {
|
|
107
|
+
throw new sdk_core_1.InvalidTransactionError('Source must be the same for every operation but it changed from ' + this._source + ' to ' + operation.source);
|
|
108
|
+
}
|
|
109
|
+
else {
|
|
110
|
+
this._source = operation.source;
|
|
111
|
+
}
|
|
112
|
+
switch (operation.kind) {
|
|
113
|
+
case local_forging_1.CODEC.OP_ORIGINATION:
|
|
114
|
+
await this.recordOriginationOpFields(operation, operationIndex);
|
|
115
|
+
operationIndex++;
|
|
116
|
+
break;
|
|
117
|
+
case local_forging_1.CODEC.OP_REVEAL:
|
|
118
|
+
this.recordRevealOpFields(operation);
|
|
119
|
+
break;
|
|
120
|
+
case local_forging_1.CODEC.OP_TRANSACTION:
|
|
121
|
+
this.recordTransactionOpFields(operation);
|
|
122
|
+
break;
|
|
123
|
+
default:
|
|
124
|
+
break;
|
|
125
|
+
}
|
|
126
|
+
}
|
|
127
|
+
}
|
|
128
|
+
/**
|
|
129
|
+
* Record the most important fields from an origination operation.
|
|
130
|
+
*
|
|
131
|
+
* @param {Operation} operation An operation object from a Tezos transaction
|
|
132
|
+
* @param {number} index The origination operation index in the transaction. Used to calculate the
|
|
133
|
+
* originated address
|
|
134
|
+
*/
|
|
135
|
+
async recordOriginationOpFields(operation, index) {
|
|
136
|
+
const originationData = (0, multisigUtils_1.getOriginationDataFromOperation)(operation);
|
|
137
|
+
if (originationData.forwarderDestination) {
|
|
138
|
+
this._type = sdk_core_1.TransactionType.AddressInitialization;
|
|
139
|
+
this._forwarderDestination = originationData.forwarderDestination;
|
|
140
|
+
}
|
|
141
|
+
else {
|
|
142
|
+
this._type = sdk_core_1.TransactionType.WalletInitialization;
|
|
143
|
+
this._owners = (0, multisigUtils_1.getOwnersPublicKeys)(operation);
|
|
144
|
+
}
|
|
145
|
+
this._delegate = operation.delegate;
|
|
146
|
+
this._outputs.push({
|
|
147
|
+
// Kt addresses can only be calculated for signed transactions with an id
|
|
148
|
+
address: this._id ? await Utils.calculateOriginatedAddress(this._id, index) : '',
|
|
149
|
+
// Balance
|
|
150
|
+
value: operation.balance,
|
|
151
|
+
});
|
|
152
|
+
this._inputs.push({
|
|
153
|
+
address: operation.source,
|
|
154
|
+
// Balance + fees + max gas + max storage are paid by the source account
|
|
155
|
+
value: new bignumber_js_1.default(operation.balance).plus(operation.fee).toString(),
|
|
156
|
+
});
|
|
157
|
+
}
|
|
158
|
+
/**
|
|
159
|
+
* Record the most important fields from a reveal operation.
|
|
160
|
+
*
|
|
161
|
+
* @param {RevealOp} operation A reveal operation object from a Tezos transaction
|
|
162
|
+
*/
|
|
163
|
+
recordRevealOpFields(operation) {
|
|
164
|
+
this._type = sdk_core_1.TransactionType.AccountUpdate;
|
|
165
|
+
this._publicKeyToReveal = operation.public_key;
|
|
166
|
+
this._inputs.push({
|
|
167
|
+
address: operation.source,
|
|
168
|
+
// Balance + fees + max gas + max storage are paid by the source account
|
|
169
|
+
value: operation.fee,
|
|
170
|
+
});
|
|
171
|
+
}
|
|
172
|
+
/**
|
|
173
|
+
* Record the most important fields for a Transaction operation.
|
|
174
|
+
*
|
|
175
|
+
* @param {TransactionOp} operation A transaction object from a Tezos operation
|
|
176
|
+
*/
|
|
177
|
+
recordTransactionOpFields(operation) {
|
|
178
|
+
if (operation.parameters) {
|
|
179
|
+
this._type = sdk_core_1.TransactionType.Send;
|
|
180
|
+
}
|
|
181
|
+
else {
|
|
182
|
+
this._type = sdk_core_1.TransactionType.SingleSigSend;
|
|
183
|
+
}
|
|
184
|
+
const transferData = (0, multisigUtils_1.getMultisigTransferDataFromOperation)(operation);
|
|
185
|
+
// Fees are paid by the source account, along with the amount in the transaction
|
|
186
|
+
this._inputs.push({
|
|
187
|
+
address: operation.source,
|
|
188
|
+
value: new bignumber_js_1.default(transferData.fee.fee).toFixed(0),
|
|
189
|
+
});
|
|
190
|
+
if (transferData.coin === 'mutez') {
|
|
191
|
+
this._outputs.push({
|
|
192
|
+
// Kt addresses can only be calculated for signed transactions with an id
|
|
193
|
+
address: transferData.to,
|
|
194
|
+
// Balance
|
|
195
|
+
value: transferData.amount,
|
|
196
|
+
});
|
|
197
|
+
// The funds being transferred from the wallet
|
|
198
|
+
this._inputs.push({
|
|
199
|
+
address: transferData.from,
|
|
200
|
+
// Balance + fees + max gas + max storage are paid by the source account
|
|
201
|
+
value: transferData.amount,
|
|
202
|
+
});
|
|
203
|
+
}
|
|
204
|
+
}
|
|
205
|
+
/**
|
|
206
|
+
* Sign the transaction with the provided key. It does not check if the signer is allowed to sign
|
|
207
|
+
* it or not.
|
|
208
|
+
*
|
|
209
|
+
* @param {KeyPair} keyPair The key to sign the transaction with
|
|
210
|
+
*/
|
|
211
|
+
async sign(keyPair) {
|
|
212
|
+
// TODO: fail if the transaction is already signed
|
|
213
|
+
// Check if there is a transaction to sign
|
|
214
|
+
if (!this._parsedTransaction) {
|
|
215
|
+
throw new sdk_core_1.InvalidTransactionError('Empty transaction');
|
|
216
|
+
}
|
|
217
|
+
// Get the transaction body to sign
|
|
218
|
+
const encodedTransaction = await local_forging_1.localForger.forge(this._parsedTransaction);
|
|
219
|
+
const signedTransaction = await Utils.sign(keyPair, encodedTransaction);
|
|
220
|
+
this._encodedTransaction = signedTransaction.sbytes;
|
|
221
|
+
// The transaction id can only be calculated for signed transactions
|
|
222
|
+
this._id = await Utils.calculateTransactionId(this._encodedTransaction);
|
|
223
|
+
await this.initFromParsedTransaction(this._parsedTransaction, this._id);
|
|
224
|
+
this._signatures.push(signedTransaction.sig);
|
|
225
|
+
}
|
|
226
|
+
/**
|
|
227
|
+
* Update the list of signatures for a multisig transaction operation.
|
|
228
|
+
*
|
|
229
|
+
* @param {IndexedSignature[]} signatures List of signatures and the index they should be put on
|
|
230
|
+
* in the multisig transfer
|
|
231
|
+
* @param {number} index The transfer index to add the signatures to
|
|
232
|
+
*/
|
|
233
|
+
async addTransferSignature(signatures, index) {
|
|
234
|
+
if (!this._parsedTransaction) {
|
|
235
|
+
throw new sdk_core_1.InvalidTransactionError('Empty transaction');
|
|
236
|
+
}
|
|
237
|
+
(0, multisigUtils_1.updateMultisigTransferSignatures)(this._parsedTransaction.contents[index], signatures);
|
|
238
|
+
this._encodedTransaction = await local_forging_1.localForger.forge(this._parsedTransaction);
|
|
239
|
+
}
|
|
240
|
+
/** @inheritdoc */
|
|
241
|
+
canSign(key) {
|
|
242
|
+
// TODO: check the key belongs to the _source account in _parsedTransaction
|
|
243
|
+
return true;
|
|
244
|
+
}
|
|
245
|
+
/** @inheritdoc */
|
|
246
|
+
toJson() {
|
|
247
|
+
if (!this._parsedTransaction) {
|
|
248
|
+
throw new sdk_core_1.InvalidTransactionError('Empty transaction');
|
|
249
|
+
}
|
|
250
|
+
return this._parsedTransaction;
|
|
251
|
+
}
|
|
252
|
+
/** @inheritdoc */
|
|
253
|
+
toBroadcastFormat() {
|
|
254
|
+
if (!this._encodedTransaction) {
|
|
255
|
+
throw new sdk_core_1.InvalidTransactionError('Missing encoded transaction');
|
|
256
|
+
}
|
|
257
|
+
return this._encodedTransaction;
|
|
258
|
+
}
|
|
259
|
+
/**
|
|
260
|
+
* Get the transaction source if it is available.
|
|
261
|
+
*
|
|
262
|
+
* @returns {string} Source of the transaction
|
|
263
|
+
*/
|
|
264
|
+
get source() {
|
|
265
|
+
if (!this._source) {
|
|
266
|
+
throw new sdk_core_1.InvalidTransactionError('Transaction not initialized');
|
|
267
|
+
}
|
|
268
|
+
return this._source;
|
|
269
|
+
}
|
|
270
|
+
/**
|
|
271
|
+
* Get the transaction delegation address if it is available.
|
|
272
|
+
*
|
|
273
|
+
* @returns {string} transaction delegation address
|
|
274
|
+
*/
|
|
275
|
+
get delegate() {
|
|
276
|
+
return this._delegate;
|
|
277
|
+
}
|
|
278
|
+
/**
|
|
279
|
+
* Get the public key revealed by the transaction if it exists
|
|
280
|
+
*
|
|
281
|
+
* @returns {string} public key
|
|
282
|
+
*/
|
|
283
|
+
get publicKeyToReveal() {
|
|
284
|
+
return this._publicKeyToReveal;
|
|
285
|
+
}
|
|
286
|
+
/**
|
|
287
|
+
* Get the destination of an address initialization transaction if it exists
|
|
288
|
+
*
|
|
289
|
+
* @returns {string} forwarder destination
|
|
290
|
+
*/
|
|
291
|
+
get forwarderDestination() {
|
|
292
|
+
return this._forwarderDestination;
|
|
293
|
+
}
|
|
294
|
+
get owners() {
|
|
295
|
+
return this._owners;
|
|
296
|
+
}
|
|
297
|
+
/**
|
|
298
|
+
* Get the signatures for the given multisig transfer,
|
|
299
|
+
*
|
|
300
|
+
* @param {number} transferIndex The transfer script index in the Tezos transaction
|
|
301
|
+
* @returns {IndexedSignature[]} A list of signatures with their index inside the multisig transfer
|
|
302
|
+
* script
|
|
303
|
+
*/
|
|
304
|
+
getTransferSignatures(transferIndex = 0) {
|
|
305
|
+
if (!this._parsedTransaction) {
|
|
306
|
+
return [];
|
|
307
|
+
}
|
|
308
|
+
return (0, multisigUtils_1.getMultisigTransferSignatures)(this._parsedTransaction.contents[transferIndex]);
|
|
309
|
+
}
|
|
310
|
+
/**
|
|
311
|
+
* Get the list of index per tezos transaction type. This is useful to locate specific operations
|
|
312
|
+
* within the transaction and verify or sign them.
|
|
313
|
+
*
|
|
314
|
+
* @returns {{[p: string]: number[]}} List of indexes where the key is the transaction kind
|
|
315
|
+
*/
|
|
316
|
+
getIndexesByTransactionType() {
|
|
317
|
+
if (!this._parsedTransaction) {
|
|
318
|
+
return {};
|
|
319
|
+
}
|
|
320
|
+
const indexes = {};
|
|
321
|
+
for (let i = 0; i < this._parsedTransaction.contents.length; i++) {
|
|
322
|
+
const kind = this._parsedTransaction.contents[i].kind;
|
|
323
|
+
indexes[kind] = indexes[kind] ? indexes[kind].concat([i]) : [i];
|
|
324
|
+
}
|
|
325
|
+
return indexes;
|
|
326
|
+
}
|
|
327
|
+
}
|
|
328
|
+
exports.Transaction = Transaction;
|
|
329
|
+
//# 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  InvalidTransactionError,\n  ParseTransactionError,\n  TransactionType,\n} from '@bitgo-beta/sdk-core';\nimport { BaseCoin as CoinConfig } from '@bitgo-beta/statics';\nimport { CODEC, localForger } from '@taquito/local-forging';\nimport BigNumber from 'bignumber.js';\nimport { IndexedSignature, OriginationOp, ParsedTransaction, RevealOp, TransactionOp } from './iface';\nimport { KeyPair } from './keyPair';\nimport {\n  getMultisigTransferDataFromOperation,\n  getMultisigTransferSignatures,\n  getOriginationDataFromOperation,\n  getOwnersPublicKeys,\n  updateMultisigTransferSignatures,\n} from './multisigUtils';\nimport * as Utils from './utils';\n\n/**\n * Tezos transaction model.\n */\nexport class Transaction extends BaseTransaction {\n  private _parsedTransaction?: ParsedTransaction; // transaction in JSON format\n  private _encodedTransaction?: string; // transaction in hex format\n  private _source: string;\n  private _delegate?: string;\n  private _forwarderDestination?: string;\n  private _publicKeyToReveal?: string;\n  private _owners: string[];\n\n  /**\n   * Public constructor.\n   *\n   * @param {Readonly<CoinConfig>} coinConfig\n   */\n  constructor(coinConfig: Readonly<CoinConfig>) {\n    super(coinConfig);\n    this._owners = [];\n  }\n\n  /**\n   * Initialize the transaction fields based on another serialized transaction.\n   *\n   * @param serializedTransaction Transaction in broadcast format.\n   */\n  async initFromSerializedTransaction(serializedTransaction: string): Promise<void> {\n    this._encodedTransaction = serializedTransaction;\n    try {\n      const parsedTransaction = await localForger.parse(serializedTransaction);\n      await this.initFromParsedTransaction(parsedTransaction);\n    } catch (e) {\n      // If it throws, it is possible the serialized transaction is signed, which is not supported\n      // by local-forging. Try extracting the last 64 bytes and parse it again.\n      const unsignedSerializedTransaction = serializedTransaction.slice(0, -128);\n      const signature = serializedTransaction.slice(-128);\n      if (Utils.isValidSignature(signature)) {\n        throw new ParseTransactionError('Invalid transaction');\n      }\n      // TODO: encode the signature and save it in _signature\n      const parsedTransaction = await localForger.parse(unsignedSerializedTransaction);\n      const transactionId = await Utils.calculateTransactionId(serializedTransaction);\n      await this.initFromParsedTransaction(parsedTransaction, transactionId);\n    }\n  }\n\n  /**\n   * Initialize the transaction fields based on another parsed transaction.\n   *\n   * @param {ParsedTransaction} parsedTransaction A Tezos transaction object\n   * @param {string} transactionId The transaction id of the parsedTransaction if it is signed\n   */\n  async initFromParsedTransaction(parsedTransaction: ParsedTransaction, transactionId?: string): Promise<void> {\n    if (!this._encodedTransaction) {\n      this._encodedTransaction = await localForger.forge(parsedTransaction);\n    }\n    if (transactionId) {\n      // If the transaction id is passed, save it and clean up the entries since they will be\n      // recalculated\n      this._id = transactionId;\n      this._inputs = [];\n      this._outputs = [];\n    } else {\n      this._id = '';\n    }\n    this._parsedTransaction = parsedTransaction;\n    let operationIndex = 0;\n    for (const operation of parsedTransaction.contents) {\n      if (this._source && this._source !== operation.source) {\n        throw new InvalidTransactionError(\n          'Source must be the same for every operation but it changed from ' + this._source + ' to ' + operation.source\n        );\n      } else {\n        this._source = operation.source;\n      }\n      switch (operation.kind) {\n        case CODEC.OP_ORIGINATION:\n          await this.recordOriginationOpFields(operation as OriginationOp, operationIndex);\n          operationIndex++;\n          break;\n        case CODEC.OP_REVEAL:\n          this.recordRevealOpFields(operation as RevealOp);\n          break;\n        case CODEC.OP_TRANSACTION:\n          this.recordTransactionOpFields(operation as TransactionOp);\n          break;\n        default:\n          break;\n      }\n    }\n  }\n\n  /**\n   * Record the most important fields from an origination operation.\n   *\n   * @param {Operation} operation An operation object from a Tezos transaction\n   * @param {number} index The origination operation index in the transaction. Used to calculate the\n   *      originated address\n   */\n  private async recordOriginationOpFields(operation: OriginationOp, index: number): Promise<void> {\n    const originationData = getOriginationDataFromOperation(operation);\n    if (originationData.forwarderDestination) {\n      this._type = TransactionType.AddressInitialization;\n      this._forwarderDestination = originationData.forwarderDestination;\n    } else {\n      this._type = TransactionType.WalletInitialization;\n      this._owners = getOwnersPublicKeys(operation);\n    }\n\n    this._delegate = operation.delegate;\n    this._outputs.push({\n      // Kt addresses can only be calculated for signed transactions with an id\n      address: this._id ? await Utils.calculateOriginatedAddress(this._id, index) : '',\n      // Balance\n      value: operation.balance,\n    });\n    this._inputs.push({\n      address: operation.source,\n      // Balance + fees + max gas + max storage are paid by the source account\n      value: new BigNumber(operation.balance).plus(operation.fee).toString(),\n    });\n  }\n\n  /**\n   * Record the most important fields from a reveal operation.\n   *\n   * @param {RevealOp} operation A reveal operation object from a Tezos transaction\n   */\n  private recordRevealOpFields(operation: RevealOp): void {\n    this._type = TransactionType.AccountUpdate;\n    this._publicKeyToReveal = operation.public_key;\n    this._inputs.push({\n      address: operation.source,\n      // Balance + fees + max gas + max storage are paid by the source account\n      value: operation.fee,\n    });\n  }\n\n  /**\n   * Record the most important fields for a Transaction operation.\n   *\n   * @param {TransactionOp} operation A transaction object from a Tezos operation\n   */\n  private recordTransactionOpFields(operation: TransactionOp): void {\n    if (operation.parameters) {\n      this._type = TransactionType.Send;\n    } else {\n      this._type = TransactionType.SingleSigSend;\n    }\n    const transferData = getMultisigTransferDataFromOperation(operation);\n    // Fees are paid by the source account, along with the amount in the transaction\n    this._inputs.push({\n      address: operation.source,\n      value: new BigNumber(transferData.fee.fee).toFixed(0),\n    });\n\n    if (transferData.coin === 'mutez') {\n      this._outputs.push({\n        // Kt addresses can only be calculated for signed transactions with an id\n        address: transferData.to,\n        // Balance\n        value: transferData.amount,\n      });\n      // The funds being transferred from the wallet\n      this._inputs.push({\n        address: transferData.from,\n        // Balance + fees + max gas + max storage are paid by the source account\n        value: transferData.amount,\n      });\n    }\n  }\n\n  /**\n   * Sign the transaction with the provided key. It does not check if the signer is allowed to sign\n   * it or not.\n   *\n   * @param {KeyPair} keyPair The key to sign the transaction with\n   */\n  async sign(keyPair: KeyPair): Promise<void> {\n    // TODO: fail if the transaction is already signed\n    // Check if there is a transaction to sign\n    if (!this._parsedTransaction) {\n      throw new InvalidTransactionError('Empty transaction');\n    }\n    // Get the transaction body to sign\n    const encodedTransaction = await localForger.forge(this._parsedTransaction);\n\n    const signedTransaction = await Utils.sign(keyPair, encodedTransaction);\n    this._encodedTransaction = signedTransaction.sbytes;\n\n    // The transaction id can only be calculated for signed transactions\n    this._id = await Utils.calculateTransactionId(this._encodedTransaction);\n    await this.initFromParsedTransaction(this._parsedTransaction, this._id);\n\n    this._signatures.push(signedTransaction.sig);\n  }\n\n  /**\n   * Update the list of signatures for a multisig transaction operation.\n   *\n   * @param {IndexedSignature[]} signatures List of signatures and the index they should be put on\n   *    in the multisig transfer\n   * @param {number} index The transfer index to add the signatures to\n   */\n  async addTransferSignature(signatures: IndexedSignature[], index: number): Promise<void> {\n    if (!this._parsedTransaction) {\n      throw new InvalidTransactionError('Empty transaction');\n    }\n    updateMultisigTransferSignatures(this._parsedTransaction.contents[index] as TransactionOp, signatures);\n    this._encodedTransaction = await localForger.forge(this._parsedTransaction);\n  }\n\n  /** @inheritdoc */\n  canSign(key: BaseKey): boolean {\n    // TODO: check the key belongs to the _source account in _parsedTransaction\n    return true;\n  }\n\n  /** @inheritdoc */\n  toJson(): ParsedTransaction {\n    if (!this._parsedTransaction) {\n      throw new InvalidTransactionError('Empty transaction');\n    }\n    return this._parsedTransaction;\n  }\n\n  /** @inheritdoc */\n  toBroadcastFormat(): string {\n    if (!this._encodedTransaction) {\n      throw new InvalidTransactionError('Missing encoded transaction');\n    }\n    return this._encodedTransaction;\n  }\n\n  /**\n   * Get the transaction source if it is available.\n   *\n   * @returns {string} Source of the transaction\n   */\n  get source(): string {\n    if (!this._source) {\n      throw new InvalidTransactionError('Transaction not initialized');\n    }\n    return this._source;\n  }\n\n  /**\n   * Get the transaction delegation address if it is available.\n   *\n   * @returns {string} transaction delegation address\n   */\n  get delegate(): string | undefined {\n    return this._delegate;\n  }\n\n  /**\n   * Get the public key revealed by the transaction if it exists\n   *\n   * @returns {string} public key\n   */\n  get publicKeyToReveal(): string | undefined {\n    return this._publicKeyToReveal;\n  }\n\n  /**\n   * Get the destination of an address initialization transaction if it exists\n   *\n   * @returns {string} forwarder destination\n   */\n  get forwarderDestination(): string | undefined {\n    return this._forwarderDestination;\n  }\n\n  get owners(): string[] {\n    return this._owners;\n  }\n\n  /**\n   * Get the signatures for the given multisig transfer,\n   *\n   * @param {number} transferIndex The transfer script index in the Tezos transaction\n   * @returns {IndexedSignature[]} A list of signatures with their index inside the multisig transfer\n   *      script\n   */\n  getTransferSignatures(transferIndex = 0): IndexedSignature[] {\n    if (!this._parsedTransaction) {\n      return [];\n    }\n    return getMultisigTransferSignatures(this._parsedTransaction.contents[transferIndex] as TransactionOp);\n  }\n\n  /**\n   * Get the list of index per tezos transaction type. This is useful to locate specific operations\n   * within the transaction and verify or sign them.\n   *\n   * @returns {{[p: string]: number[]}} List of indexes where the key is the transaction kind\n   */\n  getIndexesByTransactionType(): { [kind: string]: number[] } {\n    if (!this._parsedTransaction) {\n      return {};\n    }\n    const indexes = {};\n    for (let i = 0; i < this._parsedTransaction.contents.length; i++) {\n      const kind = this._parsedTransaction.contents[i].kind;\n      indexes[kind] = indexes[kind] ? indexes[kind].concat([i]) : [i];\n    }\n    return indexes;\n  }\n}\n"]}
|
|
@@ -0,0 +1,171 @@
|
|
|
1
|
+
import { BaseKey, BaseTransactionBuilder, TransactionType } from '@bitgo-beta/sdk-core';
|
|
2
|
+
import { BaseCoin as CoinConfig } from '@bitgo-beta/statics';
|
|
3
|
+
import BigNumber from 'bignumber.js';
|
|
4
|
+
import { Address } from './address';
|
|
5
|
+
import { Fee, IndexedData, Key } from './iface';
|
|
6
|
+
import { Transaction } from './transaction';
|
|
7
|
+
import { TransferBuilder } from './transferBuilder';
|
|
8
|
+
interface DataToSignOverride extends IndexedData {
|
|
9
|
+
dataToSign: string;
|
|
10
|
+
}
|
|
11
|
+
/**
|
|
12
|
+
* Tezos transaction builder.
|
|
13
|
+
*/
|
|
14
|
+
export declare class TransactionBuilder extends BaseTransactionBuilder {
|
|
15
|
+
private _serializedTransaction;
|
|
16
|
+
private _transaction;
|
|
17
|
+
private _type;
|
|
18
|
+
private _blockHeader;
|
|
19
|
+
private _counter;
|
|
20
|
+
private _fee;
|
|
21
|
+
private _sourceAddress;
|
|
22
|
+
private _sourceKeyPair?;
|
|
23
|
+
private _publicKeyToReveal;
|
|
24
|
+
private _initialBalance;
|
|
25
|
+
private _initialDelegate;
|
|
26
|
+
private _walletOwnerPublicKeys;
|
|
27
|
+
private _multisigSignerKeyPairs;
|
|
28
|
+
private _dataToSignOverride;
|
|
29
|
+
private _transfers;
|
|
30
|
+
private _forwarderDestination;
|
|
31
|
+
/**
|
|
32
|
+
* Public constructor.
|
|
33
|
+
*
|
|
34
|
+
* @param {CoinConfig} _coinConfig - coin configuration
|
|
35
|
+
*/
|
|
36
|
+
constructor(_coinConfig: Readonly<CoinConfig>);
|
|
37
|
+
/** @inheritdoc */
|
|
38
|
+
protected fromImplementation(rawTransaction: string): Transaction;
|
|
39
|
+
/** @inheritdoc */
|
|
40
|
+
protected signImplementation(key: Key): Transaction;
|
|
41
|
+
/** @inheritdoc */
|
|
42
|
+
protected buildImplementation(): Promise<Transaction>;
|
|
43
|
+
/**
|
|
44
|
+
* Set the transaction branch id.
|
|
45
|
+
*
|
|
46
|
+
* @param {string} blockId A block hash to use as branch reference
|
|
47
|
+
*/
|
|
48
|
+
branch(blockId: string): void;
|
|
49
|
+
/**
|
|
50
|
+
* The type of transaction being built.
|
|
51
|
+
*
|
|
52
|
+
* @param {TransactionType} type - type of the transaction
|
|
53
|
+
*/
|
|
54
|
+
type(type: TransactionType): void;
|
|
55
|
+
/**
|
|
56
|
+
* Set the transaction fees. Low fees may get a transaction rejected or never picked up by bakers.
|
|
57
|
+
*
|
|
58
|
+
* @param {Fee} fee Baker fees. May also include the maximum gas and storage fees to pay
|
|
59
|
+
*/
|
|
60
|
+
fee(fee: Fee): void;
|
|
61
|
+
/**
|
|
62
|
+
* Set the transaction initiator. This account will pay for the transaction fees, but it will not
|
|
63
|
+
* be added as an owner of a wallet in a init transaction, unless manually set as one of the
|
|
64
|
+
* owners.
|
|
65
|
+
*
|
|
66
|
+
* @param {string} source A Tezos address
|
|
67
|
+
*/
|
|
68
|
+
source(source: string): void;
|
|
69
|
+
/**
|
|
70
|
+
* Set an amount of mutez to transfer in this transaction this transaction. This is different than
|
|
71
|
+
* the amount to transfer from a multisig wallet.
|
|
72
|
+
*
|
|
73
|
+
* @param {string} amount Amount in mutez (1/1000000 Tezies)
|
|
74
|
+
*/
|
|
75
|
+
initialBalance(amount: string): void;
|
|
76
|
+
/**
|
|
77
|
+
* Set the transaction counter to prevent submitting repeated transactions.
|
|
78
|
+
*
|
|
79
|
+
* @param {string} counter The counter to use
|
|
80
|
+
*/
|
|
81
|
+
counter(counter: string): void;
|
|
82
|
+
/**
|
|
83
|
+
* Set the destination address of a forwarder contract
|
|
84
|
+
* Used in forwarder contract deployment as destination address
|
|
85
|
+
*
|
|
86
|
+
* @param {string} contractAddress - contract address to use
|
|
87
|
+
*/
|
|
88
|
+
forwarderDestination(contractAddress: string): void;
|
|
89
|
+
/**
|
|
90
|
+
* The public key to reveal.
|
|
91
|
+
*
|
|
92
|
+
* @param {string} publicKey A Tezos public key
|
|
93
|
+
*/
|
|
94
|
+
publicKeyToReveal(publicKey: string): void;
|
|
95
|
+
/**
|
|
96
|
+
* Build a reveal operation for the source account with default fees.
|
|
97
|
+
*
|
|
98
|
+
* @returns {RevealOp} A Tezos reveal operation
|
|
99
|
+
*/
|
|
100
|
+
private buildPublicKeyRevelationOperation;
|
|
101
|
+
/**
|
|
102
|
+
* Set one of the owners of the multisig wallet.
|
|
103
|
+
*
|
|
104
|
+
* @param {string} publicKey A Tezos public key
|
|
105
|
+
*/
|
|
106
|
+
owner(publicKey: string): void;
|
|
107
|
+
/**
|
|
108
|
+
* Set an initial delegate to initialize this wallet to. This is different than the delegation to
|
|
109
|
+
* set while doing a separate delegation transaction.
|
|
110
|
+
*
|
|
111
|
+
* @param {string} delegate The address to delegate the funds to
|
|
112
|
+
*/
|
|
113
|
+
initialDelegate(delegate: string): void;
|
|
114
|
+
/**
|
|
115
|
+
* Build an origination operation for a generic multisig contract.
|
|
116
|
+
*
|
|
117
|
+
* @returns {Operation} A Tezos origination operation
|
|
118
|
+
*/
|
|
119
|
+
private buildWalletInitializationOperations;
|
|
120
|
+
/**
|
|
121
|
+
* Initialize a new TransferBuilder to for a singlesig or multisig transaction.
|
|
122
|
+
*
|
|
123
|
+
* @param {string} amount Amount in mutez to be transferred
|
|
124
|
+
* @returns {TransferBuilder} A transfer builder
|
|
125
|
+
*/
|
|
126
|
+
transfer(amount: string): TransferBuilder;
|
|
127
|
+
/**
|
|
128
|
+
* Calculate the signatures for the multisig transaction.
|
|
129
|
+
*
|
|
130
|
+
* @param {string} packedData The string in hexadecimal to sign
|
|
131
|
+
* @returns {Promise<string[]>} List of signatures for packedData
|
|
132
|
+
*/
|
|
133
|
+
private getSignatures;
|
|
134
|
+
/**
|
|
135
|
+
* Override the data to sign for a specific transfer. Used for offline signing to pass the
|
|
136
|
+
* respective dataToSign for transfer at a particular index.
|
|
137
|
+
*
|
|
138
|
+
* @param {DataToSignOverride} data - data to override
|
|
139
|
+
*/
|
|
140
|
+
overrideDataToSign(data: DataToSignOverride): void;
|
|
141
|
+
/**
|
|
142
|
+
* Build a transaction operation for a generic multisig contract.
|
|
143
|
+
*
|
|
144
|
+
* @returns {Promise<TransactionOp[]>} A Tezos transaction operation
|
|
145
|
+
*/
|
|
146
|
+
private buildSendTransactionContent;
|
|
147
|
+
/**
|
|
148
|
+
* Build a transaction operation for a forwarder contract
|
|
149
|
+
*
|
|
150
|
+
* @returns {OriginationOp} a Tezos transaction operation
|
|
151
|
+
*/
|
|
152
|
+
private buildForwarderDeploymentContent;
|
|
153
|
+
/** @inheritdoc */
|
|
154
|
+
validateValue(value: BigNumber): void;
|
|
155
|
+
/** @inheritdoc */
|
|
156
|
+
validateAddress(address: Address): void;
|
|
157
|
+
/** @inheritdoc */
|
|
158
|
+
validateKey(key: BaseKey): void;
|
|
159
|
+
/** @inheritdoc */
|
|
160
|
+
validateRawTransaction(rawTransaction: any): void;
|
|
161
|
+
/** @inheritdoc */
|
|
162
|
+
validateTransaction(transaction: Transaction): void;
|
|
163
|
+
/** @inheritdoc */
|
|
164
|
+
displayName(): string;
|
|
165
|
+
/** @inheritdoc */
|
|
166
|
+
protected get transaction(): Transaction;
|
|
167
|
+
/** @inheritdoc */
|
|
168
|
+
protected set transaction(transaction: Transaction);
|
|
169
|
+
}
|
|
170
|
+
export {};
|
|
171
|
+
//# sourceMappingURL=transactionBuilder.d.ts.map
|