Targetprocess MCP Server

by aaronsb
Verified

hybrid server

The server is able to function both locally and remotely, depending on the configuration or use case.

Integrations

  • Provides tools for interacting with Targetprocess, a project management and agile planning platform. Enables searching, creating, and updating entities (User Stories, Bugs, Tasks, Features, etc.), querying with complex filters, exploring data models and relationships, and handling authentication and API interactions.

Targetprocess MCP Server

The Model Context Protocol (MCP) is a standard that enables AI assistants to interact with external tools and services through a unified interface. MCP servers provide these capabilities by exposing tools and resources that AI assistants can use to accomplish tasks.

This MCP server provides tools for interacting with Targetprocess, a project management and agile planning platform. It enables AI assistants to:

  • Search and retrieve Targetprocess entities (User Stories, Bugs, Tasks, Features, etc.)
  • Create and update entities with proper validation
  • Query entities with complex filters and includes
  • Inspect and discover the Targetprocess data model
  • Handle authentication and API interactions safely

Key Features

  • Data Model Discovery: Explore and understand complex Targetprocess implementations
  • Powerful Querying: Use complex filters and includes to retrieve exactly the data you need
  • Entity Management: Create and update entities with proper validation
  • Relationship Exploration: Understand how different entities relate to each other
  • Error Handling: Robust error handling with retries and informative messages
  • Documentation Integration: Built-in access to Targetprocess documentation

Use Cases

This MCP server is particularly valuable in corporate settings where Targetprocess might handle millions of records with complex schemas and data models. Common use cases include:

  • Data Model Discovery: Map and understand complex Targetprocess implementations
  • Enterprise Analytics: Extract and analyze data across millions of records
  • Cross-System Integration: Use as a bridge between Targetprocess and other systems
  • Custom Reporting: Build specialized reports not available in the standard UI
  • Batch Operations: Manage large-scale changes across many entities
  • Schema Exploration: Discover custom fields and relationships in complex implementations

For detailed examples and implementation guides, see USECASES.md.

Getting Started

Clone the repository recursively to include the documentation search tool:

git clone --recursive https://github.com/aaronsb/apptio-target-process-mcp.git cd apptio-target-process-mcp

Development Resources

This repository includes a documentation scraper/searcher for Targetprocess developer documentation as a submodule. You can use it to quickly search through Targetprocess's documentation:

# From the project root: pushd resources/target-process-docs && npm install && ./refresh-docs.sh && popd # First time setup # To search documentation (from any directory): pushd resources/target-process-docs && ./search-docs.sh "your search query" && popd # Example search: pushd resources/target-process-docs && ./search-docs.sh "entity states" && popd

The search tool is located in resources/target-process-docs. We use pushd/popd commands here because:

  1. The tool requires access to its database files using relative paths
  2. pushd saves your current directory location
  3. Temporarily changes to the tool's directory to run the command
  4. popd automatically returns you to your previous location This approach lets you run searches from any directory while ensuring the tool can find its database files.

This tool provides a powerful way to search through Targetprocess's developer documentation locally. The search results include relevant documentation sections with context, making it easier to find specific API details or implementation guidance.

CI/CD Pipeline

The project uses GitHub Actions for automated builds:

  • Pushes to main branch trigger new container builds
  • Version tags (v*..) create versioned releases
  • Images are published to GitHub Container Registry

You can use the published image:

docker run -i --rm \ -e TP_DOMAIN=your-domain.tpondemand.com \ -e TP_USERNAME=your-username \ -e TP_PASSWORD=your-password \ ghcr.io/aaronsb/apptio-target-process-mcp

Environment Variables

  • TP_DOMAIN: Your Targetprocess domain (e.g., company.tpondemand.com)
  • TP_USERNAME: Your Targetprocess username
  • TP_PASSWORD: Your Targetprocess password

Local Development with Docker

For local development and testing, use the provided scripts:

  1. Build the local image:

    Note: The build script uses Docker's quiet mode by default to minimize log output. This is intentional to reduce AI token consumption when interacting with tools like Cline that process the build output. In quiet mode, the full build log is saved to /tmp/apptio-target-process-mcp/docker-build.log. Use --verbose flag to see build output directly in the terminal.

./scripts/build-local.sh # Quiet mode (default), logs to file ./scripts/build-local.sh --verbose # Full build output in terminal
  1. Run the local image:
./scripts/run-local.sh
  1. Configure Cline: Edit ~/.config/Code/User/globalStorage/saoudrizwan.claude-dev/settings/cline_mcp_settings.json:
{ "mcpServers": { "targetprocess": { "command": "./scripts/run-local.sh", "disabled": false, "autoApprove": [] } } }

Local Development without Docker

Prerequisites

  • Node.js 20 or later
  • npm

Setup

  1. Clone the repository recursively:
git clone --recursive https://github.com/modelcontextprotocol/targetprocess-mcp.git cd targetprocess-mcp

Note: The --recursive flag is required to also clone the documentation search tool submodule.

  1. Install dependencies:
npm install
  1. Copy the example config:
cp config/targetprocess.example.json config/targetprocess.json
  1. Edit config/targetprocess.json with your Targetprocess credentials.

Building

npm run build

Running

node build/index.js

API Capabilities

For detailed examples and common use cases, see USECASES.md.

The MCP server provides the following tools for interacting with Targetprocess:

search_entities

Search for Targetprocess entities (UserStory, Bug, Task, Feature) with filtering and includes.

{ "type": "UserStory", // Required: Entity type to search for "where": "EntityState.Name eq 'Open'", // Optional: Filter expression "take": 10, // Optional: Number of items to return (default: 100, max: 1000) "include": ["Project", "Team"] // Optional: Related data to include }

get_entity

Get detailed information about a specific entity.

{ "type": "UserStory", // Required: Entity type "id": 123456, // Required: Entity ID "include": ["Project", "Team"] // Optional: Related data to include }

create_entity

Create a new entity in Targetprocess.

{ "type": "UserStory", // Required: Entity type to create "name": "Story Name", // Required: Entity name "description": "Details...", // Optional: Entity description "project": { // Required: Project to create in "id": 123 }, "team": { // Optional: Team to assign "id": 456 } }

update_entity

Update an existing entity.

{ "type": "UserStory", // Required: Entity type "id": 123456, // Required: Entity ID "fields": { // Required: Fields to update "name": "New Name", "description": "New description", "status": { "id": 789 } } }

inspect_object

Inspect Targetprocess objects and properties through the API.

{ "action": "list_types", // Required: Action to perform "entityType": "UserStory", // Required for some actions: Entity type to inspect "propertyName": "Description" // Required for some actions: Property to inspect }

Performance Considerations

When working with large Targetprocess instances that may contain millions of records:

  1. Use Specific Queries: Always use the most specific query possible to limit result sets
  2. Limit Result Size: Use the take parameter to limit the number of results returned
  3. Include Only Necessary Data: Only include related data that you actually need
  4. Consider Pagination: For large result sets, implement pagination in your application
  5. Batch Operations: For bulk operations, consider batching requests to avoid overloading the API

LLM Integration

This MCP server can be used with various AI assistants that support the Model Context Protocol:

For configuration and setup instructions, see llms-install.md.

Configuration

The server can be configured either through environment variables or a JSON config file.

Config File Format

{ "domain": "your-domain.tpondemand.com", "credentials": { "username": "your-username", "password": "your-password" } }

License

MIT

You must be authenticated.

A
security – no known vulnerabilities
A
license - permissive license
A
quality - confirmed to work

Provides tools for interacting with Targetprocess, a project management and agile planning platform, enabling AI assistants to search, create, and update project entities with proper validation.

  1. Key Features
    1. Use Cases
      1. Getting Started
        1. Development Resources
          1. Documentation Search
            1. CI/CD Pipeline
              1. Environment Variables
                1. Local Development with Docker
                  1. Local Development without Docker
                    1. Prerequisites
                      1. Setup
                        1. Building
                          1. Running
                          2. API Capabilities
                            1. search_entities
                              1. get_entity
                                1. create_entity
                                  1. update_entity
                                    1. inspect_object
                                    2. Performance Considerations
                                      1. LLM Integration
                                        1. Configuration
                                          1. Config File Format
                                          2. License