From 5ae0af7bf468511e9a7d12c8d905facc1feee0c5 Mon Sep 17 00:00:00 2001 From: Iveta Date: Wed, 28 Oct 2020 09:58:34 -0400 Subject: [PATCH] Trezor: custom prop to add manifest (#182) * Trezor: custom prop to add manifest * Require custom prop to be an object + changelog updates --- CHANGELOG.md | 8 +++++++- package.json | 4 ++-- src/KeyManager.ts | 6 +++++- src/keyTypeHandlers/trezor.ts | 14 +++++++++++++- src/types/keys.ts | 3 +++ 5 files changed, 30 insertions(+), 5 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 0e6773ee..d988c815 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -1,6 +1,12 @@ ## In master -## [v0.3.0-rc.1] +## [v0.3.0-rc.2] + +- [KeyManager] Added optional `custom` prop to `signTransaction()` to allow + passing additional info. +- [KeyManager] Trezor wallet: pass manifest info through `custom` prop. + +## [v0.3.0-rc.1](https://github.com/stellar/js-stellar-wallets/compare/v0.2.0-rc.2...v0.3.0-rc.1) **Breaking changes**: diff --git a/package.json b/package.json index a4bd1484..31acd70a 100644 --- a/package.json +++ b/package.json @@ -1,6 +1,6 @@ { "name": "@stellar/wallet-sdk", - "version": "0.3.0-rc.1", + "version": "0.3.0-rc.2", "description": "Libraries to help you write Stellar-enabled wallets in Javascript", "main": "dist/index.js", "types": "dist/index.d.ts", @@ -87,7 +87,7 @@ "lodash": "^4.17.14", "query-string": "^6.4.2", "scrypt-async": "^2.0.1", - "trezor-connect": "^8.1.9", + "trezor-connect": "^8.1.16", "tweetnacl": "^1.0.1", "tweetnacl-util": "^0.15.0" } diff --git a/src/KeyManager.ts b/src/KeyManager.ts index 059186aa..f1908759 100644 --- a/src/KeyManager.ts +++ b/src/KeyManager.ts @@ -36,6 +36,9 @@ export interface SignTransactionParams { transaction: Transaction; id: string; password: string; + custom?: { + [key: string]: any; + }; } export interface ChangePasswordParams { @@ -236,7 +239,7 @@ export class KeyManager { public async signTransaction( params: SignTransactionParams, ): Promise { - const { transaction, id, password } = params; + const { transaction, id, password, custom } = params; let key = this._readFromCache(id); if (!key) { @@ -257,6 +260,7 @@ export class KeyManager { const signedTransaction = await keyHandler.signTransaction({ transaction, key, + custom, }); return signedTransaction; } diff --git a/src/keyTypeHandlers/trezor.ts b/src/keyTypeHandlers/trezor.ts index 5d09f088..9f6b45e8 100644 --- a/src/keyTypeHandlers/trezor.ts +++ b/src/keyTypeHandlers/trezor.ts @@ -8,7 +8,7 @@ import { transformTransaction } from "../helpers/trezorTransformTransaction"; export const trezorHandler: KeyTypeHandler = { keyType: KeyType.trezor, async signTransaction(params: HandlerSignTransactionParams) { - const { transaction, key } = params; + const { transaction, key, custom } = params; if (key.privateKey !== "") { throw new Error( @@ -18,7 +18,19 @@ export const trezorHandler: KeyTypeHandler = { ); } + if (!custom || !custom.email || !custom.appUrl) { + throw new Error( + `Trezor Connect manifest with "email" and "appUrl" props is required. + Make sure they are passed through "custom" prop.`, + ); + } + try { + TrezorConnect.manifest({ + email: custom.email, + appUrl: custom.appUrl, + }); + const trezorParams = transformTransaction("m/44'/148'/0'", transaction); const response = await TrezorConnect.stellarSignTransaction(trezorParams); diff --git a/src/types/keys.ts b/src/types/keys.ts index 52943de7..1b09b826 100644 --- a/src/types/keys.ts +++ b/src/types/keys.ts @@ -145,6 +145,9 @@ export interface KeyStore { export interface HandlerSignTransactionParams { transaction: Transaction; key: Key; + custom?: { + [key: string]: any; + }; } /**