@bitgo/sdk-coin-celo 1.0.1-rc.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 +8 -0
- package/LICENSE +191 -0
- package/README.md +30 -0
- package/dist/src/celo.d.ts +14 -0
- package/dist/src/celo.d.ts.map +1 -0
- package/dist/src/celo.js +29 -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 +5 -0
- package/dist/src/index.d.ts.map +1 -0
- package/dist/src/index.js +17 -0
- package/dist/src/lib/index.d.ts +7 -0
- package/dist/src/lib/index.d.ts.map +1 -0
- package/dist/src/lib/index.js +34 -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 +26 -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 +276 -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/transaction.d.ts +9 -0
- package/dist/src/lib/transaction.d.ts.map +1 -0
- package/dist/src/lib/transaction.js +37 -0
- package/dist/src/lib/transactionBuilder.d.ts +85 -0
- package/dist/src/lib/transactionBuilder.d.ts.map +1 -0
- package/dist/src/lib/transactionBuilder.js +208 -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 +51 -0
- package/dist/src/lib/types.d.ts.map +1 -0
- package/dist/src/lib/types.js +222 -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 +99 -0
- package/dist/src/tcelo.d.ts +11 -0
- package/dist/src/tcelo.d.ts.map +1 -0
- package/dist/src/tcelo.js +14 -0
- package/package.json +63 -0
|
@@ -0,0 +1,208 @@
|
|
|
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 sdk_coin_eth_1 = require("@bitgo/sdk-coin-eth");
|
|
9
|
+
const sdk_core_1 = require("@bitgo/sdk-core");
|
|
10
|
+
const transaction_1 = require("./transaction");
|
|
11
|
+
const stakingBuilder_1 = require("./stakingBuilder");
|
|
12
|
+
const utils_1 = require("./utils");
|
|
13
|
+
const transferBuilder_1 = require("./transferBuilder");
|
|
14
|
+
const ethereumjs_util_1 = require("ethereumjs-util");
|
|
15
|
+
class TransactionBuilder extends sdk_coin_eth_1.TransactionBuilder {
|
|
16
|
+
constructor(_coinConfig) {
|
|
17
|
+
super(_coinConfig);
|
|
18
|
+
this._common = utils_1.getCommon(this._coinConfig.network.type);
|
|
19
|
+
this.transaction = new transaction_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 = transaction_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 transaction_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
|
+
* Get the final v value. Final v is described in EIP-155.
|
|
200
|
+
*
|
|
201
|
+
* @protected for internal use when the enableFinalVField flag is true.
|
|
202
|
+
*/
|
|
203
|
+
getFinalV() {
|
|
204
|
+
return ethereumjs_util_1.addHexPrefix(this._common.chainIdBN().toString(16));
|
|
205
|
+
}
|
|
206
|
+
}
|
|
207
|
+
exports.TransactionBuilder = TransactionBuilder;
|
|
208
|
+
//# 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 { TransactionBuilder as EthTransactionBuilder, TxData, walletSimpleConstructor } from '@bitgo/sdk-coin-eth';\nimport { BuildTransactionError, TransactionType, StakingOperationTypes } from '@bitgo/sdk-core';\nimport { Transaction } from './transaction';\nimport { StakingBuilder } from './stakingBuilder';\nimport { StakingCall } from './stakingCall';\nimport { getCommon, walletSimpleByteCode } from './utils';\nimport { TransferBuilder } from './transferBuilder';\nimport { addHexPrefix } from 'ethereumjs-util';\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   * Get the final v value. Final v is described in EIP-155.\n   *\n   * @protected for internal use when the enableFinalVField flag is true.\n   */\n  protected getFinalV(): string {\n    return addHexPrefix(this._common.chainIdBN().toString(16));\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,51 @@
|
|
|
1
|
+
/// <reference types="node" />
|
|
2
|
+
import { EthLikeTransactionData, KeyPair, LegacyTxData } from '@bitgo/sdk-coin-eth';
|
|
3
|
+
export declare class CeloTransaction {
|
|
4
|
+
private raw;
|
|
5
|
+
private _from;
|
|
6
|
+
private _senderPubKey?;
|
|
7
|
+
private _signatures;
|
|
8
|
+
private _feeCurrency;
|
|
9
|
+
private _gatewayFeeRecipient;
|
|
10
|
+
private _gatewayFee;
|
|
11
|
+
nonce: Buffer;
|
|
12
|
+
gasLimit: Buffer;
|
|
13
|
+
gasPrice: Buffer;
|
|
14
|
+
data: Buffer;
|
|
15
|
+
value: Buffer;
|
|
16
|
+
to: Buffer;
|
|
17
|
+
v: Buffer;
|
|
18
|
+
r: Buffer;
|
|
19
|
+
s: Buffer;
|
|
20
|
+
/**
|
|
21
|
+
* Clean hex formatted values ensuring they have an even length
|
|
22
|
+
*
|
|
23
|
+
* @param numberValue Hex formatted number value. Example '0x01'
|
|
24
|
+
* @returns sanitized value
|
|
25
|
+
*/
|
|
26
|
+
private sanitizeHexString;
|
|
27
|
+
constructor(tx: LegacyTxData);
|
|
28
|
+
private initRaw;
|
|
29
|
+
hash(includeSignature?: boolean): Buffer;
|
|
30
|
+
getSenderAddress(): Buffer;
|
|
31
|
+
getSenderPublicKey(): any;
|
|
32
|
+
serialize(): Buffer;
|
|
33
|
+
sign(privateKey: Buffer): void;
|
|
34
|
+
verifySignature(): boolean;
|
|
35
|
+
getChainId(): number;
|
|
36
|
+
}
|
|
37
|
+
export declare class CeloTransactionData implements EthLikeTransactionData {
|
|
38
|
+
private tx;
|
|
39
|
+
private deployedAddress?;
|
|
40
|
+
constructor(tx: CeloTransaction, deployedAddress?: string);
|
|
41
|
+
static fromJson(tx: LegacyTxData): CeloTransactionData;
|
|
42
|
+
sign(keyPair: KeyPair): Promise<void>;
|
|
43
|
+
/** @inheritdoc */
|
|
44
|
+
toJson(): LegacyTxData;
|
|
45
|
+
private setSignatureFields;
|
|
46
|
+
/** @inheritdoc */
|
|
47
|
+
toSerialized(): string;
|
|
48
|
+
private static txJsonToCeloTx;
|
|
49
|
+
private static encodedTxToJson;
|
|
50
|
+
}
|
|
51
|
+
//# 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;IAUxC,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,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.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_utils_old_1 = require("@bitgo/ethereumjs-utils-old");
|
|
10
|
+
const ethereumjs_util_1 = require("ethereumjs-util");
|
|
11
|
+
const sdk_coin_eth_1 = require("@bitgo/sdk-coin-eth");
|
|
12
|
+
class CeloTransaction {
|
|
13
|
+
constructor(tx) {
|
|
14
|
+
this._feeCurrency = ethereumjs_utils_old_1.toBuffer('0x');
|
|
15
|
+
this._gatewayFeeRecipient = ethereumjs_utils_old_1.toBuffer('0x');
|
|
16
|
+
this._gatewayFee = ethereumjs_utils_old_1.toBuffer('0x');
|
|
17
|
+
this.to = ethereumjs_utils_old_1.toBuffer([]);
|
|
18
|
+
this.v = ethereumjs_utils_old_1.toBuffer([]);
|
|
19
|
+
this.r = ethereumjs_utils_old_1.toBuffer([]);
|
|
20
|
+
this.s = ethereumjs_utils_old_1.toBuffer([]);
|
|
21
|
+
this.nonce = ethereumjs_util_1.unpad(ethereumjs_utils_old_1.toBuffer(tx.nonce));
|
|
22
|
+
this.gasLimit = ethereumjs_utils_old_1.toBuffer(this.sanitizeHexString(tx.gasLimit));
|
|
23
|
+
this.gasPrice = ethereumjs_utils_old_1.toBuffer(this.sanitizeHexString(tx.gasPrice));
|
|
24
|
+
this.data = ethereumjs_utils_old_1.toBuffer(tx.data);
|
|
25
|
+
this.value = ethereumjs_utils_old_1.toBuffer(this.sanitizeHexString(tx.value));
|
|
26
|
+
if (tx.to) {
|
|
27
|
+
this.to = ethereumjs_utils_old_1.toBuffer(tx.to);
|
|
28
|
+
}
|
|
29
|
+
if (tx.v) {
|
|
30
|
+
this.v = ethereumjs_utils_old_1.toBuffer(tx.v);
|
|
31
|
+
}
|
|
32
|
+
if (tx.r) {
|
|
33
|
+
this.r = ethereumjs_utils_old_1.toBuffer(tx.r);
|
|
34
|
+
}
|
|
35
|
+
if (tx.s) {
|
|
36
|
+
this.s = ethereumjs_utils_old_1.toBuffer(tx.s);
|
|
37
|
+
}
|
|
38
|
+
if (tx.from) {
|
|
39
|
+
this._from = ethereumjs_utils_old_1.toBuffer(tx.from);
|
|
40
|
+
}
|
|
41
|
+
this.initRaw();
|
|
42
|
+
}
|
|
43
|
+
// TODO: validate if this needs to be moved to Utils class
|
|
44
|
+
/**
|
|
45
|
+
* Clean hex formatted values ensuring they have an even length
|
|
46
|
+
*
|
|
47
|
+
* @param numberValue Hex formatted number value. Example '0x01'
|
|
48
|
+
* @returns sanitized value
|
|
49
|
+
*/
|
|
50
|
+
sanitizeHexString(numberValue) {
|
|
51
|
+
if (numberValue === '0x0') {
|
|
52
|
+
return '0x';
|
|
53
|
+
}
|
|
54
|
+
else if (numberValue.length % 2 === 0) {
|
|
55
|
+
return numberValue;
|
|
56
|
+
}
|
|
57
|
+
return '0x0' + numberValue.slice(2);
|
|
58
|
+
}
|
|
59
|
+
initRaw() {
|
|
60
|
+
this.raw = [
|
|
61
|
+
this.nonce,
|
|
62
|
+
this.gasPrice,
|
|
63
|
+
this.gasLimit,
|
|
64
|
+
this._feeCurrency,
|
|
65
|
+
this._gatewayFeeRecipient,
|
|
66
|
+
this._gatewayFee,
|
|
67
|
+
this.to,
|
|
68
|
+
this.value,
|
|
69
|
+
this.data,
|
|
70
|
+
this.v,
|
|
71
|
+
this.r,
|
|
72
|
+
this.s,
|
|
73
|
+
];
|
|
74
|
+
}
|
|
75
|
+
hash(includeSignature) {
|
|
76
|
+
let items;
|
|
77
|
+
if (includeSignature) {
|
|
78
|
+
items = this.raw;
|
|
79
|
+
}
|
|
80
|
+
else {
|
|
81
|
+
items = this.raw.slice(0, 9).concat([ethereumjs_utils_old_1.toBuffer(this.getChainId()), ethereumjs_util_1.unpad(ethereumjs_utils_old_1.toBuffer(0)), ethereumjs_util_1.unpad(ethereumjs_utils_old_1.toBuffer(0))]);
|
|
82
|
+
}
|
|
83
|
+
return ethereumjs_utils_old_1.rlphash(items);
|
|
84
|
+
}
|
|
85
|
+
getSenderAddress() {
|
|
86
|
+
if (this._from) {
|
|
87
|
+
return this._from;
|
|
88
|
+
}
|
|
89
|
+
const pubKey = this.getSenderPublicKey();
|
|
90
|
+
this._from = ethereumjs_utils_old_1.publicToAddress(pubKey);
|
|
91
|
+
return this._from;
|
|
92
|
+
}
|
|
93
|
+
getSenderPublicKey() {
|
|
94
|
+
if (this.verifySignature()) {
|
|
95
|
+
// If the signature was verified successfully the _senderPubKey field is defined
|
|
96
|
+
return this._senderPubKey;
|
|
97
|
+
}
|
|
98
|
+
throw new Error('Invalid Signature');
|
|
99
|
+
}
|
|
100
|
+
serialize() {
|
|
101
|
+
return ethereumjs_utils_old_1.rlp.encode(this.raw);
|
|
102
|
+
}
|
|
103
|
+
sign(privateKey) {
|
|
104
|
+
this._signatures = [this.v, this.r, this.s, privateKey];
|
|
105
|
+
}
|
|
106
|
+
verifySignature() {
|
|
107
|
+
const msgHash = this.hash(false);
|
|
108
|
+
try {
|
|
109
|
+
const chainId = this.getChainId();
|
|
110
|
+
const v = ethereumjs_utils_old_1.bufferToInt(this.v) - (2 * chainId + 35);
|
|
111
|
+
this._senderPubKey = ethereumjs_utils_old_1.ecrecover(msgHash, v + 27, this.r, this.s);
|
|
112
|
+
}
|
|
113
|
+
catch (e) {
|
|
114
|
+
return false;
|
|
115
|
+
}
|
|
116
|
+
return !!this._senderPubKey;
|
|
117
|
+
}
|
|
118
|
+
getChainId() {
|
|
119
|
+
let chainId = ethereumjs_utils_old_1.bufferToInt(this.v);
|
|
120
|
+
if (this.r.length && this.s.length) {
|
|
121
|
+
chainId = (chainId - 35) >> 1;
|
|
122
|
+
}
|
|
123
|
+
return chainId;
|
|
124
|
+
}
|
|
125
|
+
}
|
|
126
|
+
exports.CeloTransaction = CeloTransaction;
|
|
127
|
+
class CeloTransactionData {
|
|
128
|
+
constructor(tx, deployedAddress) {
|
|
129
|
+
this.tx = tx;
|
|
130
|
+
this.deployedAddress = deployedAddress;
|
|
131
|
+
}
|
|
132
|
+
static fromJson(tx) {
|
|
133
|
+
const chainId = ethereumjs_utils_old_1.addHexPrefix(new bignumber_js_1.default(Number(tx.chainId)).toString(16));
|
|
134
|
+
return new CeloTransactionData(new CeloTransaction({
|
|
135
|
+
_type: sdk_coin_eth_1.ETHTransactionType.LEGACY,
|
|
136
|
+
nonce: tx.nonce,
|
|
137
|
+
to: tx.to,
|
|
138
|
+
gasPrice: ethereumjs_utils_old_1.addHexPrefix(new bignumber_js_1.default(tx.gasPrice).toString(16)),
|
|
139
|
+
gasLimit: ethereumjs_utils_old_1.addHexPrefix(new bignumber_js_1.default(tx.gasLimit).toString(16)),
|
|
140
|
+
value: ethereumjs_utils_old_1.addHexPrefix(new bignumber_js_1.default(tx.value).toString(16)),
|
|
141
|
+
data: tx.data === '0x' ? '' : tx.data,
|
|
142
|
+
from: tx.from,
|
|
143
|
+
s: tx.s,
|
|
144
|
+
r: tx.r,
|
|
145
|
+
v: tx.v || chainId,
|
|
146
|
+
}), tx.deployedAddress);
|
|
147
|
+
}
|
|
148
|
+
async sign(keyPair) {
|
|
149
|
+
const privateKey = ethereumjs_utils_old_1.addHexPrefix(keyPair.getKeys().prv);
|
|
150
|
+
const data = CeloTransactionData.txJsonToCeloTx(this.toJson(), keyPair.getAddress());
|
|
151
|
+
const celoLocalWallet = new wallet_local_1.LocalWallet();
|
|
152
|
+
celoLocalWallet.addAccount(privateKey);
|
|
153
|
+
const rawTransaction = await celoLocalWallet.signTransaction(data);
|
|
154
|
+
const nonceBigNumber = new bignumber_js_1.default(rawTransaction.tx.nonce);
|
|
155
|
+
rawTransaction.tx.nonce = ethereumjs_utils_old_1.addHexPrefix(nonceBigNumber.toString(16));
|
|
156
|
+
rawTransaction.raw = data.data === undefined ? '' : data.data;
|
|
157
|
+
rawTransaction.tx.gas = rawTransaction.tx.gas;
|
|
158
|
+
this.tx = new CeloTransaction(CeloTransactionData.encodedTxToJson(rawTransaction));
|
|
159
|
+
this.tx.sign(ethereumjs_utils_old_1.toBuffer(privateKey));
|
|
160
|
+
}
|
|
161
|
+
/** @inheritdoc */
|
|
162
|
+
toJson() {
|
|
163
|
+
const result = {
|
|
164
|
+
_type: sdk_coin_eth_1.ETHTransactionType.LEGACY,
|
|
165
|
+
nonce: ethereumjs_utils_old_1.bufferToInt(this.tx.nonce),
|
|
166
|
+
gasPrice: new bignumber_js_1.default(ethereumjs_utils_old_1.bufferToHex(this.tx.gasPrice), 16).toString(10),
|
|
167
|
+
gasLimit: new bignumber_js_1.default(ethereumjs_utils_old_1.bufferToHex(this.tx.gasLimit), 16).toString(10),
|
|
168
|
+
value: this.tx.value.length === 0 ? '0' : new bignumber_js_1.default(ethereumjs_utils_old_1.bufferToHex(this.tx.value), 16).toString(10),
|
|
169
|
+
data: ethereumjs_utils_old_1.bufferToHex(this.tx.data),
|
|
170
|
+
id: ethereumjs_utils_old_1.addHexPrefix(ethereumjs_utils_old_1.bufferToHex(this.tx.hash(true))),
|
|
171
|
+
};
|
|
172
|
+
if (this.tx.to && this.tx.to.length) {
|
|
173
|
+
result.to = ethereumjs_utils_old_1.bufferToHex(this.tx.to);
|
|
174
|
+
}
|
|
175
|
+
if (this.tx.verifySignature()) {
|
|
176
|
+
result.from = ethereumjs_utils_old_1.bufferToHex(this.tx.getSenderAddress());
|
|
177
|
+
}
|
|
178
|
+
const chainId = this.tx.getChainId();
|
|
179
|
+
if (chainId) {
|
|
180
|
+
result.chainId = chainId.toString();
|
|
181
|
+
}
|
|
182
|
+
if (this.deployedAddress) {
|
|
183
|
+
result.deployedAddress = this.deployedAddress;
|
|
184
|
+
}
|
|
185
|
+
this.setSignatureFields(result);
|
|
186
|
+
return result;
|
|
187
|
+
}
|
|
188
|
+
setSignatureFields(result) {
|
|
189
|
+
if (this.tx.v && this.tx.v.length) {
|
|
190
|
+
result.v = ethereumjs_utils_old_1.bufferToHex(this.tx.v);
|
|
191
|
+
}
|
|
192
|
+
if (this.tx.r && this.tx.r.length) {
|
|
193
|
+
result.r = ethereumjs_utils_old_1.bufferToHex(this.tx.r);
|
|
194
|
+
}
|
|
195
|
+
if (this.tx.s && this.tx.s.length) {
|
|
196
|
+
result.s = ethereumjs_utils_old_1.bufferToHex(this.tx.s);
|
|
197
|
+
}
|
|
198
|
+
}
|
|
199
|
+
/** @inheritdoc */
|
|
200
|
+
toSerialized() {
|
|
201
|
+
return ethereumjs_utils_old_1.addHexPrefix(this.tx.serialize().toString('hex'));
|
|
202
|
+
}
|
|
203
|
+
static txJsonToCeloTx(txJson, signer) {
|
|
204
|
+
// the celo library requires you to specify the signer address with the from field
|
|
205
|
+
return Object.assign({}, txJson, {
|
|
206
|
+
chainId: txJson.chainId === undefined ? 0 : parseInt(txJson.chainId, 10),
|
|
207
|
+
gas: txJson.gasLimit,
|
|
208
|
+
from: signer,
|
|
209
|
+
});
|
|
210
|
+
}
|
|
211
|
+
static encodedTxToJson(encodedTx) {
|
|
212
|
+
return {
|
|
213
|
+
...encodedTx.tx,
|
|
214
|
+
_type: sdk_coin_eth_1.ETHTransactionType.LEGACY,
|
|
215
|
+
nonce: parseInt(encodedTx.tx.nonce, 16),
|
|
216
|
+
gasLimit: encodedTx.tx.gas,
|
|
217
|
+
data: encodedTx.raw,
|
|
218
|
+
};
|
|
219
|
+
}
|
|
220
|
+
}
|
|
221
|
+
exports.CeloTransactionData = CeloTransactionData;
|
|
222
|
+
//# 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} from '@bitgo/ethereumjs-utils-old';\nimport { unpad } 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') {\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 = unpad(toBuffer(tx.nonce));\n    this.gasLimit = toBuffer(this.sanitizeHexString(tx.gasLimit));\n    this.gasPrice = toBuffer(this.sanitizeHexString(tx.gasPrice));\n    this.data = toBuffer(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.slice(0, 9).concat([toBuffer(this.getChainId()), unpad(toBuffer(0)), unpad(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"]}
|