@bitgo-beta/sdk-coin-avaxp 3.5.10-beta.99 → 3.5.10-beta.991
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/CHANGELOG.md +661 -0
- package/dist/src/avaxp.d.ts +7 -6
- package/dist/src/avaxp.d.ts.map +1 -1
- package/dist/src/avaxp.js +50 -40
- package/dist/src/iface.d.ts +0 -4
- package/dist/src/iface.d.ts.map +1 -1
- package/dist/src/iface.js +1 -1
- package/dist/src/index.js +23 -9
- package/dist/src/lib/atomicInCTransactionBuilder.d.ts +2 -3
- package/dist/src/lib/atomicInCTransactionBuilder.d.ts.map +1 -1
- package/dist/src/lib/atomicInCTransactionBuilder.js +1 -1
- package/dist/src/lib/atomicTransactionBuilder.d.ts +2 -4
- package/dist/src/lib/atomicTransactionBuilder.d.ts.map +1 -1
- package/dist/src/lib/atomicTransactionBuilder.js +7 -9
- package/dist/src/lib/delegatorTxBuilder.d.ts +6 -7
- package/dist/src/lib/delegatorTxBuilder.d.ts.map +1 -1
- package/dist/src/lib/delegatorTxBuilder.js +9 -11
- package/dist/src/lib/deprecatedTransaction.d.ts +98 -0
- package/dist/src/lib/deprecatedTransaction.d.ts.map +1 -0
- package/dist/src/lib/deprecatedTransaction.js +344 -0
- package/dist/src/lib/deprecatedTransactionBuilder.d.ts +114 -0
- package/dist/src/lib/deprecatedTransactionBuilder.d.ts.map +1 -0
- package/dist/src/lib/deprecatedTransactionBuilder.js +210 -0
- package/dist/src/lib/exportInCTxBuilder.d.ts +8 -9
- package/dist/src/lib/exportInCTxBuilder.d.ts.map +1 -1
- package/dist/src/lib/exportInCTxBuilder.js +4 -4
- package/dist/src/lib/exportTxBuilder.d.ts +4 -5
- package/dist/src/lib/exportTxBuilder.d.ts.map +1 -1
- package/dist/src/lib/exportTxBuilder.js +3 -3
- package/dist/src/lib/iface.d.ts +12 -9
- package/dist/src/lib/iface.d.ts.map +1 -1
- package/dist/src/lib/iface.js +2 -2
- package/dist/src/lib/importInCTxBuilder.d.ts +4 -5
- package/dist/src/lib/importInCTxBuilder.d.ts.map +1 -1
- package/dist/src/lib/importInCTxBuilder.js +6 -6
- package/dist/src/lib/importTxBuilder.d.ts +4 -4
- package/dist/src/lib/importTxBuilder.d.ts.map +1 -1
- package/dist/src/lib/importTxBuilder.js +3 -3
- package/dist/src/lib/index.d.ts +2 -0
- package/dist/src/lib/index.d.ts.map +1 -1
- package/dist/src/lib/index.js +11 -3
- package/dist/src/lib/keyPair.d.ts +0 -1
- package/dist/src/lib/keyPair.d.ts.map +1 -1
- package/dist/src/lib/keyPair.js +20 -21
- package/dist/src/lib/permissionlessValidatorTxBuilder.d.ts +154 -0
- package/dist/src/lib/permissionlessValidatorTxBuilder.d.ts.map +1 -0
- package/dist/src/lib/permissionlessValidatorTxBuilder.js +452 -0
- package/dist/src/lib/transaction.d.ts +19 -41
- package/dist/src/lib/transaction.d.ts.map +1 -1
- package/dist/src/lib/transaction.js +68 -168
- package/dist/src/lib/transactionBuilder.d.ts +31 -82
- package/dist/src/lib/transactionBuilder.d.ts.map +1 -1
- package/dist/src/lib/transactionBuilder.js +65 -151
- package/dist/src/lib/transactionBuilderFactory.d.ts +16 -8
- package/dist/src/lib/transactionBuilderFactory.d.ts.map +1 -1
- package/dist/src/lib/transactionBuilderFactory.js +77 -19
- package/dist/src/lib/utils.d.ts +23 -9
- package/dist/src/lib/utils.d.ts.map +1 -1
- package/dist/src/lib/utils.js +72 -22
- package/dist/src/lib/utxoEngine.d.ts +10 -2
- package/dist/src/lib/utxoEngine.d.ts.map +1 -1
- package/dist/src/lib/utxoEngine.js +29 -6
- package/dist/src/lib/validatorTxBuilder.d.ts +4 -4
- package/dist/src/lib/validatorTxBuilder.d.ts.map +1 -1
- package/dist/src/lib/validatorTxBuilder.js +2 -2
- package/dist/test/resources/avaxp.d.ts +80 -6
- package/dist/test/resources/avaxp.d.ts.map +1 -1
- package/dist/test/resources/avaxp.js +166 -33
- package/dist/test/resources/tx/importP.js +8 -8
- package/dist/test/unit/avaxp.js +109 -117
- package/dist/test/unit/lib/exportC2PTxBuilder.js +23 -9
- package/dist/test/unit/lib/exportP2CTxBuilder.js +27 -17
- package/dist/test/unit/lib/importC2PTxBuilder.js +25 -11
- package/dist/test/unit/lib/importP2CTxBuilder.js +25 -13
- package/dist/test/unit/lib/keyPair.js +23 -9
- package/dist/test/unit/lib/permissionlessValidatorTxBuilder.d.ts +2 -0
- package/dist/test/unit/lib/permissionlessValidatorTxBuilder.d.ts.map +1 -0
- package/dist/test/unit/lib/permissionlessValidatorTxBuilder.js +341 -0
- package/dist/test/unit/lib/signFlowTestSuit.js +2 -2
- package/dist/test/unit/lib/transactionBuilderFactory.js +25 -11
- package/dist/test/unit/lib/utils.js +23 -9
- package/dist/test/unit/lib/utxoEngine.js +6 -6
- package/dist/test/unit/lib/validateTxBuilder.js +29 -20
- package/dist/tsconfig.tsbuildinfo +1 -1
- package/package.json +10 -10
|
@@ -4,16 +4,18 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
|
4
4
|
};
|
|
5
5
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
6
|
exports.TransactionBuilderFactory = void 0;
|
|
7
|
+
const avalanchejs_1 = require("@bitgo-forks/avalanchejs");
|
|
7
8
|
const sdk_core_1 = require("@bitgo-beta/sdk-core");
|
|
8
|
-
const validatorTxBuilder_1 = require("./validatorTxBuilder");
|
|
9
|
-
const platformvm_1 = require("avalanche/dist/apis/platformvm");
|
|
10
|
-
const evm_1 = require("avalanche/dist/apis/evm");
|
|
11
9
|
const avalanche_1 = require("avalanche");
|
|
12
|
-
const
|
|
10
|
+
const evm_1 = require("avalanche/dist/apis/evm");
|
|
11
|
+
const platformvm_1 = require("avalanche/dist/apis/platformvm");
|
|
12
|
+
const exportInCTxBuilder_1 = require("./exportInCTxBuilder");
|
|
13
13
|
const exportTxBuilder_1 = require("./exportTxBuilder");
|
|
14
|
-
const importTxBuilder_1 = require("./importTxBuilder");
|
|
15
14
|
const importInCTxBuilder_1 = require("./importInCTxBuilder");
|
|
16
|
-
const
|
|
15
|
+
const importTxBuilder_1 = require("./importTxBuilder");
|
|
16
|
+
const permissionlessValidatorTxBuilder_1 = require("./permissionlessValidatorTxBuilder");
|
|
17
|
+
const utils_1 = __importDefault(require("./utils"));
|
|
18
|
+
const validatorTxBuilder_1 = require("./validatorTxBuilder");
|
|
17
19
|
class TransactionBuilderFactory extends sdk_core_1.BaseTransactionBuilderFactory {
|
|
18
20
|
constructor(_coinConfig) {
|
|
19
21
|
super(_coinConfig);
|
|
@@ -22,49 +24,97 @@ class TransactionBuilderFactory extends sdk_core_1.BaseTransactionBuilderFactory
|
|
|
22
24
|
/** @inheritdoc */
|
|
23
25
|
from(raw) {
|
|
24
26
|
utils_1.default.validateRawTransaction(raw);
|
|
25
|
-
raw = utils_1.default.removeHexPrefix(raw);
|
|
26
27
|
let txSource = 'PVM';
|
|
27
|
-
let tx;
|
|
28
28
|
let transactionBuilder = undefined;
|
|
29
|
+
let tx;
|
|
30
|
+
const rawNoHex = utils_1.default.removeHexPrefix(raw);
|
|
29
31
|
try {
|
|
30
32
|
tx = new platformvm_1.Tx();
|
|
31
33
|
// could throw an error if a txType doesn't match.
|
|
32
|
-
tx.fromBuffer(avalanche_1.Buffer.from(
|
|
34
|
+
tx.fromBuffer(avalanche_1.Buffer.from(rawNoHex, 'hex'));
|
|
33
35
|
if (!utils_1.default.isTransactionOf(tx, this._coinConfig.network.blockchainID)) {
|
|
34
|
-
throw new Error('It is not a transaction of this
|
|
36
|
+
throw new Error('It is not a transaction of this platformvm old flow');
|
|
35
37
|
}
|
|
36
38
|
}
|
|
37
|
-
catch {
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
39
|
+
catch (e) {
|
|
40
|
+
try {
|
|
41
|
+
txSource = 'EVM';
|
|
42
|
+
tx = new evm_1.Tx();
|
|
43
|
+
tx.fromBuffer(avalanche_1.Buffer.from(rawNoHex, 'hex'));
|
|
44
|
+
if (!utils_1.default.isTransactionOf(tx, this._coinConfig.network.cChainBlockchainID)) {
|
|
45
|
+
throw new Error('It is not a transaction of this network or C chain EVM');
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
catch (e) {
|
|
49
|
+
try {
|
|
50
|
+
txSource = 'PVM';
|
|
51
|
+
// this should be the last because other PVM functions are still being detected in the new SDK
|
|
52
|
+
const manager = avalanchejs_1.utils.getManagerForVM('PVM');
|
|
53
|
+
const [codec, txBytes] = manager.getCodecFromBuffer(avalanchejs_1.utils.hexToBuffer(raw));
|
|
54
|
+
const unpackedTx = codec.UnpackPrefix(txBytes);
|
|
55
|
+
// A signed transaction includes 4 bytes for the number of credentials as an Int type that is not known by the codec
|
|
56
|
+
// We'll skip those 4 bytes, instead we'll loop until we've parsed all credentials
|
|
57
|
+
// @see https://docs.avax.network/reference/avalanchego/p-chain/txn-format#signed-transaction-example
|
|
58
|
+
const credentials = [];
|
|
59
|
+
let credentialBytes = unpackedTx[1].slice(4);
|
|
60
|
+
let moreCredentials = true;
|
|
61
|
+
do {
|
|
62
|
+
try {
|
|
63
|
+
const [credential, rest] = codec.UnpackPrefix(credentialBytes);
|
|
64
|
+
credentials.push(credential);
|
|
65
|
+
credentialBytes = rest;
|
|
66
|
+
}
|
|
67
|
+
catch (e) {
|
|
68
|
+
moreCredentials = false;
|
|
69
|
+
}
|
|
70
|
+
} while (credentialBytes.length > 0 && moreCredentials);
|
|
71
|
+
const unpacked = codec.UnpackPrefix(txBytes);
|
|
72
|
+
const permissionlessValidatorTx = unpacked[0];
|
|
73
|
+
const outputs = permissionlessValidatorTx.baseTx.outputs;
|
|
74
|
+
const output = outputs[0].output;
|
|
75
|
+
if (outputs[0].getAssetId() !== this._coinConfig.network.avaxAssetID) {
|
|
76
|
+
throw new Error('The Asset ID of the output does not match the transaction');
|
|
77
|
+
}
|
|
78
|
+
const fromAddresses = output.outputOwners.addrs.map((a) => avalanchejs_1.utils.hexToBuffer(a.toHex()));
|
|
79
|
+
const addressMaps = fromAddresses.map((a) => new avalanchejs_1.utils.AddressMap([[new avalanchejs_1.Address(a), 0]]));
|
|
80
|
+
tx = new avalanchejs_1.UnsignedTx(unpacked[0], [], new avalanchejs_1.utils.AddressMaps(addressMaps), credentials);
|
|
81
|
+
}
|
|
82
|
+
catch (e) {
|
|
83
|
+
throw new Error(`The transaction type is not recognized as an old PVM or old EVM transaction. Additionally, parsing of the new PVM AddPermissionlessValidatorTx type failed: ${e.message}`);
|
|
84
|
+
}
|
|
43
85
|
}
|
|
44
86
|
}
|
|
45
87
|
if (txSource === 'PVM') {
|
|
46
|
-
if (
|
|
88
|
+
if (tx?.tx?._type && permissionlessValidatorTxBuilder_1.PermissionlessValidatorTxBuilder.verifyTxType(tx.tx._type)) {
|
|
89
|
+
transactionBuilder = this.getPermissionlessValidatorTxBuilder();
|
|
90
|
+
transactionBuilder.initBuilder(tx);
|
|
91
|
+
}
|
|
92
|
+
else if (validatorTxBuilder_1.ValidatorTxBuilder.verifyTxType(tx.getUnsignedTx().getTransaction())) {
|
|
47
93
|
transactionBuilder = this.getValidatorBuilder();
|
|
94
|
+
transactionBuilder.initBuilder(tx);
|
|
48
95
|
}
|
|
49
96
|
else if (exportTxBuilder_1.ExportTxBuilder.verifyTxType(tx.getUnsignedTx().getTransaction())) {
|
|
50
97
|
transactionBuilder = this.getExportBuilder();
|
|
98
|
+
transactionBuilder.initBuilder(tx);
|
|
51
99
|
}
|
|
52
100
|
else if (importTxBuilder_1.ImportTxBuilder.verifyTxType(tx.getUnsignedTx().getTransaction())) {
|
|
53
101
|
transactionBuilder = this.getImportBuilder();
|
|
102
|
+
transactionBuilder.initBuilder(tx);
|
|
54
103
|
}
|
|
55
104
|
}
|
|
56
105
|
else if (txSource === 'EVM') {
|
|
57
106
|
if (importInCTxBuilder_1.ImportInCTxBuilder.verifyTxType(tx.getUnsignedTx().getTransaction())) {
|
|
58
107
|
transactionBuilder = this.getImportInCBuilder();
|
|
108
|
+
transactionBuilder.initBuilder(tx);
|
|
59
109
|
}
|
|
60
110
|
else if (exportInCTxBuilder_1.ExportInCTxBuilder.verifyTxType(tx.getUnsignedTx().getTransaction())) {
|
|
61
111
|
transactionBuilder = this.getExportInCBuilder();
|
|
112
|
+
transactionBuilder.initBuilder(tx);
|
|
62
113
|
}
|
|
63
114
|
}
|
|
64
115
|
if (transactionBuilder === undefined) {
|
|
65
116
|
throw new sdk_core_1.NotSupported('Transaction cannot be parsed or has an unsupported transaction type');
|
|
66
117
|
}
|
|
67
|
-
transactionBuilder.initBuilder(tx);
|
|
68
118
|
return transactionBuilder;
|
|
69
119
|
}
|
|
70
120
|
/** @inheritdoc */
|
|
@@ -79,6 +129,14 @@ class TransactionBuilderFactory extends sdk_core_1.BaseTransactionBuilderFactory
|
|
|
79
129
|
getValidatorBuilder() {
|
|
80
130
|
return new validatorTxBuilder_1.ValidatorTxBuilder(this._coinConfig);
|
|
81
131
|
}
|
|
132
|
+
/**
|
|
133
|
+
* Initialize Permissionless Validator builder
|
|
134
|
+
*
|
|
135
|
+
* @returns {PermissionlessValidatorTxBuilder} the builder initialized
|
|
136
|
+
*/
|
|
137
|
+
getPermissionlessValidatorTxBuilder() {
|
|
138
|
+
return new permissionlessValidatorTxBuilder_1.PermissionlessValidatorTxBuilder(this._coinConfig);
|
|
139
|
+
}
|
|
82
140
|
/**
|
|
83
141
|
* Export Cross chain transfer
|
|
84
142
|
*
|
|
@@ -117,4 +175,4 @@ class TransactionBuilderFactory extends sdk_core_1.BaseTransactionBuilderFactory
|
|
|
117
175
|
}
|
|
118
176
|
}
|
|
119
177
|
exports.TransactionBuilderFactory = TransactionBuilderFactory;
|
|
120
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"transactionBuilderFactory.js","sourceRoot":"","sources":["../../../src/lib/transactionBuilderFactory.ts"],"names":[],"mappings":"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","sourcesContent":["import { AvalancheNetwork, BaseCoin as CoinConfig } from '@bitgo-beta/statics';\nimport { BaseTransactionBuilderFactory, NotSupported } from '@bitgo-beta/sdk-core';\nimport { TransactionBuilder } from './transactionBuilder';\nimport { ValidatorTxBuilder } from './validatorTxBuilder';\nimport { Tx } from 'avalanche/dist/apis/platformvm';\nimport { Tx as EVMTx } from 'avalanche/dist/apis/evm';\nimport { Buffer as BufferAvax } from 'avalanche';\nimport utils from './utils';\nimport { ExportTxBuilder } from './exportTxBuilder';\nimport { ImportTxBuilder } from './importTxBuilder';\nimport { ImportInCTxBuilder } from './importInCTxBuilder';\nimport { ExportInCTxBuilder } from './exportInCTxBuilder';\n\nexport class TransactionBuilderFactory extends BaseTransactionBuilderFactory {\n  protected recoverSigner = false;\n  constructor(_coinConfig: Readonly<CoinConfig>) {\n    super(_coinConfig);\n  }\n\n  /** @inheritdoc */\n  from(raw: string): TransactionBuilder {\n    utils.validateRawTransaction(raw);\n    raw = utils.removeHexPrefix(raw);\n    let txSource: 'EVM' | 'PVM' = 'PVM';\n    let tx: Tx | EVMTx;\n    let transactionBuilder: TransactionBuilder | undefined = undefined;\n\n    try {\n      tx = new Tx();\n      // could throw an error if a txType doesn't match.\n      tx.fromBuffer(BufferAvax.from(raw, 'hex'));\n\n      if (!utils.isTransactionOf(tx, (this._coinConfig.network as AvalancheNetwork).blockchainID)) {\n        throw new Error('It is not a transaction of this network');\n      }\n    } catch {\n      txSource = 'EVM';\n      tx = new EVMTx();\n      tx.fromBuffer(BufferAvax.from(raw, 'hex'));\n\n      if (!utils.isTransactionOf(tx, (this._coinConfig.network as AvalancheNetwork).cChainBlockchainID)) {\n        throw new Error('It is not a transaction of this network or C chain');\n      }\n    }\n    if (txSource === 'PVM') {\n      if (ValidatorTxBuilder.verifyTxType(tx.getUnsignedTx().getTransaction())) {\n        transactionBuilder = this.getValidatorBuilder();\n      } else if (ExportTxBuilder.verifyTxType(tx.getUnsignedTx().getTransaction())) {\n        transactionBuilder = this.getExportBuilder();\n      } else if (ImportTxBuilder.verifyTxType(tx.getUnsignedTx().getTransaction())) {\n        transactionBuilder = this.getImportBuilder();\n      }\n    } else if (txSource === 'EVM') {\n      if (ImportInCTxBuilder.verifyTxType(tx.getUnsignedTx().getTransaction())) {\n        transactionBuilder = this.getImportInCBuilder();\n      } else if (ExportInCTxBuilder.verifyTxType(tx.getUnsignedTx().getTransaction())) {\n        transactionBuilder = this.getExportInCBuilder();\n      }\n    }\n    if (transactionBuilder === undefined) {\n      throw new NotSupported('Transaction cannot be parsed or has an unsupported transaction type');\n    }\n    transactionBuilder.initBuilder(tx);\n    return transactionBuilder;\n  }\n\n  /** @inheritdoc */\n  getTransferBuilder(): TransactionBuilder {\n    throw new NotSupported('Transfer is not supported in P Chain');\n  }\n\n  /**\n   * Initialize Validator builder\n   *\n   * @returns {ValidatorTxBuilder} the builder initialized\n   */\n  getValidatorBuilder(): ValidatorTxBuilder {\n    return new ValidatorTxBuilder(this._coinConfig);\n  }\n\n  /**\n   * Export Cross chain transfer\n   *\n   * @returns {ExportTxBuilder} the builder initialized\n   */\n  getExportBuilder(): ExportTxBuilder {\n    return new ExportTxBuilder(this._coinConfig);\n  }\n\n  /**\n   * Import Cross chain transfer\n   *\n   * @returns {ImportTxBuilder} the builder initialized\n   */\n  getImportBuilder(): ImportTxBuilder {\n    return new ImportTxBuilder(this._coinConfig);\n  }\n\n  /**\n   * Import in C chain Cross chain transfer\n   *\n   * @returns {ImportInCTxBuilder} the builder initialized\n   */\n  getImportInCBuilder(): ImportInCTxBuilder {\n    return new ImportInCTxBuilder(this._coinConfig);\n  }\n\n  /**\n   * Export in C chain Cross chain transfer\n   *\n   * @returns {ExportInCTxBuilder} the builder initialized\n   */\n  getExportInCBuilder(): ExportInCTxBuilder {\n    return new ExportInCTxBuilder(this._coinConfig);\n  }\n\n  /** @inheritdoc */\n  getWalletInitializationBuilder(): TransactionBuilder {\n    throw new NotSupported('Wallet initialization is not needed');\n  }\n}\n"]}
|
|
178
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"transactionBuilderFactory.js","sourceRoot":"","sources":["../../../src/lib/transactionBuilderFactory.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Address,\n  utils as AvaxUtils,\n  Credential,\n  pvmSerial,\n  TransferOutput,\n  UnsignedTx,\n} from '@bitgo-forks/avalanchejs';\nimport { BaseTransactionBuilderFactory, NotSupported } from '@bitgo-beta/sdk-core';\nimport { AvalancheNetwork, BaseCoin as CoinConfig } from '@bitgo-beta/statics';\nimport { Buffer as BufferAvax } from 'avalanche';\nimport { Tx as EVMTx } from 'avalanche/dist/apis/evm';\nimport { Tx as PVMTx } from 'avalanche/dist/apis/platformvm';\nimport { DeprecatedTransactionBuilder } from './deprecatedTransactionBuilder';\nimport { ExportInCTxBuilder } from './exportInCTxBuilder';\nimport { ExportTxBuilder } from './exportTxBuilder';\nimport { ImportInCTxBuilder } from './importInCTxBuilder';\nimport { ImportTxBuilder } from './importTxBuilder';\nimport { PermissionlessValidatorTxBuilder } from './permissionlessValidatorTxBuilder';\nimport { TransactionBuilder } from './transactionBuilder';\nimport utils from './utils';\nimport { ValidatorTxBuilder } from './validatorTxBuilder';\n\nexport class TransactionBuilderFactory extends BaseTransactionBuilderFactory {\n  protected recoverSigner = false;\n  constructor(_coinConfig: Readonly<CoinConfig>) {\n    super(_coinConfig);\n  }\n\n  /** @inheritdoc */\n  from(raw: string): TransactionBuilder | DeprecatedTransactionBuilder {\n    utils.validateRawTransaction(raw);\n    let txSource: 'EVM' | 'PVM' = 'PVM';\n    let transactionBuilder: TransactionBuilder | DeprecatedTransactionBuilder | undefined = undefined;\n    let tx: PVMTx | EVMTx | UnsignedTx;\n    const rawNoHex = utils.removeHexPrefix(raw);\n    try {\n      tx = new PVMTx();\n      // could throw an error if a txType doesn't match.\n      tx.fromBuffer(BufferAvax.from(rawNoHex, 'hex'));\n\n      if (!utils.isTransactionOf(tx, (this._coinConfig.network as AvalancheNetwork).blockchainID)) {\n        throw new Error('It is not a transaction of this platformvm old flow');\n      }\n    } catch (e) {\n      try {\n        txSource = 'EVM';\n        tx = new EVMTx();\n        tx.fromBuffer(BufferAvax.from(rawNoHex, 'hex'));\n\n        if (!utils.isTransactionOf(tx, (this._coinConfig.network as AvalancheNetwork).cChainBlockchainID)) {\n          throw new Error('It is not a transaction of this network or C chain EVM');\n        }\n      } catch (e) {\n        try {\n          txSource = 'PVM';\n          // this should be the last because other PVM functions are still being detected in the new SDK\n          const manager = AvaxUtils.getManagerForVM('PVM');\n          const [codec, txBytes] = manager.getCodecFromBuffer(AvaxUtils.hexToBuffer(raw));\n          const unpackedTx = codec.UnpackPrefix<pvmSerial.AddPermissionlessValidatorTx>(txBytes);\n          // A signed transaction includes 4 bytes for the number of credentials as an Int type that is not known by the codec\n          // We'll skip those 4 bytes, instead we'll loop until we've parsed all credentials\n          // @see https://docs.avax.network/reference/avalanchego/p-chain/txn-format#signed-transaction-example\n          const credentials: Credential[] = [];\n          let credentialBytes = unpackedTx[1].slice(4);\n          let moreCredentials = true;\n          do {\n            try {\n              const [credential, rest] = codec.UnpackPrefix<Credential>(credentialBytes);\n              credentials.push(credential);\n              credentialBytes = rest;\n            } catch (e) {\n              moreCredentials = false;\n            }\n          } while (credentialBytes.length > 0 && moreCredentials);\n\n          const unpacked = codec.UnpackPrefix<pvmSerial.AddPermissionlessValidatorTx>(txBytes);\n          const permissionlessValidatorTx = unpacked[0] as pvmSerial.AddPermissionlessValidatorTx;\n          const outputs = permissionlessValidatorTx.baseTx.outputs;\n          const output = outputs[0].output as TransferOutput;\n          if (outputs[0].getAssetId() !== (this._coinConfig.network as AvalancheNetwork).avaxAssetID) {\n            throw new Error('The Asset ID of the output does not match the transaction');\n          }\n          const fromAddresses = output.outputOwners.addrs.map((a) => AvaxUtils.hexToBuffer(a.toHex()));\n          const addressMaps = fromAddresses.map((a) => new AvaxUtils.AddressMap([[new Address(a), 0]]));\n          tx = new UnsignedTx(unpacked[0], [], new AvaxUtils.AddressMaps(addressMaps), credentials);\n        } catch (e) {\n          throw new Error(\n            `The transaction type is not recognized as an old PVM or old EVM transaction. Additionally, parsing of the new PVM AddPermissionlessValidatorTx type failed: ${e.message}`\n          );\n        }\n      }\n    }\n\n    if (txSource === 'PVM') {\n      if ((tx as UnsignedTx)?.tx?._type && PermissionlessValidatorTxBuilder.verifyTxType((tx as UnsignedTx).tx._type)) {\n        transactionBuilder = this.getPermissionlessValidatorTxBuilder();\n        transactionBuilder.initBuilder(tx);\n      } else if (ValidatorTxBuilder.verifyTxType((tx as PVMTx).getUnsignedTx().getTransaction())) {\n        transactionBuilder = this.getValidatorBuilder();\n        transactionBuilder.initBuilder(tx as PVMTx);\n      } else if (ExportTxBuilder.verifyTxType((tx as PVMTx).getUnsignedTx().getTransaction())) {\n        transactionBuilder = this.getExportBuilder();\n        transactionBuilder.initBuilder(tx as PVMTx);\n      } else if (ImportTxBuilder.verifyTxType((tx as PVMTx).getUnsignedTx().getTransaction())) {\n        transactionBuilder = this.getImportBuilder();\n        transactionBuilder.initBuilder(tx as PVMTx);\n      }\n    } else if (txSource === 'EVM') {\n      if (ImportInCTxBuilder.verifyTxType((tx as EVMTx).getUnsignedTx().getTransaction())) {\n        transactionBuilder = this.getImportInCBuilder();\n        transactionBuilder.initBuilder(tx as EVMTx);\n      } else if (ExportInCTxBuilder.verifyTxType((tx as EVMTx).getUnsignedTx().getTransaction())) {\n        transactionBuilder = this.getExportInCBuilder();\n        transactionBuilder.initBuilder(tx as EVMTx);\n      }\n    }\n    if (transactionBuilder === undefined) {\n      throw new NotSupported('Transaction cannot be parsed or has an unsupported transaction type');\n    }\n    return transactionBuilder;\n  }\n\n  /** @inheritdoc */\n  getTransferBuilder(): DeprecatedTransactionBuilder {\n    throw new NotSupported('Transfer is not supported in P Chain');\n  }\n\n  /**\n   * Initialize Validator builder\n   *\n   * @returns {ValidatorTxBuilder} the builder initialized\n   */\n  getValidatorBuilder(): ValidatorTxBuilder {\n    return new ValidatorTxBuilder(this._coinConfig);\n  }\n\n  /**\n   * Initialize Permissionless Validator builder\n   *\n   * @returns {PermissionlessValidatorTxBuilder} the builder initialized\n   */\n  getPermissionlessValidatorTxBuilder(): PermissionlessValidatorTxBuilder {\n    return new PermissionlessValidatorTxBuilder(this._coinConfig);\n  }\n\n  /**\n   * Export Cross chain transfer\n   *\n   * @returns {ExportTxBuilder} the builder initialized\n   */\n  getExportBuilder(): ExportTxBuilder {\n    return new ExportTxBuilder(this._coinConfig);\n  }\n\n  /**\n   * Import Cross chain transfer\n   *\n   * @returns {ImportTxBuilder} the builder initialized\n   */\n  getImportBuilder(): ImportTxBuilder {\n    return new ImportTxBuilder(this._coinConfig);\n  }\n\n  /**\n   * Import in C chain Cross chain transfer\n   *\n   * @returns {ImportInCTxBuilder} the builder initialized\n   */\n  getImportInCBuilder(): ImportInCTxBuilder {\n    return new ImportInCTxBuilder(this._coinConfig);\n  }\n\n  /**\n   * Export in C chain Cross chain transfer\n   *\n   * @returns {ExportInCTxBuilder} the builder initialized\n   */\n  getExportInCBuilder(): ExportInCTxBuilder {\n    return new ExportInCTxBuilder(this._coinConfig);\n  }\n\n  /** @inheritdoc */\n  getWalletInitializationBuilder(): DeprecatedTransactionBuilder {\n    throw new NotSupported('Wallet initialization is not needed');\n  }\n}\n"]}
|
package/dist/src/lib/utils.d.ts
CHANGED
|
@@ -1,15 +1,15 @@
|
|
|
1
|
-
|
|
1
|
+
import { Signature as AvaxSignature, TransferableOutput } from '@bitgo-forks/avalanchejs';
|
|
2
2
|
import { BaseUtils, Entry } from '@bitgo-beta/sdk-core';
|
|
3
|
-
import { Buffer as BufferAvax } from 'avalanche';
|
|
4
|
-
import { NodeIDStringToBuffer } from 'avalanche/dist/utils';
|
|
5
|
-
import { BaseTx, TransferableOutput } from 'avalanche/dist/apis/platformvm';
|
|
6
|
-
import { Credential } from 'avalanche/dist/common/credentials';
|
|
7
3
|
import { AvalancheNetwork } from '@bitgo-beta/statics';
|
|
4
|
+
import { Buffer as BufferAvax } from 'avalanche';
|
|
5
|
+
import { BaseTx, TransferableOutput as DeprecatedTransferableOutput } from 'avalanche/dist/apis/platformvm';
|
|
8
6
|
import { Signature } from 'avalanche/dist/common';
|
|
9
|
-
import {
|
|
7
|
+
import { Credential } from 'avalanche/dist/common/credentials';
|
|
8
|
+
import { NodeIDStringToBuffer } from 'avalanche/dist/utils';
|
|
9
|
+
import { DeprecatedOutput, DeprecatedTx, Output } from './iface';
|
|
10
10
|
export declare class Utils implements BaseUtils {
|
|
11
11
|
private binTools;
|
|
12
|
-
cb58Decode: (bytes:
|
|
12
|
+
cb58Decode: (bytes: BufferAvax | string) => BufferAvax;
|
|
13
13
|
cb58Encode: (bytes: BufferAvax) => string;
|
|
14
14
|
stringToBuffer: (str: string) => BufferAvax;
|
|
15
15
|
bufferToString: (buff: BufferAvax) => string;
|
|
@@ -101,6 +101,7 @@ export declare class Utils implements BaseUtils {
|
|
|
101
101
|
*/
|
|
102
102
|
verifySignature(network: AvalancheNetwork, message: Buffer, signature: Buffer, prv: Buffer): boolean;
|
|
103
103
|
createSig(sigHex: string): Signature;
|
|
104
|
+
createNewSig(sigHex: string): AvaxSignature;
|
|
104
105
|
/**
|
|
105
106
|
* Avaxp wrapper to recovery signature using Avalanche's buffer
|
|
106
107
|
* @param network
|
|
@@ -128,11 +129,18 @@ export declare class Utils implements BaseUtils {
|
|
|
128
129
|
/**
|
|
129
130
|
* Check if tx is for the blockchainId
|
|
130
131
|
*
|
|
131
|
-
* @param {
|
|
132
|
+
* @param {DeprecatedTx} tx
|
|
132
133
|
* @param {string} blockchainId
|
|
133
134
|
* @returns true if tx is for blockchainId
|
|
134
135
|
*/
|
|
135
|
-
isTransactionOf(tx:
|
|
136
|
+
isTransactionOf(tx: DeprecatedTx, blockchainId: string): boolean;
|
|
137
|
+
/**
|
|
138
|
+
* Check if Output is from PVM.
|
|
139
|
+
* Output could be EVM or PVM output.
|
|
140
|
+
* @param {DeprecatedOutput} output
|
|
141
|
+
* @returns {boolean} output is DeprecatedTransferableOutput
|
|
142
|
+
*/
|
|
143
|
+
deprecatedIsTransferableOutput(output: DeprecatedOutput): output is DeprecatedTransferableOutput;
|
|
136
144
|
/**
|
|
137
145
|
* Check if Output is from PVM.
|
|
138
146
|
* Output could be EVM or PVM output.
|
|
@@ -140,6 +148,12 @@ export declare class Utils implements BaseUtils {
|
|
|
140
148
|
* @returns {boolean} output is TransferableOutput
|
|
141
149
|
*/
|
|
142
150
|
isTransferableOutput(output: Output): output is TransferableOutput;
|
|
151
|
+
/**
|
|
152
|
+
* Return a mapper function to that network address representation.
|
|
153
|
+
* @param network required to stringify addresses
|
|
154
|
+
* @return mapper function
|
|
155
|
+
*/
|
|
156
|
+
deprecatedMapOutputToEntry(network: AvalancheNetwork): (DeprecatedOutput: any) => Entry;
|
|
143
157
|
/**
|
|
144
158
|
* Return a mapper function to that network address representation.
|
|
145
159
|
* @param network required to stringify addresses
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"utils.d.ts","sourceRoot":"","sources":["../../../src/lib/utils.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"utils.d.ts","sourceRoot":"","sources":["../../../src/lib/utils.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,IAAI,aAAa,EAAE,kBAAkB,EAA+B,MAAM,0BAA0B,CAAC;AACvH,OAAO,EACL,SAAS,EACT,KAAK,EAMN,MAAM,sBAAsB,CAAC;AAC9B,OAAO,EAAE,gBAAgB,EAAE,MAAM,qBAAqB,CAAC;AACvD,OAAO,EAAgB,MAAM,IAAI,UAAU,EAAE,MAAM,WAAW,CAAC;AAE/D,OAAO,EAEL,MAAM,EACN,kBAAkB,IAAI,4BAA4B,EAEnD,MAAM,gCAAgC,CAAC;AAExC,OAAO,EAAE,SAAS,EAAE,MAAM,uBAAuB,CAAC;AAClD,OAAO,EAAE,UAAU,EAAE,MAAM,mCAAmC,CAAC;AAC/D,OAAO,EAAE,oBAAoB,EAAE,MAAM,sBAAsB,CAAC;AAG5D,OAAO,EAAqB,gBAAgB,EAAE,YAAY,EAAE,MAAM,EAAE,MAAM,SAAS,CAAC;AAEpF,qBAAa,KAAM,YAAW,SAAS;IACrC,OAAO,CAAC,QAAQ,CAA0B;IACnC,UAAU,6CAA4B;IACtC,UAAU,gCAA4B;IACtC,cAAc,8BAAgC;IAC9C,cAAc,+BAAgC;IAC9C,oBAAoB,8BAAwB;IAC5C,eAAe,8DAAiC;IAEhD,SAAS,CAAC,eAAe,EAAE,MAAM,EAAE,EAAE,mBAAmB,EAAE,MAAM,EAAE,GAAG,OAAO;IAInF;;;;;OAKG;IACH,kBAAkB;IAClB,cAAc,CAAC,OAAO,EAAE,MAAM,GAAG,MAAM,EAAE,GAAG,OAAO;IAYnD,OAAO,CAAC,mBAAmB;IAI3B;;;;;OAKG;IACH,kBAAkB;IAClB,cAAc,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO;IAIrC;;;;;;OAMG;IACH,gBAAgB,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO;IAiC/B,YAAY,QAAS,MAAM,KAAG,UAAU,CAAuC;IAEtF;;;;;;;;;;OAUG;IACH,iBAAiB,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO;IAUvC;;;;;OAKG;IACH,WAAW,CAAC,KAAK,EAAE,MAAM,GAAG,OAAO;IAInC,kBAAkB;IAClB,gBAAgB,CAAC,SAAS,EAAE,MAAM,GAAG,OAAO;IAI5C,kBAAkB;IAClB,oBAAoB,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO;IAI3C,cAAc,CAAC,EAAE,EAAE,MAAM,GAAG,UAAU,EAAE;IAIxC;;;;;;OAMG;IACH,yBAAyB,CAAC,OAAO,EAAE,gBAAgB,EAAE,OAAO,EAAE,UAAU,EAAE,GAAG,EAAE,UAAU,GAAG,UAAU;IAMtG;;;;;;OAMG;IACH,eAAe,CAAC,OAAO,EAAE,gBAAgB,EAAE,OAAO,EAAE,MAAM,EAAE,GAAG,EAAE,MAAM,GAAG,MAAM;IAIhF;;;;;;;OAOG;IACH,yBAAyB,CACvB,OAAO,EAAE,gBAAgB,EACzB,OAAO,EAAE,UAAU,EACnB,SAAS,EAAE,UAAU,EACrB,GAAG,EAAE,UAAU,GACd,OAAO;IAMV;;;;;;;OAOG;IACH,eAAe,CAAC,OAAO,EAAE,gBAAgB,EAAE,OAAO,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,EAAE,GAAG,EAAE,MAAM,GAAG,OAAO;IASpG,SAAS,CAAC,MAAM,EAAE,MAAM,GAAG,SAAS;IAMpC,YAAY,CAAC,MAAM,EAAE,MAAM,GAAG,aAAa;IAK3C;;;;;;OAMG;IACH,2BAA2B,CAAC,OAAO,EAAE,gBAAgB,EAAE,OAAO,EAAE,UAAU,EAAE,SAAS,EAAE,UAAU,GAAG,UAAU;IAK9G;;;;;;OAMG;IACH,iBAAiB,CAAC,OAAO,EAAE,gBAAgB,EAAE,OAAO,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,GAAG,MAAM;IAIxF,MAAM,CAAC,GAAG,EAAE,UAAU,GAAG,MAAM;IAI/B;;;;;OAKG;IACH,sBAAsB,CAAC,cAAc,EAAE,MAAM,GAAG,IAAI;IASpD;;;;;;OAMG;IACH,eAAe,CAAC,EAAE,EAAE,YAAY,EAAE,YAAY,EAAE,MAAM,GAAG,OAAO;IAIhE;;;;;OAKG;IACH,8BAA8B,CAAC,MAAM,EAAE,gBAAgB,GAAG,MAAM,IAAI,4BAA4B;IAIhG;;;;;OAKG;IACH,oBAAoB,CAAC,MAAM,EAAE,MAAM,GAAG,MAAM,IAAI,kBAAkB;IAIlE;;;;OAIG;IACH,0BAA0B,CAAC,OAAO,EAAE,gBAAgB,GAAG,CAAC,gBAAgB,KAAA,KAAK,KAAK;IAyBlF;;;;OAIG;IACH,gBAAgB,CAAC,OAAO,EAAE,gBAAgB,GAAG,CAAC,MAAM,KAAA,KAAK,KAAK;IAmB9D;;;;OAIG;IACH,eAAe,CAAC,GAAG,EAAE,MAAM,GAAG,MAAM;IAOpC;;;;OAIG;IACH,uBAAuB,CAAC,SAAS,EAAE,MAAM,GAAG,UAAU;IAItD;;;;OAIG;IACH,uBAAuB,CAAC,SAAS,EAAE,UAAU,GAAG,MAAM;CAGvD;AAED,QAAA,MAAM,KAAK,OAAc,CAAC;AAE1B,eAAe,KAAK,CAAC"}
|
package/dist/src/lib/utils.js
CHANGED
|
@@ -1,7 +1,11 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
3
|
if (k2 === undefined) k2 = k;
|
|
4
|
-
Object.
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
5
9
|
}) : (function(o, m, k, k2) {
|
|
6
10
|
if (k2 === undefined) k2 = k;
|
|
7
11
|
o[k2] = m[k];
|
|
@@ -11,23 +15,34 @@ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (
|
|
|
11
15
|
}) : function(o, v) {
|
|
12
16
|
o["default"] = v;
|
|
13
17
|
});
|
|
14
|
-
var __importStar = (this && this.__importStar) || function (
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
};
|
|
18
|
+
var __importStar = (this && this.__importStar) || (function () {
|
|
19
|
+
var ownKeys = function(o) {
|
|
20
|
+
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
21
|
+
var ar = [];
|
|
22
|
+
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
23
|
+
return ar;
|
|
24
|
+
};
|
|
25
|
+
return ownKeys(o);
|
|
26
|
+
};
|
|
27
|
+
return function (mod) {
|
|
28
|
+
if (mod && mod.__esModule) return mod;
|
|
29
|
+
var result = {};
|
|
30
|
+
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
31
|
+
__setModuleDefault(result, mod);
|
|
32
|
+
return result;
|
|
33
|
+
};
|
|
34
|
+
})();
|
|
21
35
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
22
36
|
exports.Utils = void 0;
|
|
37
|
+
const avalanchejs_1 = require("@bitgo-forks/avalanchejs");
|
|
23
38
|
const sdk_core_1 = require("@bitgo-beta/sdk-core");
|
|
24
39
|
const avalanche_1 = require("avalanche");
|
|
25
|
-
const utils_1 = require("avalanche/dist/utils");
|
|
26
|
-
const elliptic_1 = require("elliptic");
|
|
27
40
|
const platformvm_1 = require("avalanche/dist/apis/platformvm");
|
|
28
41
|
const keychain_1 = require("avalanche/dist/apis/platformvm/keychain");
|
|
29
42
|
const common_1 = require("avalanche/dist/common");
|
|
43
|
+
const utils_1 = require("avalanche/dist/utils");
|
|
30
44
|
const createHash = __importStar(require("create-hash"));
|
|
45
|
+
const secp256k1_1 = require("@noble/curves/secp256k1");
|
|
31
46
|
const iface_1 = require("./iface");
|
|
32
47
|
class Utils {
|
|
33
48
|
constructor() {
|
|
@@ -80,7 +95,7 @@ class Utils {
|
|
|
80
95
|
* @returns {boolean} - the validation result
|
|
81
96
|
*/
|
|
82
97
|
isValidPublicKey(pub) {
|
|
83
|
-
if (sdk_core_1.isValidXpub(pub))
|
|
98
|
+
if ((0, sdk_core_1.isValidXpub)(pub))
|
|
84
99
|
return true;
|
|
85
100
|
let pubBuf;
|
|
86
101
|
if (pub.length === 50) {
|
|
@@ -106,11 +121,9 @@ class Utils {
|
|
|
106
121
|
pubBuf = avalanche_1.Buffer.from(pub, 'hex');
|
|
107
122
|
}
|
|
108
123
|
// validate the public key
|
|
109
|
-
const secp256k1 = new elliptic_1.ec('secp256k1');
|
|
110
124
|
try {
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
return result;
|
|
125
|
+
secp256k1_1.secp256k1.ProjectivePoint.fromHex(pubBuf.toString('hex'));
|
|
126
|
+
return true;
|
|
114
127
|
}
|
|
115
128
|
catch (e) {
|
|
116
129
|
return false;
|
|
@@ -128,7 +141,7 @@ class Utils {
|
|
|
128
141
|
* @returns {boolean} - the validation result
|
|
129
142
|
*/
|
|
130
143
|
isValidPrivateKey(prv) {
|
|
131
|
-
if (sdk_core_1.isValidXprv(prv))
|
|
144
|
+
if ((0, sdk_core_1.isValidXprv)(prv))
|
|
132
145
|
return true;
|
|
133
146
|
if (prv.length !== 64 && prv.length !== 66)
|
|
134
147
|
return false;
|
|
@@ -154,7 +167,7 @@ class Utils {
|
|
|
154
167
|
throw new sdk_core_1.NotImplementedError('isValidTransactionId not implemented');
|
|
155
168
|
}
|
|
156
169
|
getCredentials(tx) {
|
|
157
|
-
return tx.getIns().map((ins) => platformvm_1.SelectCredentialClass(ins.getInput().getCredentialID()));
|
|
170
|
+
return tx.getIns().map((ins) => (0, platformvm_1.SelectCredentialClass)(ins.getInput().getCredentialID()));
|
|
158
171
|
}
|
|
159
172
|
/**
|
|
160
173
|
* Avaxp wrapper to create signature and return it for credentials using Avalanche's buffer
|
|
@@ -207,6 +220,10 @@ class Utils {
|
|
|
207
220
|
sig.fromBuffer(avalanche_1.Buffer.from(sigHex.padStart(130, '0'), 'hex'));
|
|
208
221
|
return sig;
|
|
209
222
|
}
|
|
223
|
+
createNewSig(sigHex) {
|
|
224
|
+
const buffer = avalanche_1.Buffer.from(sigHex.padStart(130, '0'), 'hex');
|
|
225
|
+
return new avalanchejs_1.Signature(buffer);
|
|
226
|
+
}
|
|
210
227
|
/**
|
|
211
228
|
* Avaxp wrapper to recovery signature using Avalanche's buffer
|
|
212
229
|
* @param network
|
|
@@ -248,13 +265,22 @@ class Utils {
|
|
|
248
265
|
/**
|
|
249
266
|
* Check if tx is for the blockchainId
|
|
250
267
|
*
|
|
251
|
-
* @param {
|
|
268
|
+
* @param {DeprecatedTx} tx
|
|
252
269
|
* @param {string} blockchainId
|
|
253
270
|
* @returns true if tx is for blockchainId
|
|
254
271
|
*/
|
|
255
272
|
isTransactionOf(tx, blockchainId) {
|
|
256
273
|
return utils.cb58Encode(tx.getUnsignedTx().getTransaction().getBlockchainID()) === blockchainId;
|
|
257
274
|
}
|
|
275
|
+
/**
|
|
276
|
+
* Check if Output is from PVM.
|
|
277
|
+
* Output could be EVM or PVM output.
|
|
278
|
+
* @param {DeprecatedOutput} output
|
|
279
|
+
* @returns {boolean} output is DeprecatedTransferableOutput
|
|
280
|
+
*/
|
|
281
|
+
deprecatedIsTransferableOutput(output) {
|
|
282
|
+
return 'getOutput' in output;
|
|
283
|
+
}
|
|
258
284
|
/**
|
|
259
285
|
* Check if Output is from PVM.
|
|
260
286
|
* Output could be EVM or PVM output.
|
|
@@ -262,16 +288,16 @@ class Utils {
|
|
|
262
288
|
* @returns {boolean} output is TransferableOutput
|
|
263
289
|
*/
|
|
264
290
|
isTransferableOutput(output) {
|
|
265
|
-
return
|
|
291
|
+
return output?._type === avalanchejs_1.TypeSymbols.TransferableOutput;
|
|
266
292
|
}
|
|
267
293
|
/**
|
|
268
294
|
* Return a mapper function to that network address representation.
|
|
269
295
|
* @param network required to stringify addresses
|
|
270
296
|
* @return mapper function
|
|
271
297
|
*/
|
|
272
|
-
|
|
298
|
+
deprecatedMapOutputToEntry(network) {
|
|
273
299
|
return (output) => {
|
|
274
|
-
if (this.
|
|
300
|
+
if (this.deprecatedIsTransferableOutput(output)) {
|
|
275
301
|
const amountOutput = output.getOutput();
|
|
276
302
|
const address = amountOutput
|
|
277
303
|
.getAddresses()
|
|
@@ -294,6 +320,30 @@ class Utils {
|
|
|
294
320
|
}
|
|
295
321
|
};
|
|
296
322
|
}
|
|
323
|
+
/**
|
|
324
|
+
* Return a mapper function to that network address representation.
|
|
325
|
+
* @param network required to stringify addresses
|
|
326
|
+
* @return mapper function
|
|
327
|
+
*/
|
|
328
|
+
mapOutputToEntry(network) {
|
|
329
|
+
return (output) => {
|
|
330
|
+
if (this.isTransferableOutput(output)) {
|
|
331
|
+
const outputAmount = output.amount();
|
|
332
|
+
const address = output.output
|
|
333
|
+
.getOwners()
|
|
334
|
+
.map((a) => this.addressToString(network.hrp, network.alias, avalanche_1.Buffer.from(a)))
|
|
335
|
+
.sort()
|
|
336
|
+
.join(iface_1.ADDRESS_SEPARATOR);
|
|
337
|
+
return {
|
|
338
|
+
value: outputAmount.toString(),
|
|
339
|
+
address,
|
|
340
|
+
};
|
|
341
|
+
}
|
|
342
|
+
else {
|
|
343
|
+
throw new Error('Invalid output type');
|
|
344
|
+
}
|
|
345
|
+
};
|
|
346
|
+
}
|
|
297
347
|
/**
|
|
298
348
|
* remove hex prefix (0x)
|
|
299
349
|
* @param hex string
|
|
@@ -325,4 +375,4 @@ class Utils {
|
|
|
325
375
|
exports.Utils = Utils;
|
|
326
376
|
const utils = new Utils();
|
|
327
377
|
exports.default = utils;
|
|
328
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"utils.js","sourceRoot":"","sources":["../../../src/lib/utils.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  isValidXpub,\n  isValidXprv,\n  NotImplementedError,\n  BaseUtils,\n  InvalidTransactionError,\n  ParseTransactionError,\n  Entry,\n} from '@bitgo-beta/sdk-core';\nimport { BinTools, BN, Buffer as BufferAvax } from 'avalanche';\nimport { NodeIDStringToBuffer } from 'avalanche/dist/utils';\nimport { ec } from 'elliptic';\nimport { AmountOutput, BaseTx, SelectCredentialClass, TransferableOutput } from 'avalanche/dist/apis/platformvm';\nimport { Credential } from 'avalanche/dist/common/credentials';\nimport { KeyPair as KeyPairAvax } from 'avalanche/dist/apis/platformvm/keychain';\nimport { AvalancheNetwork } from '@bitgo-beta/statics';\nimport { Signature } from 'avalanche/dist/common';\nimport * as createHash from 'create-hash';\nimport { EVMOutput } from 'avalanche/dist/apis/evm';\nimport { ADDRESS_SEPARATOR, Output, Tx } from './iface';\n\nexport class Utils implements BaseUtils {\n  private binTools = BinTools.getInstance();\n  public cb58Decode = this.binTools.cb58Decode;\n  public cb58Encode = this.binTools.cb58Encode;\n  public stringToBuffer = this.binTools.stringToBuffer;\n  public bufferToString = this.binTools.bufferToString;\n  public NodeIDStringToBuffer = NodeIDStringToBuffer;\n  public addressToString = this.binTools.addressToString;\n\n  public includeIn(walletAddresses: string[], otxoOutputAddresses: string[]): boolean {\n    return walletAddresses.map((a) => otxoOutputAddresses.includes(a)).reduce((a, b) => a && b, true);\n  }\n\n  /**\n   * Checks if it is a valid address no illegal characters\n   *\n   * @param {string} address - address to be validated\n   * @returns {boolean} - the validation result\n   */\n  /** @inheritdoc */\n  isValidAddress(address: string | string[]): boolean {\n    const addressArr: string[] = Array.isArray(address) ? address : address.split('~');\n\n    for (const address of addressArr) {\n      if (!this.isValidAddressRegex(address)) {\n        return false;\n      }\n    }\n\n    return true;\n  }\n\n  private isValidAddressRegex(address: string): boolean {\n    return /^(^P||NodeID)-[a-zA-Z0-9]+$/.test(address);\n  }\n\n  /**\n   * Checks if it is a valid blockId with length 66 including 0x\n   *\n   * @param {string} hash - blockId to be validated\n   * @returns {boolean} - the validation result\n   */\n  /** @inheritdoc */\n  isValidBlockId(hash: string): boolean {\n    return this.binTools.isCB58(hash) && this.binTools.b58ToBuffer(hash).length === 36;\n  }\n\n  /**\n   * Checks if the string is a valid protocol public key or\n   * extended public key.\n   *\n   * @param {string} pub - the  public key to be validated\n   * @returns {boolean} - the validation result\n   */\n  isValidPublicKey(pub: string): boolean {\n    if (isValidXpub(pub)) return true;\n\n    let pubBuf;\n    if (pub.length === 50) {\n      try {\n        pubBuf = utils.cb58Decode(pub);\n      } catch {\n        return false;\n      }\n    } else {\n      if (pub.length !== 66 && pub.length !== 130) return false;\n\n      const firstByte = pub.slice(0, 2);\n\n      // uncompressed public key\n      if (pub.length === 130 && firstByte !== '04') return false;\n\n      // compressed public key\n      if (pub.length === 66 && firstByte !== '02' && firstByte !== '03') return false;\n\n      if (!this.allHexChars(pub)) return false;\n\n      pubBuf = BufferAvax.from(pub, 'hex');\n    }\n    // validate the public key\n    const secp256k1 = new ec('secp256k1');\n    try {\n      const keyPair = secp256k1.keyFromPublic(pubBuf);\n      const { result } = keyPair.validate();\n      return result;\n    } catch (e) {\n      return false;\n    }\n  }\n\n  public parseAddress = (pub: string): BufferAvax => this.binTools.stringToAddress(pub);\n\n  /**\n   * Returns whether or not the string is a valid protocol private key, or extended\n   * private key.\n   *\n   * The protocol key format is described in the @stacks/transactions npm package, in the\n   * createStacksPrivateKey function:\n   * https://github.com/blockstack/stacks.js/blob/master/packages/transactions/src/keys.ts#L125\n   *\n   * @param {string} prv - the private key (or extended private key) to be validated\n   * @returns {boolean} - the validation result\n   */\n  isValidPrivateKey(prv: string): boolean {\n    if (isValidXprv(prv)) return true;\n\n    if (prv.length !== 64 && prv.length !== 66) return false;\n\n    if (prv.length === 66 && prv.slice(64) !== '01') return false;\n\n    return this.allHexChars(prv);\n  }\n\n  /**\n   * Returns whether or not the string is a composed of hex chars only\n   *\n   * @param {string} maybe - the  string to be validated\n   * @returns {boolean} - the validation result\n   */\n  allHexChars(maybe: string): boolean {\n    return /^(0x){0,1}([0-9a-f])+$/i.test(maybe);\n  }\n\n  /** @inheritdoc */\n  isValidSignature(signature: string): boolean {\n    throw new NotImplementedError('isValidSignature not implemented');\n  }\n\n  /** @inheritdoc */\n  isValidTransactionId(txId: string): boolean {\n    throw new NotImplementedError('isValidTransactionId not implemented');\n  }\n\n  getCredentials(tx: BaseTx): Credential[] {\n    return tx.getIns().map((ins) => SelectCredentialClass(ins.getInput().getCredentialID()));\n  }\n\n  /**\n   * Avaxp wrapper to create signature and return it for credentials using Avalanche's buffer\n   * @param network\n   * @param message\n   * @param prv\n   * @return signature\n   */\n  createSignatureAvaxBuffer(network: AvalancheNetwork, message: BufferAvax, prv: BufferAvax): BufferAvax {\n    const ky = new KeyPairAvax(network.hrp, network.networkID.toString());\n    ky.importKey(prv);\n    return ky.sign(message);\n  }\n\n  /**\n   * Avaxp wrapper to create signature and return it for credentials\n   * @param network\n   * @param message\n   * @param prv\n   * @return signature\n   */\n  createSignature(network: AvalancheNetwork, message: Buffer, prv: Buffer): Buffer {\n    return Buffer.from(this.createSignatureAvaxBuffer(network, BufferAvax.from(message), BufferAvax.from(prv)));\n  }\n\n  /**\n   * Avaxp wrapper to verify signature using Avalanche's buffer\n   * @param network\n   * @param message\n   * @param signature\n   * @param prv\n   * @return true if it's verify successful\n   */\n  verifySignatureAvaxBuffer(\n    network: AvalancheNetwork,\n    message: BufferAvax,\n    signature: BufferAvax,\n    prv: BufferAvax\n  ): boolean {\n    const ky = new KeyPairAvax(network.hrp, network.networkID.toString());\n    ky.importKey(prv);\n    return ky.verify(message, signature);\n  }\n\n  /**\n   * Avaxp wrapper to verify signature\n   * @param network\n   * @param message\n   * @param signature\n   * @param prv\n   * @return true if it's verify successful\n   */\n  verifySignature(network: AvalancheNetwork, message: Buffer, signature: Buffer, prv: Buffer): boolean {\n    return this.verifySignatureAvaxBuffer(\n      network,\n      BufferAvax.from(message),\n      BufferAvax.from(signature),\n      BufferAvax.from(prv)\n    );\n  }\n\n  createSig(sigHex: string): Signature {\n    const sig = new Signature();\n    sig.fromBuffer(BufferAvax.from(sigHex.padStart(130, '0'), 'hex'));\n    return sig;\n  }\n\n  /**\n   * Avaxp wrapper to recovery signature using Avalanche's buffer\n   * @param network\n   * @param message\n   * @param signature\n   * @return\n   */\n  recoverySignatureAvaxBuffer(network: AvalancheNetwork, message: BufferAvax, signature: BufferAvax): BufferAvax {\n    const ky = new KeyPairAvax(network.hrp, network.networkID.toString());\n    return ky.recover(message, signature);\n  }\n\n  /**\n   * Avaxp wrapper to verify signature\n   * @param network\n   * @param message\n   * @param signature\n   * @return true if it's verify successful\n   */\n  recoverySignature(network: AvalancheNetwork, message: Buffer, signature: Buffer): Buffer {\n    return Buffer.from(this.recoverySignatureAvaxBuffer(network, BufferAvax.from(message), BufferAvax.from(signature)));\n  }\n\n  sha256(buf: Uint8Array): Buffer {\n    return createHash.default('sha256').update(buf).digest();\n  }\n\n  /**\n   * Check the raw transaction has a valid format in the blockchain context, throw otherwise.\n   * It's to reuse in TransactionBuilder and TransactionBuilderFactory\n   *\n   * @param rawTransaction Transaction as hex string\n   */\n  validateRawTransaction(rawTransaction: string): void {\n    if (!rawTransaction) {\n      throw new InvalidTransactionError('Raw transaction is empty');\n    }\n    if (!utils.allHexChars(rawTransaction)) {\n      throw new ParseTransactionError('Raw transaction is not hex string');\n    }\n  }\n\n  /**\n   * Check if tx is for the blockchainId\n   *\n   * @param {Tx} tx\n   * @param {string} blockchainId\n   * @returns true if tx is for blockchainId\n   */\n  isTransactionOf(tx: Tx, blockchainId: string): boolean {\n    return utils.cb58Encode(tx.getUnsignedTx().getTransaction().getBlockchainID()) === blockchainId;\n  }\n\n  /**\n   * Check if Output is from PVM.\n   * Output could be EVM or PVM output.\n   * @param {Output} output\n   * @returns {boolean} output is TransferableOutput\n   */\n  isTransferableOutput(output: Output): output is TransferableOutput {\n    return 'getOutput' in output;\n  }\n\n  /**\n   * Return a mapper function to that network address representation.\n   * @param network required to stringify addresses\n   * @return mapper function\n   */\n  mapOutputToEntry(network: AvalancheNetwork): (Output) => Entry {\n    return (output: Output) => {\n      if (this.isTransferableOutput(output)) {\n        const amountOutput = output.getOutput() as AmountOutput;\n        const address = amountOutput\n          .getAddresses()\n          .map((a) => this.addressToString(network.hrp, network.alias, a))\n          .sort()\n          .join(ADDRESS_SEPARATOR);\n        return {\n          value: amountOutput.getAmount().toString(),\n          address,\n        };\n      } else {\n        const evmOutput = output as EVMOutput;\n        return {\n          // it should be evmOuput.getAmount(), but it returns a 0.\n          value: new BN((evmOutput as any).amount).toString(),\n          // C-Chain address.\n          address: '0x' + evmOutput.getAddressString(),\n        };\n      }\n    };\n  }\n\n  /**\n   * remove hex prefix (0x)\n   * @param hex string\n   * @returns hex without 0x\n   */\n  removeHexPrefix(hex: string): string {\n    if (hex.startsWith('0x')) {\n      return hex.substring(2);\n    }\n    return hex;\n  }\n\n  /**\n   * Outputidx convert from number (as string) to buffer.\n   * @param {string} outputidx number\n   * @return {BufferAvax} buffer of size 4 with that number value\n   */\n  outputidxNumberToBuffer(outputidx: string): BufferAvax {\n    return BufferAvax.from(Number(outputidx).toString(16).padStart(8, '0'), 'hex');\n  }\n\n  /**\n   * Outputidx buffer to number (as string)\n   * @param {BufferAvax} outputidx\n   * @return {string} outputidx number\n   */\n  outputidxBufferToNumber(outputidx: BufferAvax): string {\n    return parseInt(outputidx.toString('hex'), 16).toString();\n  }\n}\n\nconst utils = new Utils();\n\nexport default utils;\n"]}
|
|
378
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"utils.js","sourceRoot":"","sources":["../../../src/lib/utils.ts"],"names":[],"mappings":"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","sourcesContent":["import { Signature as AvaxSignature, TransferableOutput, TransferOutput, TypeSymbols } from '@bitgo-forks/avalanchejs';\nimport {\n  BaseUtils,\n  Entry,\n  InvalidTransactionError,\n  isValidXprv,\n  isValidXpub,\n  NotImplementedError,\n  ParseTransactionError,\n} from '@bitgo-beta/sdk-core';\nimport { AvalancheNetwork } from '@bitgo-beta/statics';\nimport { BinTools, BN, Buffer as BufferAvax } from 'avalanche';\nimport { EVMOutput } from 'avalanche/dist/apis/evm';\nimport {\n  AmountOutput,\n  BaseTx,\n  TransferableOutput as DeprecatedTransferableOutput,\n  SelectCredentialClass,\n} from 'avalanche/dist/apis/platformvm';\nimport { KeyPair as KeyPairAvax } from 'avalanche/dist/apis/platformvm/keychain';\nimport { Signature } from 'avalanche/dist/common';\nimport { Credential } from 'avalanche/dist/common/credentials';\nimport { NodeIDStringToBuffer } from 'avalanche/dist/utils';\nimport * as createHash from 'create-hash';\nimport { secp256k1 } from '@noble/curves/secp256k1';\nimport { ADDRESS_SEPARATOR, DeprecatedOutput, DeprecatedTx, Output } from './iface';\n\nexport class Utils implements BaseUtils {\n  private binTools = BinTools.getInstance();\n  public cb58Decode = this.binTools.cb58Decode;\n  public cb58Encode = this.binTools.cb58Encode;\n  public stringToBuffer = this.binTools.stringToBuffer;\n  public bufferToString = this.binTools.bufferToString;\n  public NodeIDStringToBuffer = NodeIDStringToBuffer;\n  public addressToString = this.binTools.addressToString;\n\n  public includeIn(walletAddresses: string[], otxoOutputAddresses: string[]): boolean {\n    return walletAddresses.map((a) => otxoOutputAddresses.includes(a)).reduce((a, b) => a && b, true);\n  }\n\n  /**\n   * Checks if it is a valid address no illegal characters\n   *\n   * @param {string} address - address to be validated\n   * @returns {boolean} - the validation result\n   */\n  /** @inheritdoc */\n  isValidAddress(address: string | string[]): boolean {\n    const addressArr: string[] = Array.isArray(address) ? address : address.split('~');\n\n    for (const address of addressArr) {\n      if (!this.isValidAddressRegex(address)) {\n        return false;\n      }\n    }\n\n    return true;\n  }\n\n  private isValidAddressRegex(address: string): boolean {\n    return /^(^P||NodeID)-[a-zA-Z0-9]+$/.test(address);\n  }\n\n  /**\n   * Checks if it is a valid blockId with length 66 including 0x\n   *\n   * @param {string} hash - blockId to be validated\n   * @returns {boolean} - the validation result\n   */\n  /** @inheritdoc */\n  isValidBlockId(hash: string): boolean {\n    return this.binTools.isCB58(hash) && this.binTools.b58ToBuffer(hash).length === 36;\n  }\n\n  /**\n   * Checks if the string is a valid protocol public key or\n   * extended public key.\n   *\n   * @param {string} pub - the  public key to be validated\n   * @returns {boolean} - the validation result\n   */\n  isValidPublicKey(pub: string): boolean {\n    if (isValidXpub(pub)) return true;\n\n    let pubBuf;\n    if (pub.length === 50) {\n      try {\n        pubBuf = utils.cb58Decode(pub);\n      } catch {\n        return false;\n      }\n    } else {\n      if (pub.length !== 66 && pub.length !== 130) return false;\n\n      const firstByte = pub.slice(0, 2);\n\n      // uncompressed public key\n      if (pub.length === 130 && firstByte !== '04') return false;\n\n      // compressed public key\n      if (pub.length === 66 && firstByte !== '02' && firstByte !== '03') return false;\n\n      if (!this.allHexChars(pub)) return false;\n      pubBuf = BufferAvax.from(pub, 'hex');\n    }\n    // validate the public key\n    try {\n      secp256k1.ProjectivePoint.fromHex(pubBuf.toString('hex'));\n      return true;\n    } catch (e) {\n      return false;\n    }\n  }\n\n  public parseAddress = (pub: string): BufferAvax => this.binTools.stringToAddress(pub);\n\n  /**\n   * Returns whether or not the string is a valid protocol private key, or extended\n   * private key.\n   *\n   * The protocol key format is described in the @stacks/transactions npm package, in the\n   * createStacksPrivateKey function:\n   * https://github.com/blockstack/stacks.js/blob/master/packages/transactions/src/keys.ts#L125\n   *\n   * @param {string} prv - the private key (or extended private key) to be validated\n   * @returns {boolean} - the validation result\n   */\n  isValidPrivateKey(prv: string): boolean {\n    if (isValidXprv(prv)) return true;\n\n    if (prv.length !== 64 && prv.length !== 66) return false;\n\n    if (prv.length === 66 && prv.slice(64) !== '01') return false;\n\n    return this.allHexChars(prv);\n  }\n\n  /**\n   * Returns whether or not the string is a composed of hex chars only\n   *\n   * @param {string} maybe - the  string to be validated\n   * @returns {boolean} - the validation result\n   */\n  allHexChars(maybe: string): boolean {\n    return /^(0x){0,1}([0-9a-f])+$/i.test(maybe);\n  }\n\n  /** @inheritdoc */\n  isValidSignature(signature: string): boolean {\n    throw new NotImplementedError('isValidSignature not implemented');\n  }\n\n  /** @inheritdoc */\n  isValidTransactionId(txId: string): boolean {\n    throw new NotImplementedError('isValidTransactionId not implemented');\n  }\n\n  getCredentials(tx: BaseTx): Credential[] {\n    return tx.getIns().map((ins) => SelectCredentialClass(ins.getInput().getCredentialID()));\n  }\n\n  /**\n   * Avaxp wrapper to create signature and return it for credentials using Avalanche's buffer\n   * @param network\n   * @param message\n   * @param prv\n   * @return signature\n   */\n  createSignatureAvaxBuffer(network: AvalancheNetwork, message: BufferAvax, prv: BufferAvax): BufferAvax {\n    const ky = new KeyPairAvax(network.hrp, network.networkID.toString());\n    ky.importKey(prv);\n    return ky.sign(message);\n  }\n\n  /**\n   * Avaxp wrapper to create signature and return it for credentials\n   * @param network\n   * @param message\n   * @param prv\n   * @return signature\n   */\n  createSignature(network: AvalancheNetwork, message: Buffer, prv: Buffer): Buffer {\n    return Buffer.from(this.createSignatureAvaxBuffer(network, BufferAvax.from(message), BufferAvax.from(prv)));\n  }\n\n  /**\n   * Avaxp wrapper to verify signature using Avalanche's buffer\n   * @param network\n   * @param message\n   * @param signature\n   * @param prv\n   * @return true if it's verify successful\n   */\n  verifySignatureAvaxBuffer(\n    network: AvalancheNetwork,\n    message: BufferAvax,\n    signature: BufferAvax,\n    prv: BufferAvax\n  ): boolean {\n    const ky = new KeyPairAvax(network.hrp, network.networkID.toString());\n    ky.importKey(prv);\n    return ky.verify(message, signature);\n  }\n\n  /**\n   * Avaxp wrapper to verify signature\n   * @param network\n   * @param message\n   * @param signature\n   * @param prv\n   * @return true if it's verify successful\n   */\n  verifySignature(network: AvalancheNetwork, message: Buffer, signature: Buffer, prv: Buffer): boolean {\n    return this.verifySignatureAvaxBuffer(\n      network,\n      BufferAvax.from(message),\n      BufferAvax.from(signature),\n      BufferAvax.from(prv)\n    );\n  }\n\n  createSig(sigHex: string): Signature {\n    const sig = new Signature();\n    sig.fromBuffer(BufferAvax.from(sigHex.padStart(130, '0'), 'hex'));\n    return sig;\n  }\n\n  createNewSig(sigHex: string): AvaxSignature {\n    const buffer = BufferAvax.from(sigHex.padStart(130, '0'), 'hex');\n    return new AvaxSignature(buffer);\n  }\n\n  /**\n   * Avaxp wrapper to recovery signature using Avalanche's buffer\n   * @param network\n   * @param message\n   * @param signature\n   * @return\n   */\n  recoverySignatureAvaxBuffer(network: AvalancheNetwork, message: BufferAvax, signature: BufferAvax): BufferAvax {\n    const ky = new KeyPairAvax(network.hrp, network.networkID.toString());\n    return ky.recover(message, signature);\n  }\n\n  /**\n   * Avaxp wrapper to verify signature\n   * @param network\n   * @param message\n   * @param signature\n   * @return true if it's verify successful\n   */\n  recoverySignature(network: AvalancheNetwork, message: Buffer, signature: Buffer): Buffer {\n    return Buffer.from(this.recoverySignatureAvaxBuffer(network, BufferAvax.from(message), BufferAvax.from(signature)));\n  }\n\n  sha256(buf: Uint8Array): Buffer {\n    return createHash.default('sha256').update(buf).digest();\n  }\n\n  /**\n   * Check the raw transaction has a valid format in the blockchain context, throw otherwise.\n   * It's to reuse in TransactionBuilder and TransactionBuilderFactory\n   *\n   * @param rawTransaction Transaction as hex string\n   */\n  validateRawTransaction(rawTransaction: string): void {\n    if (!rawTransaction) {\n      throw new InvalidTransactionError('Raw transaction is empty');\n    }\n    if (!utils.allHexChars(rawTransaction)) {\n      throw new ParseTransactionError('Raw transaction is not hex string');\n    }\n  }\n\n  /**\n   * Check if tx is for the blockchainId\n   *\n   * @param {DeprecatedTx} tx\n   * @param {string} blockchainId\n   * @returns true if tx is for blockchainId\n   */\n  isTransactionOf(tx: DeprecatedTx, blockchainId: string): boolean {\n    return utils.cb58Encode((tx as DeprecatedTx).getUnsignedTx().getTransaction().getBlockchainID()) === blockchainId;\n  }\n\n  /**\n   * Check if Output is from PVM.\n   * Output could be EVM or PVM output.\n   * @param {DeprecatedOutput} output\n   * @returns {boolean} output is DeprecatedTransferableOutput\n   */\n  deprecatedIsTransferableOutput(output: DeprecatedOutput): output is DeprecatedTransferableOutput {\n    return 'getOutput' in output;\n  }\n\n  /**\n   * Check if Output is from PVM.\n   * Output could be EVM or PVM output.\n   * @param {Output} output\n   * @returns {boolean} output is TransferableOutput\n   */\n  isTransferableOutput(output: Output): output is TransferableOutput {\n    return output?._type === TypeSymbols.TransferableOutput;\n  }\n\n  /**\n   * Return a mapper function to that network address representation.\n   * @param network required to stringify addresses\n   * @return mapper function\n   */\n  deprecatedMapOutputToEntry(network: AvalancheNetwork): (DeprecatedOutput) => Entry {\n    return (output: DeprecatedOutput) => {\n      if (this.deprecatedIsTransferableOutput(output)) {\n        const amountOutput = output.getOutput() as AmountOutput;\n        const address = amountOutput\n          .getAddresses()\n          .map((a) => this.addressToString(network.hrp, network.alias, a))\n          .sort()\n          .join(ADDRESS_SEPARATOR);\n        return {\n          value: amountOutput.getAmount().toString(),\n          address,\n        };\n      } else {\n        const evmOutput = output as EVMOutput;\n        return {\n          // it should be evmOuput.getAmount(), but it returns a 0.\n          value: new BN((evmOutput as any).amount).toString(),\n          // C-Chain address.\n          address: '0x' + evmOutput.getAddressString(),\n        };\n      }\n    };\n  }\n\n  /**\n   * Return a mapper function to that network address representation.\n   * @param network required to stringify addresses\n   * @return mapper function\n   */\n  mapOutputToEntry(network: AvalancheNetwork): (Output) => Entry {\n    return (output: Output) => {\n      if (this.isTransferableOutput(output)) {\n        const outputAmount = output.amount();\n        const address = (output.output as TransferOutput)\n          .getOwners()\n          .map((a) => this.addressToString(network.hrp, network.alias, BufferAvax.from(a)))\n          .sort()\n          .join(ADDRESS_SEPARATOR);\n        return {\n          value: outputAmount.toString(),\n          address,\n        };\n      } else {\n        throw new Error('Invalid output type');\n      }\n    };\n  }\n\n  /**\n   * remove hex prefix (0x)\n   * @param hex string\n   * @returns hex without 0x\n   */\n  removeHexPrefix(hex: string): string {\n    if (hex.startsWith('0x')) {\n      return hex.substring(2);\n    }\n    return hex;\n  }\n\n  /**\n   * Outputidx convert from number (as string) to buffer.\n   * @param {string} outputidx number\n   * @return {BufferAvax} buffer of size 4 with that number value\n   */\n  outputidxNumberToBuffer(outputidx: string): BufferAvax {\n    return BufferAvax.from(Number(outputidx).toString(16).padStart(8, '0'), 'hex');\n  }\n\n  /**\n   * Outputidx buffer to number (as string)\n   * @param {BufferAvax} outputidx\n   * @return {string} outputidx number\n   */\n  outputidxBufferToNumber(outputidx: BufferAvax): string {\n    return parseInt(outputidx.toString('hex'), 16).toString();\n  }\n}\n\nconst utils = new Utils();\n\nexport default utils;\n"]}
|
|
@@ -1,8 +1,8 @@
|
|
|
1
|
-
/// <reference types="bn.js" />
|
|
2
1
|
import { DecodedUtxoObj } from './iface';
|
|
3
2
|
import { BN, Buffer as BufferAvax } from 'avalanche';
|
|
4
3
|
import { Signature } from 'avalanche/dist/common';
|
|
5
4
|
import { StandardTransferableInput } from 'avalanche/dist/common/input';
|
|
5
|
+
import { avaxSerial } from '@bitgo-forks/avalanchejs';
|
|
6
6
|
export interface InputData {
|
|
7
7
|
amount: BN;
|
|
8
8
|
txidBuf: BufferAvax;
|
|
@@ -17,7 +17,15 @@ export interface InputData {
|
|
|
17
17
|
* @param {StandardTransferableInput[]} utxos as transaction ins.
|
|
18
18
|
* @returns the list of UTXOs
|
|
19
19
|
*/
|
|
20
|
-
export declare function
|
|
20
|
+
export declare function deprecatedRecoverUtxos(utxos: StandardTransferableInput[]): DecodedUtxoObj[];
|
|
21
|
+
/**
|
|
22
|
+
* Inputs can be controlled but outputs get reordered in transactions
|
|
23
|
+
* In order to make sure that the mapping is always correct we create an addressIndex which matches to the appropriate
|
|
24
|
+
* signatureIdx
|
|
25
|
+
* @param {avaxSerial.TransferableInput[]} utxos as transaction ins.
|
|
26
|
+
* @returns the list of UTXOs
|
|
27
|
+
*/
|
|
28
|
+
export declare function recoverUtxos(utxos: avaxSerial.TransferableInput[]): DecodedUtxoObj[];
|
|
21
29
|
/**
|
|
22
30
|
* Convert Utxos into inputs data. Input Objects changes regarding chains. This method return a plain object to be mapped late in chain input.
|
|
23
31
|
* Sender is a list of owners address and utxo address must contains all of them.
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"utxoEngine.d.ts","sourceRoot":"","sources":["../../../src/lib/utxoEngine.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"utxoEngine.d.ts","sourceRoot":"","sources":["../../../src/lib/utxoEngine.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAA6B,MAAM,SAAS,CAAC;AACpE,OAAO,EAAE,EAAE,EAAE,MAAM,IAAI,UAAU,EAAE,MAAM,WAAW,CAAC;AACrD,OAAO,EAAE,SAAS,EAAE,MAAM,uBAAuB,CAAC;AAGlD,OAAO,EAAuB,yBAAyB,EAAE,MAAM,6BAA6B,CAAC;AAC7F,OAAO,EAAE,UAAU,EAAE,MAAM,0BAA0B,CAAC;AAEtD,MAAM,WAAW,SAAS;IACxB,MAAM,EAAE,EAAE,CAAC;IACX,OAAO,EAAE,UAAU,CAAC;IACpB,SAAS,EAAE,UAAU,CAAC;IACtB,aAAa,EAAE,MAAM,EAAE,CAAC;IACxB,UAAU,EAAE,SAAS,EAAE,CAAC;CACzB;AAED;;;;;;GAMG;AACH,wBAAgB,sBAAsB,CAAC,KAAK,EAAE,yBAAyB,EAAE,GAAG,cAAc,EAAE,CAiB3F;AAED;;;;;;GAMG;AACH,wBAAgB,YAAY,CAAC,KAAK,EAAE,UAAU,CAAC,iBAAiB,EAAE,GAAG,cAAc,EAAE,CAiBpF;AAED;;;;;;;;;;;;;;;;;;;GAmBG;AACH,wBAAgB,WAAW,CACzB,KAAK,EAAE,cAAc,EAAE,EACvB,MAAM,EAAE,UAAU,EAAE,EACpB,SAAS,SAAI,GACZ;IACD,MAAM,EAAE,SAAS,EAAE,CAAC;IACpB,MAAM,EAAE,EAAE,CAAC;CACZ,CAuCA"}
|