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=trueto 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 tools —
troi_create_offerbuilds 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.
- Download
AirLST MCP Installer.appfrom your team - Double-click to run — follow the prompts to enter your Troi credentials
- 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) → Sicherheitscenter → API 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_USERis your Troi login name (e.g.j.doe), not your email address.TROI_CLIENT_IDis usually1(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:
- Call without
confirmed→ server returns a preview of what would happen, no API call is made - 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 numbertroi_start_approval— submits a document for approval
This works with any MCP client, no special sampling or UI support required.
License
MIT
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file troi_mcp-1.3.6.tar.gz.
File metadata
- Download URL: troi_mcp-1.3.6.tar.gz
- Upload date:
- Size: 98.9 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
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
1df5ee9f63a254649bd468484737f7dd018c1559de2310439fac7b9dd7586577
|
|
| MD5 |
57904afa00b952a045217e39e77666f0
|
|
| BLAKE2b-256 |
3d6fae98fc1e3a85a352063ef6f43469ba0177327543080bf7a443a2b6bdf7aa
|
File details
Details for the file troi_mcp-1.3.6-py3-none-any.whl.
File metadata
- Download URL: troi_mcp-1.3.6-py3-none-any.whl
- Upload date:
- Size: 46.8 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
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
9b1506bb2289a761d10930a51a96472dd2f3bf23dfa52fbbca5da5436742eb63
|
|
| MD5 |
4480a8a95339c45b9383e793b7344014
|
|
| BLAKE2b-256 |
b43ae38caf172d5b843a66da86feb94a33447725f63b6e45ee4de155ee90173e
|