Docs
Standard messages

Standard message signing

Standard messaging signing allows for the signing of any arbitrary string message.

💡

If you're looking to sign Structured Data, please click here.

Usage

@micro-stacks/react exports a hook for this: useOpenSignMessage. This hook exposes the callback to interact with a connected wallet. The hook returns a callback, openSignMessage which takes a message of type string value. isRequestPending is also returned, a boolean value to denote if there is a current request open (meaning the use has already requested a signature). The pending state is handled all internally for every wallet request, so you don't need to manually handle any loading logic.

As with all of the hooks that interact with the wallet, you can also pass an onFinish and onCancel callback.

Example

Below you will find a simple component that renders an input and a button. The input is captured in a useState hook, and piped into the openSignMessage callback, wrapped in a useCallback hook.

import * as React from 'react';
import { useOpenSignMessage } from '@micro-stacks/react';

const SignMessageComponent = () => {
  const { openSignMessage, isRequestPending } = useOpenSignMessage();

  const [payload, setPayload] = React.useState(null);
  const [message, setMessage] = React.useState("");

  const onClick = React.useCallback(async () => {
    await openSignMessage({
      message,
      onFinish: (walletResponse) => {
        setPayload(walletResponse);
      },
    });
  }, [message]);

  return (
    <div
      style={{
        display: "grid",
        gap: "20px",
      }}
    >
      <h5>Sign a message!</h5>
      <input
        style={{ display: "block" }}
        onChange={(e) => setMessage(e.currentTarget.value)}
      />
      <button onClick={onClick}>
        {isRequestPending ? "Loading..." : "Sign message"}
      </button>
      <code>
        <pre>{JSON.stringify(payload, null, 2)}</pre>
      </code>
    </div>
  );
};

Verification

To verify a signed message, you can import verifyMessageSignature from micro-stacks/connect.

Example

import { verifyMessageSignature } from 'micro-stacks/connect';

// original message
const message = 'hi there how are you';

// from the wallet
const payload = {
  signature: '0c956388e3bf84a2873b2fdd9c6845cceb14cea0e342bdc233dbc25e32e84aa77d483f80160541c92bf3d48beed82dcbea58c3d3f93d7cbc3fbefdbd48cecf2e01',
  publicKey: '035b08fd4d14786187f51a3360864665fa437a9ad22bbdf7ae716d4599f26943a7',
};

const isValid = verifyMessageSignature({ message, signature: payload.signature, publicKey: payload.publicKey });