@bitgo-beta/key-card 0.1.2-alpha.41 → 0.1.2-alpha.411

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,8 +1,41 @@
1
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 () {
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
+ })();
2
35
  Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.generateQrData = void 0;
36
+ exports.generateQrData = generateQrData;
4
37
  const sdk_api_1 = require("@bitgo-beta/sdk-api");
5
- const assert = require("assert");
38
+ const assert = __importStar(require("assert"));
6
39
  function getPubFromKey(key) {
7
40
  switch (key.type) {
8
41
  case 'blsdkg':
@@ -14,6 +47,13 @@ function getPubFromKey(key) {
14
47
  }
15
48
  }
16
49
  function generateUserQrData(userKeychain, userMasterKey) {
50
+ if (userKeychain.reducedEncryptedPrv) {
51
+ return {
52
+ title: 'A: User Key',
53
+ description: 'This is your private key, encrypted with your wallet password.',
54
+ data: userKeychain.reducedEncryptedPrv,
55
+ };
56
+ }
17
57
  if (userKeychain.encryptedPrv) {
18
58
  return {
19
59
  title: 'A: User Key',
@@ -22,7 +62,7 @@ function generateUserQrData(userKeychain, userMasterKey) {
22
62
  };
23
63
  }
24
64
  const pub = getPubFromKey(userKeychain);
25
- assert(pub);
65
+ assert.ok(pub);
26
66
  return {
27
67
  title: 'A: Provided User Key',
28
68
  description: 'This is the public key you provided for your wallet.',
@@ -31,8 +71,14 @@ function generateUserQrData(userKeychain, userMasterKey) {
31
71
  };
32
72
  }
33
73
  function generateBackupQrData(coin, backupKeychain, { backupKeyProvider, backupMasterKey, } = {}) {
34
- var _a;
35
74
  const title = 'B: Backup Key';
75
+ if (backupKeychain.reducedEncryptedPrv) {
76
+ return {
77
+ title,
78
+ description: 'This is your backup private key, encrypted with your wallet password.',
79
+ data: backupKeychain.reducedEncryptedPrv,
80
+ };
81
+ }
36
82
  if (backupKeychain.encryptedPrv) {
37
83
  return {
38
84
  title,
@@ -41,8 +87,8 @@ function generateBackupQrData(coin, backupKeychain, { backupKeyProvider, backupM
41
87
  };
42
88
  }
43
89
  if (backupKeyProvider === 'BitGo Trust' && backupKeychain.type === 'tss') {
44
- const keyShares = (_a = backupKeychain.keyShares) === null || _a === void 0 ? void 0 : _a.filter((keyShare) => keyShare.to === 'backup');
45
- assert((keyShares === null || keyShares === void 0 ? void 0 : keyShares.length) === 2);
90
+ const keyShares = backupKeychain.keyShares?.filter((keyShare) => keyShare.to === 'backup');
91
+ assert.ok(keyShares?.length === 2);
46
92
  return {
47
93
  title: 'B: Backup Key Shares',
48
94
  description: `These are the key shares for ${backupKeyProvider}. If BitGo Inc. goes out of business,\r\n` +
@@ -51,7 +97,7 @@ function generateBackupQrData(coin, backupKeychain, { backupKeyProvider, backupM
51
97
  };
52
98
  }
53
99
  const pub = getPubFromKey(backupKeychain);
54
- assert(pub);
100
+ assert.ok(pub);
55
101
  if (backupKeyProvider) {
56
102
  return {
57
103
  title: 'B: Backup Key',
@@ -69,24 +115,42 @@ function generateBackupQrData(coin, backupKeychain, { backupKeyProvider, backupM
69
115
  }
70
116
  function generateBitGoQrData(bitgoKeychain) {
71
117
  const bitgoData = getPubFromKey(bitgoKeychain);
72
- assert(bitgoData);
118
+ assert.ok(bitgoData);
73
119
  return {
74
120
  title: 'C: BitGo Public Key',
75
121
  description: 'This is the public part of the key that BitGo will use to ' + 'co-sign transactions\r\nwith you on your wallet.',
76
122
  data: bitgoData,
77
123
  };
78
124
  }
79
- function generateQrData({ backupKeychain, backupKeyProvider, backupMasterKey, bitgoKeychain, coin, passcodeEncryptionCode, passphrase, userKeychain, userMasterKey, }) {
125
+ function generateUserMasterPublicKeyQRData(publicKey) {
126
+ return {
127
+ title: 'E: Master User Public Key',
128
+ description: 'This is the public key used to derive the user key for the wallet. This is not stored by BitGo, and may be required for use in recovery scenarios.',
129
+ data: publicKey,
130
+ };
131
+ }
132
+ function generateBackupMasterPublicKeyQRData(publicKey) {
133
+ return {
134
+ title: 'F: Master Backup Public Key',
135
+ description: 'This is the public key used to derive the backup key for the wallet. This is not stored by BitGo, and may be required for use in recovery scenarios.',
136
+ data: publicKey,
137
+ };
138
+ }
139
+ function generateQrData({ backupKeychain, backupKeyProvider, backupMasterKey, bitgoKeychain, coin, passcodeEncryptionCode, passphrase, userKeychain, userMasterKey, userMasterPublicKey, backupMasterPublicKey, }) {
80
140
  const qrData = {
81
141
  user: generateUserQrData(userKeychain, userMasterKey),
142
+ userMasterPublicKey: userMasterPublicKey ? generateUserMasterPublicKeyQRData(userMasterPublicKey) : undefined,
82
143
  backup: generateBackupQrData(coin, backupKeychain, {
83
144
  backupKeyProvider,
84
145
  backupMasterKey,
85
146
  }),
147
+ backupMasterPublicKey: backupMasterPublicKey
148
+ ? generateBackupMasterPublicKeyQRData(backupMasterPublicKey)
149
+ : undefined,
86
150
  bitgo: generateBitGoQrData(bitgoKeychain),
87
151
  };
88
152
  if (passphrase && passcodeEncryptionCode) {
89
- const encryptedWalletPasscode = sdk_api_1.encrypt(passcodeEncryptionCode, passphrase);
153
+ const encryptedWalletPasscode = (0, sdk_api_1.encrypt)(passcodeEncryptionCode, passphrase);
90
154
  qrData.passcode = {
91
155
  title: 'D: Encrypted wallet Password',
92
156
  description: 'This is the wallet password, encrypted client-side with a key held by BitGo.',
@@ -95,5 +159,4 @@ function generateQrData({ backupKeychain, backupKeyProvider, backupMasterKey, bi
95
159
  }
96
160
  return qrData;
97
161
  }
98
- exports.generateQrData = generateQrData;
99
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"generateQrData.js","sourceRoot":"","sources":["../../src/generateQrData.ts"],"names":[],"mappings":"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","sourcesContent":["import { BaseCoin } from '@bitgo-beta/statics';\nimport { Keychain } from '@bitgo-beta/sdk-core';\nimport { encrypt } from '@bitgo-beta/sdk-api';\nimport * as assert from 'assert';\n\nexport interface GenerateQrDataParams {\n  // The backup keychain as it is returned from the BitGo API upon creation\n  backupKeychain: Keychain;\n  // The name of the 3rd party provider of the backup key if neither the user nor BitGo stores it\n  backupKeyProvider?: string;\n  // The key id of the backup key, only used for cold keys\n  backupMasterKey?: string;\n  // The BitGo keychain as it is returned from the BitGo API upon creation\n  bitgoKeychain: Keychain;\n  // The coin of the wallet that was/ is about to be created\n  coin: Readonly<BaseCoin>;\n  // A code that can be used to encrypt the wallet password to.\n  // If both the passphrase and passcodeEncryptionCode are passed, then this code encrypts the passphrase with the\n  // passcodeEncryptionCode and puts the result into Box D. Allows recoveries of the wallet password.\n  passcodeEncryptionCode?: string;\n  // The wallet password\n  // If both the passphrase and passcodeEncryptionCode are passed, then this code encrypts the passphrase with the\n  // passcodeEncryptionCode and puts the result into Box D. Allows recoveries of the wallet password.\n  passphrase?: string;\n  // The user keychain as it is returned from the BitGo API upon creation\n  userKeychain: Keychain;\n  // The key id of the user key, only used for cold keys\n  userMasterKey?: string;\n}\n\ninterface QrDataEntry {\n  data: string;\n  description: string;\n  title: string;\n  publicMasterKey?: string;\n}\n\nexport interface QrData {\n  backup?: QrDataEntry;\n  bitgo?: QrDataEntry;\n  passcode?: QrDataEntry;\n  user: QrDataEntry;\n}\n\nfunction getPubFromKey(key: Keychain): string | undefined {\n  switch (key.type) {\n    case 'blsdkg':\n      return key.commonPub;\n    case 'tss':\n      return key.commonKeychain;\n    case 'independent':\n      return key.pub;\n  }\n}\n\nfunction generateUserQrData(userKeychain: Keychain, userMasterKey?: string): QrDataEntry {\n  if (userKeychain.encryptedPrv) {\n    return {\n      title: 'A: User Key',\n      description: 'This is your private key, encrypted with your wallet password.',\n      data: userKeychain.encryptedPrv,\n    };\n  }\n\n  const pub = getPubFromKey(userKeychain);\n  assert(pub);\n\n  return {\n    title: 'A: Provided User Key',\n    description: 'This is the public key you provided for your wallet.',\n    data: pub,\n    publicMasterKey: userMasterKey,\n  };\n}\n\nfunction generateBackupQrData(\n  coin: Readonly<BaseCoin>,\n  backupKeychain: Keychain,\n  {\n    backupKeyProvider,\n    backupMasterKey,\n  }: {\n    backupKeyProvider?: string;\n    backupMasterKey?: string;\n  } = {}\n): QrDataEntry {\n  const title = 'B: Backup Key';\n  if (backupKeychain.encryptedPrv) {\n    return {\n      title,\n      description: 'This is your backup private key, encrypted with your wallet password.',\n      data: backupKeychain.encryptedPrv,\n    };\n  }\n\n  if (backupKeyProvider === 'BitGo Trust' && backupKeychain.type === 'tss') {\n    const keyShares = backupKeychain.keyShares?.filter((keyShare) => keyShare.to === 'backup');\n    assert(keyShares?.length === 2);\n    return {\n      title: 'B: Backup Key Shares',\n      description:\n        `These are the key shares for ${backupKeyProvider}. If BitGo Inc. goes out of business,\\r\\n` +\n        `contact ${backupKeyProvider} and they will help you recover your funds.`,\n      data: JSON.stringify(keyShares),\n    };\n  }\n\n  const pub = getPubFromKey(backupKeychain);\n  assert(pub);\n\n  if (backupKeyProvider) {\n    return {\n      title: 'B: Backup Key',\n      description:\n        `This is the public key held at ${backupKeyProvider}, an ${coin.name} recovery service. ` +\n        `If you lose\\r\\nyour key, ${backupKeyProvider} will be able to sign transactions to recover funds.`,\n      data: pub,\n    };\n  }\n\n  return {\n    title: 'B: Provided Backup Key',\n    description: 'This is the public key you provided for your wallet.',\n    data: pub,\n    publicMasterKey: backupMasterKey,\n  };\n}\n\nfunction generateBitGoQrData(bitgoKeychain: Keychain): QrDataEntry {\n  const bitgoData = getPubFromKey(bitgoKeychain);\n  assert(bitgoData);\n\n  return {\n    title: 'C: BitGo Public Key',\n    description:\n      'This is the public part of the key that BitGo will use to ' + 'co-sign transactions\\r\\nwith you on your wallet.',\n    data: bitgoData,\n  };\n}\n\nexport function generateQrData({\n  backupKeychain,\n  backupKeyProvider,\n  backupMasterKey,\n  bitgoKeychain,\n  coin,\n  passcodeEncryptionCode,\n  passphrase,\n  userKeychain,\n  userMasterKey,\n}: GenerateQrDataParams): QrData {\n  const qrData: QrData = {\n    user: generateUserQrData(userKeychain, userMasterKey),\n    backup: generateBackupQrData(coin, backupKeychain, {\n      backupKeyProvider,\n      backupMasterKey,\n    }),\n    bitgo: generateBitGoQrData(bitgoKeychain),\n  };\n\n  if (passphrase && passcodeEncryptionCode) {\n    const encryptedWalletPasscode = encrypt(passcodeEncryptionCode, passphrase);\n\n    qrData.passcode = {\n      title: 'D: Encrypted wallet Password',\n      description: 'This is the wallet password, encrypted client-side with a key held by BitGo.',\n      data: encryptedWalletPasscode,\n    };\n  }\n\n  return qrData;\n}\n"]}
162
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"generateQrData.js","sourceRoot":"","sources":["../../src/generateQrData.ts"],"names":[],"mappings":"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","sourcesContent":["import { BaseCoin } from '@bitgo-beta/statics';\nimport { Keychain } from '@bitgo-beta/sdk-core';\nimport { encrypt } from '@bitgo-beta/sdk-api';\nimport * as assert from 'assert';\nimport { GenerateQrDataParams, MasterPublicKeyQrDataEntry, QrData, QrDataEntry } from './types';\n\nfunction getPubFromKey(key: Keychain): string | undefined {\n  switch (key.type) {\n    case 'blsdkg':\n      return key.commonPub;\n    case 'tss':\n      return key.commonKeychain;\n    case 'independent':\n      return key.pub;\n  }\n}\n\nfunction generateUserQrData(userKeychain: Keychain, userMasterKey?: string): QrDataEntry {\n  if (userKeychain.reducedEncryptedPrv) {\n    return {\n      title: 'A: User Key',\n      description: 'This is your private key, encrypted with your wallet password.',\n      data: userKeychain.reducedEncryptedPrv,\n    };\n  }\n  if (userKeychain.encryptedPrv) {\n    return {\n      title: 'A: User Key',\n      description: 'This is your private key, encrypted with your wallet password.',\n      data: userKeychain.encryptedPrv,\n    };\n  }\n\n  const pub = getPubFromKey(userKeychain);\n  assert.ok(pub);\n\n  return {\n    title: 'A: Provided User Key',\n    description: 'This is the public key you provided for your wallet.',\n    data: pub,\n    publicMasterKey: userMasterKey,\n  };\n}\n\nfunction generateBackupQrData(\n  coin: Readonly<BaseCoin>,\n  backupKeychain: Keychain,\n  {\n    backupKeyProvider,\n    backupMasterKey,\n  }: {\n    backupKeyProvider?: string;\n    backupMasterKey?: string;\n  } = {}\n): QrDataEntry {\n  const title = 'B: Backup Key';\n  if (backupKeychain.reducedEncryptedPrv) {\n    return {\n      title,\n      description: 'This is your backup private key, encrypted with your wallet password.',\n      data: backupKeychain.reducedEncryptedPrv,\n    };\n  }\n  if (backupKeychain.encryptedPrv) {\n    return {\n      title,\n      description: 'This is your backup private key, encrypted with your wallet password.',\n      data: backupKeychain.encryptedPrv,\n    };\n  }\n\n  if (backupKeyProvider === 'BitGo Trust' && backupKeychain.type === 'tss') {\n    const keyShares = backupKeychain.keyShares?.filter((keyShare) => keyShare.to === 'backup');\n    assert.ok(keyShares?.length === 2);\n    return {\n      title: 'B: Backup Key Shares',\n      description:\n        `These are the key shares for ${backupKeyProvider}. If BitGo Inc. goes out of business,\\r\\n` +\n        `contact ${backupKeyProvider} and they will help you recover your funds.`,\n      data: JSON.stringify(keyShares),\n    };\n  }\n\n  const pub = getPubFromKey(backupKeychain);\n  assert.ok(pub);\n\n  if (backupKeyProvider) {\n    return {\n      title: 'B: Backup Key',\n      description:\n        `This is the public key held at ${backupKeyProvider}, an ${coin.name} recovery service. ` +\n        `If you lose\\r\\nyour key, ${backupKeyProvider} will be able to sign transactions to recover funds.`,\n      data: pub,\n    };\n  }\n\n  return {\n    title: 'B: Provided Backup Key',\n    description: 'This is the public key you provided for your wallet.',\n    data: pub,\n    publicMasterKey: backupMasterKey,\n  };\n}\n\nfunction generateBitGoQrData(bitgoKeychain: Keychain): QrDataEntry {\n  const bitgoData = getPubFromKey(bitgoKeychain);\n  assert.ok(bitgoData);\n\n  return {\n    title: 'C: BitGo Public Key',\n    description:\n      'This is the public part of the key that BitGo will use to ' + 'co-sign transactions\\r\\nwith you on your wallet.',\n    data: bitgoData,\n  };\n}\n\nfunction generateUserMasterPublicKeyQRData(publicKey: string): MasterPublicKeyQrDataEntry {\n  return {\n    title: 'E: Master User Public Key',\n    description:\n      'This is the public key used to derive the user key for the wallet. This is not stored by BitGo, and may be required for use in recovery scenarios.',\n    data: publicKey,\n  };\n}\n\nfunction generateBackupMasterPublicKeyQRData(publicKey: string): MasterPublicKeyQrDataEntry {\n  return {\n    title: 'F: Master Backup Public Key',\n    description:\n      'This is the public key used to derive the backup key for the wallet. This is not stored by BitGo, and may be required for use in recovery scenarios.',\n    data: publicKey,\n  };\n}\n\nexport function generateQrData({\n  backupKeychain,\n  backupKeyProvider,\n  backupMasterKey,\n  bitgoKeychain,\n  coin,\n  passcodeEncryptionCode,\n  passphrase,\n  userKeychain,\n  userMasterKey,\n  userMasterPublicKey,\n  backupMasterPublicKey,\n}: GenerateQrDataParams): QrData {\n  const qrData: QrData = {\n    user: generateUserQrData(userKeychain, userMasterKey),\n    userMasterPublicKey: userMasterPublicKey ? generateUserMasterPublicKeyQRData(userMasterPublicKey) : undefined,\n    backup: generateBackupQrData(coin, backupKeychain, {\n      backupKeyProvider,\n      backupMasterKey,\n    }),\n    backupMasterPublicKey: backupMasterPublicKey\n      ? generateBackupMasterPublicKeyQRData(backupMasterPublicKey)\n      : undefined,\n    bitgo: generateBitGoQrData(bitgoKeychain),\n  };\n\n  if (passphrase && passcodeEncryptionCode) {\n    const encryptedWalletPasscode = encrypt(passcodeEncryptionCode, passphrase);\n\n    qrData.passcode = {\n      title: 'D: Encrypted wallet Password',\n      description: 'This is the wallet password, encrypted client-side with a key held by BitGo.',\n      data: encryptedWalletPasscode,\n    };\n  }\n\n  return qrData;\n}\n"]}
@@ -1,12 +1,8 @@
1
- import { GenerateQrDataParams } from './generateQrData';
1
+ import { GenerateKeycardParams } from './types';
2
2
  export * from './drawKeycard';
3
3
  export * from './faq';
4
4
  export * from './generateQrData';
5
5
  export * from './utils';
6
- export interface GenerateKeycardParams extends GenerateQrDataParams {
7
- activationCode?: string;
8
- keyCardImage?: HTMLImageElement;
9
- walletLabel: string;
10
- }
6
+ export * from './types';
11
7
  export declare function generateKeycard(params: GenerateKeycardParams): Promise<void>;
12
8
  //# sourceMappingURL=index.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAkB,oBAAoB,EAAE,MAAM,kBAAkB,CAAC;AAIxE,cAAc,eAAe,CAAC;AAC9B,cAAc,OAAO,CAAC;AACtB,cAAc,kBAAkB,CAAC;AACjC,cAAc,SAAS,CAAC;AAExB,MAAM,WAAW,qBAAsB,SAAQ,oBAAoB;IACjE,cAAc,CAAC,EAAE,MAAM,CAAC;IACxB,YAAY,CAAC,EAAE,gBAAgB,CAAC;IAChC,WAAW,EAAE,MAAM,CAAC;CACrB;AAED,wBAAsB,eAAe,CAAC,MAAM,EAAE,qBAAqB,GAAG,OAAO,CAAC,IAAI,CAAC,CAMlF"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,qBAAqB,EAAE,MAAM,SAAS,CAAC;AAEhD,cAAc,eAAe,CAAC;AAC9B,cAAc,OAAO,CAAC;AACtB,cAAc,kBAAkB,CAAC;AACjC,cAAc,SAAS,CAAC;AACxB,cAAc,SAAS,CAAC;AAExB,wBAAsB,eAAe,CAAC,MAAM,EAAE,qBAAqB,GAAG,OAAO,CAAC,IAAI,CAAC,CAelF"}
package/dist/src/index.js CHANGED
@@ -1,7 +1,11 @@
1
1
  "use strict";
2
2
  var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
3
  if (k2 === undefined) k2 = k;
4
- Object.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];
@@ -10,20 +14,32 @@ var __exportStar = (this && this.__exportStar) || function(m, exports) {
10
14
  for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
11
15
  };
12
16
  Object.defineProperty(exports, "__esModule", { value: true });
13
- exports.generateKeycard = void 0;
17
+ exports.generateKeycard = generateKeycard;
14
18
  const generateQrData_1 = require("./generateQrData");
15
19
  const faq_1 = require("./faq");
16
20
  const drawKeycard_1 = require("./drawKeycard");
21
+ const generateParamsForKeyCreation_1 = require("./generateParamsForKeyCreation");
17
22
  __exportStar(require("./drawKeycard"), exports);
18
23
  __exportStar(require("./faq"), exports);
19
24
  __exportStar(require("./generateQrData"), exports);
20
25
  __exportStar(require("./utils"), exports);
26
+ __exportStar(require("./types"), exports);
21
27
  async function generateKeycard(params) {
22
- const questions = faq_1.generateFaq(params.coin.fullName);
23
- const qrData = generateQrData_1.generateQrData(params);
24
- const keycard = await drawKeycard_1.drawKeycard({ ...params, questions, qrData });
25
- // Save the PDF on the user's browser
26
- keycard.save(`BitGo Keycard for ${params.walletLabel}.pdf`);
28
+ if ('coin' in params) {
29
+ const questions = (0, faq_1.generateFaq)(params.coin.fullName);
30
+ const qrData = (0, generateQrData_1.generateQrData)(params);
31
+ const keycard = await (0, drawKeycard_1.drawKeycard)({ ...params, questions, qrData });
32
+ const label = params.walletLabel || params.coin.fullName;
33
+ keycard.save(`BitGo Keycard for ${label}.pdf`);
34
+ }
35
+ else if ('curve' in params) {
36
+ const data = (0, generateParamsForKeyCreation_1.generateParamsForKeyCreation)(params);
37
+ const keycard = await (0, drawKeycard_1.drawKeycard)(data);
38
+ const label = params.walletLabel || params.curve;
39
+ keycard.save(`BitGo Keycard for ${label}.pdf`);
40
+ }
41
+ else {
42
+ throw new Error('Either curve or coin must be provided');
43
+ }
27
44
  }
28
- exports.generateKeycard = generateKeycard;
29
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7OztBQUFBLHFEQUF3RTtBQUN4RSwrQkFBb0M7QUFDcEMsK0NBQTRDO0FBRTVDLGdEQUE4QjtBQUM5Qix3Q0FBc0I7QUFDdEIsbURBQWlDO0FBQ2pDLDBDQUF3QjtBQVFqQixLQUFLLFVBQVUsZUFBZSxDQUFDLE1BQTZCO0lBQ2pFLE1BQU0sU0FBUyxHQUFHLGlCQUFXLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxRQUFRLENBQUMsQ0FBQztJQUNwRCxNQUFNLE1BQU0sR0FBRywrQkFBYyxDQUFDLE1BQU0sQ0FBQyxDQUFDO0lBQ3RDLE1BQU0sT0FBTyxHQUFHLE1BQU0seUJBQVcsQ0FBQyxFQUFFLEdBQUcsTUFBTSxFQUFFLFNBQVMsRUFBRSxNQUFNLEVBQUUsQ0FBQyxDQUFDO0lBQ3BFLHFDQUFxQztJQUNyQyxPQUFPLENBQUMsSUFBSSxDQUFDLHFCQUFxQixNQUFNLENBQUMsV0FBVyxNQUFNLENBQUMsQ0FBQztBQUM5RCxDQUFDO0FBTkQsMENBTUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBnZW5lcmF0ZVFyRGF0YSwgR2VuZXJhdGVRckRhdGFQYXJhbXMgfSBmcm9tICcuL2dlbmVyYXRlUXJEYXRhJztcbmltcG9ydCB7IGdlbmVyYXRlRmFxIH0gZnJvbSAnLi9mYXEnO1xuaW1wb3J0IHsgZHJhd0tleWNhcmQgfSBmcm9tICcuL2RyYXdLZXljYXJkJztcblxuZXhwb3J0ICogZnJvbSAnLi9kcmF3S2V5Y2FyZCc7XG5leHBvcnQgKiBmcm9tICcuL2ZhcSc7XG5leHBvcnQgKiBmcm9tICcuL2dlbmVyYXRlUXJEYXRhJztcbmV4cG9ydCAqIGZyb20gJy4vdXRpbHMnO1xuXG5leHBvcnQgaW50ZXJmYWNlIEdlbmVyYXRlS2V5Y2FyZFBhcmFtcyBleHRlbmRzIEdlbmVyYXRlUXJEYXRhUGFyYW1zIHtcbiAgYWN0aXZhdGlvbkNvZGU/OiBzdHJpbmc7XG4gIGtleUNhcmRJbWFnZT86IEhUTUxJbWFnZUVsZW1lbnQ7XG4gIHdhbGxldExhYmVsOiBzdHJpbmc7XG59XG5cbmV4cG9ydCBhc3luYyBmdW5jdGlvbiBnZW5lcmF0ZUtleWNhcmQocGFyYW1zOiBHZW5lcmF0ZUtleWNhcmRQYXJhbXMpOiBQcm9taXNlPHZvaWQ+IHtcbiAgY29uc3QgcXVlc3Rpb25zID0gZ2VuZXJhdGVGYXEocGFyYW1zLmNvaW4uZnVsbE5hbWUpO1xuICBjb25zdCBxckRhdGEgPSBnZW5lcmF0ZVFyRGF0YShwYXJhbXMpO1xuICBjb25zdCBrZXljYXJkID0gYXdhaXQgZHJhd0tleWNhcmQoeyAuLi5wYXJhbXMsIHF1ZXN0aW9ucywgcXJEYXRhIH0pO1xuICAvLyBTYXZlIHRoZSBQREYgb24gdGhlIHVzZXIncyBicm93c2VyXG4gIGtleWNhcmQuc2F2ZShgQml0R28gS2V5Y2FyZCBmb3IgJHtwYXJhbXMud2FsbGV0TGFiZWx9LnBkZmApO1xufVxuIl19
45
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7OztBQVlBLDBDQWVDO0FBM0JELHFEQUFrRDtBQUNsRCwrQkFBb0M7QUFDcEMsK0NBQTRDO0FBQzVDLGlGQUE4RTtBQUc5RSxnREFBOEI7QUFDOUIsd0NBQXNCO0FBQ3RCLG1EQUFpQztBQUNqQywwQ0FBd0I7QUFDeEIsMENBQXdCO0FBRWpCLEtBQUssVUFBVSxlQUFlLENBQUMsTUFBNkI7SUFDakUsSUFBSSxNQUFNLElBQUksTUFBTSxFQUFFLENBQUM7UUFDckIsTUFBTSxTQUFTLEdBQUcsSUFBQSxpQkFBVyxFQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFDLENBQUM7UUFDcEQsTUFBTSxNQUFNLEdBQUcsSUFBQSwrQkFBYyxFQUFDLE1BQU0sQ0FBQyxDQUFDO1FBQ3RDLE1BQU0sT0FBTyxHQUFHLE1BQU0sSUFBQSx5QkFBVyxFQUFDLEVBQUUsR0FBRyxNQUFNLEVBQUUsU0FBUyxFQUFFLE1BQU0sRUFBRSxDQUFDLENBQUM7UUFDcEUsTUFBTSxLQUFLLEdBQUcsTUFBTSxDQUFDLFdBQVcsSUFBSSxNQUFNLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBQztRQUN6RCxPQUFPLENBQUMsSUFBSSxDQUFDLHFCQUFxQixLQUFLLE1BQU0sQ0FBQyxDQUFDO0lBQ2pELENBQUM7U0FBTSxJQUFJLE9BQU8sSUFBSSxNQUFNLEVBQUUsQ0FBQztRQUM3QixNQUFNLElBQUksR0FBRyxJQUFBLDJEQUE0QixFQUFDLE1BQU0sQ0FBQyxDQUFDO1FBQ2xELE1BQU0sT0FBTyxHQUFHLE1BQU0sSUFBQSx5QkFBVyxFQUFDLElBQUksQ0FBQyxDQUFDO1FBQ3hDLE1BQU0sS0FBSyxHQUFHLE1BQU0sQ0FBQyxXQUFXLElBQUksTUFBTSxDQUFDLEtBQUssQ0FBQztRQUNqRCxPQUFPLENBQUMsSUFBSSxDQUFDLHFCQUFxQixLQUFLLE1BQU0sQ0FBQyxDQUFDO0lBQ2pELENBQUM7U0FBTSxDQUFDO1FBQ04sTUFBTSxJQUFJLEtBQUssQ0FBQyx1Q0FBdUMsQ0FBQyxDQUFDO0lBQzNELENBQUM7QUFDSCxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgZ2VuZXJhdGVRckRhdGEgfSBmcm9tICcuL2dlbmVyYXRlUXJEYXRhJztcbmltcG9ydCB7IGdlbmVyYXRlRmFxIH0gZnJvbSAnLi9mYXEnO1xuaW1wb3J0IHsgZHJhd0tleWNhcmQgfSBmcm9tICcuL2RyYXdLZXljYXJkJztcbmltcG9ydCB7IGdlbmVyYXRlUGFyYW1zRm9yS2V5Q3JlYXRpb24gfSBmcm9tICcuL2dlbmVyYXRlUGFyYW1zRm9yS2V5Q3JlYXRpb24nO1xuaW1wb3J0IHsgR2VuZXJhdGVLZXljYXJkUGFyYW1zIH0gZnJvbSAnLi90eXBlcyc7XG5cbmV4cG9ydCAqIGZyb20gJy4vZHJhd0tleWNhcmQnO1xuZXhwb3J0ICogZnJvbSAnLi9mYXEnO1xuZXhwb3J0ICogZnJvbSAnLi9nZW5lcmF0ZVFyRGF0YSc7XG5leHBvcnQgKiBmcm9tICcuL3V0aWxzJztcbmV4cG9ydCAqIGZyb20gJy4vdHlwZXMnO1xuXG5leHBvcnQgYXN5bmMgZnVuY3Rpb24gZ2VuZXJhdGVLZXljYXJkKHBhcmFtczogR2VuZXJhdGVLZXljYXJkUGFyYW1zKTogUHJvbWlzZTx2b2lkPiB7XG4gIGlmICgnY29pbicgaW4gcGFyYW1zKSB7XG4gICAgY29uc3QgcXVlc3Rpb25zID0gZ2VuZXJhdGVGYXEocGFyYW1zLmNvaW4uZnVsbE5hbWUpO1xuICAgIGNvbnN0IHFyRGF0YSA9IGdlbmVyYXRlUXJEYXRhKHBhcmFtcyk7XG4gICAgY29uc3Qga2V5Y2FyZCA9IGF3YWl0IGRyYXdLZXljYXJkKHsgLi4ucGFyYW1zLCBxdWVzdGlvbnMsIHFyRGF0YSB9KTtcbiAgICBjb25zdCBsYWJlbCA9IHBhcmFtcy53YWxsZXRMYWJlbCB8fCBwYXJhbXMuY29pbi5mdWxsTmFtZTtcbiAgICBrZXljYXJkLnNhdmUoYEJpdEdvIEtleWNhcmQgZm9yICR7bGFiZWx9LnBkZmApO1xuICB9IGVsc2UgaWYgKCdjdXJ2ZScgaW4gcGFyYW1zKSB7XG4gICAgY29uc3QgZGF0YSA9IGdlbmVyYXRlUGFyYW1zRm9yS2V5Q3JlYXRpb24ocGFyYW1zKTtcbiAgICBjb25zdCBrZXljYXJkID0gYXdhaXQgZHJhd0tleWNhcmQoZGF0YSk7XG4gICAgY29uc3QgbGFiZWwgPSBwYXJhbXMud2FsbGV0TGFiZWwgfHwgcGFyYW1zLmN1cnZlO1xuICAgIGtleWNhcmQuc2F2ZShgQml0R28gS2V5Y2FyZCBmb3IgJHtsYWJlbH0ucGRmYCk7XG4gIH0gZWxzZSB7XG4gICAgdGhyb3cgbmV3IEVycm9yKCdFaXRoZXIgY3VydmUgb3IgY29pbiBtdXN0IGJlIHByb3ZpZGVkJyk7XG4gIH1cbn1cbiJdfQ==
@@ -0,0 +1,60 @@
1
+ import { Keychain } from '@bitgo-beta/sdk-core';
2
+ import { BaseCoin, KeyCurve } from '@bitgo-beta/statics';
3
+ export interface GenerateQrDataBaseParams {
4
+ activationCode?: string;
5
+ keyCardImage?: HTMLImageElement;
6
+ walletLabel: string;
7
+ }
8
+ export interface GenerateQrDataForKeychainParams {
9
+ bitgoKeychain: Keychain;
10
+ curve: KeyCurve;
11
+ }
12
+ export interface GenerateQrDataParams {
13
+ backupKeychain: Keychain;
14
+ backupKeyProvider?: string;
15
+ backupMasterKey?: string;
16
+ /**
17
+ * @description The key used to derive the backup key using {@link backupMasterKey} as the seed.
18
+ */
19
+ backupMasterPublicKey?: string;
20
+ bitgoKeychain: Keychain;
21
+ coin: Readonly<BaseCoin>;
22
+ passcodeEncryptionCode?: string;
23
+ passphrase?: string;
24
+ userKeychain: Keychain;
25
+ userMasterKey?: string;
26
+ /**
27
+ * @description The key used to derive the user key using {@link userMasterKey} as the seed.
28
+ */
29
+ userMasterPublicKey?: string;
30
+ }
31
+ export type GenerateKeycardParams = GenerateQrDataBaseParams & (GenerateQrDataForKeychainParams | GenerateQrDataParams);
32
+ export interface IDrawKeyCard {
33
+ activationCode?: string;
34
+ keyCardImage?: HTMLImageElement;
35
+ qrData: QrData;
36
+ questions: FAQ[];
37
+ walletLabel?: string;
38
+ curve?: KeyCurve;
39
+ }
40
+ export interface FAQ {
41
+ question: string;
42
+ answer: string[];
43
+ }
44
+ export interface QrDataEntry {
45
+ data: string;
46
+ description: string;
47
+ title: string;
48
+ publicMasterKey?: string;
49
+ }
50
+ export type MasterPublicKeyQrDataEntry = Omit<QrDataEntry, 'publicMasterKey'>;
51
+ export interface QrData {
52
+ backup?: QrDataEntry;
53
+ backupMasterPublicKey?: MasterPublicKeyQrDataEntry;
54
+ bitgo?: QrDataEntry;
55
+ passcode?: QrDataEntry;
56
+ curve?: KeyCurve;
57
+ user: QrDataEntry;
58
+ userMasterPublicKey?: MasterPublicKeyQrDataEntry;
59
+ }
60
+ //# sourceMappingURL=types.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/types.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,sBAAsB,CAAC;AAChD,OAAO,EAAE,QAAQ,EAAE,QAAQ,EAAE,MAAM,qBAAqB,CAAC;AAEzD,MAAM,WAAW,wBAAwB;IACvC,cAAc,CAAC,EAAE,MAAM,CAAC;IACxB,YAAY,CAAC,EAAE,gBAAgB,CAAC;IAChC,WAAW,EAAE,MAAM,CAAC;CACrB;AAED,MAAM,WAAW,+BAA+B;IAE9C,aAAa,EAAE,QAAQ,CAAC;IAExB,KAAK,EAAE,QAAQ,CAAC;CACjB;AAED,MAAM,WAAW,oBAAoB;IAEnC,cAAc,EAAE,QAAQ,CAAC;IAEzB,iBAAiB,CAAC,EAAE,MAAM,CAAC;IAE3B,eAAe,CAAC,EAAE,MAAM,CAAC;IACzB;;OAEG;IACH,qBAAqB,CAAC,EAAE,MAAM,CAAC;IAE/B,aAAa,EAAE,QAAQ,CAAC;IAExB,IAAI,EAAE,QAAQ,CAAC,QAAQ,CAAC,CAAC;IAIzB,sBAAsB,CAAC,EAAE,MAAM,CAAC;IAIhC,UAAU,CAAC,EAAE,MAAM,CAAC;IAEpB,YAAY,EAAE,QAAQ,CAAC;IAEvB,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB;;OAEG;IACH,mBAAmB,CAAC,EAAE,MAAM,CAAC;CAC9B;AAED,MAAM,MAAM,qBAAqB,GAAG,wBAAwB,GAAG,CAAC,+BAA+B,GAAG,oBAAoB,CAAC,CAAC;AAExH,MAAM,WAAW,YAAY;IAC3B,cAAc,CAAC,EAAE,MAAM,CAAC;IACxB,YAAY,CAAC,EAAE,gBAAgB,CAAC;IAChC,MAAM,EAAE,MAAM,CAAC;IACf,SAAS,EAAE,GAAG,EAAE,CAAC;IACjB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,KAAK,CAAC,EAAE,QAAQ,CAAC;CAClB;AAED,MAAM,WAAW,GAAG;IAClB,QAAQ,EAAE,MAAM,CAAC;IAEjB,MAAM,EAAE,MAAM,EAAE,CAAC;CAClB;AAED,MAAM,WAAW,WAAW;IAC1B,IAAI,EAAE,MAAM,CAAC;IACb,WAAW,EAAE,MAAM,CAAC;IACpB,KAAK,EAAE,MAAM,CAAC;IACd,eAAe,CAAC,EAAE,MAAM,CAAC;CAC1B;AAED,MAAM,MAAM,0BAA0B,GAAG,IAAI,CAAC,WAAW,EAAE,iBAAiB,CAAC,CAAC;AAE9E,MAAM,WAAW,MAAM;IACrB,MAAM,CAAC,EAAE,WAAW,CAAC;IACrB,qBAAqB,CAAC,EAAE,0BAA0B,CAAC;IACnD,KAAK,CAAC,EAAE,WAAW,CAAC;IACpB,QAAQ,CAAC,EAAE,WAAW,CAAC;IACvB,KAAK,CAAC,EAAE,QAAQ,CAAC;IACjB,IAAI,EAAE,WAAW,CAAC;IAClB,mBAAmB,CAAC,EAAE,0BAA0B,CAAC;CAClD"}
@@ -0,0 +1,3 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvdHlwZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEtleWNoYWluIH0gZnJvbSAnQGJpdGdvLWJldGEvc2RrLWNvcmUnO1xuaW1wb3J0IHsgQmFzZUNvaW4sIEtleUN1cnZlIH0gZnJvbSAnQGJpdGdvLWJldGEvc3RhdGljcyc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgR2VuZXJhdGVRckRhdGFCYXNlUGFyYW1zIHtcbiAgYWN0aXZhdGlvbkNvZGU/OiBzdHJpbmc7XG4gIGtleUNhcmRJbWFnZT86IEhUTUxJbWFnZUVsZW1lbnQ7XG4gIHdhbGxldExhYmVsOiBzdHJpbmc7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgR2VuZXJhdGVRckRhdGFGb3JLZXljaGFpblBhcmFtcyB7XG4gIC8vIFRoZSBCaXRHbyBrZXljaGFpbiBhcyBpdCBpcyByZXR1cm5lZCBmcm9tIHRoZSBCaXRHbyBBUEkgdXBvbiBjcmVhdGlvblxuICBiaXRnb0tleWNoYWluOiBLZXljaGFpbjtcbiAgLy8gVGhlIGN1cnZlIHVzZWQgZm9yIHRoZSBrZXlcbiAgY3VydmU6IEtleUN1cnZlO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIEdlbmVyYXRlUXJEYXRhUGFyYW1zIHtcbiAgLy8gVGhlIGJhY2t1cCBrZXljaGFpbiBhcyBpdCBpcyByZXR1cm5lZCBmcm9tIHRoZSBCaXRHbyBBUEkgdXBvbiBjcmVhdGlvblxuICBiYWNrdXBLZXljaGFpbjogS2V5Y2hhaW47XG4gIC8vIFRoZSBuYW1lIG9mIHRoZSAzcmQgcGFydHkgcHJvdmlkZXIgb2YgdGhlIGJhY2t1cCBrZXkgaWYgbmVpdGhlciB0aGUgdXNlciBub3IgQml0R28gc3RvcmVzIGl0XG4gIGJhY2t1cEtleVByb3ZpZGVyPzogc3RyaW5nO1xuICAvLyBUaGUga2V5IGlkIG9mIHRoZSBiYWNrdXAga2V5LCBvbmx5IHVzZWQgZm9yIGNvbGQga2V5c1xuICBiYWNrdXBNYXN0ZXJLZXk/OiBzdHJpbmc7XG4gIC8qKlxuICAgKiBAZGVzY3JpcHRpb24gVGhlIGtleSB1c2VkIHRvIGRlcml2ZSB0aGUgYmFja3VwIGtleSB1c2luZyB7QGxpbmsgYmFja3VwTWFzdGVyS2V5fSBhcyB0aGUgc2VlZC5cbiAgICovXG4gIGJhY2t1cE1hc3RlclB1YmxpY0tleT86IHN0cmluZztcbiAgLy8gVGhlIEJpdEdvIGtleWNoYWluIGFzIGl0IGlzIHJldHVybmVkIGZyb20gdGhlIEJpdEdvIEFQSSB1cG9uIGNyZWF0aW9uXG4gIGJpdGdvS2V5Y2hhaW46IEtleWNoYWluO1xuICAvLyBUaGUgY29pbiBvZiB0aGUgd2FsbGV0IHRoYXQgd2FzLyBpcyBhYm91dCB0byBiZSBjcmVhdGVkXG4gIGNvaW46IFJlYWRvbmx5PEJhc2VDb2luPjtcbiAgLy8gQSBjb2RlIHRoYXQgY2FuIGJlIHVzZWQgdG8gZW5jcnlwdCB0aGUgd2FsbGV0IHBhc3N3b3JkIHRvLlxuICAvLyBJZiBib3RoIHRoZSBwYXNzcGhyYXNlIGFuZCBwYXNzY29kZUVuY3J5cHRpb25Db2RlIGFyZSBwYXNzZWQsIHRoZW4gdGhpcyBjb2RlIGVuY3J5cHRzIHRoZSBwYXNzcGhyYXNlIHdpdGggdGhlXG4gIC8vIHBhc3Njb2RlRW5jcnlwdGlvbkNvZGUgYW5kIHB1dHMgdGhlIHJlc3VsdCBpbnRvIEJveCBELiBBbGxvd3MgcmVjb3ZlcmllcyBvZiB0aGUgd2FsbGV0IHBhc3N3b3JkLlxuICBwYXNzY29kZUVuY3J5cHRpb25Db2RlPzogc3RyaW5nO1xuICAvLyBUaGUgd2FsbGV0IHBhc3N3b3JkXG4gIC8vIElmIGJvdGggdGhlIHBhc3NwaHJhc2UgYW5kIHBhc3Njb2RlRW5jcnlwdGlvbkNvZGUgYXJlIHBhc3NlZCwgdGhlbiB0aGlzIGNvZGUgZW5jcnlwdHMgdGhlIHBhc3NwaHJhc2Ugd2l0aCB0aGVcbiAgLy8gcGFzc2NvZGVFbmNyeXB0aW9uQ29kZSBhbmQgcHV0cyB0aGUgcmVzdWx0IGludG8gQm94IEQuIEFsbG93cyByZWNvdmVyaWVzIG9mIHRoZSB3YWxsZXQgcGFzc3dvcmQuXG4gIHBhc3NwaHJhc2U/OiBzdHJpbmc7XG4gIC8vIFRoZSB1c2VyIGtleWNoYWluIGFzIGl0IGlzIHJldHVybmVkIGZyb20gdGhlIEJpdEdvIEFQSSB1cG9uIGNyZWF0aW9uXG4gIHVzZXJLZXljaGFpbjogS2V5Y2hhaW47XG4gIC8vIFRoZSBrZXkgaWQgb2YgdGhlIHVzZXIga2V5LCBvbmx5IHVzZWQgZm9yIGNvbGQga2V5c1xuICB1c2VyTWFzdGVyS2V5Pzogc3RyaW5nO1xuICAvKipcbiAgICogQGRlc2NyaXB0aW9uIFRoZSBrZXkgdXNlZCB0byBkZXJpdmUgdGhlIHVzZXIga2V5IHVzaW5nIHtAbGluayB1c2VyTWFzdGVyS2V5fSBhcyB0aGUgc2VlZC5cbiAgICovXG4gIHVzZXJNYXN0ZXJQdWJsaWNLZXk/OiBzdHJpbmc7XG59XG5cbmV4cG9ydCB0eXBlIEdlbmVyYXRlS2V5Y2FyZFBhcmFtcyA9IEdlbmVyYXRlUXJEYXRhQmFzZVBhcmFtcyAmIChHZW5lcmF0ZVFyRGF0YUZvcktleWNoYWluUGFyYW1zIHwgR2VuZXJhdGVRckRhdGFQYXJhbXMpO1xuXG5leHBvcnQgaW50ZXJmYWNlIElEcmF3S2V5Q2FyZCB7XG4gIGFjdGl2YXRpb25Db2RlPzogc3RyaW5nO1xuICBrZXlDYXJkSW1hZ2U/OiBIVE1MSW1hZ2VFbGVtZW50O1xuICBxckRhdGE6IFFyRGF0YTtcbiAgcXVlc3Rpb25zOiBGQVFbXTtcbiAgd2FsbGV0TGFiZWw/OiBzdHJpbmc7XG4gIGN1cnZlPzogS2V5Q3VydmU7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgRkFRIHtcbiAgcXVlc3Rpb246IHN0cmluZztcbiAgLy8gdGhlIGFuc3dlciB0byB0aGUgcXVlc3Rpb24sIGFscmVhZHkgc3BsaXQgaW50byBpbmRpdmlkdWFsIGxpbmVzIG9mIHRleHRcbiAgYW5zd2VyOiBzdHJpbmdbXTtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBRckRhdGFFbnRyeSB7XG4gIGRhdGE6IHN0cmluZztcbiAgZGVzY3JpcHRpb246IHN0cmluZztcbiAgdGl0bGU6IHN0cmluZztcbiAgcHVibGljTWFzdGVyS2V5Pzogc3RyaW5nO1xufVxuXG5leHBvcnQgdHlwZSBNYXN0ZXJQdWJsaWNLZXlRckRhdGFFbnRyeSA9IE9taXQ8UXJEYXRhRW50cnksICdwdWJsaWNNYXN0ZXJLZXknPjtcblxuZXhwb3J0IGludGVyZmFjZSBRckRhdGEge1xuICBiYWNrdXA/OiBRckRhdGFFbnRyeTtcbiAgYmFja3VwTWFzdGVyUHVibGljS2V5PzogTWFzdGVyUHVibGljS2V5UXJEYXRhRW50cnk7XG4gIGJpdGdvPzogUXJEYXRhRW50cnk7XG4gIHBhc3Njb2RlPzogUXJEYXRhRW50cnk7XG4gIGN1cnZlPzogS2V5Q3VydmU7XG4gIHVzZXI6IFFyRGF0YUVudHJ5O1xuICB1c2VyTWFzdGVyUHVibGljS2V5PzogTWFzdGVyUHVibGljS2V5UXJEYXRhRW50cnk7XG59XG4iXX0=
package/dist/src/utils.js CHANGED
@@ -1,6 +1,6 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.splitKeys = void 0;
3
+ exports.splitKeys = splitKeys;
4
4
  function splitKeys(key, limit) {
5
5
  if (key.length <= limit) {
6
6
  return [key];
@@ -13,5 +13,4 @@ function splitKeys(key, limit) {
13
13
  }
14
14
  return keys;
15
15
  }
16
- exports.splitKeys = splitKeys;
17
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXRpbHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvdXRpbHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQUEsU0FBZ0IsU0FBUyxDQUFDLEdBQVcsRUFBRSxLQUFhO0lBQ2xELElBQUksR0FBRyxDQUFDLE1BQU0sSUFBSSxLQUFLLEVBQUU7UUFDdkIsT0FBTyxDQUFDLEdBQUcsQ0FBQyxDQUFDO0tBQ2Q7SUFFRCxNQUFNLElBQUksR0FBYSxFQUFFLENBQUM7SUFFMUIsSUFBSSxVQUFVLEdBQUcsS0FBSyxDQUFDO0lBQ3ZCLEtBQUssSUFBSSxDQUFDLEdBQUcsQ0FBQyxFQUFFLENBQUMsR0FBRyxHQUFHLENBQUMsTUFBTSxFQUFFLENBQUMsSUFBSSxLQUFLLEVBQUU7UUFDMUMsSUFBSSxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsU0FBUyxDQUFDLENBQUMsRUFBRSxVQUFVLENBQUMsQ0FBQyxDQUFDO1FBQ3hDLFVBQVUsR0FBRyxJQUFJLENBQUMsR0FBRyxDQUFDLFVBQVUsR0FBRyxLQUFLLEVBQUUsR0FBRyxDQUFDLE1BQU0sQ0FBQyxDQUFDO0tBQ3ZEO0lBRUQsT0FBTyxJQUFJLENBQUM7QUFDZCxDQUFDO0FBZEQsOEJBY0MiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgZnVuY3Rpb24gc3BsaXRLZXlzKGtleTogc3RyaW5nLCBsaW1pdDogbnVtYmVyKTogc3RyaW5nW10ge1xuICBpZiAoa2V5Lmxlbmd0aCA8PSBsaW1pdCkge1xuICAgIHJldHVybiBba2V5XTtcbiAgfVxuXG4gIGNvbnN0IGtleXM6IHN0cmluZ1tdID0gW107XG5cbiAgbGV0IHJpZ2h0SW5kZXggPSBsaW1pdDtcbiAgZm9yIChsZXQgaSA9IDA7IGkgPCBrZXkubGVuZ3RoOyBpICs9IGxpbWl0KSB7XG4gICAga2V5cy5wdXNoKGtleS5zdWJzdHJpbmcoaSwgcmlnaHRJbmRleCkpO1xuICAgIHJpZ2h0SW5kZXggPSBNYXRoLm1pbihyaWdodEluZGV4ICsgbGltaXQsIGtleS5sZW5ndGgpO1xuICB9XG5cbiAgcmV0dXJuIGtleXM7XG59XG4iXX0=
16
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXRpbHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvdXRpbHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFBQSw4QkFjQztBQWRELFNBQWdCLFNBQVMsQ0FBQyxHQUFXLEVBQUUsS0FBYTtJQUNsRCxJQUFJLEdBQUcsQ0FBQyxNQUFNLElBQUksS0FBSyxFQUFFLENBQUM7UUFDeEIsT0FBTyxDQUFDLEdBQUcsQ0FBQyxDQUFDO0lBQ2YsQ0FBQztJQUVELE1BQU0sSUFBSSxHQUFhLEVBQUUsQ0FBQztJQUUxQixJQUFJLFVBQVUsR0FBRyxLQUFLLENBQUM7SUFDdkIsS0FBSyxJQUFJLENBQUMsR0FBRyxDQUFDLEVBQUUsQ0FBQyxHQUFHLEdBQUcsQ0FBQyxNQUFNLEVBQUUsQ0FBQyxJQUFJLEtBQUssRUFBRSxDQUFDO1FBQzNDLElBQUksQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLFNBQVMsQ0FBQyxDQUFDLEVBQUUsVUFBVSxDQUFDLENBQUMsQ0FBQztRQUN4QyxVQUFVLEdBQUcsSUFBSSxDQUFDLEdBQUcsQ0FBQyxVQUFVLEdBQUcsS0FBSyxFQUFFLEdBQUcsQ0FBQyxNQUFNLENBQUMsQ0FBQztJQUN4RCxDQUFDO0lBRUQsT0FBTyxJQUFJLENBQUM7QUFDZCxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGZ1bmN0aW9uIHNwbGl0S2V5cyhrZXk6IHN0cmluZywgbGltaXQ6IG51bWJlcik6IHN0cmluZ1tdIHtcbiAgaWYgKGtleS5sZW5ndGggPD0gbGltaXQpIHtcbiAgICByZXR1cm4gW2tleV07XG4gIH1cblxuICBjb25zdCBrZXlzOiBzdHJpbmdbXSA9IFtdO1xuXG4gIGxldCByaWdodEluZGV4ID0gbGltaXQ7XG4gIGZvciAobGV0IGkgPSAwOyBpIDwga2V5Lmxlbmd0aDsgaSArPSBsaW1pdCkge1xuICAgIGtleXMucHVzaChrZXkuc3Vic3RyaW5nKGksIHJpZ2h0SW5kZXgpKTtcbiAgICByaWdodEluZGV4ID0gTWF0aC5taW4ocmlnaHRJbmRleCArIGxpbWl0LCBrZXkubGVuZ3RoKTtcbiAgfVxuXG4gIHJldHVybiBrZXlzO1xufVxuIl19