@metamask/keyring-snap-sdk
Version:
MetaMask Keyring Snap SDK
158 lines • 7.08 kB
JavaScript
import { KeyringRpcMethod, GetAccountRequestStruct, CreateAccountRequestStruct, ListAccountTransactionsRequestStruct, ApproveRequestRequestStruct, DeleteAccountRequestStruct, ExportAccountRequestStruct, GetRequestRequestStruct, RejectRequestRequestStruct, SubmitRequestRequestStruct, UpdateAccountRequestStruct, FilterAccountChainsStruct, ListAccountsRequestStruct, ListRequestsRequestStruct, GetAccountBalancesRequestStruct, ListAccountAssetsRequestStruct, ResolveAccountAddressRequestStruct, DiscoverAccountsRequestStruct } from "@metamask/keyring-api";
import { JsonRpcRequestStruct } from "@metamask/keyring-utils";
import { assert } from "@metamask/superstruct";
/**
* Error thrown when a keyring JSON-RPC method is not supported.
*/
export class MethodNotSupportedError extends Error {
constructor(method) {
super(`Method not supported: ${method}`);
}
}
/**
* Inner function that dispatches JSON-RPC request to the associated Keyring
* methods.
*
* @param keyring - Keyring instance.
* @param request - Keyring JSON-RPC request.
* @returns A promise that resolves to the keyring response.
*/
async function dispatchRequest(keyring, request) {
// We first have to make sure that the request is a valid JSON-RPC request so
// we can check its method name.
assert(request, JsonRpcRequestStruct);
switch (request.method) {
case `${KeyringRpcMethod.ListAccounts}`: {
assert(request, ListAccountsRequestStruct);
return keyring.listAccounts();
}
case `${KeyringRpcMethod.GetAccount}`: {
assert(request, GetAccountRequestStruct);
return keyring.getAccount(request.params.id);
}
case `${KeyringRpcMethod.CreateAccount}`: {
assert(request, CreateAccountRequestStruct);
return keyring.createAccount(request.params.options);
}
case `${KeyringRpcMethod.DiscoverAccounts}`: {
if (keyring.discoverAccounts === undefined) {
throw new MethodNotSupportedError(request.method);
}
assert(request, DiscoverAccountsRequestStruct);
return keyring.discoverAccounts(request.params.scopes, request.params.entropySource, request.params.groupIndex);
}
case `${KeyringRpcMethod.ListAccountTransactions}`: {
if (keyring.listAccountTransactions === undefined) {
throw new MethodNotSupportedError(request.method);
}
assert(request, ListAccountTransactionsRequestStruct);
return keyring.listAccountTransactions(request.params.id, request.params.pagination);
}
case `${KeyringRpcMethod.ListAccountAssets}`: {
if (keyring.listAccountAssets === undefined) {
throw new MethodNotSupportedError(request.method);
}
assert(request, ListAccountAssetsRequestStruct);
return keyring.listAccountAssets(request.params.id);
}
case `${KeyringRpcMethod.GetAccountBalances}`: {
if (keyring.getAccountBalances === undefined) {
throw new MethodNotSupportedError(request.method);
}
assert(request, GetAccountBalancesRequestStruct);
return keyring.getAccountBalances(request.params.id, request.params.assets);
}
case `${KeyringRpcMethod.ResolveAccountAddress}`: {
if (keyring.resolveAccountAddress === undefined) {
throw new MethodNotSupportedError(request.method);
}
assert(request, ResolveAccountAddressRequestStruct);
return keyring.resolveAccountAddress(request.params.scope, request.params.request);
}
case `${KeyringRpcMethod.FilterAccountChains}`: {
assert(request, FilterAccountChainsStruct);
return keyring.filterAccountChains(request.params.id, request.params.chains);
}
case `${KeyringRpcMethod.UpdateAccount}`: {
assert(request, UpdateAccountRequestStruct);
return keyring.updateAccount(request.params.account);
}
case `${KeyringRpcMethod.DeleteAccount}`: {
assert(request, DeleteAccountRequestStruct);
return keyring.deleteAccount(request.params.id);
}
case `${KeyringRpcMethod.ExportAccount}`: {
if (keyring.exportAccount === undefined) {
throw new MethodNotSupportedError(request.method);
}
assert(request, ExportAccountRequestStruct);
return keyring.exportAccount(request.params.id);
}
case `${KeyringRpcMethod.ListRequests}`: {
if (keyring.listRequests === undefined) {
throw new MethodNotSupportedError(request.method);
}
assert(request, ListRequestsRequestStruct);
return keyring.listRequests();
}
case `${KeyringRpcMethod.GetRequest}`: {
if (keyring.getRequest === undefined) {
throw new MethodNotSupportedError(request.method);
}
assert(request, GetRequestRequestStruct);
return keyring.getRequest(request.params.id);
}
case `${KeyringRpcMethod.SubmitRequest}`: {
assert(request, SubmitRequestRequestStruct);
return keyring.submitRequest(request.params);
}
case `${KeyringRpcMethod.ApproveRequest}`: {
if (keyring.approveRequest === undefined) {
throw new MethodNotSupportedError(request.method);
}
assert(request, ApproveRequestRequestStruct);
return keyring.approveRequest(request.params.id, request.params.data);
}
case `${KeyringRpcMethod.RejectRequest}`: {
if (keyring.rejectRequest === undefined) {
throw new MethodNotSupportedError(request.method);
}
assert(request, RejectRequestRequestStruct);
return keyring.rejectRequest(request.params.id);
}
default: {
throw new MethodNotSupportedError(request.method);
}
}
}
/**
* Handles a keyring JSON-RPC request.
*
* This function is meant to be used as a handler for Keyring JSON-RPC requests
* in an Accounts Snap.
*
* @param keyring - Keyring instance.
* @param request - Keyring JSON-RPC request.
* @returns A promise that resolves to the keyring response.
* @example
* ```ts
* export const onKeyringRequest: OnKeyringRequestHandler = async ({
* origin,
* request,
* }) => {
* return await handleKeyringRequest(keyring, request);
* };
* ```
*/
export async function handleKeyringRequest(keyring, request) {
try {
return await dispatchRequest(keyring, request);
}
catch (error) {
const message = error instanceof Error && typeof error.message === 'string'
? error.message
: 'An unknown error occurred while handling the keyring request';
throw new Error(message);
}
}
//# sourceMappingURL=rpc-handler.mjs.map