@bitgo-beta/sdk-core 8.2.1-beta.255 → 8.2.1-beta.256

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/CHANGELOG.md CHANGED
@@ -3,6 +3,116 @@
3
3
  All notable changes to this project will be documented in this file.
4
4
  See [Conventional Commits](https://conventionalcommits.org) for commit guidelines.
5
5
 
6
+ # [25.0.0](https://github.com/BitGo/BitGoJS/compare/@bitgo/sdk-core@8.13.0...@bitgo/sdk-core@25.0.0) (2024-01-30)
7
+
8
+ ### Bug Fixes
9
+
10
+ - add pendingApprovaId in prebuildTxTss response ([049466b](https://github.com/BitGo/BitGoJS/commit/049466b56b5353899b6f9172a369f2d3dad58003))
11
+ - downgrade from `io-ts@2.2.x` to `io-ts@2.1.3` ([78f138a](https://github.com/BitGo/BitGoJS/commit/78f138a595b7fca8e4ebb63f7c2012157118cbfc))
12
+ - remove unused dynamic headers ([4243c1d](https://github.com/BitGo/BitGoJS/commit/4243c1d02a59793f30b50a9efb80d1da8709aa4c))
13
+ - **root:** add source to tss smc wallet creation ([316ff20](https://github.com/BitGo/BitGoJS/commit/316ff200f5eb8803f3591ab28a5c1b1f27f28e38))
14
+ - **root:** improve error handling for consolidateAccount ([0d74c2a](https://github.com/BitGo/BitGoJS/commit/0d74c2aaca1076ad6b9ca9bd2de38ade56c886e3))
15
+ - **root:** update @types/node ([cedc1a0](https://github.com/BitGo/BitGoJS/commit/cedc1a0035e79bb42fda57bf6ac29d606242f50b))
16
+ - **sdk-core:** add change address type for utxo coins ([711ba2d](https://github.com/BitGo/BitGoJS/commit/711ba2d8bd00cbb0ec644eefd20356507a50adb1))
17
+ - **sdk-core:** add pendingappr id in build api ([3ace9ac](https://github.com/BitGo/BitGoJS/commit/3ace9ac74a0729f8ade84e8a0c8cd67429563147))
18
+ - **sdk-core:** add rebuild step before eddsa signing ([462c7f8](https://github.com/BitGo/BitGoJS/commit/462c7f8519a96fcbc8d333a49b24d2d07479590b))
19
+ - **sdk-core:** do not hardcode eddsa tss utils in PA ([366ffd2](https://github.com/BitGo/BitGoJS/commit/366ffd2ccfd52c220e74b32914dcfebc3ae307d3))
20
+ - **sdk-core:** do not sign txRequest full with PA ([6558de2](https://github.com/BitGo/BitGoJS/commit/6558de263edea51ff2c87dc37889af5ba0654a4d))
21
+ - **sdk-core:** export bip32HdTree as BIP32 ([cc80aa6](https://github.com/BitGo/BitGoJS/commit/cc80aa6dfc7ba7ac0657df6a685c7ebd6dc094a0))
22
+ - **sdk-core:** fix coreum node url ([936c76d](https://github.com/BitGo/BitGoJS/commit/936c76d65d7d6b0eaf42ed96c63db1e5efaa62f7))
23
+ - **sdk-core:** fix dc wallet creation ([70c5e35](https://github.com/BitGo/BitGoJS/commit/70c5e35525c2803f739265ebbc734ab8de4d1870))
24
+ - **sdk-core:** fix ecdsa with external signer ([09884c0](https://github.com/BitGo/BitGoJS/commit/09884c03f971e71c55f0461b449c18cf68c095db))
25
+ - **sdk-core:** fix hash for tss ecdsa PA signing ([e57f6f9](https://github.com/BitGo/BitGoJS/commit/e57f6f926d1b99fb3cad3953f05550163474bcfb))
26
+ - **sdk-core:** fix issue related to bignumber version ([519fe47](https://github.com/BitGo/BitGoJS/commit/519fe479ef51a72ddc1e94f87c10e031c0fd2c3f))
27
+ - **sdk-core:** handle txRequest full PA before signing ([9de0eae](https://github.com/BitGo/BitGoJS/commit/9de0eae7cab1ad406e80a818555a7c8557b47eb3))
28
+ - **sdk-core:** include tests in tsconfig.json ([91c1c6c](https://github.com/BitGo/BitGoJS/commit/91c1c6c47f809cbd826db2a7a59c96b74f0273e9))
29
+ - **sdk-core:** move --recursive flag to package.json ([1147ebe](https://github.com/BitGo/BitGoJS/commit/1147ebe3d2ab1868fe1c6bbf343f68becc7d1169))
30
+ - **sdk-core:** only add headers if they exist and nonempty ([e85c55a](https://github.com/BitGo/BitGoJS/commit/e85c55a15c579fb44b853c8937c3dada562210b6))
31
+ - **sdk-core:** sign txRequest full in pendingApproval.approve ([c9f6eea](https://github.com/BitGo/BitGoJS/commit/c9f6eea52ad230f6b5485aba8b70f0b6ec11e8b9))
32
+ - **sdk-core:** use BuildParams.encode when consolidating unspents ([f83f096](https://github.com/BitGo/BitGoJS/commit/f83f096b2839a0324d891d81c01e5265d10e4b97))
33
+ - **statics:** make corrections for arbeth and opeth ([5dfc405](https://github.com/BitGo/BitGoJS/commit/5dfc405a36fc97b2c902fec44562b169d8013a18))
34
+ - use public types for tx send ([6a0e5c7](https://github.com/BitGo/BitGoJS/commit/6a0e5c74d27d4a7ed5e9972e184fb9744b15793e))
35
+ - use whitelisted send params for tx initiate ([0cf9f4c](https://github.com/BitGo/BitGoJS/commit/0cf9f4c4aeb8a74cd81aad4b0da08d1de30d73a0))
36
+
37
+ ### chore
38
+
39
+ - update `BitGo/public-types` to `2.0.0` ([a74148d](https://github.com/BitGo/BitGoJS/commit/a74148d8f16e565bcd0e64f79b0b0d0b9e683145))
40
+
41
+ ### Code Refactoring
42
+
43
+ - rename coin 'core' to 'coreum' ([baecc01](https://github.com/BitGo/BitGoJS/commit/baecc013ff7243ce78ebd767bffdb0763b8b4cdb))
44
+
45
+ ### Features
46
+
47
+ - add address book methods to wallet class ([ff315b3](https://github.com/BitGo/BitGoJS/commit/ff315b33c225e1b56870cf2bc41b68fab520bb92))
48
+ - add bitgo network methods to trading class ([94b3093](https://github.com/BitGo/BitGoJS/commit/94b3093e8cd5791e5fd1877341d4ab7ab5a7009f))
49
+ - add rbf params to accelerateTransaction ([605dd31](https://github.com/BitGo/BitGoJS/commit/605dd317321279f320c17460df12f5ac2c959960))
50
+ - add walletFlags property, helper methods ([f0fd760](https://github.com/BitGo/BitGoJS/commit/f0fd760122334d86b0d4239bc3b23e0983a1d524))
51
+ - **bitgo:** use holesky etherscan url instead of goerli ([61962f6](https://github.com/BitGo/BitGoJS/commit/61962f6e273fd654575d3c93d9faf1a46bd361e4))
52
+ - deprecate old settlement code ([550380d](https://github.com/BitGo/BitGoJS/commit/550380d7838586a407bfb805d2ac7e99c6cf1cec))
53
+ - **express:** add external signer support for signig with derivation paths ([ceb89dd](https://github.com/BitGo/BitGoJS/commit/ceb89dd72b7f5f7c59484d5517ac32c4f499fd32))
54
+ - **root:** whitelist apiVersion for buildAccountConsolidations ([83003de](https://github.com/BitGo/BitGoJS/commit/83003de987b49b5c462d08623d6687501958e4b5))
55
+ - **sdk-coin-algo:** support for token enablement ([af718c9](https://github.com/BitGo/BitGoJS/commit/af718c992d0663722fe951f0a29a20825ba0e91c))
56
+ - **sdk-coin-bera:** add Berachain skeleton ([b3d43c5](https://github.com/BitGo/BitGoJS/commit/b3d43c52c7fd10d5fdc40123b3ad61cfe4784e5d))
57
+ - **sdk-coin-core:** add coreum sdk ([af73ccd](https://github.com/BitGo/BitGoJS/commit/af73ccd445b52dcf378ebd18260e628de0687043))
58
+ - **sdk-coin-dot:** create function to produce broadcastable dot sweep ([ad9c9c4](https://github.com/BitGo/BitGoJS/commit/ad9c9c4cc79639a5745e82f62566afa6db2b8c6d))
59
+ - **sdk-coin-hbar:** implement recover method for native hbar ([45c4b7a](https://github.com/BitGo/BitGoJS/commit/45c4b7a7591176cb665efbdbb4279d40f3a869dd))
60
+ - **sdk-coin-islm:** add Islamic Coin ([c49bdd1](https://github.com/BitGo/BitGoJS/commit/c49bdd18df36a20d6e27cdd2686ec687bf653596))
61
+ - **sdk-coin-sol:** add sol token recovery support ([8a46e48](https://github.com/BitGo/BitGoJS/commit/8a46e482205fb33439e123dc288720225926b443))
62
+ - **sdk-coin-sol:** add transaction message authorize builder ([649b7df](https://github.com/BitGo/BitGoJS/commit/649b7df0f65c2eee08e7c1e009ebb3c03cf4d011))
63
+ - **sdk-coin-sol:** add tx builder for delegate and deactivate ([a7cdaaa](https://github.com/BitGo/BitGoJS/commit/a7cdaaa5a7b3bab83bccc82a7c001a9f23e94207))
64
+ - **sdk-coin-sol:** create method to produce broadcastable sol sweep txn ([d69ca4e](https://github.com/BitGo/BitGoJS/commit/d69ca4ea0688c4cf7c738ca826a9231438bb49c5))
65
+ - **sdk-coin-sui:** add custom tx type ([8136220](https://github.com/BitGo/BitGoJS/commit/81362200468f8a2d25b97186f56de5d5729fa0cf))
66
+ - **sdk-coin-trx:** batch consolidate native TRX to base ([a781709](https://github.com/BitGo/BitGoJS/commit/a781709e296ac37edd8c49587fb46a3ae0202cce))
67
+ - **sdk-coin-zeta:** add recovery functionality for zeta ([b7d428f](https://github.com/BitGo/BitGoJS/commit/b7d428fcd69a22add44399a9a0e4eeb4519c4113))
68
+ - **sdk-coin-zketh:** add zketh token support ([086b86c](https://github.com/BitGo/BitGoJS/commit/086b86c7886174997a01bea04617256f66e08720))
69
+ - **sdk-core:** add custodial and smc tss wallet to generateWallet method ([ea80f4f](https://github.com/BitGo/BitGoJS/commit/ea80f4fa208ca6874fdd7d99d597c347e4628ecc))
70
+ - **sdk-core:** add function to transfer nfts ([b77b386](https://github.com/BitGo/BitGoJS/commit/b77b386bf77408d4b1617ba3bc44e5899a65f2e0))
71
+ - **sdk-core:** add helpers to support resigning ent challenges ([e9bb150](https://github.com/BitGo/BitGoJS/commit/e9bb1505af331f6caa7b0bcda2037483f57238fd))
72
+ - **sdk-core:** add limit as a valid build param ([e538192](https://github.com/BitGo/BitGoJS/commit/e5381929667ab4ea622deb7bc2cc916764fce2d3))
73
+ - **sdk-core:** add new fields to StakeOptions ([ed90855](https://github.com/BitGo/BitGoJS/commit/ed90855118014238684643597c8cc9a024d223bf))
74
+ - **sdk-core:** add new method to sign tss txs ([3e2654d](https://github.com/BitGo/BitGoJS/commit/3e2654d31baae8723d5a449ed79be14980410e1b))
75
+ - **sdk-core:** add optional StakeOptions fields ([bff557c](https://github.com/BitGo/BitGoJS/commit/bff557c5d5cc6f5e53096d7ea8a9848b97e18249))
76
+ - **sdk-core:** add postWithCodec utility function ([ff1ad07](https://github.com/BitGo/BitGoJS/commit/ff1ad07dfe476d38ae17cfb691ef0e6375a394ea))
77
+ - **sdk-core:** add support for bulk unspent consolidation ([daee9f0](https://github.com/BitGo/BitGoJS/commit/daee9f0a3480bbae08a5b06d1c7c683ce979210a))
78
+ - **sdk-core:** add support to allow external change address ([cbef823](https://github.com/BitGo/BitGoJS/commit/cbef823c431271ce542124e5a6a079549eec3099))
79
+ - **sdk-core:** add type for serializedNtilde with verifiers ([b8ba323](https://github.com/BitGo/BitGoJS/commit/b8ba323b5a00fceb1017c1c953375edbd5459f60))
80
+ - **sdk-core:** add, use SendTransactionRequest and BuildParams codecs ([724fc6c](https://github.com/BitGo/BitGoJS/commit/724fc6c3adee3ef7dbeb39e023f2270ff36a233d))
81
+ - **sdk-core:** allow tss signing with unencrypted prv ([306dd37](https://github.com/BitGo/BitGoJS/commit/306dd37d61f8648b65be6ca99b0f4014fdc5a61b))
82
+ - **sdk-core:** create distributed custody wallet ([e53c9a4](https://github.com/BitGo/BitGoJS/commit/e53c9a489b557198fc1606856f32d7ede85e269b))
83
+ - **sdk-core:** extend build param codec ([e224ca3](https://github.com/BitGo/BitGoJS/commit/e224ca306608e9618d080fdb623db09307a91910))
84
+ - **sdk-core:** flag to do segwit override for bulk consolidations ([2bcdaf0](https://github.com/BitGo/BitGoJS/commit/2bcdaf01953daf68734e96a0046cf69f85a602f1))
85
+ - **sdk-core:** generate and verify schnorr proof of X_i ([ff58298](https://github.com/BitGo/BitGoJS/commit/ff58298c21ee8de4f6cee4fec857666e9556d0f3))
86
+ - **sdk-core:** get utxo script types by coin ([b3cbc61](https://github.com/BitGo/BitGoJS/commit/b3cbc617565547b05d6ae2b1df184e9c0e2e247c))
87
+ - **sdk-core:** phase 5 of gg18 signing ([d8ab3df](https://github.com/BitGo/BitGoJS/commit/d8ab3df38c7f0dc445117f68340cd3f17dfc9a68))
88
+ - **sdk-core:** provide skipKeychain to wallet share API request ([4fcc705](https://github.com/BitGo/BitGoJS/commit/4fcc705e04de4c6beed541b096f2fe65b44c0a53))
89
+ - **sdk-core:** support webauthn decryption in base wallet fn ([d6dea1a](https://github.com/BitGo/BitGoJS/commit/d6dea1a02affb57ac03bd9019ec02581d897565c))
90
+ - **sdk-core:** use BuildParams codec in Wallet.accelerateTransaction ([a9fab81](https://github.com/BitGo/BitGoJS/commit/a9fab813f27cdb40123c49b01570ecb6b9a67d91))
91
+ - **sdk-core:** use BuildParams codec in Wallet.sendAccountConsolidation ([7d340ec](https://github.com/BitGo/BitGoJS/commit/7d340ec674116badf3b05aadf1d9aae130a8c69d))
92
+ - **sdk-core:** util to decrypt webauthn encrypted keys ([84a30c4](https://github.com/BitGo/BitGoJS/commit/84a30c4baf7aac110685aa73852f6d3ffb3bd579))
93
+ - **sdk-core:** whitelist distributed custody params ([2536388](https://github.com/BitGo/BitGoJS/commit/253638867d28e874d7d1ba808558cea16bc743f7))
94
+ - **sdk-lib-mpc:** move ecdsa hdtree from core ([f0311a8](https://github.com/BitGo/BitGoJS/commit/f0311a8606b1a6aa82309ef7bb9a349782819c28))
95
+ - **sdk-lib-mpc:** move shamir ([42fc946](https://github.com/BitGo/BitGoJS/commit/42fc946c8a5c4a1f7a09e5a9cb6c64a0b266a2a7))
96
+ - **sdk-lib-mpc:** move types to types.ts ([cf2f482](https://github.com/BitGo/BitGoJS/commit/cf2f4821792172b1657fbcecd8886df5bacd817a))
97
+ - update secp256k1 to 5.0.0 and keccak to 3.0.3 ([e2c37e6](https://github.com/BitGo/BitGoJS/commit/e2c37e6b0139c9f6948a22d8921bc3e1f88bed4c))
98
+ - use psbt for prebuild when wallet is distributedCustody ([10f5e1a](https://github.com/BitGo/BitGoJS/commit/10f5e1ab37d2bea6acd93f94defbe786e4a027b9))
99
+ - whitelist rbf build params ([208bc83](https://github.com/BitGo/BitGoJS/commit/208bc833deedcd620832a7695e0cad1bbd53c59f))
100
+
101
+ ### BREAKING CHANGES
102
+
103
+ - Update `public-types` to `2.0.0`
104
+
105
+ Ticket: VL-000
106
+
107
+ - BitGo requires using `io-ts@2.1.3` in it's
108
+ entire stack. this downgrades the version of `io-ts` to
109
+ adhere to this requirement.
110
+
111
+ VL-000
112
+
113
+ - **bitgo:** changed default eth testnet etherscan url to holesky
114
+ - rename coin module, coin name, named exports for coreum
115
+
6
116
  # [24.0.0](https://github.com/BitGo/BitGoJS/compare/@bitgo/sdk-core@8.13.0...@bitgo/sdk-core@24.0.0) (2024-01-26)
7
117
 
8
118
  ### Bug Fixes
@@ -5,6 +5,10 @@ export declare type KeyValidityDict = {
5
5
  keyID: pgp.KeyID;
6
6
  valid: boolean | null;
7
7
  }[];
8
+ export declare type AuthEncMessage = {
9
+ encryptedMessage: string;
10
+ signature: string;
11
+ };
8
12
  /**
9
13
  * Fetches BitGo's public gpg key used in MPC flows
10
14
  * @param {BitGoBase} bitgo BitGo object
@@ -82,6 +86,20 @@ export declare function createShareProof(privateArmor: string, uValue: string, a
82
86
  * TODO(BG-47170): Delete once gpg signatures are fully supported
83
87
  */
84
88
  export declare function encryptText(text: string, key: Key): Promise<string>;
89
+ /**
90
+ * Encrypts and detach signs a string
91
+ * @param text string to encrypt and sign
92
+ * @param publicArmor public key to encrypt with
93
+ * @param privateArmor private key to sign with
94
+ */
95
+ export declare function encryptAndDetachSignText(text: string, publicArmor: string, privateArmor: string): Promise<AuthEncMessage>;
96
+ /**
97
+ * Encrypts and detach signs a string
98
+ * @param text string to encrypt and sign
99
+ * @param publicArmor public key to verify signature with
100
+ * @param privateArmor private key to decrypt with
101
+ */
102
+ export declare function decryptAndVerifySignedText(encryptedAndSignedMessage: AuthEncMessage, publicArmor: string, privateArmor: string): Promise<string>;
85
103
  /**
86
104
  * Encrypts and signs a string
87
105
  * @param text string to encrypt and sign
@@ -1 +1 @@
1
- {"version":3,"file":"opengpgUtils.d.ts","sourceRoot":"","sources":["../../../../src/bitgo/utils/opengpgUtils.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,GAAG,MAAM,SAAS,CAAC;AAC/B,OAAO,EAIL,GAAG,EAOJ,MAAM,SAAS,CAAC;AAGjB,OAAO,EAAE,SAAS,EAAE,MAAM,cAAc,CAAC;AAKzC,oBAAY,eAAe,GAAG;IAC5B,KAAK,EAAE,GAAG,CAAC,KAAK,CAAC;IACjB,KAAK,EAAE,OAAO,GAAG,IAAI,CAAC;CACvB,EAAE,CAAC;AAEJ;;;;GAIG;AACH,wBAAsB,iBAAiB,CAAC,KAAK,EAAE,SAAS,GAAG,OAAO,CAAC,GAAG,CAAC,CAQtE;AAED;;;;;;;GAOG;AACH,wBAAsB,wBAAwB,CAC5C,MAAM,EAAE,GAAG,EACX,WAAW,EAAE,GAAG,EAChB,UAAU,EAAE,OAAO,GAClB,OAAO,CAAC,eAAe,CAAC,CAM1B;AAED;;;GAGG;AACH,wBAAsB,iBAAiB,CAAC,KAAK,EAAE,SAAS,GAAG,OAAO,CAAC,GAAG,CAAC,CAMtE;AAED;;;;;;;;GAQG;AACH,wBAAsB,gBAAgB,CACpC,YAAY,EAAE,MAAM,EACpB,iBAAiB,EAAE,MAAM,EACzB,MAAM,EAAE,MAAM,EACd,IAAI,EAAE,OAAO,GAAG,OAAO,GACtB,OAAO,CAAC,OAAO,CAAC,CAoBlB;AAED;;;;;;;GAOG;AACH,wBAAsB,qBAAqB,CACzC,eAAe,EAAE,MAAM,EACvB,eAAe,EAAE,MAAM,EACvB,YAAY,EAAE;IAAE,IAAI,EAAE,MAAM,CAAC;IAAC,KAAK,EAAE,MAAM,CAAA;CAAE,EAAE,GAC9C,OAAO,CAAC,OAAO,CAAC,CAiBlB;AAED;;;;;;;GAOG;AACH,wBAAsB,qBAAqB,CACzC,iBAAiB,EAAE,MAAM,EACzB,sBAAsB,EAAE,MAAM,EAC9B,SAAS,EAAE;IAAE,IAAI,EAAE,MAAM,CAAC;IAAC,KAAK,EAAE,MAAM,CAAA;CAAE,EAAE,GAC3C,OAAO,CAAC,MAAM,CAAC,CAmDjB;AAED;;;;;;;;;;GAUG;AACH,wBAAsB,gBAAgB,CAAC,YAAY,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC,CA6D1G;AAED;;;;;;;;;GASG;AACH,wBAAsB,WAAW,CAAC,IAAI,EAAE,MAAM,EAAE,GAAG,EAAE,GAAG,GAAG,OAAO,CAAC,MAAM,CAAC,CAczE;AAED;;;;;GAKG;AACH,wBAAsB,kBAAkB,CAAC,IAAI,EAAE,MAAM,EAAE,WAAW,EAAE,MAAM,EAAE,YAAY,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC,CAmBjH;AAED;;;;;;GAMG;AACH,wBAAsB,iBAAiB,CAAC,MAAM,EAAE,MAAM,EAAE,WAAW,EAAE,MAAM,EAAE,YAAY,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC,CAclH;AAED;;;;;;GAMG;AACH,wBAAsB,QAAQ,CAAC,IAAI,EAAE,MAAM,EAAE,YAAY,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC,CAWlF;AAED;;;;;;GAMG;AACH,wBAAsB,eAAe,CAAC,IAAI,EAAE,MAAM,EAAE,gBAAgB,EAAE,MAAM,EAAE,WAAW,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC,CAoBnH;AAED;;;;;;GAMG;AACH,wBAAsB,kBAAkB,CACtC,QAAQ,EAAE,GAAG,CAAC,iBAAiB,EAC/B,QAAQ,CAAC,EAAE,MAAM,GAAG,SAAS,EAC7B,KAAK,CAAC,EAAE,MAAM,GAAG,SAAS,GACzB,OAAO,CAAC,GAAG,CAAC,iBAAiB,CAAC,MAAM,CAAC,CAAC,CAkBxC"}
1
+ {"version":3,"file":"opengpgUtils.d.ts","sourceRoot":"","sources":["../../../../src/bitgo/utils/opengpgUtils.ts"],"names":[],"mappings":"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"}
@@ -23,7 +23,7 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
23
23
  return (mod && mod.__esModule) ? mod : { "default": mod };
24
24
  };
25
25
  Object.defineProperty(exports, "__esModule", { value: true });
26
- exports.generateGPGKeyPair = exports.verifySignature = exports.signText = exports.readSignedMessage = exports.encryptAndSignText = exports.encryptText = exports.createShareProof = exports.createSharedDataProof = exports.verifySharedDataProof = exports.verifyShareProof = exports.getTrustGpgPubKey = exports.verifyPrimaryUserWrapper = exports.getBitgoGpgPubKey = void 0;
26
+ exports.generateGPGKeyPair = exports.verifySignature = exports.signText = exports.readSignedMessage = exports.encryptAndSignText = exports.decryptAndVerifySignedText = exports.encryptAndDetachSignText = exports.encryptText = exports.createShareProof = exports.createSharedDataProof = exports.verifySharedDataProof = exports.verifyShareProof = exports.getTrustGpgPubKey = exports.verifyPrimaryUserWrapper = exports.getBitgoGpgPubKey = void 0;
27
27
  const pgp = __importStar(require("openpgp"));
28
28
  const openpgp_1 = require("openpgp");
29
29
  const _ = __importStar(require("lodash"));
@@ -277,6 +277,67 @@ async function encryptText(text, key) {
277
277
  });
278
278
  }
279
279
  exports.encryptText = encryptText;
280
+ /**
281
+ * Encrypts and detach signs a string
282
+ * @param text string to encrypt and sign
283
+ * @param publicArmor public key to encrypt with
284
+ * @param privateArmor private key to sign with
285
+ */
286
+ async function encryptAndDetachSignText(text, publicArmor, privateArmor) {
287
+ const publicKey = await openpgp_1.readKey({ armoredKey: publicArmor });
288
+ const privateKey = await openpgp_1.readPrivateKey({ armoredKey: privateArmor });
289
+ const message = await openpgp_1.createMessage({ text });
290
+ const encryptedMessage = await openpgp_1.encrypt({
291
+ message,
292
+ encryptionKeys: publicKey,
293
+ format: 'armored',
294
+ config: {
295
+ rejectCurves: new Set(),
296
+ showVersion: false,
297
+ showComment: false,
298
+ },
299
+ });
300
+ const signature = await openpgp_1.sign({
301
+ message,
302
+ signingKeys: privateKey,
303
+ format: 'armored',
304
+ detached: true,
305
+ config: {
306
+ rejectCurves: new Set(),
307
+ showVersion: false,
308
+ showComment: false,
309
+ },
310
+ });
311
+ return {
312
+ encryptedMessage: encryptedMessage,
313
+ signature: signature,
314
+ };
315
+ }
316
+ exports.encryptAndDetachSignText = encryptAndDetachSignText;
317
+ /**
318
+ * Encrypts and detach signs a string
319
+ * @param text string to encrypt and sign
320
+ * @param publicArmor public key to verify signature with
321
+ * @param privateArmor private key to decrypt with
322
+ */
323
+ async function decryptAndVerifySignedText(encryptedAndSignedMessage, publicArmor, privateArmor) {
324
+ const publicKey = await openpgp_1.readKey({ armoredKey: publicArmor });
325
+ const privateKey = await openpgp_1.readPrivateKey({ armoredKey: privateArmor });
326
+ const decryptedMessage = await openpgp_1.decrypt({
327
+ message: await openpgp_1.readMessage({ armoredMessage: encryptedAndSignedMessage.encryptedMessage }),
328
+ decryptionKeys: privateKey,
329
+ signature: await openpgp_1.readSignature({ armoredSignature: encryptedAndSignedMessage.signature }),
330
+ verificationKeys: publicKey,
331
+ expectSigned: true,
332
+ config: {
333
+ rejectCurves: new Set(),
334
+ showVersion: false,
335
+ showComment: false,
336
+ },
337
+ });
338
+ return decryptedMessage.data;
339
+ }
340
+ exports.decryptAndVerifySignedText = decryptAndVerifySignedText;
280
341
  /**
281
342
  * Encrypts and signs a string
282
343
  * @param text string to encrypt and sign
@@ -394,4 +455,4 @@ async function generateGPGKeyPair(keyCurve, username, email) {
394
455
  return gpgKey;
395
456
  }
396
457
  exports.generateGPGKeyPair = generateGPGKeyPair;
397
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"opengpgUtils.js","sourceRoot":"","sources":["../../../../src/bitgo/utils/opengpgUtils.ts"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable @typescript-eslint/ban-ts-comment */\n\nimport * as pgp from 'openpgp';\nimport {\n  createMessage,\n  decrypt,\n  encrypt,\n  Key,\n  readKey,\n  readMessage,\n  readPrivateKey,\n  readSignature,\n  sign,\n  verify,\n} from 'openpgp';\nimport * as _ from 'lodash';\nimport { ecc as secp256k1 } from '@bitgo-beta/utxo-lib';\nimport { BitGoBase } from '../bitgoBase';\nimport crypto from 'crypto';\n\nconst sodium = require('libsodium-wrappers-sumo');\n\nexport type KeyValidityDict = {\n  keyID: pgp.KeyID;\n  valid: boolean | null;\n}[];\n\n/**\n * Fetches BitGo's public gpg key used in MPC flows\n * @param {BitGoBase} bitgo BitGo object\n * @return {Key} public gpg key\n */\nexport async function getBitgoGpgPubKey(bitgo: BitGoBase): Promise<Key> {\n  const constants = await bitgo.fetchConstants();\n  if (!constants.mpc || !constants.mpc.bitgoPublicKey) {\n    throw new Error('Unable to create MPC keys - bitgoPublicKey is missing from constants');\n  }\n\n  const bitgoPublicKeyStr = constants.mpc.bitgoPublicKey as string;\n  return await readKey({ armoredKey: bitgoPublicKeyStr });\n}\n\n/**\n * Verifies the primary user on a GPG key using a reference key representing the user to be checked.\n * Allows a verification without a date check by wrapping verifyPrimaryUser of openpgp.\n * @param {Key} pubKey gpg key to check the primary user of.\n * @param {Key} primaryUser gpg key of the user to check.\n * @param {boolean} checkDates If false, disable date checks in the openpgp call to check the primary user.\n * @return {KeyValidityDict} list of users checked and whether each passed as a primary user in pubKey or not.\n */\nexport async function verifyPrimaryUserWrapper(\n  pubKey: Key,\n  primaryUser: Key,\n  checkDates: boolean\n): Promise<KeyValidityDict> {\n  if (checkDates) {\n    return await pubKey.verifyPrimaryUser([primaryUser]);\n  } else {\n    return await pubKey.verifyPrimaryUser([primaryUser], null as unknown as undefined);\n  }\n}\n\n/**\n * Fetches Trust pub key string\n * @param bitgo\n */\nexport async function getTrustGpgPubKey(bitgo: BitGoBase): Promise<Key> {\n  const constants = await bitgo.fetchConstants();\n  if (!constants.trustPubKey) {\n    throw new Error('Unable to get trustPubKey');\n  }\n  return readKey({ armoredKey: constants.trustPubKey });\n}\n\n/**\n * Verify an Eddsa or Ecdsa KeyShare Proof.\n *\n * @param senderPubKey public key of the sender of the privateShareProof\n * @param privateShareProof u value proof\n * @param uValue u value from an Eddsa keyshare\n * @param algo\n * @return {boolean} whether uValue proof actually was signed by sender as part of their subkeys\n */\nexport async function verifyShareProof(\n  senderPubKey: string,\n  privateShareProof: string,\n  uValue: string,\n  algo: 'eddsa' | 'ecdsa'\n): Promise<boolean> {\n  const decodedProof = await pgp.readKey({ armoredKey: privateShareProof });\n  const senderGpgKey = await pgp.readKey({ armoredKey: senderPubKey });\n  if (!(await verifyPrimaryUserWrapper(decodedProof, senderGpgKey, true))[0].valid) {\n    return false;\n  }\n  const proofSubkeys = decodedProof.getSubkeys()[1];\n  if (algo === 'eddsa') {\n    const decodedUValueProof = Buffer.from(proofSubkeys.keyPacket.publicParams['Q'].slice(1)).toString('hex');\n    const rawUValueProof = Buffer.from(\n      sodium.crypto_scalarmult_ed25519_base_noclamp(Buffer.from(uValue, 'hex'))\n    ).toString('hex');\n    return decodedUValueProof === rawUValueProof;\n  } else if (algo === 'ecdsa') {\n    const decodedUValueProof = Buffer.from(proofSubkeys.keyPacket.publicParams['Q']).toString('hex');\n    const rawUValueProof = secp256k1.pointFromScalar(Buffer.from(uValue, 'hex'), false);\n    return rawUValueProof !== null && decodedUValueProof === Buffer.from(rawUValueProof).toString('hex');\n  } else {\n    throw new Error('Invalid algorithm provided');\n  }\n}\n\n/**\n * Verify a shared data proof.\n *\n * @param senderPubKeyArm public key of the signer of the key with proof data\n * @param keyWithNotation signed reciever key with notation data\n * @param dataToVerify data to be checked against notation data in the signed key\n * @return {boolean} whether proof is valid\n */\nexport async function verifySharedDataProof(\n  senderPubKeyArm: string,\n  keyWithNotation: string,\n  dataToVerify: { name: string; value: string }[]\n): Promise<boolean> {\n  const senderPubKey = await pgp.readKey({ armoredKey: senderPubKeyArm });\n  const signedKey = await pgp.readKey({ armoredKey: keyWithNotation });\n  if (\n    !(await verifyPrimaryUserWrapper(signedKey, senderPubKey, true).then((values) =>\n      _.some(values, (value) => value.valid)\n    ))\n  ) {\n    return false;\n  }\n  const primaryUser = await signedKey.getPrimaryUser();\n  const anyInvalidProof = _.some(\n    // @ts-ignore\n    primaryUser.user.otherCertifications[0].rawNotations,\n    (notation) => dataToVerify.find((i) => i.name === notation.name)?.value !== Buffer.from(notation.value).toString()\n  );\n  return !anyInvalidProof;\n}\n\n/**\n * Creates a proof through adding notation data to a GPG ceritifying signature.\n *\n * @param privateKeyArmored gpg private key in armor format of the sender\n * @param publicKeyToCertArmored gpg public key in armor fomrat of the reciever\n * @param notations data to be proofed\n * @return {string} keyshare proof\n */\nexport async function createSharedDataProof(\n  privateKeyArmored: string,\n  publicKeyToCertArmored: string,\n  notations: { name: string; value: string }[]\n): Promise<string> {\n  const certifyingKey = await pgp.readKey({ armoredKey: privateKeyArmored });\n  const publicKeyToCert = await pgp.readKey({ armoredKey: publicKeyToCertArmored });\n  const dateTime = new Date();\n  // UserId Packet.\n  const userIdPkt = new pgp.UserIDPacket();\n  const primaryUser = await publicKeyToCert.getPrimaryUser();\n  // @ts-ignore\n  userIdPkt.userID = primaryUser.user.userID.userID;\n  // Signature packet.\n  const signaturePacket = new pgp.SignaturePacket();\n  signaturePacket.signatureType = pgp.enums.signature.certPositive;\n  signaturePacket.publicKeyAlgorithm = pgp.enums.publicKey.ecdsa;\n  signaturePacket.hashAlgorithm = pgp.enums.hash.sha256;\n  // @ts-ignore\n  signaturePacket.issuerFingerprint = await primaryUser.user.mainKey.keyPacket.getFingerprintBytes();\n  // @ts-ignore\n  signaturePacket.issuerKeyID = primaryUser.user.mainKey.keyPacket.keyID;\n  // @ts-ignore\n  signaturePacket.signingKeyID = primaryUser.user.mainKey.keyPacket.keyID;\n  // @ts-ignore\n  signaturePacket.signersUserID = primaryUser.user.userID.userID;\n  // @ts-ignore\n  signaturePacket.features = [1];\n  notations.forEach(({ name, value }) => {\n    signaturePacket.rawNotations.push({\n      name: name,\n      value: new Uint8Array(Buffer.from(value)),\n      humanReadable: true,\n      critical: false,\n    });\n  });\n\n  // Prepare signing data.\n  const keydataToSign = {};\n  // @ts-ignore\n  keydataToSign.key = publicKeyToCert.keyPacket;\n  // @ts-ignore\n  keydataToSign.userID = userIdPkt;\n\n  // Sign the data (create certification).\n  // @ts-ignore\n  await signaturePacket.sign(certifyingKey.keyPacket, keydataToSign, dateTime);\n\n  // Assemble packets together.\n  const publicKeyToCertPkts = publicKeyToCert.toPacketList();\n  const newKeyPktList = new pgp.PacketList();\n  newKeyPktList.push(...publicKeyToCertPkts.slice(0, 3), signaturePacket, ...publicKeyToCertPkts.slice(3));\n  // @ts-ignore\n  const newPubKey = new pgp.PublicKey(newKeyPktList);\n  return newPubKey.armor().replace(/\\r\\n/g, '\\n');\n}\n\n/**\n * Creates a KeyShare Proof based on given algo.\n *\n * Creates an EdDSA KeyShare Proof by appending an ed25519 subkey (auth) to an armored gpg private key.\n * Creates an ECDSA KeyShare Proof by Append a secp256k1 subkey (auth) to a PGP keychain.\n *\n * @param privateArmor gpg private key in armor format\n * @param uValue u value from an Eddsa keyshare\n * @param algo algo to use, eddsa or ecdsa\n * @return {string} keyshare proof\n */\nexport async function createShareProof(privateArmor: string, uValue: string, algo: string): Promise<string> {\n  const privateKey = await readKey({ armoredKey: privateArmor });\n  const dateTime = new Date();\n  // @ts-ignore - type inconsistency, this ctor supports a date param: https://docs.openpgpjs.org/SecretSubkeyPacket.html\n  const secretSubkeyPacket = new pgp.SecretSubkeyPacket(dateTime);\n  secretSubkeyPacket.algorithm = pgp.enums.publicKey[algo];\n  // @ts-ignore - same as above\n  secretSubkeyPacket.isEncrypted = false;\n  let oid;\n  let Q;\n  if (algo === 'eddsa') {\n    await sodium.ready;\n    const subKeyVal = Buffer.from(\n      sodium.crypto_scalarmult_ed25519_base_noclamp(Buffer.from(uValue, 'hex'), 'uint8array')\n    );\n    // Sub-key (encryption key) packet.\n    oid = [0x2b, 0x06, 0x01, 0x04, 0x01, 0xda, 0x47, 0x0f, 0x01];\n    // @ts-ignore\n    oid.write = () => new Uint8Array(Buffer.from('092b06010401da470f01', 'hex'));\n    Q = new Uint8Array([0x40, ...subKeyVal]);\n  } else if (algo === 'ecdsa') {\n    oid = [0x2b, 0x81, 0x04, 0x00, 0x0a];\n    // @ts-ignore - same as above\n    oid.write = () => new Uint8Array(Buffer.from('052b8104000a', 'hex'));\n    Q = secp256k1.pointFromScalar(new Uint8Array(Buffer.from(uValue, 'hex')), false);\n  }\n  secretSubkeyPacket.publicParams = {\n    oid,\n    Q,\n  };\n  // @ts-ignore - same as above\n  await secretSubkeyPacket.computeFingerprintAndKeyID();\n\n  // Sub-key signature packet.\n  const subKeydataToSign = {\n    key: privateKey.keyPacket,\n    bind: secretSubkeyPacket,\n  };\n  const subkeySignaturePacket = new pgp.SignaturePacket();\n  subkeySignaturePacket.signatureType = pgp.enums.signature.subkeyBinding;\n  subkeySignaturePacket.publicKeyAlgorithm = pgp.enums.publicKey.ecdsa;\n  subkeySignaturePacket.hashAlgorithm = pgp.enums.hash.sha256;\n  subkeySignaturePacket.keyFlags = new Uint8Array([pgp.enums.keyFlags.authentication]);\n\n  // Sign the subkey\n  // @ts-ignore - sign supports arbitrary data for 2nd param: https://docs.openpgpjs.org/SignaturePacket.html\n  await subkeySignaturePacket.sign(privateKey.keyPacket, subKeydataToSign, dateTime);\n\n  // Assemble packets together.\n  const newKeyPktList = new pgp.PacketList();\n  const privateKeyPkts = privateKey.toPacketList();\n  privateKeyPkts.forEach((packet) => newKeyPktList.push(packet));\n  newKeyPktList.push(secretSubkeyPacket, subkeySignaturePacket);\n  // @ts-ignore - supports packet list as ctor param: https://docs.openpgpjs.org/PrivateKey.html\n  const newPubKey = new pgp.PrivateKey(newKeyPktList).toPublic();\n\n  if (!(await verifyPrimaryUserWrapper(newPubKey, privateKey, true))[0].valid) {\n    throw new Error('Incorrect signature');\n  }\n\n  return newPubKey.armor().replace(/\\r\\n/g, '\\n');\n}\n\n/**\n * Encrypts string using gpg key\n * @DEPRECATED - should use encryptAndSignText instead for added security\n *\n * @param text string to encrypt\n * @param key encryption key\n * @return {string} encrypted string\n *\n * TODO(BG-47170): Delete once gpg signatures are fully supported\n */\nexport async function encryptText(text: string, key: Key): Promise<string> {\n  const messageToEncrypt = await createMessage({\n    text,\n  });\n  return await encrypt({\n    message: messageToEncrypt,\n    encryptionKeys: [key],\n    format: 'armored',\n    config: {\n      rejectCurves: new Set(),\n      showVersion: false,\n      showComment: false,\n    },\n  });\n}\n\n/**\n * Encrypts and signs a string\n * @param text string to encrypt and sign\n * @param publicArmor public key to encrypt with\n * @param privateArmor private key to sign with\n */\nexport async function encryptAndSignText(text: string, publicArmor: string, privateArmor: string): Promise<string> {\n  const publicKey = await readKey({ armoredKey: publicArmor });\n  const privateKey = await readPrivateKey({ armoredKey: privateArmor });\n\n  const message = await createMessage({ text });\n\n  const signedMessage = await encrypt({\n    message,\n    encryptionKeys: publicKey,\n    signingKeys: privateKey,\n    format: 'armored',\n    config: {\n      rejectCurves: new Set(),\n      showVersion: false,\n      showComment: false,\n    },\n  });\n\n  return signedMessage;\n}\n\n/**\n * Reads a signed and encrypted message\n *\n * @param signed signed and encrypted message\n * @param publicArmor public key to verify signature\n * @param privateArmor private key to decrypt message\n */\nexport async function readSignedMessage(signed: string, publicArmor: string, privateArmor: string): Promise<string> {\n  const publicKey = await readKey({ armoredKey: publicArmor });\n  const privateKey = await readPrivateKey({ armoredKey: privateArmor });\n\n  const message = await readMessage({ armoredMessage: signed });\n  const decrypted = await decrypt({\n    message,\n    verificationKeys: publicKey,\n    decryptionKeys: privateKey,\n    expectSigned: true,\n    config: { rejectCurves: new Set() },\n  });\n\n  return decrypted.data;\n}\n\n/**\n * Generates a signature\n *\n * @param text string to generate a signature for\n * @param privateArmor private key as armored string\n * @return {string} armored signature string\n */\nexport async function signText(text: string, privateArmor: string): Promise<string> {\n  const privateKey = await readPrivateKey({ armoredKey: privateArmor });\n  const message = await createMessage({ text });\n  const signature = await sign({\n    message,\n    signingKeys: privateKey,\n    format: 'armored',\n    detached: true,\n  });\n\n  return signature;\n}\n\n/**\n * Verifies signature was generated by the public key and matches the expected text\n *\n * @param text text that the signature was for\n * @param armoredSignature signed message as an armored string\n * @param publicArmor public key that generated the signature\n */\nexport async function verifySignature(text: string, armoredSignature: string, publicArmor: string): Promise<boolean> {\n  const publicKey = await readKey({ armoredKey: publicArmor });\n  const signature = await readSignature({ armoredSignature });\n  const message = await createMessage({ text });\n  const verificationResult = await verify({\n    message,\n    signature,\n    verificationKeys: publicKey,\n  });\n\n  if (verificationResult.signatures.length !== 1) {\n    throw new Error('Invalid number of signatures');\n  }\n\n  try {\n    await verificationResult.signatures[0].verified;\n    return text === verificationResult.data;\n  } catch {\n    return false;\n  }\n}\n\n/**\n * Generate a GPG key pair\n *\n * @param: keyCurve the curve to create a key with\n * @param: username name of the user (optional)\n * @param: email email of the user (optional)\n */\nexport async function generateGPGKeyPair(\n  keyCurve: pgp.EllipticCurveName,\n  username?: string | undefined,\n  email?: string | undefined\n): Promise<pgp.SerializedKeyPair<string>> {\n  const randomHexString = crypto.randomBytes(12).toString('hex');\n  username = username ?? randomHexString;\n  email = email ?? `user-${randomHexString}@${randomHexString}.com`;\n\n  // Allow generating secp256k1 key pairs\n  pgp.config.rejectCurves = new Set();\n  const gpgKey = await pgp.generateKey({\n    userIDs: [\n      {\n        name: username,\n        email,\n      },\n    ],\n    curve: keyCurve,\n  });\n\n  return gpgKey;\n}\n"]}
458
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"opengpgUtils.js","sourceRoot":"","sources":["../../../../src/bitgo/utils/opengpgUtils.ts"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable @typescript-eslint/ban-ts-comment */\n\nimport * as pgp from 'openpgp';\nimport {\n  createMessage,\n  decrypt,\n  encrypt,\n  Key,\n  readKey,\n  readMessage,\n  readPrivateKey,\n  readSignature,\n  sign,\n  verify,\n} from 'openpgp';\nimport * as _ from 'lodash';\nimport { ecc as secp256k1 } from '@bitgo-beta/utxo-lib';\nimport { BitGoBase } from '../bitgoBase';\nimport crypto from 'crypto';\n\nconst sodium = require('libsodium-wrappers-sumo');\n\nexport type KeyValidityDict = {\n  keyID: pgp.KeyID;\n  valid: boolean | null;\n}[];\n\nexport type AuthEncMessage = {\n  encryptedMessage: string;\n  signature: string;\n};\n\n/**\n * Fetches BitGo's public gpg key used in MPC flows\n * @param {BitGoBase} bitgo BitGo object\n * @return {Key} public gpg key\n */\nexport async function getBitgoGpgPubKey(bitgo: BitGoBase): Promise<Key> {\n  const constants = await bitgo.fetchConstants();\n  if (!constants.mpc || !constants.mpc.bitgoPublicKey) {\n    throw new Error('Unable to create MPC keys - bitgoPublicKey is missing from constants');\n  }\n\n  const bitgoPublicKeyStr = constants.mpc.bitgoPublicKey as string;\n  return await readKey({ armoredKey: bitgoPublicKeyStr });\n}\n\n/**\n * Verifies the primary user on a GPG key using a reference key representing the user to be checked.\n * Allows a verification without a date check by wrapping verifyPrimaryUser of openpgp.\n * @param {Key} pubKey gpg key to check the primary user of.\n * @param {Key} primaryUser gpg key of the user to check.\n * @param {boolean} checkDates If false, disable date checks in the openpgp call to check the primary user.\n * @return {KeyValidityDict} list of users checked and whether each passed as a primary user in pubKey or not.\n */\nexport async function verifyPrimaryUserWrapper(\n  pubKey: Key,\n  primaryUser: Key,\n  checkDates: boolean\n): Promise<KeyValidityDict> {\n  if (checkDates) {\n    return await pubKey.verifyPrimaryUser([primaryUser]);\n  } else {\n    return await pubKey.verifyPrimaryUser([primaryUser], null as unknown as undefined);\n  }\n}\n\n/**\n * Fetches Trust pub key string\n * @param bitgo\n */\nexport async function getTrustGpgPubKey(bitgo: BitGoBase): Promise<Key> {\n  const constants = await bitgo.fetchConstants();\n  if (!constants.trustPubKey) {\n    throw new Error('Unable to get trustPubKey');\n  }\n  return readKey({ armoredKey: constants.trustPubKey });\n}\n\n/**\n * Verify an Eddsa or Ecdsa KeyShare Proof.\n *\n * @param senderPubKey public key of the sender of the privateShareProof\n * @param privateShareProof u value proof\n * @param uValue u value from an Eddsa keyshare\n * @param algo\n * @return {boolean} whether uValue proof actually was signed by sender as part of their subkeys\n */\nexport async function verifyShareProof(\n  senderPubKey: string,\n  privateShareProof: string,\n  uValue: string,\n  algo: 'eddsa' | 'ecdsa'\n): Promise<boolean> {\n  const decodedProof = await pgp.readKey({ armoredKey: privateShareProof });\n  const senderGpgKey = await pgp.readKey({ armoredKey: senderPubKey });\n  if (!(await verifyPrimaryUserWrapper(decodedProof, senderGpgKey, true))[0].valid) {\n    return false;\n  }\n  const proofSubkeys = decodedProof.getSubkeys()[1];\n  if (algo === 'eddsa') {\n    const decodedUValueProof = Buffer.from(proofSubkeys.keyPacket.publicParams['Q'].slice(1)).toString('hex');\n    const rawUValueProof = Buffer.from(\n      sodium.crypto_scalarmult_ed25519_base_noclamp(Buffer.from(uValue, 'hex'))\n    ).toString('hex');\n    return decodedUValueProof === rawUValueProof;\n  } else if (algo === 'ecdsa') {\n    const decodedUValueProof = Buffer.from(proofSubkeys.keyPacket.publicParams['Q']).toString('hex');\n    const rawUValueProof = secp256k1.pointFromScalar(Buffer.from(uValue, 'hex'), false);\n    return rawUValueProof !== null && decodedUValueProof === Buffer.from(rawUValueProof).toString('hex');\n  } else {\n    throw new Error('Invalid algorithm provided');\n  }\n}\n\n/**\n * Verify a shared data proof.\n *\n * @param senderPubKeyArm public key of the signer of the key with proof data\n * @param keyWithNotation signed reciever key with notation data\n * @param dataToVerify data to be checked against notation data in the signed key\n * @return {boolean} whether proof is valid\n */\nexport async function verifySharedDataProof(\n  senderPubKeyArm: string,\n  keyWithNotation: string,\n  dataToVerify: { name: string; value: string }[]\n): Promise<boolean> {\n  const senderPubKey = await pgp.readKey({ armoredKey: senderPubKeyArm });\n  const signedKey = await pgp.readKey({ armoredKey: keyWithNotation });\n  if (\n    !(await verifyPrimaryUserWrapper(signedKey, senderPubKey, true).then((values) =>\n      _.some(values, (value) => value.valid)\n    ))\n  ) {\n    return false;\n  }\n  const primaryUser = await signedKey.getPrimaryUser();\n  const anyInvalidProof = _.some(\n    // @ts-ignore\n    primaryUser.user.otherCertifications[0].rawNotations,\n    (notation) => dataToVerify.find((i) => i.name === notation.name)?.value !== Buffer.from(notation.value).toString()\n  );\n  return !anyInvalidProof;\n}\n\n/**\n * Creates a proof through adding notation data to a GPG ceritifying signature.\n *\n * @param privateKeyArmored gpg private key in armor format of the sender\n * @param publicKeyToCertArmored gpg public key in armor fomrat of the reciever\n * @param notations data to be proofed\n * @return {string} keyshare proof\n */\nexport async function createSharedDataProof(\n  privateKeyArmored: string,\n  publicKeyToCertArmored: string,\n  notations: { name: string; value: string }[]\n): Promise<string> {\n  const certifyingKey = await pgp.readKey({ armoredKey: privateKeyArmored });\n  const publicKeyToCert = await pgp.readKey({ armoredKey: publicKeyToCertArmored });\n  const dateTime = new Date();\n  // UserId Packet.\n  const userIdPkt = new pgp.UserIDPacket();\n  const primaryUser = await publicKeyToCert.getPrimaryUser();\n  // @ts-ignore\n  userIdPkt.userID = primaryUser.user.userID.userID;\n  // Signature packet.\n  const signaturePacket = new pgp.SignaturePacket();\n  signaturePacket.signatureType = pgp.enums.signature.certPositive;\n  signaturePacket.publicKeyAlgorithm = pgp.enums.publicKey.ecdsa;\n  signaturePacket.hashAlgorithm = pgp.enums.hash.sha256;\n  // @ts-ignore\n  signaturePacket.issuerFingerprint = await primaryUser.user.mainKey.keyPacket.getFingerprintBytes();\n  // @ts-ignore\n  signaturePacket.issuerKeyID = primaryUser.user.mainKey.keyPacket.keyID;\n  // @ts-ignore\n  signaturePacket.signingKeyID = primaryUser.user.mainKey.keyPacket.keyID;\n  // @ts-ignore\n  signaturePacket.signersUserID = primaryUser.user.userID.userID;\n  // @ts-ignore\n  signaturePacket.features = [1];\n  notations.forEach(({ name, value }) => {\n    signaturePacket.rawNotations.push({\n      name: name,\n      value: new Uint8Array(Buffer.from(value)),\n      humanReadable: true,\n      critical: false,\n    });\n  });\n\n  // Prepare signing data.\n  const keydataToSign = {};\n  // @ts-ignore\n  keydataToSign.key = publicKeyToCert.keyPacket;\n  // @ts-ignore\n  keydataToSign.userID = userIdPkt;\n\n  // Sign the data (create certification).\n  // @ts-ignore\n  await signaturePacket.sign(certifyingKey.keyPacket, keydataToSign, dateTime);\n\n  // Assemble packets together.\n  const publicKeyToCertPkts = publicKeyToCert.toPacketList();\n  const newKeyPktList = new pgp.PacketList();\n  newKeyPktList.push(...publicKeyToCertPkts.slice(0, 3), signaturePacket, ...publicKeyToCertPkts.slice(3));\n  // @ts-ignore\n  const newPubKey = new pgp.PublicKey(newKeyPktList);\n  return newPubKey.armor().replace(/\\r\\n/g, '\\n');\n}\n\n/**\n * Creates a KeyShare Proof based on given algo.\n *\n * Creates an EdDSA KeyShare Proof by appending an ed25519 subkey (auth) to an armored gpg private key.\n * Creates an ECDSA KeyShare Proof by Append a secp256k1 subkey (auth) to a PGP keychain.\n *\n * @param privateArmor gpg private key in armor format\n * @param uValue u value from an Eddsa keyshare\n * @param algo algo to use, eddsa or ecdsa\n * @return {string} keyshare proof\n */\nexport async function createShareProof(privateArmor: string, uValue: string, algo: string): Promise<string> {\n  const privateKey = await readKey({ armoredKey: privateArmor });\n  const dateTime = new Date();\n  // @ts-ignore - type inconsistency, this ctor supports a date param: https://docs.openpgpjs.org/SecretSubkeyPacket.html\n  const secretSubkeyPacket = new pgp.SecretSubkeyPacket(dateTime);\n  secretSubkeyPacket.algorithm = pgp.enums.publicKey[algo];\n  // @ts-ignore - same as above\n  secretSubkeyPacket.isEncrypted = false;\n  let oid;\n  let Q;\n  if (algo === 'eddsa') {\n    await sodium.ready;\n    const subKeyVal = Buffer.from(\n      sodium.crypto_scalarmult_ed25519_base_noclamp(Buffer.from(uValue, 'hex'), 'uint8array')\n    );\n    // Sub-key (encryption key) packet.\n    oid = [0x2b, 0x06, 0x01, 0x04, 0x01, 0xda, 0x47, 0x0f, 0x01];\n    // @ts-ignore\n    oid.write = () => new Uint8Array(Buffer.from('092b06010401da470f01', 'hex'));\n    Q = new Uint8Array([0x40, ...subKeyVal]);\n  } else if (algo === 'ecdsa') {\n    oid = [0x2b, 0x81, 0x04, 0x00, 0x0a];\n    // @ts-ignore - same as above\n    oid.write = () => new Uint8Array(Buffer.from('052b8104000a', 'hex'));\n    Q = secp256k1.pointFromScalar(new Uint8Array(Buffer.from(uValue, 'hex')), false);\n  }\n  secretSubkeyPacket.publicParams = {\n    oid,\n    Q,\n  };\n  // @ts-ignore - same as above\n  await secretSubkeyPacket.computeFingerprintAndKeyID();\n\n  // Sub-key signature packet.\n  const subKeydataToSign = {\n    key: privateKey.keyPacket,\n    bind: secretSubkeyPacket,\n  };\n  const subkeySignaturePacket = new pgp.SignaturePacket();\n  subkeySignaturePacket.signatureType = pgp.enums.signature.subkeyBinding;\n  subkeySignaturePacket.publicKeyAlgorithm = pgp.enums.publicKey.ecdsa;\n  subkeySignaturePacket.hashAlgorithm = pgp.enums.hash.sha256;\n  subkeySignaturePacket.keyFlags = new Uint8Array([pgp.enums.keyFlags.authentication]);\n\n  // Sign the subkey\n  // @ts-ignore - sign supports arbitrary data for 2nd param: https://docs.openpgpjs.org/SignaturePacket.html\n  await subkeySignaturePacket.sign(privateKey.keyPacket, subKeydataToSign, dateTime);\n\n  // Assemble packets together.\n  const newKeyPktList = new pgp.PacketList();\n  const privateKeyPkts = privateKey.toPacketList();\n  privateKeyPkts.forEach((packet) => newKeyPktList.push(packet));\n  newKeyPktList.push(secretSubkeyPacket, subkeySignaturePacket);\n  // @ts-ignore - supports packet list as ctor param: https://docs.openpgpjs.org/PrivateKey.html\n  const newPubKey = new pgp.PrivateKey(newKeyPktList).toPublic();\n\n  if (!(await verifyPrimaryUserWrapper(newPubKey, privateKey, true))[0].valid) {\n    throw new Error('Incorrect signature');\n  }\n\n  return newPubKey.armor().replace(/\\r\\n/g, '\\n');\n}\n\n/**\n * Encrypts string using gpg key\n * @DEPRECATED - should use encryptAndSignText instead for added security\n *\n * @param text string to encrypt\n * @param key encryption key\n * @return {string} encrypted string\n *\n * TODO(BG-47170): Delete once gpg signatures are fully supported\n */\nexport async function encryptText(text: string, key: Key): Promise<string> {\n  const messageToEncrypt = await createMessage({\n    text,\n  });\n  return await encrypt({\n    message: messageToEncrypt,\n    encryptionKeys: [key],\n    format: 'armored',\n    config: {\n      rejectCurves: new Set(),\n      showVersion: false,\n      showComment: false,\n    },\n  });\n}\n\n/**\n * Encrypts and detach signs a string\n * @param text string to encrypt and sign\n * @param publicArmor public key to encrypt with\n * @param privateArmor private key to sign with\n */\nexport async function encryptAndDetachSignText(\n  text: string,\n  publicArmor: string,\n  privateArmor: string\n): Promise<AuthEncMessage> {\n  const publicKey = await readKey({ armoredKey: publicArmor });\n  const privateKey = await readPrivateKey({ armoredKey: privateArmor });\n  const message = await createMessage({ text });\n  const encryptedMessage = await encrypt({\n    message,\n    encryptionKeys: publicKey,\n    format: 'armored',\n    config: {\n      rejectCurves: new Set(),\n      showVersion: false,\n      showComment: false,\n    },\n  });\n  const signature = await sign({\n    message,\n    signingKeys: privateKey,\n    format: 'armored',\n    detached: true,\n    config: {\n      rejectCurves: new Set(),\n      showVersion: false,\n      showComment: false,\n    },\n  });\n  return {\n    encryptedMessage: encryptedMessage,\n    signature: signature,\n  };\n}\n\n/**\n * Encrypts and detach signs a string\n * @param text string to encrypt and sign\n * @param publicArmor public key to verify signature with\n * @param privateArmor private key to decrypt with\n */\nexport async function decryptAndVerifySignedText(\n  encryptedAndSignedMessage: AuthEncMessage,\n  publicArmor: string,\n  privateArmor: string\n): Promise<string> {\n  const publicKey = await readKey({ armoredKey: publicArmor });\n  const privateKey = await readPrivateKey({ armoredKey: privateArmor });\n  const decryptedMessage = await decrypt({\n    message: await readMessage({ armoredMessage: encryptedAndSignedMessage.encryptedMessage }),\n    decryptionKeys: privateKey,\n    signature: await readSignature({ armoredSignature: encryptedAndSignedMessage.signature }),\n    verificationKeys: publicKey,\n    expectSigned: true,\n    config: {\n      rejectCurves: new Set(),\n      showVersion: false,\n      showComment: false,\n    },\n  });\n  return decryptedMessage.data;\n}\n\n/**\n * Encrypts and signs a string\n * @param text string to encrypt and sign\n * @param publicArmor public key to encrypt with\n * @param privateArmor private key to sign with\n */\nexport async function encryptAndSignText(text: string, publicArmor: string, privateArmor: string): Promise<string> {\n  const publicKey = await readKey({ armoredKey: publicArmor });\n  const privateKey = await readPrivateKey({ armoredKey: privateArmor });\n\n  const message = await createMessage({ text });\n\n  const signedMessage = await encrypt({\n    message,\n    encryptionKeys: publicKey,\n    signingKeys: privateKey,\n    format: 'armored',\n    config: {\n      rejectCurves: new Set(),\n      showVersion: false,\n      showComment: false,\n    },\n  });\n\n  return signedMessage;\n}\n\n/**\n * Reads a signed and encrypted message\n *\n * @param signed signed and encrypted message\n * @param publicArmor public key to verify signature\n * @param privateArmor private key to decrypt message\n */\nexport async function readSignedMessage(signed: string, publicArmor: string, privateArmor: string): Promise<string> {\n  const publicKey = await readKey({ armoredKey: publicArmor });\n  const privateKey = await readPrivateKey({ armoredKey: privateArmor });\n\n  const message = await readMessage({ armoredMessage: signed });\n  const decrypted = await decrypt({\n    message,\n    verificationKeys: publicKey,\n    decryptionKeys: privateKey,\n    expectSigned: true,\n    config: { rejectCurves: new Set() },\n  });\n\n  return decrypted.data;\n}\n\n/**\n * Generates a signature\n *\n * @param text string to generate a signature for\n * @param privateArmor private key as armored string\n * @return {string} armored signature string\n */\nexport async function signText(text: string, privateArmor: string): Promise<string> {\n  const privateKey = await readPrivateKey({ armoredKey: privateArmor });\n  const message = await createMessage({ text });\n  const signature = await sign({\n    message,\n    signingKeys: privateKey,\n    format: 'armored',\n    detached: true,\n  });\n\n  return signature;\n}\n\n/**\n * Verifies signature was generated by the public key and matches the expected text\n *\n * @param text text that the signature was for\n * @param armoredSignature signed message as an armored string\n * @param publicArmor public key that generated the signature\n */\nexport async function verifySignature(text: string, armoredSignature: string, publicArmor: string): Promise<boolean> {\n  const publicKey = await readKey({ armoredKey: publicArmor });\n  const signature = await readSignature({ armoredSignature });\n  const message = await createMessage({ text });\n  const verificationResult = await verify({\n    message,\n    signature,\n    verificationKeys: publicKey,\n  });\n\n  if (verificationResult.signatures.length !== 1) {\n    throw new Error('Invalid number of signatures');\n  }\n\n  try {\n    await verificationResult.signatures[0].verified;\n    return text === verificationResult.data;\n  } catch {\n    return false;\n  }\n}\n\n/**\n * Generate a GPG key pair\n *\n * @param: keyCurve the curve to create a key with\n * @param: username name of the user (optional)\n * @param: email email of the user (optional)\n */\nexport async function generateGPGKeyPair(\n  keyCurve: pgp.EllipticCurveName,\n  username?: string | undefined,\n  email?: string | undefined\n): Promise<pgp.SerializedKeyPair<string>> {\n  const randomHexString = crypto.randomBytes(12).toString('hex');\n  username = username ?? randomHexString;\n  email = email ?? `user-${randomHexString}@${randomHexString}.com`;\n\n  // Allow generating secp256k1 key pairs\n  pgp.config.rejectCurves = new Set();\n  const gpgKey = await pgp.generateKey({\n    userIDs: [\n      {\n        name: username,\n        email,\n      },\n    ],\n    curve: keyCurve,\n  });\n\n  return gpgKey;\n}\n"]}