Skip to main content
Glama
tanmay4l

Futarchy MCP Server

by tanmay4l

getProposals

Retrieve all governance proposals for a specific DAO to review active decisions and voting status.

Instructions

Get all proposals for a specific DAO

Input Schema

TableJSON Schema
NameRequiredDescriptionDefault
daoIdYesThe ID of the DAO to get proposals for

Implementation Reference

  • The asynchronous handler function for the MCP 'getProposals' tool. It calls the FutarchyApiClient.getProposals method with the provided daoId, handles the response, and returns formatted text content or an error.
    async ({ daoId }) => {
      try {
        const response = await apiClient.getProposals(daoId);
        
        if (!response.success) {
          return {
            content: [
              {
                type: "text" as const,
                text: response.error || 'Unknown error',
              },
            ],
            isError: true,
          };
        }
        
        return {
          content: [
            {
              type: "text" as const,
              text: JSON.stringify(response.data, null, 2),
            },
          ],
        };
      } catch (error: any) {
        return {
          content: [
            {
              type: "text" as const,
              text: `Error fetching proposals: ${error.message || 'Unknown error'}`,
            },
          ],
          isError: true,
        };
      }
  • Registration of the 'getProposals' MCP tool using McpServer.tool(), including the tool name, description, input schema (daoId), and handler reference.
    server.tool(
      "getProposals",
      "Get all proposals for a specific DAO",
      {
        daoId: z.string().describe("The ID of the DAO to get proposals for"),
      },
      async ({ daoId }) => {
        try {
          const response = await apiClient.getProposals(daoId);
          
          if (!response.success) {
            return {
              content: [
                {
                  type: "text" as const,
                  text: response.error || 'Unknown error',
                },
              ],
              isError: true,
            };
          }
          
          return {
            content: [
              {
                type: "text" as const,
                text: JSON.stringify(response.data, null, 2),
              },
            ],
          };
        } catch (error: any) {
          return {
            content: [
              {
                type: "text" as const,
                text: `Error fetching proposals: ${error.message || 'Unknown error'}`,
              },
            ],
            isError: true,
          };
        }
      }
    );
  • Zod schema definition for the input parameters of getProposals (GetProposalsParamsSchema), matching the inline schema used in registration.
    export const GetProposalsParamsSchema = z.object({
      daoId: z.string().describe("The ID of the DAO to get proposals for"),
    });
  • Helper function in FutarchyApiClient that performs the actual HTTP fetch to retrieve proposals for a given DAO ID from the backend API.
    async getProposals(daoId: string): Promise<Response> {
      try {
        const response = await fetch(`${this.baseUrl}/daos/${daoId}/proposals`);
        if (!response.ok) {
          throw new Error(`HTTP error! Status: ${response.status}`);
        }
        const data = await response.json();
        
        return {
          success: true,
          data: data.proposals
        };
      } catch (error: any) {
        return {
          success: false,
          error: error.message || `Failed to fetch proposals for DAO: ${daoId}`
        };
      }

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/tanmay4l/FutarchyMCPServer'

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