@bitgo-beta/sdk-coin-xtz 1.4.3-alpha.40 → 1.4.3-alpha.401

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.
Files changed (42) hide show
  1. package/.mocharc.yml +1 -1
  2. package/CHANGELOG.md +678 -0
  3. package/package.json +12 -11
  4. package/dist/src/index.d.ts +0 -5
  5. package/dist/src/index.d.ts.map +0 -1
  6. package/dist/src/index.js +0 -30
  7. package/dist/src/lib/address.d.ts +0 -8
  8. package/dist/src/lib/address.d.ts.map +0 -1
  9. package/dist/src/lib/address.js +0 -10
  10. package/dist/src/lib/iface.d.ts +0 -115
  11. package/dist/src/lib/iface.d.ts.map +0 -1
  12. package/dist/src/lib/iface.js +0 -3
  13. package/dist/src/lib/index.d.ts +0 -10
  14. package/dist/src/lib/index.d.ts.map +0 -1
  15. package/dist/src/lib/index.js +0 -37
  16. package/dist/src/lib/keyPair.d.ts +0 -40
  17. package/dist/src/lib/keyPair.d.ts.map +0 -1
  18. package/dist/src/lib/keyPair.js +0 -135
  19. package/dist/src/lib/multisigUtils.d.ts +0 -134
  20. package/dist/src/lib/multisigUtils.d.ts.map +0 -1
  21. package/dist/src/lib/multisigUtils.js +0 -1180
  22. package/dist/src/lib/transaction.d.ts +0 -119
  23. package/dist/src/lib/transaction.d.ts.map +0 -1
  24. package/dist/src/lib/transaction.js +0 -315
  25. package/dist/src/lib/transactionBuilder.d.ts +0 -171
  26. package/dist/src/lib/transactionBuilder.d.ts.map +0 -1
  27. package/dist/src/lib/transactionBuilder.js +0 -453
  28. package/dist/src/lib/transferBuilder.d.ts +0 -24
  29. package/dist/src/lib/transferBuilder.d.ts.map +0 -1
  30. package/dist/src/lib/transferBuilder.js +0 -64
  31. package/dist/src/lib/utils.d.ts +0 -265
  32. package/dist/src/lib/utils.d.ts.map +0 -1
  33. package/dist/src/lib/utils.js +0 -460
  34. package/dist/src/register.d.ts +0 -3
  35. package/dist/src/register.d.ts.map +0 -1
  36. package/dist/src/register.js +0 -11
  37. package/dist/src/txtz.d.ts +0 -13
  38. package/dist/src/txtz.d.ts.map +0 -1
  39. package/dist/src/txtz.js +0 -14
  40. package/dist/src/xtz.d.ts +0 -80
  41. package/dist/src/xtz.d.ts.map +0 -1
  42. package/dist/src/xtz.js +0 -189
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@bitgo-beta/sdk-coin-xtz",
3
- "version": "1.4.3-alpha.40",
3
+ "version": "1.4.3-alpha.401",
4
4
  "description": "BitGo SDK coin library for Tezos",
5
5
  "main": "./dist/src/index.js",
6
6
  "types": "./dist/src/index.d.ts",
@@ -18,7 +18,7 @@
18
18
  "author": "BitGo SDK Team <sdkteam@bitgo.com>",
19
19
  "license": "MIT",
20
20
  "engines": {
21
- "node": ">=14 <17"
21
+ "node": ">=20 <23"
22
22
  },
23
23
  "repository": {
24
24
  "type": "git",
@@ -40,21 +40,22 @@
40
40
  ]
41
41
  },
42
42
  "dependencies": {
43
- "@bitgo-beta/blake2b": "3.2.1-alpha.40",
44
- "@bitgo-beta/sdk-core": "2.4.1-alpha.40",
45
- "@bitgo-beta/statics": "10.0.1-alpha.40",
46
- "@bitgo-beta/utxo-lib": "4.0.1-alpha.40",
43
+ "@bitgo-beta/blake2b": "3.2.1-alpha.405",
44
+ "@bitgo-beta/sdk-core": "2.4.1-alpha.404",
45
+ "@bitgo-beta/secp256k1": "1.0.1-alpha.362",
46
+ "@bitgo-beta/statics": "10.0.1-alpha.404",
47
+ "@noble/curves": "1.8.1",
47
48
  "@taquito/local-forging": "6.3.5-beta.0",
48
49
  "@taquito/signer": "6.3.5-beta.0",
49
50
  "bignumber.js": "^9.0.0",
50
51
  "bs58check": "^2.1.2",
51
- "elliptic": "^6.5.2",
52
52
  "libsodium-wrappers": "^0.7.6",
53
- "lodash": "^4.17.15"
53
+ "lodash": "^4.17.15",
54
+ "superagent": "^9.0.1"
54
55
  },
55
56
  "devDependencies": {
56
- "@bitgo-beta/sdk-api": "1.6.1-alpha.40",
57
- "@bitgo-beta/sdk-test": "^1.2.15"
57
+ "@bitgo-beta/sdk-api": "1.6.1-alpha.404",
58
+ "@bitgo-beta/sdk-test": "^9.1.1"
58
59
  },
59
- "gitHead": "87ab899d3a9d7705605ada595f9b3d1ec48f0a9a"
60
+ "gitHead": "2b67af7f803199038ec5cc7d183db3c8f95d8f77"
60
61
  }
@@ -1,5 +0,0 @@
1
- export * as XtzLib from './lib';
2
- export * from './xtz';
3
- export * from './txtz';
4
- export * from './register';
5
- //# sourceMappingURL=index.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,MAAM,OAAO,CAAC;AAChC,cAAc,OAAO,CAAC;AACtB,cAAc,QAAQ,CAAC;AACvB,cAAc,YAAY,CAAC"}
package/dist/src/index.js DELETED
@@ -1,30 +0,0 @@
1
- "use strict";
2
- var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
- if (k2 === undefined) k2 = k;
4
- Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
5
- }) : (function(o, m, k, k2) {
6
- if (k2 === undefined) k2 = k;
7
- o[k2] = m[k];
8
- }));
9
- var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
10
- Object.defineProperty(o, "default", { enumerable: true, value: v });
11
- }) : function(o, v) {
12
- o["default"] = v;
13
- });
14
- var __importStar = (this && this.__importStar) || function (mod) {
15
- if (mod && mod.__esModule) return mod;
16
- var result = {};
17
- if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
18
- __setModuleDefault(result, mod);
19
- return result;
20
- };
21
- var __exportStar = (this && this.__exportStar) || function(m, exports) {
22
- for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
23
- };
24
- Object.defineProperty(exports, "__esModule", { value: true });
25
- exports.XtzLib = void 0;
26
- exports.XtzLib = __importStar(require("./lib"));
27
- __exportStar(require("./xtz"), exports);
28
- __exportStar(require("./txtz"), exports);
29
- __exportStar(require("./register"), exports);
30
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQUFBLGdEQUFnQztBQUNoQyx3Q0FBc0I7QUFDdEIseUNBQXVCO0FBQ3ZCLDZDQUEyQiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGFzIFh0ekxpYiBmcm9tICcuL2xpYic7XG5leHBvcnQgKiBmcm9tICcuL3h0eic7XG5leHBvcnQgKiBmcm9tICcuL3R4dHonO1xuZXhwb3J0ICogZnJvbSAnLi9yZWdpc3Rlcic7XG4iXX0=
@@ -1,8 +0,0 @@
1
- import { BaseAddress } from '@bitgo-beta/sdk-core';
2
- /**
3
- * Base 58 address with tz2 prefix (secp256k1)
4
- */
5
- export declare class Address implements BaseAddress {
6
- address: string;
7
- }
8
- //# sourceMappingURL=address.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"address.d.ts","sourceRoot":"","sources":["../../../src/lib/address.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,sBAAsB,CAAC;AAEnD;;GAEG;AACH,qBAAa,OAAQ,YAAW,WAAW;IAEzC,OAAO,EAAE,MAAM,CAAC;CACjB"}
@@ -1,10 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.Address = void 0;
4
- /**
5
- * Base 58 address with tz2 prefix (secp256k1)
6
- */
7
- class Address {
8
- }
9
- exports.Address = Address;
10
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWRkcmVzcy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9saWIvYWRkcmVzcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFFQTs7R0FFRztBQUNILE1BQWEsT0FBTztDQUduQjtBQUhELDBCQUdDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQmFzZUFkZHJlc3MgfSBmcm9tICdAYml0Z28tYmV0YS9zZGstY29yZSc7XG5cbi8qKlxuICogQmFzZSA1OCBhZGRyZXNzIHdpdGggdHoyIHByZWZpeCAoc2VjcDI1NmsxKVxuICovXG5leHBvcnQgY2xhc3MgQWRkcmVzcyBpbXBsZW1lbnRzIEJhc2VBZGRyZXNzIHtcbiAgLy8gdGhlIGJhc2U1OCByZXByZXNlbnRhdGlvblxuICBhZGRyZXNzOiBzdHJpbmc7XG59XG4iXX0=
@@ -1,115 +0,0 @@
1
- /// <reference types="node" />
2
- import { BaseFee, BaseKey, SignTransactionOptions, TransactionFee, TransactionRecipient as Recipient, TransactionPrebuild as BaseTransactionPrebuild } from '@bitgo-beta/sdk-core';
3
- export interface XtzSignTransactionOptions extends SignTransactionOptions {
4
- txPrebuild: TransactionPrebuild;
5
- prv: string;
6
- }
7
- export interface TxInfo {
8
- recipients: Recipient[];
9
- from: string;
10
- txid: string;
11
- }
12
- export interface AddressInfo {
13
- address: string;
14
- chain: number;
15
- index: number;
16
- }
17
- export interface TransactionPrebuild extends BaseTransactionPrebuild {
18
- txHex: string;
19
- txInfo: TxInfo;
20
- addressInfo: AddressInfo;
21
- feeInfo: XtzTransactionFee;
22
- source: string;
23
- dataToSign: string;
24
- }
25
- export interface XtzTransactionFee {
26
- fee: string;
27
- gasLimit?: string;
28
- storageLimit?: string;
29
- }
30
- export interface ExplainTransactionOptions {
31
- txHex?: string;
32
- halfSigned?: {
33
- txHex: string;
34
- };
35
- feeInfo: TransactionFee;
36
- }
37
- export interface HashType {
38
- prefix: Buffer;
39
- byteLength: number;
40
- }
41
- export interface Operation {
42
- kind: string;
43
- counter: string;
44
- source: string;
45
- fee: string;
46
- gas_limit: string;
47
- storage_limit: string;
48
- }
49
- export interface RevealOp extends Operation {
50
- public_key: string;
51
- }
52
- export interface OriginationOp extends Operation {
53
- balance: string;
54
- script: any;
55
- delegate?: string;
56
- }
57
- export interface TransactionOp extends Operation {
58
- parameters?: any;
59
- destination: string;
60
- amount: string;
61
- }
62
- export interface ParsedTransaction {
63
- branch: string;
64
- contents: Operation[];
65
- }
66
- /**
67
- * Different Tezos specific fees
68
- */
69
- export interface Fee extends BaseFee {
70
- gasLimit?: string;
71
- storageLimit?: string;
72
- }
73
- /**
74
- * Send transaction information
75
- */
76
- export interface TransferData {
77
- amount: string;
78
- coin?: string;
79
- from: string;
80
- to: string;
81
- fee: Fee;
82
- dataToSign?: string;
83
- counter?: string;
84
- }
85
- /**
86
- * Origination transaction information
87
- */
88
- export interface OriginationData {
89
- fee: Fee;
90
- counter?: string;
91
- balance?: string;
92
- from?: string;
93
- forwarderDestination?: string;
94
- }
95
- /**
96
- * Taquito return type for sign operations
97
- */
98
- export interface SignResponse {
99
- bytes: string;
100
- sig: any;
101
- prefixSig: any;
102
- sbytes: string;
103
- }
104
- export interface IndexedData {
105
- index?: number;
106
- }
107
- /**
108
- * Tezos keys can have a specific order in the smart contracts, hence the need to add an index field
109
- */
110
- export interface Key extends BaseKey, IndexedData {
111
- }
112
- export interface IndexedSignature extends IndexedData {
113
- signature: string;
114
- }
115
- //# sourceMappingURL=iface.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"iface.d.ts","sourceRoot":"","sources":["../../../src/lib/iface.ts"],"names":[],"mappings":";AAAA,OAAO,EACL,OAAO,EACP,OAAO,EACP,sBAAsB,EACtB,cAAc,EACd,oBAAoB,IAAI,SAAS,EACjC,mBAAmB,IAAI,uBAAuB,EAC/C,MAAM,sBAAsB,CAAC;AAE9B,MAAM,WAAW,yBAA0B,SAAQ,sBAAsB;IACvE,UAAU,EAAE,mBAAmB,CAAC;IAChC,GAAG,EAAE,MAAM,CAAC;CACb;AAED,MAAM,WAAW,MAAM;IACrB,UAAU,EAAE,SAAS,EAAE,CAAC;IACxB,IAAI,EAAE,MAAM,CAAC;IACb,IAAI,EAAE,MAAM,CAAC;CACd;AAED,MAAM,WAAW,WAAW;IAC1B,OAAO,EAAE,MAAM,CAAC;IAChB,KAAK,EAAE,MAAM,CAAC;IACd,KAAK,EAAE,MAAM,CAAC;CACf;AAED,MAAM,WAAW,mBAAoB,SAAQ,uBAAuB;IAClE,KAAK,EAAE,MAAM,CAAC;IACd,MAAM,EAAE,MAAM,CAAC;IACf,WAAW,EAAE,WAAW,CAAC;IACzB,OAAO,EAAE,iBAAiB,CAAC;IAC3B,MAAM,EAAE,MAAM,CAAC;IACf,UAAU,EAAE,MAAM,CAAC;CACpB;AAED,MAAM,WAAW,iBAAiB;IAChC,GAAG,EAAE,MAAM,CAAC;IACZ,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,YAAY,CAAC,EAAE,MAAM,CAAC;CACvB;AAED,MAAM,WAAW,yBAAyB;IACxC,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,UAAU,CAAC,EAAE;QACX,KAAK,EAAE,MAAM,CAAC;KACf,CAAC;IACF,OAAO,EAAE,cAAc,CAAC;CACzB;AAED,MAAM,WAAW,QAAQ;IACvB,MAAM,EAAE,MAAM,CAAC;IACf,UAAU,EAAE,MAAM,CAAC;CACpB;AAED,MAAM,WAAW,SAAS;IACxB,IAAI,EAAE,MAAM,CAAC;IACb,OAAO,EAAE,MAAM,CAAC;IAChB,MAAM,EAAE,MAAM,CAAC;IACf,GAAG,EAAE,MAAM,CAAC;IACZ,SAAS,EAAE,MAAM,CAAC;IAClB,aAAa,EAAE,MAAM,CAAC;CACvB;AAED,MAAM,WAAW,QAAS,SAAQ,SAAS;IACzC,UAAU,EAAE,MAAM,CAAC;CACpB;AAED,MAAM,WAAW,aAAc,SAAQ,SAAS;IAC9C,OAAO,EAAE,MAAM,CAAC;IAChB,MAAM,EAAE,GAAG,CAAC;IACZ,QAAQ,CAAC,EAAE,MAAM,CAAC;CACnB;AAED,MAAM,WAAW,aAAc,SAAQ,SAAS;IAC9C,UAAU,CAAC,EAAE,GAAG,CAAC;IACjB,WAAW,EAAE,MAAM,CAAC;IACpB,MAAM,EAAE,MAAM,CAAC;CAChB;AAED,MAAM,WAAW,iBAAiB;IAChC,MAAM,EAAE,MAAM,CAAC;IACf,QAAQ,EAAE,SAAS,EAAE,CAAC;CACvB;AAED;;GAEG;AACH,MAAM,WAAW,GAAI,SAAQ,OAAO;IAClC,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,YAAY,CAAC,EAAE,MAAM,CAAC;CACvB;AAED;;GAEG;AACH,MAAM,WAAW,YAAY;IAC3B,MAAM,EAAE,MAAM,CAAC;IACf,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,IAAI,EAAE,MAAM,CAAC;IACb,EAAE,EAAE,MAAM,CAAC;IACX,GAAG,EAAE,GAAG,CAAC;IACT,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,OAAO,CAAC,EAAE,MAAM,CAAC;CAClB;AAED;;GAEG;AACH,MAAM,WAAW,eAAe;IAC9B,GAAG,EAAE,GAAG,CAAC;IACT,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,oBAAoB,CAAC,EAAE,MAAM,CAAC;CAC/B;AACD;;GAEG;AACH,MAAM,WAAW,YAAY;IAC3B,KAAK,EAAE,MAAM,CAAC;IACd,GAAG,EAAE,GAAG,CAAC;IACT,SAAS,EAAE,GAAG,CAAC;IACf,MAAM,EAAE,MAAM,CAAC;CAChB;AAED,MAAM,WAAW,WAAW;IAC1B,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB;AAED;;GAEG;AACH,MAAM,WAAW,GAAI,SAAQ,OAAO,EAAE,WAAW;CAAG;AAEpD,MAAM,WAAW,gBAAiB,SAAQ,WAAW;IACnD,SAAS,EAAE,MAAM,CAAC;CACnB"}
@@ -1,3 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaWZhY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvbGliL2lmYWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICBCYXNlRmVlLFxuICBCYXNlS2V5LFxuICBTaWduVHJhbnNhY3Rpb25PcHRpb25zLFxuICBUcmFuc2FjdGlvbkZlZSxcbiAgVHJhbnNhY3Rpb25SZWNpcGllbnQgYXMgUmVjaXBpZW50LFxuICBUcmFuc2FjdGlvblByZWJ1aWxkIGFzIEJhc2VUcmFuc2FjdGlvblByZWJ1aWxkLFxufSBmcm9tICdAYml0Z28tYmV0YS9zZGstY29yZSc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgWHR6U2lnblRyYW5zYWN0aW9uT3B0aW9ucyBleHRlbmRzIFNpZ25UcmFuc2FjdGlvbk9wdGlvbnMge1xuICB0eFByZWJ1aWxkOiBUcmFuc2FjdGlvblByZWJ1aWxkO1xuICBwcnY6IHN0cmluZztcbn1cblxuZXhwb3J0IGludGVyZmFjZSBUeEluZm8ge1xuICByZWNpcGllbnRzOiBSZWNpcGllbnRbXTtcbiAgZnJvbTogc3RyaW5nO1xuICB0eGlkOiBzdHJpbmc7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgQWRkcmVzc0luZm8ge1xuICBhZGRyZXNzOiBzdHJpbmc7XG4gIGNoYWluOiBudW1iZXI7XG4gIGluZGV4OiBudW1iZXI7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgVHJhbnNhY3Rpb25QcmVidWlsZCBleHRlbmRzIEJhc2VUcmFuc2FjdGlvblByZWJ1aWxkIHtcbiAgdHhIZXg6IHN0cmluZztcbiAgdHhJbmZvOiBUeEluZm87XG4gIGFkZHJlc3NJbmZvOiBBZGRyZXNzSW5mbztcbiAgZmVlSW5mbzogWHR6VHJhbnNhY3Rpb25GZWU7XG4gIHNvdXJjZTogc3RyaW5nO1xuICBkYXRhVG9TaWduOiBzdHJpbmc7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgWHR6VHJhbnNhY3Rpb25GZWUge1xuICBmZWU6IHN0cmluZztcbiAgZ2FzTGltaXQ/OiBzdHJpbmc7XG4gIHN0b3JhZ2VMaW1pdD86IHN0cmluZztcbn1cblxuZXhwb3J0IGludGVyZmFjZSBFeHBsYWluVHJhbnNhY3Rpb25PcHRpb25zIHtcbiAgdHhIZXg/OiBzdHJpbmc7XG4gIGhhbGZTaWduZWQ/OiB7XG4gICAgdHhIZXg6IHN0cmluZztcbiAgfTtcbiAgZmVlSW5mbzogVHJhbnNhY3Rpb25GZWU7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgSGFzaFR5cGUge1xuICBwcmVmaXg6IEJ1ZmZlcjtcbiAgYnl0ZUxlbmd0aDogbnVtYmVyO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIE9wZXJhdGlvbiB7XG4gIGtpbmQ6IHN0cmluZztcbiAgY291bnRlcjogc3RyaW5nO1xuICBzb3VyY2U6IHN0cmluZztcbiAgZmVlOiBzdHJpbmc7XG4gIGdhc19saW1pdDogc3RyaW5nO1xuICBzdG9yYWdlX2xpbWl0OiBzdHJpbmc7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgUmV2ZWFsT3AgZXh0ZW5kcyBPcGVyYXRpb24ge1xuICBwdWJsaWNfa2V5OiBzdHJpbmc7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgT3JpZ2luYXRpb25PcCBleHRlbmRzIE9wZXJhdGlvbiB7XG4gIGJhbGFuY2U6IHN0cmluZztcbiAgc2NyaXB0OiBhbnk7XG4gIGRlbGVnYXRlPzogc3RyaW5nO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIFRyYW5zYWN0aW9uT3AgZXh0ZW5kcyBPcGVyYXRpb24ge1xuICBwYXJhbWV0ZXJzPzogYW55O1xuICBkZXN0aW5hdGlvbjogc3RyaW5nO1xuICBhbW91bnQ6IHN0cmluZztcbn1cblxuZXhwb3J0IGludGVyZmFjZSBQYXJzZWRUcmFuc2FjdGlvbiB7XG4gIGJyYW5jaDogc3RyaW5nO1xuICBjb250ZW50czogT3BlcmF0aW9uW107XG59XG5cbi8qKlxuICogRGlmZmVyZW50IFRlem9zIHNwZWNpZmljIGZlZXNcbiAqL1xuZXhwb3J0IGludGVyZmFjZSBGZWUgZXh0ZW5kcyBCYXNlRmVlIHtcbiAgZ2FzTGltaXQ/OiBzdHJpbmc7XG4gIHN0b3JhZ2VMaW1pdD86IHN0cmluZztcbn1cblxuLyoqXG4gKiBTZW5kIHRyYW5zYWN0aW9uIGluZm9ybWF0aW9uXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgVHJhbnNmZXJEYXRhIHtcbiAgYW1vdW50OiBzdHJpbmc7XG4gIGNvaW4/OiBzdHJpbmc7XG4gIGZyb206IHN0cmluZztcbiAgdG86IHN0cmluZztcbiAgZmVlOiBGZWU7XG4gIGRhdGFUb1NpZ24/OiBzdHJpbmc7XG4gIGNvdW50ZXI/OiBzdHJpbmc7XG59XG5cbi8qKlxuICogT3JpZ2luYXRpb24gdHJhbnNhY3Rpb24gaW5mb3JtYXRpb25cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBPcmlnaW5hdGlvbkRhdGEge1xuICBmZWU6IEZlZTtcbiAgY291bnRlcj86IHN0cmluZztcbiAgYmFsYW5jZT86IHN0cmluZztcbiAgZnJvbT86IHN0cmluZztcbiAgZm9yd2FyZGVyRGVzdGluYXRpb24/OiBzdHJpbmc7XG59XG4vKipcbiAqIFRhcXVpdG8gcmV0dXJuIHR5cGUgZm9yIHNpZ24gb3BlcmF0aW9uc1xuICovXG5leHBvcnQgaW50ZXJmYWNlIFNpZ25SZXNwb25zZSB7XG4gIGJ5dGVzOiBzdHJpbmc7XG4gIHNpZzogYW55O1xuICBwcmVmaXhTaWc6IGFueTtcbiAgc2J5dGVzOiBzdHJpbmc7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgSW5kZXhlZERhdGEge1xuICBpbmRleD86IG51bWJlcjtcbn1cblxuLyoqXG4gKiBUZXpvcyBrZXlzIGNhbiBoYXZlIGEgc3BlY2lmaWMgb3JkZXIgaW4gdGhlIHNtYXJ0IGNvbnRyYWN0cywgaGVuY2UgdGhlIG5lZWQgdG8gYWRkIGFuIGluZGV4IGZpZWxkXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgS2V5IGV4dGVuZHMgQmFzZUtleSwgSW5kZXhlZERhdGEge31cblxuZXhwb3J0IGludGVyZmFjZSBJbmRleGVkU2lnbmF0dXJlIGV4dGVuZHMgSW5kZXhlZERhdGEge1xuICBzaWduYXR1cmU6IHN0cmluZztcbn1cbiJdfQ==
@@ -1,10 +0,0 @@
1
- export { KeyPair } from './keyPair';
2
- export { Address } from './address';
3
- export { Transaction } from './transaction';
4
- export { TransactionBuilder } from './transactionBuilder';
5
- import * as Interface from './iface';
6
- import * as Utils from './utils';
7
- import * as MultisigUtils from './multisigUtils';
8
- declare const mergedUtils: typeof Utils & typeof MultisigUtils;
9
- export { Interface, mergedUtils as Utils };
10
- //# sourceMappingURL=index.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/lib/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AACpC,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AACpC,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAC5C,OAAO,EAAE,kBAAkB,EAAE,MAAM,sBAAsB,CAAC;AAE1D,OAAO,KAAK,SAAS,MAAM,SAAS,CAAC;AACrC,OAAO,KAAK,KAAK,MAAM,SAAS,CAAC;AACjC,OAAO,KAAK,aAAa,MAAM,iBAAiB,CAAC;AACjD,QAAA,MAAM,WAAW,qCAAsC,CAAC;AAExD,OAAO,EAAE,SAAS,EAAE,WAAW,IAAI,KAAK,EAAE,CAAC"}
@@ -1,37 +0,0 @@
1
- "use strict";
2
- var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
- if (k2 === undefined) k2 = k;
4
- Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
5
- }) : (function(o, m, k, k2) {
6
- if (k2 === undefined) k2 = k;
7
- o[k2] = m[k];
8
- }));
9
- var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
10
- Object.defineProperty(o, "default", { enumerable: true, value: v });
11
- }) : function(o, v) {
12
- o["default"] = v;
13
- });
14
- var __importStar = (this && this.__importStar) || function (mod) {
15
- if (mod && mod.__esModule) return mod;
16
- var result = {};
17
- if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
18
- __setModuleDefault(result, mod);
19
- return result;
20
- };
21
- Object.defineProperty(exports, "__esModule", { value: true });
22
- exports.Utils = exports.Interface = exports.TransactionBuilder = exports.Transaction = exports.Address = exports.KeyPair = void 0;
23
- var keyPair_1 = require("./keyPair");
24
- Object.defineProperty(exports, "KeyPair", { enumerable: true, get: function () { return keyPair_1.KeyPair; } });
25
- var address_1 = require("./address");
26
- Object.defineProperty(exports, "Address", { enumerable: true, get: function () { return address_1.Address; } });
27
- var transaction_1 = require("./transaction");
28
- Object.defineProperty(exports, "Transaction", { enumerable: true, get: function () { return transaction_1.Transaction; } });
29
- var transactionBuilder_1 = require("./transactionBuilder");
30
- Object.defineProperty(exports, "TransactionBuilder", { enumerable: true, get: function () { return transactionBuilder_1.TransactionBuilder; } });
31
- const Interface = __importStar(require("./iface"));
32
- exports.Interface = Interface;
33
- const Utils = __importStar(require("./utils"));
34
- const MultisigUtils = __importStar(require("./multisigUtils"));
35
- const mergedUtils = Object.assign(Utils, MultisigUtils);
36
- exports.Utils = mergedUtils;
37
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvbGliL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQSxxQ0FBb0M7QUFBM0Isa0dBQUEsT0FBTyxPQUFBO0FBQ2hCLHFDQUFvQztBQUEzQixrR0FBQSxPQUFPLE9BQUE7QUFDaEIsNkNBQTRDO0FBQW5DLDBHQUFBLFdBQVcsT0FBQTtBQUNwQiwyREFBMEQ7QUFBakQsd0hBQUEsa0JBQWtCLE9BQUE7QUFFM0IsbURBQXFDO0FBSzVCLDhCQUFTO0FBSmxCLCtDQUFpQztBQUNqQywrREFBaUQ7QUFDakQsTUFBTSxXQUFXLEdBQUcsTUFBTSxDQUFDLE1BQU0sQ0FBQyxLQUFLLEVBQUUsYUFBYSxDQUFDLENBQUM7QUFFckIsNEJBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgeyBLZXlQYWlyIH0gZnJvbSAnLi9rZXlQYWlyJztcbmV4cG9ydCB7IEFkZHJlc3MgfSBmcm9tICcuL2FkZHJlc3MnO1xuZXhwb3J0IHsgVHJhbnNhY3Rpb24gfSBmcm9tICcuL3RyYW5zYWN0aW9uJztcbmV4cG9ydCB7IFRyYW5zYWN0aW9uQnVpbGRlciB9IGZyb20gJy4vdHJhbnNhY3Rpb25CdWlsZGVyJztcblxuaW1wb3J0ICogYXMgSW50ZXJmYWNlIGZyb20gJy4vaWZhY2UnO1xuaW1wb3J0ICogYXMgVXRpbHMgZnJvbSAnLi91dGlscyc7XG5pbXBvcnQgKiBhcyBNdWx0aXNpZ1V0aWxzIGZyb20gJy4vbXVsdGlzaWdVdGlscyc7XG5jb25zdCBtZXJnZWRVdGlscyA9IE9iamVjdC5hc3NpZ24oVXRpbHMsIE11bHRpc2lnVXRpbHMpO1xuXG5leHBvcnQgeyBJbnRlcmZhY2UsIG1lcmdlZFV0aWxzIGFzIFV0aWxzIH07XG4iXX0=
@@ -1,40 +0,0 @@
1
- import { DefaultKeys, KeyPairOptions, Secp256k1ExtendedKeyPair } from '@bitgo-beta/sdk-core';
2
- /**
3
- * Tezos keys and address management.
4
- */
5
- export declare class KeyPair extends Secp256k1ExtendedKeyPair {
6
- /**
7
- * Public constructor. By default, creates a key pair with a random master seed.
8
- *
9
- * @param {KeyPairOptions} source Either a master seed, a private key (extended or raw), or a public key
10
- * (extended, compressed, or uncompressed)
11
- */
12
- constructor(source?: KeyPairOptions);
13
- /**
14
- * Build a Hierarchical Deterministic node or an ECPair from a private key.
15
- * Specific Tezos implementation
16
- *
17
- * @param {string} prv An extended or raw private key
18
- */
19
- recordKeysFromPrivateKey(prv: string): void;
20
- /**
21
- * Build a Hierarchical Deterministic node or an ECPair from a public key.
22
- * Specific Tezos implementation
23
- *
24
- * @param {string} pub - An extended, compressed, or uncompressed public key
25
- */
26
- recordKeysFromPublicKey(pub: string): void;
27
- /**
28
- * Return Tezos default keys with the respective prefixes
29
- *
30
- * @returns {DefaultKeys} The keys in the protocol default key format
31
- */
32
- getKeys(): DefaultKeys;
33
- /**
34
- * Get a public address.
35
- *
36
- * @returns {string} The public address
37
- */
38
- getAddress(): string;
39
- }
40
- //# sourceMappingURL=keyPair.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"keyPair.d.ts","sourceRoot":"","sources":["../../../src/lib/keyPair.ts"],"names":[],"mappings":"AAGA,OAAO,EACL,WAAW,EAQX,cAAc,EACd,wBAAwB,EACzB,MAAM,sBAAsB,CAAC;AAK9B;;GAEG;AACH,qBAAa,OAAQ,SAAQ,wBAAwB;IACnD;;;;;OAKG;gBACS,MAAM,CAAC,EAAE,cAAc;IAoBnC;;;;;OAKG;IACH,wBAAwB,CAAC,GAAG,EAAE,MAAM,GAAG,IAAI;IAa3C;;;;;OAKG;IACH,uBAAuB,CAAC,GAAG,EAAE,MAAM,GAAG,IAAI;IAa1C;;;;OAIG;IACH,OAAO,IAAI,WAAW;IAYtB;;;;OAIG;IACH,UAAU,IAAI,MAAM;CAMrB"}
@@ -1,135 +0,0 @@
1
- "use strict";
2
- var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
- if (k2 === undefined) k2 = k;
4
- Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
5
- }) : (function(o, m, k, k2) {
6
- if (k2 === undefined) k2 = k;
7
- o[k2] = m[k];
8
- }));
9
- var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
10
- Object.defineProperty(o, "default", { enumerable: true, value: v });
11
- }) : function(o, v) {
12
- o["default"] = v;
13
- });
14
- var __importStar = (this && this.__importStar) || function (mod) {
15
- if (mod && mod.__esModule) return mod;
16
- var result = {};
17
- if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
18
- __setModuleDefault(result, mod);
19
- return result;
20
- };
21
- var __importDefault = (this && this.__importDefault) || function (mod) {
22
- return (mod && mod.__esModule) ? mod : { "default": mod };
23
- };
24
- Object.defineProperty(exports, "__esModule", { value: true });
25
- exports.KeyPair = void 0;
26
- const crypto_1 = require("crypto");
27
- const blake2b_1 = __importDefault(require("@bitgo-beta/blake2b"));
28
- const utxo_lib_1 = require("@bitgo-beta/utxo-lib");
29
- const sdk_core_1 = require("@bitgo-beta/sdk-core");
30
- const Utils = __importStar(require("./utils"));
31
- const DEFAULT_SEED_SIZE_BYTES = 16;
32
- /**
33
- * Tezos keys and address management.
34
- */
35
- class KeyPair extends sdk_core_1.Secp256k1ExtendedKeyPair {
36
- /**
37
- * Public constructor. By default, creates a key pair with a random master seed.
38
- *
39
- * @param {KeyPairOptions} source Either a master seed, a private key (extended or raw), or a public key
40
- * (extended, compressed, or uncompressed)
41
- */
42
- constructor(source) {
43
- super(source);
44
- if (!source) {
45
- const seed = crypto_1.randomBytes(DEFAULT_SEED_SIZE_BYTES);
46
- this.hdNode = utxo_lib_1.bip32.fromSeed(seed);
47
- }
48
- else if (sdk_core_1.isSeed(source)) {
49
- this.hdNode = utxo_lib_1.bip32.fromSeed(source.seed);
50
- }
51
- else if (sdk_core_1.isPrivateKey(source)) {
52
- this.recordKeysFromPrivateKey(source.prv);
53
- }
54
- else if (sdk_core_1.isPublicKey(source)) {
55
- this.recordKeysFromPublicKey(source.pub);
56
- }
57
- else {
58
- throw new Error('Invalid key pair options');
59
- }
60
- if (this.hdNode) {
61
- this.keyPair = sdk_core_1.Secp256k1ExtendedKeyPair.toKeyPair(this.hdNode);
62
- }
63
- }
64
- /**
65
- * Build a Hierarchical Deterministic node or an ECPair from a private key.
66
- * Specific Tezos implementation
67
- *
68
- * @param {string} prv An extended or raw private key
69
- */
70
- recordKeysFromPrivateKey(prv) {
71
- if (sdk_core_1.isValidXprv(prv)) {
72
- this.hdNode = utxo_lib_1.bip32.fromBase58(prv);
73
- }
74
- else if (sdk_core_1.isValidPrv(prv)) {
75
- // Cannot create the HD node without the chain code, so create a regular Key Chain
76
- this.keyPair = utxo_lib_1.ECPair.fromPrivateKey(Buffer.from(prv, 'hex'));
77
- }
78
- else if (Utils.isValidKey(prv, Utils.hashTypes.spsk)) {
79
- this.keyPair = utxo_lib_1.ECPair.fromPrivateKey(Utils.decodeKey(prv, Utils.hashTypes.spsk));
80
- }
81
- else {
82
- throw new Error('Unsupported private key');
83
- }
84
- }
85
- /**
86
- * Build a Hierarchical Deterministic node or an ECPair from a public key.
87
- * Specific Tezos implementation
88
- *
89
- * @param {string} pub - An extended, compressed, or uncompressed public key
90
- */
91
- recordKeysFromPublicKey(pub) {
92
- if (sdk_core_1.isValidXpub(pub)) {
93
- this.hdNode = utxo_lib_1.bip32.fromBase58(pub);
94
- }
95
- else if (sdk_core_1.isValidPub(pub)) {
96
- // Cannot create an HD node without the chain code, so create a regular Key Chain
97
- this.keyPair = utxo_lib_1.ECPair.fromPublicKey(Buffer.from(pub, 'hex'));
98
- }
99
- else if (Utils.isValidKey(pub, Utils.hashTypes.sppk)) {
100
- this.keyPair = utxo_lib_1.ECPair.fromPublicKey(Utils.decodeKey(pub, Utils.hashTypes.sppk));
101
- }
102
- else {
103
- throw new Error('Unsupported public key: ' + pub);
104
- }
105
- }
106
- /**
107
- * Return Tezos default keys with the respective prefixes
108
- *
109
- * @returns {DefaultKeys} The keys in the protocol default key format
110
- */
111
- getKeys() {
112
- // Always use the compressed version to be consistent
113
- const result = {
114
- pub: Utils.base58encode(Utils.hashTypes.sppk.prefix, this.getPublicKey({ compressed: true })),
115
- };
116
- const prvBuffer = this.getPrivateKey();
117
- if (prvBuffer) {
118
- result.prv = Utils.base58encode(Utils.hashTypes.spsk.prefix, prvBuffer);
119
- }
120
- return result;
121
- }
122
- /**
123
- * Get a public address.
124
- *
125
- * @returns {string} The public address
126
- */
127
- getAddress() {
128
- const pub = this.getPublicKey({ compressed: true });
129
- const out = Buffer.alloc(20);
130
- const b2b = blake2b_1.default(out.length).update(pub).digest(out);
131
- return Utils.base58encode(Utils.hashTypes.tz2.prefix, b2b);
132
- }
133
- }
134
- exports.KeyPair = KeyPair;
135
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"keyPair.js","sourceRoot":"","sources":["../../../src/lib/keyPair.ts"],"names":[],"mappings":"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","sourcesContent":["import { randomBytes } from 'crypto';\nimport blake2b from '@bitgo-beta/blake2b';\nimport { bip32, ECPair } from '@bitgo-beta/utxo-lib';\nimport {\n  DefaultKeys,\n  isPrivateKey,\n  isPublicKey,\n  isSeed,\n  isValidPrv,\n  isValidPub,\n  isValidXprv,\n  isValidXpub,\n  KeyPairOptions,\n  Secp256k1ExtendedKeyPair,\n} from '@bitgo-beta/sdk-core';\nimport * as Utils from './utils';\n\nconst DEFAULT_SEED_SIZE_BYTES = 16;\n\n/**\n * Tezos keys and address management.\n */\nexport class KeyPair extends Secp256k1ExtendedKeyPair {\n  /**\n   * Public constructor. By default, creates a key pair with a random master seed.\n   *\n   * @param {KeyPairOptions} source Either a master seed, a private key (extended or raw), or a public key\n   *     (extended, compressed, or uncompressed)\n   */\n  constructor(source?: KeyPairOptions) {\n    super(source);\n    if (!source) {\n      const seed = randomBytes(DEFAULT_SEED_SIZE_BYTES);\n      this.hdNode = bip32.fromSeed(seed);\n    } else if (isSeed(source)) {\n      this.hdNode = bip32.fromSeed(source.seed);\n    } else if (isPrivateKey(source)) {\n      this.recordKeysFromPrivateKey(source.prv);\n    } else if (isPublicKey(source)) {\n      this.recordKeysFromPublicKey(source.pub);\n    } else {\n      throw new Error('Invalid key pair options');\n    }\n\n    if (this.hdNode) {\n      this.keyPair = Secp256k1ExtendedKeyPair.toKeyPair(this.hdNode);\n    }\n  }\n\n  /**\n   * Build a Hierarchical Deterministic node or an ECPair from a private key.\n   * Specific Tezos implementation\n   *\n   * @param {string} prv An extended or raw private key\n   */\n  recordKeysFromPrivateKey(prv: string): void {\n    if (isValidXprv(prv)) {\n      this.hdNode = bip32.fromBase58(prv);\n    } else if (isValidPrv(prv)) {\n      // Cannot create the HD node without the chain code, so create a regular Key Chain\n      this.keyPair = ECPair.fromPrivateKey(Buffer.from(prv, 'hex'));\n    } else if (Utils.isValidKey(prv, Utils.hashTypes.spsk)) {\n      this.keyPair = ECPair.fromPrivateKey(Utils.decodeKey(prv, Utils.hashTypes.spsk));\n    } else {\n      throw new Error('Unsupported private key');\n    }\n  }\n\n  /**\n   * Build a Hierarchical Deterministic node or an ECPair from a public key.\n   * Specific Tezos implementation\n   *\n   * @param {string} pub - An extended, compressed, or uncompressed public key\n   */\n  recordKeysFromPublicKey(pub: string): void {\n    if (isValidXpub(pub)) {\n      this.hdNode = bip32.fromBase58(pub);\n    } else if (isValidPub(pub)) {\n      // Cannot create an HD node without the chain code, so create a regular Key Chain\n      this.keyPair = ECPair.fromPublicKey(Buffer.from(pub, 'hex'));\n    } else if (Utils.isValidKey(pub, Utils.hashTypes.sppk)) {\n      this.keyPair = ECPair.fromPublicKey(Utils.decodeKey(pub, Utils.hashTypes.sppk));\n    } else {\n      throw new Error('Unsupported public key: ' + pub);\n    }\n  }\n\n  /**\n   * Return Tezos default keys with the respective prefixes\n   *\n   * @returns {DefaultKeys} The keys in the protocol default key format\n   */\n  getKeys(): DefaultKeys {\n    // Always use the compressed version to be consistent\n    const result: DefaultKeys = {\n      pub: Utils.base58encode(Utils.hashTypes.sppk.prefix, this.getPublicKey({ compressed: true })),\n    };\n    const prvBuffer: Buffer | undefined = this.getPrivateKey();\n    if (prvBuffer) {\n      result.prv = Utils.base58encode(Utils.hashTypes.spsk.prefix, prvBuffer);\n    }\n    return result;\n  }\n\n  /**\n   * Get a public address.\n   *\n   * @returns {string} The public address\n   */\n  getAddress(): string {\n    const pub = this.getPublicKey({ compressed: true });\n    const out = Buffer.alloc(20);\n    const b2b = blake2b(out.length).update(pub).digest(out);\n    return Utils.base58encode(Utils.hashTypes.tz2.prefix, b2b);\n  }\n}\n"]}
@@ -1,134 +0,0 @@
1
- import { IndexedSignature, OriginationData, OriginationOp, RevealOp, TransactionOp, TransferData } from './iface';
2
- /**
3
- * Helper method to get the transfer details from a generic multisig transaction operation.
4
- *
5
- * @param {TransactionOp} operation A transaction operation JSON
6
- * @returns {TransferData} Information about the destination, token and transfer amount
7
- */
8
- export declare function getMultisigTransferDataFromOperation(operation: TransactionOp): TransferData;
9
- /**
10
- * Helper method to get the wallet or address initialization tx from an origination operation
11
- *
12
- * @param {OriginationOp} operation
13
- * @returns {OriginationData} Information about the wallet contract creating a forwarder contract
14
- */
15
- export declare function getOriginationDataFromOperation(operation: OriginationOp): OriginationData;
16
- /**
17
- * Helper method to build a singlesig transaction operation.
18
- *
19
- * @param {string} counter Source account next counter
20
- * @param {string} source The account that will pay for fees, and in singlesig transactions, where
21
- * the funds are taken from
22
- * @param {string} amount The amount in mutez to be transferred
23
- * @param {string} destination The account address to send the funds to
24
- * @param {string} fee Fees in mutez to pay by the source account
25
- * @param {string} gasLimit Maximum amount in mutez to spend in gas fees
26
- * @param {string} storageLimit Maximum amount in mutez to spend in storage fees
27
- * @returns {TransactionOp}A Tezos transaction operation
28
- */
29
- export declare function singlesigTransactionOperation(counter: string, source: string, amount: string, destination: string, fee?: string, gasLimit?: string, storageLimit?: string): TransactionOp;
30
- /**
31
- * Create a multisig wallet transaction operation.
32
- *
33
- * @see {@link transactionOperation}
34
- * @param {string} counter Source account next counter
35
- * @param {string} source The account that will pay for fees, and in singlesig transactions, where
36
- * the funds are taken from
37
- * @param {string} amount The amount in mutez to be transferred
38
- * @param {string} contractAddress If it is a multisig transfer, the smart contract address with the
39
- * funds to be transferred from
40
- * @param {string} contractCounter If it is a multisig transfer, the smart contract counter to use
41
- * in the next transaction
42
- * @param {string} destinationAddress An implicit or originated address to transfer fudns to
43
- * @param {string[]} signatures signatures List of signatures authorizing the funds transfer form
44
- * the multisig wallet
45
- * @param {string} fee Fees in mutez to pay by the source account
46
- * @param {string} gasLimit Maximum amount in mutez to spend in gas fees
47
- * @param {string} storageLimit Maximum amount in mutez to spend in storage fees
48
- * @param {number} m The number of signers (owners) for the multisig wallet being used. Default is 3
49
- * @returns {TransactionOp} A Tezos operation with a generic multisig transfer
50
- */
51
- export declare function multisigTransactionOperation(counter: string, source: string, amount: string, contractAddress: string, contractCounter: string, destinationAddress: string, signatures: IndexedSignature[], fee?: string, gasLimit?: string, storageLimit?: string, m?: number): TransactionOp;
52
- /**
53
- * Replace the signatures in a multisig transaction operation with new ones.
54
- *
55
- * @param {TransactionOp} transaction Transaction to mutate
56
- * @param {IndexedSignature[]} signatures List of transactions and their order
57
- */
58
- export declare function updateMultisigTransferSignatures(transaction: TransactionOp, signatures: IndexedSignature[]): void;
59
- /**
60
- * Ge the list if multisig signatures if any in a convenient format.
61
- *
62
- * @param {TransactionOp} transaction The transaction to search the signatures in
63
- * @returns {IndexedSignature[]} A list of signatures and their order in teh transfer script
64
- */
65
- export declare function getMultisigTransferSignatures(transaction: TransactionOp): IndexedSignature[];
66
- /**
67
- * Helper function to build the Michelson script to be signed to transfer funds from a multisig
68
- * wallet.
69
- *
70
- * @param contractAddress The multisig smart contract address
71
- * @param {string} destinationAddress The destination account address (implicit or originated)
72
- * @param {number} amount Number of mutez to transfer
73
- * @param {string} contractCounter Wallet counter to use in the transaction
74
- * @returns A JSON representation of the Michelson script to sign and approve a transfer
75
- */
76
- export declare function genericMultisigDataToSign(contractAddress: string, destinationAddress: string, amount: string, contractCounter: string): {
77
- data: {
78
- prim: string;
79
- args: any[];
80
- };
81
- type: {
82
- prim: string;
83
- args: any[];
84
- };
85
- };
86
- /**
87
- * Create a reveal operation for a public key.
88
- *
89
- * @param {string} counter Source account next counter
90
- * @param {string} source Source account address
91
- * @param {string} pubKey The public key to reveal
92
- * @param {string} fee Fees in mutez to pay by the source account
93
- * @param {string} gasLimit Maximum amount in mutez to spend in gas fees
94
- * @param {string} storageLimit Maximum amount in mutez to spend in storage fees
95
- * @returns An origination operation
96
- */
97
- export declare function revealOperation(counter: string, source: string, pubKey: string, fee?: string, gasLimit?: string, storageLimit?: string): RevealOp;
98
- /**
99
- * Create an origination operation for the generic multisg contract. It does not create a reveal
100
- * operation for the source account.
101
- *
102
- * @param {string} counter Valid source account counter to use
103
- * @param {string} source Source account address
104
- * @param {string} fee Fees in mutez to pay by the source account
105
- * @param {string} gasLimit Maximum amount in mutez to spend in gas fees
106
- * @param {string} storageLimit Maximum amount in mutez to spend in storage fees
107
- * @param {string} balance New multisig account initial balance taken from the source account
108
- * @param {string[]} pubKeys List of public keys of the multisig owner
109
- * @param {string} delegate Optional implicit address to delegate the wallet funds to
110
- * @param {number} threshold Minimum number of signatures required to authorize a multisig operation
111
- * @returns An origination operation
112
- */
113
- export declare function genericMultisigOriginationOperation(counter: string, source: string, fee: string, gasLimit: string, storageLimit: string, balance: string, pubKeys: string[], delegate?: string, threshold?: number): OriginationOp;
114
- /**
115
- * Get the public key of each owner of an multisig wallet origination contract.
116
- *
117
- * @param {OriginationOp} operation An operation with the generic multisig wallet origination
118
- * @returns {string[]} List of all the owners set in the origination transaction
119
- */
120
- export declare function getOwnersPublicKeys(operation: OriginationOp): string[];
121
- /**
122
- * Create an origination operation for a forwarder contract
123
- *
124
- * @param {string} contractAddress originated multisig address to forward funds
125
- * @param {string} counter Valid source account counter to use
126
- * @param {string} source Source account address
127
- * @param {string} fee Fees in mutez to pay by the source account
128
- * @param {string} gasLimit Maximum amount in mutez to spend in gas fees
129
- * @param {string} storageLimit Maximum amount in mutez to spend in storage fees
130
- * @param {string} balance New multisig account initial balance taken from the source account
131
- * @returns {OriginationOp} the operation
132
- */
133
- export declare function forwarderOriginationOperation(contractAddress: string, counter: string, source: string, fee: string, gasLimit: string, storageLimit: string, balance: string): OriginationOp;
134
- //# sourceMappingURL=multisigUtils.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"multisigUtils.d.ts","sourceRoot":"","sources":["../../../src/lib/multisigUtils.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,gBAAgB,EAAE,eAAe,EAAE,aAAa,EAAE,QAAQ,EAAE,aAAa,EAAE,YAAY,EAAE,MAAM,SAAS,CAAC;AAOlH;;;;;GAKG;AACH,wBAAgB,oCAAoC,CAAC,SAAS,EAAE,aAAa,GAAG,YAAY,CA4C3F;AAED;;;;;GAKG;AACH,wBAAgB,+BAA+B,CAAC,SAAS,EAAE,aAAa,GAAG,eAAe,CAmBzF;AACD;;;;;;;;;;;;GAYG;AACH,wBAAgB,6BAA6B,CAC3C,OAAO,EAAE,MAAM,EACf,MAAM,EAAE,MAAM,EACd,MAAM,EAAE,MAAM,EACd,WAAW,EAAE,MAAM,EACnB,GAAG,GAAE,MAAwC,EAC7C,QAAQ,GAAE,MAA8C,EACxD,YAAY,GAAE,MAAkD,GAC/D,aAAa,CAWf;AAED;;;;;;;;;;;;;;;;;;;;GAoBG;AACH,wBAAgB,4BAA4B,CAC1C,OAAO,EAAE,MAAM,EACf,MAAM,EAAE,MAAM,EACd,MAAM,EAAE,MAAM,EACd,eAAe,EAAE,MAAM,EACvB,eAAe,EAAE,MAAM,EACvB,kBAAkB,EAAE,MAAM,EAC1B,UAAU,EAAE,gBAAgB,EAAE,EAC9B,GAAG,GAAE,MAAwC,EAC7C,QAAQ,GAAE,MAA8C,EACxD,YAAY,GAAE,MAAkD,EAChE,CAAC,GAAE,MAAkB,GACpB,aAAa,CAYf;AAmCD;;;;;GAKG;AACH,wBAAgB,gCAAgC,CAAC,WAAW,EAAE,aAAa,EAAE,UAAU,EAAE,gBAAgB,EAAE,QAE1G;AAED;;;;;GAKG;AACH,wBAAgB,6BAA6B,CAAC,WAAW,EAAE,aAAa,GAAG,gBAAgB,EAAE,CAe5F;AAqCD;;;;;;;;;GASG;AACH,wBAAgB,yBAAyB,CACvC,eAAe,EAAE,MAAM,EACvB,kBAAkB,EAAE,MAAM,EAC1B,MAAM,EAAE,MAAM,EACd,eAAe,EAAE,MAAM;;;;;;;;;EAuDxB;AAoFD;;;;;;;;;;GAUG;AACH,wBAAgB,eAAe,CAC7B,OAAO,EAAE,MAAM,EACf,MAAM,EAAE,MAAM,EACd,MAAM,EAAE,MAAM,EACd,GAAG,GAAE,MAAsC,EAC3C,QAAQ,GAAE,MAA4C,EACtD,YAAY,GAAE,MAAgD,GAC7D,QAAQ,CAUV;AAED;;;;;;;;;;;;;;GAcG;AACH,wBAAgB,mCAAmC,CACjD,OAAO,EAAE,MAAM,EACf,MAAM,EAAE,MAAM,EACd,GAAG,EAAE,MAAM,EACX,QAAQ,EAAE,MAAM,EAChB,YAAY,EAAE,MAAM,EACpB,OAAO,EAAE,MAAM,EACf,OAAO,EAAE,MAAM,EAAE,EACjB,QAAQ,CAAC,EAAE,MAAM,EACjB,SAAS,GAAE,MAAkB,GAC5B,aAAa,CAoCf;AAED;;;;;GAKG;AACH,wBAAgB,mBAAmB,CAAC,SAAS,EAAE,aAAa,GAAG,MAAM,EAAE,CAMtE;AAypBD;;;;;;;;;;;GAWG;AACH,wBAAgB,6BAA6B,CAC3C,eAAe,EAAE,MAAM,EACvB,OAAO,EAAE,MAAM,EACf,MAAM,EAAE,MAAM,EACd,GAAG,EAAE,MAAM,EACX,QAAQ,EAAE,MAAM,EAChB,YAAY,EAAE,MAAM,EACpB,OAAO,EAAE,MAAM,GACd,aAAa,CAcf"}