targetprocess-mcp-server
Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@targetprocess-mcp-servershow me my open bugs"
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
Targetprocess MCP Server
An MCP (Model Context Protocol) server that enables AI assistants to interact with the Targetprocess project management platform through structured tools and natural language workflows.
This server exposes powerful capabilities for querying, creating, and managing Targetprocess entities such as user stories, bugs, tasks, and features.
It acts as a bridge between LLM agents and the Targetprocess API, providing:
Structured tool-based access
Semantic, natural-language-driven workflows
Features
Create standalone bugs or bugs linked to a user story/bug card
Retrieve TP entities: bugs, user stories, features, releases
LLM-Friendly Tools
Designed for Claude MCP AI agents
Related MCP server: PingCode MCP Server
Use Cases examples:
"Show me currently active release"
"write me test cases based on 145322 tp user story"
"write detailed test cases based on 145642 bug, format them inside html element, create a test plan and add test cases to it"
"add a comment to 145155 card saying 'test'"
"write test cases based on 145640 feature"
"create a bug based on 145637 user story where Add Tile flyout (for a Static Tile) not show"
"search for a card with 'Text Element' title"
Available tools:
Releases
get_current_releases— List all current releases (no params needed)get_release_bugs— Get bugs for a release (name, optional results)get_release_features— Get features for a release (name, optional results)get_release_user_stories— Get user stories for a release (name, optional results)get_release_user_stories_with_description— Same as above but includes full descriptions (name, withDescription)get_release_open_bugs— Get only active/open bugs for a release (name, withDescription, optional results)get_release_open_user_stories— Get only active/open user stories for a release (name, withDescription, optional results)
Features
get_feature_user_stories— Get all user stories for a feature by its ID (id)get_not_covered_user_stories_in_feature— Get user stories in a feature not yet covered by tests, includescoveredfield based on "Test Automation" custom field (id)
User Stories
get_user_story_bugs— Get all bugs linked to a user story by its ID (id)
Tasks
get_in_progress_tasks_and_bugs— Get all Tasks and Bugs currently in "In Progress" state assigned to a given user (userId)create_task— Create a new task linked to a user story (title, userStoryId, optional description)list_my_user_stories— List User Stories assigned to the current user, optionally filtered by state (optional state, optional take, optional skip)list_my_bugs— List Bugs assigned to the current user, optionally filtered by state (optional state, optional take, optional skip)
Cards — Read
get_card_current_status— Get EntityState, TeamState, and assigned teams for a card (id, optional resourceType: UserStory | Bug | Feature, default: UserStory)get_bug_content— Fetch full content of a bug by ID (id)get_user_story_content— Fetch full content of a user story by ID (id)get_bug_comments— Get comments on a bug (id, optional results)get_user_story_comments— Get comments on a user story (id, optional results)get_user_story_test_cases— Fetch the linked test plan and all its test cases (with steps) for a user story (resourceId)search_tp_cards— Search TP cards by keyword or phrase in description (keyword, optional entityType: UserStories | Bugs, default: UserStories)
Cards — Write
add_comment— Post a comment to any card (id, comment)add_comment_with_user— Post a comment to any card and mention a specific user (id, comment, user object fromget_users)update_bug— Update an existing bug (id, optional title, optional bugContent, optional origin, optional projectId, optional teamId, optional entityStateId)Resolve state name → ID via
get_bug_workflowsbefore passingentityStateIdupdate_user_story— Update an existing user story (id, optional title, optional description, optional projectId, optional teamId, optional entityStateId)Resolve state name → ID via
get_user_story_workflowsbefore passingentityStateIdupdate_user_story_state— Update the sub-state (team assignment entity state) for a user story (id, optional entityStateId, optional teamId, optional teamAssignmentId)Call
get_user_story_contentfirst to find the assigned team andteamAssignmentIdCall
get_user_story_workflowsto resolve the target state name →entityStateId
create_bug— Create a standalone bug (title, bugContent, optional origin, optional projectId, optional teamId, optional entityStateName)originaccepted values:Production - Customer,Production - Internal,Pre-Release - Customer,Pre-Release - Internal,Regression - Dev01,Regression - Team Env,Manual QA(default),Developer Raised,OperationsentityStateNameaccepted values:Backlog,In Triage,Ready for Dev,In Dev,Blocked,PR Raised,Ready for Feature PCH,Ready for Feature QA,In Feature QA,Failed Feature QA,Ready for Merge,Ready to Deploy to Dev01,Ready for Dev01 QA,In Dev01 QA,Failed Dev01 QA,Ready to Deploy to prod,Closed
projectId and teamId are optional — fall back to TP_PROJECT_ID and TP_TEAM_ID from config
create_bug_based_on_card— Create a bug linked to an existing user story or bug card (card object with id+type, title, bugContent, optional origin, optional projectId, optional teamId)
projectId and teamId are optional — fall back to TP_PROJECT_ID and TP_TEAM_ID from config
create_user_story— Create a new user story (title, optional description, optional featureId, optional releaseId, optional projectId, optional teamId)
projectId and teamId are optional — fall back to TP_PROJECT_ID and TP_TEAM_ID from config
create_feature— Create a new feature (title, optional description, optional epicId, optional releaseId, optional projectId, optional teamId)
projectId and teamId are optional — fall back to TP_PROJECT_ID and TP_TEAM_ID from config
create_test_plan— Create a test plan linked to a UserStory, Bug, or Feature (title, resourceId, optional resourceType, optional description/startDate/endDate)
requires TP_PROJECT_ID,
Test Case Workflows
write_test_cases— Fetch a card (UserStory, Bug, or Feature) by ID and trigger the full test case writing workflow: Claude analyzes the card, generates detailed test cases covering happy path, edge cases, and error scenarios, creates a linked test plan viacreate_test_plan, then callsadd_test_cases_to_test_plan. Each test case description contains Preconditions and Test Type as HTML; steps are passed as a structured array (resourceId, optional resourceType)add_test_cases_to_test_plan— Add pre-generated test cases to an existing test plan. Each test case has aname, an HTMLdescription(Preconditions and Test Type only), and astepsarray of{ description, result }objects — steps are created via the TP test step API rather than embedded in the description (testPlanId, testCases array of {name, description, steps})
Processes & Workflows
get_processes— Get all Targetprocess processes (no params needed)get_process_workflows— Get workflows for a specific process (processId)get_bug_workflows— Get all bug entity states/workflows for the configured process (no params needed)get_user_story_workflows— Get all user story entity states/workflows for the configured process (no params needed)
Projects
get_projects— Get all Targetprocess projects (no params needed)
Teams
get_teams— Get all Targetprocess teams returning id and name (no params needed)get_teams_and_team_assignments— Get all teams and team assignments (id and name for each) (no params needed)
User
get_logged_in_user— Get the currently logged-in user's info (no params needed)get_users— Get all Targetprocess users (no params needed)get_user_by_id— Get a single Targetprocess user by their ID (id)
Time Tracking
log_time— Log time spent on a Task, User Story, or Bug (entityId, entityType: Task | UserStory | Bug, hours, optional description, optional date)get_my_time_logs— Get recent time log entries submitted by the current user (optional take)
Developer Tools
get_commit_message— Returns a formatted commit message string for a task or bug ID (id, type: task | bug)Format for task on a user story:
F#<featureId> US#<userStoryId> T#<taskId> <title>Format for bug on a user story:F#<featureId> US#<userStoryId> B#<bugId> <title>Format for standalone bug:B#<bugId> <title>
Installation
Local Installation for Development
{
"mcpServers": {
"targetprocess": {
"command": "/Users/xxx/.config/nvm/versions/node/v22.14.0/bin/node",
"args": [
"/path/to/repository"
],
"env": {
"TP_TOKEN": "<your-tp-token>" // Settings -> Authentication and Security -> New Access Token,
"TP_BASE_URL": "<tp-api-endpoint>",
"TP_OWNER_ID": "<tp-owner-id>", // your user id
"TP_PROJECT_ID": "<tp-project-id>"
"TP_TEAM_ID": "<tp-team-id>"
}
}
}Claude Desktop
You need to havenode and npm installed on your machine.
{
"mcpServers": {
"targetprocess": {
"command": "npx",
"args": [
"-y",
"targetprocess-mcp-server"
],
"env": {
"TP_TOKEN": "<your-tp-token>" // Settings -> Authentication and Security -> New Access Token,
"TP_BASE_URL": "<tp-api-endpoint>", // required
"TP_OWNER_ID": "<tp-owner-id>", // required, your user id
"TP_PROJECT_ID": "<tp-project-id>", // optional see available tools
"TP_TEAM_ID": "<tp-team-id>" // optional see available tools
}
}
},
}
Claude Code
claude mcp add targetprocess -s user \
-e TP_TOKEN=<your-tp-token> -e TP_BASE_URL=<tp-api-endpoint> -- npx -y targetprocess-mcp-serverLocal Development
git clone --recursive https://github.com/SerhiiMaksymiv/targetprocess-mcp-server.git
cd targetprocess-mcp-server
npm install
npm run buildTesting
Tests live in tests/ and use Vitest. All tool handlers are extracted to src/handlers/ and tested with mocked TpClient instances — no network calls are made.
npx vitest run # run all tests once
npx vitest # watch modeCoverage
33 of 46 tools (72%) are covered by unit tests.
Test file | Handlers covered |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
This server cannot be installed
Maintenance
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.
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/SerhiiMaksymiv/targetprocess-mcp-server'
If you have feedback or need assistance with the MCP directory API, please join our Discord server