Skip to main content
Glama

add_project

Create a new project in Backlog with customizable settings such as project name, key, chart and subtask functionality, text formatting rules, and leader editing permissions.

Instructions

Creates a new project

Input Schema

TableJSON Schema
NameRequiredDescriptionDefault
chartEnabledNoWhether to enable chart (default: false)
keyYesProject key
nameYesProject name
projectLeaderCanEditProjectLeaderNoWhether project leaders can edit other project leaders (default: false)
subtaskingEnabledNoWhether to enable subtasking (default: false)
textFormattingRuleNoText formatting rule (default: 'backlog')

Implementation Reference

  • The async handler function for the 'add_project' tool. It takes input parameters and calls backlog.postProject() to create a new project, applying default values for optional boolean and enum fields.
    handler: async ({ name, key, chartEnabled, subtaskingEnabled, projectLeaderCanEditProjectLeader, textFormattingRule, }) => backlog.postProject({ name, key, chartEnabled: chartEnabled ?? false, subtaskingEnabled: subtaskingEnabled ?? false, projectLeaderCanEditProjectLeader: projectLeaderCanEditProjectLeader ?? false, textFormattingRule: textFormattingRule ?? 'backlog', }), };
  • Zod schema definition for the input parameters of the 'add_project' tool using buildToolSchema.
    const addProjectSchema = buildToolSchema((t) => ({ name: z.string().describe(t('TOOL_ADD_PROJECT_NAME', 'Project name')), key: z.string().describe(t('TOOL_ADD_PROJECT_KEY', 'Project key')), chartEnabled: z .boolean() .optional() .describe( t( 'TOOL_ADD_PROJECT_CHART_ENABLED', 'Whether to enable chart (default: false)' ) ), subtaskingEnabled: z .boolean() .optional() .describe( t( 'TOOL_ADD_PROJECT_SUBTASKING_ENABLED', 'Whether to enable subtasking (default: false)' ) ), projectLeaderCanEditProjectLeader: z .boolean() .optional() .describe( t( 'TOOL_ADD_PROJECT_LEADER_CAN_EDIT', 'Whether project leaders can edit other project leaders (default: false)' ) ), textFormattingRule: z .enum(['backlog', 'markdown']) .optional() .describe( t( 'TOOL_ADD_PROJECT_TEXT_FORMATTING', "Text formatting rule (default: 'backlog')" ) ), }));
  • The 'add_project' tool is registered (via addProjectTool factory) in the 'project' toolset group within the allTools function.
    tools: [ getProjectListTool(backlog, helper), addProjectTool(backlog, helper), getProjectTool(backlog, helper), updateProjectTool(backlog, helper), deleteProjectTool(backlog, helper), ],
  • Full tool definition including name 'add_project', input schema (from addProjectSchema), output schema (ProjectSchema), description, and handler. This factory function is called during registration.
    export const addProjectTool = ( backlog: Backlog, { t }: TranslationHelper ): ToolDefinition< ReturnType<typeof addProjectSchema>, (typeof ProjectSchema)['shape'] > => { return { name: 'add_project', description: t('TOOL_ADD_PROJECT_DESCRIPTION', 'Creates a new project'), schema: z.object(addProjectSchema(t)), outputSchema: ProjectSchema, handler: async ({ name, key, chartEnabled, subtaskingEnabled, projectLeaderCanEditProjectLeader, textFormattingRule, }) => backlog.postProject({ name, key, chartEnabled: chartEnabled ?? false, subtaskingEnabled: subtaskingEnabled ?? false, projectLeaderCanEditProjectLeader: projectLeaderCanEditProjectLeader ?? false, textFormattingRule: textFormattingRule ?? 'backlog', }), }; };

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/nulab/backlog-mcp-server'

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