@bitgo-beta/sdk-coin-algo 1.3.19-beta.99 → 1.3.19-beta.990

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.
@@ -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.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
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,13 +15,23 @@ 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 (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
- };
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
  var __importDefault = (this && this.__importDefault) || function (mod) {
22
36
  return (mod && mod.__esModule) ? mod : { "default": mod };
23
37
  };
@@ -76,11 +90,11 @@ class Utils {
76
90
  }
77
91
  /** @inheritdoc */
78
92
  isValidPublicKey(key) {
79
- return sdk_core_1.isValidEd25519PublicKey(key);
93
+ return (0, sdk_core_1.isValidEd25519PublicKey)(key);
80
94
  }
81
95
  /** @inheritdoc */
82
96
  isValidPrivateKey(key) {
83
- return sdk_core_1.isValidEd25519SecretKey(key);
97
+ return (0, sdk_core_1.isValidEd25519SecretKey)(key);
84
98
  }
85
99
  /**
86
100
  * Returns an hex string of the given buffer
@@ -199,6 +213,16 @@ class Utils {
199
213
  publicKeyToAlgoAddress(pk) {
200
214
  return new keyPair_1.KeyPair({ pub: Buffer.from(pk).toString('hex') }).getAddress();
201
215
  }
216
+ /**
217
+ Transforms a decrypted Ed25519 private key into an algorand address.
218
+ @param {string} privateKey The Ed25519 private key.
219
+ @returns {string} The algorand address.
220
+ **/
221
+ privateKeyToAlgoAddress(privateKey) {
222
+ // Derive the account from the private key
223
+ const keypair = new keyPair_1.KeyPair({ prv: privateKey });
224
+ return keypair.getAddress();
225
+ }
202
226
  /**
203
227
  * Checks if a unsigned algo transaction can be decoded.
204
228
  *
@@ -536,4 +560,4 @@ class Utils {
536
560
  exports.Utils = Utils;
537
561
  const utils = new Utils();
538
562
  exports.default = utils;
539
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"utils.js","sourceRoot":"","sources":["../../../src/lib/utils.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;AAAA,sDAA8B;AAC9B,8DAAkC;AAClC,oDAAsC;AACtC,gDAAkC;AAClC,0DAA+B;AAC/B,0DAA+B;AAC/B,oDAAuB;AAEvB,uCAAoC;AACpC,iDAA8C;AAC9C,iFAAmE;AACnE,iFAAmE;AACnE,mDAO8B;AAE9B,MAAM,6BAA6B,GAAG,CAAC,CAAC;AACxC,MAAM,oBAAoB,GAAG,EAAE,CAAC;AAChC,MAAM,yBAAyB,GAAG,EAAE,CAAC;AACrC,MAAM,2BAA2B,GAAG,EAAE,CAAC;AACvC,MAAM,iBAAiB,GAAG,EAAE,CAAC;AAE7B;;;;;GAKG;AACH,SAAS,WAAW,CAAC,KAAa;IAChC,OAAO,mBAAmB,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;AACzC,CAAC;AAED;;;;;;GAMG;AACH,SAAS,YAAY,CAAC,CAAa,EAAE,CAAa;IAChD,MAAM,CAAC,GAAG,IAAI,UAAU,CAAC,CAAC,CAAC,MAAM,GAAG,CAAC,CAAC,MAAM,CAAC,CAAC;IAC9C,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;IACT,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC,MAAM,CAAC,CAAC;IACnB,OAAO,CAAC,CAAC;AACX,CAAC;AAED,MAAa,KAAK;IAChB,kBAAkB;IAClB,cAAc,CAAC,OAAe;QAC5B,OAAO,iBAAO,CAAC,cAAc,CAAC,OAAO,CAAC,CAAC;IACzC,CAAC;IAED,kBAAkB;IAClB,oBAAoB,CAAC,IAAY;QAC/B,IAAI,IAAI,CAAC,MAAM,KAAK,GAAG,EAAE;YACvB,OAAO,KAAK,CAAC;SACd;QAED,OAAO,WAAW,CAAC,IAAI,CAAC,CAAC;IAC3B,CAAC;IAED,kBAAkB;IAClB,gBAAgB,CAAC,GAAW;QAC1B,OAAO,kCAAuB,CAAC,GAAG,CAAC,CAAC;IACtC,CAAC;IAED,kBAAkB;IAClB,iBAAiB,CAAC,GAAW;QAC3B,OAAO,kCAAuB,CAAC,GAAG,CAAC,CAAC;IACtC,CAAC;IAED;;;;;OAKG;IACH,KAAK,CAAC,MAAkB;QACtB,OAAO,GAAG,CAAC,MAAM,CAAC,MAAM,EAAE,IAAI,CAAC,CAAC;IAClC,CAAC;IAED,kBAAkB;IAClB,gBAAgB,CAAC,SAAiB;QAChC,MAAM,IAAI,8BAAmB,CAAC,mCAAmC,CAAC,CAAC;IACrE,CAAC;IAED,kBAAkB;IAClB,cAAc,CAAC,IAAY;QACzB,MAAM,IAAI,8BAAmB,CAAC,uBAAuB,CAAC,CAAC;IACzD,CAAC;IAED;;;;;;OAMG;IACH,YAAY,CAAC,IAAgB,EAAE,IAAgB;QAC7C,OAAO,IAAI,CAAC,MAAM,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;IACjC,CAAC;IAED;;;;;OAKG;IACH,YAAY,CAAC,GAAW;QACtB,OAAO,MAAM,CAAC,IAAI,CAAC,GAAG,EAAE,KAAK,CAAC,CAAC;IACjC,CAAC;IAED;;;;;OAKG;IACH,WAAW,CAAC,IAAY;QACtB,IAAI,OAAO,IAAI,KAAK,QAAQ;YAAE,OAAO,KAAK,CAAC;QAE3C,IAAI,IAAI,CAAC,MAAM,KAAK,oBAAoB;YAAE,OAAO,KAAK,CAAC;QAEvD,gBAAgB;QAChB,IAAI,OAAO,CAAC;QACZ,IAAI;YACF,OAAO,GAAG,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC;SACjC;QAAC,OAAO,CAAC,EAAE;YACV,OAAO,KAAK,CAAC;SACd;QAED,mBAAmB;QACnB,MAAM,QAAQ,GAAG,IAAI,UAAU,CAC7B,mBAAM,CAAC,UAAU,CAAC,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,KAAK,CAAC,iBAAiB,GAAG,6BAA6B,EAAE,iBAAiB,CAAC,CAClH,CAAC;QAEF,8DAA8D;QAC9D,OAAO,gBAAC,CAAC,OAAO,CAAC,QAAQ,EAAE,OAAO,CAAC,QAAQ,CAAC,CAAC;IAC/C,CAAC;IAED;;;;;OAKG;IACH,UAAU,CAAC,SAAiB;QAC1B,WAAW;QACX,MAAM,IAAI,GAAG,SAAS,CAAC,KAAK,CAAC,CAAC,EAAE,iBAAiB,CAAC,CAAC;QACnD,mBAAmB;QACnB,MAAM,QAAQ,GAAG,MAAM,CAAC,IAAI,CAC1B,mBAAM,CAAC,UAAU,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,KAAK,CAAC,iBAAiB,GAAG,6BAA6B,EAAE,iBAAiB,CAAC,CAC1G,CAAC;QACF,MAAM,WAAW,GAAG,mBAAM,CAAC,MAAM,CAAC,YAAY,CAAC,IAAI,EAAE,QAAQ,CAAC,CAAC,CAAC;QAEhE,OAAO,WAAW,CAAC,QAAQ,EAAE,CAAC,KAAK,CAAC,CAAC,EAAE,oBAAoB,CAAC,CAAC,CAAC,4BAA4B;IAC5F,CAAC;IAED;;;;;;;;;OASG;IACH,UAAU,CAAC,IAAY;QACrB,gBAAgB;QAChB,MAAM,OAAO,GAAG,mBAAM,CAAC,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;QAE5C,eAAe;QACf,IAAI,OAAO,CAAC,MAAM,KAAK,yBAAyB;YAAE,MAAM,IAAI,KAAK,CAAC,4BAA4B,CAAC,CAAC;QAChG,OAAO;YACL,IAAI,EAAE,IAAI,UAAU,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,EAAE,yBAAyB,GAAG,6BAA6B,CAAC,CAAC;YACjG,QAAQ,EAAE,IAAI,UAAU,CAAC,OAAO,CAAC,KAAK,CAAC,iBAAiB,EAAE,yBAAyB,CAAC,CAAC;SACtF,CAAC;IACJ,CAAC;IAED;;;;;;;OAOG;IACH,eAAe,CAAC,OAAmB,EAAE,SAAiB,EAAE,GAAe;QACrE,OAAO,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,OAAO,EAAE,SAAS,EAAE,GAAG,CAAC,CAAC;IAC5D,CAAC;IAED;;;;;;;OAOG;IACH,sBAAsB,CAAC,EAAc;QACnC,OAAO,IAAI,iBAAO,CAAC,EAAE,GAAG,EAAE,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC,UAAU,EAAE,CAAC;IAC5E,CAAC;IACD;;;;;OAKG;IACO,0BAA0B,CAAC,GAAe;QAClD,IAAI;YACF,iBAAO,CAAC,yBAAyB,CAAC,GAAG,CAAC,CAAC;YACvC,OAAO,IAAI,CAAC;SACb;QAAC,MAAM;YACN,OAAO,KAAK,CAAC;SACd;IACH,CAAC;IAED;;;;;OAKG;IACO,4BAA4B,CAAC,GAAe;QACpD,IAAI;YACF,iBAAO,CAAC,uBAAuB,CAAC,GAAG,CAAC,CAAC;YACrC,OAAO,IAAI,CAAC;SACb;QAAC,MAAM;YACN,OAAO,KAAK,CAAC;SACd;IACH,CAAC;IAED;;;;;OAKG;IACH,aAAa,CAAC,QAA6B;QACzC,IAAI,MAAM,GACR,OAAO,QAAQ,KAAK,QAAQ;YAC1B,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,QAAQ,EAAE,WAAW,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,QAAQ,CAAC;YACjE,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QAE5B,wFAAwF;QACxF,iEAAiE;QACjE,gFAAgF;QAChF,oBAAoB;QACpB,gGAAgG;QAChG,MAAM,SAAS,GAAG,QAAQ,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;QAC1C,IACE,SAAS,CAAC,GAAG;YACb,SAAS,CAAC,GAAG,CAAC,IAAI,KAAK,QAAQ;YAC/B,SAAS,CAAC,GAAG,CAAC,OAAO;YACrB,SAAS,CAAC,GAAG,CAAC,OAAO;YACrB,SAAS,CAAC,GAAG,CAAC,MAAM,EACpB;YACA,SAAS,CAAC,GAAG,CAAC,OAAO,GAAG,SAAS,CAAC,GAAG,CAAC,OAAO,IAAI,SAAS,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;YAC7E,SAAS,CAAC,GAAG,CAAC,MAAM,GAAG,SAAS,CAAC,GAAG,CAAC,MAAM,IAAI,SAAS,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;YAC3E,MAAM,GAAG,SAAS,CAAC,IAAI,IAAI,SAAS,CAAC,GAAG,CAAC,CAAC,CAAC,QAAQ,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,MAAM,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC;SACxG;QAED,IAAI;YACF,OAAO,IAAI,CAAC,8BAA8B,CAAC,MAAM,CAAC,CAAC;SACpD;QAAC,MAAM;YACN,uCAAuC;SACxC;QAED,IAAI;YACF,OAAO,IAAI,CAAC,4BAA4B,CAAC,MAAM,CAAC,CAAC;SAClD;QAAC,MAAM;YACN,MAAM,IAAI,kCAAuB,CAAC,+BAA+B,CAAC,CAAC;SACpE;IACH,CAAC;IAED;;;;;OAKG;IACH,4BAA4B,CAAC,MAAc;QACzC,qBAAqB;QACrB,iGAAiG;QACjG,8DAA8D;QAC9D,8GAA8G;QAC9G,wGAAwG;QACxG,MAAM,EAAE,GAAG,iBAAO,CAAC,uBAAuB,CAAC,MAAM,CAAC,CAAC;QAEnD,MAAM,OAAO,GAAa,EAAE,CAAC;QAC7B,MAAM,QAAQ,GAAa,EAAE,CAAC;QAC9B,IAAI,EAAE,CAAC,IAAI,IAAI,EAAE,CAAC,IAAI,CAAC,MAAM,EAAE;YAC7B,KAAK,MAAM,GAAG,IAAI,EAAE,CAAC,IAAI,CAAC,MAAM,EAAE;gBAChC,MAAM,IAAI,GAAG,iBAAO,CAAC,aAAa,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;gBAC3C,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;gBACnB,IAAI,GAAG,CAAC,CAAC,EAAE;oBACT,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;iBACrB;aACF;SACF;QAED,OAAO;YACL,cAAc,EAAE,IAAI,UAAU,CAAC,MAAM,CAAC;YACtC,GAAG,EAAE,EAAE,CAAC,GAAG;YACX,MAAM,EAAE,IAAI;YACZ,OAAO,EAAE,OAAO;YAChB,QAAQ,EAAE,QAAQ;SACnB,CAAC;IACJ,CAAC;IAED;;;;;OAKG;IACH,8BAA8B,CAAC,MAAc;QAC3C,MAAM,GAAG,GAAG,iBAAO,CAAC,yBAAyB,CAAC,MAAM,CAAC,CAAC;QACtD,OAAO;YACL,cAAc,EAAE,IAAI,UAAU,CAAC,MAAM,CAAC;YACtC,GAAG;YACH,MAAM,EAAE,KAAK;SACd,CAAC;IACJ,CAAC;IAED;;;;;;OAMG;IACH,SAAS,CAAC,GAA0C;QAClD,OAAO,iBAAO,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC;IAChC,CAAC;IAED;;;;OAIG;IACH,SAAS,CAAC,CAAoB;QAC5B,OAAO,iBAAO,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC;IAC9B,CAAC;IAED;;;;;OAKG;IACH,mBAAmB,CAAC,EAAU;QAC5B,MAAM,OAAO,GAAG,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,CAAC;QAChD,IAAI,CAAC,IAAI,CAAC,iBAAiB,CAAC,OAAO,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,EAAE;YACpD,MAAM,IAAI,qBAAU,CAAC,mBAAmB,EAAE,CAAC,QAAQ,CAAC,KAAK,CAAC,aAAa,CAAC,CAAC;SAC1E;QACD,MAAM,YAAY,GAAG,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;QACrC,OAAO,iBAAO,CAAC,mBAAmB,CAAC,YAAY,CAAC,CAAC;IACnD,CAAC;IAED;;;;;;;OAOG;IACH,gBAAgB,CAAC,QAAgB;QAC/B,OAAO,iBAAO,CAAC,6BAA6B,CAAC,QAAQ,CAAC,CAAC;IACzD,CAAC;IAED;;;;OAIG;IACH,eAAe,CAAC,IAAgB;QAC9B,MAAM,EAAE,GAAG,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,CAAC;QACvC,MAAM,gBAAgB,GAAG,iBAAO,CAAC,mBAAmB,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC;QAC5D,OAAO,IAAI,CAAC,aAAa,CAAC,gBAAgB,CAAC,CAAC;IAC9C,CAAC;IAED;;;;;OAKG;IACO,aAAa,CAAC,gBAA4B;QAClD,MAAM,EAAE,GAAG,gBAAgB,CAAC,KAAK,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;QACzC,OAAO,IAAI,iBAAO,CAAC,EAAE,GAAG,EAAE,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC;IAC/D,CAAC;IAED;;;;;OAKG;IACO,gBAAgB,CAAC,IAAgB;QACzC,OAAO,iBAAO,CAAC,6BAA6B,CAAC,IAAI,CAAC,CAAC;IACrD,CAAC;IAED;;;;;OAKG;IACO,8BAA8B,CAAC,SAAiB;QACxD,OAAO,qBAAO,CAAC,MAAM,CAAC,uBAAuB,CAAC,SAAS,CAAC,CAAC;IAC3D,CAAC;IAED;;;;;OAKG;IACO,6BAA6B,CAAC,SAAiB;QACvD,OAAO,qBAAO,CAAC,MAAM,CAAC,sBAAsB,CAAC,SAAS,CAAC,CAAC;IAC1D,CAAC;IAED;;;;;OAKG;IACH,sBAAsB,CAAC,IAAY;QACjC,OAAO,2BAAY,CAAC,MAAM,CAAC,qBAAO,CAAC,MAAM,CAAC,uBAAuB,CAAC,IAAI,CAAC,CAAC,CAAC;IAC3E,CAAC;IAED;;;;;OAKG;IACH,aAAa,CAAC,IAAgB;QAC5B,OAAO,iBAAO,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC;IACrC,CAAC;IAED;;;;;OAKG;IACH,aAAa,CAAC,IAAY;QACxB,OAAO,iBAAO,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC;IACrC,CAAC;IAED;;;;;;OAMG;IACH,2BAA2B,CAAC,eAAuB;QACjD,8BAA8B;QAC9B,IAAI,IAAI,CAAC,cAAc,CAAC,eAAe,CAAC,EAAE;YACxC,OAAO,eAAe,CAAC;SACxB;QACD,wBAAwB;QACxB,IAAI,IAAI,CAAC,8BAA8B,CAAC,eAAe,CAAC,EAAE;YACxD,MAAM,UAAU,GAAG,IAAI,CAAC,6BAA6B,CAAC,eAAe,CAAC,CAAC;YACvE,MAAM,WAAW,GAAG,IAAI,CAAC,aAAa,CAAC,UAAU,CAAC,CAAC;YACnD,IAAI,IAAI,CAAC,cAAc,CAAC,WAAW,CAAC,EAAE;gBACpC,OAAO,WAAW,CAAC;aACpB;YACD,MAAM,IAAI,KAAK,CAAC,mEAAmE,CAAC,CAAC;SACtF;QACD,MAAM,IAAI,KAAK,CAAC,mDAAmD,CAAC,CAAC;IACvE,CAAC;IAED;;;;;;;OAOG;IACH,eAAe,CAAC,OAAe,EAAE,SAAiB,EAAE,KAAe;QACjE,OAAO,iBAAO,CAAC,eAAe,CAAC;YAC7B,OAAO;YACP,SAAS;YACT,KAAK;SACN,CAAC,CAAC;IACL,CAAC;IAED;;;;;OAKG;IACH,eAAe;QACb,OAAO,iBAAO,CAAC,eAAe,EAAE,CAAC;IACnC,CAAC;IAED,uBAAuB,CAAC,IAAgB;QACtC,MAAM,IAAI,GAAG,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;QAC9C,OAAO;YACL,IAAI,EAAE,iBAAO,CAAC,aAAa,CAAC,IAAI,CAAC,SAAS,CAAC;YAC3C,EAAE,EAAE,IAAI,CAAC,SAAS;SACnB,CAAC;IACJ,CAAC;IAED;;;;;;;;OAQG;IACH,eAAe,CAAC,QAAgB;QAC9B,MAAM,OAAO,GAAG,MAAM,CAAC,IAAI,CAAC,QAAQ,EAAE,QAAQ,CAAC,CAAC;QAChD,MAAM,YAAY,GAAG,iBAAO,CAAC,uBAAuB,CAAC,OAAO,CAAC,CAAC;QAC9D,MAAM,uBAAuB,GAAG,YAAY,CAAC,GAAG,CAAC,oBAAoB,EAAE,CAAC;QACxE,MAAM,aAAa,GAAG,EAAE,IAAI,EAAE,YAAY,CAAC,IAAI,EAAE,GAAG,EAAE,uBAAuB,EAAE,CAAC;QAChF,MAAM,MAAM,GAAG,QAAQ,CAAC,MAAM,CAAC,aAAa,CAAC,CAAC;QAC9C,MAAM,GAAG,GAAG,MAAM,CAAC,IAAI,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC,CAAC;QAClC,MAAM,EAAE,GAAG,MAAM,CAAC,IAAI,CAAC,YAAY,CAAC,GAAG,EAAE,MAAM,CAAC,CAAC,CAAC;QAClD,MAAM,IAAI,GAAG,MAAM,CAAC,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,EAAE,CAAC,CAAC,CAAC;QACnD,OAAO,mBAAM,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,KAAK,CAAC,CAAC,EAAE,2BAA2B,CAAC,CAAC;IACnE,CAAC;IAED;;;;;;;OAOG;IACH,cAAc,CAAC,MAAc,EAAE,IAAY,EAAE,EAAU,EAAE,gBAAyB;QAChF,IAAI,IAAI,GAAG,eAAe,CAAC;QAC3B,IAAI,MAAM,KAAK,GAAG,IAAI,IAAI,KAAK,EAAE,EAAE;YACjC,IAAI,GAAG,CAAC,gBAAgB,CAAC,CAAC,CAAC,aAAa,CAAC,CAAC,CAAC,cAAc,CAAC;SAC3D;QACD,OAAO,IAAI,CAAC;IACd,CAAC;IAED;;;OAGG;IACH,cAAc,CAAC,GAAW;QACxB,IAAI,CAAC,GAAG,IAAI,OAAO,GAAG,KAAK,QAAQ,EAAE;YACnC,MAAM,IAAI,KAAK,CAAC,uBAAuB,CAAC,CAAC;SAC1C;QACD,MAAM,YAAY,GAChB,sGAAsG,CAAC;QACzG,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE;YAC3B,MAAM,IAAI,KAAK,CAAC,uBAAuB,CAAC,CAAC;SAC1C;IACH,CAAC;CACF;AAtgBD,sBAsgBC;AAED,MAAM,KAAK,GAAG,IAAI,KAAK,EAAE,CAAC;AAE1B,kBAAe,KAAK,CAAC","sourcesContent":["import algosdk from 'algosdk';\nimport stellar from 'stellar-sdk';\nimport * as hex from '@stablelib/hex';\nimport * as nacl from 'tweetnacl';\nimport base32 from 'hi-base32';\nimport sha512 from 'js-sha512';\nimport _ from 'lodash';\nimport { Address, EncodedTx, Seed } from './ifaces';\nimport { KeyPair } from './keyPair';\nimport { SeedEncoding } from './seedEncoding';\nimport * as algoNacl from 'algosdk/dist/cjs/src/nacl/naclWrappers';\nimport * as encoding from 'algosdk/dist/cjs/src/encoding/encoding';\nimport {\n  BaseUtils,\n  NotImplementedError,\n  InvalidTransactionError,\n  InvalidKey,\n  isValidEd25519PublicKey,\n  isValidEd25519SecretKey,\n} from '@bitgo-beta/sdk-core';\n\nconst ALGORAND_CHECKSUM_BYTE_LENGTH = 4;\nconst ALGORAND_SEED_LENGTH = 58;\nconst ALGORAND_SEED_BYTE_LENGTH = 36;\nconst ALGORAND_TRANSACTION_LENGTH = 52;\nconst SEED_BYTES_LENGTH = 32;\n\n/**\n * Determines whether the string is only composed of hex chars.\n *\n * @param {string} maybe The string to be validated.\n * @returns {boolean} true if the string consists of only hex characters, otherwise false.\n */\nfunction allHexChars(maybe: string): boolean {\n  return /^([0-9a-f]{2})+$/i.test(maybe);\n}\n\n/**\n * ConcatArrays takes two array and returns a joint array of both\n *\n * @param a {Uint8Array} first array to concat\n * @param b {Uint8Array} second array\n * @returns {Uint8Array} a new array containing all elements of 'a' followed by all elements of 'b'\n */\nfunction concatArrays(a: Uint8Array, b: Uint8Array): Uint8Array {\n  const c = new Uint8Array(a.length + b.length);\n  c.set(a);\n  c.set(b, a.length);\n  return c;\n}\n\nexport class Utils implements BaseUtils {\n  /** @inheritdoc */\n  isValidAddress(address: string): boolean {\n    return algosdk.isValidAddress(address);\n  }\n\n  /** @inheritdoc */\n  isValidTransactionId(txId: string): boolean {\n    if (txId.length !== 104) {\n      return false;\n    }\n\n    return allHexChars(txId);\n  }\n\n  /** @inheritdoc */\n  isValidPublicKey(key: string): boolean {\n    return isValidEd25519PublicKey(key);\n  }\n\n  /** @inheritdoc */\n  isValidPrivateKey(key: string): boolean {\n    return isValidEd25519SecretKey(key);\n  }\n\n  /**\n   * Returns an hex string of the given buffer\n   *\n   * @param {Uint8Array} buffer - the buffer to be converted to hex\n   * @returns {string} - the hex value\n   */\n  toHex(buffer: Uint8Array): string {\n    return hex.encode(buffer, true);\n  }\n\n  /** @inheritdoc */\n  isValidSignature(signature: string): boolean {\n    throw new NotImplementedError('isValidSignature not implemented.');\n  }\n\n  /** @inheritdoc */\n  isValidBlockId(hash: string): boolean {\n    throw new NotImplementedError('hash not implemented.');\n  }\n\n  /**\n   * Compare two Keys\n   *\n   * @param {Uint8Array} key1 - key to be compare\n   * @param {Uint8Array} key2 - key to be compare\n   * @returns {boolean} - returns true if both keys are equal\n   */\n  areKeysEqual(key1: Uint8Array, key2: Uint8Array): boolean {\n    return nacl.verify(key1, key2);\n  }\n\n  /**\n   * Returns a Uint8Array of the given hex string\n   *\n   * @param {string} str - the hex string to be converted\n   * @returns {string} - the Uint8Array value\n   */\n  toUint8Array(str: string): Uint8Array {\n    return Buffer.from(str, 'hex');\n  }\n\n  /**\n   * Determines whether a seed is valid.\n   *\n   * @param {string} seed - the seed to be validated\n   * @returns {boolean} - true if the seed is valid\n   */\n  isValidSeed(seed: string): boolean {\n    if (typeof seed !== 'string') return false;\n\n    if (seed.length !== ALGORAND_SEED_LENGTH) return false;\n\n    // Try to decode\n    let decoded;\n    try {\n      decoded = this.decodeSeed(seed);\n    } catch (e) {\n      return false;\n    }\n\n    // Compute checksum\n    const checksum = new Uint8Array(\n      sha512.sha512_256.array(decoded.seed).slice(SEED_BYTES_LENGTH - ALGORAND_CHECKSUM_BYTE_LENGTH, SEED_BYTES_LENGTH)\n    );\n\n    // Check if the checksum matches the one from the decoded seed\n    return _.isEqual(checksum, decoded.checksum);\n  }\n\n  /**\n   * Encode an algo seed\n   *\n   * @param  {Buffer} secretKey - the valid secretKey .\n   * @returns {string} - the seed to be validated.\n   */\n  encodeSeed(secretKey: Buffer): string {\n    // get seed\n    const seed = secretKey.slice(0, SEED_BYTES_LENGTH);\n    // compute checksum\n    const checksum = Buffer.from(\n      sha512.sha512_256.array(seed).slice(SEED_BYTES_LENGTH - ALGORAND_CHECKSUM_BYTE_LENGTH, SEED_BYTES_LENGTH)\n    );\n    const encodedSeed = base32.encode(concatArrays(seed, checksum));\n\n    return encodedSeed.toString().slice(0, ALGORAND_SEED_LENGTH); // removing the extra '===='\n  }\n\n  /**\n   * decodeSeed decodes an algo seed\n   *\n   * Decoding algo seed is same as decoding address.\n   * Latest version of algo sdk (1.9, at this writing) does not expose explicit method for decoding seed.\n   * Parameter is decoded and split into seed and checksum.\n   *\n   * @param {string} seed - hex or base64 encoded seed to be validated\n   * @returns {Seed} - validated object Seed\n   */\n  decodeSeed(seed: string): Seed {\n    // try to decode\n    const decoded = base32.decode.asBytes(seed);\n\n    // Sanity check\n    if (decoded.length !== ALGORAND_SEED_BYTE_LENGTH) throw new Error('seed seems to be malformed');\n    return {\n      seed: new Uint8Array(decoded.slice(0, ALGORAND_SEED_BYTE_LENGTH - ALGORAND_CHECKSUM_BYTE_LENGTH)),\n      checksum: new Uint8Array(decoded.slice(SEED_BYTES_LENGTH, ALGORAND_SEED_BYTE_LENGTH)),\n    };\n  }\n\n  /**\n   * Verifies if signature for message is valid.\n   *\n   * @param pub {Uint8Array} public key\n   * @param message {Uint8Array} signed message\n   * @param signature {Buffer} signature to verify\n   * @returns {Boolean} true if signature is valid.\n   */\n  verifySignature(message: Uint8Array, signature: Buffer, pub: Uint8Array): boolean {\n    return nacl.sign.detached.verify(message, signature, pub);\n  }\n\n  /**\n   * Transforms an Ed25519 public key into an algorand address.\n   *\n   * @param {Uint8Array} pk The Ed25519 public key.\n   * @see https://developer.algorand.org/docs/features/accounts/#transformation-public-key-to-algorand-address\n   *\n   * @returns {string} The algorand address.\n   */\n  publicKeyToAlgoAddress(pk: Uint8Array): string {\n    return new KeyPair({ pub: Buffer.from(pk).toString('hex') }).getAddress();\n  }\n  /**\n   * Checks if a unsigned algo transaction can be decoded.\n   *\n   * @param {Uint8Array} txn The encoded unsigned transaction.\n   * @returns {boolean} true if the transaction can be decoded, otherwise false\n   */\n  protected isDecodableUnsignedAlgoTxn(txn: Uint8Array): boolean {\n    try {\n      algosdk.decodeUnsignedTransaction(txn);\n      return true;\n    } catch {\n      return false;\n    }\n  }\n\n  /**\n   * Checks if a signed algo transaction can be decoded.\n   *\n   * @param {Uint8Array} txn The encoded signed transaction.\n   * @returns {boolean} true if the transaction can be decoded, otherwise false\n   */\n  protected isDecodableSignedTransaction(txn: Uint8Array): boolean {\n    try {\n      algosdk.decodeSignedTransaction(txn);\n      return true;\n    } catch {\n      return false;\n    }\n  }\n\n  /**\n   * Decodes a signed or unsigned algo transaction.\n   *\n   * @param {Uint8Array | string} txnBytes The encoded unsigned or signed txn.\n   * @returns {EncodedTx} The decoded transaction.\n   */\n  decodeAlgoTxn(txnBytes: Uint8Array | string): EncodedTx {\n    let buffer =\n      typeof txnBytes === 'string'\n        ? Buffer.from(txnBytes, allHexChars(txnBytes) ? 'hex' : 'base64')\n        : Buffer.from(txnBytes);\n\n    // In order to maintain backward compatibility with old keyreg transactions encoded with\n    // forked algosdk 1.2.0 (https://github.com/BitGo/algosdk-bitgo),\n    // the relevant information is extracted and parsed following the latest algosdk\n    // release standard.\n    // This way we can decode transactions successfully by still maintaining backward compatibility.\n    const decodedTx = encoding.decode(buffer);\n    if (\n      decodedTx.txn &&\n      decodedTx.txn.type === 'keyreg' &&\n      decodedTx.txn.votefst &&\n      decodedTx.txn.votelst &&\n      decodedTx.txn.votekd\n    ) {\n      decodedTx.txn.votekey = decodedTx.txn.votekey || decodedTx.msig.subsig[0].pk;\n      decodedTx.txn.selkey = decodedTx.txn.selkey || decodedTx.msig.subsig[0].pk;\n      buffer = decodedTx.msig || decodedTx.sig ? encoding.encode(decodedTx) : encoding.encode(decodedTx.txn);\n    }\n\n    try {\n      return this.tryToDecodeUnsignedTransaction(buffer);\n    } catch {\n      // Ignore error to try different format\n    }\n\n    try {\n      return this.tryToDecodeSignedTransaction(buffer);\n    } catch {\n      throw new InvalidTransactionError('Transaction cannot be decoded');\n    }\n  }\n\n  /**\n   * Try to decode a signed Algo transaction\n   * @param buffer the encoded transaction\n   * @returns { EncodedTx } the decoded signed transaction\n   * @throws error if it is not a valid encoded signed transaction\n   */\n  tryToDecodeSignedTransaction(buffer: Buffer): EncodedTx {\n    // TODO: Replace with\n    // return algosdk.Transaction.from_obj_for_encoding(algosdk.decodeSignedTransaction(buffer).txn);\n    // see: https://github.com/algorand/js-algorand-sdk/issues/364\n    // \"...some parts of the codebase treat the output of Transaction.from_obj_for_encoding as EncodedTransaction.\n    // They need to be fixed(or we at least need to make it so Transaction conforms to EncodedTransaction).\"\n    const tx = algosdk.decodeSignedTransaction(buffer);\n\n    const signers: string[] = [];\n    const signedBy: string[] = [];\n    if (tx.msig && tx.msig.subsig) {\n      for (const sig of tx.msig.subsig) {\n        const addr = algosdk.encodeAddress(sig.pk);\n        signers.push(addr);\n        if (sig.s) {\n          signedBy.push(addr);\n        }\n      }\n    }\n\n    return {\n      rawTransaction: new Uint8Array(buffer),\n      txn: tx.txn,\n      signed: true,\n      signers: signers,\n      signedBy: signedBy,\n    };\n  }\n\n  /**\n   * Try to decode an unsigned Algo transaction\n   * @param buffer the encoded transaction\n   * @returns {EncodedTx} the decoded unsigned transaction\n   * @throws error if it is not a valid encoded unsigned transaction\n   */\n  tryToDecodeUnsignedTransaction(buffer: Buffer): EncodedTx {\n    const txn = algosdk.decodeUnsignedTransaction(buffer);\n    return {\n      rawTransaction: new Uint8Array(buffer),\n      txn,\n      signed: false,\n    };\n  }\n\n  /*\n   * encodeObj takes a javascript object and returns its msgpack encoding\n   * Note that the encoding sorts the fields alphabetically\n   *\n   * @param {Record<string | number | symbol, any>} obj js obj\n   * @returns {Uint8Array} Uint8Array binary representation\n   */\n  encodeObj(obj: Record<string | number | symbol, any>): Uint8Array {\n    return algosdk.encodeObj(obj);\n  }\n\n  /**\n   * decodeObj takes a Uint8Array and returns its javascript obj\n   * @param o - Uint8Array to decode\n   * @returns object\n   */\n  decodeObj(o: ArrayLike<number>): unknown {\n    return algosdk.decodeObj(o);\n  }\n\n  /**\n   * secretKeyToMnemonic takes an Algorant secret key and returns the corresponding mnemonic\n   *\n   * @param sk - Algorant secret key\n   * @return Secret key is associated mnemonic\n   */\n  secretKeyToMnemonic(sk: Buffer): string {\n    const skValid = Buffer.from(sk.toString('hex'));\n    if (!this.isValidPrivateKey(skValid.toString('hex'))) {\n      throw new InvalidKey(`The secret key: ${sk.toString('hex')} is invalid`);\n    }\n    const skUnit8Array = Buffer.from(sk);\n    return algosdk.secretKeyToMnemonic(skUnit8Array);\n  }\n\n  /**\n   * seedFromMnemonic converts a mnemonic generated using this library into the source key used to create it\n   * It returns an error if the passed mnemonic has an incorrect checksum, if the number of words is unexpected, or if one\n   * of the passed words is not found in the words list\n   *\n   * @param mnemonic - 25 words mnemonic\n   * @returns 32 bytes long seed\n   */\n  seedFromMnemonic(mnemonic: string): Uint8Array {\n    return algosdk.mnemonicToMasterDerivationKey(mnemonic);\n  }\n\n  /**\n   * keyPairFromSeed generates an object with secretKey and publicKey using the algosdk\n   * @param seed 32 bytes long seed\n   * @returns KeyPair\n   */\n  keyPairFromSeed(seed: Uint8Array): KeyPair {\n    const mn = this.mnemonicFromSeed(seed);\n    const base64PrivateKey = algosdk.mnemonicToSecretKey(mn).sk;\n    return this.createKeyPair(base64PrivateKey);\n  }\n\n  /**\n   * Generate a new `KeyPair` object from the given private key.\n   *\n   * @param base64PrivateKey 64 bytes long privateKey\n   * @returns KeyPair\n   */\n  protected createKeyPair(base64PrivateKey: Uint8Array): KeyPair {\n    const sk = base64PrivateKey.slice(0, 32);\n    return new KeyPair({ prv: Buffer.from(sk).toString('hex') });\n  }\n\n  /**\n   * decodePrivateKey generates a seed with a mnemonic and using algosdk.\n   *\n   * @param seed 32 bytes long seed\n   * @returns mnemonic - 25 words mnemonic - 25 words mnemonic\n   */\n  protected mnemonicFromSeed(seed: Uint8Array): string {\n    return algosdk.masterDerivationKeyToMnemonic(seed);\n  }\n\n  /**\n   * Validates the key with the stellar-sdk\n   *\n   * @param publicKey\n   * @returns boolean\n   */\n  protected isValidEd25519PublicKeyStellar(publicKey: string): boolean {\n    return stellar.StrKey.isValidEd25519PublicKey(publicKey);\n  }\n\n  /**\n   * Decodes the key with the stellar-sdk\n   *\n   * @param publicKey\n   * @returns Buffer\n   */\n  protected decodeEd25519PublicKeyStellar(publicKey: string): Buffer {\n    return stellar.StrKey.decodeEd25519PublicKey(publicKey);\n  }\n\n  /**\n   * Convert a stellar seed to algorand encoding\n   *\n   * @param seed\n   * @returns string the encoded seed\n   */\n  convertFromStellarSeed(seed: string): string {\n    return SeedEncoding.encode(stellar.StrKey.decodeEd25519SecretSeed(seed));\n  }\n\n  /**\n   * Returns an address encoded with algosdk\n   *\n   * @param addr\n   * @returns string\n   */\n  encodeAddress(addr: Uint8Array): string {\n    return algosdk.encodeAddress(addr);\n  }\n\n  /**\n   * Return an address decoded with algosdk\n   *\n   * @param addr\n   * @returns Address\n   */\n  decodeAddress(addr: string): Address {\n    return algosdk.decodeAddress(addr);\n  }\n\n  /**\n   * Converts an address into an ALGO one\n   * If the given data is a Stellar address or public key, it is converted to ALGO address.\n   *\n   * @param addressOrPubKey an ALGO address, or an Stellar address or public key\n   * @returns address algo address string\n   */\n  stellarAddressToAlgoAddress(addressOrPubKey: string): string {\n    // we have an Algorand address\n    if (this.isValidAddress(addressOrPubKey)) {\n      return addressOrPubKey;\n    }\n    // we have a stellar key\n    if (this.isValidEd25519PublicKeyStellar(addressOrPubKey)) {\n      const stellarPub = this.decodeEd25519PublicKeyStellar(addressOrPubKey);\n      const algoAddress = this.encodeAddress(stellarPub);\n      if (this.isValidAddress(algoAddress)) {\n        return algoAddress;\n      }\n      throw new Error('Cannot convert Stellar address to an Algorand address via pubkey.');\n    }\n    throw new Error('Neither an Algorand address nor a stellar pubkey.');\n  }\n\n  /**\n   * multisigAddress takes multisig metadata (preimage) and returns the corresponding human readable Algorand address.\n   *\n   * @param {number} version mutlisig version\n   * @param {number} threshold multisig threshold\n   * @param {string[]} addrs list of Algorand addresses\n   * @returns {string} human readable Algorand address.\n   */\n  multisigAddress(version: number, threshold: number, addrs: string[]): string {\n    return algosdk.multisigAddress({\n      version,\n      threshold,\n      addrs,\n    });\n  }\n\n  /**\n   * generateAccount generates un account with a secretKey and an address\n   *\n   * Function has not params\n   * @returns Account\n   */\n  generateAccount(): algosdk.Account {\n    return algosdk.generateAccount();\n  }\n\n  generateAccountFromSeed(seed: Uint8Array): algosdk.Account {\n    const keys = nacl.sign.keyPair.fromSeed(seed);\n    return {\n      addr: algosdk.encodeAddress(keys.publicKey),\n      sk: keys.secretKey,\n    };\n  }\n\n  /**\n   * Generates Tx ID from an encoded multisig transaction\n   *\n   * This is done because of a change made on version 1.10.1 on algosdk so method txID() only supports SignedTransaction type.\n   * (https://github.com/algorand/js-algorand-sdk/blob/develop/CHANGELOG.md#1101)\n   *\n   * @param {string} txBase64 - encoded base64 multisig transaction\n   * @returns {string} - transaction ID\n   */\n  getMultisigTxID(txBase64: string): string {\n    const txBytes = Buffer.from(txBase64, 'base64');\n    const decodeSignTx = algosdk.decodeSignedTransaction(txBytes);\n    const wellFormedDecodedSignTx = decodeSignTx.txn.get_obj_for_encoding();\n    const txForEncoding = { msig: decodeSignTx.msig, txn: wellFormedDecodedSignTx };\n    const en_msg = encoding.encode(txForEncoding);\n    const tag = Buffer.from([84, 88]);\n    const gh = Buffer.from(concatArrays(tag, en_msg));\n    const hash = Buffer.from(algoNacl.genericHash(gh));\n    return base32.encode(hash).slice(0, ALGORAND_TRANSACTION_LENGTH);\n  }\n\n  /**\n   * Determines if a given transaction data is to enable or disable a token\n   * @param amount the amount in transaction\n   * @param from the originated address\n   * @param to the target address\n   * @param closeRemainderTo (optional) address to send remaining units in originated address\n   * @returns 'enableToken' or 'disableToken'\n   */\n  getTokenTxType(amount: string, from: string, to: string, closeRemainderTo?: string): string {\n    let type = 'transferToken';\n    if (amount === '0' && from === to) {\n      type = !closeRemainderTo ? 'enableToken' : 'disableToken';\n    }\n    return type;\n  }\n\n  /**\n   * Validate if the key is a valid base64 string\n   * @param key the key to validate\n   */\n  validateBase64(key: string): void {\n    if (!key || typeof key !== 'string') {\n      throw new Error('Invalid base64 string');\n    }\n    const base64RegExp =\n      /^(?:[a-zA-Z0-9+\\/]{4})*(?:|(?:[a-zA-Z0-9+\\/]{3}=)|(?:[a-zA-Z0-9+\\/]{2}==)|(?:[a-zA-Z0-9+\\/]{1}===))$/;\n    if (!base64RegExp.test(key)) {\n      throw new Error('Invalid base64 string');\n    }\n  }\n}\n\nconst utils = new Utils();\n\nexport default utils;\n"]}
563
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"utils.js","sourceRoot":"","sources":["../../../src/lib/utils.ts"],"names":[],"mappings":"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","sourcesContent":["import algosdk from 'algosdk';\nimport stellar from 'stellar-sdk';\nimport * as hex from '@stablelib/hex';\nimport * as nacl from 'tweetnacl';\nimport base32 from 'hi-base32';\nimport sha512 from 'js-sha512';\nimport _ from 'lodash';\nimport { Address, EncodedTx, Seed } from './ifaces';\nimport { KeyPair } from './keyPair';\nimport { SeedEncoding } from './seedEncoding';\nimport * as algoNacl from 'algosdk/dist/cjs/src/nacl/naclWrappers';\nimport * as encoding from 'algosdk/dist/cjs/src/encoding/encoding';\nimport {\n  BaseUtils,\n  NotImplementedError,\n  InvalidTransactionError,\n  InvalidKey,\n  isValidEd25519PublicKey,\n  isValidEd25519SecretKey,\n} from '@bitgo-beta/sdk-core';\n\nconst ALGORAND_CHECKSUM_BYTE_LENGTH = 4;\nconst ALGORAND_SEED_LENGTH = 58;\nconst ALGORAND_SEED_BYTE_LENGTH = 36;\nconst ALGORAND_TRANSACTION_LENGTH = 52;\nconst SEED_BYTES_LENGTH = 32;\n\n/**\n * Determines whether the string is only composed of hex chars.\n *\n * @param {string} maybe The string to be validated.\n * @returns {boolean} true if the string consists of only hex characters, otherwise false.\n */\nfunction allHexChars(maybe: string): boolean {\n  return /^([0-9a-f]{2})+$/i.test(maybe);\n}\n\n/**\n * ConcatArrays takes two array and returns a joint array of both\n *\n * @param a {Uint8Array} first array to concat\n * @param b {Uint8Array} second array\n * @returns {Uint8Array} a new array containing all elements of 'a' followed by all elements of 'b'\n */\nfunction concatArrays(a: Uint8Array, b: Uint8Array): Uint8Array {\n  const c = new Uint8Array(a.length + b.length);\n  c.set(a);\n  c.set(b, a.length);\n  return c;\n}\n\nexport class Utils implements BaseUtils {\n  /** @inheritdoc */\n  isValidAddress(address: string): boolean {\n    return algosdk.isValidAddress(address);\n  }\n\n  /** @inheritdoc */\n  isValidTransactionId(txId: string): boolean {\n    if (txId.length !== 104) {\n      return false;\n    }\n\n    return allHexChars(txId);\n  }\n\n  /** @inheritdoc */\n  isValidPublicKey(key: string): boolean {\n    return isValidEd25519PublicKey(key);\n  }\n\n  /** @inheritdoc */\n  isValidPrivateKey(key: string): boolean {\n    return isValidEd25519SecretKey(key);\n  }\n\n  /**\n   * Returns an hex string of the given buffer\n   *\n   * @param {Uint8Array} buffer - the buffer to be converted to hex\n   * @returns {string} - the hex value\n   */\n  toHex(buffer: Uint8Array): string {\n    return hex.encode(buffer, true);\n  }\n\n  /** @inheritdoc */\n  isValidSignature(signature: string): boolean {\n    throw new NotImplementedError('isValidSignature not implemented.');\n  }\n\n  /** @inheritdoc */\n  isValidBlockId(hash: string): boolean {\n    throw new NotImplementedError('hash not implemented.');\n  }\n\n  /**\n   * Compare two Keys\n   *\n   * @param {Uint8Array} key1 - key to be compare\n   * @param {Uint8Array} key2 - key to be compare\n   * @returns {boolean} - returns true if both keys are equal\n   */\n  areKeysEqual(key1: Uint8Array, key2: Uint8Array): boolean {\n    return nacl.verify(key1, key2);\n  }\n\n  /**\n   * Returns a Uint8Array of the given hex string\n   *\n   * @param {string} str - the hex string to be converted\n   * @returns {string} - the Uint8Array value\n   */\n  toUint8Array(str: string): Uint8Array {\n    return Buffer.from(str, 'hex');\n  }\n\n  /**\n   * Determines whether a seed is valid.\n   *\n   * @param {string} seed - the seed to be validated\n   * @returns {boolean} - true if the seed is valid\n   */\n  isValidSeed(seed: string): boolean {\n    if (typeof seed !== 'string') return false;\n\n    if (seed.length !== ALGORAND_SEED_LENGTH) return false;\n\n    // Try to decode\n    let decoded;\n    try {\n      decoded = this.decodeSeed(seed);\n    } catch (e) {\n      return false;\n    }\n\n    // Compute checksum\n    const checksum = new Uint8Array(\n      sha512.sha512_256.array(decoded.seed).slice(SEED_BYTES_LENGTH - ALGORAND_CHECKSUM_BYTE_LENGTH, SEED_BYTES_LENGTH)\n    );\n\n    // Check if the checksum matches the one from the decoded seed\n    return _.isEqual(checksum, decoded.checksum);\n  }\n\n  /**\n   * Encode an algo seed\n   *\n   * @param  {Buffer} secretKey - the valid secretKey .\n   * @returns {string} - the seed to be validated.\n   */\n  encodeSeed(secretKey: Buffer): string {\n    // get seed\n    const seed = secretKey.slice(0, SEED_BYTES_LENGTH);\n    // compute checksum\n    const checksum = Buffer.from(\n      sha512.sha512_256.array(seed).slice(SEED_BYTES_LENGTH - ALGORAND_CHECKSUM_BYTE_LENGTH, SEED_BYTES_LENGTH)\n    );\n    const encodedSeed = base32.encode(concatArrays(seed, checksum));\n\n    return encodedSeed.toString().slice(0, ALGORAND_SEED_LENGTH); // removing the extra '===='\n  }\n\n  /**\n   * decodeSeed decodes an algo seed\n   *\n   * Decoding algo seed is same as decoding address.\n   * Latest version of algo sdk (1.9, at this writing) does not expose explicit method for decoding seed.\n   * Parameter is decoded and split into seed and checksum.\n   *\n   * @param {string} seed - hex or base64 encoded seed to be validated\n   * @returns {Seed} - validated object Seed\n   */\n  decodeSeed(seed: string): Seed {\n    // try to decode\n    const decoded = base32.decode.asBytes(seed);\n\n    // Sanity check\n    if (decoded.length !== ALGORAND_SEED_BYTE_LENGTH) throw new Error('seed seems to be malformed');\n    return {\n      seed: new Uint8Array(decoded.slice(0, ALGORAND_SEED_BYTE_LENGTH - ALGORAND_CHECKSUM_BYTE_LENGTH)),\n      checksum: new Uint8Array(decoded.slice(SEED_BYTES_LENGTH, ALGORAND_SEED_BYTE_LENGTH)),\n    };\n  }\n\n  /**\n   * Verifies if signature for message is valid.\n   *\n   * @param pub {Uint8Array} public key\n   * @param message {Uint8Array} signed message\n   * @param signature {Buffer} signature to verify\n   * @returns {Boolean} true if signature is valid.\n   */\n  verifySignature(message: Uint8Array, signature: Buffer, pub: Uint8Array): boolean {\n    return nacl.sign.detached.verify(message, signature, pub);\n  }\n\n  /**\n   * Transforms an Ed25519 public key into an algorand address.\n   *\n   * @param {Uint8Array} pk The Ed25519 public key.\n   * @see https://developer.algorand.org/docs/features/accounts/#transformation-public-key-to-algorand-address\n   *\n   * @returns {string} The algorand address.\n   */\n  publicKeyToAlgoAddress(pk: Uint8Array): string {\n    return new KeyPair({ pub: Buffer.from(pk).toString('hex') }).getAddress();\n  }\n\n  /**\n   Transforms a decrypted Ed25519 private key into an algorand address.\n   @param {string} privateKey The Ed25519 private key.\n   @returns {string} The algorand address.\n   **/\n  privateKeyToAlgoAddress(privateKey: string): string {\n    // Derive the account from the private key\n    const keypair = new KeyPair({ prv: privateKey });\n    return keypair.getAddress();\n  }\n\n  /**\n   * Checks if a unsigned algo transaction can be decoded.\n   *\n   * @param {Uint8Array} txn The encoded unsigned transaction.\n   * @returns {boolean} true if the transaction can be decoded, otherwise false\n   */\n  protected isDecodableUnsignedAlgoTxn(txn: Uint8Array): boolean {\n    try {\n      algosdk.decodeUnsignedTransaction(txn);\n      return true;\n    } catch {\n      return false;\n    }\n  }\n\n  /**\n   * Checks if a signed algo transaction can be decoded.\n   *\n   * @param {Uint8Array} txn The encoded signed transaction.\n   * @returns {boolean} true if the transaction can be decoded, otherwise false\n   */\n  protected isDecodableSignedTransaction(txn: Uint8Array): boolean {\n    try {\n      algosdk.decodeSignedTransaction(txn);\n      return true;\n    } catch {\n      return false;\n    }\n  }\n\n  /**\n   * Decodes a signed or unsigned algo transaction.\n   *\n   * @param {Uint8Array | string} txnBytes The encoded unsigned or signed txn.\n   * @returns {EncodedTx} The decoded transaction.\n   */\n  decodeAlgoTxn(txnBytes: Uint8Array | string): EncodedTx {\n    let buffer =\n      typeof txnBytes === 'string'\n        ? Buffer.from(txnBytes, allHexChars(txnBytes) ? 'hex' : 'base64')\n        : Buffer.from(txnBytes);\n\n    // In order to maintain backward compatibility with old keyreg transactions encoded with\n    // forked algosdk 1.2.0 (https://github.com/BitGo/algosdk-bitgo),\n    // the relevant information is extracted and parsed following the latest algosdk\n    // release standard.\n    // This way we can decode transactions successfully by still maintaining backward compatibility.\n    const decodedTx = encoding.decode(buffer);\n    if (\n      decodedTx.txn &&\n      decodedTx.txn.type === 'keyreg' &&\n      decodedTx.txn.votefst &&\n      decodedTx.txn.votelst &&\n      decodedTx.txn.votekd\n    ) {\n      decodedTx.txn.votekey = decodedTx.txn.votekey || decodedTx.msig.subsig[0].pk;\n      decodedTx.txn.selkey = decodedTx.txn.selkey || decodedTx.msig.subsig[0].pk;\n      buffer = decodedTx.msig || decodedTx.sig ? encoding.encode(decodedTx) : encoding.encode(decodedTx.txn);\n    }\n\n    try {\n      return this.tryToDecodeUnsignedTransaction(buffer);\n    } catch {\n      // Ignore error to try different format\n    }\n\n    try {\n      return this.tryToDecodeSignedTransaction(buffer);\n    } catch {\n      throw new InvalidTransactionError('Transaction cannot be decoded');\n    }\n  }\n\n  /**\n   * Try to decode a signed Algo transaction\n   * @param buffer the encoded transaction\n   * @returns { EncodedTx } the decoded signed transaction\n   * @throws error if it is not a valid encoded signed transaction\n   */\n  tryToDecodeSignedTransaction(buffer: Buffer): EncodedTx {\n    // TODO: Replace with\n    // return algosdk.Transaction.from_obj_for_encoding(algosdk.decodeSignedTransaction(buffer).txn);\n    // see: https://github.com/algorand/js-algorand-sdk/issues/364\n    // \"...some parts of the codebase treat the output of Transaction.from_obj_for_encoding as EncodedTransaction.\n    // They need to be fixed(or we at least need to make it so Transaction conforms to EncodedTransaction).\"\n    const tx = algosdk.decodeSignedTransaction(buffer);\n\n    const signers: string[] = [];\n    const signedBy: string[] = [];\n    if (tx.msig && tx.msig.subsig) {\n      for (const sig of tx.msig.subsig) {\n        const addr = algosdk.encodeAddress(sig.pk);\n        signers.push(addr);\n        if (sig.s) {\n          signedBy.push(addr);\n        }\n      }\n    }\n\n    return {\n      rawTransaction: new Uint8Array(buffer),\n      txn: tx.txn,\n      signed: true,\n      signers: signers,\n      signedBy: signedBy,\n    };\n  }\n\n  /**\n   * Try to decode an unsigned Algo transaction\n   * @param buffer the encoded transaction\n   * @returns {EncodedTx} the decoded unsigned transaction\n   * @throws error if it is not a valid encoded unsigned transaction\n   */\n  tryToDecodeUnsignedTransaction(buffer: Buffer): EncodedTx {\n    const txn = algosdk.decodeUnsignedTransaction(buffer);\n    return {\n      rawTransaction: new Uint8Array(buffer),\n      txn,\n      signed: false,\n    };\n  }\n\n  /*\n   * encodeObj takes a javascript object and returns its msgpack encoding\n   * Note that the encoding sorts the fields alphabetically\n   *\n   * @param {Record<string | number | symbol, any>} obj js obj\n   * @returns {Uint8Array} Uint8Array binary representation\n   */\n  encodeObj(obj: Record<string | number | symbol, any>): Uint8Array {\n    return algosdk.encodeObj(obj);\n  }\n\n  /**\n   * decodeObj takes a Uint8Array and returns its javascript obj\n   * @param o - Uint8Array to decode\n   * @returns object\n   */\n  decodeObj(o: ArrayLike<number>): unknown {\n    return algosdk.decodeObj(o);\n  }\n\n  /**\n   * secretKeyToMnemonic takes an Algorant secret key and returns the corresponding mnemonic\n   *\n   * @param sk - Algorant secret key\n   * @return Secret key is associated mnemonic\n   */\n  secretKeyToMnemonic(sk: Buffer): string {\n    const skValid = Buffer.from(sk.toString('hex'));\n    if (!this.isValidPrivateKey(skValid.toString('hex'))) {\n      throw new InvalidKey(`The secret key: ${sk.toString('hex')} is invalid`);\n    }\n    const skUnit8Array = Buffer.from(sk);\n    return algosdk.secretKeyToMnemonic(skUnit8Array);\n  }\n\n  /**\n   * seedFromMnemonic converts a mnemonic generated using this library into the source key used to create it\n   * It returns an error if the passed mnemonic has an incorrect checksum, if the number of words is unexpected, or if one\n   * of the passed words is not found in the words list\n   *\n   * @param mnemonic - 25 words mnemonic\n   * @returns 32 bytes long seed\n   */\n  seedFromMnemonic(mnemonic: string): Uint8Array {\n    return algosdk.mnemonicToMasterDerivationKey(mnemonic);\n  }\n\n  /**\n   * keyPairFromSeed generates an object with secretKey and publicKey using the algosdk\n   * @param seed 32 bytes long seed\n   * @returns KeyPair\n   */\n  keyPairFromSeed(seed: Uint8Array): KeyPair {\n    const mn = this.mnemonicFromSeed(seed);\n    const base64PrivateKey = algosdk.mnemonicToSecretKey(mn).sk;\n    return this.createKeyPair(base64PrivateKey);\n  }\n\n  /**\n   * Generate a new `KeyPair` object from the given private key.\n   *\n   * @param base64PrivateKey 64 bytes long privateKey\n   * @returns KeyPair\n   */\n  protected createKeyPair(base64PrivateKey: Uint8Array): KeyPair {\n    const sk = base64PrivateKey.slice(0, 32);\n    return new KeyPair({ prv: Buffer.from(sk).toString('hex') });\n  }\n\n  /**\n   * decodePrivateKey generates a seed with a mnemonic and using algosdk.\n   *\n   * @param seed 32 bytes long seed\n   * @returns mnemonic - 25 words mnemonic - 25 words mnemonic\n   */\n  protected mnemonicFromSeed(seed: Uint8Array): string {\n    return algosdk.masterDerivationKeyToMnemonic(seed);\n  }\n\n  /**\n   * Validates the key with the stellar-sdk\n   *\n   * @param publicKey\n   * @returns boolean\n   */\n  protected isValidEd25519PublicKeyStellar(publicKey: string): boolean {\n    return stellar.StrKey.isValidEd25519PublicKey(publicKey);\n  }\n\n  /**\n   * Decodes the key with the stellar-sdk\n   *\n   * @param publicKey\n   * @returns Buffer\n   */\n  protected decodeEd25519PublicKeyStellar(publicKey: string): Buffer {\n    return stellar.StrKey.decodeEd25519PublicKey(publicKey);\n  }\n\n  /**\n   * Convert a stellar seed to algorand encoding\n   *\n   * @param seed\n   * @returns string the encoded seed\n   */\n  convertFromStellarSeed(seed: string): string {\n    return SeedEncoding.encode(stellar.StrKey.decodeEd25519SecretSeed(seed));\n  }\n\n  /**\n   * Returns an address encoded with algosdk\n   *\n   * @param addr\n   * @returns string\n   */\n  encodeAddress(addr: Uint8Array): string {\n    return algosdk.encodeAddress(addr);\n  }\n\n  /**\n   * Return an address decoded with algosdk\n   *\n   * @param addr\n   * @returns Address\n   */\n  decodeAddress(addr: string): Address {\n    return algosdk.decodeAddress(addr);\n  }\n\n  /**\n   * Converts an address into an ALGO one\n   * If the given data is a Stellar address or public key, it is converted to ALGO address.\n   *\n   * @param addressOrPubKey an ALGO address, or an Stellar address or public key\n   * @returns address algo address string\n   */\n  stellarAddressToAlgoAddress(addressOrPubKey: string): string {\n    // we have an Algorand address\n    if (this.isValidAddress(addressOrPubKey)) {\n      return addressOrPubKey;\n    }\n    // we have a stellar key\n    if (this.isValidEd25519PublicKeyStellar(addressOrPubKey)) {\n      const stellarPub = this.decodeEd25519PublicKeyStellar(addressOrPubKey);\n      const algoAddress = this.encodeAddress(stellarPub);\n      if (this.isValidAddress(algoAddress)) {\n        return algoAddress;\n      }\n      throw new Error('Cannot convert Stellar address to an Algorand address via pubkey.');\n    }\n    throw new Error('Neither an Algorand address nor a stellar pubkey.');\n  }\n\n  /**\n   * multisigAddress takes multisig metadata (preimage) and returns the corresponding human readable Algorand address.\n   *\n   * @param {number} version mutlisig version\n   * @param {number} threshold multisig threshold\n   * @param {string[]} addrs list of Algorand addresses\n   * @returns {string} human readable Algorand address.\n   */\n  multisigAddress(version: number, threshold: number, addrs: string[]): string {\n    return algosdk.multisigAddress({\n      version,\n      threshold,\n      addrs,\n    });\n  }\n\n  /**\n   * generateAccount generates un account with a secretKey and an address\n   *\n   * Function has not params\n   * @returns Account\n   */\n  generateAccount(): algosdk.Account {\n    return algosdk.generateAccount();\n  }\n\n  generateAccountFromSeed(seed: Uint8Array): algosdk.Account {\n    const keys = nacl.sign.keyPair.fromSeed(seed);\n    return {\n      addr: algosdk.encodeAddress(keys.publicKey),\n      sk: keys.secretKey,\n    };\n  }\n\n  /**\n   * Generates Tx ID from an encoded multisig transaction\n   *\n   * This is done because of a change made on version 1.10.1 on algosdk so method txID() only supports SignedTransaction type.\n   * (https://github.com/algorand/js-algorand-sdk/blob/develop/CHANGELOG.md#1101)\n   *\n   * @param {string} txBase64 - encoded base64 multisig transaction\n   * @returns {string} - transaction ID\n   */\n  getMultisigTxID(txBase64: string): string {\n    const txBytes = Buffer.from(txBase64, 'base64');\n    const decodeSignTx = algosdk.decodeSignedTransaction(txBytes);\n    const wellFormedDecodedSignTx = decodeSignTx.txn.get_obj_for_encoding();\n    const txForEncoding = { msig: decodeSignTx.msig, txn: wellFormedDecodedSignTx };\n    const en_msg = encoding.encode(txForEncoding);\n    const tag = Buffer.from([84, 88]);\n    const gh = Buffer.from(concatArrays(tag, en_msg));\n    const hash = Buffer.from(algoNacl.genericHash(gh));\n    return base32.encode(hash).slice(0, ALGORAND_TRANSACTION_LENGTH);\n  }\n\n  /**\n   * Determines if a given transaction data is to enable or disable a token\n   * @param amount the amount in transaction\n   * @param from the originated address\n   * @param to the target address\n   * @param closeRemainderTo (optional) address to send remaining units in originated address\n   * @returns 'enableToken' or 'disableToken'\n   */\n  getTokenTxType(amount: string, from: string, to: string, closeRemainderTo?: string): string {\n    let type = 'transferToken';\n    if (amount === '0' && from === to) {\n      type = !closeRemainderTo ? 'enableToken' : 'disableToken';\n    }\n    return type;\n  }\n\n  /**\n   * Validate if the key is a valid base64 string\n   * @param key the key to validate\n   */\n  validateBase64(key: string): void {\n    if (!key || typeof key !== 'string') {\n      throw new Error('Invalid base64 string');\n    }\n    const base64RegExp =\n      /^(?:[a-zA-Z0-9+\\/]{4})*(?:|(?:[a-zA-Z0-9+\\/]{3}=)|(?:[a-zA-Z0-9+\\/]{2}==)|(?:[a-zA-Z0-9+\\/]{1}===))$/;\n    if (!base64RegExp.test(key)) {\n      throw new Error('Invalid base64 string');\n    }\n  }\n}\n\nconst utils = new Utils();\n\nexport default utils;\n"]}
@@ -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.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
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,13 +15,23 @@ 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 (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
- };
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.SeedValidator = void 0;
23
37
  const stellar = __importStar(require("stellar-sdk"));
@@ -86,4 +100,4 @@ class SeedValidator {
86
100
  }
87
101
  }
88
102
  exports.SeedValidator = SeedValidator;
89
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VlZFZhbGlkYXRvci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9zZWVkVmFsaWRhdG9yLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQSxxREFBdUM7QUFDdkMsMENBQTRCO0FBQzVCLGlEQUFpRDtBQUNqRCwrQkFBa0M7QUFDbEMsMERBQXFEO0FBQ3JEOztHQUVHO0FBQ0gsTUFBYSxhQUFhO0lBQ3hCOzs7OztPQUtHO0lBQ0gsTUFBTSxDQUFDLHFCQUFxQixDQUFDLElBQVk7UUFDdkMsSUFBSSxJQUFJLEdBQTJCLFNBQVMsQ0FBQztRQUU3Qyw0RkFBNEY7UUFDNUYsSUFBSSxDQUFDLGFBQWEsQ0FBQyx1QkFBdUIsQ0FBQyxJQUFJLENBQUMsRUFBRTtZQUNoRCw2RkFBNkY7WUFDN0YsNkVBQTZFO1lBQzdFLDhCQUE4QjtZQUU5QixJQUFJLGVBQVMsQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDO2dCQUFFLElBQUksR0FBRyxvQkFBVSxDQUFDLElBQUksQ0FBQztZQUN4RCxJQUFJLE9BQU8sQ0FBQyxNQUFNLENBQUMsd0JBQXdCLENBQUMsSUFBSSxDQUFDO2dCQUFFLElBQUksR0FBRyxvQkFBVSxDQUFDLEdBQUcsQ0FBQztZQUN6RSxJQUFJLGFBQWEsQ0FBQyxxQkFBcUIsQ0FBQyxJQUFJLENBQUM7Z0JBQUUsSUFBSSxHQUFHLG9CQUFVLENBQUMsSUFBSSxDQUFDO1NBQ3ZFO1FBRUQsT0FBTyxJQUFJLENBQUM7SUFDZCxDQUFDO0lBRUQ7Ozs7T0FJRztJQUNILE1BQU0sQ0FBQyx5QkFBeUIsQ0FBQyxJQUFZLEVBQUUsVUFBc0I7UUFDbkUsTUFBTSxXQUFXLEdBQUcsYUFBYSxDQUFDLHFCQUFxQixDQUFDLElBQUksQ0FBQyxDQUFDO1FBQzlELE9BQU8sVUFBVSxLQUFLLFdBQVcsQ0FBQztJQUNwQyxDQUFDO0lBRUQ7Ozs7T0FJRztJQUNILE1BQU0sQ0FBQyx1QkFBdUIsQ0FBQyxJQUFZO1FBQ3pDLE1BQU0sVUFBVSxHQUFHLGVBQVMsQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDLENBQUM7UUFDL0MsTUFBTSxhQUFhLEdBQUcsT0FBTyxDQUFDLE1BQU0sQ0FBQyx3QkFBd0IsQ0FBQyxJQUFJLENBQUMsQ0FBQztRQUNwRSxNQUFNLFVBQVUsR0FBRyxhQUFhLENBQUMscUJBQXFCLENBQUMsSUFBSSxDQUFDLENBQUM7UUFFN0QsT0FBTyxDQUFDLENBQUMsR0FBRyxDQUFDLENBQUMsVUFBVSxFQUFFLGFBQWEsRUFBRSxVQUFVLENBQUMsQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUM5RCxDQUFDO0lBRUQ7OztPQUdHO0lBQ0gsTUFBTSxDQUFDLHFCQUFxQixDQUFDLElBQVk7UUFDdkMsSUFBSTtZQUNGLHlCQUFVLENBQUMsVUFBVSxDQUFDLElBQUksQ0FBQyxDQUFDO1NBQzdCO1FBQUMsTUFBTTtZQUNOLE9BQU8sS0FBSyxDQUFDO1NBQ2Q7UUFDRCxPQUFPLElBQUksQ0FBQztJQUNkLENBQUM7Q0FDRjtBQTNERCxzQ0EyREMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgKiBhcyBzdGVsbGFyIGZyb20gJ3N0ZWxsYXItc2RrJztcbmltcG9ydCAqIGFzIF8gZnJvbSAnbG9kYXNoJztcbmltcG9ydCB7IENvaW5GYW1pbHkgfSBmcm9tICdAYml0Z28tYmV0YS9zdGF0aWNzJztcbmltcG9ydCB7IGFsZ29VdGlscyB9IGZyb20gJy4vbGliJztcbmltcG9ydCB7IFByaXZhdGVLZXkgfSBmcm9tICdAaGFzaGdyYXBoL2NyeXB0b2dyYXBoeSc7XG4vKipcbiAqIFRoaXMgY2xhc3NlcyBpbnRlbnRpb24gaXMgdG8gZ3Vlc3MvdmVyaWZ5IHdoYXQgc2VlZHMgY29tZSBmcm9tIHdoZXJlLlxuICovXG5leHBvcnQgY2xhc3MgU2VlZFZhbGlkYXRvciB7XG4gIC8qKlxuICAgKiBUcnkgdG8gZ3Vlc3Mgd2hhdCBraW5kIG9mIHNlZWQgdGhpcyBjb3VsZCBiZVxuICAgKiBAcGFyYW0gc2VlZFxuICAgKiBAcmV0dXJucyB7c3RyaW5nfSAtIHJldHVybnMgdW5kZWZpbmVkIGlmIHRoZSBjb2luIHR5cGUgaXMgdW5kZXRlY3RhYmxlLiByZXR1cm5zXG4gICAqIHRoZSBjb2luIGZhbWlseSBvdGhlcndpc2UuXG4gICAqL1xuICBzdGF0aWMgZ2V0Q29pbkZhbWlseUZyb21TZWVkKHNlZWQ6IHN0cmluZyk6IENvaW5GYW1pbHkgfCB1bmRlZmluZWQge1xuICAgIGxldCBjb2luOiBDb2luRmFtaWx5IHwgdW5kZWZpbmVkID0gdW5kZWZpbmVkO1xuXG4gICAgLy8gaWYgdGhpcyBjYW4gYmUgaW1wbGVtZW50ZWQgaW4gbW9yZSB0aGFuIG9uZSBjb21wZXRpbmcgc2VlZCBmb3JtYXQsIHRoYXQgY291bGQgYmUgYW4gaXNzdWVcbiAgICBpZiAoIVNlZWRWYWxpZGF0b3IuaGFzQ29tcGV0aW5nU2VlZEZvcm1hdHMoc2VlZCkpIHtcbiAgICAgIC8vIG9yZGVyaW5nIGdlbmVyYWxseSBtYXR0ZXJzIGhlcmUgLSBoYmFyIGlzIHRoZSBsZWFzdCBwZXJtaXNzaXZlIGZvciBzZWVkIGNoZWNraW5nLCBhbGdvIGFuZFxuICAgICAgLy8gc3RlbGxhciBoYXZlIGNoZWNrc3Vtcy4gY29pbiBpcyBndWFyYW50ZWVkIHRvIGJlIG11dHVhbGx5IGV4Y2x1c2l2ZSBieSB0aGVcbiAgICAgIC8vIGNvbXBldGluZyBzZWVkIGZvcm1hdCBjaGVja1xuXG4gICAgICBpZiAoYWxnb1V0aWxzLmlzVmFsaWRTZWVkKHNlZWQpKSBjb2luID0gQ29pbkZhbWlseS5BTEdPO1xuICAgICAgaWYgKHN0ZWxsYXIuU3RyS2V5LmlzVmFsaWRFZDI1NTE5U2VjcmV0U2VlZChzZWVkKSkgY29pbiA9IENvaW5GYW1pbHkuWExNO1xuICAgICAgaWYgKFNlZWRWYWxpZGF0b3IuaXNWYWxpZEhiYXJTZWVkRm9ybWF0KHNlZWQpKSBjb2luID0gQ29pbkZhbWlseS5IQkFSO1xuICAgIH1cblxuICAgIHJldHVybiBjb2luO1xuICB9XG5cbiAgLyoqXG4gICAqIENoZWNrcyB3aGV0aGVyIHRoaXMgaXMgYSB2YWxpZCBzZWVkIGZvciB0aGlzIGNvaW4gZmFtaWx5IHR5cGUuXG4gICAqIEBwYXJhbSBzZWVkIC0gc2VlZFxuICAgKiBAcGFyYW0gY29pbkZhbWlseSAtIHRoZSBjb2luRmFtaWx5IG9mIHRoZSBjb2luIHdlJ3JlIHdvcmtpbmcgd2l0aFxuICAgKi9cbiAgc3RhdGljIGlzVmFsaWRFZDI1NTE5U2VlZEZvckNvaW4oc2VlZDogc3RyaW5nLCBjb2luRmFtaWx5OiBDb2luRmFtaWx5KTogYm9vbGVhbiB7XG4gICAgY29uc3QgZ3Vlc3NlZENvaW4gPSBTZWVkVmFsaWRhdG9yLmdldENvaW5GYW1pbHlGcm9tU2VlZChzZWVkKTtcbiAgICByZXR1cm4gY29pbkZhbWlseSA9PT0gZ3Vlc3NlZENvaW47XG4gIH1cblxuICAvKipcbiAgICogV2UgbmVlZCB0byBlbnN1cmUgdGhlcmUgaXMgbm8gb3ZlcmxhcCBmb3IgYW55IHR3byBzZWVkcyB3ZSBwdXQgaW50byB0aGlzIGZ1bmN0aW9uLiBUaGlzIGZ1bmN0aW9uc1xuICAgKiBpbnRlbnRpb24gaXMgZm9yIGdhdGluZyB3aGV0aGVyIHRoaXMgc2VlZCBjb3VsZCBwb3NzaWJseSBtYXRjaCB0d28gZm9ybWF0cyBvciBpcyBpbnZhbGlkIGl0c2VsZi5cbiAgICogQHBhcmFtIHNlZWRcbiAgICovXG4gIHN0YXRpYyBoYXNDb21wZXRpbmdTZWVkRm9ybWF0cyhzZWVkOiBzdHJpbmcpOiBib29sZWFuIHtcbiAgICBjb25zdCBpc0FsZ29TZWVkID0gYWxnb1V0aWxzLmlzVmFsaWRTZWVkKHNlZWQpO1xuICAgIGNvbnN0IGlzU3RlbGxhclNlZWQgPSBzdGVsbGFyLlN0cktleS5pc1ZhbGlkRWQyNTUxOVNlY3JldFNlZWQoc2VlZCk7XG4gICAgY29uc3QgaXNIYmFyU2VlZCA9IFNlZWRWYWxpZGF0b3IuaXNWYWxpZEhiYXJTZWVkRm9ybWF0KHNlZWQpO1xuXG4gICAgcmV0dXJuIF8uc3VtKFtpc0FsZ29TZWVkLCBpc1N0ZWxsYXJTZWVkLCBpc0hiYXJTZWVkXSkgIT09IDE7XG4gIH1cblxuICAvKipcbiAgICogQ2hlY2tzIGlmIHRoaXMgaXMgYSB2YWxpZCBIYmFyIHBydi4gVGhlc2UgY2FuIGJlIGVuY29kZWQgZGlmZmVyZW50bHkuXG4gICAqIEBwYXJhbSBzZWVkXG4gICAqL1xuICBzdGF0aWMgaXNWYWxpZEhiYXJTZWVkRm9ybWF0KHNlZWQ6IHN0cmluZyk6IGJvb2xlYW4ge1xuICAgIHRyeSB7XG4gICAgICBQcml2YXRlS2V5LmZyb21TdHJpbmcoc2VlZCk7XG4gICAgfSBjYXRjaCB7XG4gICAgICByZXR1cm4gZmFsc2U7XG4gICAgfVxuICAgIHJldHVybiB0cnVlO1xuICB9XG59XG4iXX0=
103
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VlZFZhbGlkYXRvci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9zZWVkVmFsaWRhdG9yLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQUFBLHFEQUF1QztBQUN2QywwQ0FBNEI7QUFDNUIsaURBQWlEO0FBQ2pELCtCQUFrQztBQUNsQywwREFBcUQ7QUFDckQ7O0dBRUc7QUFDSCxNQUFhLGFBQWE7SUFDeEI7Ozs7O09BS0c7SUFDSCxNQUFNLENBQUMscUJBQXFCLENBQUMsSUFBWTtRQUN2QyxJQUFJLElBQUksR0FBMkIsU0FBUyxDQUFDO1FBRTdDLDRGQUE0RjtRQUM1RixJQUFJLENBQUMsYUFBYSxDQUFDLHVCQUF1QixDQUFDLElBQUksQ0FBQyxFQUFFLENBQUM7WUFDakQsNkZBQTZGO1lBQzdGLDZFQUE2RTtZQUM3RSw4QkFBOEI7WUFFOUIsSUFBSSxlQUFTLENBQUMsV0FBVyxDQUFDLElBQUksQ0FBQztnQkFBRSxJQUFJLEdBQUcsb0JBQVUsQ0FBQyxJQUFJLENBQUM7WUFDeEQsSUFBSSxPQUFPLENBQUMsTUFBTSxDQUFDLHdCQUF3QixDQUFDLElBQUksQ0FBQztnQkFBRSxJQUFJLEdBQUcsb0JBQVUsQ0FBQyxHQUFHLENBQUM7WUFDekUsSUFBSSxhQUFhLENBQUMscUJBQXFCLENBQUMsSUFBSSxDQUFDO2dCQUFFLElBQUksR0FBRyxvQkFBVSxDQUFDLElBQUksQ0FBQztRQUN4RSxDQUFDO1FBRUQsT0FBTyxJQUFJLENBQUM7SUFDZCxDQUFDO0lBRUQ7Ozs7T0FJRztJQUNILE1BQU0sQ0FBQyx5QkFBeUIsQ0FBQyxJQUFZLEVBQUUsVUFBc0I7UUFDbkUsTUFBTSxXQUFXLEdBQUcsYUFBYSxDQUFDLHFCQUFxQixDQUFDLElBQUksQ0FBQyxDQUFDO1FBQzlELE9BQU8sVUFBVSxLQUFLLFdBQVcsQ0FBQztJQUNwQyxDQUFDO0lBRUQ7Ozs7T0FJRztJQUNILE1BQU0sQ0FBQyx1QkFBdUIsQ0FBQyxJQUFZO1FBQ3pDLE1BQU0sVUFBVSxHQUFHLGVBQVMsQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDLENBQUM7UUFDL0MsTUFBTSxhQUFhLEdBQUcsT0FBTyxDQUFDLE1BQU0sQ0FBQyx3QkFBd0IsQ0FBQyxJQUFJLENBQUMsQ0FBQztRQUNwRSxNQUFNLFVBQVUsR0FBRyxhQUFhLENBQUMscUJBQXFCLENBQUMsSUFBSSxDQUFDLENBQUM7UUFFN0QsT0FBTyxDQUFDLENBQUMsR0FBRyxDQUFDLENBQUMsVUFBVSxFQUFFLGFBQWEsRUFBRSxVQUFVLENBQUMsQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUM5RCxDQUFDO0lBRUQ7OztPQUdHO0lBQ0gsTUFBTSxDQUFDLHFCQUFxQixDQUFDLElBQVk7UUFDdkMsSUFBSSxDQUFDO1lBQ0gseUJBQVUsQ0FBQyxVQUFVLENBQUMsSUFBSSxDQUFDLENBQUM7UUFDOUIsQ0FBQztRQUFDLE1BQU0sQ0FBQztZQUNQLE9BQU8sS0FBSyxDQUFDO1FBQ2YsQ0FBQztRQUNELE9BQU8sSUFBSSxDQUFDO0lBQ2QsQ0FBQztDQUNGO0FBM0RELHNDQTJEQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCAqIGFzIHN0ZWxsYXIgZnJvbSAnc3RlbGxhci1zZGsnO1xuaW1wb3J0ICogYXMgXyBmcm9tICdsb2Rhc2gnO1xuaW1wb3J0IHsgQ29pbkZhbWlseSB9IGZyb20gJ0BiaXRnby1iZXRhL3N0YXRpY3MnO1xuaW1wb3J0IHsgYWxnb1V0aWxzIH0gZnJvbSAnLi9saWInO1xuaW1wb3J0IHsgUHJpdmF0ZUtleSB9IGZyb20gJ0BoYXNoZ3JhcGgvY3J5cHRvZ3JhcGh5Jztcbi8qKlxuICogVGhpcyBjbGFzc2VzIGludGVudGlvbiBpcyB0byBndWVzcy92ZXJpZnkgd2hhdCBzZWVkcyBjb21lIGZyb20gd2hlcmUuXG4gKi9cbmV4cG9ydCBjbGFzcyBTZWVkVmFsaWRhdG9yIHtcbiAgLyoqXG4gICAqIFRyeSB0byBndWVzcyB3aGF0IGtpbmQgb2Ygc2VlZCB0aGlzIGNvdWxkIGJlXG4gICAqIEBwYXJhbSBzZWVkXG4gICAqIEByZXR1cm5zIHtzdHJpbmd9IC0gcmV0dXJucyB1bmRlZmluZWQgaWYgdGhlIGNvaW4gdHlwZSBpcyB1bmRldGVjdGFibGUuIHJldHVybnNcbiAgICogdGhlIGNvaW4gZmFtaWx5IG90aGVyd2lzZS5cbiAgICovXG4gIHN0YXRpYyBnZXRDb2luRmFtaWx5RnJvbVNlZWQoc2VlZDogc3RyaW5nKTogQ29pbkZhbWlseSB8IHVuZGVmaW5lZCB7XG4gICAgbGV0IGNvaW46IENvaW5GYW1pbHkgfCB1bmRlZmluZWQgPSB1bmRlZmluZWQ7XG5cbiAgICAvLyBpZiB0aGlzIGNhbiBiZSBpbXBsZW1lbnRlZCBpbiBtb3JlIHRoYW4gb25lIGNvbXBldGluZyBzZWVkIGZvcm1hdCwgdGhhdCBjb3VsZCBiZSBhbiBpc3N1ZVxuICAgIGlmICghU2VlZFZhbGlkYXRvci5oYXNDb21wZXRpbmdTZWVkRm9ybWF0cyhzZWVkKSkge1xuICAgICAgLy8gb3JkZXJpbmcgZ2VuZXJhbGx5IG1hdHRlcnMgaGVyZSAtIGhiYXIgaXMgdGhlIGxlYXN0IHBlcm1pc3NpdmUgZm9yIHNlZWQgY2hlY2tpbmcsIGFsZ28gYW5kXG4gICAgICAvLyBzdGVsbGFyIGhhdmUgY2hlY2tzdW1zLiBjb2luIGlzIGd1YXJhbnRlZWQgdG8gYmUgbXV0dWFsbHkgZXhjbHVzaXZlIGJ5IHRoZVxuICAgICAgLy8gY29tcGV0aW5nIHNlZWQgZm9ybWF0IGNoZWNrXG5cbiAgICAgIGlmIChhbGdvVXRpbHMuaXNWYWxpZFNlZWQoc2VlZCkpIGNvaW4gPSBDb2luRmFtaWx5LkFMR087XG4gICAgICBpZiAoc3RlbGxhci5TdHJLZXkuaXNWYWxpZEVkMjU1MTlTZWNyZXRTZWVkKHNlZWQpKSBjb2luID0gQ29pbkZhbWlseS5YTE07XG4gICAgICBpZiAoU2VlZFZhbGlkYXRvci5pc1ZhbGlkSGJhclNlZWRGb3JtYXQoc2VlZCkpIGNvaW4gPSBDb2luRmFtaWx5LkhCQVI7XG4gICAgfVxuXG4gICAgcmV0dXJuIGNvaW47XG4gIH1cblxuICAvKipcbiAgICogQ2hlY2tzIHdoZXRoZXIgdGhpcyBpcyBhIHZhbGlkIHNlZWQgZm9yIHRoaXMgY29pbiBmYW1pbHkgdHlwZS5cbiAgICogQHBhcmFtIHNlZWQgLSBzZWVkXG4gICAqIEBwYXJhbSBjb2luRmFtaWx5IC0gdGhlIGNvaW5GYW1pbHkgb2YgdGhlIGNvaW4gd2UncmUgd29ya2luZyB3aXRoXG4gICAqL1xuICBzdGF0aWMgaXNWYWxpZEVkMjU1MTlTZWVkRm9yQ29pbihzZWVkOiBzdHJpbmcsIGNvaW5GYW1pbHk6IENvaW5GYW1pbHkpOiBib29sZWFuIHtcbiAgICBjb25zdCBndWVzc2VkQ29pbiA9IFNlZWRWYWxpZGF0b3IuZ2V0Q29pbkZhbWlseUZyb21TZWVkKHNlZWQpO1xuICAgIHJldHVybiBjb2luRmFtaWx5ID09PSBndWVzc2VkQ29pbjtcbiAgfVxuXG4gIC8qKlxuICAgKiBXZSBuZWVkIHRvIGVuc3VyZSB0aGVyZSBpcyBubyBvdmVybGFwIGZvciBhbnkgdHdvIHNlZWRzIHdlIHB1dCBpbnRvIHRoaXMgZnVuY3Rpb24uIFRoaXMgZnVuY3Rpb25zXG4gICAqIGludGVudGlvbiBpcyBmb3IgZ2F0aW5nIHdoZXRoZXIgdGhpcyBzZWVkIGNvdWxkIHBvc3NpYmx5IG1hdGNoIHR3byBmb3JtYXRzIG9yIGlzIGludmFsaWQgaXRzZWxmLlxuICAgKiBAcGFyYW0gc2VlZFxuICAgKi9cbiAgc3RhdGljIGhhc0NvbXBldGluZ1NlZWRGb3JtYXRzKHNlZWQ6IHN0cmluZyk6IGJvb2xlYW4ge1xuICAgIGNvbnN0IGlzQWxnb1NlZWQgPSBhbGdvVXRpbHMuaXNWYWxpZFNlZWQoc2VlZCk7XG4gICAgY29uc3QgaXNTdGVsbGFyU2VlZCA9IHN0ZWxsYXIuU3RyS2V5LmlzVmFsaWRFZDI1NTE5U2VjcmV0U2VlZChzZWVkKTtcbiAgICBjb25zdCBpc0hiYXJTZWVkID0gU2VlZFZhbGlkYXRvci5pc1ZhbGlkSGJhclNlZWRGb3JtYXQoc2VlZCk7XG5cbiAgICByZXR1cm4gXy5zdW0oW2lzQWxnb1NlZWQsIGlzU3RlbGxhclNlZWQsIGlzSGJhclNlZWRdKSAhPT0gMTtcbiAgfVxuXG4gIC8qKlxuICAgKiBDaGVja3MgaWYgdGhpcyBpcyBhIHZhbGlkIEhiYXIgcHJ2LiBUaGVzZSBjYW4gYmUgZW5jb2RlZCBkaWZmZXJlbnRseS5cbiAgICogQHBhcmFtIHNlZWRcbiAgICovXG4gIHN0YXRpYyBpc1ZhbGlkSGJhclNlZWRGb3JtYXQoc2VlZDogc3RyaW5nKTogYm9vbGVhbiB7XG4gICAgdHJ5IHtcbiAgICAgIFByaXZhdGVLZXkuZnJvbVN0cmluZyhzZWVkKTtcbiAgICB9IGNhdGNoIHtcbiAgICAgIHJldHVybiBmYWxzZTtcbiAgICB9XG4gICAgcmV0dXJuIHRydWU7XG4gIH1cbn1cbiJdfQ==
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@bitgo-beta/sdk-coin-algo",
3
- "version": "1.3.19-beta.99",
3
+ "version": "1.3.19-beta.990",
4
4
  "description": "BitGo SDK coin library for Algorand",
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": ">=16 <19"
21
+ "node": ">=18 <23"
22
22
  },
23
23
  "repository": {
24
24
  "type": "git",
@@ -40,12 +40,11 @@
40
40
  ]
41
41
  },
42
42
  "dependencies": {
43
- "@bitgo-beta/sdk-core": "8.2.1-beta.99",
44
- "@bitgo-beta/statics": "15.1.1-beta.101",
45
- "@bitgo-beta/utxo-lib": "8.0.3-beta.99",
43
+ "@bitgo-beta/sdk-core": "8.2.1-beta.992",
44
+ "@bitgo-beta/statics": "15.1.1-beta.995",
46
45
  "@hashgraph/cryptography": "1.1.2",
47
46
  "@stablelib/hex": "^1.0.0",
48
- "algosdk": "1.14.0",
47
+ "algosdk": "1.23.1",
49
48
  "bignumber.js": "^9.0.0",
50
49
  "hi-base32": "^0.5.1",
51
50
  "joi": "^17.4.0",
@@ -55,10 +54,10 @@
55
54
  "tweetnacl": "^1.0.3"
56
55
  },
57
56
  "devDependencies": {
58
- "@bitgo-beta/sdk-api": "1.10.1-beta.99",
59
- "@bitgo-beta/sdk-test": "^1.2.32",
57
+ "@bitgo-beta/sdk-api": "1.10.1-beta.991",
58
+ "@bitgo-beta/sdk-test": "^8.0.94",
60
59
  "should": "^13.1.3",
61
60
  "sinon": "^7.5.0"
62
61
  },
63
- "gitHead": "38f96b7f29a3d50a63bb6e884549cbf4e1a84cb1"
62
+ "gitHead": "8abf9149c6a0c5dd7a7b400f4854d8c8030129b6"
64
63
  }