@rango-dev/provider-ledger 0.4.1-next.6 → 0.4.1-next.7
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/dist/helpers.d.ts.map +1 -1
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +1 -1
- package/dist/index.js.map +4 -4
- package/dist/provider-ledger.build.json +1 -1
- package/dist/state.d.ts +3 -0
- package/dist/state.d.ts.map +1 -0
- package/package.json +2 -2
- package/src/helpers.ts +4 -2
- package/src/index.ts +36 -3
- package/src/signers/ethereum.ts +2 -2
- package/src/signers/solana.ts +4 -4
- package/src/state.ts +10 -0
package/dist/helpers.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"helpers.d.ts","sourceRoot":"","sources":["../src/helpers.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,SAAS,MAAM,wBAAwB,CAAC;
|
|
1
|
+
{"version":3,"file":"helpers.d.ts","sourceRoot":"","sources":["../src/helpers.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,SAAS,MAAM,wBAAwB,CAAC;AAQpD,eAAO,MAAM,cAAc,mBAAmB,CAAC;AAC/C,eAAO,MAAM,iBAAiB,gBAAgB,CAAC;AAE/C,eAAO,MAAM,gBAAgB,KAAK,CAAC;AAoBnC,wBAAgB,cAAc,CAAC,KAAK,EAAE,GAAG,OASxC;AAED,wBAAgB,iBAAiB,kBAWhC;AAED,wBAAsB,mBAAmB,IAAI,OAAO,CAAC;IACnD,QAAQ,EAAE,MAAM,EAAE,CAAC;IACnB,OAAO,EAAE,MAAM,CAAC;CACjB,CAAC,CAoBD;AAED,wBAAsB,iBAAiB,IAAI,OAAO,CAAC;IACjD,QAAQ,EAAE,MAAM,EAAE,CAAC;IACnB,OAAO,EAAE,MAAM,CAAC;CACjB,CAAC,CAsBD;AAID,wBAAsB,gBAAgB,uBAMrC;AAED,wBAAsB,mBAAmB,kBAKxC"}
|
package/dist/index.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EACV,OAAO,EACP,UAAU,
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EACV,OAAO,EACP,UAAU,EAEV,UAAU,EACX,MAAM,2BAA2B,CAAC;AAEnC,OAAO,EAAuB,WAAW,EAAE,MAAM,2BAA2B,CAAC;AAC7E,OAAO,EAAE,KAAK,cAAc,EAAE,KAAK,aAAa,EAAE,MAAM,aAAa,CAAC;AAEtE,OAAO,EAEL,iBAAiB,EAGlB,MAAM,WAAW,CAAC;AAInB,eAAO,MAAM,MAAM;;CAElB,CAAC;AAEF,eAAO,MAAM,WAAW,0BAAoB,CAAC;AAC7C,eAAO,MAAM,OAAO,EAAE,OAmCrB,CAAC;AAEF,eAAO,MAAM,UAAU,EAAE,UAExB,CAAC;AAEF,eAAO,MAAM,UAAU,EAAE,CAAC,QAAQ,EAAE,GAAG,KAAK,aAAsB,CAAC;AAEnE,eAAO,MAAM,aAAa,EAAE,CAAC,cAAc,EAAE,cAAc,EAAE,KAAK,UAiCjE,CAAC"}
|
package/dist/index.js
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
var k=Object.defineProperty;var
|
|
1
|
+
var k=Object.defineProperty;var r=(t,n)=>k(t,"name",{value:n,configurable:!0});import{Namespace as h,Networks as F,WalletTypes as $}from"@rango-dev/wallets-shared";import{getAltStatusMessage as x}from"@ledgerhq/errors";import{ETHEREUM_CHAIN_ID as L,Networks as u}from"@rango-dev/wallets-shared";import U from"bs58";var P="";function T(t){P=t}r(T,"setDerivationPath");function s(){return P}r(s,"getDerivationPath");var _=16,A={21781:"The device is locked",25871:"Related application is not ready on your device",27013:"Action denied by user"};function B(t){return A[t]?A[t]:x(t)?x(t):`Ledger device unknown error 0x${t.toString(_)}`}r(B,"getLedgerErrorMessage");function g(t){return t?.statusCode?new Error(B(t.statusCode)):t?.code==="INSUFFICIENT_FUNDS"?new Error("Insufficient funds for transaction"):t}r(g,"getLedgerError");function D(){let t=new Map;return t.set(u.ETHEREUM,{chainId:L}),t.set(u.SOLANA,{chainId:u.SOLANA}),t}r(D,"getLedgerInstance");async function I(){try{let t=await m(),n=new(await import("@ledgerhq/hw-app-eth")).default(t),a=[],o=await n.getAddress(s(),!1,!0);return a.push(o.address),{accounts:a,chainId:L}}catch(t){throw g(t)}finally{await i()}}r(I,"getEthereumAccounts");async function M(){try{let t=await m(),n=new(await import("@ledgerhq/hw-app-solana")).default(t),a=[],o=await n.getAddress(s());return a.push(U.encode(o.address)),{accounts:a,chainId:u.SOLANA}}catch(t){throw g(t)}finally{await i()}}r(M,"getSolanaAccounts");var l=null;async function m(){return l=await(await import("@ledgerhq/hw-transport-webhid")).default.create(),l}r(m,"transportConnect");async function i(){l&&(await l.close(),l=null)}r(i,"transportDisconnect");import{DefaultSignerFactory as W,TransactionType as N}from"rango-types";import{DEFAULT_ETHEREUM_RPC_URL as G}from"@rango-dev/wallets-shared";import{JsonRpcProvider as H,Transaction as b}from"ethers";import{SignerError as z}from"rango-types";var d=class{static{r(this,"EthereumSigner")}async signMessage(){throw z.UnimplementedError("signMessage")}async signAndSendTx(n,a,o){try{let e=new H(G),w=await e.getTransactionCount(a),c={to:n.to,gasPrice:n.gasPrice,gasLimit:n.gasLimit,nonce:w,chainId:o,data:n.data,value:n.value,maxPriorityFeePerGas:n.maxPriorityFeePerGas,maxFeePerGas:n.maxFeePerGas},p=b.from(c).unsignedSerialized.substring(2),y=await(await import("@ledgerhq/hw-app-eth")).ledgerService.resolveTransaction(p,{},{}),S=await m(),E=await new(await import("@ledgerhq/hw-app-eth")).default(S).signTransaction(s(),p,y),C=b.from({...c,signature:{r:"0x"+E.r,s:"0x"+E.s,v:parseInt(E.v)}}).serialized;return{hash:(await e.broadcastTransaction(C)).hash}}catch(e){throw g(e)}finally{await i()}}};import{generalSolanaTransactionExecutor as O}from"@rango-dev/signer-solana";import{PublicKey as V}from"@solana/web3.js";import{SignerError as q}from"rango-types";function K(t){return"version"in t}r(K,"isVersionedTransaction");var f=class{static{r(this,"SolanaSigner")}async signMessage(){throw q.UnimplementedError("signMessage")}async signAndSendTx(n){try{return{hash:await O(n,r(async e=>{let w=await m(),c=new(await import("@ledgerhq/hw-app-solana")).default(w),p;K(e)?p=await c.signTransaction(s(),e.message.serialize()):p=await c.signTransaction(s(),e.serialize());let y=await c.getAddress(s()),S=new V(y.address);return e.addSignature(S,Buffer.from(p.signature)),e.serialize()},"DefaultSolanaSigner"))}}catch(a){throw g(a)}finally{await i()}}};function v(){let t=new W;return t.registerSigner(N.EVM,new d),t.registerSigner(N.SOLANA,new f),t}r(v,"getSigners");var Dt={type:$.LEDGER},It=D,Mt=r(async({namespaces:t})=>{let n=[],a=t?.find(e=>e.namespace===h.Solana),o=t?.find(e=>e.namespace===h.Evm);if(a)if(a.derivationPath){T(a.derivationPath);let e=await M();n.push(e)}else throw new Error("Derivation Path can not be empty.");else if(o)if(o.derivationPath){T(o.derivationPath);let e=await I();n.push(e)}else throw new Error("Derivation Path can not be empty.");else throw new Error(`It appears that you have selected a namespace that is not yet supported by our system. Your namespaces: ${t?.map(e=>e.namespace)}`);return n},"connect"),bt=r(async()=>{i()},"disconnect"),Nt=v,Ft=r(t=>{let n=[],a=t.find(e=>e.name===F.ETHEREUM);a&&n.push(a);let o=t.find(e=>e.name===F.SOLANA);return o&&n.push(o),{name:"Ledger",img:"https://raw.githubusercontent.com/rango-exchange/assets/main/wallets/ledger/icon.svg",installLink:{DEFAULT:"https://support.ledger.com/hc/en-us/articles/4404389606417-Download-and-install-Ledger-Live?docs=true"},color:"black",supportedChains:n,namespaces:[h.Evm,h.Solana],singleNamespace:!0,showOnMobile:!1,needsDerivationPath:!0}},"getWalletInfo");export{Dt as config,Mt as connect,bt as disconnect,It as getInstance,Nt as getSigners,Ft as getWalletInfo};
|
|
2
2
|
//# sourceMappingURL=index.js.map
|
package/dist/index.js.map
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
|
-
"sources": ["../src/index.ts", "../src/helpers.ts", "../src/signer.ts", "../src/signers/ethereum.ts", "../src/signers/solana.ts"],
|
|
4
|
-
"sourcesContent": ["import type {\n Connect,\n Disconnect,\n WalletInfo,\n} from '@rango-dev/wallets-shared';\n\nimport { Namespace, Networks, WalletTypes } from '@rango-dev/wallets-shared';\nimport { type BlockchainMeta, type SignerFactory } from 'rango-types';\n\nimport {\n getEthereumAccounts,\n getLedgerInstance,\n getSolanaAccounts,\n transportDisconnect,\n} from './helpers';\nimport signer from './signer';\n\nexport const config = {\n type: WalletTypes.LEDGER,\n};\n\nexport const getInstance = getLedgerInstance;\nexport const connect: Connect = async ({ namespaces }) => {\n if (namespaces?.includes(Namespace.Solana)) {\n return await getSolanaAccounts();\n }\n return await getEthereumAccounts();\n};\n\nexport const disconnect: Disconnect = async () => {\n void transportDisconnect();\n};\n\nexport const getSigners: (provider: any) => SignerFactory = signer;\n\nexport const getWalletInfo: (allBlockChains: BlockchainMeta[]) => WalletInfo = (\n allBlockChains\n) => {\n const supportedChains: BlockchainMeta[] = [];\n\n const ethereumBlockchain = allBlockChains.find(\n (chain) => chain.name === Networks.ETHEREUM\n );\n if (ethereumBlockchain) {\n supportedChains.push(ethereumBlockchain);\n }\n\n const solanaBlockchain = allBlockChains.find(\n (chain) => chain.name === Networks.SOLANA\n );\n if (solanaBlockchain) {\n supportedChains.push(solanaBlockchain);\n }\n\n return {\n name: 'Ledger',\n img: 'https://raw.githubusercontent.com/rango-exchange/assets/main/wallets/ledger/icon.svg',\n installLink: {\n DEFAULT:\n 'https://support.ledger.com/hc/en-us/articles/4404389606417-Download-and-install-Ledger-Live?docs=true',\n },\n color: 'black',\n supportedChains,\n namespaces: [Namespace.Evm, Namespace.Solana],\n singleNamespace: true,\n showOnMobile: false,\n };\n};\n", "import type Transport from '@ledgerhq/hw-transport';\n\nimport { getAltStatusMessage } from '@ledgerhq/errors';\nimport { ETHEREUM_CHAIN_ID, Networks } from '@rango-dev/wallets-shared';\nimport bs58 from 'bs58';\n\nexport const ETH_BIP32_PATH = \"44'/60'/0'/0/0\";\nexport const SOLANA_BIP32_PATH = \"44'/501'/0'\";\n\nexport const HEXADECIMAL_BASE = 16;\n\nconst ledgerFrequentErrorMessages: { [statusCode: number]: string } = {\n 0x5515: 'The device is locked',\n 0x650f: 'Related application is not ready on your device',\n 0x6985: 'Action denied by user',\n};\n\nfunction getLedgerErrorMessage(statusCode: number): string {\n if (ledgerFrequentErrorMessages[statusCode]) {\n return ledgerFrequentErrorMessages[statusCode];\n } else if (getAltStatusMessage(statusCode)) {\n return getAltStatusMessage(statusCode) as string;\n }\n\n return `Ledger device unknown error 0x${statusCode.toString(\n HEXADECIMAL_BASE\n )}`; // Hexadecimal numbers are more commonly recognized and utilized for representing ledger error codes\n}\n\nexport function getLedgerError(error: any) {\n if (error?.statusCode) {\n return new Error(getLedgerErrorMessage(error.statusCode));\n }\n\n if (error?.code === 'INSUFFICIENT_FUNDS') {\n return new Error('Insufficient funds for transaction');\n }\n return error;\n}\n\nexport function getLedgerInstance() {\n /*\n * Instances have a required property which is `chainId` and is using in swap execution.\n * Here we are setting it as Ethereum always since we are supporting only eth for now.\n */\n const instances = new Map();\n\n instances.set(Networks.ETHEREUM, { chainId: ETHEREUM_CHAIN_ID });\n instances.set(Networks.SOLANA, { chainId: Networks.SOLANA });\n\n return instances;\n}\n\nexport async function getEthereumAccounts(): Promise<{\n accounts: string[];\n chainId: string;\n}> {\n try {\n const transport = await transportConnect();\n\n const eth = new (await import('@ledgerhq/hw-app-eth')).default(transport);\n\n const accounts: string[] = [];\n\n const result = await eth.getAddress(ETH_BIP32_PATH, false, true);\n accounts.push(result.address);\n\n return {\n accounts: accounts,\n chainId: ETHEREUM_CHAIN_ID,\n };\n } catch (error: any) {\n throw getLedgerError(error);\n } finally {\n await transportDisconnect();\n }\n}\n\nexport async function getSolanaAccounts(): Promise<{\n accounts: string[];\n chainId: string;\n}> {\n try {\n const transport = await transportConnect();\n\n const solana = new (await import('@ledgerhq/hw-app-solana')).default(\n transport\n );\n\n const accounts: string[] = [];\n\n const result = await solana.getAddress(SOLANA_BIP32_PATH);\n accounts.push(bs58.encode(result.address));\n\n return {\n accounts: accounts,\n chainId: Networks.SOLANA,\n };\n } catch (error: any) {\n throw getLedgerError(error);\n } finally {\n await transportDisconnect();\n }\n}\n\nlet transportConnection: Transport | null = null;\n\nexport async function transportConnect() {\n transportConnection = await (\n await import('@ledgerhq/hw-transport-webhid')\n ).default.create();\n\n return transportConnection;\n}\n\nexport async function transportDisconnect() {\n if (transportConnection) {\n await transportConnection.close();\n transportConnection = null;\n }\n}\n", "import type { SignerFactory } from 'rango-types';\n\nimport { DefaultSignerFactory, TransactionType as TxType } from 'rango-types';\n\nimport { EthereumSigner } from './signers/ethereum';\nimport { SolanaSigner } from './signers/solana';\n\nexport default function getSigners(): SignerFactory {\n const signers = new DefaultSignerFactory();\n signers.registerSigner(TxType.EVM, new EthereumSigner());\n signers.registerSigner(TxType.SOLANA, new SolanaSigner());\n return signers;\n}\n", "import type { TransactionLike } from 'ethers';\nimport type { GenericSigner } from 'rango-types';\nimport type { EvmTransaction } from 'rango-types/lib/api/main';\n\nimport { DEFAULT_ETHEREUM_RPC_URL } from '@rango-dev/wallets-shared';\nimport { JsonRpcProvider, Transaction } from 'ethers';\nimport { SignerError } from 'rango-types';\n\nimport {\n ETH_BIP32_PATH,\n getLedgerError,\n transportConnect,\n transportDisconnect,\n} from '../helpers';\n\nexport class EthereumSigner implements GenericSigner<EvmTransaction> {\n async signMessage(): Promise<string> {\n // TODO: Should be implemented using eth.signPersonalMessage\n throw SignerError.UnimplementedError('signMessage');\n }\n\n async signAndSendTx(\n tx: EvmTransaction,\n fromAddress: string,\n chainId: string | null\n ): Promise<{ hash: string }> {\n try {\n const provider = new JsonRpcProvider(DEFAULT_ETHEREUM_RPC_URL); // Provider to broadcast transaction\n\n const transactionCount = await provider.getTransactionCount(fromAddress); // Get nonce\n\n const transaction: TransactionLike<string> = {\n to: tx.to,\n gasPrice: tx.gasPrice,\n gasLimit: tx.gasLimit,\n nonce: transactionCount,\n chainId: chainId,\n data: tx.data,\n value: tx.value,\n maxPriorityFeePerGas: tx.maxPriorityFeePerGas,\n maxFeePerGas: tx.maxFeePerGas,\n };\n\n const unsignedTx =\n Transaction.from(transaction).unsignedSerialized.substring(2); // Create unsigned transaction\n\n const resolution = await (\n await import('@ledgerhq/hw-app-eth')\n ).ledgerService.resolveTransaction(unsignedTx, {}, {}); // metadata necessary to allow the device to clear sign information\n\n const transport = await transportConnect();\n\n const eth = new (await import('@ledgerhq/hw-app-eth')).default(transport);\n\n const signature = await eth.signTransaction(\n ETH_BIP32_PATH,\n unsignedTx,\n resolution\n );\n\n const signedTx = Transaction.from({\n ...transaction,\n signature: {\n r: '0x' + signature.r,\n s: '0x' + signature.s,\n v: parseInt(signature.v),\n },\n }).serialized;\n\n const broadcastResult = await provider.broadcastTransaction(signedTx);\n\n return { hash: broadcastResult.hash };\n } catch (error) {\n throw getLedgerError(error);\n } finally {\n await transportDisconnect();\n }\n }\n}\n", "import type { SolanaWeb3Signer } from '@rango-dev/signer-solana';\nimport type { Transaction, VersionedTransaction } from '@solana/web3.js';\nimport type { GenericSigner, SolanaTransaction } from 'rango-types';\n\nimport { generalSolanaTransactionExecutor } from '@rango-dev/signer-solana';\nimport { PublicKey } from '@solana/web3.js';\nimport { SignerError } from 'rango-types';\n\nimport {\n getLedgerError,\n SOLANA_BIP32_PATH,\n transportConnect,\n transportDisconnect,\n} from '../helpers';\n\nexport function isVersionedTransaction(\n transaction: Transaction | VersionedTransaction\n): transaction is VersionedTransaction {\n return 'version' in transaction;\n}\n\nexport class SolanaSigner implements GenericSigner<SolanaTransaction> {\n async signMessage(): Promise<string> {\n throw SignerError.UnimplementedError('signMessage');\n }\n\n async signAndSendTx(tx: SolanaTransaction): Promise<{ hash: string }> {\n try {\n const DefaultSolanaSigner: SolanaWeb3Signer = async (\n solanaWeb3Transaction: Transaction | VersionedTransaction\n ) => {\n const transport = await transportConnect();\n const solana = new (await import('@ledgerhq/hw-app-solana')).default(\n transport\n );\n\n let signResult;\n if (isVersionedTransaction(solanaWeb3Transaction)) {\n signResult = await solana.signTransaction(\n SOLANA_BIP32_PATH,\n solanaWeb3Transaction.message.serialize() as Buffer\n );\n } else {\n signResult = await solana.signTransaction(\n SOLANA_BIP32_PATH,\n solanaWeb3Transaction.serialize()\n );\n }\n\n const addressResult = await solana.getAddress(SOLANA_BIP32_PATH);\n\n const publicKey = new PublicKey(addressResult.address);\n\n solanaWeb3Transaction.addSignature(\n publicKey,\n Buffer.from(signResult.signature)\n );\n\n const serializedTx = solanaWeb3Transaction.serialize();\n\n return serializedTx;\n };\n const hash = await generalSolanaTransactionExecutor(\n tx,\n DefaultSolanaSigner\n );\n return { hash };\n } catch (error) {\n throw getLedgerError(error);\n } finally {\n await transportDisconnect();\n }\n }\n}\n"],
|
|
5
|
-
"mappings": "+
|
|
6
|
-
"names": ["Namespace", "Networks", "WalletTypes", "getAltStatusMessage", "ETHEREUM_CHAIN_ID", "Networks", "bs58", "
|
|
3
|
+
"sources": ["../src/index.ts", "../src/helpers.ts", "../src/state.ts", "../src/signer.ts", "../src/signers/ethereum.ts", "../src/signers/solana.ts"],
|
|
4
|
+
"sourcesContent": ["import type {\n Connect,\n Disconnect,\n ProviderConnectResult,\n WalletInfo,\n} from '@rango-dev/wallets-shared';\n\nimport { Namespace, Networks, WalletTypes } from '@rango-dev/wallets-shared';\nimport { type BlockchainMeta, type SignerFactory } from 'rango-types';\n\nimport {\n getEthereumAccounts,\n getLedgerInstance,\n getSolanaAccounts,\n transportDisconnect,\n} from './helpers';\nimport signer from './signer';\nimport { setDerivationPath } from './state';\n\nexport const config = {\n type: WalletTypes.LEDGER,\n};\n\nexport const getInstance = getLedgerInstance;\nexport const connect: Connect = async ({ namespaces }) => {\n const results: ProviderConnectResult[] = [];\n\n const solanaNamespace = namespaces?.find(\n (namespaceItem) => namespaceItem.namespace === Namespace.Solana\n );\n const evmNamespace = namespaces?.find(\n (namespaceItem) => namespaceItem.namespace === Namespace.Evm\n );\n\n if (solanaNamespace) {\n if (solanaNamespace.derivationPath) {\n setDerivationPath(solanaNamespace.derivationPath);\n const accounts = await getSolanaAccounts();\n results.push(accounts);\n } else {\n throw new Error('Derivation Path can not be empty.');\n }\n } else if (evmNamespace) {\n if (evmNamespace.derivationPath) {\n setDerivationPath(evmNamespace.derivationPath);\n const accounts = await getEthereumAccounts();\n results.push(accounts);\n } else {\n throw new Error('Derivation Path can not be empty.');\n }\n } else {\n throw new Error(\n `It appears that you have selected a namespace that is not yet supported by our system. Your namespaces: ${namespaces?.map(\n (namespaceItem) => namespaceItem.namespace\n )}`\n );\n }\n\n return results;\n};\n\nexport const disconnect: Disconnect = async () => {\n void transportDisconnect();\n};\n\nexport const getSigners: (provider: any) => SignerFactory = signer;\n\nexport const getWalletInfo: (allBlockChains: BlockchainMeta[]) => WalletInfo = (\n allBlockChains\n) => {\n const supportedChains: BlockchainMeta[] = [];\n\n const ethereumBlockchain = allBlockChains.find(\n (chain) => chain.name === Networks.ETHEREUM\n );\n if (ethereumBlockchain) {\n supportedChains.push(ethereumBlockchain);\n }\n\n const solanaBlockchain = allBlockChains.find(\n (chain) => chain.name === Networks.SOLANA\n );\n if (solanaBlockchain) {\n supportedChains.push(solanaBlockchain);\n }\n\n return {\n name: 'Ledger',\n img: 'https://raw.githubusercontent.com/rango-exchange/assets/main/wallets/ledger/icon.svg',\n installLink: {\n DEFAULT:\n 'https://support.ledger.com/hc/en-us/articles/4404389606417-Download-and-install-Ledger-Live?docs=true',\n },\n color: 'black',\n supportedChains,\n namespaces: [Namespace.Evm, Namespace.Solana],\n singleNamespace: true,\n showOnMobile: false,\n needsDerivationPath: true,\n };\n};\n", "import type Transport from '@ledgerhq/hw-transport';\n\nimport { getAltStatusMessage } from '@ledgerhq/errors';\nimport { ETHEREUM_CHAIN_ID, Networks } from '@rango-dev/wallets-shared';\nimport bs58 from 'bs58';\n\nimport { getDerivationPath } from './state';\n\nexport const ETH_BIP32_PATH = \"44'/60'/0'/0/0\";\nexport const SOLANA_BIP32_PATH = \"44'/501'/0'\";\n\nexport const HEXADECIMAL_BASE = 16;\n\nconst ledgerFrequentErrorMessages: { [statusCode: number]: string } = {\n 0x5515: 'The device is locked',\n 0x650f: 'Related application is not ready on your device',\n 0x6985: 'Action denied by user',\n};\n\nfunction getLedgerErrorMessage(statusCode: number): string {\n if (ledgerFrequentErrorMessages[statusCode]) {\n return ledgerFrequentErrorMessages[statusCode];\n } else if (getAltStatusMessage(statusCode)) {\n return getAltStatusMessage(statusCode) as string;\n }\n\n return `Ledger device unknown error 0x${statusCode.toString(\n HEXADECIMAL_BASE\n )}`; // Hexadecimal numbers are more commonly recognized and utilized for representing ledger error codes\n}\n\nexport function getLedgerError(error: any) {\n if (error?.statusCode) {\n return new Error(getLedgerErrorMessage(error.statusCode));\n }\n\n if (error?.code === 'INSUFFICIENT_FUNDS') {\n return new Error('Insufficient funds for transaction');\n }\n return error;\n}\n\nexport function getLedgerInstance() {\n /*\n * Instances have a required property which is `chainId` and is using in swap execution.\n * Here we are setting it as Ethereum always since we are supporting only eth for now.\n */\n const instances = new Map();\n\n instances.set(Networks.ETHEREUM, { chainId: ETHEREUM_CHAIN_ID });\n instances.set(Networks.SOLANA, { chainId: Networks.SOLANA });\n\n return instances;\n}\n\nexport async function getEthereumAccounts(): Promise<{\n accounts: string[];\n chainId: string;\n}> {\n try {\n const transport = await transportConnect();\n\n const eth = new (await import('@ledgerhq/hw-app-eth')).default(transport);\n\n const accounts: string[] = [];\n\n const result = await eth.getAddress(getDerivationPath(), false, true);\n accounts.push(result.address);\n\n return {\n accounts: accounts,\n chainId: ETHEREUM_CHAIN_ID,\n };\n } catch (error: any) {\n throw getLedgerError(error);\n } finally {\n await transportDisconnect();\n }\n}\n\nexport async function getSolanaAccounts(): Promise<{\n accounts: string[];\n chainId: string;\n}> {\n try {\n const transport = await transportConnect();\n\n const solana = new (await import('@ledgerhq/hw-app-solana')).default(\n transport\n );\n\n const accounts: string[] = [];\n\n const result = await solana.getAddress(getDerivationPath());\n accounts.push(bs58.encode(result.address));\n\n return {\n accounts: accounts,\n chainId: Networks.SOLANA,\n };\n } catch (error: any) {\n throw getLedgerError(error);\n } finally {\n await transportDisconnect();\n }\n}\n\nlet transportConnection: Transport | null = null;\n\nexport async function transportConnect() {\n transportConnection = await (\n await import('@ledgerhq/hw-transport-webhid')\n ).default.create();\n\n return transportConnection;\n}\n\nexport async function transportDisconnect() {\n if (transportConnection) {\n await transportConnection.close();\n transportConnection = null;\n }\n}\n", "// We keep derivationPath here because we need to maintain it for signing transactions after it is set in connect method\nlet derivationPath = '';\n\nexport function setDerivationPath(path: string) {\n derivationPath = path;\n}\n\nexport function getDerivationPath() {\n return derivationPath;\n}\n", "import type { SignerFactory } from 'rango-types';\n\nimport { DefaultSignerFactory, TransactionType as TxType } from 'rango-types';\n\nimport { EthereumSigner } from './signers/ethereum';\nimport { SolanaSigner } from './signers/solana';\n\nexport default function getSigners(): SignerFactory {\n const signers = new DefaultSignerFactory();\n signers.registerSigner(TxType.EVM, new EthereumSigner());\n signers.registerSigner(TxType.SOLANA, new SolanaSigner());\n return signers;\n}\n", "import type { TransactionLike } from 'ethers';\nimport type { GenericSigner } from 'rango-types';\nimport type { EvmTransaction } from 'rango-types/lib/api/main';\n\nimport { DEFAULT_ETHEREUM_RPC_URL } from '@rango-dev/wallets-shared';\nimport { JsonRpcProvider, Transaction } from 'ethers';\nimport { SignerError } from 'rango-types';\n\nimport {\n getLedgerError,\n transportConnect,\n transportDisconnect,\n} from '../helpers';\nimport { getDerivationPath } from '../state';\n\nexport class EthereumSigner implements GenericSigner<EvmTransaction> {\n async signMessage(): Promise<string> {\n // TODO: Should be implemented using eth.signPersonalMessage\n throw SignerError.UnimplementedError('signMessage');\n }\n\n async signAndSendTx(\n tx: EvmTransaction,\n fromAddress: string,\n chainId: string | null\n ): Promise<{ hash: string }> {\n try {\n const provider = new JsonRpcProvider(DEFAULT_ETHEREUM_RPC_URL); // Provider to broadcast transaction\n\n const transactionCount = await provider.getTransactionCount(fromAddress); // Get nonce\n\n const transaction: TransactionLike<string> = {\n to: tx.to,\n gasPrice: tx.gasPrice,\n gasLimit: tx.gasLimit,\n nonce: transactionCount,\n chainId: chainId,\n data: tx.data,\n value: tx.value,\n maxPriorityFeePerGas: tx.maxPriorityFeePerGas,\n maxFeePerGas: tx.maxFeePerGas,\n };\n\n const unsignedTx =\n Transaction.from(transaction).unsignedSerialized.substring(2); // Create unsigned transaction\n\n const resolution = await (\n await import('@ledgerhq/hw-app-eth')\n ).ledgerService.resolveTransaction(unsignedTx, {}, {}); // metadata necessary to allow the device to clear sign information\n\n const transport = await transportConnect();\n\n const eth = new (await import('@ledgerhq/hw-app-eth')).default(transport);\n\n const signature = await eth.signTransaction(\n getDerivationPath(),\n unsignedTx,\n resolution\n );\n\n const signedTx = Transaction.from({\n ...transaction,\n signature: {\n r: '0x' + signature.r,\n s: '0x' + signature.s,\n v: parseInt(signature.v),\n },\n }).serialized;\n\n const broadcastResult = await provider.broadcastTransaction(signedTx);\n\n return { hash: broadcastResult.hash };\n } catch (error) {\n throw getLedgerError(error);\n } finally {\n await transportDisconnect();\n }\n }\n}\n", "import type { SolanaWeb3Signer } from '@rango-dev/signer-solana';\nimport type { Transaction, VersionedTransaction } from '@solana/web3.js';\nimport type { GenericSigner, SolanaTransaction } from 'rango-types';\n\nimport { generalSolanaTransactionExecutor } from '@rango-dev/signer-solana';\nimport { PublicKey } from '@solana/web3.js';\nimport { SignerError } from 'rango-types';\n\nimport {\n getLedgerError,\n transportConnect,\n transportDisconnect,\n} from '../helpers';\nimport { getDerivationPath } from '../state';\n\nexport function isVersionedTransaction(\n transaction: Transaction | VersionedTransaction\n): transaction is VersionedTransaction {\n return 'version' in transaction;\n}\n\nexport class SolanaSigner implements GenericSigner<SolanaTransaction> {\n async signMessage(): Promise<string> {\n throw SignerError.UnimplementedError('signMessage');\n }\n\n async signAndSendTx(tx: SolanaTransaction): Promise<{ hash: string }> {\n try {\n const DefaultSolanaSigner: SolanaWeb3Signer = async (\n solanaWeb3Transaction: Transaction | VersionedTransaction\n ) => {\n const transport = await transportConnect();\n const solana = new (await import('@ledgerhq/hw-app-solana')).default(\n transport\n );\n\n let signResult;\n if (isVersionedTransaction(solanaWeb3Transaction)) {\n signResult = await solana.signTransaction(\n getDerivationPath(),\n solanaWeb3Transaction.message.serialize() as Buffer\n );\n } else {\n signResult = await solana.signTransaction(\n getDerivationPath(),\n solanaWeb3Transaction.serialize()\n );\n }\n\n const addressResult = await solana.getAddress(getDerivationPath());\n\n const publicKey = new PublicKey(addressResult.address);\n\n solanaWeb3Transaction.addSignature(\n publicKey,\n Buffer.from(signResult.signature)\n );\n\n const serializedTx = solanaWeb3Transaction.serialize();\n\n return serializedTx;\n };\n const hash = await generalSolanaTransactionExecutor(\n tx,\n DefaultSolanaSigner\n );\n return { hash };\n } catch (error) {\n throw getLedgerError(error);\n } finally {\n await transportDisconnect();\n }\n }\n}\n"],
|
|
5
|
+
"mappings": "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",
|
|
6
|
+
"names": ["Namespace", "Networks", "WalletTypes", "getAltStatusMessage", "ETHEREUM_CHAIN_ID", "Networks", "bs58", "derivationPath", "setDerivationPath", "path", "__name", "getDerivationPath", "HEXADECIMAL_BASE", "ledgerFrequentErrorMessages", "getLedgerErrorMessage", "statusCode", "getAltStatusMessage", "__name", "getLedgerError", "error", "getLedgerInstance", "instances", "Networks", "ETHEREUM_CHAIN_ID", "getEthereumAccounts", "transport", "transportConnect", "eth", "accounts", "result", "getDerivationPath", "transportDisconnect", "getSolanaAccounts", "solana", "bs58", "transportConnection", "DefaultSignerFactory", "TxType", "DEFAULT_ETHEREUM_RPC_URL", "JsonRpcProvider", "Transaction", "SignerError", "EthereumSigner", "__name", "SignerError", "tx", "fromAddress", "chainId", "provider", "JsonRpcProvider", "DEFAULT_ETHEREUM_RPC_URL", "transactionCount", "transaction", "unsignedTx", "Transaction", "resolution", "transport", "transportConnect", "signature", "getDerivationPath", "signedTx", "error", "getLedgerError", "transportDisconnect", "generalSolanaTransactionExecutor", "PublicKey", "SignerError", "isVersionedTransaction", "transaction", "__name", "SolanaSigner", "SignerError", "tx", "generalSolanaTransactionExecutor", "solanaWeb3Transaction", "transport", "transportConnect", "solana", "signResult", "getDerivationPath", "addressResult", "publicKey", "PublicKey", "error", "getLedgerError", "transportDisconnect", "getSigners", "signers", "DefaultSignerFactory", "TxType", "EthereumSigner", "SolanaSigner", "__name", "config", "WalletTypes", "getInstance", "getLedgerInstance", "connect", "__name", "namespaces", "results", "solanaNamespace", "namespaceItem", "Namespace", "evmNamespace", "setDerivationPath", "accounts", "getSolanaAccounts", "getEthereumAccounts", "disconnect", "transportDisconnect", "getSigners", "getWalletInfo", "allBlockChains", "supportedChains", "ethereumBlockchain", "chain", "Networks", "solanaBlockchain"]
|
|
7
7
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"inputs":{"src/helpers.ts":{"bytes":
|
|
1
|
+
{"inputs":{"src/state.ts":{"bytes":290,"imports":[{"path":"<runtime>","kind":"import-statement","external":true}],"format":"esm"},"src/helpers.ts":{"bytes":3300,"imports":[{"path":"@ledgerhq/errors","kind":"import-statement","external":true},{"path":"@rango-dev/wallets-shared","kind":"import-statement","external":true},{"path":"bs58","kind":"import-statement","external":true},{"path":"src/state.ts","kind":"import-statement","original":"./state"},{"path":"@ledgerhq/hw-app-eth","kind":"dynamic-import","external":true},{"path":"@ledgerhq/hw-app-solana","kind":"dynamic-import","external":true},{"path":"@ledgerhq/hw-transport-webhid","kind":"dynamic-import","external":true},{"path":"<runtime>","kind":"import-statement","external":true}],"format":"esm"},"src/signers/ethereum.ts":{"bytes":2461,"imports":[{"path":"@rango-dev/wallets-shared","kind":"import-statement","external":true},{"path":"ethers","kind":"import-statement","external":true},{"path":"rango-types","kind":"import-statement","external":true},{"path":"src/helpers.ts","kind":"import-statement","original":"../helpers"},{"path":"src/state.ts","kind":"import-statement","original":"../state"},{"path":"@ledgerhq/hw-app-eth","kind":"dynamic-import","external":true},{"path":"@ledgerhq/hw-app-eth","kind":"dynamic-import","external":true},{"path":"<runtime>","kind":"import-statement","external":true}],"format":"esm"},"src/signers/solana.ts":{"bytes":2281,"imports":[{"path":"@rango-dev/signer-solana","kind":"import-statement","external":true},{"path":"@solana/web3.js","kind":"import-statement","external":true},{"path":"rango-types","kind":"import-statement","external":true},{"path":"src/helpers.ts","kind":"import-statement","original":"../helpers"},{"path":"src/state.ts","kind":"import-statement","original":"../state"},{"path":"@ledgerhq/hw-app-solana","kind":"dynamic-import","external":true},{"path":"<runtime>","kind":"import-statement","external":true}],"format":"esm"},"src/signer.ts":{"bytes":475,"imports":[{"path":"rango-types","kind":"import-statement","external":true},{"path":"src/signers/ethereum.ts","kind":"import-statement","original":"./signers/ethereum"},{"path":"src/signers/solana.ts","kind":"import-statement","original":"./signers/solana"},{"path":"<runtime>","kind":"import-statement","external":true}],"format":"esm"},"src/index.ts":{"bytes":2851,"imports":[{"path":"@rango-dev/wallets-shared","kind":"import-statement","external":true},{"path":"rango-types","kind":"import-statement","external":true},{"path":"src/helpers.ts","kind":"import-statement","original":"./helpers"},{"path":"src/signer.ts","kind":"import-statement","original":"./signer"},{"path":"src/state.ts","kind":"import-statement","original":"./state"},{"path":"<runtime>","kind":"import-statement","external":true}],"format":"esm"}},"outputs":{"dist/index.js.map":{"imports":[],"exports":[],"inputs":{},"bytes":19027},"dist/index.js":{"imports":[{"path":"@rango-dev/wallets-shared","kind":"import-statement","external":true},{"path":"@ledgerhq/errors","kind":"import-statement","external":true},{"path":"@rango-dev/wallets-shared","kind":"import-statement","external":true},{"path":"bs58","kind":"import-statement","external":true},{"path":"@ledgerhq/hw-app-eth","kind":"dynamic-import","external":true},{"path":"@ledgerhq/hw-app-solana","kind":"dynamic-import","external":true},{"path":"@ledgerhq/hw-transport-webhid","kind":"dynamic-import","external":true},{"path":"rango-types","kind":"import-statement","external":true},{"path":"@rango-dev/wallets-shared","kind":"import-statement","external":true},{"path":"ethers","kind":"import-statement","external":true},{"path":"rango-types","kind":"import-statement","external":true},{"path":"@ledgerhq/hw-app-eth","kind":"dynamic-import","external":true},{"path":"@ledgerhq/hw-app-eth","kind":"dynamic-import","external":true},{"path":"@rango-dev/signer-solana","kind":"import-statement","external":true},{"path":"@solana/web3.js","kind":"import-statement","external":true},{"path":"rango-types","kind":"import-statement","external":true},{"path":"@ledgerhq/hw-app-solana","kind":"dynamic-import","external":true}],"exports":["config","connect","disconnect","getInstance","getSigners","getWalletInfo"],"entryPoint":"src/index.ts","inputs":{"src/index.ts":{"bytesInOutput":1189},"src/helpers.ts":{"bytesInOutput":1400},"src/state.ts":{"bytesInOutput":99},"src/signer.ts":{"bytesInOutput":187},"src/signers/ethereum.ts":{"bytesInOutput":923},"src/signers/solana.ts":{"bytesInOutput":750}},"bytes":4769}}}
|
package/dist/state.d.ts
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"state.d.ts","sourceRoot":"","sources":["../src/state.ts"],"names":[],"mappings":"AAGA,wBAAgB,iBAAiB,CAAC,IAAI,EAAE,MAAM,QAE7C;AAED,wBAAgB,iBAAiB,WAEhC"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@rango-dev/provider-ledger",
|
|
3
|
-
"version": "0.4.1-next.
|
|
3
|
+
"version": "0.4.1-next.7",
|
|
4
4
|
"license": "MIT",
|
|
5
5
|
"type": "module",
|
|
6
6
|
"source": "./src/index.ts",
|
|
@@ -26,7 +26,7 @@
|
|
|
26
26
|
"@ledgerhq/hw-app-solana": "^7.1.6",
|
|
27
27
|
"@ledgerhq/hw-transport-webhid": "^6.28.6",
|
|
28
28
|
"@rango-dev/signer-solana": "^0.29.1-next.1",
|
|
29
|
-
"@rango-dev/wallets-shared": "^0.34.1-next.
|
|
29
|
+
"@rango-dev/wallets-shared": "^0.34.1-next.6",
|
|
30
30
|
"@solana/web3.js": "^1.91.4",
|
|
31
31
|
"bs58": "^5.0.0",
|
|
32
32
|
"ethers": "^6.11.1",
|
package/src/helpers.ts
CHANGED
|
@@ -4,6 +4,8 @@ import { getAltStatusMessage } from '@ledgerhq/errors';
|
|
|
4
4
|
import { ETHEREUM_CHAIN_ID, Networks } from '@rango-dev/wallets-shared';
|
|
5
5
|
import bs58 from 'bs58';
|
|
6
6
|
|
|
7
|
+
import { getDerivationPath } from './state';
|
|
8
|
+
|
|
7
9
|
export const ETH_BIP32_PATH = "44'/60'/0'/0/0";
|
|
8
10
|
export const SOLANA_BIP32_PATH = "44'/501'/0'";
|
|
9
11
|
|
|
@@ -62,7 +64,7 @@ export async function getEthereumAccounts(): Promise<{
|
|
|
62
64
|
|
|
63
65
|
const accounts: string[] = [];
|
|
64
66
|
|
|
65
|
-
const result = await eth.getAddress(
|
|
67
|
+
const result = await eth.getAddress(getDerivationPath(), false, true);
|
|
66
68
|
accounts.push(result.address);
|
|
67
69
|
|
|
68
70
|
return {
|
|
@@ -89,7 +91,7 @@ export async function getSolanaAccounts(): Promise<{
|
|
|
89
91
|
|
|
90
92
|
const accounts: string[] = [];
|
|
91
93
|
|
|
92
|
-
const result = await solana.getAddress(
|
|
94
|
+
const result = await solana.getAddress(getDerivationPath());
|
|
93
95
|
accounts.push(bs58.encode(result.address));
|
|
94
96
|
|
|
95
97
|
return {
|
package/src/index.ts
CHANGED
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
import type {
|
|
2
2
|
Connect,
|
|
3
3
|
Disconnect,
|
|
4
|
+
ProviderConnectResult,
|
|
4
5
|
WalletInfo,
|
|
5
6
|
} from '@rango-dev/wallets-shared';
|
|
6
7
|
|
|
@@ -14,6 +15,7 @@ import {
|
|
|
14
15
|
transportDisconnect,
|
|
15
16
|
} from './helpers';
|
|
16
17
|
import signer from './signer';
|
|
18
|
+
import { setDerivationPath } from './state';
|
|
17
19
|
|
|
18
20
|
export const config = {
|
|
19
21
|
type: WalletTypes.LEDGER,
|
|
@@ -21,10 +23,40 @@ export const config = {
|
|
|
21
23
|
|
|
22
24
|
export const getInstance = getLedgerInstance;
|
|
23
25
|
export const connect: Connect = async ({ namespaces }) => {
|
|
24
|
-
|
|
25
|
-
|
|
26
|
+
const results: ProviderConnectResult[] = [];
|
|
27
|
+
|
|
28
|
+
const solanaNamespace = namespaces?.find(
|
|
29
|
+
(namespaceItem) => namespaceItem.namespace === Namespace.Solana
|
|
30
|
+
);
|
|
31
|
+
const evmNamespace = namespaces?.find(
|
|
32
|
+
(namespaceItem) => namespaceItem.namespace === Namespace.Evm
|
|
33
|
+
);
|
|
34
|
+
|
|
35
|
+
if (solanaNamespace) {
|
|
36
|
+
if (solanaNamespace.derivationPath) {
|
|
37
|
+
setDerivationPath(solanaNamespace.derivationPath);
|
|
38
|
+
const accounts = await getSolanaAccounts();
|
|
39
|
+
results.push(accounts);
|
|
40
|
+
} else {
|
|
41
|
+
throw new Error('Derivation Path can not be empty.');
|
|
42
|
+
}
|
|
43
|
+
} else if (evmNamespace) {
|
|
44
|
+
if (evmNamespace.derivationPath) {
|
|
45
|
+
setDerivationPath(evmNamespace.derivationPath);
|
|
46
|
+
const accounts = await getEthereumAccounts();
|
|
47
|
+
results.push(accounts);
|
|
48
|
+
} else {
|
|
49
|
+
throw new Error('Derivation Path can not be empty.');
|
|
50
|
+
}
|
|
51
|
+
} else {
|
|
52
|
+
throw new Error(
|
|
53
|
+
`It appears that you have selected a namespace that is not yet supported by our system. Your namespaces: ${namespaces?.map(
|
|
54
|
+
(namespaceItem) => namespaceItem.namespace
|
|
55
|
+
)}`
|
|
56
|
+
);
|
|
26
57
|
}
|
|
27
|
-
|
|
58
|
+
|
|
59
|
+
return results;
|
|
28
60
|
};
|
|
29
61
|
|
|
30
62
|
export const disconnect: Disconnect = async () => {
|
|
@@ -64,5 +96,6 @@ export const getWalletInfo: (allBlockChains: BlockchainMeta[]) => WalletInfo = (
|
|
|
64
96
|
namespaces: [Namespace.Evm, Namespace.Solana],
|
|
65
97
|
singleNamespace: true,
|
|
66
98
|
showOnMobile: false,
|
|
99
|
+
needsDerivationPath: true,
|
|
67
100
|
};
|
|
68
101
|
};
|
package/src/signers/ethereum.ts
CHANGED
|
@@ -7,11 +7,11 @@ import { JsonRpcProvider, Transaction } from 'ethers';
|
|
|
7
7
|
import { SignerError } from 'rango-types';
|
|
8
8
|
|
|
9
9
|
import {
|
|
10
|
-
ETH_BIP32_PATH,
|
|
11
10
|
getLedgerError,
|
|
12
11
|
transportConnect,
|
|
13
12
|
transportDisconnect,
|
|
14
13
|
} from '../helpers';
|
|
14
|
+
import { getDerivationPath } from '../state';
|
|
15
15
|
|
|
16
16
|
export class EthereumSigner implements GenericSigner<EvmTransaction> {
|
|
17
17
|
async signMessage(): Promise<string> {
|
|
@@ -53,7 +53,7 @@ export class EthereumSigner implements GenericSigner<EvmTransaction> {
|
|
|
53
53
|
const eth = new (await import('@ledgerhq/hw-app-eth')).default(transport);
|
|
54
54
|
|
|
55
55
|
const signature = await eth.signTransaction(
|
|
56
|
-
|
|
56
|
+
getDerivationPath(),
|
|
57
57
|
unsignedTx,
|
|
58
58
|
resolution
|
|
59
59
|
);
|
package/src/signers/solana.ts
CHANGED
|
@@ -8,10 +8,10 @@ import { SignerError } from 'rango-types';
|
|
|
8
8
|
|
|
9
9
|
import {
|
|
10
10
|
getLedgerError,
|
|
11
|
-
SOLANA_BIP32_PATH,
|
|
12
11
|
transportConnect,
|
|
13
12
|
transportDisconnect,
|
|
14
13
|
} from '../helpers';
|
|
14
|
+
import { getDerivationPath } from '../state';
|
|
15
15
|
|
|
16
16
|
export function isVersionedTransaction(
|
|
17
17
|
transaction: Transaction | VersionedTransaction
|
|
@@ -37,17 +37,17 @@ export class SolanaSigner implements GenericSigner<SolanaTransaction> {
|
|
|
37
37
|
let signResult;
|
|
38
38
|
if (isVersionedTransaction(solanaWeb3Transaction)) {
|
|
39
39
|
signResult = await solana.signTransaction(
|
|
40
|
-
|
|
40
|
+
getDerivationPath(),
|
|
41
41
|
solanaWeb3Transaction.message.serialize() as Buffer
|
|
42
42
|
);
|
|
43
43
|
} else {
|
|
44
44
|
signResult = await solana.signTransaction(
|
|
45
|
-
|
|
45
|
+
getDerivationPath(),
|
|
46
46
|
solanaWeb3Transaction.serialize()
|
|
47
47
|
);
|
|
48
48
|
}
|
|
49
49
|
|
|
50
|
-
const addressResult = await solana.getAddress(
|
|
50
|
+
const addressResult = await solana.getAddress(getDerivationPath());
|
|
51
51
|
|
|
52
52
|
const publicKey = new PublicKey(addressResult.address);
|
|
53
53
|
|
package/src/state.ts
ADDED
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
// We keep derivationPath here because we need to maintain it for signing transactions after it is set in connect method
|
|
2
|
+
let derivationPath = '';
|
|
3
|
+
|
|
4
|
+
export function setDerivationPath(path: string) {
|
|
5
|
+
derivationPath = path;
|
|
6
|
+
}
|
|
7
|
+
|
|
8
|
+
export function getDerivationPath() {
|
|
9
|
+
return derivationPath;
|
|
10
|
+
}
|