viem
Version:
60 lines (53 loc) • 1.72 kB
text/typescript
import type { Address } from 'abitype'
import type {
ByteArray,
Hex,
SignableMessage,
Signature,
} from '../../types/misc.js'
import { type GetAddressErrorType, getAddress } from '../address/getAddress.js'
import {
type IsAddressEqualErrorType,
isAddressEqual,
} from '../address/isAddressEqual.js'
import type { ErrorType } from '../../errors/utils.js'
import {
type RecoverMessageAddressErrorType,
recoverMessageAddress,
} from './recoverMessageAddress.js'
export type VerifyMessageParameters = {
/** The address that signed the original message. */
address: Address
/** The message to be verified. */
message: SignableMessage
/** The signature that was generated by signing the message with the address's private key. */
signature: Hex | ByteArray | Signature
}
export type VerifyMessageReturnType = boolean
export type VerifyMessageErrorType =
| IsAddressEqualErrorType
| GetAddressErrorType
| RecoverMessageAddressErrorType
| ErrorType
/**
* Verify that a message was signed by the provided address.
*
* Note: Only supports Externally Owned Accounts. Does not support Contract Accounts.
* It is highly recommended to use `publicClient.verifyMessage` instead to ensure
* wallet interoperability.
*
* - Docs {@link https://viem.sh/docs/utilities/verifyMessage}
*
* @param parameters - {@link VerifyMessageParameters}
* @returns Whether or not the signature is valid. {@link VerifyMessageReturnType}
*/
export async function verifyMessage({
address,
message,
signature,
}: VerifyMessageParameters): Promise<VerifyMessageReturnType> {
return isAddressEqual(
getAddress(address),
await recoverMessageAddress({ message, signature }),
)
}