@bitgo-beta/sdk-coin-xrp 1.3.3-alpha.23 → 1.3.3-alpha.230

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 (60) hide show
  1. package/CHANGELOG.md +445 -0
  2. package/dist/src/index.d.ts +4 -2
  3. package/dist/src/index.d.ts.map +1 -1
  4. package/dist/src/index.js +10 -4
  5. package/dist/src/lib/accountSetBuilder.d.ts +18 -0
  6. package/dist/src/lib/accountSetBuilder.d.ts.map +1 -0
  7. package/dist/src/lib/accountSetBuilder.js +63 -0
  8. package/dist/src/lib/constants.d.ts +8 -0
  9. package/dist/src/lib/constants.d.ts.map +1 -0
  10. package/dist/src/lib/constants.js +30 -0
  11. package/dist/src/lib/iface.d.ts +108 -0
  12. package/dist/src/lib/iface.d.ts.map +1 -0
  13. package/dist/src/lib/iface.js +11 -0
  14. package/dist/src/lib/index.d.ts +14 -0
  15. package/dist/src/lib/index.d.ts.map +1 -0
  16. package/dist/src/lib/index.js +43 -0
  17. package/dist/src/lib/keyPair.d.ts +35 -0
  18. package/dist/src/lib/keyPair.d.ts.map +1 -0
  19. package/dist/src/lib/keyPair.js +109 -0
  20. package/dist/src/lib/tokenTransferBuilder.d.ts +29 -0
  21. package/dist/src/lib/tokenTransferBuilder.d.ts.map +1 -0
  22. package/dist/src/lib/tokenTransferBuilder.js +91 -0
  23. package/dist/src/lib/transaction.d.ts +62 -0
  24. package/dist/src/lib/transaction.d.ts.map +1 -0
  25. package/dist/src/lib/transaction.js +371 -0
  26. package/dist/src/lib/transactionBuilder.d.ts +72 -0
  27. package/dist/src/lib/transactionBuilder.d.ts.map +1 -0
  28. package/dist/src/lib/transactionBuilder.js +253 -0
  29. package/dist/src/lib/transactionBuilderFactory.d.ts +39 -0
  30. package/dist/src/lib/transactionBuilderFactory.d.ts.map +1 -0
  31. package/dist/src/lib/transactionBuilderFactory.js +97 -0
  32. package/dist/src/lib/transferBuilder.d.ts +28 -0
  33. package/dist/src/lib/transferBuilder.d.ts.map +1 -0
  34. package/dist/src/lib/transferBuilder.js +82 -0
  35. package/dist/src/lib/trustsetBuilder.d.ts +21 -0
  36. package/dist/src/lib/trustsetBuilder.d.ts.map +1 -0
  37. package/dist/src/lib/trustsetBuilder.js +72 -0
  38. package/dist/src/lib/utils.d.ts +69 -0
  39. package/dist/src/lib/utils.d.ts.map +1 -0
  40. package/dist/src/lib/utils.js +268 -0
  41. package/dist/src/lib/walletInitializationBuilder.d.ts +19 -0
  42. package/dist/src/lib/walletInitializationBuilder.d.ts.map +1 -0
  43. package/dist/src/lib/walletInitializationBuilder.js +76 -0
  44. package/dist/src/register.d.ts.map +1 -1
  45. package/dist/src/register.js +5 -1
  46. package/dist/src/ripple.d.ts +112 -2
  47. package/dist/src/ripple.d.ts.map +1 -1
  48. package/dist/src/ripple.js +17 -14
  49. package/dist/src/txrp.d.ts +3 -2
  50. package/dist/src/txrp.d.ts.map +1 -1
  51. package/dist/src/txrp.js +5 -5
  52. package/dist/src/xrp.d.ts +14 -60
  53. package/dist/src/xrp.d.ts.map +1 -1
  54. package/dist/src/xrp.js +260 -144
  55. package/dist/src/xrpToken.d.ts +21 -0
  56. package/dist/src/xrpToken.d.ts.map +1 -0
  57. package/dist/src/xrpToken.js +58 -0
  58. package/dist/tsconfig.tsbuildinfo +1 -8595
  59. package/package.json +11 -11
  60. package/.mocharc.yml +0 -8
@@ -0,0 +1,72 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.TrustSetBuilder = void 0;
7
+ const sdk_core_1 = require("@bitgo-beta/sdk-core");
8
+ const bignumber_js_1 = __importDefault(require("bignumber.js"));
9
+ const iface_1 = require("./iface");
10
+ const transactionBuilder_1 = require("./transactionBuilder");
11
+ const utils_1 = __importDefault(require("./utils"));
12
+ class TrustSetBuilder extends transactionBuilder_1.TransactionBuilder {
13
+ constructor(_coinConfig) {
14
+ super(_coinConfig);
15
+ }
16
+ get transactionType() {
17
+ return sdk_core_1.TransactionType.TrustLine;
18
+ }
19
+ get xrpTransactionType() {
20
+ return iface_1.XrpTransactionType.TrustSet;
21
+ }
22
+ initBuilder(tx) {
23
+ super.initBuilder(tx);
24
+ const { amount } = tx.toJson();
25
+ if (!amount) {
26
+ throw new sdk_core_1.BuildTransactionError('Missing amount');
27
+ }
28
+ if (!utils_1.default.isIssuedCurrencyAmount(amount)) {
29
+ throw new sdk_core_1.BuildTransactionError('Invalid Limit Amount');
30
+ }
31
+ // The amount is represented in decimal notation, so we need to multiply it by the decimal places
32
+ const amountBigNum = (0, bignumber_js_1.default)(amount.value).shiftedBy(this._coinConfig.decimalPlaces);
33
+ this.amount(amountBigNum.toFixed());
34
+ }
35
+ /**
36
+ * Set the amount to send
37
+ * @param {string} amount - the amount sent
38
+ * @returns {TransactionBuilder} This transaction builder
39
+ */
40
+ amount(amount) {
41
+ if (typeof amount !== 'string') {
42
+ throw new Error(`amount type ${typeof amount} must be a string`);
43
+ }
44
+ const amountBigNum = (0, bignumber_js_1.default)(amount);
45
+ if (amountBigNum.lt(0)) {
46
+ throw new Error(`amount ${amount} is not valid`);
47
+ }
48
+ const currency = utils_1.default.getXrpCurrencyFromTokenName(this._coinConfig.name);
49
+ // Unlike most coins, XRP Token amounts are represented in decimal notation
50
+ const value = amountBigNum.shiftedBy(-1 * this._coinConfig.decimalPlaces).toFixed();
51
+ this._amount = {
52
+ value: value,
53
+ ...currency,
54
+ };
55
+ return this;
56
+ }
57
+ /** @inheritdoc */
58
+ async buildImplementation() {
59
+ if (!this._sender) {
60
+ throw new sdk_core_1.BuildTransactionError('Sender must be set before building the transaction');
61
+ }
62
+ const trustSetFields = {
63
+ TransactionType: this.xrpTransactionType,
64
+ Account: this._sender,
65
+ LimitAmount: this._amount,
66
+ };
67
+ this._specificFields = trustSetFields;
68
+ return await super.buildImplementation();
69
+ }
70
+ }
71
+ exports.TrustSetBuilder = TrustSetBuilder;
72
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJ1c3RzZXRCdWlsZGVyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2xpYi90cnVzdHNldEJ1aWxkZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7O0FBQUEsbURBQThFO0FBRTlFLGdFQUFxQztBQUVyQyxtQ0FBNkM7QUFFN0MsNkRBQTBEO0FBQzFELG9EQUE0QjtBQUU1QixNQUFhLGVBQWdCLFNBQVEsdUNBQWtCO0lBR3JELFlBQVksV0FBaUM7UUFDM0MsS0FBSyxDQUFDLFdBQVcsQ0FBQyxDQUFDO0lBQ3JCLENBQUM7SUFFRCxJQUFjLGVBQWU7UUFDM0IsT0FBTywwQkFBZSxDQUFDLFNBQVMsQ0FBQztJQUNuQyxDQUFDO0lBRUQsSUFBYyxrQkFBa0I7UUFDOUIsT0FBTywwQkFBa0IsQ0FBQyxRQUFRLENBQUM7SUFDckMsQ0FBQztJQUVELFdBQVcsQ0FBQyxFQUFlO1FBQ3pCLEtBQUssQ0FBQyxXQUFXLENBQUMsRUFBRSxDQUFDLENBQUM7UUFFdEIsTUFBTSxFQUFFLE1BQU0sRUFBRSxHQUFHLEVBQUUsQ0FBQyxNQUFNLEVBQUUsQ0FBQztRQUMvQixJQUFJLENBQUMsTUFBTSxFQUFFO1lBQ1gsTUFBTSxJQUFJLGdDQUFxQixDQUFDLGdCQUFnQixDQUFDLENBQUM7U0FDbkQ7UUFDRCxJQUFJLENBQUMsZUFBSyxDQUFDLHNCQUFzQixDQUFDLE1BQU0sQ0FBQyxFQUFFO1lBQ3pDLE1BQU0sSUFBSSxnQ0FBcUIsQ0FBQyxzQkFBc0IsQ0FBQyxDQUFDO1NBQ3pEO1FBQ0QsaUdBQWlHO1FBQ2pHLE1BQU0sWUFBWSxHQUFHLElBQUEsc0JBQVMsRUFBQyxNQUFNLENBQUMsS0FBSyxDQUFDLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxXQUFXLENBQUMsYUFBYSxDQUFDLENBQUM7UUFDdkYsSUFBSSxDQUFDLE1BQU0sQ0FBQyxZQUFZLENBQUMsT0FBTyxFQUFFLENBQUMsQ0FBQztJQUN0QyxDQUFDO0lBRUQ7Ozs7T0FJRztJQUNILE1BQU0sQ0FBQyxNQUFjO1FBQ25CLElBQUksT0FBTyxNQUFNLEtBQUssUUFBUSxFQUFFO1lBQzlCLE1BQU0sSUFBSSxLQUFLLENBQUMsZUFBZSxPQUFPLE1BQU0sbUJBQW1CLENBQUMsQ0FBQztTQUNsRTtRQUNELE1BQU0sWUFBWSxHQUFHLElBQUEsc0JBQVMsRUFBQyxNQUFNLENBQUMsQ0FBQztRQUN2QyxJQUFJLFlBQVksQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDLEVBQUU7WUFDdEIsTUFBTSxJQUFJLEtBQUssQ0FBQyxVQUFVLE1BQU0sZUFBZSxDQUFDLENBQUM7U0FDbEQ7UUFDRCxNQUFNLFFBQVEsR0FBRyxlQUFLLENBQUMsMkJBQTJCLENBQUMsSUFBSSxDQUFDLFdBQVcsQ0FBQyxJQUFJLENBQUMsQ0FBQztRQUMxRSwyRUFBMkU7UUFDM0UsTUFBTSxLQUFLLEdBQUcsWUFBWSxDQUFDLFNBQVMsQ0FBQyxDQUFDLENBQUMsR0FBRyxJQUFJLENBQUMsV0FBVyxDQUFDLGFBQWEsQ0FBQyxDQUFDLE9BQU8sRUFBRSxDQUFDO1FBQ3BGLElBQUksQ0FBQyxPQUFPLEdBQUc7WUFDYixLQUFLLEVBQUUsS0FBSztZQUNaLEdBQUcsUUFBUTtTQUNaLENBQUM7UUFDRixPQUFPLElBQUksQ0FBQztJQUNkLENBQUM7SUFFRCxrQkFBa0I7SUFDUixLQUFLLENBQUMsbUJBQW1CO1FBQ2pDLElBQUksQ0FBQyxJQUFJLENBQUMsT0FBTyxFQUFFO1lBQ2pCLE1BQU0sSUFBSSxnQ0FBcUIsQ0FBQyxvREFBb0QsQ0FBQyxDQUFDO1NBQ3ZGO1FBRUQsTUFBTSxjQUFjLEdBQWE7WUFDL0IsZUFBZSxFQUFFLElBQUksQ0FBQyxrQkFBa0I7WUFDeEMsT0FBTyxFQUFFLElBQUksQ0FBQyxPQUFPO1lBQ3JCLFdBQVcsRUFBRSxJQUFJLENBQUMsT0FBTztTQUMxQixDQUFDO1FBRUYsSUFBSSxDQUFDLGVBQWUsR0FBRyxjQUFjLENBQUM7UUFFdEMsT0FBTyxNQUFNLEtBQUssQ0FBQyxtQkFBbUIsRUFBRSxDQUFDO0lBQzNDLENBQUM7Q0FDRjtBQXJFRCwwQ0FxRUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBCdWlsZFRyYW5zYWN0aW9uRXJyb3IsIFRyYW5zYWN0aW9uVHlwZSB9IGZyb20gJ0BiaXRnby1iZXRhL3Nkay1jb3JlJztcbmltcG9ydCB7IEJhc2VDb2luIGFzIENvaW5Db25maWcgfSBmcm9tICdAYml0Z28tYmV0YS9zdGF0aWNzJztcbmltcG9ydCBCaWdOdW1iZXIgZnJvbSAnYmlnbnVtYmVyLmpzJztcbmltcG9ydCB7IElzc3VlZEN1cnJlbmN5QW1vdW50LCBUcnVzdFNldCB9IGZyb20gJ3hycGwnO1xuaW1wb3J0IHsgWHJwVHJhbnNhY3Rpb25UeXBlIH0gZnJvbSAnLi9pZmFjZSc7XG5pbXBvcnQgeyBUcmFuc2FjdGlvbiB9IGZyb20gJy4vdHJhbnNhY3Rpb24nO1xuaW1wb3J0IHsgVHJhbnNhY3Rpb25CdWlsZGVyIH0gZnJvbSAnLi90cmFuc2FjdGlvbkJ1aWxkZXInO1xuaW1wb3J0IHV0aWxzIGZyb20gJy4vdXRpbHMnO1xuXG5leHBvcnQgY2xhc3MgVHJ1c3RTZXRCdWlsZGVyIGV4dGVuZHMgVHJhbnNhY3Rpb25CdWlsZGVyIHtcbiAgcHJpdmF0ZSBfYW1vdW50OiBJc3N1ZWRDdXJyZW5jeUFtb3VudDtcblxuICBjb25zdHJ1Y3RvcihfY29pbkNvbmZpZzogUmVhZG9ubHk8Q29pbkNvbmZpZz4pIHtcbiAgICBzdXBlcihfY29pbkNvbmZpZyk7XG4gIH1cblxuICBwcm90ZWN0ZWQgZ2V0IHRyYW5zYWN0aW9uVHlwZSgpOiBUcmFuc2FjdGlvblR5cGUge1xuICAgIHJldHVybiBUcmFuc2FjdGlvblR5cGUuVHJ1c3RMaW5lO1xuICB9XG5cbiAgcHJvdGVjdGVkIGdldCB4cnBUcmFuc2FjdGlvblR5cGUoKTogWHJwVHJhbnNhY3Rpb25UeXBlLlRydXN0U2V0IHtcbiAgICByZXR1cm4gWHJwVHJhbnNhY3Rpb25UeXBlLlRydXN0U2V0O1xuICB9XG5cbiAgaW5pdEJ1aWxkZXIodHg6IFRyYW5zYWN0aW9uKTogdm9pZCB7XG4gICAgc3VwZXIuaW5pdEJ1aWxkZXIodHgpO1xuXG4gICAgY29uc3QgeyBhbW91bnQgfSA9IHR4LnRvSnNvbigpO1xuICAgIGlmICghYW1vdW50KSB7XG4gICAgICB0aHJvdyBuZXcgQnVpbGRUcmFuc2FjdGlvbkVycm9yKCdNaXNzaW5nIGFtb3VudCcpO1xuICAgIH1cbiAgICBpZiAoIXV0aWxzLmlzSXNzdWVkQ3VycmVuY3lBbW91bnQoYW1vdW50KSkge1xuICAgICAgdGhyb3cgbmV3IEJ1aWxkVHJhbnNhY3Rpb25FcnJvcignSW52YWxpZCBMaW1pdCBBbW91bnQnKTtcbiAgICB9XG4gICAgLy8gVGhlIGFtb3VudCBpcyByZXByZXNlbnRlZCBpbiBkZWNpbWFsIG5vdGF0aW9uLCBzbyB3ZSBuZWVkIHRvIG11bHRpcGx5IGl0IGJ5IHRoZSBkZWNpbWFsIHBsYWNlc1xuICAgIGNvbnN0IGFtb3VudEJpZ051bSA9IEJpZ051bWJlcihhbW91bnQudmFsdWUpLnNoaWZ0ZWRCeSh0aGlzLl9jb2luQ29uZmlnLmRlY2ltYWxQbGFjZXMpO1xuICAgIHRoaXMuYW1vdW50KGFtb3VudEJpZ051bS50b0ZpeGVkKCkpO1xuICB9XG5cbiAgLyoqXG4gICAqICBTZXQgdGhlIGFtb3VudCB0byBzZW5kXG4gICAqIEBwYXJhbSB7c3RyaW5nfSBhbW91bnQgLSB0aGUgYW1vdW50IHNlbnRcbiAgICogQHJldHVybnMge1RyYW5zYWN0aW9uQnVpbGRlcn0gVGhpcyB0cmFuc2FjdGlvbiBidWlsZGVyXG4gICAqL1xuICBhbW91bnQoYW1vdW50OiBzdHJpbmcpOiBUcmFuc2FjdGlvbkJ1aWxkZXIge1xuICAgIGlmICh0eXBlb2YgYW1vdW50ICE9PSAnc3RyaW5nJykge1xuICAgICAgdGhyb3cgbmV3IEVycm9yKGBhbW91bnQgdHlwZSAke3R5cGVvZiBhbW91bnR9IG11c3QgYmUgYSBzdHJpbmdgKTtcbiAgICB9XG4gICAgY29uc3QgYW1vdW50QmlnTnVtID0gQmlnTnVtYmVyKGFtb3VudCk7XG4gICAgaWYgKGFtb3VudEJpZ051bS5sdCgwKSkge1xuICAgICAgdGhyb3cgbmV3IEVycm9yKGBhbW91bnQgJHthbW91bnR9IGlzIG5vdCB2YWxpZGApO1xuICAgIH1cbiAgICBjb25zdCBjdXJyZW5jeSA9IHV0aWxzLmdldFhycEN1cnJlbmN5RnJvbVRva2VuTmFtZSh0aGlzLl9jb2luQ29uZmlnLm5hbWUpO1xuICAgIC8vIFVubGlrZSBtb3N0IGNvaW5zLCBYUlAgVG9rZW4gYW1vdW50cyBhcmUgcmVwcmVzZW50ZWQgaW4gZGVjaW1hbCBub3RhdGlvblxuICAgIGNvbnN0IHZhbHVlID0gYW1vdW50QmlnTnVtLnNoaWZ0ZWRCeSgtMSAqIHRoaXMuX2NvaW5Db25maWcuZGVjaW1hbFBsYWNlcykudG9GaXhlZCgpO1xuICAgIHRoaXMuX2Ftb3VudCA9IHtcbiAgICAgIHZhbHVlOiB2YWx1ZSxcbiAgICAgIC4uLmN1cnJlbmN5LFxuICAgIH07XG4gICAgcmV0dXJuIHRoaXM7XG4gIH1cblxuICAvKiogQGluaGVyaXRkb2MgKi9cbiAgcHJvdGVjdGVkIGFzeW5jIGJ1aWxkSW1wbGVtZW50YXRpb24oKTogUHJvbWlzZTxUcmFuc2FjdGlvbj4ge1xuICAgIGlmICghdGhpcy5fc2VuZGVyKSB7XG4gICAgICB0aHJvdyBuZXcgQnVpbGRUcmFuc2FjdGlvbkVycm9yKCdTZW5kZXIgbXVzdCBiZSBzZXQgYmVmb3JlIGJ1aWxkaW5nIHRoZSB0cmFuc2FjdGlvbicpO1xuICAgIH1cblxuICAgIGNvbnN0IHRydXN0U2V0RmllbGRzOiBUcnVzdFNldCA9IHtcbiAgICAgIFRyYW5zYWN0aW9uVHlwZTogdGhpcy54cnBUcmFuc2FjdGlvblR5cGUsXG4gICAgICBBY2NvdW50OiB0aGlzLl9zZW5kZXIsXG4gICAgICBMaW1pdEFtb3VudDogdGhpcy5fYW1vdW50LFxuICAgIH07XG5cbiAgICB0aGlzLl9zcGVjaWZpY0ZpZWxkcyA9IHRydXN0U2V0RmllbGRzO1xuXG4gICAgcmV0dXJuIGF3YWl0IHN1cGVyLmJ1aWxkSW1wbGVtZW50YXRpb24oKTtcbiAgfVxufVxuIl19
@@ -0,0 +1,69 @@
1
+ import { BaseUtils } from '@bitgo-beta/sdk-core';
2
+ import * as xrpl from 'xrpl';
3
+ import { Amount, IssuedCurrencyAmount } from 'xrpl';
4
+ import { Address, SignerDetails } from './iface';
5
+ declare class Utils implements BaseUtils {
6
+ isValidAddress(address: string): boolean;
7
+ isValidTransactionId(txId: string): boolean;
8
+ isValidPublicKey(key: string): boolean;
9
+ isValidPrivateKey(key: string): boolean;
10
+ isValidSignature(signature: string): boolean;
11
+ isValidBlockId(hash: string): boolean;
12
+ isValidHex(hex: string): boolean;
13
+ /**
14
+ * Parse an address string into address and destination tag
15
+ */
16
+ getAddressDetails(address: string): Address;
17
+ /**
18
+ * Construct a full, normalized address from an address and destination tag
19
+ */
20
+ normalizeAddress({ address, destinationTag }: Address): string;
21
+ /**
22
+ * @param message hex encoded string
23
+ * @param privateKey
24
+ * return hex encoded signature string, throws if any of the inputs are invalid
25
+ */
26
+ signString(message: string, privateKey: string): string;
27
+ /**
28
+ * @param message hex encoded string
29
+ * @param signature hex encooded signature string
30
+ * @param publicKey
31
+ * return boolean, throws if any of the inputs are invalid
32
+ */
33
+ verifySignature(message: string, signature: string, publicKey: string): boolean;
34
+ /**
35
+ * Check the raw transaction has a valid format in the blockchain context, throw otherwise.
36
+ *
37
+ * @param {string} rawTransaction - Transaction in hex string format
38
+ */
39
+ validateRawTransaction(rawTransaction: string): void;
40
+ /**
41
+ * Checks if raw transaction can be deserialized
42
+ *
43
+ * @param {string} rawTransaction - transaction in base64 string format
44
+ * @returns {boolean} - the validation result
45
+ */
46
+ isValidRawTransaction(rawTransaction: string): boolean;
47
+ validateAccountSetFlag(setFlag: number): void;
48
+ validateSigner(signer: SignerDetails): void;
49
+ /**
50
+ * Determines if the provided `amount` is for a token payment
51
+ */
52
+ isIssuedCurrencyAmount(amount: Amount): amount is IssuedCurrencyAmount;
53
+ /**
54
+ * Get the associated XRP Currency details from token name. Throws an error if token is unsupported
55
+ * @param {string} tokenName - The token name
56
+ */
57
+ getXrpCurrencyFromTokenName(tokenName: string): xrpl.IssuedCurrency;
58
+ /**
59
+ * Decodes a serialized XRPL transaction.
60
+ *
61
+ * @param {string} txHex - The serialized transaction in hex.
62
+ * @returns {Object} - Decoded transaction object.
63
+ * @throws {Error} - If decoding fails or input is invalid.
64
+ */
65
+ decodeTransaction(txHex: string): Record<string, unknown>;
66
+ }
67
+ declare const utils: Utils;
68
+ export default utils;
69
+ //# sourceMappingURL=utils.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"utils.d.ts","sourceRoot":"","sources":["../../../src/lib/utils.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,SAAS,EAKV,MAAM,sBAAsB,CAAC;AAK9B,OAAO,KAAK,IAAI,MAAM,MAAM,CAAC;AAC7B,OAAO,EAAE,MAAM,EAAE,oBAAoB,EAAE,MAAM,MAAM,CAAC;AAEpD,OAAO,EAAE,OAAO,EAAE,aAAa,EAAE,MAAM,SAAS,CAAC;AAGjD,cAAM,KAAM,YAAW,SAAS;IAC9B,cAAc,CAAC,OAAO,EAAE,MAAM,GAAG,OAAO;IASxC,oBAAoB,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO;IAI3C,gBAAgB,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO;IAStC,iBAAiB,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO;IASvC,gBAAgB,CAAC,SAAS,EAAE,MAAM,GAAG,OAAO;IAI5C,cAAc,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO;IAIrC,UAAU,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO;IAIhC;;OAEG;IACI,iBAAiB,CAAC,OAAO,EAAE,MAAM,GAAG,OAAO;IA8ClD;;OAEG;IACI,gBAAgB,CAAC,EAAE,OAAO,EAAE,cAAc,EAAE,EAAE,OAAO,GAAG,MAAM;IAgBrE;;;;OAIG;IACI,UAAU,CAAC,OAAO,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,GAAG,MAAM;IAU9D;;;;;OAKG;IACI,eAAe,CAAC,OAAO,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,GAAG,OAAO;IAiBtF;;;;OAIG;IACI,sBAAsB,CAAC,cAAc,EAAE,MAAM,GAAG,IAAI;IAY3D;;;;;OAKG;IACI,qBAAqB,CAAC,cAAc,EAAE,MAAM,GAAG,OAAO;IAUtD,sBAAsB,CAAC,OAAO,EAAE,MAAM;IAStC,cAAc,CAAC,MAAM,EAAE,aAAa,GAAG,IAAI;IAYlD;;OAEG;IACI,sBAAsB,CAAC,MAAM,EAAE,MAAM,GAAG,MAAM,IAAI,oBAAoB;IAU7E;;;OAGG;IACI,2BAA2B,CAAC,SAAS,EAAE,MAAM,GAAG,IAAI,CAAC,cAAc;IAc1E;;;;;;OAMG;IACI,iBAAiB,CAAC,KAAK,EAAE,MAAM;CAUvC;AAED,QAAA,MAAM,KAAK,OAAc,CAAC;AAE1B,eAAe,KAAK,CAAC"}
@@ -0,0 +1,268 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = 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);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || function (mod) {
19
+ if (mod && mod.__esModule) return mod;
20
+ var result = {};
21
+ if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
22
+ __setModuleDefault(result, mod);
23
+ return result;
24
+ };
25
+ Object.defineProperty(exports, "__esModule", { value: true });
26
+ const sdk_core_1 = require("@bitgo-beta/sdk-core");
27
+ const statics_1 = require("@bitgo-beta/statics");
28
+ const querystring = __importStar(require("querystring"));
29
+ const rippleKeypairs = __importStar(require("ripple-keypairs"));
30
+ const url = __importStar(require("url"));
31
+ const xrpl = __importStar(require("xrpl"));
32
+ const constants_1 = require("./constants");
33
+ const keyPair_1 = require("./keyPair");
34
+ class Utils {
35
+ isValidAddress(address) {
36
+ try {
37
+ const addressDetails = this.getAddressDetails(address);
38
+ return address === this.normalizeAddress(addressDetails);
39
+ }
40
+ catch (e) {
41
+ return false;
42
+ }
43
+ }
44
+ isValidTransactionId(txId) {
45
+ return this.isValidHex(txId);
46
+ }
47
+ isValidPublicKey(key) {
48
+ try {
49
+ new keyPair_1.KeyPair({ pub: key });
50
+ return true;
51
+ }
52
+ catch {
53
+ return false;
54
+ }
55
+ }
56
+ isValidPrivateKey(key) {
57
+ try {
58
+ new keyPair_1.KeyPair({ prv: key });
59
+ return true;
60
+ }
61
+ catch {
62
+ return false;
63
+ }
64
+ }
65
+ isValidSignature(signature) {
66
+ return this.isValidHex(signature);
67
+ }
68
+ isValidBlockId(hash) {
69
+ return this.isValidHex(hash);
70
+ }
71
+ isValidHex(hex) {
72
+ return /^([a-fA-F0-9])+$/.test(hex);
73
+ }
74
+ /**
75
+ * Parse an address string into address and destination tag
76
+ */
77
+ getAddressDetails(address) {
78
+ const destinationDetails = url.parse(address);
79
+ const destinationAddress = destinationDetails.pathname;
80
+ if (!destinationAddress || !xrpl.isValidClassicAddress(destinationAddress)) {
81
+ throw new sdk_core_1.InvalidAddressError(`destination address "${destinationAddress}" is not valid`);
82
+ }
83
+ // there are no other properties like destination tags
84
+ if (destinationDetails.pathname === address) {
85
+ return {
86
+ address: address,
87
+ destinationTag: undefined,
88
+ };
89
+ }
90
+ if (!destinationDetails.query) {
91
+ throw new sdk_core_1.InvalidAddressError('no query params present');
92
+ }
93
+ const queryDetails = querystring.parse(destinationDetails.query);
94
+ if (!queryDetails.dt) {
95
+ // if there are more properties, the query details need to contain the destination tag property.
96
+ throw new sdk_core_1.InvalidAddressError('destination tag missing');
97
+ }
98
+ if (Array.isArray(queryDetails.dt)) {
99
+ // if queryDetails.dt is an array, that means dt was given multiple times, which is not valid
100
+ throw new sdk_core_1.InvalidAddressError(`destination tag can appear at most once, but ${queryDetails.dt.length} destination tags were found`);
101
+ }
102
+ const parsedTag = parseInt(queryDetails.dt, 10);
103
+ if (!Number.isSafeInteger(parsedTag)) {
104
+ throw new sdk_core_1.InvalidAddressError('invalid destination tag');
105
+ }
106
+ if (parsedTag > 0xffffffff || parsedTag < 0) {
107
+ throw new sdk_core_1.InvalidAddressError('destination tag out of range');
108
+ }
109
+ return {
110
+ address: destinationAddress,
111
+ destinationTag: parsedTag,
112
+ };
113
+ }
114
+ /**
115
+ * Construct a full, normalized address from an address and destination tag
116
+ */
117
+ normalizeAddress({ address, destinationTag }) {
118
+ if (typeof address !== 'string') {
119
+ throw new sdk_core_1.InvalidAddressError('invalid address, expected string');
120
+ }
121
+ if (typeof destinationTag === 'undefined' || destinationTag === null) {
122
+ return address;
123
+ }
124
+ if (!Number.isInteger(destinationTag)) {
125
+ throw new sdk_core_1.InvalidAddressError('invalid destination tag, expected integer');
126
+ }
127
+ if (destinationTag > 0xffffffff || destinationTag < 0) {
128
+ throw new sdk_core_1.InvalidAddressError('destination tag out of range');
129
+ }
130
+ return `${address}?dt=${destinationTag}`;
131
+ }
132
+ /**
133
+ * @param message hex encoded string
134
+ * @param privateKey
135
+ * return hex encoded signature string, throws if any of the inputs are invalid
136
+ */
137
+ signString(message, privateKey) {
138
+ if (!this.isValidHex(message)) {
139
+ throw new sdk_core_1.UtilsError('message must be a hex encoded string');
140
+ }
141
+ if (!this.isValidPrivateKey(privateKey)) {
142
+ throw new sdk_core_1.UtilsError('invalid private key');
143
+ }
144
+ return rippleKeypairs.sign(message, privateKey);
145
+ }
146
+ /**
147
+ * @param message hex encoded string
148
+ * @param signature hex encooded signature string
149
+ * @param publicKey
150
+ * return boolean, throws if any of the inputs are invalid
151
+ */
152
+ verifySignature(message, signature, publicKey) {
153
+ if (!this.isValidHex(message)) {
154
+ throw new sdk_core_1.UtilsError('message must be a hex encoded string');
155
+ }
156
+ if (!this.isValidSignature(signature)) {
157
+ throw new sdk_core_1.UtilsError('invalid signature');
158
+ }
159
+ if (!this.isValidPublicKey(publicKey)) {
160
+ throw new sdk_core_1.UtilsError('invalid public key');
161
+ }
162
+ try {
163
+ return rippleKeypairs.verify(message, signature, publicKey);
164
+ }
165
+ catch (e) {
166
+ return false;
167
+ }
168
+ }
169
+ /**
170
+ * Check the raw transaction has a valid format in the blockchain context, throw otherwise.
171
+ *
172
+ * @param {string} rawTransaction - Transaction in hex string format
173
+ */
174
+ validateRawTransaction(rawTransaction) {
175
+ if (!rawTransaction) {
176
+ throw new sdk_core_1.InvalidTransactionError('Invalid raw transaction: Undefined');
177
+ }
178
+ if (!this.isValidHex(rawTransaction)) {
179
+ throw new sdk_core_1.InvalidTransactionError('Invalid raw transaction: Hex string expected');
180
+ }
181
+ if (!this.isValidRawTransaction(rawTransaction)) {
182
+ throw new sdk_core_1.InvalidTransactionError('Invalid raw transaction');
183
+ }
184
+ }
185
+ /**
186
+ * Checks if raw transaction can be deserialized
187
+ *
188
+ * @param {string} rawTransaction - transaction in base64 string format
189
+ * @returns {boolean} - the validation result
190
+ */
191
+ isValidRawTransaction(rawTransaction) {
192
+ try {
193
+ const jsonTx = xrpl.decode(rawTransaction);
194
+ xrpl.validate(jsonTx);
195
+ return true;
196
+ }
197
+ catch (e) {
198
+ return false;
199
+ }
200
+ }
201
+ validateAccountSetFlag(setFlag) {
202
+ if (typeof setFlag !== 'number') {
203
+ throw new sdk_core_1.UtilsError(`setFlag ${setFlag} is not valid`);
204
+ }
205
+ if (!constants_1.VALID_ACCOUNT_SET_FLAGS.includes(setFlag)) {
206
+ throw new sdk_core_1.UtilsError(`setFlag ${setFlag} is not a valid account set flag`);
207
+ }
208
+ }
209
+ validateSigner(signer) {
210
+ if (!signer.address) {
211
+ throw new sdk_core_1.UtilsError('signer must have an address');
212
+ }
213
+ if (!this.isValidAddress(signer.address)) {
214
+ throw new sdk_core_1.UtilsError(`signer address ${signer.address} is invalid`);
215
+ }
216
+ if (typeof signer.weight !== 'number' || signer.weight < 0) {
217
+ throw new sdk_core_1.UtilsError(`signer weight ${signer.weight} is not valid`);
218
+ }
219
+ }
220
+ /**
221
+ * Determines if the provided `amount` is for a token payment
222
+ */
223
+ isIssuedCurrencyAmount(amount) {
224
+ return (!!amount &&
225
+ typeof amount === 'object' &&
226
+ typeof amount.currency === 'string' &&
227
+ typeof amount.issuer === 'string' &&
228
+ typeof amount.value === 'string');
229
+ }
230
+ /**
231
+ * Get the associated XRP Currency details from token name. Throws an error if token is unsupported
232
+ * @param {string} tokenName - The token name
233
+ */
234
+ getXrpCurrencyFromTokenName(tokenName) {
235
+ if (!statics_1.coins.has(tokenName)) {
236
+ throw new sdk_core_1.UnsupportedTokenError(`${tokenName} is not supported`);
237
+ }
238
+ const token = statics_1.coins.get(tokenName);
239
+ if (!token.isToken || !(token instanceof statics_1.XrpCoin)) {
240
+ throw new sdk_core_1.UnsupportedTokenError(`${tokenName} is not an XRP token`);
241
+ }
242
+ return {
243
+ currency: token.currencyCode,
244
+ issuer: token.issuerAddress,
245
+ };
246
+ }
247
+ /**
248
+ * Decodes a serialized XRPL transaction.
249
+ *
250
+ * @param {string} txHex - The serialized transaction in hex.
251
+ * @returns {Object} - Decoded transaction object.
252
+ * @throws {Error} - If decoding fails or input is invalid.
253
+ */
254
+ decodeTransaction(txHex) {
255
+ if (typeof txHex !== 'string' || txHex.trim() === '') {
256
+ throw new Error('Invalid transaction hex. Expected a non-empty string.');
257
+ }
258
+ try {
259
+ return xrpl.decode(txHex);
260
+ }
261
+ catch (error) {
262
+ throw new Error(`Failed to decode transaction: ${error.message}`);
263
+ }
264
+ }
265
+ }
266
+ const utils = new Utils();
267
+ exports.default = utils;
268
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"utils.js","sourceRoot":"","sources":["../../../src/lib/utils.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  BaseUtils,\n  InvalidAddressError,\n  InvalidTransactionError,\n  UnsupportedTokenError,\n  UtilsError,\n} from '@bitgo-beta/sdk-core';\nimport { coins, XrpCoin } from '@bitgo-beta/statics';\nimport * as querystring from 'querystring';\nimport * as rippleKeypairs from 'ripple-keypairs';\nimport * as url from 'url';\nimport * as xrpl from 'xrpl';\nimport { Amount, IssuedCurrencyAmount } from 'xrpl';\nimport { VALID_ACCOUNT_SET_FLAGS } from './constants';\nimport { Address, SignerDetails } from './iface';\nimport { KeyPair as XrpKeyPair } from './keyPair';\n\nclass Utils implements BaseUtils {\n  isValidAddress(address: string): boolean {\n    try {\n      const addressDetails = this.getAddressDetails(address);\n      return address === this.normalizeAddress(addressDetails);\n    } catch (e) {\n      return false;\n    }\n  }\n\n  isValidTransactionId(txId: string): boolean {\n    return this.isValidHex(txId);\n  }\n\n  isValidPublicKey(key: string): boolean {\n    try {\n      new XrpKeyPair({ pub: key });\n      return true;\n    } catch {\n      return false;\n    }\n  }\n\n  isValidPrivateKey(key: string): boolean {\n    try {\n      new XrpKeyPair({ prv: key });\n      return true;\n    } catch {\n      return false;\n    }\n  }\n\n  isValidSignature(signature: string): boolean {\n    return this.isValidHex(signature);\n  }\n\n  isValidBlockId(hash: string): boolean {\n    return this.isValidHex(hash);\n  }\n\n  isValidHex(hex: string): boolean {\n    return /^([a-fA-F0-9])+$/.test(hex);\n  }\n\n  /**\n   * Parse an address string into address and destination tag\n   */\n  public getAddressDetails(address: string): Address {\n    const destinationDetails = url.parse(address);\n    const destinationAddress = destinationDetails.pathname;\n    if (!destinationAddress || !xrpl.isValidClassicAddress(destinationAddress)) {\n      throw new InvalidAddressError(`destination address \"${destinationAddress}\" is not valid`);\n    }\n    // there are no other properties like destination tags\n    if (destinationDetails.pathname === address) {\n      return {\n        address: address,\n        destinationTag: undefined,\n      };\n    }\n\n    if (!destinationDetails.query) {\n      throw new InvalidAddressError('no query params present');\n    }\n\n    const queryDetails = querystring.parse(destinationDetails.query);\n    if (!queryDetails.dt) {\n      // if there are more properties, the query details need to contain the destination tag property.\n      throw new InvalidAddressError('destination tag missing');\n    }\n\n    if (Array.isArray(queryDetails.dt)) {\n      // if queryDetails.dt is an array, that means dt was given multiple times, which is not valid\n      throw new InvalidAddressError(\n        `destination tag can appear at most once, but ${queryDetails.dt.length} destination tags were found`\n      );\n    }\n\n    const parsedTag = parseInt(queryDetails.dt, 10);\n    if (!Number.isSafeInteger(parsedTag)) {\n      throw new InvalidAddressError('invalid destination tag');\n    }\n\n    if (parsedTag > 0xffffffff || parsedTag < 0) {\n      throw new InvalidAddressError('destination tag out of range');\n    }\n\n    return {\n      address: destinationAddress,\n      destinationTag: parsedTag,\n    };\n  }\n\n  /**\n   * Construct a full, normalized address from an address and destination tag\n   */\n  public normalizeAddress({ address, destinationTag }: Address): string {\n    if (typeof address !== 'string') {\n      throw new InvalidAddressError('invalid address, expected string');\n    }\n    if (typeof destinationTag === 'undefined' || destinationTag === null) {\n      return address;\n    }\n    if (!Number.isInteger(destinationTag)) {\n      throw new InvalidAddressError('invalid destination tag, expected integer');\n    }\n    if (destinationTag > 0xffffffff || destinationTag < 0) {\n      throw new InvalidAddressError('destination tag out of range');\n    }\n    return `${address}?dt=${destinationTag}`;\n  }\n\n  /**\n   * @param message hex encoded string\n   * @param privateKey\n   * return hex encoded signature string, throws if any of the inputs are invalid\n   */\n  public signString(message: string, privateKey: string): string {\n    if (!this.isValidHex(message)) {\n      throw new UtilsError('message must be a hex encoded string');\n    }\n    if (!this.isValidPrivateKey(privateKey)) {\n      throw new UtilsError('invalid private key');\n    }\n    return rippleKeypairs.sign(message, privateKey);\n  }\n\n  /**\n   * @param message hex encoded string\n   * @param signature hex encooded signature string\n   * @param publicKey\n   * return boolean, throws if any of the inputs are invalid\n   */\n  public verifySignature(message: string, signature: string, publicKey: string): boolean {\n    if (!this.isValidHex(message)) {\n      throw new UtilsError('message must be a hex encoded string');\n    }\n    if (!this.isValidSignature(signature)) {\n      throw new UtilsError('invalid signature');\n    }\n    if (!this.isValidPublicKey(publicKey)) {\n      throw new UtilsError('invalid public key');\n    }\n    try {\n      return rippleKeypairs.verify(message, signature, publicKey);\n    } catch (e) {\n      return false;\n    }\n  }\n\n  /**\n   * Check the raw transaction has a valid format in the blockchain context, throw otherwise.\n   *\n   * @param {string} rawTransaction - Transaction in hex string format\n   */\n  public validateRawTransaction(rawTransaction: string): void {\n    if (!rawTransaction) {\n      throw new InvalidTransactionError('Invalid raw transaction: Undefined');\n    }\n    if (!this.isValidHex(rawTransaction)) {\n      throw new InvalidTransactionError('Invalid raw transaction: Hex string expected');\n    }\n    if (!this.isValidRawTransaction(rawTransaction)) {\n      throw new InvalidTransactionError('Invalid raw transaction');\n    }\n  }\n\n  /**\n   * Checks if raw transaction can be deserialized\n   *\n   * @param {string} rawTransaction - transaction in base64 string format\n   * @returns {boolean} - the validation result\n   */\n  public isValidRawTransaction(rawTransaction: string): boolean {\n    try {\n      const jsonTx = xrpl.decode(rawTransaction);\n      xrpl.validate(jsonTx);\n      return true;\n    } catch (e) {\n      return false;\n    }\n  }\n\n  public validateAccountSetFlag(setFlag: number) {\n    if (typeof setFlag !== 'number') {\n      throw new UtilsError(`setFlag ${setFlag} is not valid`);\n    }\n    if (!VALID_ACCOUNT_SET_FLAGS.includes(setFlag)) {\n      throw new UtilsError(`setFlag ${setFlag} is not a valid account set flag`);\n    }\n  }\n\n  public validateSigner(signer: SignerDetails): void {\n    if (!signer.address) {\n      throw new UtilsError('signer must have an address');\n    }\n    if (!this.isValidAddress(signer.address)) {\n      throw new UtilsError(`signer address ${signer.address} is invalid`);\n    }\n    if (typeof signer.weight !== 'number' || signer.weight < 0) {\n      throw new UtilsError(`signer weight ${signer.weight} is not valid`);\n    }\n  }\n\n  /**\n   * Determines if the provided `amount` is for a token payment\n   */\n  public isIssuedCurrencyAmount(amount: Amount): amount is IssuedCurrencyAmount {\n    return (\n      !!amount &&\n      typeof amount === 'object' &&\n      typeof amount.currency === 'string' &&\n      typeof amount.issuer === 'string' &&\n      typeof amount.value === 'string'\n    );\n  }\n\n  /**\n   * Get the associated XRP Currency details from token name. Throws an error if token is unsupported\n   * @param {string} tokenName - The token name\n   */\n  public getXrpCurrencyFromTokenName(tokenName: string): xrpl.IssuedCurrency {\n    if (!coins.has(tokenName)) {\n      throw new UnsupportedTokenError(`${tokenName} is not supported`);\n    }\n    const token = coins.get(tokenName);\n    if (!token.isToken || !(token instanceof XrpCoin)) {\n      throw new UnsupportedTokenError(`${tokenName} is not an XRP token`);\n    }\n    return {\n      currency: token.currencyCode,\n      issuer: token.issuerAddress,\n    };\n  }\n\n  /**\n   * Decodes a serialized XRPL transaction.\n   *\n   * @param {string} txHex - The serialized transaction in hex.\n   * @returns {Object} - Decoded transaction object.\n   * @throws {Error} - If decoding fails or input is invalid.\n   */\n  public decodeTransaction(txHex: string) {\n    if (typeof txHex !== 'string' || txHex.trim() === '') {\n      throw new Error('Invalid transaction hex. Expected a non-empty string.');\n    }\n    try {\n      return xrpl.decode(txHex);\n    } catch (error) {\n      throw new Error(`Failed to decode transaction: ${error.message}`);\n    }\n  }\n}\n\nconst utils = new Utils();\n\nexport default utils;\n"]}
@@ -0,0 +1,19 @@
1
+ import { TransactionType } from '@bitgo-beta/sdk-core';
2
+ import { BaseCoin as CoinConfig } from '@bitgo-beta/statics';
3
+ import { SignerEntry } from 'xrpl/dist/npm/models/common';
4
+ import { SignerDetails } from './iface';
5
+ import { Transaction } from './transaction';
6
+ import { TransactionBuilder } from './transactionBuilder';
7
+ export declare class WalletInitializationBuilder extends TransactionBuilder {
8
+ protected _signerQuorum: number;
9
+ protected _signerEntries: SignerEntry[];
10
+ constructor(_coinConfig: Readonly<CoinConfig>);
11
+ protected get transactionType(): TransactionType;
12
+ protected get xrpTransactionType(): 'SignerListSet';
13
+ signerQuorum(quorum: number): TransactionBuilder;
14
+ signer(signer: SignerDetails): TransactionBuilder;
15
+ initBuilder(tx: Transaction): void;
16
+ /** @inheritdoc */
17
+ protected buildImplementation(): Promise<Transaction>;
18
+ }
19
+ //# sourceMappingURL=walletInitializationBuilder.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"walletInitializationBuilder.d.ts","sourceRoot":"","sources":["../../../src/lib/walletInitializationBuilder.ts"],"names":[],"mappings":"AAAA,OAAO,EAAyB,eAAe,EAAE,MAAM,sBAAsB,CAAC;AAC9E,OAAO,EAAE,QAAQ,IAAI,UAAU,EAAE,MAAM,qBAAqB,CAAC;AAC7D,OAAO,EAAE,WAAW,EAAE,MAAM,6BAA6B,CAAC;AAE1D,OAAO,EAAE,aAAa,EAAE,MAAM,SAAS,CAAC;AACxC,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAC5C,OAAO,EAAE,kBAAkB,EAAE,MAAM,sBAAsB,CAAC;AAG1D,qBAAa,2BAA4B,SAAQ,kBAAkB;IACjE,SAAS,CAAC,aAAa,EAAE,MAAM,CAAC;IAChC,SAAS,CAAC,cAAc,EAAE,WAAW,EAAE,CAAM;gBACjC,WAAW,EAAE,QAAQ,CAAC,UAAU,CAAC;IAI7C,SAAS,KAAK,eAAe,IAAI,eAAe,CAE/C;IAED,SAAS,KAAK,kBAAkB,IAAI,eAAe,CAElD;IAED,YAAY,CAAC,MAAM,EAAE,MAAM,GAAG,kBAAkB;IAQhD,MAAM,CAAC,MAAM,EAAE,aAAa,GAAG,kBAAkB;IAWjD,WAAW,CAAC,EAAE,EAAE,WAAW,GAAG,IAAI;IAkBlC,kBAAkB;cACF,mBAAmB,IAAI,OAAO,CAAC,WAAW,CAAC;CAuB5D"}
@@ -0,0 +1,76 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.WalletInitializationBuilder = void 0;
7
+ const sdk_core_1 = require("@bitgo-beta/sdk-core");
8
+ const constants_1 = require("./constants");
9
+ const transactionBuilder_1 = require("./transactionBuilder");
10
+ const utils_1 = __importDefault(require("./utils"));
11
+ class WalletInitializationBuilder extends transactionBuilder_1.TransactionBuilder {
12
+ constructor(_coinConfig) {
13
+ super(_coinConfig);
14
+ this._signerEntries = [];
15
+ }
16
+ get transactionType() {
17
+ return sdk_core_1.TransactionType.WalletInitialization;
18
+ }
19
+ get xrpTransactionType() {
20
+ return 'SignerListSet';
21
+ }
22
+ signerQuorum(quorum) {
23
+ if (typeof quorum !== 'number' || quorum < 1) {
24
+ throw new Error(`quorum must be a valid number greater than 0, got: ${quorum}`);
25
+ }
26
+ this._signerQuorum = quorum;
27
+ return this;
28
+ }
29
+ signer(signer) {
30
+ if (this._signerEntries.length > constants_1.MAX_SIGNERS) {
31
+ throw new sdk_core_1.BuildTransactionError(`Cannot have more than ${constants_1.MAX_SIGNERS} signers`);
32
+ }
33
+ utils_1.default.validateSigner(signer);
34
+ this._signerEntries.push({
35
+ SignerEntry: { Account: signer.address, SignerWeight: signer.weight },
36
+ });
37
+ return this;
38
+ }
39
+ initBuilder(tx) {
40
+ super.initBuilder(tx);
41
+ const { signerEntries, signerQuorum } = tx.toJson();
42
+ if (signerQuorum) {
43
+ this.signerQuorum(signerQuorum);
44
+ }
45
+ if (signerEntries === null || signerEntries === void 0 ? void 0 : signerEntries.length) {
46
+ signerEntries.forEach((signer) => this.signer({
47
+ address: signer.SignerEntry.Account,
48
+ weight: signer.SignerEntry.SignerWeight,
49
+ }));
50
+ }
51
+ }
52
+ /** @inheritdoc */
53
+ async buildImplementation() {
54
+ if (!this._sender) {
55
+ throw new sdk_core_1.BuildTransactionError('Sender must be set before building the transaction');
56
+ }
57
+ if (!this._signerQuorum || this._signerQuorum < constants_1.MIN_SIGNER_QUORUM) {
58
+ throw new sdk_core_1.BuildTransactionError('Signer quorum must be set before building the transaction');
59
+ }
60
+ if (!this._signerEntries) {
61
+ throw new sdk_core_1.BuildTransactionError('Signers must be set before building the transaction');
62
+ }
63
+ if (this._signerEntries.length < constants_1.MIN_SIGNERS || this._signerEntries.length > constants_1.MAX_SIGNERS) {
64
+ throw new sdk_core_1.BuildTransactionError(`Signers must be between ${constants_1.MIN_SIGNERS} and ${constants_1.MAX_SIGNERS}`);
65
+ }
66
+ this._specificFields = {
67
+ TransactionType: this.xrpTransactionType,
68
+ Account: this._sender,
69
+ SignerQuorum: this._signerQuorum,
70
+ SignerEntries: this._signerEntries,
71
+ };
72
+ return await super.buildImplementation();
73
+ }
74
+ }
75
+ exports.WalletInitializationBuilder = WalletInitializationBuilder;
76
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid2FsbGV0SW5pdGlhbGl6YXRpb25CdWlsZGVyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2xpYi93YWxsZXRJbml0aWFsaXphdGlvbkJ1aWxkZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7O0FBQUEsbURBQThFO0FBRzlFLDJDQUEwRTtBQUcxRSw2REFBMEQ7QUFDMUQsb0RBQTRCO0FBRTVCLE1BQWEsMkJBQTRCLFNBQVEsdUNBQWtCO0lBR2pFLFlBQVksV0FBaUM7UUFDM0MsS0FBSyxDQUFDLFdBQVcsQ0FBQyxDQUFDO1FBRlgsbUJBQWMsR0FBa0IsRUFBRSxDQUFDO0lBRzdDLENBQUM7SUFFRCxJQUFjLGVBQWU7UUFDM0IsT0FBTywwQkFBZSxDQUFDLG9CQUFvQixDQUFDO0lBQzlDLENBQUM7SUFFRCxJQUFjLGtCQUFrQjtRQUM5QixPQUFPLGVBQWUsQ0FBQztJQUN6QixDQUFDO0lBRUQsWUFBWSxDQUFDLE1BQWM7UUFDekIsSUFBSSxPQUFPLE1BQU0sS0FBSyxRQUFRLElBQUksTUFBTSxHQUFHLENBQUMsRUFBRTtZQUM1QyxNQUFNLElBQUksS0FBSyxDQUFDLHNEQUFzRCxNQUFNLEVBQUUsQ0FBQyxDQUFDO1NBQ2pGO1FBQ0QsSUFBSSxDQUFDLGFBQWEsR0FBRyxNQUFNLENBQUM7UUFDNUIsT0FBTyxJQUFJLENBQUM7SUFDZCxDQUFDO0lBRUQsTUFBTSxDQUFDLE1BQXFCO1FBQzFCLElBQUksSUFBSSxDQUFDLGNBQWMsQ0FBQyxNQUFNLEdBQUcsdUJBQVcsRUFBRTtZQUM1QyxNQUFNLElBQUksZ0NBQXFCLENBQUMseUJBQXlCLHVCQUFXLFVBQVUsQ0FBQyxDQUFDO1NBQ2pGO1FBQ0QsZUFBSyxDQUFDLGNBQWMsQ0FBQyxNQUFNLENBQUMsQ0FBQztRQUM3QixJQUFJLENBQUMsY0FBYyxDQUFDLElBQUksQ0FBQztZQUN2QixXQUFXLEVBQUUsRUFBRSxPQUFPLEVBQUUsTUFBTSxDQUFDLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxDQUFDLE1BQU0sRUFBRTtTQUN0RSxDQUFDLENBQUM7UUFDSCxPQUFPLElBQUksQ0FBQztJQUNkLENBQUM7SUFFRCxXQUFXLENBQUMsRUFBZTtRQUN6QixLQUFLLENBQUMsV0FBVyxDQUFDLEVBQUUsQ0FBQyxDQUFDO1FBRXRCLE1BQU0sRUFBRSxhQUFhLEVBQUUsWUFBWSxFQUFFLEdBQUcsRUFBRSxDQUFDLE1BQU0sRUFBRSxDQUFDO1FBQ3BELElBQUksWUFBWSxFQUFFO1lBQ2hCLElBQUksQ0FBQyxZQUFZLENBQUMsWUFBWSxDQUFDLENBQUM7U0FDakM7UUFFRCxJQUFJLGFBQWEsYUFBYixhQUFhLHVCQUFiLGFBQWEsQ0FBRSxNQUFNLEVBQUU7WUFDekIsYUFBYSxDQUFDLE9BQU8sQ0FBQyxDQUFDLE1BQU0sRUFBRSxFQUFFLENBQy9CLElBQUksQ0FBQyxNQUFNLENBQUM7Z0JBQ1YsT0FBTyxFQUFFLE1BQU0sQ0FBQyxXQUFXLENBQUMsT0FBTztnQkFDbkMsTUFBTSxFQUFFLE1BQU0sQ0FBQyxXQUFXLENBQUMsWUFBWTthQUN4QyxDQUFDLENBQ0gsQ0FBQztTQUNIO0lBQ0gsQ0FBQztJQUVELGtCQUFrQjtJQUNSLEtBQUssQ0FBQyxtQkFBbUI7UUFDakMsSUFBSSxDQUFDLElBQUksQ0FBQyxPQUFPLEVBQUU7WUFDakIsTUFBTSxJQUFJLGdDQUFxQixDQUFDLG9EQUFvRCxDQUFDLENBQUM7U0FDdkY7UUFDRCxJQUFJLENBQUMsSUFBSSxDQUFDLGFBQWEsSUFBSSxJQUFJLENBQUMsYUFBYSxHQUFHLDZCQUFpQixFQUFFO1lBQ2pFLE1BQU0sSUFBSSxnQ0FBcUIsQ0FBQywyREFBMkQsQ0FBQyxDQUFDO1NBQzlGO1FBQ0QsSUFBSSxDQUFDLElBQUksQ0FBQyxjQUFjLEVBQUU7WUFDeEIsTUFBTSxJQUFJLGdDQUFxQixDQUFDLHFEQUFxRCxDQUFDLENBQUM7U0FDeEY7UUFFRCxJQUFJLElBQUksQ0FBQyxjQUFjLENBQUMsTUFBTSxHQUFHLHVCQUFXLElBQUksSUFBSSxDQUFDLGNBQWMsQ0FBQyxNQUFNLEdBQUcsdUJBQVcsRUFBRTtZQUN4RixNQUFNLElBQUksZ0NBQXFCLENBQUMsMkJBQTJCLHVCQUFXLFFBQVEsdUJBQVcsRUFBRSxDQUFDLENBQUM7U0FDOUY7UUFFRCxJQUFJLENBQUMsZUFBZSxHQUFHO1lBQ3JCLGVBQWUsRUFBRSxJQUFJLENBQUMsa0JBQWtCO1lBQ3hDLE9BQU8sRUFBRSxJQUFJLENBQUMsT0FBTztZQUNyQixZQUFZLEVBQUUsSUFBSSxDQUFDLGFBQWE7WUFDaEMsYUFBYSxFQUFFLElBQUksQ0FBQyxjQUFjO1NBQ25DLENBQUM7UUFDRixPQUFPLE1BQU0sS0FBSyxDQUFDLG1CQUFtQixFQUFFLENBQUM7SUFDM0MsQ0FBQztDQUNGO0FBNUVELGtFQTRFQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEJ1aWxkVHJhbnNhY3Rpb25FcnJvciwgVHJhbnNhY3Rpb25UeXBlIH0gZnJvbSAnQGJpdGdvLWJldGEvc2RrLWNvcmUnO1xuaW1wb3J0IHsgQmFzZUNvaW4gYXMgQ29pbkNvbmZpZyB9IGZyb20gJ0BiaXRnby1iZXRhL3N0YXRpY3MnO1xuaW1wb3J0IHsgU2lnbmVyRW50cnkgfSBmcm9tICd4cnBsL2Rpc3QvbnBtL21vZGVscy9jb21tb24nO1xuaW1wb3J0IHsgTUFYX1NJR05FUlMsIE1JTl9TSUdORVJfUVVPUlVNLCBNSU5fU0lHTkVSUyB9IGZyb20gJy4vY29uc3RhbnRzJztcbmltcG9ydCB7IFNpZ25lckRldGFpbHMgfSBmcm9tICcuL2lmYWNlJztcbmltcG9ydCB7IFRyYW5zYWN0aW9uIH0gZnJvbSAnLi90cmFuc2FjdGlvbic7XG5pbXBvcnQgeyBUcmFuc2FjdGlvbkJ1aWxkZXIgfSBmcm9tICcuL3RyYW5zYWN0aW9uQnVpbGRlcic7XG5pbXBvcnQgdXRpbHMgZnJvbSAnLi91dGlscyc7XG5cbmV4cG9ydCBjbGFzcyBXYWxsZXRJbml0aWFsaXphdGlvbkJ1aWxkZXIgZXh0ZW5kcyBUcmFuc2FjdGlvbkJ1aWxkZXIge1xuICBwcm90ZWN0ZWQgX3NpZ25lclF1b3J1bTogbnVtYmVyO1xuICBwcm90ZWN0ZWQgX3NpZ25lckVudHJpZXM6IFNpZ25lckVudHJ5W10gPSBbXTtcbiAgY29uc3RydWN0b3IoX2NvaW5Db25maWc6IFJlYWRvbmx5PENvaW5Db25maWc+KSB7XG4gICAgc3VwZXIoX2NvaW5Db25maWcpO1xuICB9XG5cbiAgcHJvdGVjdGVkIGdldCB0cmFuc2FjdGlvblR5cGUoKTogVHJhbnNhY3Rpb25UeXBlIHtcbiAgICByZXR1cm4gVHJhbnNhY3Rpb25UeXBlLldhbGxldEluaXRpYWxpemF0aW9uO1xuICB9XG5cbiAgcHJvdGVjdGVkIGdldCB4cnBUcmFuc2FjdGlvblR5cGUoKTogJ1NpZ25lckxpc3RTZXQnIHtcbiAgICByZXR1cm4gJ1NpZ25lckxpc3RTZXQnO1xuICB9XG5cbiAgc2lnbmVyUXVvcnVtKHF1b3J1bTogbnVtYmVyKTogVHJhbnNhY3Rpb25CdWlsZGVyIHtcbiAgICBpZiAodHlwZW9mIHF1b3J1bSAhPT0gJ251bWJlcicgfHwgcXVvcnVtIDwgMSkge1xuICAgICAgdGhyb3cgbmV3IEVycm9yKGBxdW9ydW0gbXVzdCBiZSBhIHZhbGlkIG51bWJlciBncmVhdGVyIHRoYW4gMCwgZ290OiAke3F1b3J1bX1gKTtcbiAgICB9XG4gICAgdGhpcy5fc2lnbmVyUXVvcnVtID0gcXVvcnVtO1xuICAgIHJldHVybiB0aGlzO1xuICB9XG5cbiAgc2lnbmVyKHNpZ25lcjogU2lnbmVyRGV0YWlscyk6IFRyYW5zYWN0aW9uQnVpbGRlciB7XG4gICAgaWYgKHRoaXMuX3NpZ25lckVudHJpZXMubGVuZ3RoID4gTUFYX1NJR05FUlMpIHtcbiAgICAgIHRocm93IG5ldyBCdWlsZFRyYW5zYWN0aW9uRXJyb3IoYENhbm5vdCBoYXZlIG1vcmUgdGhhbiAke01BWF9TSUdORVJTfSBzaWduZXJzYCk7XG4gICAgfVxuICAgIHV0aWxzLnZhbGlkYXRlU2lnbmVyKHNpZ25lcik7XG4gICAgdGhpcy5fc2lnbmVyRW50cmllcy5wdXNoKHtcbiAgICAgIFNpZ25lckVudHJ5OiB7IEFjY291bnQ6IHNpZ25lci5hZGRyZXNzLCBTaWduZXJXZWlnaHQ6IHNpZ25lci53ZWlnaHQgfSxcbiAgICB9KTtcbiAgICByZXR1cm4gdGhpcztcbiAgfVxuXG4gIGluaXRCdWlsZGVyKHR4OiBUcmFuc2FjdGlvbik6IHZvaWQge1xuICAgIHN1cGVyLmluaXRCdWlsZGVyKHR4KTtcblxuICAgIGNvbnN0IHsgc2lnbmVyRW50cmllcywgc2lnbmVyUXVvcnVtIH0gPSB0eC50b0pzb24oKTtcbiAgICBpZiAoc2lnbmVyUXVvcnVtKSB7XG4gICAgICB0aGlzLnNpZ25lclF1b3J1bShzaWduZXJRdW9ydW0pO1xuICAgIH1cblxuICAgIGlmIChzaWduZXJFbnRyaWVzPy5sZW5ndGgpIHtcbiAgICAgIHNpZ25lckVudHJpZXMuZm9yRWFjaCgoc2lnbmVyKSA9PlxuICAgICAgICB0aGlzLnNpZ25lcih7XG4gICAgICAgICAgYWRkcmVzczogc2lnbmVyLlNpZ25lckVudHJ5LkFjY291bnQsXG4gICAgICAgICAgd2VpZ2h0OiBzaWduZXIuU2lnbmVyRW50cnkuU2lnbmVyV2VpZ2h0LFxuICAgICAgICB9KVxuICAgICAgKTtcbiAgICB9XG4gIH1cblxuICAvKiogQGluaGVyaXRkb2MgKi9cbiAgcHJvdGVjdGVkIGFzeW5jIGJ1aWxkSW1wbGVtZW50YXRpb24oKTogUHJvbWlzZTxUcmFuc2FjdGlvbj4ge1xuICAgIGlmICghdGhpcy5fc2VuZGVyKSB7XG4gICAgICB0aHJvdyBuZXcgQnVpbGRUcmFuc2FjdGlvbkVycm9yKCdTZW5kZXIgbXVzdCBiZSBzZXQgYmVmb3JlIGJ1aWxkaW5nIHRoZSB0cmFuc2FjdGlvbicpO1xuICAgIH1cbiAgICBpZiAoIXRoaXMuX3NpZ25lclF1b3J1bSB8fCB0aGlzLl9zaWduZXJRdW9ydW0gPCBNSU5fU0lHTkVSX1FVT1JVTSkge1xuICAgICAgdGhyb3cgbmV3IEJ1aWxkVHJhbnNhY3Rpb25FcnJvcignU2lnbmVyIHF1b3J1bSBtdXN0IGJlIHNldCBiZWZvcmUgYnVpbGRpbmcgdGhlIHRyYW5zYWN0aW9uJyk7XG4gICAgfVxuICAgIGlmICghdGhpcy5fc2lnbmVyRW50cmllcykge1xuICAgICAgdGhyb3cgbmV3IEJ1aWxkVHJhbnNhY3Rpb25FcnJvcignU2lnbmVycyBtdXN0IGJlIHNldCBiZWZvcmUgYnVpbGRpbmcgdGhlIHRyYW5zYWN0aW9uJyk7XG4gICAgfVxuXG4gICAgaWYgKHRoaXMuX3NpZ25lckVudHJpZXMubGVuZ3RoIDwgTUlOX1NJR05FUlMgfHwgdGhpcy5fc2lnbmVyRW50cmllcy5sZW5ndGggPiBNQVhfU0lHTkVSUykge1xuICAgICAgdGhyb3cgbmV3IEJ1aWxkVHJhbnNhY3Rpb25FcnJvcihgU2lnbmVycyBtdXN0IGJlIGJldHdlZW4gJHtNSU5fU0lHTkVSU30gYW5kICR7TUFYX1NJR05FUlN9YCk7XG4gICAgfVxuXG4gICAgdGhpcy5fc3BlY2lmaWNGaWVsZHMgPSB7XG4gICAgICBUcmFuc2FjdGlvblR5cGU6IHRoaXMueHJwVHJhbnNhY3Rpb25UeXBlLFxuICAgICAgQWNjb3VudDogdGhpcy5fc2VuZGVyLFxuICAgICAgU2lnbmVyUXVvcnVtOiB0aGlzLl9zaWduZXJRdW9ydW0sXG4gICAgICBTaWduZXJFbnRyaWVzOiB0aGlzLl9zaWduZXJFbnRyaWVzLFxuICAgIH07XG4gICAgcmV0dXJuIGF3YWl0IHN1cGVyLmJ1aWxkSW1wbGVtZW50YXRpb24oKTtcbiAgfVxufVxuIl19
@@ -1 +1 @@
1
- {"version":3,"file":"register.d.ts","sourceRoot":"","sources":["../../src/register.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,sBAAsB,CAAC;AAIjD,eAAO,MAAM,QAAQ,QAAS,SAAS,KAAG,IAGzC,CAAC"}
1
+ {"version":3,"file":"register.d.ts","sourceRoot":"","sources":["../../src/register.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,sBAAsB,CAAC;AAKjD,eAAO,MAAM,QAAQ,QAAS,SAAS,KAAG,IAMzC,CAAC"}
@@ -3,9 +3,13 @@ Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.register = void 0;
4
4
  const txrp_1 = require("./txrp");
5
5
  const xrp_1 = require("./xrp");
6
+ const xrpToken_1 = require("./xrpToken");
6
7
  const register = (sdk) => {
7
8
  sdk.register('xrp', xrp_1.Xrp.createInstance);
8
9
  sdk.register('txrp', txrp_1.Txrp.createInstance);
10
+ xrpToken_1.XrpToken.createTokenConstructors().forEach(({ name, coinConstructor }) => {
11
+ sdk.register(name, coinConstructor);
12
+ });
9
13
  };
10
14
  exports.register = register;
11
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVnaXN0ZXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvcmVnaXN0ZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQ0EsaUNBQThCO0FBQzlCLCtCQUE0QjtBQUVyQixNQUFNLFFBQVEsR0FBRyxDQUFDLEdBQWMsRUFBUSxFQUFFO0lBQy9DLEdBQUcsQ0FBQyxRQUFRLENBQUMsS0FBSyxFQUFFLFNBQUcsQ0FBQyxjQUFjLENBQUMsQ0FBQztJQUN4QyxHQUFHLENBQUMsUUFBUSxDQUFDLE1BQU0sRUFBRSxXQUFJLENBQUMsY0FBYyxDQUFDLENBQUM7QUFDNUMsQ0FBQyxDQUFDO0FBSFcsUUFBQSxRQUFRLFlBR25CIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQml0R29CYXNlIH0gZnJvbSAnQGJpdGdvLWJldGEvc2RrLWNvcmUnO1xuaW1wb3J0IHsgVHhycCB9IGZyb20gJy4vdHhycCc7XG5pbXBvcnQgeyBYcnAgfSBmcm9tICcuL3hycCc7XG5cbmV4cG9ydCBjb25zdCByZWdpc3RlciA9IChzZGs6IEJpdEdvQmFzZSk6IHZvaWQgPT4ge1xuICBzZGsucmVnaXN0ZXIoJ3hycCcsIFhycC5jcmVhdGVJbnN0YW5jZSk7XG4gIHNkay5yZWdpc3RlcigndHhycCcsIFR4cnAuY3JlYXRlSW5zdGFuY2UpO1xufTtcbiJdfQ==
15
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVnaXN0ZXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvcmVnaXN0ZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQ0EsaUNBQThCO0FBQzlCLCtCQUE0QjtBQUM1Qix5Q0FBc0M7QUFFL0IsTUFBTSxRQUFRLEdBQUcsQ0FBQyxHQUFjLEVBQVEsRUFBRTtJQUMvQyxHQUFHLENBQUMsUUFBUSxDQUFDLEtBQUssRUFBRSxTQUFHLENBQUMsY0FBYyxDQUFDLENBQUM7SUFDeEMsR0FBRyxDQUFDLFFBQVEsQ0FBQyxNQUFNLEVBQUUsV0FBSSxDQUFDLGNBQWMsQ0FBQyxDQUFDO0lBQzFDLG1CQUFRLENBQUMsdUJBQXVCLEVBQUUsQ0FBQyxPQUFPLENBQUMsQ0FBQyxFQUFFLElBQUksRUFBRSxlQUFlLEVBQUUsRUFBRSxFQUFFO1FBQ3ZFLEdBQUcsQ0FBQyxRQUFRLENBQUMsSUFBSSxFQUFFLGVBQWUsQ0FBQyxDQUFDO0lBQ3RDLENBQUMsQ0FBQyxDQUFDO0FBQ0wsQ0FBQyxDQUFDO0FBTlcsUUFBQSxRQUFRLFlBTW5CIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQml0R29CYXNlIH0gZnJvbSAnQGJpdGdvLWJldGEvc2RrLWNvcmUnO1xuaW1wb3J0IHsgVHhycCB9IGZyb20gJy4vdHhycCc7XG5pbXBvcnQgeyBYcnAgfSBmcm9tICcuL3hycCc7XG5pbXBvcnQgeyBYcnBUb2tlbiB9IGZyb20gJy4veHJwVG9rZW4nO1xuXG5leHBvcnQgY29uc3QgcmVnaXN0ZXIgPSAoc2RrOiBCaXRHb0Jhc2UpOiB2b2lkID0+IHtcbiAgc2RrLnJlZ2lzdGVyKCd4cnAnLCBYcnAuY3JlYXRlSW5zdGFuY2UpO1xuICBzZGsucmVnaXN0ZXIoJ3R4cnAnLCBUeHJwLmNyZWF0ZUluc3RhbmNlKTtcbiAgWHJwVG9rZW4uY3JlYXRlVG9rZW5Db25zdHJ1Y3RvcnMoKS5mb3JFYWNoKCh7IG5hbWUsIGNvaW5Db25zdHJ1Y3RvciB9KSA9PiB7XG4gICAgc2RrLnJlZ2lzdGVyKG5hbWUsIGNvaW5Db25zdHJ1Y3Rvcik7XG4gIH0pO1xufTtcbiJdfQ==