Skip to main content
Use MiniKit.attestation() to request an app attestation token for a request hash.

Availability

  • Works natively in World App
  • Supports a custom fallback outside World App

Basic Usage

import { MiniKit } from "@worldcoin/minikit-js";
import type {
  CommandResultByVia,
  MiniAppAttestationSuccessPayload,
  MiniKitAttestationOptions,
} from "@worldcoin/minikit-js/commands";

export async function requestAttestation() {
  const input = {
    requestHash: "0x1234",
  } satisfies MiniKitAttestationOptions;

  const result: CommandResultByVia<
    MiniAppAttestationSuccessPayload,
    MiniAppAttestationSuccessPayload,
    "minikit"
  > = await MiniKit.attestation(input);

  console.log(result.data.token);
}

Result

type AttestationResponse =
  | {
      executedWith: "minikit";
      data: {
        status: "success";
        version: number;
        token: string;
      };
    }
  | {
      executedWith: "fallback";
      data: unknown;
    };

Fallback Behavior

Use a custom fallback if you want equivalent behavior outside World App.

Error Codes

CodeMeaning
unauthorizedThe request is not authorized
attestation_failedAttestation generation failed
integrity_failedIntegrity checks failed
invalid_inputThe request hash is invalid
unsupported_versionThe command version is not supported