Skip to main content

MCP server for Primavera P6 XER schedule files — parse, analyze, and quality-check with AI

Project description

P6XER MCP Server

PyPI version Python 3.12+ License: MIT MCP

A full-featured Model Context Protocol (MCP) server for Primavera P6 XER files, built on PyP6XER.

Exposes 13 Tools, 3 Resources, and 2 Prompts so any MCP-compatible AI client (Claude Desktop, Claude Code, Cursor, etc.) can interactively parse, query, and analyze .xer schedule files.


🚀 Features

🔧 Tools (13)

Tool Description
parse_xer_file Parse an XER file — project list, totals, status breakdowns
get_project_activities Activities with filters: project_id, project_short_name, status, task_type
get_critical_path Critical path activities (float ≤ 0), sorted by early start
analyze_resource_utilization Planned/actual hours & costs per resource; over-allocation flags
check_schedule_quality DCMA-style check: missing logic, long durations, high float, unresourced tasks
get_resources List resources, optionally filtered by type
get_resource_assignments Resource–activity assignments with enriched names and costs
get_wbs Work Breakdown Structure hierarchy
get_relationships Predecessor/successor relationships enriched with task codes
get_calendars Calendar definitions with hours-per-period data
get_schedule_summary At-a-glance stats: counts, date range, critical count
get_earned_value EVM: PV, EV, AC, CV, SV, CPI, SPI, EAC per project
get_activity_detail Full detail for one activity (preds + succs + resources)

📋 Resources (3)

URI Description
xer-project://{file_path}/{project_id} Detailed text summary of a specific project
xer-activities://{file_path} Activities summary with status breakdown and duration stats
xer-resources://{file_path} Resources summary with type breakdown and assignment stats

💬 Prompts (2)

Prompt Types
analyze_xer_project general · schedule · resources · progress · quality
xer_reporting_prompt executive · detailed · critical_path · resource · milestone

� Install from Store

Via PyPI (uvx — no install needed)

uvx p6xer-mcp-server

Via PyPI (pip)

pip install p6xer-mcp-server
p6xer-mcp-server

Via Smithery

Search for p6xer-mcp-server on smithery.ai and click Install. It will generate the correct Claude Desktop config automatically.

Via GitHub MCP Registry

The server is listed in the GitHub MCP Registry. In Claude Code:

claude mcp add p6xer -- uvx p6xer-mcp-server

Claude Desktop config (after PyPI install)

{
  "mcpServers": {
    "p6xer": {
      "command": "uvx",
      "args": ["p6xer-mcp-server"]
    }
  }
}

�📦 Installation

# Clone the repo
git clone https://github.com/osama-ata/p6xer-mcp-server.git
cd p6xer-mcp-server

# Install with uv (recommended)
uv sync

# Or with pip
pip install "mcp[cli]>=1.6.0,<2.0.0" pyp6xer

🏃 Running

Development / MCP Inspector:

uv run mcp dev src/p6xer_mcp_server/server.py

Stdio (Claude Desktop / Claude Code):

uv run p6xer-mcp-server

🔌 Claude Desktop

Add to claude_desktop_config.json:

{
  "mcpServers": {
    "p6xer": {
      "command": "uvx",
      "args": ["p6xer-mcp-server"]
    }
  }
}

Config file locations:

  • macOS: ~/Library/Application Support/Claude/claude_desktop_config.json
  • Windows: %APPDATA%\Claude\claude_desktop_config.json
  • Linux: ~/.config/Claude/claude_desktop_config.json

🔌 Claude Code (CLI)

claude mcp add p6xer -- uvx p6xer-mcp-server

💬 Example Prompts

Once connected:

Parse project.xer and give me an overview of all projects

What are all the critical path activities, sorted by start date?

Run a DCMA schedule quality check on project.xer

Calculate earned value metrics — what are the CPI and SPI?

Show all resource assignments for "John Smith"

What are the predecessors and successors of activity A1000?

List all over-allocated labor resources

Generate an executive summary report for project.xer

📊 Tool Reference

Filter parameters (most tools accept)

  • project_id – numeric P6 project ID (e.g. "1234")
  • project_short_name – project short name string (e.g. "PROJ1")

Status codes

TK_NotStart · TK_Active · TK_Complete

Task types

TT_Task · TT_Mile · TT_FinMile · TT_WBS

Resource types

RT_Labor · RT_Mat · RT_Equip


🗂️ Project Structure

p6xer-mcp-server/
├── src/
│   └── p6xer_mcp_server/
│       ├── __init__.py
│       └── server.py       # All tools, resources, and prompts
├── manifest.json           # MCPB bundle manifest
├── mcp.json                # MCP registry metadata
├── smithery.yaml           # Smithery registry configuration
├── pyproject.toml
└── README.md

📋 Requirements

  • Python ≥ 3.10
  • mcp[cli] >= 1.6.0, < 2.0.0
  • pyp6xer >= 1.16.0

📄 License

MIT


🚢 Publishing to PyPI (GitHub Actions + Trusted Publishing)

This repository includes a release workflow at .github/workflows/publish-to-pypi.yml based on the PyPA guide and pypa/gh-action-pypi-publish.

1) Configure Trusted Publishers

Create trusted publishers for this exact workflow file:

Use these values:

  • Owner: osama-ata
  • Repository: p6xer-mcp-server
  • Workflow file: publish-to-pypi.yml
  • Environment: pypi (for PyPI), testpypi (for TestPyPI)
  • Project name: p6xer-mcp-server

2) Create GitHub Environments

In repository settings, create two environments:

  • pypi
  • testpypi

Recommended security setup:

  • Require manual approval for pypi
  • No approval required for testpypi

3) Build locally (optional sanity check)

python -m pip install --upgrade build twine
python -m build
python -m twine check dist/*

4) Release flow

  • Push to main: publishes to TestPyPI
  • Push tag v* (for example v0.1.1): publishes to PyPI
git tag v0.1.1
git push origin v0.1.1

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

p6xer_mcp_server-0.1.2.tar.gz (75.6 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

p6xer_mcp_server-0.1.2-py3-none-any.whl (13.8 kB view details)

Uploaded Python 3

File details

Details for the file p6xer_mcp_server-0.1.2.tar.gz.

File metadata

  • Download URL: p6xer_mcp_server-0.1.2.tar.gz
  • Upload date:
  • Size: 75.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for p6xer_mcp_server-0.1.2.tar.gz
Algorithm Hash digest
SHA256 db70f19b6e967ab95943cbaeb51c76510e8a53ee4aea2d94631e5e23644f03b0
MD5 3ce3591f516d8251a6408df9497866df
BLAKE2b-256 01584232822dfe0b5925af83ec3194d723269336efe08179a84a28c1b5f8034c

See more details on using hashes here.

Provenance

The following attestation bundles were made for p6xer_mcp_server-0.1.2.tar.gz:

Publisher: publish-to-pypi.yml on osama-ata/p6xer-mcp-server

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file p6xer_mcp_server-0.1.2-py3-none-any.whl.

File metadata

File hashes

Hashes for p6xer_mcp_server-0.1.2-py3-none-any.whl
Algorithm Hash digest
SHA256 026a443cae5c43a88fd4c939612dabb17b5fd25da7a2027406abb35b709b78d8
MD5 d4bd2c8f30f0bd140dff834004faa4b9
BLAKE2b-256 8c8d016acebce3d37ec73f1309195828c89d0c99de7b44cf0e6680a2e1f25df9

See more details on using hashes here.

Provenance

The following attestation bundles were made for p6xer_mcp_server-0.1.2-py3-none-any.whl:

Publisher: publish-to-pypi.yml on osama-ata/p6xer-mcp-server

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page