@bitgo/sdk-coin-celo 5.1.15 → 5.2.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/.mocharc.yml +1 -1
- package/CHANGELOG.md +6 -0
- package/LICENSE +191 -0
- package/dist/src/celo.d.ts +17 -0
- package/dist/src/celo.d.ts.map +1 -0
- package/dist/src/celo.js +44 -0
- package/dist/src/celoToken.d.ts +34 -0
- package/dist/src/celoToken.d.ts.map +1 -0
- package/dist/src/celoToken.js +73 -0
- package/dist/src/index.d.ts +6 -0
- package/dist/src/index.d.ts.map +1 -0
- package/dist/src/index.js +22 -0
- package/dist/src/lib/index.d.ts +8 -0
- package/dist/src/lib/index.d.ts.map +1 -0
- package/dist/src/lib/index.js +50 -0
- package/dist/src/lib/resources.d.ts +10 -0
- package/dist/src/lib/resources.d.ts.map +1 -0
- package/dist/src/lib/resources.js +25 -0
- package/dist/src/lib/stakingBuilder.d.ts +91 -0
- package/dist/src/lib/stakingBuilder.d.ts.map +1 -0
- package/dist/src/lib/stakingBuilder.js +306 -0
- package/dist/src/lib/stakingCall.d.ts +7 -0
- package/dist/src/lib/stakingCall.d.ts.map +1 -0
- package/dist/src/lib/stakingCall.js +13 -0
- package/dist/src/lib/testnetTransactionBuilder.d.ts +15 -0
- package/dist/src/lib/testnetTransactionBuilder.d.ts.map +1 -0
- package/dist/src/lib/testnetTransactionBuilder.js +68 -0
- package/dist/src/lib/transactionBuilder.d.ts +86 -0
- package/dist/src/lib/transactionBuilder.d.ts.map +1 -0
- package/dist/src/lib/transactionBuilder.js +222 -0
- package/dist/src/lib/transferBuilder.d.ts +19 -0
- package/dist/src/lib/transferBuilder.d.ts.map +1 -0
- package/dist/src/lib/transferBuilder.js +27 -0
- package/dist/src/lib/types.d.ts +50 -0
- package/dist/src/lib/types.d.ts.map +1 -0
- package/dist/src/lib/types.js +223 -0
- package/dist/src/lib/utils.d.ts +18 -0
- package/dist/src/lib/utils.d.ts.map +1 -0
- package/dist/src/lib/utils.js +113 -0
- package/dist/src/register.d.ts +3 -0
- package/dist/src/register.d.ts.map +1 -0
- package/dist/src/register.js +15 -0
- package/dist/src/tcelo.d.ts +13 -0
- package/dist/src/tcelo.d.ts.map +1 -0
- package/dist/src/tcelo.js +19 -0
- package/package.json +8 -8
|
@@ -0,0 +1,222 @@
|
|
|
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 ethereumjs_abi_1 = __importDefault(require("ethereumjs-abi"));
|
|
8
|
+
const abstract_eth_1 = require("@bitgo/abstract-eth");
|
|
9
|
+
const sdk_coin_eth_1 = require("@bitgo/sdk-coin-eth");
|
|
10
|
+
const sdk_core_1 = require("@bitgo/sdk-core");
|
|
11
|
+
const stakingBuilder_1 = require("./stakingBuilder");
|
|
12
|
+
const utils_1 = require("./utils");
|
|
13
|
+
const transferBuilder_1 = require("./transferBuilder");
|
|
14
|
+
const bignumber_js_1 = __importDefault(require("bignumber.js"));
|
|
15
|
+
class TransactionBuilder extends sdk_coin_eth_1.TransactionBuilder {
|
|
16
|
+
constructor(_coinConfig) {
|
|
17
|
+
super(_coinConfig);
|
|
18
|
+
this._common = (0, utils_1.getCommon)(this._coinConfig.network.type);
|
|
19
|
+
this.transaction = new abstract_eth_1.Transaction(this._coinConfig, this._common);
|
|
20
|
+
}
|
|
21
|
+
/** @inheritdoc */
|
|
22
|
+
type(type) {
|
|
23
|
+
super.type(type);
|
|
24
|
+
this._stakingBuilder = undefined;
|
|
25
|
+
}
|
|
26
|
+
getTransactionData() {
|
|
27
|
+
switch (this._type) {
|
|
28
|
+
case sdk_core_1.TransactionType.StakingLock:
|
|
29
|
+
return this.buildLockStakeTransaction();
|
|
30
|
+
case sdk_core_1.TransactionType.StakingUnlock:
|
|
31
|
+
case sdk_core_1.TransactionType.StakingVote:
|
|
32
|
+
case sdk_core_1.TransactionType.StakingUnvote:
|
|
33
|
+
case sdk_core_1.TransactionType.StakingActivate:
|
|
34
|
+
case sdk_core_1.TransactionType.StakingWithdraw:
|
|
35
|
+
return this.buildStakingTransaction();
|
|
36
|
+
}
|
|
37
|
+
return super.getTransactionData();
|
|
38
|
+
}
|
|
39
|
+
/** @inheritdoc */
|
|
40
|
+
fromImplementation(rawTransaction) {
|
|
41
|
+
let tx;
|
|
42
|
+
if (/^0x?[0-9a-f]{1,}$/.test(rawTransaction.toLowerCase())) {
|
|
43
|
+
tx = abstract_eth_1.Transaction.fromSerialized(this._coinConfig, this._common, rawTransaction);
|
|
44
|
+
super.loadBuilderInput(tx.toJson());
|
|
45
|
+
}
|
|
46
|
+
else {
|
|
47
|
+
const txData = JSON.parse(rawTransaction);
|
|
48
|
+
tx = new abstract_eth_1.Transaction(this._coinConfig, this._common, txData);
|
|
49
|
+
}
|
|
50
|
+
return tx;
|
|
51
|
+
}
|
|
52
|
+
setTransactionTypeFields(decodedType, transactionJson) {
|
|
53
|
+
switch (decodedType) {
|
|
54
|
+
case sdk_core_1.TransactionType.StakingLock:
|
|
55
|
+
this._stakingBuilder = new stakingBuilder_1.StakingBuilder(this._coinConfig)
|
|
56
|
+
.type(sdk_core_1.StakingOperationTypes.LOCK)
|
|
57
|
+
.amount(transactionJson.value);
|
|
58
|
+
break;
|
|
59
|
+
case sdk_core_1.TransactionType.StakingUnlock:
|
|
60
|
+
case sdk_core_1.TransactionType.StakingVote:
|
|
61
|
+
case sdk_core_1.TransactionType.StakingUnvote:
|
|
62
|
+
case sdk_core_1.TransactionType.StakingActivate:
|
|
63
|
+
case sdk_core_1.TransactionType.StakingWithdraw:
|
|
64
|
+
this._stakingBuilder = new stakingBuilder_1.StakingBuilder(this._coinConfig, transactionJson.data);
|
|
65
|
+
break;
|
|
66
|
+
default:
|
|
67
|
+
super.setTransactionTypeFields(decodedType, transactionJson);
|
|
68
|
+
break;
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
/**
|
|
72
|
+
* Returns the smart contract encoded data
|
|
73
|
+
*
|
|
74
|
+
* @param {string[]} addresses - the contract signers
|
|
75
|
+
* @returns {string} - the smart contract encoded data
|
|
76
|
+
*/
|
|
77
|
+
getContractData(addresses) {
|
|
78
|
+
const params = [addresses];
|
|
79
|
+
const resultEncodedParameters = ethereumjs_abi_1.default.rawEncode(sdk_coin_eth_1.walletSimpleConstructor, params)
|
|
80
|
+
.toString('hex')
|
|
81
|
+
.replace('0x', '');
|
|
82
|
+
return utils_1.walletSimpleByteCode + resultEncodedParameters;
|
|
83
|
+
}
|
|
84
|
+
// region Stake methods
|
|
85
|
+
/**
|
|
86
|
+
* Gets the staking lock builder if exist, or creates a new one for this transaction and returns it
|
|
87
|
+
* requires: amount
|
|
88
|
+
*
|
|
89
|
+
* @returns {StakingBuilder} the staking builder
|
|
90
|
+
*/
|
|
91
|
+
lock() {
|
|
92
|
+
if (this._type !== sdk_core_1.TransactionType.StakingLock) {
|
|
93
|
+
throw new sdk_core_1.BuildTransactionError('Lock can only be set for Staking Lock transactions type');
|
|
94
|
+
}
|
|
95
|
+
return this.getBuilder(sdk_core_1.StakingOperationTypes.LOCK);
|
|
96
|
+
}
|
|
97
|
+
/**
|
|
98
|
+
* Gets the staking vote builder if exist, or creates a new one for this transaction and returns it
|
|
99
|
+
* requires: group, lesser, greater, amount
|
|
100
|
+
*
|
|
101
|
+
* @returns {StakingBuilder} the staking builder
|
|
102
|
+
*/
|
|
103
|
+
vote() {
|
|
104
|
+
if (this._type !== sdk_core_1.TransactionType.StakingVote) {
|
|
105
|
+
throw new sdk_core_1.BuildTransactionError('Votes can only be set for a staking transaction');
|
|
106
|
+
}
|
|
107
|
+
return this.getBuilder(sdk_core_1.StakingOperationTypes.VOTE);
|
|
108
|
+
}
|
|
109
|
+
/**
|
|
110
|
+
* Gets the staking activate builder if exist, or creates a new one for this transaction and returns it
|
|
111
|
+
* requires: group
|
|
112
|
+
*
|
|
113
|
+
* @returns {StakingBuilder} the staking builder
|
|
114
|
+
*/
|
|
115
|
+
activate() {
|
|
116
|
+
if (this._type !== sdk_core_1.TransactionType.StakingActivate) {
|
|
117
|
+
throw new sdk_core_1.BuildTransactionError('Activation can only be set for a staking transaction');
|
|
118
|
+
}
|
|
119
|
+
return this.getBuilder(sdk_core_1.StakingOperationTypes.ACTIVATE);
|
|
120
|
+
}
|
|
121
|
+
/**
|
|
122
|
+
* Gets the staking unlock builder if exist, or creates a new one for this transaction and returns it
|
|
123
|
+
* requires: amount
|
|
124
|
+
*
|
|
125
|
+
* @returns {StakingBuilder} the staking builder
|
|
126
|
+
*/
|
|
127
|
+
unlock() {
|
|
128
|
+
if (this._type !== sdk_core_1.TransactionType.StakingUnlock) {
|
|
129
|
+
throw new sdk_core_1.BuildTransactionError('Unlock can only be set for Staking Unlock transactions type');
|
|
130
|
+
}
|
|
131
|
+
return this.getBuilder(sdk_core_1.StakingOperationTypes.UNLOCK);
|
|
132
|
+
}
|
|
133
|
+
/**
|
|
134
|
+
* Gets the staking unvote builder if exist, or creates a new one for this transaction and returns it
|
|
135
|
+
* requires: group, lesser, greater, amount, index
|
|
136
|
+
*
|
|
137
|
+
* @returns {StakingBuilder} the staking builder
|
|
138
|
+
*/
|
|
139
|
+
unvote() {
|
|
140
|
+
if (this._type !== sdk_core_1.TransactionType.StakingUnvote) {
|
|
141
|
+
throw new sdk_core_1.BuildTransactionError('Unvote can only be set for a staking transaction');
|
|
142
|
+
}
|
|
143
|
+
return this.getBuilder(sdk_core_1.StakingOperationTypes.UNVOTE);
|
|
144
|
+
}
|
|
145
|
+
/**
|
|
146
|
+
* Gets the staking withdraw builder if exist, or creates a new one for this transaction and returns it
|
|
147
|
+
* requires: index (unlock list)
|
|
148
|
+
*
|
|
149
|
+
* @returns {StakingBuilder} the staking builder
|
|
150
|
+
*/
|
|
151
|
+
withdraw() {
|
|
152
|
+
if (this._type !== sdk_core_1.TransactionType.StakingWithdraw) {
|
|
153
|
+
throw new sdk_core_1.BuildTransactionError('Withdraw can only be set for a staking transaction');
|
|
154
|
+
}
|
|
155
|
+
return this.getBuilder(sdk_core_1.StakingOperationTypes.WITHDRAW);
|
|
156
|
+
}
|
|
157
|
+
/** @inheritdoc */
|
|
158
|
+
transfer(data) {
|
|
159
|
+
if (this._type !== sdk_core_1.TransactionType.Send) {
|
|
160
|
+
throw new sdk_core_1.BuildTransactionError('Transfers can only be set for send transactions');
|
|
161
|
+
}
|
|
162
|
+
if (!this._transfer) {
|
|
163
|
+
this._transfer = new transferBuilder_1.TransferBuilder(data);
|
|
164
|
+
}
|
|
165
|
+
return this._transfer;
|
|
166
|
+
}
|
|
167
|
+
/**
|
|
168
|
+
* Get the appropriate builder for the selected type
|
|
169
|
+
*
|
|
170
|
+
* @param {StakingOperationTypes} type the selected type for the staking builder
|
|
171
|
+
* @returns {StakingBuilder} the staking builder for the selected type
|
|
172
|
+
*/
|
|
173
|
+
getBuilder(type) {
|
|
174
|
+
if (!this._stakingBuilder) {
|
|
175
|
+
this._stakingBuilder = new stakingBuilder_1.StakingBuilder(this._coinConfig).type(type);
|
|
176
|
+
}
|
|
177
|
+
return this._stakingBuilder;
|
|
178
|
+
}
|
|
179
|
+
getStaking() {
|
|
180
|
+
if (!this._stakingBuilder) {
|
|
181
|
+
throw new sdk_core_1.BuildTransactionError('No staking information set');
|
|
182
|
+
}
|
|
183
|
+
return this._stakingBuilder.build();
|
|
184
|
+
}
|
|
185
|
+
buildLockStakeTransaction() {
|
|
186
|
+
const stake = this.getStaking();
|
|
187
|
+
const data = this.buildBase(stake.serialize());
|
|
188
|
+
data.to = stake.address;
|
|
189
|
+
data.value = stake.amount;
|
|
190
|
+
return data;
|
|
191
|
+
}
|
|
192
|
+
buildStakingTransaction() {
|
|
193
|
+
const stake = this.getStaking();
|
|
194
|
+
const data = this.buildBase(stake.serialize());
|
|
195
|
+
data.to = stake.address;
|
|
196
|
+
return data;
|
|
197
|
+
}
|
|
198
|
+
/**
|
|
199
|
+
* The value to send along with this transaction. 0 by default
|
|
200
|
+
*
|
|
201
|
+
* @param {string} value The value to send along with this transaction
|
|
202
|
+
*/
|
|
203
|
+
value(value) {
|
|
204
|
+
this.validatePrecision(value, 'Value');
|
|
205
|
+
this._value = value;
|
|
206
|
+
}
|
|
207
|
+
validatePrecision(value, context) {
|
|
208
|
+
context = context ? context + ' ' : '';
|
|
209
|
+
const valueNumber = Number(value);
|
|
210
|
+
// the Celo library internally converts the string value to a number and converts to hex, which can result in a loss of precision for numbers with >= 15 significant digits
|
|
211
|
+
const valueBigNumber = new bignumber_js_1.default(valueNumber.toString(16), 16);
|
|
212
|
+
if (isNaN(valueNumber)) {
|
|
213
|
+
throw new sdk_core_1.BuildTransactionError(`${context}${value} is not a valid number`);
|
|
214
|
+
}
|
|
215
|
+
else if (!valueBigNumber.isEqualTo(valueNumber)) {
|
|
216
|
+
// TODO(BG-62714): remove this check once the celo library is fixed
|
|
217
|
+
throw new sdk_core_1.BuildTransactionError(`${context}${value} cannot be represented by a JS number, please try using fewer significant digits. We are working to support all values in the future.`);
|
|
218
|
+
}
|
|
219
|
+
}
|
|
220
|
+
}
|
|
221
|
+
exports.TransactionBuilder = TransactionBuilder;
|
|
222
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"transactionBuilder.js","sourceRoot":"","sources":["../../../src/lib/transactionBuilder.ts"],"names":[],"mappings":"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","sourcesContent":["import { BaseCoin as CoinConfig } from '@bitgo/statics';\nimport EthereumAbi from 'ethereumjs-abi';\nimport { Transaction } from '@bitgo/abstract-eth';\nimport { TransactionBuilder as EthTransactionBuilder, TxData, walletSimpleConstructor } from '@bitgo/sdk-coin-eth';\nimport { BuildTransactionError, TransactionType, StakingOperationTypes } from '@bitgo/sdk-core';\nimport { StakingBuilder } from './stakingBuilder';\nimport { StakingCall } from './stakingCall';\nimport { getCommon, walletSimpleByteCode } from './utils';\nimport { TransferBuilder } from './transferBuilder';\nimport BigNumber from 'bignumber.js';\n\nexport class TransactionBuilder extends EthTransactionBuilder {\n  // Staking specific parameters\n  private _stakingBuilder?: StakingBuilder;\n  protected _transfer: TransferBuilder;\n\n  constructor(_coinConfig: Readonly<CoinConfig>) {\n    super(_coinConfig);\n    this._common = getCommon(this._coinConfig.network.type);\n    this.transaction = new Transaction(this._coinConfig, this._common);\n  }\n\n  /** @inheritdoc */\n  type(type: TransactionType): void {\n    super.type(type);\n    this._stakingBuilder = undefined;\n  }\n\n  protected getTransactionData(): TxData {\n    switch (this._type) {\n      case TransactionType.StakingLock:\n        return this.buildLockStakeTransaction();\n      case TransactionType.StakingUnlock:\n      case TransactionType.StakingVote:\n      case TransactionType.StakingUnvote:\n      case TransactionType.StakingActivate:\n      case TransactionType.StakingWithdraw:\n        return this.buildStakingTransaction();\n    }\n    return super.getTransactionData();\n  }\n\n  /** @inheritdoc */\n  protected fromImplementation(rawTransaction: string): Transaction {\n    let tx: Transaction;\n    if (/^0x?[0-9a-f]{1,}$/.test(rawTransaction.toLowerCase())) {\n      tx = Transaction.fromSerialized(this._coinConfig, this._common, rawTransaction);\n      super.loadBuilderInput(tx.toJson());\n    } else {\n      const txData = JSON.parse(rawTransaction);\n      tx = new Transaction(this._coinConfig, this._common, txData);\n    }\n    return tx;\n  }\n\n  protected setTransactionTypeFields(decodedType: TransactionType, transactionJson: TxData): void {\n    switch (decodedType) {\n      case TransactionType.StakingLock:\n        this._stakingBuilder = new StakingBuilder(this._coinConfig)\n          .type(StakingOperationTypes.LOCK)\n          .amount(transactionJson.value);\n        break;\n      case TransactionType.StakingUnlock:\n      case TransactionType.StakingVote:\n      case TransactionType.StakingUnvote:\n      case TransactionType.StakingActivate:\n      case TransactionType.StakingWithdraw:\n        this._stakingBuilder = new StakingBuilder(this._coinConfig, transactionJson.data);\n        break;\n      default:\n        super.setTransactionTypeFields(decodedType, transactionJson);\n        break;\n    }\n  }\n\n  /**\n   * Returns the smart contract encoded data\n   *\n   * @param {string[]} addresses - the contract signers\n   * @returns {string} - the smart contract encoded data\n   */\n  protected getContractData(addresses: string[]): string {\n    const params = [addresses];\n    const resultEncodedParameters = EthereumAbi.rawEncode(walletSimpleConstructor, params)\n      .toString('hex')\n      .replace('0x', '');\n    return walletSimpleByteCode + resultEncodedParameters;\n  }\n\n  // region Stake methods\n\n  /**\n   * Gets the staking lock builder if exist, or creates a new one for this transaction and returns it\n   * requires: amount\n   *\n   * @returns {StakingBuilder} the staking builder\n   */\n  lock(): StakingBuilder {\n    if (this._type !== TransactionType.StakingLock) {\n      throw new BuildTransactionError('Lock can only be set for Staking Lock transactions type');\n    }\n\n    return this.getBuilder(StakingOperationTypes.LOCK);\n  }\n\n  /**\n   * Gets the staking vote builder if exist, or creates a new one for this transaction and returns it\n   * requires: group, lesser, greater, amount\n   *\n   * @returns {StakingBuilder} the staking builder\n   */\n  vote(): StakingBuilder {\n    if (this._type !== TransactionType.StakingVote) {\n      throw new BuildTransactionError('Votes can only be set for a staking transaction');\n    }\n\n    return this.getBuilder(StakingOperationTypes.VOTE);\n  }\n\n  /**\n   * Gets the staking activate builder if exist, or creates a new one for this transaction and returns it\n   * requires: group\n   *\n   * @returns {StakingBuilder} the staking builder\n   */\n  activate(): StakingBuilder {\n    if (this._type !== TransactionType.StakingActivate) {\n      throw new BuildTransactionError('Activation can only be set for a staking transaction');\n    }\n\n    return this.getBuilder(StakingOperationTypes.ACTIVATE);\n  }\n\n  /**\n   * Gets the staking unlock builder if exist, or creates a new one for this transaction and returns it\n   * requires: amount\n   *\n   * @returns {StakingBuilder} the staking builder\n   */\n  unlock(): StakingBuilder {\n    if (this._type !== TransactionType.StakingUnlock) {\n      throw new BuildTransactionError('Unlock can only be set for Staking Unlock transactions type');\n    }\n\n    return this.getBuilder(StakingOperationTypes.UNLOCK);\n  }\n\n  /**\n   * Gets the staking unvote builder if exist, or creates a new one for this transaction and returns it\n   * requires: group, lesser, greater, amount, index\n   *\n   * @returns {StakingBuilder} the staking builder\n   */\n  unvote(): StakingBuilder {\n    if (this._type !== TransactionType.StakingUnvote) {\n      throw new BuildTransactionError('Unvote can only be set for a staking transaction');\n    }\n\n    return this.getBuilder(StakingOperationTypes.UNVOTE);\n  }\n\n  /**\n   * Gets the staking withdraw builder if exist, or creates a new one for this transaction and returns it\n   * requires: index (unlock list)\n   *\n   * @returns {StakingBuilder} the staking builder\n   */\n  withdraw(): StakingBuilder {\n    if (this._type !== TransactionType.StakingWithdraw) {\n      throw new BuildTransactionError('Withdraw can only be set for a staking transaction');\n    }\n\n    return this.getBuilder(StakingOperationTypes.WITHDRAW);\n  }\n\n  /** @inheritdoc */\n  transfer(data?: string): TransferBuilder {\n    if (this._type !== TransactionType.Send) {\n      throw new BuildTransactionError('Transfers can only be set for send transactions');\n    }\n    if (!this._transfer) {\n      this._transfer = new TransferBuilder(data);\n    }\n    return this._transfer;\n  }\n\n  /**\n   * Get the appropriate builder for the selected type\n   *\n   * @param {StakingOperationTypes} type the selected type for the staking builder\n   * @returns {StakingBuilder} the staking builder for the selected type\n   */\n  private getBuilder(type: StakingOperationTypes): StakingBuilder {\n    if (!this._stakingBuilder) {\n      this._stakingBuilder = new StakingBuilder(this._coinConfig).type(type);\n    }\n\n    return this._stakingBuilder;\n  }\n\n  private getStaking(): StakingCall {\n    if (!this._stakingBuilder) {\n      throw new BuildTransactionError('No staking information set');\n    }\n    return this._stakingBuilder.build();\n  }\n\n  private buildLockStakeTransaction(): TxData {\n    const stake = this.getStaking();\n    const data = this.buildBase(stake.serialize());\n    data.to = stake.address;\n    data.value = stake.amount;\n\n    return data;\n  }\n\n  private buildStakingTransaction(): TxData {\n    const stake = this.getStaking();\n    const data = this.buildBase(stake.serialize());\n    data.to = stake.address;\n\n    return data;\n  }\n\n  /**\n   * The value to send along with this transaction. 0 by default\n   *\n   * @param {string} value The value to send along with this transaction\n   */\n  value(value: string): void {\n    this.validatePrecision(value, 'Value');\n    this._value = value;\n  }\n\n  validatePrecision(value: string, context?: string): void {\n    context = context ? context + ' ' : '';\n    const valueNumber = Number(value);\n    // the Celo library internally converts the string value to a number and converts to hex, which can result in a loss of precision for numbers with >= 15 significant digits\n    const valueBigNumber = new BigNumber(valueNumber.toString(16), 16);\n    if (isNaN(valueNumber)) {\n      throw new BuildTransactionError(`${context}${value} is not a valid number`);\n    } else if (!valueBigNumber.isEqualTo(valueNumber)) {\n      // TODO(BG-62714): remove this check once the celo library is fixed\n      throw new BuildTransactionError(\n        `${context}${value} cannot be represented by a JS number, please try using fewer significant digits. We are working to support all values in the future.`\n      );\n    }\n  }\n  // endregion\n}\n"]}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import { TransferBuilder as EthTransferBuilder } from '@bitgo/sdk-coin-eth';
|
|
2
|
+
/** CELO transfer builder */
|
|
3
|
+
export declare class TransferBuilder extends EthTransferBuilder {
|
|
4
|
+
/**
|
|
5
|
+
* Get the prefix used in generating an operation hash for sending tokens
|
|
6
|
+
* See https://github.com/BitGo/eth-multisig-v2/blob/master/contracts/coins/CeloWalletSimple.sol
|
|
7
|
+
*
|
|
8
|
+
* @returns the string prefix
|
|
9
|
+
*/
|
|
10
|
+
protected getTokenOperationHashPrefix(): string;
|
|
11
|
+
/**
|
|
12
|
+
* Get the prefix used in generating an operation hash for sending native coins
|
|
13
|
+
* See https://github.com/BitGo/eth-multisig-v2/blob/master/contracts/coins/CeloWalletSimple.sol
|
|
14
|
+
*
|
|
15
|
+
* @returns the string prefix
|
|
16
|
+
*/
|
|
17
|
+
protected getNativeOperationHashPrefix(): string;
|
|
18
|
+
}
|
|
19
|
+
//# 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,eAAe,IAAI,kBAAkB,EAAE,MAAM,qBAAqB,CAAC;AAE5E,4BAA4B;AAC5B,qBAAa,eAAgB,SAAQ,kBAAkB;IACrD;;;;;OAKG;IACH,SAAS,CAAC,2BAA2B,IAAI,MAAM;IAI/C;;;;;OAKG;IACH,SAAS,CAAC,4BAA4B,IAAI,MAAM;CAGjD"}
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.TransferBuilder = void 0;
|
|
4
|
+
const sdk_coin_eth_1 = require("@bitgo/sdk-coin-eth");
|
|
5
|
+
/** CELO transfer builder */
|
|
6
|
+
class TransferBuilder extends sdk_coin_eth_1.TransferBuilder {
|
|
7
|
+
/**
|
|
8
|
+
* Get the prefix used in generating an operation hash for sending tokens
|
|
9
|
+
* See https://github.com/BitGo/eth-multisig-v2/blob/master/contracts/coins/CeloWalletSimple.sol
|
|
10
|
+
*
|
|
11
|
+
* @returns the string prefix
|
|
12
|
+
*/
|
|
13
|
+
getTokenOperationHashPrefix() {
|
|
14
|
+
return 'CELO-ERC20';
|
|
15
|
+
}
|
|
16
|
+
/**
|
|
17
|
+
* Get the prefix used in generating an operation hash for sending native coins
|
|
18
|
+
* See https://github.com/BitGo/eth-multisig-v2/blob/master/contracts/coins/CeloWalletSimple.sol
|
|
19
|
+
*
|
|
20
|
+
* @returns the string prefix
|
|
21
|
+
*/
|
|
22
|
+
getNativeOperationHashPrefix() {
|
|
23
|
+
return 'CELO';
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
exports.TransferBuilder = TransferBuilder;
|
|
27
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJhbnNmZXJCdWlsZGVyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2xpYi90cmFuc2ZlckJ1aWxkZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQUEsc0RBQTRFO0FBRTVFLDRCQUE0QjtBQUM1QixNQUFhLGVBQWdCLFNBQVEsOEJBQWtCO0lBQ3JEOzs7OztPQUtHO0lBQ08sMkJBQTJCO1FBQ25DLE9BQU8sWUFBWSxDQUFDO0lBQ3RCLENBQUM7SUFFRDs7Ozs7T0FLRztJQUNPLDRCQUE0QjtRQUNwQyxPQUFPLE1BQU0sQ0FBQztJQUNoQixDQUFDO0NBQ0Y7QUFwQkQsMENBb0JDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgVHJhbnNmZXJCdWlsZGVyIGFzIEV0aFRyYW5zZmVyQnVpbGRlciB9IGZyb20gJ0BiaXRnby9zZGstY29pbi1ldGgnO1xuXG4vKiogQ0VMTyB0cmFuc2ZlciBidWlsZGVyICovXG5leHBvcnQgY2xhc3MgVHJhbnNmZXJCdWlsZGVyIGV4dGVuZHMgRXRoVHJhbnNmZXJCdWlsZGVyIHtcbiAgLyoqXG4gICAqIEdldCB0aGUgcHJlZml4IHVzZWQgaW4gZ2VuZXJhdGluZyBhbiBvcGVyYXRpb24gaGFzaCBmb3Igc2VuZGluZyB0b2tlbnNcbiAgICogU2VlIGh0dHBzOi8vZ2l0aHViLmNvbS9CaXRHby9ldGgtbXVsdGlzaWctdjIvYmxvYi9tYXN0ZXIvY29udHJhY3RzL2NvaW5zL0NlbG9XYWxsZXRTaW1wbGUuc29sXG4gICAqXG4gICAqIEByZXR1cm5zIHRoZSBzdHJpbmcgcHJlZml4XG4gICAqL1xuICBwcm90ZWN0ZWQgZ2V0VG9rZW5PcGVyYXRpb25IYXNoUHJlZml4KCk6IHN0cmluZyB7XG4gICAgcmV0dXJuICdDRUxPLUVSQzIwJztcbiAgfVxuXG4gIC8qKlxuICAgKiBHZXQgdGhlIHByZWZpeCB1c2VkIGluIGdlbmVyYXRpbmcgYW4gb3BlcmF0aW9uIGhhc2ggZm9yIHNlbmRpbmcgbmF0aXZlIGNvaW5zXG4gICAqIFNlZSBodHRwczovL2dpdGh1Yi5jb20vQml0R28vZXRoLW11bHRpc2lnLXYyL2Jsb2IvbWFzdGVyL2NvbnRyYWN0cy9jb2lucy9DZWxvV2FsbGV0U2ltcGxlLnNvbFxuICAgKlxuICAgKiBAcmV0dXJucyB0aGUgc3RyaW5nIHByZWZpeFxuICAgKi9cbiAgcHJvdGVjdGVkIGdldE5hdGl2ZU9wZXJhdGlvbkhhc2hQcmVmaXgoKTogc3RyaW5nIHtcbiAgICByZXR1cm4gJ0NFTE8nO1xuICB9XG59XG4iXX0=
|
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
import { EthLikeTransactionData, KeyPair, LegacyTxData } from '@bitgo/sdk-coin-eth';
|
|
2
|
+
export declare class CeloTransaction {
|
|
3
|
+
private raw;
|
|
4
|
+
private _from;
|
|
5
|
+
private _senderPubKey?;
|
|
6
|
+
private _signatures;
|
|
7
|
+
private _feeCurrency;
|
|
8
|
+
private _gatewayFeeRecipient;
|
|
9
|
+
private _gatewayFee;
|
|
10
|
+
nonce: Buffer;
|
|
11
|
+
gasLimit: Buffer;
|
|
12
|
+
gasPrice: Buffer;
|
|
13
|
+
data: Buffer;
|
|
14
|
+
value: Buffer;
|
|
15
|
+
to: Buffer;
|
|
16
|
+
v: Buffer;
|
|
17
|
+
r: Buffer;
|
|
18
|
+
s: Buffer;
|
|
19
|
+
/**
|
|
20
|
+
* Clean hex formatted values ensuring they have an even length
|
|
21
|
+
*
|
|
22
|
+
* @param numberValue Hex formatted number value. Example '0x01'
|
|
23
|
+
* @returns sanitized value
|
|
24
|
+
*/
|
|
25
|
+
private sanitizeHexString;
|
|
26
|
+
constructor(tx: LegacyTxData);
|
|
27
|
+
private initRaw;
|
|
28
|
+
hash(includeSignature?: boolean): Buffer;
|
|
29
|
+
getSenderAddress(): Buffer;
|
|
30
|
+
getSenderPublicKey(): any;
|
|
31
|
+
serialize(): Buffer;
|
|
32
|
+
sign(privateKey: Buffer): void;
|
|
33
|
+
verifySignature(): boolean;
|
|
34
|
+
getChainId(): number;
|
|
35
|
+
}
|
|
36
|
+
export declare class CeloTransactionData implements EthLikeTransactionData {
|
|
37
|
+
private tx;
|
|
38
|
+
private deployedAddress?;
|
|
39
|
+
constructor(tx: CeloTransaction, deployedAddress?: string);
|
|
40
|
+
static fromJson(tx: LegacyTxData): CeloTransactionData;
|
|
41
|
+
sign(keyPair: KeyPair): Promise<void>;
|
|
42
|
+
/** @inheritdoc */
|
|
43
|
+
toJson(): LegacyTxData;
|
|
44
|
+
private setSignatureFields;
|
|
45
|
+
/** @inheritdoc */
|
|
46
|
+
toSerialized(): string;
|
|
47
|
+
private static txJsonToCeloTx;
|
|
48
|
+
private static encodedTxToJson;
|
|
49
|
+
}
|
|
50
|
+
//# sourceMappingURL=types.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../src/lib/types.ts"],"names":[],"mappings":"AAcA,OAAO,EAAE,sBAAsB,EAAsB,OAAO,EAAE,YAAY,EAAE,MAAM,qBAAqB,CAAC;AAExG,qBAAa,eAAe;IAC1B,OAAO,CAAC,GAAG,CAAW;IACtB,OAAO,CAAC,KAAK,CAAS;IACtB,OAAO,CAAC,aAAa,CAAC,CAAC;IACvB,OAAO,CAAC,WAAW,CAAW;IAC9B,OAAO,CAAC,YAAY,CAA0B;IAC9C,OAAO,CAAC,oBAAoB,CAA0B;IACtD,OAAO,CAAC,WAAW,CAA0B;IAC7C,KAAK,EAAE,MAAM,CAAC;IACd,QAAQ,EAAE,MAAM,CAAC;IACjB,QAAQ,EAAE,MAAM,CAAC;IACjB,IAAI,EAAE,MAAM,CAAC;IACb,KAAK,EAAE,MAAM,CAAC;IACd,EAAE,EAAE,MAAM,CAAgB;IAC1B,CAAC,EAAE,MAAM,CAAgB;IACzB,CAAC,EAAE,MAAM,CAAgB;IACzB,CAAC,EAAE,MAAM,CAAgB;IAGzB;;;;;OAKG;IACH,OAAO,CAAC,iBAAiB;gBASb,EAAE,EAAE,YAAY;IAwB5B,OAAO,CAAC,OAAO;IAiBf,IAAI,CAAC,gBAAgB,CAAC,EAAE,OAAO,GAAG,MAAM;IAYxC,gBAAgB,IAAI,MAAM;IAS1B,kBAAkB;IAQlB,SAAS,IAAI,MAAM;IAInB,IAAI,CAAC,UAAU,EAAE,MAAM,GAAG,IAAI;IAI9B,eAAe,IAAI,OAAO;IAY1B,UAAU,IAAI,MAAM;CAOrB;AAED,qBAAa,mBAAoB,YAAW,sBAAsB;IAChE,OAAO,CAAC,EAAE,CAAkB;IAC5B,OAAO,CAAC,eAAe,CAAC,CAAS;gBAErB,EAAE,EAAE,eAAe,EAAE,eAAe,CAAC,EAAE,MAAM;WAK3C,QAAQ,CAAC,EAAE,EAAE,YAAY,GAAG,mBAAmB;IAoBvD,IAAI,CAAC,OAAO,EAAE,OAAO;IAe3B,kBAAkB;IAClB,MAAM,IAAI,YAAY;IAiCtB,OAAO,CAAC,kBAAkB;IAc1B,kBAAkB;IAClB,YAAY,IAAI,MAAM;IAItB,OAAO,CAAC,MAAM,CAAC,cAAc;IAS7B,OAAO,CAAC,MAAM,CAAC,eAAe;CAS/B"}
|
|
@@ -0,0 +1,223 @@
|
|
|
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.CeloTransactionData = exports.CeloTransaction = void 0;
|
|
7
|
+
const bignumber_js_1 = __importDefault(require("bignumber.js"));
|
|
8
|
+
const wallet_local_1 = require("@celo/wallet-local");
|
|
9
|
+
const ethereumjs_util_1 = require("ethereumjs-util");
|
|
10
|
+
const sdk_coin_eth_1 = require("@bitgo/sdk-coin-eth");
|
|
11
|
+
class CeloTransaction {
|
|
12
|
+
// TODO: validate if this needs to be moved to Utils class
|
|
13
|
+
/**
|
|
14
|
+
* Clean hex formatted values ensuring they have an even length
|
|
15
|
+
*
|
|
16
|
+
* @param numberValue Hex formatted number value. Example '0x01'
|
|
17
|
+
* @returns sanitized value
|
|
18
|
+
*/
|
|
19
|
+
sanitizeHexString(numberValue) {
|
|
20
|
+
if (numberValue === '0x0' || numberValue == '') {
|
|
21
|
+
return '0x';
|
|
22
|
+
}
|
|
23
|
+
else if (numberValue.length % 2 === 0) {
|
|
24
|
+
return numberValue;
|
|
25
|
+
}
|
|
26
|
+
return '0x0' + numberValue.slice(2);
|
|
27
|
+
}
|
|
28
|
+
constructor(tx) {
|
|
29
|
+
this._feeCurrency = (0, ethereumjs_util_1.toBuffer)('0x');
|
|
30
|
+
this._gatewayFeeRecipient = (0, ethereumjs_util_1.toBuffer)('0x');
|
|
31
|
+
this._gatewayFee = (0, ethereumjs_util_1.toBuffer)('0x');
|
|
32
|
+
this.to = (0, ethereumjs_util_1.toBuffer)([]);
|
|
33
|
+
this.v = (0, ethereumjs_util_1.toBuffer)([]);
|
|
34
|
+
this.r = (0, ethereumjs_util_1.toBuffer)([]);
|
|
35
|
+
this.s = (0, ethereumjs_util_1.toBuffer)([]);
|
|
36
|
+
this.nonce = (0, ethereumjs_util_1.unpadBuffer)((0, ethereumjs_util_1.toBuffer)(tx.nonce));
|
|
37
|
+
this.gasLimit = (0, ethereumjs_util_1.toBuffer)(this.sanitizeHexString(tx.gasLimit));
|
|
38
|
+
this.gasPrice = (0, ethereumjs_util_1.toBuffer)(this.sanitizeHexString(tx.gasPrice));
|
|
39
|
+
this.data = (0, ethereumjs_util_1.toBuffer)(this.sanitizeHexString(tx.data));
|
|
40
|
+
this.value = (0, ethereumjs_util_1.toBuffer)(this.sanitizeHexString(tx.value));
|
|
41
|
+
if (tx.to) {
|
|
42
|
+
this.to = (0, ethereumjs_util_1.toBuffer)(tx.to);
|
|
43
|
+
}
|
|
44
|
+
if (tx.v) {
|
|
45
|
+
this.v = (0, ethereumjs_util_1.toBuffer)(tx.v);
|
|
46
|
+
}
|
|
47
|
+
if (tx.r) {
|
|
48
|
+
this.r = (0, ethereumjs_util_1.toBuffer)(tx.r);
|
|
49
|
+
}
|
|
50
|
+
if (tx.s) {
|
|
51
|
+
this.s = (0, ethereumjs_util_1.toBuffer)(tx.s);
|
|
52
|
+
}
|
|
53
|
+
if (tx.from) {
|
|
54
|
+
this._from = (0, ethereumjs_util_1.toBuffer)(tx.from);
|
|
55
|
+
}
|
|
56
|
+
this.initRaw();
|
|
57
|
+
}
|
|
58
|
+
initRaw() {
|
|
59
|
+
this.raw = [
|
|
60
|
+
this.nonce,
|
|
61
|
+
this.gasPrice,
|
|
62
|
+
this.gasLimit,
|
|
63
|
+
this._feeCurrency,
|
|
64
|
+
this._gatewayFeeRecipient,
|
|
65
|
+
this._gatewayFee,
|
|
66
|
+
this.to,
|
|
67
|
+
this.value,
|
|
68
|
+
this.data,
|
|
69
|
+
this.v,
|
|
70
|
+
this.r,
|
|
71
|
+
this.s,
|
|
72
|
+
];
|
|
73
|
+
}
|
|
74
|
+
hash(includeSignature) {
|
|
75
|
+
let items;
|
|
76
|
+
if (includeSignature) {
|
|
77
|
+
items = this.raw;
|
|
78
|
+
}
|
|
79
|
+
else {
|
|
80
|
+
items = this.raw
|
|
81
|
+
.slice(0, 9)
|
|
82
|
+
.concat([(0, ethereumjs_util_1.toBuffer)(this.getChainId()), (0, ethereumjs_util_1.unpadBuffer)((0, ethereumjs_util_1.toBuffer)(0)), (0, ethereumjs_util_1.unpadBuffer)((0, ethereumjs_util_1.toBuffer)(0))]);
|
|
83
|
+
}
|
|
84
|
+
return (0, ethereumjs_util_1.rlphash)(items);
|
|
85
|
+
}
|
|
86
|
+
getSenderAddress() {
|
|
87
|
+
if (this._from) {
|
|
88
|
+
return this._from;
|
|
89
|
+
}
|
|
90
|
+
const pubKey = this.getSenderPublicKey();
|
|
91
|
+
this._from = (0, ethereumjs_util_1.publicToAddress)(pubKey);
|
|
92
|
+
return this._from;
|
|
93
|
+
}
|
|
94
|
+
getSenderPublicKey() {
|
|
95
|
+
if (this.verifySignature()) {
|
|
96
|
+
// If the signature was verified successfully the _senderPubKey field is defined
|
|
97
|
+
return this._senderPubKey;
|
|
98
|
+
}
|
|
99
|
+
throw new Error('Invalid Signature');
|
|
100
|
+
}
|
|
101
|
+
serialize() {
|
|
102
|
+
return ethereumjs_util_1.rlp.encode(this.raw);
|
|
103
|
+
}
|
|
104
|
+
sign(privateKey) {
|
|
105
|
+
this._signatures = [this.v, this.r, this.s, privateKey];
|
|
106
|
+
}
|
|
107
|
+
verifySignature() {
|
|
108
|
+
const msgHash = this.hash(false);
|
|
109
|
+
try {
|
|
110
|
+
const chainId = this.getChainId();
|
|
111
|
+
const v = (0, ethereumjs_util_1.bufferToInt)(this.v) - (2 * chainId + 35);
|
|
112
|
+
this._senderPubKey = (0, ethereumjs_util_1.ecrecover)(msgHash, v + 27, this.r, this.s);
|
|
113
|
+
}
|
|
114
|
+
catch (e) {
|
|
115
|
+
return false;
|
|
116
|
+
}
|
|
117
|
+
return !!this._senderPubKey;
|
|
118
|
+
}
|
|
119
|
+
getChainId() {
|
|
120
|
+
let chainId = (0, ethereumjs_util_1.bufferToInt)(this.v);
|
|
121
|
+
if (this.r.length && this.s.length) {
|
|
122
|
+
chainId = (chainId - 35) >> 1;
|
|
123
|
+
}
|
|
124
|
+
return chainId;
|
|
125
|
+
}
|
|
126
|
+
}
|
|
127
|
+
exports.CeloTransaction = CeloTransaction;
|
|
128
|
+
class CeloTransactionData {
|
|
129
|
+
constructor(tx, deployedAddress) {
|
|
130
|
+
this.tx = tx;
|
|
131
|
+
this.deployedAddress = deployedAddress;
|
|
132
|
+
}
|
|
133
|
+
static fromJson(tx) {
|
|
134
|
+
const chainId = (0, ethereumjs_util_1.addHexPrefix)(new bignumber_js_1.default(Number(tx.chainId)).toString(16));
|
|
135
|
+
return new CeloTransactionData(new CeloTransaction({
|
|
136
|
+
_type: sdk_coin_eth_1.ETHTransactionType.LEGACY,
|
|
137
|
+
nonce: tx.nonce,
|
|
138
|
+
to: tx.to,
|
|
139
|
+
gasPrice: (0, ethereumjs_util_1.addHexPrefix)(new bignumber_js_1.default(tx.gasPrice).toString(16)),
|
|
140
|
+
gasLimit: (0, ethereumjs_util_1.addHexPrefix)(new bignumber_js_1.default(tx.gasLimit).toString(16)),
|
|
141
|
+
value: (0, ethereumjs_util_1.addHexPrefix)(new bignumber_js_1.default(tx.value).toString(16)),
|
|
142
|
+
data: tx.data === '0x' ? '' : tx.data,
|
|
143
|
+
from: tx.from,
|
|
144
|
+
s: tx.s,
|
|
145
|
+
r: tx.r,
|
|
146
|
+
v: tx.v || chainId,
|
|
147
|
+
}), tx.deployedAddress);
|
|
148
|
+
}
|
|
149
|
+
async sign(keyPair) {
|
|
150
|
+
const privateKey = (0, ethereumjs_util_1.addHexPrefix)(keyPair.getKeys().prv);
|
|
151
|
+
const data = CeloTransactionData.txJsonToCeloTx(this.toJson(), keyPair.getAddress());
|
|
152
|
+
const celoLocalWallet = new wallet_local_1.LocalWallet();
|
|
153
|
+
celoLocalWallet.addAccount(privateKey);
|
|
154
|
+
const rawTransaction = await celoLocalWallet.signTransaction(data);
|
|
155
|
+
const nonceBigNumber = new bignumber_js_1.default(rawTransaction.tx.nonce);
|
|
156
|
+
rawTransaction.tx.nonce = (0, ethereumjs_util_1.addHexPrefix)(nonceBigNumber.toString(16));
|
|
157
|
+
rawTransaction.raw = data.data === undefined ? '' : data.data;
|
|
158
|
+
rawTransaction.tx.gas = rawTransaction.tx.gas;
|
|
159
|
+
this.tx = new CeloTransaction(CeloTransactionData.encodedTxToJson(rawTransaction));
|
|
160
|
+
this.tx.sign((0, ethereumjs_util_1.toBuffer)(privateKey));
|
|
161
|
+
}
|
|
162
|
+
/** @inheritdoc */
|
|
163
|
+
toJson() {
|
|
164
|
+
const result = {
|
|
165
|
+
_type: sdk_coin_eth_1.ETHTransactionType.LEGACY,
|
|
166
|
+
nonce: (0, ethereumjs_util_1.bufferToInt)(this.tx.nonce),
|
|
167
|
+
gasPrice: new bignumber_js_1.default((0, ethereumjs_util_1.bufferToHex)(this.tx.gasPrice), 16).toString(10),
|
|
168
|
+
gasLimit: new bignumber_js_1.default((0, ethereumjs_util_1.bufferToHex)(this.tx.gasLimit), 16).toString(10),
|
|
169
|
+
value: this.tx.value.length === 0 ? '0' : new bignumber_js_1.default((0, ethereumjs_util_1.bufferToHex)(this.tx.value), 16).toString(10),
|
|
170
|
+
data: (0, ethereumjs_util_1.bufferToHex)(this.tx.data),
|
|
171
|
+
id: (0, ethereumjs_util_1.addHexPrefix)((0, ethereumjs_util_1.bufferToHex)(this.tx.hash(true))),
|
|
172
|
+
};
|
|
173
|
+
if (this.tx.to && this.tx.to.length) {
|
|
174
|
+
result.to = (0, ethereumjs_util_1.bufferToHex)(this.tx.to);
|
|
175
|
+
}
|
|
176
|
+
if (this.tx.verifySignature()) {
|
|
177
|
+
result.from = (0, ethereumjs_util_1.bufferToHex)(this.tx.getSenderAddress());
|
|
178
|
+
}
|
|
179
|
+
const chainId = this.tx.getChainId();
|
|
180
|
+
if (chainId) {
|
|
181
|
+
result.chainId = chainId.toString();
|
|
182
|
+
}
|
|
183
|
+
if (this.deployedAddress) {
|
|
184
|
+
result.deployedAddress = this.deployedAddress;
|
|
185
|
+
}
|
|
186
|
+
this.setSignatureFields(result);
|
|
187
|
+
return result;
|
|
188
|
+
}
|
|
189
|
+
setSignatureFields(result) {
|
|
190
|
+
if (this.tx.v && this.tx.v.length) {
|
|
191
|
+
result.v = (0, ethereumjs_util_1.bufferToHex)(this.tx.v);
|
|
192
|
+
}
|
|
193
|
+
if (this.tx.r && this.tx.r.length) {
|
|
194
|
+
result.r = (0, ethereumjs_util_1.bufferToHex)(this.tx.r);
|
|
195
|
+
}
|
|
196
|
+
if (this.tx.s && this.tx.s.length) {
|
|
197
|
+
result.s = (0, ethereumjs_util_1.bufferToHex)(this.tx.s);
|
|
198
|
+
}
|
|
199
|
+
}
|
|
200
|
+
/** @inheritdoc */
|
|
201
|
+
toSerialized() {
|
|
202
|
+
return (0, ethereumjs_util_1.addHexPrefix)(this.tx.serialize().toString('hex'));
|
|
203
|
+
}
|
|
204
|
+
static txJsonToCeloTx(txJson, signer) {
|
|
205
|
+
// the celo library requires you to specify the signer address with the from field
|
|
206
|
+
return Object.assign({}, txJson, {
|
|
207
|
+
chainId: txJson.chainId === undefined ? 0 : parseInt(txJson.chainId, 10),
|
|
208
|
+
gas: txJson.gasLimit,
|
|
209
|
+
from: signer,
|
|
210
|
+
});
|
|
211
|
+
}
|
|
212
|
+
static encodedTxToJson(encodedTx) {
|
|
213
|
+
return {
|
|
214
|
+
...encodedTx.tx,
|
|
215
|
+
_type: sdk_coin_eth_1.ETHTransactionType.LEGACY,
|
|
216
|
+
nonce: parseInt(encodedTx.tx.nonce, 16),
|
|
217
|
+
gasLimit: encodedTx.tx.gas,
|
|
218
|
+
data: encodedTx.raw,
|
|
219
|
+
};
|
|
220
|
+
}
|
|
221
|
+
}
|
|
222
|
+
exports.CeloTransactionData = CeloTransactionData;
|
|
223
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../src/lib/types.ts"],"names":[],"mappings":"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","sourcesContent":["import BigNumber from 'bignumber.js';\nimport { LocalWallet } from '@celo/wallet-local';\nimport {\n  addHexPrefix,\n  toBuffer,\n  bufferToHex,\n  bufferToInt,\n  rlp,\n  rlphash,\n  ecrecover,\n  publicToAddress,\n  unpadBuffer,\n} from 'ethereumjs-util';\nimport { CeloTx, EncodedTransaction } from '@celo/connect';\nimport { EthLikeTransactionData, ETHTransactionType, KeyPair, LegacyTxData } from '@bitgo/sdk-coin-eth';\n\nexport class CeloTransaction {\n  private raw: Buffer[];\n  private _from: Buffer;\n  private _senderPubKey?;\n  private _signatures: Buffer[];\n  private _feeCurrency: Buffer = toBuffer('0x');\n  private _gatewayFeeRecipient: Buffer = toBuffer('0x');\n  private _gatewayFee: Buffer = toBuffer('0x');\n  nonce: Buffer;\n  gasLimit: Buffer;\n  gasPrice: Buffer;\n  data: Buffer;\n  value: Buffer;\n  to: Buffer = toBuffer([]);\n  v: Buffer = toBuffer([]);\n  r: Buffer = toBuffer([]);\n  s: Buffer = toBuffer([]);\n\n  // TODO: validate if this needs to be moved to Utils class\n  /**\n   * Clean hex formatted values ensuring they have an even length\n   *\n   * @param numberValue Hex formatted number value. Example '0x01'\n   * @returns sanitized value\n   */\n  private sanitizeHexString(numberValue) {\n    if (numberValue === '0x0' || numberValue == '') {\n      return '0x';\n    } else if (numberValue.length % 2 === 0) {\n      return numberValue;\n    }\n    return '0x0' + numberValue.slice(2);\n  }\n\n  constructor(tx: LegacyTxData) {\n    this.nonce = unpadBuffer(toBuffer(tx.nonce));\n    this.gasLimit = toBuffer(this.sanitizeHexString(tx.gasLimit));\n    this.gasPrice = toBuffer(this.sanitizeHexString(tx.gasPrice));\n    this.data = toBuffer(this.sanitizeHexString(tx.data));\n    this.value = toBuffer(this.sanitizeHexString(tx.value));\n    if (tx.to) {\n      this.to = toBuffer(tx.to);\n    }\n    if (tx.v) {\n      this.v = toBuffer(tx.v);\n    }\n    if (tx.r) {\n      this.r = toBuffer(tx.r);\n    }\n    if (tx.s) {\n      this.s = toBuffer(tx.s);\n    }\n    if (tx.from) {\n      this._from = toBuffer(tx.from);\n    }\n    this.initRaw();\n  }\n\n  private initRaw() {\n    this.raw = [\n      this.nonce,\n      this.gasPrice,\n      this.gasLimit,\n      this._feeCurrency,\n      this._gatewayFeeRecipient,\n      this._gatewayFee,\n      this.to,\n      this.value,\n      this.data,\n      this.v,\n      this.r,\n      this.s,\n    ];\n  }\n\n  hash(includeSignature?: boolean): Buffer {\n    let items;\n    if (includeSignature) {\n      items = this.raw;\n    } else {\n      items = this.raw\n        .slice(0, 9)\n        .concat([toBuffer(this.getChainId()), unpadBuffer(toBuffer(0)), unpadBuffer(toBuffer(0))]);\n    }\n    return rlphash(items);\n  }\n\n  getSenderAddress(): Buffer {\n    if (this._from) {\n      return this._from;\n    }\n    const pubKey = this.getSenderPublicKey();\n    this._from = publicToAddress(pubKey);\n    return this._from;\n  }\n\n  getSenderPublicKey() {\n    if (this.verifySignature()) {\n      // If the signature was verified successfully the _senderPubKey field is defined\n      return this._senderPubKey;\n    }\n    throw new Error('Invalid Signature');\n  }\n\n  serialize(): Buffer {\n    return rlp.encode(this.raw);\n  }\n\n  sign(privateKey: Buffer): void {\n    this._signatures = [this.v, this.r, this.s, privateKey];\n  }\n\n  verifySignature(): boolean {\n    const msgHash = this.hash(false);\n    try {\n      const chainId = this.getChainId();\n      const v = bufferToInt(this.v) - (2 * chainId + 35);\n      this._senderPubKey = ecrecover(msgHash, v + 27, this.r, this.s);\n    } catch (e) {\n      return false;\n    }\n    return !!this._senderPubKey;\n  }\n\n  getChainId(): number {\n    let chainId = bufferToInt(this.v);\n    if (this.r.length && this.s.length) {\n      chainId = (chainId - 35) >> 1;\n    }\n    return chainId;\n  }\n}\n\nexport class CeloTransactionData implements EthLikeTransactionData {\n  private tx: CeloTransaction;\n  private deployedAddress?: string;\n\n  constructor(tx: CeloTransaction, deployedAddress?: string) {\n    this.tx = tx;\n    this.deployedAddress = deployedAddress;\n  }\n\n  public static fromJson(tx: LegacyTxData): CeloTransactionData {\n    const chainId = addHexPrefix(new BigNumber(Number(tx.chainId)).toString(16));\n    return new CeloTransactionData(\n      new CeloTransaction({\n        _type: ETHTransactionType.LEGACY,\n        nonce: tx.nonce,\n        to: tx.to,\n        gasPrice: addHexPrefix(new BigNumber(tx.gasPrice).toString(16)),\n        gasLimit: addHexPrefix(new BigNumber(tx.gasLimit).toString(16)),\n        value: addHexPrefix(new BigNumber(tx.value).toString(16)),\n        data: tx.data === '0x' ? '' : tx.data,\n        from: tx.from,\n        s: tx.s,\n        r: tx.r,\n        v: tx.v || chainId,\n      }),\n      tx.deployedAddress\n    );\n  }\n\n  async sign(keyPair: KeyPair) {\n    const privateKey = addHexPrefix(keyPair.getKeys().prv as string);\n    const data = CeloTransactionData.txJsonToCeloTx(this.toJson(), keyPair.getAddress());\n    const celoLocalWallet = new LocalWallet();\n    celoLocalWallet.addAccount(privateKey);\n    const rawTransaction = await celoLocalWallet.signTransaction(data);\n\n    const nonceBigNumber = new BigNumber(rawTransaction.tx.nonce);\n    rawTransaction.tx.nonce = addHexPrefix(nonceBigNumber.toString(16));\n    rawTransaction.raw = data.data === undefined ? '' : data.data;\n    rawTransaction.tx.gas = rawTransaction.tx.gas;\n    this.tx = new CeloTransaction(CeloTransactionData.encodedTxToJson(rawTransaction));\n    this.tx.sign(toBuffer(privateKey));\n  }\n\n  /** @inheritdoc */\n  toJson(): LegacyTxData {\n    const result: LegacyTxData = {\n      _type: ETHTransactionType.LEGACY,\n      nonce: bufferToInt(this.tx.nonce),\n      gasPrice: new BigNumber(bufferToHex(this.tx.gasPrice), 16).toString(10),\n      gasLimit: new BigNumber(bufferToHex(this.tx.gasLimit), 16).toString(10),\n      value: this.tx.value.length === 0 ? '0' : new BigNumber(bufferToHex(this.tx.value), 16).toString(10),\n      data: bufferToHex(this.tx.data),\n      id: addHexPrefix(bufferToHex(this.tx.hash(true))),\n    };\n\n    if (this.tx.to && this.tx.to.length) {\n      result.to = bufferToHex(this.tx.to);\n    }\n\n    if (this.tx.verifySignature()) {\n      result.from = bufferToHex(this.tx.getSenderAddress());\n    }\n\n    const chainId = this.tx.getChainId();\n    if (chainId) {\n      result.chainId = chainId.toString();\n    }\n\n    if (this.deployedAddress) {\n      result.deployedAddress = this.deployedAddress;\n    }\n\n    this.setSignatureFields(result);\n\n    return result;\n  }\n\n  private setSignatureFields(result: LegacyTxData): void {\n    if (this.tx.v && this.tx.v.length) {\n      result.v = bufferToHex(this.tx.v);\n    }\n\n    if (this.tx.r && this.tx.r.length) {\n      result.r = bufferToHex(this.tx.r);\n    }\n\n    if (this.tx.s && this.tx.s.length) {\n      result.s = bufferToHex(this.tx.s);\n    }\n  }\n\n  /** @inheritdoc */\n  toSerialized(): string {\n    return addHexPrefix(this.tx.serialize().toString('hex'));\n  }\n\n  private static txJsonToCeloTx(txJson: LegacyTxData, signer: string): CeloTx {\n    // the celo library requires you to specify the signer address with the from field\n    return Object.assign({}, txJson, {\n      chainId: txJson.chainId === undefined ? 0 : parseInt(txJson.chainId, 10),\n      gas: txJson.gasLimit,\n      from: signer,\n    });\n  }\n\n  private static encodedTxToJson(encodedTx: EncodedTransaction): LegacyTxData {\n    return {\n      ...encodedTx.tx,\n      _type: ETHTransactionType.LEGACY,\n      nonce: parseInt(encodedTx.tx.nonce, 16),\n      gasLimit: encodedTx.tx.gas,\n      data: encodedTx.raw,\n    };\n  }\n}\n"]}
|