Skip to main content
Glama

request_profile_deletion

Remove customer profiles from Klaviyo by providing email, phone number, or profile ID to comply with data privacy regulations and manage marketing lists.

Input Schema

TableJSON Schema
NameRequiredDescriptionDefault
emailNoEmail of the profile to delete
phone_numberNoPhone number of the profile to delete
profile_idNoID of the profile to delete

Implementation Reference

  • Handler function that processes the deletion request by building a payload from input params and posting to Klaviyo's data-privacy-deletion-jobs endpoint, returning the result or error.
    async (params) => { try { const payload = { data: { type: "data-privacy-deletion-job", attributes: {} } }; if (params.email) { payload.data.attributes.email = params.email; } if (params.phone_number) { payload.data.attributes.phone_number = params.phone_number; } if (params.profile_id) { payload.data.attributes.profile_id = params.profile_id; } const result = await klaviyoClient.post('/data-privacy-deletion-jobs/', payload); return { content: [{ type: "text", text: JSON.stringify(result, null, 2) }] }; } catch (error) { return { content: [{ type: "text", text: `Error requesting profile deletion: ${error.message}` }], isError: true }; } },
  • Input schema using Zod for optional parameters: email, phone_number, profile_id.
    { email: z.string().email().optional().describe("Email of the profile to delete"), phone_number: z.string().optional().describe("Phone number of the profile to delete"), profile_id: z.string().optional().describe("ID of the profile to delete") },
  • Direct registration of the 'request_profile_deletion' tool via server.tool(), specifying schema, handler, and description.
    "request_profile_deletion", { email: z.string().email().optional().describe("Email of the profile to delete"), phone_number: z.string().optional().describe("Phone number of the profile to delete"), profile_id: z.string().optional().describe("ID of the profile to delete") }, async (params) => { try { const payload = { data: { type: "data-privacy-deletion-job", attributes: {} } }; if (params.email) { payload.data.attributes.email = params.email; } if (params.phone_number) { payload.data.attributes.phone_number = params.phone_number; } if (params.profile_id) { payload.data.attributes.profile_id = params.profile_id; } const result = await klaviyoClient.post('/data-privacy-deletion-jobs/', payload); return { content: [{ type: "text", text: JSON.stringify(result, null, 2) }] }; } catch (error) { return { content: [{ type: "text", text: `Error requesting profile deletion: ${error.message}` }], isError: true }; } }, { description: "Request deletion of a profile for data privacy compliance" } );
  • src/server.js:44-44 (registration)
    Invocation of registerDataPrivacyTools on the main MCP server, which registers the request_profile_deletion tool among others.
    registerDataPrivacyTools(server);

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/ivan-rivera-projects/Klaviyo-MCP-Server-Enhanced'

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