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

Uploaded Python 3

File details

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

File metadata

  • Download URL: troi_mcp-1.3.7.tar.gz
  • Upload date:
  • Size: 100.1 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.7.tar.gz
Algorithm Hash digest
SHA256 24d36a6dbfac884710376dea9d7a8656accf9375c86f37dc0b697dcec8a6f272
MD5 5a512dda834174b71f9eb061a8bce5b4
BLAKE2b-256 7e90ba259520ed21d3c104a6ae4530dad53952558c8d4bdd37b33fb5f0baea1d

See more details on using hashes here.

File details

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

File metadata

  • Download URL: troi_mcp-1.3.7-py3-none-any.whl
  • Upload date:
  • Size: 48.0 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.7-py3-none-any.whl
Algorithm Hash digest
SHA256 70618c09379dc97bdd9a0ae3541236bd0ec32a46005e33a1e18fead90473fc13
MD5 bae57268fe732a9cf9fddfb2a0216e0d
BLAKE2b-256 81572678a183959b8318030d45b87dfe8658f95015f79cb51c6d07fa703e2b69

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