Skip to content

Commit

Permalink
add versioned transaction support for keystone (#1002)
Browse files Browse the repository at this point in the history
  • Loading branch information
soralit authored Aug 23, 2024
1 parent f372188 commit 8cc1c0f
Show file tree
Hide file tree
Showing 3 changed files with 64 additions and 73 deletions.
2 changes: 1 addition & 1 deletion packages/wallets/keystone/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -35,7 +35,7 @@
"@solana/web3.js": "^1.77.3"
},
"dependencies": {
"@keystonehq/sol-keyring": "^0.3.1",
"@keystonehq/sol-keyring": "^0.20.0",
"@solana/wallet-adapter-base": "workspace:^"
},
"devDependencies": {
Expand Down
20 changes: 15 additions & 5 deletions packages/wallets/keystone/src/adapter.ts
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,7 @@ import type { DefaultKeyring } from '@keystonehq/sol-keyring';
import type { WalletName } from '@solana/wallet-adapter-base';
import {
BaseMessageSignerWalletAdapter,
isVersionedTransaction,
WalletAccountError,
WalletLoadError,
WalletNotConnectedError,
Expand All @@ -10,7 +11,7 @@ import {
WalletReadyState,
WalletSignTransactionError,
} from '@solana/wallet-adapter-base';
import type { Transaction } from '@solana/web3.js';
import type { Transaction, TransactionVersion, VersionedTransaction } from '@solana/web3.js';
import { PublicKey } from '@solana/web3.js';

export interface KeystoneWalletAdapterConfig {}
Expand All @@ -22,7 +23,7 @@ export class KeystoneWalletAdapter extends BaseMessageSignerWalletAdapter {
url = 'https://keyst.one';
icon =
'';
readonly supportedTransactionVersions = null;
supportedTransactionVersions: ReadonlySet<TransactionVersion> = new Set(['legacy', 0]);

private _keyring: DefaultKeyring | null;
private _publicKey: PublicKey | null;
Expand Down Expand Up @@ -102,14 +103,23 @@ export class KeystoneWalletAdapter extends BaseMessageSignerWalletAdapter {
this.emit('disconnect');
}

async signTransaction<T extends Transaction>(transaction: T): Promise<T> {
async signTransaction<T extends Transaction | VersionedTransaction>(transaction: T): Promise<T> {
try {
const keyring = this._keyring;
const publicKey = this._publicKey?.toString();
const publicKey = this._publicKey;
if (!keyring || !publicKey) throw new WalletNotConnectedError();

try {
return (await keyring.signTransaction(publicKey, transaction)) as T;
if (isVersionedTransaction(transaction)) {
const txHex = transaction.serialize();
const signature = await keyring.signTransaction(publicKey.toString(), txHex);
transaction.addSignature(publicKey, signature);
} else {
const txHex = transaction.serializeMessage();
const signature = await keyring.signTransaction(publicKey.toString(), txHex);
transaction.addSignature(publicKey, Buffer.from(signature));
}
return transaction;
} catch (error: any) {
throw new WalletSignTransactionError(error?.message, error);
}
Expand Down
115 changes: 48 additions & 67 deletions pnpm-lock.yaml

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

0 comments on commit 8cc1c0f

Please sign in to comment.