Skip to main content
Glama
ggiraudon

Email MCP Server

by ggiraudon

getMessageList

Retrieve a list of email messages from a specified folder in an email server. Specify folder name and optional range parameters to fetch messages.

Instructions

Returns a list of messages in a given folder.

Input Schema

TableJSON Schema
NameRequiredDescriptionDefault
folderYes
startNo
endNo*

Implementation Reference

  • Main tool handler: defines name, description, parameters schema, and execute function that validates args, connects via factory, calls controller.getMessageList, returns JSON stringified messages.
    export const GetMessageListTool: Tool<any, typeof GetMessageListInput> = {
      name: "getMessageList",
      description: "Returns a list of messages in a given folder.",
      parameters: GetMessageListInput,
      async execute(args, context) {
        if (!args || typeof args !== 'object' || !('folder' in args)) {
          throw new Error("Missing required arguments");
        }
        const controller = ImapControllerFactory.getInstance();
        await controller.connect();
        const messages: MailItem[] = await controller.getMessageList(args.folder, args.start, args.end);
        return JSON.stringify({ messages });
      }
    };
  • Zod input schema defining required folder (string 2-100 chars), optional start number (default 1), optional end string (default '*').
    const GetMessageListInput = z.object({
      folder: z.string().min(2).max(100),
      start: z.number().min(1).optional().default(1),
      end: z.string().min(1).optional().default('*'),
    });
  • src/index.ts:51-51 (registration)
    Registers the GetMessageListTool instance with the FastMCP server.
    server.addTool(GetMessageListTool);
  • Core helper method in ImapController that opens IMAP box, fetches headers for range start:end, parses subject/from/to/date/uid into MessageListItem objects.
    getMessageList(folder: string, start: number, end: number|string): Promise<MessageListItem[]> {
        return new Promise((resolve, reject) => {
            this.imap.openBox(folder, true, (err: Error | null, box: Imap.Box) => {
                if (err) return reject(err);
                const results: MessageListItem[] = [];
                const fetch = this.imap.seq.fetch(`${start}:${end}`, { bodies: 'HEADER.FIELDS (FROM TO SUBJECT DATE)', struct: true });
                fetch.on('message', (msg: ImapMessage, seqno: number) => {
                    const item: any = { };
                    msg.on('body', (stream: any) => {
                        let buffer = '';
                        stream.on('data', (chunk: Buffer) => buffer += chunk.toString('utf8'));
                        stream.on('end', () => {
                            const headers = Imap.parseHeader(buffer);
                            item.subject = headers.subject?.[0];
                            item.from = parseAddressList(headers.from)[0];
                            item.to = parseAddressList(headers.to);
                            item.date = headers.date?.[0] ? new Date(headers.date[0]) : undefined;
                        });
                    });
                    msg.once('attributes', (attrs: any) => {
                        item.id = attrs.uid;
                    });
                    msg.once('end', () => {
                        //console.log('Parsed MessageListItem:', item);
                        results.push(MessageListItem.parse(item));
                    });
                });
                fetch.once('error', (err:Error|null) => reject(err));
                fetch.once('end', () => resolve(results));
            });
        });
    }

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/ggiraudon/emailMCPServer'

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