Commands
Sign Message
Sign message lets you create an EIP-191. You should verify the signature.
Use Case: This command is useful for applications that need to sign messages for verification purposes, ensuring that the message was indeed created by the owner of the wallet.
Example: A voting app that requires users to sign a message to prove ownership of their wallet before allowing them to vote.
Using the command
Async handlersEvent listeners
Sending the command & handling the response
The response will include a signature compliant with EIP-191. You should verify the signature.
type MiniAppSignMessageSuccessPayload = {
status: "success";
signature: string;
address: string;
version: number;
};
app/page.tsx
import { MiniKit, SignMessageInput } from '@worldcoin/minikit-js'
const signAndVerifyMessage = async () => {
const signMessagePayload: SignMessageInput = {
message: "Hello world",
};
const {finalPayload} = await MiniKit.commandsAsync.signMessage(signMessagePayload);
if (finalPayload.status === "success") {
const messageHash = hashSafeMessage(messageToSign);
const isValid = await (
await Safe.init({
provider:
"https://worldchain-mainnet.g.alchemy.com/v2/your-api-key",
safeAddress: finalPayload.address,
})
).isValidSignature(messageHash, finalPayload.signature);
// Checks functionally if the signature is correct
if (isValid) {
console.log("Signature is valid");
}
}
};
Your message is verified!