Sign Messages First
Verify Signatures
- @solana/web3.js
- @solana/kit
- Anchor
Copy
Ask AI
import { useParaSolana } from './hooks/useParaSolana';
import { PublicKey } from '@solana/web3.js';
import nacl from 'tweetnacl';
import bs58 from 'bs58';
function VerifySignature() {
const { signer } = useParaSolana();
const verifyMessage = async () => {
if (!signer) {
console.error("No signer available. Connect wallet first.");
return;
}
const message = "Hello, Solana!";
const messageBytes = new TextEncoder().encode(message);
// Sign the message first
const signature = await signer.signBytes(Buffer.from(messageBytes));
const signatureBase58 = bs58.encode(signature);
// Verify the signature
try {
const publicKeyBytes = new PublicKey(signer.address).toBytes();
const isValid = nacl.sign.detached.verify(
messageBytes,
signature,
publicKeyBytes
);
console.log("Message:", message);
console.log("Signature:", signatureBase58);
console.log("Signature valid:", isValid);
console.log("Signer:", signer.address);
return isValid;
} catch (error) {
console.error("Verification failed:", error);
return false;
}
};
return <button onClick={verifyMessage}>Sign & Verify Message</button>;
}
Copy
Ask AI
import { useParaSolanaKit } from './hooks/useParaSolanaKit';
import { getUtf8Encoder } from '@solana/kit';
import nacl from 'tweetnacl';
import bs58 from 'bs58';
function VerifySignature() {
const { signer } = useParaSolanaKit();
const verifyMessage = async () => {
if (!signer) {
console.error("No signer available. Connect wallet first.");
return;
}
const message = "Hello, Solana!";
const messageBytes = getUtf8Encoder().encode(message);
// Sign the message first
const signatureResult = await signer.signMessages([
{ content: messageBytes, signatures: {} }
]);
const signatureBytes = signatureResult[0][signer.address];
const signatureBase58 = bs58.encode(signatureBytes);
// Verify the signature
try {
const publicKeyBytes = bs58.decode(signer.address);
const isValid = nacl.sign.detached.verify(
messageBytes,
signatureBytes,
publicKeyBytes
);
console.log("Message:", message);
console.log("Signature:", signatureBase58);
console.log("Signature valid:", isValid);
console.log("Signer:", signer.address);
return isValid;
} catch (error) {
console.error("Verification failed:", error);
return false;
}
};
return <button onClick={verifyMessage}>Sign & Verify Message</button>;
}
Copy
Ask AI
import { useParaAnchor } from './hooks/useParaAnchor';
import { useParaSolana } from './hooks/useParaSolana';
import nacl from 'tweetnacl';
import bs58 from 'bs58';
function VerifySignature() {
const provider = useParaAnchor();
const { signer } = useParaSolana();
const verifyMessage = async () => {
if (!signer) {
console.error("No signer available. Connect wallet first.");
return;
}
const message = "Hello, Anchor!";
const messageBytes = new TextEncoder().encode(message);
// Sign the message first
const signature = await signer.signBytes(Buffer.from(messageBytes));
const signatureBase58 = bs58.encode(signature);
// Verify the signature
try {
const publicKeyBytes = provider.wallet.publicKey.toBytes();
const isValid = nacl.sign.detached.verify(
messageBytes,
signature,
publicKeyBytes
);
console.log("Message:", message);
console.log("Signature:", signatureBase58);
console.log("Signature valid:", isValid);
console.log("Signer:", provider.wallet.publicKey.toString());
return isValid;
} catch (error) {
console.error("Verification failed:", error);
return false;
}
};
return <button onClick={verifyMessage}>Sign & Verify Message</button>;
}