Skip to main content
Glama
JurreBrandsenInfoSupport

Zendesk API MCP Server

update_article

Modifies Zendesk Guide articles by updating title, body, locale, draft status, permissions, user segments, and labels via a structured API call using the article ID.

Input Schema

NameRequiredDescriptionDefault
bodyNoUpdated article body content (HTML)
draftNoWhether the article is a draft
idYesArticle ID to update
label_namesNoUpdated labels
localeNoUpdated article locale (e.g., 'en-us')
permission_group_idNoUpdated permission group ID
titleNoUpdated article title
user_segment_idNoUpdated user segment ID

Input Schema (JSON Schema)

{ "$schema": "http://json-schema.org/draft-07/schema#", "additionalProperties": false, "properties": { "body": { "description": "Updated article body content (HTML)", "type": "string" }, "draft": { "description": "Whether the article is a draft", "type": "boolean" }, "id": { "description": "Article ID to update", "type": "number" }, "label_names": { "description": "Updated labels", "items": { "type": "string" }, "type": "array" }, "locale": { "description": "Updated article locale (e.g., 'en-us')", "type": "string" }, "permission_group_id": { "description": "Updated permission group ID", "type": "number" }, "title": { "description": "Updated article title", "type": "string" }, "user_segment_id": { "description": "Updated user segment ID", "type": "number" } }, "required": [ "id" ], "type": "object" }

Implementation Reference

  • The async handler function for the 'update_article' MCP tool. Constructs optional article data from inputs and delegates to zendeskClient.updateArticle, formatting success/error responses.
    handler: async ({ id, title, body, locale, draft, permission_group_id, user_segment_id, label_names }) => { try { const articleData = {}; if (title !== undefined) articleData.title = title; if (body !== undefined) articleData.body = body; if (locale !== undefined) articleData.locale = locale; if (draft !== undefined) articleData.draft = draft; if (permission_group_id !== undefined) articleData.permission_group_id = permission_group_id; if (user_segment_id !== undefined) articleData.user_segment_id = user_segment_id; if (label_names !== undefined) articleData.label_names = label_names; const result = await zendeskClient.updateArticle(id, articleData); return { content: [{ type: "text", text: `Article updated successfully!\n\n${JSON.stringify(result, null, 2)}` }] }; } catch (error) { return { content: [{ type: "text", text: `Error updating article: ${error.message}` }], isError: true }; }
  • Zod input schema for the 'update_article' tool, defining required article ID and optional update fields.
    schema: { id: z.number().describe("Article ID to update"), title: z.string().optional().describe("Updated article title"), body: z.string().optional().describe("Updated article body content (HTML)"), locale: z.string().optional().describe("Updated article locale (e.g., 'en-us')"), draft: z.boolean().optional().describe("Whether the article is a draft"), permission_group_id: z.number().optional().describe("Updated permission group ID"), user_segment_id: z.number().optional().describe("Updated user segment ID"), label_names: z.array(z.string()).optional().describe("Updated labels") },
  • src/server.js:47-52 (registration)
    Tool registration loop in the MCP server that registers the 'update_article' tool (included in helpCenterTools spread into allTools) using server.tool(name, schema, handler).
    // Register each tool with the server allTools.forEach((tool) => { server.tool(tool.name, tool.schema, tool.handler, { description: tool.description, }); });
  • ZendeskClient helper method that sends a PUT request to the Zendesk Help Center API to update the specified article.
    async updateArticle(id, data) { return this.request("PUT", `/help_center/articles/${id}.json`, { article: data, }); }

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/JurreBrandsenInfoSupport/zendesk-mcp'

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