fix: ensure wallet alerts visibly and sends JSON-RPC error response
This commit is contained in:
parent
649cf28159
commit
c128875314
@ -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)
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user