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.0.tar.gz (75.7 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.0-py3-none-any.whl (13.8 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: p6xer_mcp_server-0.1.0.tar.gz
  • Upload date:
  • Size: 75.7 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.0.tar.gz
Algorithm Hash digest
SHA256 f0e15f7416477e3da242e892b53525bdc3c85267855449d51addfcf4776877b2
MD5 463765cc7a237843a82a3c6f4ec30626
BLAKE2b-256 8f0d789eddb9615517a0785a173535699446796a4f7c23b3f5b1b8f1f05f2f8b

See more details on using hashes here.

Provenance

The following attestation bundles were made for p6xer_mcp_server-0.1.0.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.0-py3-none-any.whl.

File metadata

File hashes

Hashes for p6xer_mcp_server-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 6e0dc339729e71d8490085929be9a77cd676e1ac62bd4a0db7c3254fbfba5acb
MD5 eeeb553585eeb31eb0f57a6f389fd951
BLAKE2b-256 d73c2eb2750ff4377acf82db26a67c808ad9c821d7979cb89b93330a9470bb53

See more details on using hashes here.

Provenance

The following attestation bundles were made for p6xer_mcp_server-0.1.0-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