fix: ensure wallet alerts visibly and sends JSON-RPC error response

This commit is contained in:
Ben Kremer 2023-04-05 13:50:32 +02:00
parent 649cf28159
commit c128875314

View File

@ -20,30 +20,54 @@ export async function approveEIP155Request(
switch (request.method) { switch (request.method) {
case EIP155_SIGNING_METHODS.PERSONAL_SIGN: case EIP155_SIGNING_METHODS.PERSONAL_SIGN:
case EIP155_SIGNING_METHODS.ETH_SIGN: case EIP155_SIGNING_METHODS.ETH_SIGN:
try {
const message = getSignParamsMessage(request.params) const message = getSignParamsMessage(request.params)
const signedMessage = await wallet.signMessage(message) const signedMessage = await wallet.signMessage(message)
return formatJsonRpcResult(id, signedMessage) return formatJsonRpcResult(id, signedMessage)
} catch (error: any) {
console.error(error)
alert(error.message)
return formatJsonRpcError(id, error.message)
}
case EIP155_SIGNING_METHODS.ETH_SIGN_TYPED_DATA: case EIP155_SIGNING_METHODS.ETH_SIGN_TYPED_DATA:
case EIP155_SIGNING_METHODS.ETH_SIGN_TYPED_DATA_V3: case EIP155_SIGNING_METHODS.ETH_SIGN_TYPED_DATA_V3:
case EIP155_SIGNING_METHODS.ETH_SIGN_TYPED_DATA_V4: case EIP155_SIGNING_METHODS.ETH_SIGN_TYPED_DATA_V4:
try {
const { domain, types, message: data } = getSignTypedDataParamsData(request.params) const { domain, types, message: data } = getSignTypedDataParamsData(request.params)
// https://github.com/ethers-io/ethers.js/issues/687#issuecomment-714069471 // https://github.com/ethers-io/ethers.js/issues/687#issuecomment-714069471
delete types.EIP712Domain delete types.EIP712Domain
const signedData = await wallet._signTypedData(domain, types, data) const signedData = await wallet._signTypedData(domain, types, data)
return formatJsonRpcResult(id, signedData) return formatJsonRpcResult(id, signedData)
} catch (error: any) {
console.error(error)
alert(error.message)
return formatJsonRpcError(id, error.message)
}
case EIP155_SIGNING_METHODS.ETH_SEND_TRANSACTION: case EIP155_SIGNING_METHODS.ETH_SEND_TRANSACTION:
try {
const provider = new providers.JsonRpcProvider(EIP155_CHAINS[chainId as TEIP155Chain].rpc) const provider = new providers.JsonRpcProvider(EIP155_CHAINS[chainId as TEIP155Chain].rpc)
const sendTransaction = request.params[0] const sendTransaction = request.params[0]
const connectedWallet = wallet.connect(provider) const connectedWallet = wallet.connect(provider)
const { hash } = await connectedWallet.sendTransaction(sendTransaction) const { hash } = await connectedWallet.sendTransaction(sendTransaction)
return formatJsonRpcResult(id, hash) return formatJsonRpcResult(id, hash)
} catch (error: any) {
console.error(error)
alert(error.message)
return formatJsonRpcError(id, error.message)
}
case EIP155_SIGNING_METHODS.ETH_SIGN_TRANSACTION: case EIP155_SIGNING_METHODS.ETH_SIGN_TRANSACTION:
try {
const signTransaction = request.params[0] const signTransaction = request.params[0]
const signature = await wallet.signTransaction(signTransaction) const signature = await wallet.signTransaction(signTransaction)
return formatJsonRpcResult(id, signature) return formatJsonRpcResult(id, signature)
} catch (error: any) {
console.error(error)
alert(error.message)
return formatJsonRpcError(id, error.message)
}
default: default:
throw new Error(getSdkError('INVALID_METHOD').message) throw new Error(getSdkError('INVALID_METHOD').message)
@ -53,5 +77,5 @@ export async function approveEIP155Request(
export function rejectEIP155Request(request: SignClientTypes.EventArguments['session_request']) { export function rejectEIP155Request(request: SignClientTypes.EventArguments['session_request']) {
const { id } = request const { id } = request
return formatJsonRpcError(id, getSdkError('USER_REJECTED_METHODS').message) return formatJsonRpcError(id, getSdkError('USER_REJECTED').message)
} }