Hermes 284313f908
Some checks are pending
Bidi Control Character Guard / bidi-control-guard (push) Waiting to run
Circular Dependency Check / Check for new circular dependencies (push) Waiting to run
Citus Migration Smoke / Combined migrations on single-node Citus (push) Waiting to run
E2E Fresh Install Tests / fresh-install-e2e (push) Waiting to run
ext-v2 guardrails / Run ext-v2 guard and ESLint (push) Waiting to run
Integration Tests / Check for relevant changes (push) Waiting to run
Integration Tests / ${{ (github.event_name == 'schedule' || github.event.inputs.suite == 'full') && 'Full integration suite' || 'Tier-1 integration subset' }} (push) Blocked by required conditions
Mobile checks / Mobile lint + typecheck (push) Waiting to run
Mobile checks / Mobile unit tests (push) Waiting to run
Mobile checks / Mobile dependency audit (report) (push) Waiting to run
Mobile checks / Mobile reproducibility checks (push) Waiting to run
Secrets guard (env backups) / Ensure no tracked env backup files (push) Waiting to run
Temporal Readiness / fast-readiness (push) Waiting to run
Temporal Readiness / docker-parity (push) Waiting to run
TypeScript Type Check / Nx affected typecheck (push) Waiting to run
Unit Tests / Skipped-test budget (push) Waiting to run
Unit Tests / Nx affected unit tests (push) Waiting to run
Unit Tests / Server unit coverage (informational) (push) Waiting to run
Validate Tenant Management Schema / Check for relevant changes (push) Waiting to run
Validate Tenant Management Schema / Validate Tenant Management Schema (push) Blocked by required conditions
EE Workflows Build Guard / ee-workflows-build-guard (push) Waiting to run
Initial import of AlgaPSA codebase from PSA server
Excluded: .git, node_modules, secrets/, compose.env, assemblyscript tgz

Source: /opt/alga-psa on psa.joliet.tech
2026-06-22 16:12:17 -05:00

81 lines
2.3 KiB
Markdown

# @alga-psa/mcp-connector
A small **local MCP connector** that exposes your AlgaPSA instance to MCP clients
(Claude Desktop, Cursor, …). It runs on your workstation over **stdio** and acts
entirely under **your own AlgaPSA API token** — every call inherits your existing
RBAC/ABAC permissions. There is no agent governance here; your MCP client is the
human-in-the-loop.
## How it works — progressive disclosure
Instead of exposing one tool per API endpoint (which would flood the model's
context), the connector exposes **three constant meta-tools**, regardless of how
large the AlgaPSA API is:
| Tool | Purpose |
|------|---------|
| `search_api_registry` | Find the right endpoint by natural-language query |
| `search_business_data` | Find tenant records (tickets, clients, …), ACL-scoped |
| `call_api_endpoint` | Execute a chosen endpoint by its registry id |
The agent searches, reads the one schema it needs, then calls it.
## Configuration
Two environment variables are required:
- `ALGA_INSTANCE_URL` — your AlgaPSA base URL, e.g. `https://alga.example.com`
- `ALGA_API_TOKEN` — an AlgaPSA API key (Settings → API Keys)
Optional: `ALGA_TENANT_ID`, `ALGA_REQUEST_TIMEOUT_MS` (default 30000),
`ALGA_REGISTRY_PATH` (default `/api/v1/meta/mcp-registry`),
`ALGA_SEARCH_PATH` (default `/api/v1/search`).
### Claude Desktop
Add to `claude_desktop_config.json`:
```json
{
"mcpServers": {
"alga-psa": {
"command": "npx",
"args": ["-y", "@alga-psa/mcp-connector"],
"env": {
"ALGA_INSTANCE_URL": "https://alga.example.com",
"ALGA_API_TOKEN": "your-api-key"
}
}
}
}
```
### Cursor
Add to `~/.cursor/mcp.json` (or the project `.cursor/mcp.json`):
```json
{
"mcpServers": {
"alga-psa": {
"command": "npx",
"args": ["-y", "@alga-psa/mcp-connector"],
"env": {
"ALGA_INSTANCE_URL": "https://alga.example.com",
"ALGA_API_TOKEN": "your-api-key"
}
}
}
}
```
## Local development
```bash
ALGA_INSTANCE_URL=https://alga.example.com ALGA_API_TOKEN=key npm run dev -w @alga-psa/mcp-connector
npm run build -w @alga-psa/mcp-connector # bundles to dist/index.js (npx entry)
npm test -w @alga-psa/mcp-connector
```
Diagnostics are written to **stderr**; **stdout** carries the MCP JSON-RPC stream.