npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2026 – Pkg Stats / Ryan Hefner

apptio-targetprocess-mcp

v0.1.0

Published

A Model Context Protocol (MCP) server for Apptio Target Process

Readme

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

Documentation Search

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:

With Personal Access Token:

docker run -i --rm \
  -e TP_DOMAIN=your-domain.tpondemand.com \
  -e TP_TOKEN=your-personal-access-token \
  ghcr.io/aaronsb/apptio-target-process-mcp

Environment Variables

The server requires Personal Access Token authentication:

  • TP_DOMAIN: Your Targetprocess domain (e.g., company.tpondemand.com)
  • TP_TOKEN: Your Targetprocess Personal Access Token

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

The server uses Personal Access Token authentication:

{
  "domain": "your-domain.tpondemand.com",
  "credentials": {
    "token": "your-personal-access-token"
  }
}

Creating a Personal Access Token

To create a Personal Access Token in Targetprocess:

  1. Log in to your Targetprocess account
  2. Go to your user settings (click your avatar in the top-right corner)
  3. Navigate to "Settings > Authentication and Security > Personal Access Tokens"
  4. Click "Create Token" or "Generate New Token"
  5. Give your token a descriptive name (e.g., "MCP Server")
  6. Ensure you have the "Allow creating and using access tokens" role permission
  7. Copy the generated token immediately (it won't be shown again)
  8. Use this token in your configuration (it will be base64-encoded in format: userId:tokenSecret)

Personal Access Token benefits:

  • Tokens can be revoked without changing your password
  • Tokens remain valid even after password changes
  • You can create multiple tokens for different applications
  • Tokens don't expose your password if accidentally committed to version control
  • More secure than Basic authentication, especially in SSO environments

License

MIT