Skip to main content
Glama
AlyssonM

HiveAuth MCP Server

by AlyssonM

revoke_credential

Revoke verifiable credentials by updating their status in the W3C Status List 2021 bitstring. Specify credential ID, status list index, and optional reason for revocation.

Instructions

Revoke a verifiable credential using W3C Status List 2021 specification. Updates the credential status in the bitstring status list.

Input Schema

TableJSON Schema
NameRequiredDescriptionDefault
credentialIdYes
statusListIndexYes
reasonNoReason for revocation

Implementation Reference

  • The core handler function that executes the revoke_credential tool. It validates and sanitizes the input using the schema, makes a POST request to the HiveAuth /api/revoke endpoint with credentialId, statusListIndex, and reason, handles the response to format success details or error, and returns a CallToolResult.
    export async function revokeCredential(args: any): Promise<CallToolResult> {
      // Validate and sanitize input
      const validation = validateAndSanitizeInput(RevokeCredentialInputSchema, args, 'revoke_credential');
      
      if (!validation.success) {
        return createValidationErrorResult(validation.error!);
      }
    
      const data = validation.data!;
      const { credentialId, statusListIndex, reason } = data;
    
      const HIVEAUTH_API_BASE_URL = process.env.HIVEAUTH_API_BASE_URL || 'http://localhost:3000';
      const REVOKE_ENDPOINT = `${HIVEAUTH_API_BASE_URL}/api/revoke`;
    
      try {
        const response = await fetch(REVOKE_ENDPOINT, {
          method: 'POST',
          headers: {
            'Content-Type': 'application/json',
          },
          body: JSON.stringify({ 
            credentialId, 
            statusListIndex,
            reason
          }),
        });
    
        if (!response.ok) {
          const errorData = await response.json().catch(() => ({ message: response.statusText }));
          throw new Error(`Failed to revoke credential: ${errorData.message}`);
        }
    
        const result = await response.json();
    
        const details = [
          `• Credential ID: ${credentialId}`,
          `• Status List Index: ${statusListIndex}`,
          `• Revocation Status: ✅ Successfully revoked`,
          `• Status List Updated: ${result.statusListCredential ? '✅ Yes' : '❌ No'}`
        ];
    
        if (result.statusListCredential?.id) {
          details.push(`• Updated Status List ID: ${result.statusListCredential.id}`);
        }
    
        return {
          content: [
            {
              type: 'text',
              text: `Credential Revocation Result:\n\n${details.join('\n')}`
            },
            {
              type: 'text',
              text: `\`\`\`json\n${JSON.stringify(result, null, 2)}\n\`\`\``
            }
          ]
        };
      } catch (error: any) {
        return {
          content: [
            {
              type: 'text',
              text: `Failed to revoke credential: ${error.message}`
            }
          ],
          isError: true
        };
      }
    }
  • Zod input schema for the revoke_credential tool defining required credentialId (string), statusListIndex (non-negative integer), and optional reason (string). Referenced in TOOL_SCHEMAS.revoke_credential.
    export const RevokeCredentialInputSchema = z.object({
      credentialId: z.string().min(1, 'Credential ID is required'),
      statusListIndex: z.number().int().min(0, 'Status list index must be a non-negative integer'),
      reason: z.string().optional().describe('Reason for revocation')
    });
  • Tool definition entry in TOOL_DEFINITIONS array used by createMCPTools() to generate the MCP Tool object with name, description, and JSON Schema-converted input schema for listTools.
    {
      name: 'revoke_credential',
      description: 'Revoke a verifiable credential using W3C Status List 2021 specification. Updates the credential status in the bitstring status list.',
      inputSchema: TOOL_SCHEMAS.revoke_credential
    },
  • src/index.ts:92-93 (registration)
    Handler dispatch registration in the main CallToolRequest switch statement, calling the revokeCredential function with arguments.
    case 'revoke_credential':
      return await revokeCredential(args);
  • src/index.ts:23-23 (registration)
    Import statement for the revokeCredential handler function used in the MCP server index.
    import { revokeCredential } from './tools/revokeCredential.js';

Latest Blog Posts

MCP directory API

We provide all the information about MCP servers via our MCP API.

curl -X GET 'https://glama.ai/api/mcp/v1/servers/AlyssonM/hiveauth-mcp'

If you have feedback or need assistance with the MCP directory API, please join our Discord server