Skip to main content

MCP server that connects Claude Desktop to Troi project management & time tracking

Project description

troi-mcp

MCP server that connects AI assistants to Troi project management, time tracking, and offer creation. Works with any MCP-compatible client (Claude Desktop, Claude Code, Cursor, etc.).

Features

  • 49 tools covering projects, offers, time tracking, contacts, customers, and more
  • Server-enforced permission layer — all write operations return a preview first; re-call with confirmed=true to execute
  • Irreversible action protection — offer number generation and approval submission get extra warnings
  • Price list integration — create offers directly from your Troi price list
  • Compound toolstroi_create_offer builds a complete project with phases and positions in one call

Setup

Quick Install (macOS, AirLST team)

The AirLST MCP Installer app handles everything automatically: installs uv, configures Claude Desktop, and sets up Troi (and optionally Pipedrive) with a guided UI.

  1. Download AirLST MCP Installer.app from your team
  2. Double-click to run — follow the prompts to enter your Troi credentials
  3. Restart Claude Desktop (Cmd+Q, then reopen)

To compile the installer from source:

osacompile -o "AirLST MCP Installer.app" install-airlst-mcp.applescript

Manual Setup

1. Install

pip install troi-mcp

2. Get your Troi API key

Troi → Menu (top left) → SicherheitscenterAPI v2 - Basic → copy the Token.

The Sicherheitscenter shows 3 sections — you only need the token from the first one (API v2 - Basic). The server uses HTTP Basic Auth (TROI_USER + TROI_API_KEY).

3. Add to your MCP client config

Claude Desktop — edit ~/Library/Application Support/Claude/claude_desktop_config.json:

{
  "mcpServers": {
    "troi": {
      "command": "uvx",
      "args": ["--upgrade", "troi-mcp"],
      "env": {
        "TROI_URL": "https://yourcompany.troi.software",
        "TROI_USER": "j.doe",
        "TROI_API_KEY": "your-api-key",
        "TROI_CLIENT_ID": "1"
      }
    }
  }
}

Claude Code — add to .mcp.json in your project root:

{
  "mcpServers": {
    "troi": {
      "command": "uvx",
      "args": ["--upgrade", "troi-mcp"],
      "env": {
        "TROI_URL": "https://yourcompany.troi.software",
        "TROI_USER": "j.doe",
        "TROI_API_KEY": "your-api-key",
        "TROI_CLIENT_ID": "1"
      }
    }
  }
}

Note: TROI_USER is your Troi login name (e.g. j.doe), not your email address. TROI_CLIENT_ID is usually 1 (single-tenant setups).

4. Restart your MCP client

The Troi tools will be available automatically.

Available Tools (49)

Projects & Subprojects

Tool Description
troi_list_projects List/search projects with filters
troi_get_project Get project details
troi_create_project Create a new project
troi_update_project Update project properties
troi_delete_project Delete a project
troi_list_subprojects List subprojects (phases)
troi_get_subproject Get subproject details
troi_create_subproject Create a subproject
troi_update_subproject Update a subproject
troi_delete_subproject Delete a subproject

Calculation Positions & Price Lists

Tool Description
troi_list_positions List calculation positions (budget items)
troi_get_position Get position details
troi_create_position Create a position manually
troi_create_position_from_pricelist Create a position from a price list item
troi_update_position Update a position
troi_delete_position Delete a position
troi_list_pricelist_groups List available price lists
troi_list_pricelist_items List items in a price list

Offers & Documents

Tool Description
troi_create_offer Create a complete offer (project + phases + positions) in one call
troi_get_offer_summary Get offer summary with totals
troi_list_documents List documents (offers, invoices)
troi_get_document Get document details
troi_download_offer_pdf Download offer as PDF
troi_generate_offer_number Assign an offer number and download PDF (irreversible)
troi_start_approval Submit offer for approval (irreversible)
troi_get_approval_info Get available approvers for a document

Time Tracking

Tool Description
troi_list_time_entries List booked hours
troi_get_time_entry Get time entry details
troi_create_time_entry Book time
troi_update_time_entry Update a time entry
troi_delete_time_entry Delete a time entry

Contacts & Customers

Tool Description
troi_list_contacts List/search contacts
troi_get_contact Get contact details
troi_create_contact Create a contact (company or person)
troi_update_contact Update a contact
troi_list_customers List customers (Auftraggeber)
troi_get_customer Get customer details
troi_create_customer Create a customer linked to a contact
troi_update_customer Update a customer
troi_create_customer_with_contact Create company contact + customer in one call

Reference Data

Tool Description
troi_list_employees List employees
troi_get_employee Get employee details
troi_list_clients List clients (Mandanten)
troi_get_client Get client details
troi_list_absences List absences (vacation, sick days)
troi_list_calendar_events List calendar events
troi_list_project_types List project types
troi_list_project_statuses List project statuses
troi_list_units List units (hours, days, etc.)
troi_list_booking_years List booking years

Permission Layer

All 21 write operations are server-enforced:

  1. Call without confirmed → server returns a preview of what would happen, no API call is made
  2. Call with confirmed: true → server executes the operation

Two tools are classified as irreversible and display extra warnings:

  • troi_generate_offer_number — assigns a permanent offer number
  • troi_start_approval — submits a document for approval

This works with any MCP client, no special sampling or UI support required.

License

MIT

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

troi_mcp-1.3.5.tar.gz (98.4 kB view details)

Uploaded Source

Built Distribution

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

troi_mcp-1.3.5-py3-none-any.whl (46.3 kB view details)

Uploaded Python 3

File details

Details for the file troi_mcp-1.3.5.tar.gz.

File metadata

  • Download URL: troi_mcp-1.3.5.tar.gz
  • Upload date:
  • Size: 98.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.10.7 {"installer":{"name":"uv","version":"0.10.7","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"macOS","version":null,"id":null,"libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}

File hashes

Hashes for troi_mcp-1.3.5.tar.gz
Algorithm Hash digest
SHA256 5214afc366aac10fb6c022dfd14bb1bc0c2ba69cafa527b9847a4861508459fb
MD5 7ee7c2b554b1ba7311e6904b1b1316fe
BLAKE2b-256 29f29d3977b05cbb799b93ef6050f5689e87c165e2b9a1b1fe66f47e3921e381

See more details on using hashes here.

File details

Details for the file troi_mcp-1.3.5-py3-none-any.whl.

File metadata

  • Download URL: troi_mcp-1.3.5-py3-none-any.whl
  • Upload date:
  • Size: 46.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.10.7 {"installer":{"name":"uv","version":"0.10.7","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"macOS","version":null,"id":null,"libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}

File hashes

Hashes for troi_mcp-1.3.5-py3-none-any.whl
Algorithm Hash digest
SHA256 871e9cf2f83c898bbae31fc5a5d7c61402ee1cb4fe62d7de1cc273180d6698a1
MD5 26ec125b257721afa9bb8f873a42cf13
BLAKE2b-256 4354d288aadb0095b656ee06694b613a48058a65fa7dea50b47b1316ae764e81

See more details on using hashes here.

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