@bitgo/sdk-coin-ton 1.1.0
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/.eslintignore +5 -0
- package/.mocharc.yml +8 -0
- package/CHANGELOG.md +16 -0
- package/LICENSE +191 -0
- package/README.md +30 -0
- package/dist/src/index.d.ts +5 -0
- package/dist/src/index.d.ts.map +1 -0
- package/dist/src/index.js +17 -0
- package/dist/src/lib/iface.d.ts +14 -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 +9 -0
- package/dist/src/lib/index.d.ts.map +1 -0
- package/dist/src/lib/index.js +37 -0
- package/dist/src/lib/keyPair.d.ts +25 -0
- package/dist/src/lib/keyPair.d.ts.map +1 -0
- package/dist/src/lib/keyPair.js +89 -0
- package/dist/src/lib/transaction.d.ts +32 -0
- package/dist/src/lib/transaction.d.ts.map +1 -0
- package/dist/src/lib/transaction.js +280 -0
- package/dist/src/lib/transactionBuilder.d.ts +50 -0
- package/dist/src/lib/transactionBuilder.d.ts.map +1 -0
- package/dist/src/lib/transactionBuilder.js +111 -0
- package/dist/src/lib/transactionBuilderFactory.d.ts +14 -0
- package/dist/src/lib/transactionBuilderFactory.d.ts.map +1 -0
- package/dist/src/lib/transactionBuilderFactory.js +26 -0
- package/dist/src/lib/transferBuilder.d.ts +9 -0
- package/dist/src/lib/transferBuilder.d.ts.map +1 -0
- package/dist/src/lib/transferBuilder.js +19 -0
- package/dist/src/lib/utils.d.ts +19 -0
- package/dist/src/lib/utils.d.ts.map +1 -0
- package/dist/src/lib/utils.js +54 -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/ton.d.ts +34 -0
- package/dist/src/ton.d.ts.map +1 -0
- package/dist/src/ton.js +182 -0
- package/dist/src/tton.d.ts +22 -0
- package/dist/src/tton.d.ts.map +1 -0
- package/dist/src/tton.js +30 -0
- package/package.json +57 -0
|
@@ -0,0 +1,280 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.Transaction = void 0;
|
|
7
|
+
const sdk_core_1 = require("@bitgo/sdk-core");
|
|
8
|
+
const tonweb_1 = __importDefault(require("tonweb"));
|
|
9
|
+
const bn_js_1 = require("bn.js");
|
|
10
|
+
const WALLET_ID = 698983191;
|
|
11
|
+
class Transaction extends sdk_core_1.BaseTransaction {
|
|
12
|
+
constructor(coinConfig) {
|
|
13
|
+
super(coinConfig);
|
|
14
|
+
}
|
|
15
|
+
canSign(key) {
|
|
16
|
+
return false;
|
|
17
|
+
}
|
|
18
|
+
toBroadcastFormat() {
|
|
19
|
+
return this.finalMessage;
|
|
20
|
+
}
|
|
21
|
+
toJson() {
|
|
22
|
+
return {
|
|
23
|
+
id: this._id,
|
|
24
|
+
sender: this.sender,
|
|
25
|
+
destination: this.recipient.address,
|
|
26
|
+
amount: this.recipient.amount,
|
|
27
|
+
seqno: this.seqno,
|
|
28
|
+
expirationTime: this.expireTime,
|
|
29
|
+
publicKey: this.publicKey,
|
|
30
|
+
signature: this._signatures[0],
|
|
31
|
+
};
|
|
32
|
+
}
|
|
33
|
+
get signablePayload() {
|
|
34
|
+
return Buffer.from(this.unsignedMessage, 'hex');
|
|
35
|
+
}
|
|
36
|
+
async build() {
|
|
37
|
+
this._type = sdk_core_1.TransactionType.Send;
|
|
38
|
+
const signingMessage = this.createSigningMessage(WALLET_ID, this.seqno, this.expireTime);
|
|
39
|
+
const sendMode = 3;
|
|
40
|
+
signingMessage.bits.writeUint8(sendMode);
|
|
41
|
+
signingMessage.refs.push(this.createOutMsg(this.recipient.address, this.recipient.amount, this.message));
|
|
42
|
+
this.unsignedMessage = Buffer.from(await signingMessage.hash()).toString('hex');
|
|
43
|
+
const signature = this._signatures.length > 0 ? this._signatures[0] : Buffer.from(new Uint8Array(64)).toString('hex');
|
|
44
|
+
const finalMessage = await this.createExternalMessage(signingMessage, this.seqno, signature);
|
|
45
|
+
this.finalMessage = tonweb_1.default.utils.bytesToBase64(await finalMessage.toBoc(false));
|
|
46
|
+
this._id = tonweb_1.default.utils.bytesToBase64(await finalMessage.hash());
|
|
47
|
+
}
|
|
48
|
+
createSigningMessage(walletId, seqno, expireAt) {
|
|
49
|
+
const message = new tonweb_1.default.boc.Cell();
|
|
50
|
+
message.bits.writeUint(walletId, 32);
|
|
51
|
+
if (seqno === 0) {
|
|
52
|
+
for (let i = 0; i < 32; i++) {
|
|
53
|
+
message.bits.writeBit(1);
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
else {
|
|
57
|
+
message.bits.writeUint(expireAt, 32);
|
|
58
|
+
}
|
|
59
|
+
message.bits.writeUint(seqno, 32);
|
|
60
|
+
message.bits.writeUint(0, 8); // op
|
|
61
|
+
return message;
|
|
62
|
+
}
|
|
63
|
+
createOutMsg(address, amount, payload) {
|
|
64
|
+
let payloadCell = new tonweb_1.default.boc.Cell();
|
|
65
|
+
if (payload) {
|
|
66
|
+
if (payload.refs) {
|
|
67
|
+
// is Cell
|
|
68
|
+
payloadCell = payload;
|
|
69
|
+
}
|
|
70
|
+
else if (typeof payload === 'string') {
|
|
71
|
+
if (payload.length > 0) {
|
|
72
|
+
payloadCell.bits.writeUint(0, 32);
|
|
73
|
+
payloadCell.bits.writeString(payload);
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
|
+
else {
|
|
77
|
+
payloadCell.bits.writeBytes(payload);
|
|
78
|
+
}
|
|
79
|
+
}
|
|
80
|
+
const orderHeader = tonweb_1.default.Contract.createInternalMessageHeader(new tonweb_1.default.Address(address), new bn_js_1.BN(amount));
|
|
81
|
+
return tonweb_1.default.Contract.createCommonMsgInfo(orderHeader, undefined, payloadCell);
|
|
82
|
+
}
|
|
83
|
+
async createExternalMessage(signingMessage, seqno, signature) {
|
|
84
|
+
const body = new tonweb_1.default.boc.Cell();
|
|
85
|
+
body.bits.writeBytes(Buffer.from(signature, 'hex'));
|
|
86
|
+
body.writeCell(signingMessage);
|
|
87
|
+
let stateInit;
|
|
88
|
+
if (seqno === 0) {
|
|
89
|
+
const WalletClass = tonweb_1.default.Wallets.all['v4R2'];
|
|
90
|
+
const wallet = new WalletClass(new tonweb_1.default.HttpProvider(), {
|
|
91
|
+
publicKey: tonweb_1.default.utils.hexToBytes(this.publicKey),
|
|
92
|
+
wc: 0,
|
|
93
|
+
});
|
|
94
|
+
const deploy = await wallet.createStateInit();
|
|
95
|
+
stateInit = deploy.stateInit;
|
|
96
|
+
}
|
|
97
|
+
const header = tonweb_1.default.Contract.createExternalMessageHeader(this.sender);
|
|
98
|
+
const resultMessage = tonweb_1.default.Contract.createCommonMsgInfo(header, stateInit, body);
|
|
99
|
+
return resultMessage;
|
|
100
|
+
}
|
|
101
|
+
loadInputsAndOutputs() {
|
|
102
|
+
const outputs = [];
|
|
103
|
+
const inputs = [];
|
|
104
|
+
inputs.push({
|
|
105
|
+
address: this.sender,
|
|
106
|
+
value: this.recipient.amount,
|
|
107
|
+
coin: this._coinConfig.name,
|
|
108
|
+
});
|
|
109
|
+
outputs.push({
|
|
110
|
+
address: this.recipient.address,
|
|
111
|
+
value: this.recipient.amount,
|
|
112
|
+
coin: this._coinConfig.name,
|
|
113
|
+
});
|
|
114
|
+
this._outputs = outputs;
|
|
115
|
+
this._inputs = inputs;
|
|
116
|
+
}
|
|
117
|
+
fromRawTransaction(rawTransaction) {
|
|
118
|
+
try {
|
|
119
|
+
const cell = tonweb_1.default.boc.Cell.oneFromBoc(tonweb_1.default.utils.base64ToBytes(rawTransaction));
|
|
120
|
+
const parsed = this.parseTransfer(cell);
|
|
121
|
+
parsed.value = parsed.value.toString();
|
|
122
|
+
parsed.fromAddress = parsed.fromAddress.toString(true, true, true);
|
|
123
|
+
parsed.toAddress = parsed.toAddress.toString(true, true, true);
|
|
124
|
+
this.sender = parsed.fromAddress;
|
|
125
|
+
this.recipient = { address: parsed.toAddress, amount: parsed.value };
|
|
126
|
+
this.seqno = parsed.seqno;
|
|
127
|
+
this.publicKey = parsed.publicKey;
|
|
128
|
+
this.expireTime = parsed.expireAt;
|
|
129
|
+
this.message = parsed.payload;
|
|
130
|
+
this._signatures.push(parsed.signature);
|
|
131
|
+
}
|
|
132
|
+
catch (e) {
|
|
133
|
+
throw new Error('invalid raw transaction');
|
|
134
|
+
}
|
|
135
|
+
}
|
|
136
|
+
/** @inheritDoc */
|
|
137
|
+
explainTransaction() {
|
|
138
|
+
const displayOrder = ['id', 'outputs', 'outputAmount', 'changeOutputs', 'changeAmount', 'fee'];
|
|
139
|
+
const outputs = [this.recipient];
|
|
140
|
+
const outputAmount = this.recipient.amount;
|
|
141
|
+
return {
|
|
142
|
+
displayOrder,
|
|
143
|
+
id: this.id,
|
|
144
|
+
outputs,
|
|
145
|
+
outputAmount,
|
|
146
|
+
changeOutputs: [],
|
|
147
|
+
changeAmount: '0',
|
|
148
|
+
fee: { fee: 'UNKNOWN' },
|
|
149
|
+
};
|
|
150
|
+
}
|
|
151
|
+
parseTransfer(cell) {
|
|
152
|
+
const slice = cell.beginParse();
|
|
153
|
+
// header
|
|
154
|
+
if (slice.loadUint(2).toNumber() !== 2)
|
|
155
|
+
throw Error('invalid header');
|
|
156
|
+
const externalSourceAddress = slice.loadAddress();
|
|
157
|
+
if (externalSourceAddress !== null)
|
|
158
|
+
throw Error('invalid externalSourceAddress');
|
|
159
|
+
const externalDestAddress = slice.loadAddress();
|
|
160
|
+
const externalImportFee = slice.loadCoins();
|
|
161
|
+
if (!externalImportFee.eq(new bn_js_1.BN(0)))
|
|
162
|
+
throw new Error('invalid externalImportFee');
|
|
163
|
+
// stateInit
|
|
164
|
+
let publicKey;
|
|
165
|
+
if (slice.loadBit()) {
|
|
166
|
+
if (slice.loadBit()) {
|
|
167
|
+
const stateInit = slice.loadRef();
|
|
168
|
+
stateInit.loadRef();
|
|
169
|
+
const data = stateInit.loadRef();
|
|
170
|
+
const seqno = data.loadUint(32).toNumber();
|
|
171
|
+
if (seqno !== 0)
|
|
172
|
+
throw new Error('invalid seqno');
|
|
173
|
+
const walletId = data.loadUint(32).toNumber();
|
|
174
|
+
if (walletId !== WALLET_ID)
|
|
175
|
+
throw new Error('invalid wallet id');
|
|
176
|
+
const publicKeyBuf = new Uint8Array(32);
|
|
177
|
+
for (let i = 0; i < publicKeyBuf.length; i++) {
|
|
178
|
+
publicKeyBuf[i] = data.loadUint(8);
|
|
179
|
+
}
|
|
180
|
+
publicKey = Buffer.from(publicKeyBuf).toString('hex');
|
|
181
|
+
}
|
|
182
|
+
}
|
|
183
|
+
// body
|
|
184
|
+
const bodySlice = slice.loadBit() ? slice.loadRef() : slice;
|
|
185
|
+
return {
|
|
186
|
+
fromAddress: externalDestAddress,
|
|
187
|
+
publicKey,
|
|
188
|
+
...this.parseTransferBody(bodySlice),
|
|
189
|
+
};
|
|
190
|
+
}
|
|
191
|
+
parseTransferBody(slice) {
|
|
192
|
+
const signature = Buffer.from(slice.loadBits(512)).toString('hex');
|
|
193
|
+
// signing message
|
|
194
|
+
const walletId = slice.loadUint(32).toNumber();
|
|
195
|
+
if (walletId !== WALLET_ID)
|
|
196
|
+
throw new Error('invalid walletId');
|
|
197
|
+
const expireAt = slice.loadUint(32).toNumber();
|
|
198
|
+
const seqno = slice.loadUint(32).toNumber();
|
|
199
|
+
const op = slice.loadUint(8).toNumber();
|
|
200
|
+
if (op !== 0)
|
|
201
|
+
throw new Error('invalid op');
|
|
202
|
+
const sendMode = slice.loadUint(8).toNumber();
|
|
203
|
+
if (sendMode !== 3)
|
|
204
|
+
throw new Error('invalid sendMode');
|
|
205
|
+
let order = slice.loadRef();
|
|
206
|
+
if (order.loadBit())
|
|
207
|
+
throw Error('invalid internal header');
|
|
208
|
+
if (!order.loadBit())
|
|
209
|
+
throw Error('invalid ihrDisabled');
|
|
210
|
+
const bounce = order.loadBit();
|
|
211
|
+
if (order.loadBit())
|
|
212
|
+
throw Error('invalid bounced');
|
|
213
|
+
const sourceAddress = order.loadAddress();
|
|
214
|
+
if (sourceAddress !== null)
|
|
215
|
+
throw Error('invalid externalSourceAddress');
|
|
216
|
+
const destAddress = order.loadAddress();
|
|
217
|
+
const value = order.loadCoins();
|
|
218
|
+
if (order.loadBit())
|
|
219
|
+
throw Error('invalid currencyCollection');
|
|
220
|
+
const ihrFees = order.loadCoins();
|
|
221
|
+
if (!ihrFees.eq(new bn_js_1.BN(0)))
|
|
222
|
+
throw new Error('invalid ihrFees');
|
|
223
|
+
const fwdFees = order.loadCoins();
|
|
224
|
+
if (!fwdFees.eq(new bn_js_1.BN(0)))
|
|
225
|
+
throw new Error('invalid fwdFees');
|
|
226
|
+
const createdLt = order.loadUint(64);
|
|
227
|
+
if (!createdLt.eq(new bn_js_1.BN(0)))
|
|
228
|
+
throw new Error('invalid createdLt');
|
|
229
|
+
const createdAt = order.loadUint(32);
|
|
230
|
+
if (!createdAt.eq(new bn_js_1.BN(0)))
|
|
231
|
+
throw new Error('invalid createdAt');
|
|
232
|
+
// order stateInit
|
|
233
|
+
if (order.loadBit()) {
|
|
234
|
+
order.loadRef(); // don't parse stateInit
|
|
235
|
+
}
|
|
236
|
+
// order body
|
|
237
|
+
let payload;
|
|
238
|
+
if (order.getFreeBits() > 0) {
|
|
239
|
+
if (order.loadBit()) {
|
|
240
|
+
order = order.loadRef();
|
|
241
|
+
}
|
|
242
|
+
if (order.getFreeBits() > 32) {
|
|
243
|
+
const op = order.loadUint(32);
|
|
244
|
+
const payloadBytes = order.loadBits(order.getFreeBits());
|
|
245
|
+
payload = op.eq(new bn_js_1.BN(0)) ? new TextDecoder().decode(payloadBytes) : '';
|
|
246
|
+
}
|
|
247
|
+
}
|
|
248
|
+
return {
|
|
249
|
+
toAddress: destAddress,
|
|
250
|
+
value,
|
|
251
|
+
bounce,
|
|
252
|
+
seqno,
|
|
253
|
+
expireAt,
|
|
254
|
+
payload,
|
|
255
|
+
signature,
|
|
256
|
+
walletId,
|
|
257
|
+
};
|
|
258
|
+
}
|
|
259
|
+
parseTransferStateInit(slice) {
|
|
260
|
+
if (slice === null)
|
|
261
|
+
return {};
|
|
262
|
+
slice.loadRef();
|
|
263
|
+
const data = slice.loadRef();
|
|
264
|
+
const seqno = data.loadUint(32).toNumber();
|
|
265
|
+
if (seqno !== 0)
|
|
266
|
+
throw new Error('invalid seqno');
|
|
267
|
+
const walletId = data.loadUint(32).toNumber();
|
|
268
|
+
if (walletId !== WALLET_ID)
|
|
269
|
+
throw new Error('invalid wallet id');
|
|
270
|
+
const publicKey = new Uint8Array(32);
|
|
271
|
+
for (let i = 0; i < publicKey.length; i++) {
|
|
272
|
+
publicKey[i] = data.loadUint(8);
|
|
273
|
+
}
|
|
274
|
+
return {
|
|
275
|
+
publicKey: Buffer.from(publicKey).toString('hex'),
|
|
276
|
+
};
|
|
277
|
+
}
|
|
278
|
+
}
|
|
279
|
+
exports.Transaction = Transaction;
|
|
280
|
+
//# 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  Recipient,\n  TransactionRecipient,\n  TransactionType,\n  TransactionExplanation,\n} from '@bitgo/sdk-core';\nimport { TxData } from './iface';\nimport { BaseCoin as CoinConfig } from '@bitgo/statics';\nimport TonWeb from 'tonweb';\nimport { BN } from 'bn.js';\nimport { Cell } from 'tonweb/dist/types/boc/cell';\n\nconst WALLET_ID = 698983191;\n\nexport class Transaction extends BaseTransaction {\n  public recipient: Recipient;\n  public message: string;\n  seqno: number;\n  expireTime: number;\n  sender: string;\n  publicKey: string;\n  private unsignedMessage: string;\n  private finalMessage: string;\n\n  constructor(coinConfig: Readonly<CoinConfig>) {\n    super(coinConfig);\n  }\n\n  canSign(key: BaseKey): boolean {\n    return false;\n  }\n\n  toBroadcastFormat(): string {\n    return this.finalMessage;\n  }\n\n  toJson(): TxData {\n    return {\n      id: this._id as string,\n      sender: this.sender,\n      destination: this.recipient.address,\n      amount: this.recipient.amount,\n      seqno: this.seqno,\n      expirationTime: this.expireTime,\n      publicKey: this.publicKey,\n      signature: this._signatures[0],\n    };\n  }\n\n  get signablePayload(): Buffer {\n    return Buffer.from(this.unsignedMessage, 'hex');\n  }\n\n  async build(): Promise<void> {\n    this._type = TransactionType.Send;\n    const signingMessage = this.createSigningMessage(WALLET_ID, this.seqno, this.expireTime);\n    const sendMode = 3;\n    signingMessage.bits.writeUint8(sendMode);\n    signingMessage.refs.push(this.createOutMsg(this.recipient.address, this.recipient.amount, this.message));\n    this.unsignedMessage = Buffer.from(await signingMessage.hash()).toString('hex');\n\n    const signature =\n      this._signatures.length > 0 ? this._signatures[0] : Buffer.from(new Uint8Array(64)).toString('hex');\n    const finalMessage = await this.createExternalMessage(signingMessage, this.seqno, signature);\n    this.finalMessage = TonWeb.utils.bytesToBase64(await finalMessage.toBoc(false));\n\n    this._id = TonWeb.utils.bytesToBase64(await finalMessage.hash());\n  }\n\n  private createSigningMessage(walletId, seqno, expireAt) {\n    const message = new TonWeb.boc.Cell();\n    message.bits.writeUint(walletId, 32);\n    if (seqno === 0) {\n      for (let i = 0; i < 32; i++) {\n        message.bits.writeBit(1);\n      }\n    } else {\n      message.bits.writeUint(expireAt, 32);\n    }\n    message.bits.writeUint(seqno, 32);\n    message.bits.writeUint(0, 8); // op\n    return message;\n  }\n\n  private createOutMsg(address, amount, payload) {\n    let payloadCell = new TonWeb.boc.Cell();\n    if (payload) {\n      if (payload.refs) {\n        // is Cell\n        payloadCell = payload;\n      } else if (typeof payload === 'string') {\n        if (payload.length > 0) {\n          payloadCell.bits.writeUint(0, 32);\n          payloadCell.bits.writeString(payload);\n        }\n      } else {\n        payloadCell.bits.writeBytes(payload);\n      }\n    }\n\n    const orderHeader = TonWeb.Contract.createInternalMessageHeader(new TonWeb.Address(address), new BN(amount));\n    return TonWeb.Contract.createCommonMsgInfo(orderHeader, undefined, payloadCell);\n  }\n\n  async createExternalMessage(signingMessage: Cell, seqno: number, signature: string): Promise<Cell> {\n    const body = new TonWeb.boc.Cell();\n\n    body.bits.writeBytes(Buffer.from(signature, 'hex'));\n    body.writeCell(signingMessage);\n\n    let stateInit;\n    if (seqno === 0) {\n      const WalletClass = TonWeb.Wallets.all['v4R2'];\n      const wallet = new WalletClass(new TonWeb.HttpProvider(), {\n        publicKey: TonWeb.utils.hexToBytes(this.publicKey),\n        wc: 0,\n      });\n      const deploy = await wallet.createStateInit();\n      stateInit = deploy.stateInit;\n    }\n\n    const header = TonWeb.Contract.createExternalMessageHeader(this.sender);\n    const resultMessage = TonWeb.Contract.createCommonMsgInfo(header, stateInit, body);\n    return resultMessage;\n  }\n\n  loadInputsAndOutputs(): void {\n    const outputs: Entry[] = [];\n    const inputs: Entry[] = [];\n    inputs.push({\n      address: this.sender,\n      value: this.recipient.amount,\n      coin: this._coinConfig.name,\n    });\n    outputs.push({\n      address: this.recipient.address,\n      value: this.recipient.amount,\n      coin: this._coinConfig.name,\n    });\n    this._outputs = outputs;\n    this._inputs = inputs;\n  }\n\n  fromRawTransaction(rawTransaction: string): void {\n    try {\n      const cell = TonWeb.boc.Cell.oneFromBoc(TonWeb.utils.base64ToBytes(rawTransaction));\n\n      const parsed = this.parseTransfer(cell);\n      parsed.value = parsed.value.toString();\n      parsed.fromAddress = parsed.fromAddress.toString(true, true, true);\n      parsed.toAddress = parsed.toAddress.toString(true, true, true);\n      this.sender = parsed.fromAddress;\n      this.recipient = { address: parsed.toAddress, amount: parsed.value };\n      this.seqno = parsed.seqno;\n      this.publicKey = parsed.publicKey as string;\n      this.expireTime = parsed.expireAt;\n      this.message = parsed.payload;\n      this._signatures.push(parsed.signature);\n    } catch (e) {\n      throw new Error('invalid raw transaction');\n    }\n  }\n\n  /** @inheritDoc */\n  explainTransaction(): TransactionExplanation {\n    const displayOrder = ['id', 'outputs', 'outputAmount', 'changeOutputs', 'changeAmount', 'fee'];\n\n    const outputs: TransactionRecipient[] = [this.recipient];\n    const outputAmount = this.recipient.amount;\n    return {\n      displayOrder,\n      id: this.id,\n      outputs,\n      outputAmount,\n      changeOutputs: [],\n      changeAmount: '0',\n      fee: { fee: 'UNKNOWN' },\n    };\n  }\n\n  private parseTransfer(cell: Cell): any {\n    const slice = (cell as any).beginParse();\n\n    // header\n\n    if (slice.loadUint(2).toNumber() !== 2) throw Error('invalid header');\n\n    const externalSourceAddress = slice.loadAddress();\n    if (externalSourceAddress !== null) throw Error('invalid externalSourceAddress');\n\n    const externalDestAddress = slice.loadAddress();\n\n    const externalImportFee = slice.loadCoins();\n    if (!externalImportFee.eq(new BN(0))) throw new Error('invalid externalImportFee');\n\n    // stateInit\n\n    let publicKey;\n    if (slice.loadBit()) {\n      if (slice.loadBit()) {\n        const stateInit = slice.loadRef();\n        stateInit.loadRef();\n        const data = stateInit.loadRef();\n        const seqno = data.loadUint(32).toNumber();\n        if (seqno !== 0) throw new Error('invalid seqno');\n        const walletId = data.loadUint(32).toNumber();\n        if (walletId !== WALLET_ID) throw new Error('invalid wallet id');\n        const publicKeyBuf = new Uint8Array(32);\n        for (let i = 0; i < publicKeyBuf.length; i++) {\n          publicKeyBuf[i] = data.loadUint(8);\n        }\n        publicKey = Buffer.from(publicKeyBuf).toString('hex');\n      }\n    }\n\n    // body\n    const bodySlice = slice.loadBit() ? slice.loadRef() : slice;\n\n    return {\n      fromAddress: externalDestAddress,\n      publicKey,\n      ...this.parseTransferBody(bodySlice),\n    };\n  }\n\n  private parseTransferBody(slice: any): any {\n    const signature = Buffer.from(slice.loadBits(512)).toString('hex');\n    // signing message\n\n    const walletId = slice.loadUint(32).toNumber();\n    if (walletId !== WALLET_ID) throw new Error('invalid walletId');\n\n    const expireAt = slice.loadUint(32).toNumber();\n\n    const seqno = slice.loadUint(32).toNumber();\n\n    const op = slice.loadUint(8).toNumber();\n    if (op !== 0) throw new Error('invalid op');\n\n    const sendMode = slice.loadUint(8).toNumber();\n    if (sendMode !== 3) throw new Error('invalid sendMode');\n\n    let order = slice.loadRef();\n\n    if (order.loadBit()) throw Error('invalid internal header');\n    if (!order.loadBit()) throw Error('invalid ihrDisabled');\n    const bounce = order.loadBit();\n    if (order.loadBit()) throw Error('invalid bounced');\n    const sourceAddress = order.loadAddress();\n    if (sourceAddress !== null) throw Error('invalid externalSourceAddress');\n    const destAddress = order.loadAddress();\n    const value = order.loadCoins();\n\n    if (order.loadBit()) throw Error('invalid currencyCollection');\n    const ihrFees = order.loadCoins();\n    if (!ihrFees.eq(new BN(0))) throw new Error('invalid ihrFees');\n    const fwdFees = order.loadCoins();\n    if (!fwdFees.eq(new BN(0))) throw new Error('invalid fwdFees');\n    const createdLt = order.loadUint(64);\n    if (!createdLt.eq(new BN(0))) throw new Error('invalid createdLt');\n    const createdAt = order.loadUint(32);\n    if (!createdAt.eq(new BN(0))) throw new Error('invalid createdAt');\n\n    // order stateInit\n    if (order.loadBit()) {\n      order.loadRef(); // don't parse stateInit\n    }\n\n    // order body\n    let payload;\n\n    if (order.getFreeBits() > 0) {\n      if (order.loadBit()) {\n        order = order.loadRef();\n      }\n\n      if (order.getFreeBits() > 32) {\n        const op = order.loadUint(32);\n        const payloadBytes = order.loadBits(order.getFreeBits());\n        payload = op.eq(new BN(0)) ? new TextDecoder().decode(payloadBytes) : '';\n      }\n    }\n    return {\n      toAddress: destAddress,\n      value,\n      bounce,\n      seqno,\n      expireAt,\n      payload,\n      signature,\n      walletId,\n    };\n  }\n\n  private parseTransferStateInit(slice: any): any {\n    if (slice === null) return {};\n    slice.loadRef();\n    const data = slice.loadRef();\n    const seqno = data.loadUint(32).toNumber();\n    if (seqno !== 0) throw new Error('invalid seqno');\n    const walletId = data.loadUint(32).toNumber();\n    if (walletId !== WALLET_ID) throw new Error('invalid wallet id');\n    const publicKey = new Uint8Array(32);\n    for (let i = 0; i < publicKey.length; i++) {\n      publicKey[i] = data.loadUint(8);\n    }\n    return {\n      publicKey: Buffer.from(publicKey).toString('hex'),\n    };\n  }\n}\n"]}
|
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
/// <reference types="node" />
|
|
2
|
+
import { BaseAddress, BaseKey, BaseTransactionBuilder, FeeOptions, PublicKey as BasePublicKey, TransactionType } from '@bitgo/sdk-core';
|
|
3
|
+
import { Transaction } from './transaction';
|
|
4
|
+
import BigNumber from 'bignumber.js';
|
|
5
|
+
import { BaseCoin as CoinConfig } from '@bitgo/statics';
|
|
6
|
+
export declare abstract class TransactionBuilder extends BaseTransactionBuilder {
|
|
7
|
+
protected _transaction: Transaction;
|
|
8
|
+
private _signatures;
|
|
9
|
+
constructor(coinConfig: Readonly<CoinConfig>);
|
|
10
|
+
/**
|
|
11
|
+
* The transaction type.
|
|
12
|
+
*/
|
|
13
|
+
protected abstract get transactionType(): TransactionType;
|
|
14
|
+
/** @inheritdoc */
|
|
15
|
+
protected get transaction(): Transaction;
|
|
16
|
+
/** @inheritdoc */
|
|
17
|
+
protected set transaction(transaction: Transaction);
|
|
18
|
+
/** @inheritdoc */
|
|
19
|
+
protected signImplementation(key: BaseKey): Transaction;
|
|
20
|
+
/** @inheritDoc */
|
|
21
|
+
addSignature(publicKey: BasePublicKey, signature: Buffer): void;
|
|
22
|
+
/**
|
|
23
|
+
* Sets the sender of this transaction.
|
|
24
|
+
* This account will be responsible for paying transaction fees.
|
|
25
|
+
*
|
|
26
|
+
* @param {string} senderAddress the account that is sending this transaction
|
|
27
|
+
* @returns {TransactionBuilder} This transaction builder
|
|
28
|
+
*/
|
|
29
|
+
sender(senderAddress: string): this;
|
|
30
|
+
fee(feeOptions: FeeOptions): this;
|
|
31
|
+
/** @inheritdoc */
|
|
32
|
+
protected fromImplementation(rawTransaction: string): Transaction;
|
|
33
|
+
/** @inheritdoc */
|
|
34
|
+
protected buildImplementation(): Promise<Transaction>;
|
|
35
|
+
/** @inheritdoc */
|
|
36
|
+
validateAddress(address: BaseAddress, addressFormat?: string): void;
|
|
37
|
+
/** @inheritdoc */
|
|
38
|
+
validateKey(key: BaseKey): void;
|
|
39
|
+
/** @inheritdoc */
|
|
40
|
+
validateRawTransaction(rawTransaction: string): void;
|
|
41
|
+
/** @inheritdoc */
|
|
42
|
+
validateTransaction(transaction?: Transaction): void;
|
|
43
|
+
/** @inheritdoc */
|
|
44
|
+
validateValue(value: BigNumber): void;
|
|
45
|
+
setMessage(msg: string): TransactionBuilder;
|
|
46
|
+
sequenceNumber(number: number): TransactionBuilder;
|
|
47
|
+
expireTime(number: number): TransactionBuilder;
|
|
48
|
+
publicKey(key: string): TransactionBuilder;
|
|
49
|
+
}
|
|
50
|
+
//# sourceMappingURL=transactionBuilder.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"transactionBuilder.d.ts","sourceRoot":"","sources":["../../../src/lib/transactionBuilder.ts"],"names":[],"mappings":";AAAA,OAAO,EACL,WAAW,EACX,OAAO,EACP,sBAAsB,EAEtB,UAAU,EACV,SAAS,IAAI,aAAa,EAE1B,eAAe,EAChB,MAAM,iBAAiB,CAAC;AACzB,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAE5C,OAAO,SAAS,MAAM,cAAc,CAAC;AACrC,OAAO,EAAE,QAAQ,IAAI,UAAU,EAAE,MAAM,gBAAgB,CAAC;AAExD,8BAAsB,kBAAmB,SAAQ,sBAAsB;IACrE,SAAS,CAAC,YAAY,EAAE,WAAW,CAAC;IACpC,OAAO,CAAC,WAAW,CAAmB;gBAE1B,UAAU,EAAE,QAAQ,CAAC,UAAU,CAAC;IAM5C;;OAEG;IACH,SAAS,CAAC,QAAQ,KAAK,eAAe,IAAI,eAAe,CAAC;IAE1D,kBAAkB;IAClB,SAAS,KAAK,WAAW,IAAI,WAAW,CAEvC;IAED,kBAAkB;IAClB,SAAS,KAAK,WAAW,CAAC,WAAW,EAAE,WAAW,EAEjD;IAED,kBAAkB;IAClB,SAAS,CAAC,kBAAkB,CAAC,GAAG,EAAE,OAAO,GAAG,WAAW;IAIvD,kBAAkB;IAClB,YAAY,CAAC,SAAS,EAAE,aAAa,EAAE,SAAS,EAAE,MAAM,GAAG,IAAI;IAI/D;;;;;;OAMG;IACH,MAAM,CAAC,aAAa,EAAE,MAAM,GAAG,IAAI;IAKnC,GAAG,CAAC,UAAU,EAAE,UAAU,GAAG,IAAI;IAIjC,kBAAkB;IAClB,SAAS,CAAC,kBAAkB,CAAC,cAAc,EAAE,MAAM,GAAG,WAAW;IAKjE,kBAAkB;cACF,mBAAmB,IAAI,OAAO,CAAC,WAAW,CAAC;IAa3D,kBAAkB;IAClB,eAAe,CAAC,OAAO,EAAE,WAAW,EAAE,aAAa,CAAC,EAAE,MAAM,GAAG,IAAI;IAMnE,kBAAkB;IAClB,WAAW,CAAC,GAAG,EAAE,OAAO,GAAG,IAAI;IAI/B,kBAAkB;IAClB,sBAAsB,CAAC,cAAc,EAAE,MAAM,GAAG,IAAI;IAIpD,kBAAkB;IAClB,mBAAmB,CAAC,WAAW,CAAC,EAAE,WAAW,GAAG,IAAI;IAQpD,kBAAkB;IAClB,aAAa,CAAC,KAAK,EAAE,SAAS,GAAG,IAAI;IAMrC,UAAU,CAAC,GAAG,EAAE,MAAM,GAAG,kBAAkB;IAK3C,cAAc,CAAC,MAAM,EAAE,MAAM,GAAG,kBAAkB;IAKlD,UAAU,CAAC,MAAM,EAAE,MAAM,GAAG,kBAAkB;IAK9C,SAAS,CAAC,GAAG,EAAE,MAAM,GAAG,kBAAkB;CAI3C"}
|
|
@@ -0,0 +1,111 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.TransactionBuilder = void 0;
|
|
7
|
+
const sdk_core_1 = require("@bitgo/sdk-core");
|
|
8
|
+
const transaction_1 = require("./transaction");
|
|
9
|
+
const utils_1 = __importDefault(require("./utils"));
|
|
10
|
+
const bignumber_js_1 = __importDefault(require("bignumber.js"));
|
|
11
|
+
class TransactionBuilder extends sdk_core_1.BaseTransactionBuilder {
|
|
12
|
+
constructor(coinConfig) {
|
|
13
|
+
super(coinConfig);
|
|
14
|
+
this._signatures = [];
|
|
15
|
+
this._transaction = new transaction_1.Transaction(coinConfig);
|
|
16
|
+
}
|
|
17
|
+
/** @inheritdoc */
|
|
18
|
+
get transaction() {
|
|
19
|
+
return this._transaction;
|
|
20
|
+
}
|
|
21
|
+
/** @inheritdoc */
|
|
22
|
+
set transaction(transaction) {
|
|
23
|
+
this._transaction = transaction;
|
|
24
|
+
}
|
|
25
|
+
/** @inheritdoc */
|
|
26
|
+
signImplementation(key) {
|
|
27
|
+
throw new Error('Method not implemented.');
|
|
28
|
+
}
|
|
29
|
+
/** @inheritDoc */
|
|
30
|
+
addSignature(publicKey, signature) {
|
|
31
|
+
this.transaction.signature.push(signature.toString('hex'));
|
|
32
|
+
}
|
|
33
|
+
/**
|
|
34
|
+
* Sets the sender of this transaction.
|
|
35
|
+
* This account will be responsible for paying transaction fees.
|
|
36
|
+
*
|
|
37
|
+
* @param {string} senderAddress the account that is sending this transaction
|
|
38
|
+
* @returns {TransactionBuilder} This transaction builder
|
|
39
|
+
*/
|
|
40
|
+
sender(senderAddress) {
|
|
41
|
+
this.transaction.sender = senderAddress;
|
|
42
|
+
return this;
|
|
43
|
+
}
|
|
44
|
+
fee(feeOptions) {
|
|
45
|
+
throw new Error('Method not implemented.');
|
|
46
|
+
}
|
|
47
|
+
/** @inheritdoc */
|
|
48
|
+
fromImplementation(rawTransaction) {
|
|
49
|
+
this.transaction.fromRawTransaction(rawTransaction);
|
|
50
|
+
return this.transaction;
|
|
51
|
+
}
|
|
52
|
+
/** @inheritdoc */
|
|
53
|
+
async buildImplementation() {
|
|
54
|
+
await this.transaction.build();
|
|
55
|
+
// if (this.si) {
|
|
56
|
+
// this.transaction.sign(this._signer);
|
|
57
|
+
// }
|
|
58
|
+
// if (this._signatures?.length > 0) {
|
|
59
|
+
// this.transaction.constructSignedPayload(this._signatures[0].signature);
|
|
60
|
+
// }
|
|
61
|
+
this.transaction.loadInputsAndOutputs();
|
|
62
|
+
return this.transaction;
|
|
63
|
+
}
|
|
64
|
+
// region Validators
|
|
65
|
+
/** @inheritdoc */
|
|
66
|
+
validateAddress(address, addressFormat) {
|
|
67
|
+
if (!utils_1.default.isValidAddress(address.address)) {
|
|
68
|
+
throw new sdk_core_1.BuildTransactionError('Invalid address ' + address.address);
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
/** @inheritdoc */
|
|
72
|
+
validateKey(key) {
|
|
73
|
+
throw new Error('Method not implemented.');
|
|
74
|
+
}
|
|
75
|
+
/** @inheritdoc */
|
|
76
|
+
validateRawTransaction(rawTransaction) {
|
|
77
|
+
return;
|
|
78
|
+
}
|
|
79
|
+
/** @inheritdoc */
|
|
80
|
+
validateTransaction(transaction) {
|
|
81
|
+
if (!transaction) {
|
|
82
|
+
throw new Error('transaction not defined');
|
|
83
|
+
}
|
|
84
|
+
this.validateAddress(transaction.recipient);
|
|
85
|
+
this.validateValue(new bignumber_js_1.default(transaction.recipient.amount));
|
|
86
|
+
}
|
|
87
|
+
/** @inheritdoc */
|
|
88
|
+
validateValue(value) {
|
|
89
|
+
if (value.isLessThan(0)) {
|
|
90
|
+
throw new sdk_core_1.BuildTransactionError('Value cannot be less than zero');
|
|
91
|
+
}
|
|
92
|
+
}
|
|
93
|
+
setMessage(msg) {
|
|
94
|
+
this.transaction.message = msg;
|
|
95
|
+
return this;
|
|
96
|
+
}
|
|
97
|
+
sequenceNumber(number) {
|
|
98
|
+
this.transaction.seqno = number;
|
|
99
|
+
return this;
|
|
100
|
+
}
|
|
101
|
+
expireTime(number) {
|
|
102
|
+
this.transaction.expireTime = number;
|
|
103
|
+
return this;
|
|
104
|
+
}
|
|
105
|
+
publicKey(key) {
|
|
106
|
+
this.transaction.publicKey = key;
|
|
107
|
+
return this;
|
|
108
|
+
}
|
|
109
|
+
}
|
|
110
|
+
exports.TransactionBuilder = TransactionBuilder;
|
|
111
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"transactionBuilder.js","sourceRoot":"","sources":["../../../src/lib/transactionBuilder.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  BaseAddress,\n  BaseKey,\n  BaseTransactionBuilder,\n  BuildTransactionError,\n  FeeOptions,\n  PublicKey as BasePublicKey,\n  Signature,\n  TransactionType,\n} from '@bitgo/sdk-core';\nimport { Transaction } from './transaction';\nimport utils from './utils';\nimport BigNumber from 'bignumber.js';\nimport { BaseCoin as CoinConfig } from '@bitgo/statics';\n\nexport abstract class TransactionBuilder extends BaseTransactionBuilder {\n  protected _transaction: Transaction;\n  private _signatures: Signature[] = [];\n\n  constructor(coinConfig: Readonly<CoinConfig>) {\n    super(coinConfig);\n    this._transaction = new Transaction(coinConfig);\n  }\n\n  // get and set region\n  /**\n   * The transaction type.\n   */\n  protected abstract get transactionType(): TransactionType;\n\n  /** @inheritdoc */\n  protected get transaction(): Transaction {\n    return this._transaction;\n  }\n\n  /** @inheritdoc */\n  protected set transaction(transaction: Transaction) {\n    this._transaction = transaction;\n  }\n\n  /** @inheritdoc */\n  protected signImplementation(key: BaseKey): Transaction {\n    throw new Error('Method not implemented.');\n  }\n\n  /** @inheritDoc */\n  addSignature(publicKey: BasePublicKey, signature: Buffer): void {\n    this.transaction.signature.push(signature.toString('hex'));\n  }\n\n  /**\n   * Sets the sender of this transaction.\n   * This account will be responsible for paying transaction fees.\n   *\n   * @param {string} senderAddress the account that is sending this transaction\n   * @returns {TransactionBuilder} This transaction builder\n   */\n  sender(senderAddress: string): this {\n    this.transaction.sender = senderAddress;\n    return this;\n  }\n\n  fee(feeOptions: FeeOptions): this {\n    throw new Error('Method not implemented.');\n  }\n\n  /** @inheritdoc */\n  protected fromImplementation(rawTransaction: string): Transaction {\n    this.transaction.fromRawTransaction(rawTransaction);\n    return this.transaction;\n  }\n\n  /** @inheritdoc */\n  protected async buildImplementation(): Promise<Transaction> {\n    await this.transaction.build();\n    //    if (this.si) {\n    //      this.transaction.sign(this._signer);\n    //    }\n    //    if (this._signatures?.length > 0) {\n    //      this.transaction.constructSignedPayload(this._signatures[0].signature);\n    //    }\n    this.transaction.loadInputsAndOutputs();\n    return this.transaction;\n  }\n\n  // region Validators\n  /** @inheritdoc */\n  validateAddress(address: BaseAddress, addressFormat?: string): void {\n    if (!utils.isValidAddress(address.address)) {\n      throw new BuildTransactionError('Invalid address ' + address.address);\n    }\n  }\n\n  /** @inheritdoc */\n  validateKey(key: BaseKey): void {\n    throw new Error('Method not implemented.');\n  }\n\n  /** @inheritdoc */\n  validateRawTransaction(rawTransaction: string): void {\n    return;\n  }\n\n  /** @inheritdoc */\n  validateTransaction(transaction?: Transaction): void {\n    if (!transaction) {\n      throw new Error('transaction not defined');\n    }\n    this.validateAddress(transaction.recipient);\n    this.validateValue(new BigNumber(transaction.recipient.amount));\n  }\n\n  /** @inheritdoc */\n  validateValue(value: BigNumber): void {\n    if (value.isLessThan(0)) {\n      throw new BuildTransactionError('Value cannot be less than zero');\n    }\n  }\n\n  setMessage(msg: string): TransactionBuilder {\n    this.transaction.message = msg;\n    return this;\n  }\n\n  sequenceNumber(number: number): TransactionBuilder {\n    this.transaction.seqno = number;\n    return this;\n  }\n\n  expireTime(number: number): TransactionBuilder {\n    this.transaction.expireTime = number;\n    return this;\n  }\n\n  publicKey(key: string): TransactionBuilder {\n    this.transaction.publicKey = key;\n    return this;\n  }\n}\n"]}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { BaseTransactionBuilderFactory } from '@bitgo/sdk-core';
|
|
2
|
+
import { TransactionBuilder } from './transactionBuilder';
|
|
3
|
+
import { TransferBuilder } from './transferBuilder';
|
|
4
|
+
import { BaseCoin as CoinConfig } from '@bitgo/statics';
|
|
5
|
+
export declare class TransactionBuilderFactory extends BaseTransactionBuilderFactory {
|
|
6
|
+
constructor(_coinConfig: Readonly<CoinConfig>);
|
|
7
|
+
/** @inheritdoc */
|
|
8
|
+
from(raw: string): TransactionBuilder;
|
|
9
|
+
/** @inheritdoc */
|
|
10
|
+
getTransferBuilder(): TransferBuilder;
|
|
11
|
+
/** @inheritdoc */
|
|
12
|
+
getWalletInitializationBuilder(): void;
|
|
13
|
+
}
|
|
14
|
+
//# sourceMappingURL=transactionBuilderFactory.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"transactionBuilderFactory.d.ts","sourceRoot":"","sources":["../../../src/lib/transactionBuilderFactory.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,6BAA6B,EAAE,MAAM,iBAAiB,CAAC;AAChE,OAAO,EAAE,kBAAkB,EAAE,MAAM,sBAAsB,CAAC;AAC1D,OAAO,EAAE,eAAe,EAAE,MAAM,mBAAmB,CAAC;AACpD,OAAO,EAAE,QAAQ,IAAI,UAAU,EAAE,MAAM,gBAAgB,CAAC;AAExD,qBAAa,yBAA0B,SAAQ,6BAA6B;gBAC9D,WAAW,EAAE,QAAQ,CAAC,UAAU,CAAC;IAG7C,kBAAkB;IAClB,IAAI,CAAC,GAAG,EAAE,MAAM,GAAG,kBAAkB;IAMrC,kBAAkB;IAClB,kBAAkB,IAAI,eAAe;IAIrC,kBAAkB;IAClB,8BAA8B,IAAI,IAAI;CAGvC"}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.TransactionBuilderFactory = void 0;
|
|
4
|
+
const sdk_core_1 = require("@bitgo/sdk-core");
|
|
5
|
+
const transferBuilder_1 = require("./transferBuilder");
|
|
6
|
+
class TransactionBuilderFactory extends sdk_core_1.BaseTransactionBuilderFactory {
|
|
7
|
+
constructor(_coinConfig) {
|
|
8
|
+
super(_coinConfig);
|
|
9
|
+
}
|
|
10
|
+
/** @inheritdoc */
|
|
11
|
+
from(raw) {
|
|
12
|
+
const builder = new transferBuilder_1.TransferBuilder(this._coinConfig);
|
|
13
|
+
builder.from(raw);
|
|
14
|
+
return builder;
|
|
15
|
+
}
|
|
16
|
+
/** @inheritdoc */
|
|
17
|
+
getTransferBuilder() {
|
|
18
|
+
return new transferBuilder_1.TransferBuilder(this._coinConfig);
|
|
19
|
+
}
|
|
20
|
+
/** @inheritdoc */
|
|
21
|
+
getWalletInitializationBuilder() {
|
|
22
|
+
throw new Error('Method not implemented.');
|
|
23
|
+
}
|
|
24
|
+
}
|
|
25
|
+
exports.TransactionBuilderFactory = TransactionBuilderFactory;
|
|
26
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJhbnNhY3Rpb25CdWlsZGVyRmFjdG9yeS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9saWIvdHJhbnNhY3Rpb25CdWlsZGVyRmFjdG9yeS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFBQSw4Q0FBZ0U7QUFFaEUsdURBQW9EO0FBR3BELE1BQWEseUJBQTBCLFNBQVEsd0NBQTZCO0lBQzFFLFlBQVksV0FBaUM7UUFDM0MsS0FBSyxDQUFDLFdBQVcsQ0FBQyxDQUFDO0lBQ3JCLENBQUM7SUFDRCxrQkFBa0I7SUFDbEIsSUFBSSxDQUFDLEdBQVc7UUFDZCxNQUFNLE9BQU8sR0FBRyxJQUFJLGlDQUFlLENBQUMsSUFBSSxDQUFDLFdBQVcsQ0FBQyxDQUFDO1FBQ3RELE9BQU8sQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUM7UUFDbEIsT0FBTyxPQUFPLENBQUM7SUFDakIsQ0FBQztJQUVELGtCQUFrQjtJQUNsQixrQkFBa0I7UUFDaEIsT0FBTyxJQUFJLGlDQUFlLENBQUMsSUFBSSxDQUFDLFdBQVcsQ0FBQyxDQUFDO0lBQy9DLENBQUM7SUFFRCxrQkFBa0I7SUFDbEIsOEJBQThCO1FBQzVCLE1BQU0sSUFBSSxLQUFLLENBQUMseUJBQXlCLENBQUMsQ0FBQztJQUM3QyxDQUFDO0NBQ0Y7QUFwQkQsOERBb0JDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQmFzZVRyYW5zYWN0aW9uQnVpbGRlckZhY3RvcnkgfSBmcm9tICdAYml0Z28vc2RrLWNvcmUnO1xuaW1wb3J0IHsgVHJhbnNhY3Rpb25CdWlsZGVyIH0gZnJvbSAnLi90cmFuc2FjdGlvbkJ1aWxkZXInO1xuaW1wb3J0IHsgVHJhbnNmZXJCdWlsZGVyIH0gZnJvbSAnLi90cmFuc2ZlckJ1aWxkZXInO1xuaW1wb3J0IHsgQmFzZUNvaW4gYXMgQ29pbkNvbmZpZyB9IGZyb20gJ0BiaXRnby9zdGF0aWNzJztcblxuZXhwb3J0IGNsYXNzIFRyYW5zYWN0aW9uQnVpbGRlckZhY3RvcnkgZXh0ZW5kcyBCYXNlVHJhbnNhY3Rpb25CdWlsZGVyRmFjdG9yeSB7XG4gIGNvbnN0cnVjdG9yKF9jb2luQ29uZmlnOiBSZWFkb25seTxDb2luQ29uZmlnPikge1xuICAgIHN1cGVyKF9jb2luQ29uZmlnKTtcbiAgfVxuICAvKiogQGluaGVyaXRkb2MgKi9cbiAgZnJvbShyYXc6IHN0cmluZyk6IFRyYW5zYWN0aW9uQnVpbGRlciB7XG4gICAgY29uc3QgYnVpbGRlciA9IG5ldyBUcmFuc2ZlckJ1aWxkZXIodGhpcy5fY29pbkNvbmZpZyk7XG4gICAgYnVpbGRlci5mcm9tKHJhdyk7XG4gICAgcmV0dXJuIGJ1aWxkZXI7XG4gIH1cblxuICAvKiogQGluaGVyaXRkb2MgKi9cbiAgZ2V0VHJhbnNmZXJCdWlsZGVyKCk6IFRyYW5zZmVyQnVpbGRlciB7XG4gICAgcmV0dXJuIG5ldyBUcmFuc2ZlckJ1aWxkZXIodGhpcy5fY29pbkNvbmZpZyk7XG4gIH1cblxuICAvKiogQGluaGVyaXRkb2MgKi9cbiAgZ2V0V2FsbGV0SW5pdGlhbGl6YXRpb25CdWlsZGVyKCk6IHZvaWQge1xuICAgIHRocm93IG5ldyBFcnJvcignTWV0aG9kIG5vdCBpbXBsZW1lbnRlZC4nKTtcbiAgfVxufVxuIl19
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { TransactionBuilder } from './transactionBuilder';
|
|
2
|
+
import { BaseCoin as CoinConfig } from '@bitgo/statics';
|
|
3
|
+
import { Recipient, TransactionType } from '@bitgo/sdk-core';
|
|
4
|
+
export declare class TransferBuilder extends TransactionBuilder {
|
|
5
|
+
constructor(_coinConfig: Readonly<CoinConfig>);
|
|
6
|
+
protected get transactionType(): TransactionType;
|
|
7
|
+
send(recipient: Recipient): TransferBuilder;
|
|
8
|
+
}
|
|
9
|
+
//# sourceMappingURL=transferBuilder.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"transferBuilder.d.ts","sourceRoot":"","sources":["../../../src/lib/transferBuilder.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,kBAAkB,EAAE,MAAM,sBAAsB,CAAC;AAC1D,OAAO,EAAE,QAAQ,IAAI,UAAU,EAAE,MAAM,gBAAgB,CAAC;AACxD,OAAO,EAAE,SAAS,EAAE,eAAe,EAAE,MAAM,iBAAiB,CAAC;AAE7D,qBAAa,eAAgB,SAAQ,kBAAkB;gBACzC,WAAW,EAAE,QAAQ,CAAC,UAAU,CAAC;IAI7C,SAAS,KAAK,eAAe,IAAI,eAAe,CAE/C;IAED,IAAI,CAAC,SAAS,EAAE,SAAS,GAAG,eAAe;CAI5C"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.TransferBuilder = void 0;
|
|
4
|
+
const transactionBuilder_1 = require("./transactionBuilder");
|
|
5
|
+
const sdk_core_1 = require("@bitgo/sdk-core");
|
|
6
|
+
class TransferBuilder extends transactionBuilder_1.TransactionBuilder {
|
|
7
|
+
constructor(_coinConfig) {
|
|
8
|
+
super(_coinConfig);
|
|
9
|
+
}
|
|
10
|
+
get transactionType() {
|
|
11
|
+
return sdk_core_1.TransactionType.Send;
|
|
12
|
+
}
|
|
13
|
+
send(recipient) {
|
|
14
|
+
this.transaction.recipient = recipient;
|
|
15
|
+
return this;
|
|
16
|
+
}
|
|
17
|
+
}
|
|
18
|
+
exports.TransferBuilder = TransferBuilder;
|
|
19
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJhbnNmZXJCdWlsZGVyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2xpYi90cmFuc2ZlckJ1aWxkZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQUEsNkRBQTBEO0FBRTFELDhDQUE2RDtBQUU3RCxNQUFhLGVBQWdCLFNBQVEsdUNBQWtCO0lBQ3JELFlBQVksV0FBaUM7UUFDM0MsS0FBSyxDQUFDLFdBQVcsQ0FBQyxDQUFDO0lBQ3JCLENBQUM7SUFFRCxJQUFjLGVBQWU7UUFDM0IsT0FBTywwQkFBZSxDQUFDLElBQUksQ0FBQztJQUM5QixDQUFDO0lBRUQsSUFBSSxDQUFDLFNBQW9CO1FBQ3ZCLElBQUksQ0FBQyxXQUFXLENBQUMsU0FBUyxHQUFHLFNBQVMsQ0FBQztRQUN2QyxPQUFPLElBQUksQ0FBQztJQUNkLENBQUM7Q0FDRjtBQWJELDBDQWFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgVHJhbnNhY3Rpb25CdWlsZGVyIH0gZnJvbSAnLi90cmFuc2FjdGlvbkJ1aWxkZXInO1xuaW1wb3J0IHsgQmFzZUNvaW4gYXMgQ29pbkNvbmZpZyB9IGZyb20gJ0BiaXRnby9zdGF0aWNzJztcbmltcG9ydCB7IFJlY2lwaWVudCwgVHJhbnNhY3Rpb25UeXBlIH0gZnJvbSAnQGJpdGdvL3Nkay1jb3JlJztcblxuZXhwb3J0IGNsYXNzIFRyYW5zZmVyQnVpbGRlciBleHRlbmRzIFRyYW5zYWN0aW9uQnVpbGRlciB7XG4gIGNvbnN0cnVjdG9yKF9jb2luQ29uZmlnOiBSZWFkb25seTxDb2luQ29uZmlnPikge1xuICAgIHN1cGVyKF9jb2luQ29uZmlnKTtcbiAgfVxuXG4gIHByb3RlY3RlZCBnZXQgdHJhbnNhY3Rpb25UeXBlKCk6IFRyYW5zYWN0aW9uVHlwZSB7XG4gICAgcmV0dXJuIFRyYW5zYWN0aW9uVHlwZS5TZW5kO1xuICB9XG5cbiAgc2VuZChyZWNpcGllbnQ6IFJlY2lwaWVudCk6IFRyYW5zZmVyQnVpbGRlciB7XG4gICAgdGhpcy50cmFuc2FjdGlvbi5yZWNpcGllbnQgPSByZWNpcGllbnQ7XG4gICAgcmV0dXJuIHRoaXM7XG4gIH1cbn1cbiJdfQ==
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import { BaseUtils } from '@bitgo/sdk-core';
|
|
2
|
+
export declare class Utils implements BaseUtils {
|
|
3
|
+
/** @inheritdoc */
|
|
4
|
+
isValidAddress(address: string): boolean;
|
|
5
|
+
/** @inheritdoc */
|
|
6
|
+
isValidBlockId(hash: string): boolean;
|
|
7
|
+
/** @inheritdoc */
|
|
8
|
+
isValidPrivateKey(key: string): boolean;
|
|
9
|
+
/** @inheritdoc */
|
|
10
|
+
isValidPublicKey(key: string): boolean;
|
|
11
|
+
/** @inheritdoc */
|
|
12
|
+
isValidSignature(signature: string): boolean;
|
|
13
|
+
/** @inheritdoc */
|
|
14
|
+
isValidTransactionId(txId: string): boolean;
|
|
15
|
+
getAddressFromPublicKey(publicKey: string): Promise<string>;
|
|
16
|
+
}
|
|
17
|
+
declare const utils: Utils;
|
|
18
|
+
export default utils;
|
|
19
|
+
//# sourceMappingURL=utils.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"utils.d.ts","sourceRoot":"","sources":["../../../src/lib/utils.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAA2B,MAAM,iBAAiB,CAAC;AAGrE,qBAAa,KAAM,YAAW,SAAS;IACrC,kBAAkB;IAClB,cAAc,CAAC,OAAO,EAAE,MAAM,GAAG,OAAO;IASxC,kBAAkB;IAClB,cAAc,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO;IAIrC,kBAAkB;IAClB,iBAAiB,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO;IAIvC,kBAAkB;IAClB,gBAAgB,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO;IAItC,kBAAkB;IAClB,gBAAgB,CAAC,SAAS,EAAE,MAAM,GAAG,OAAO;IAI5C,kBAAkB;IAClB,oBAAoB,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO;IAIrC,uBAAuB,CAAC,SAAS,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC;CAUlE;AAED,QAAA,MAAM,KAAK,OAAc,CAAC;AAE1B,eAAe,KAAK,CAAC"}
|