@firfi/huly-mcp
MCP server for Huly integration.
Installation
The standard configuration works with most MCP clients:
{
"mcpServers": {
"huly": {
"command": "npx",
"args": ["-y", "@firfi/huly-mcp@latest"],
"env": {
"HULY_URL": "https://huly.app",
"HULY_EMAIL": "your@email.com",
"HULY_PASSWORD": "yourpassword",
"HULY_WORKSPACE": "yourworkspace"
}
}
}
}claude mcp add huly \
-e HULY_URL=https://huly.app \
-e HULY_EMAIL=your@email.com \
-e HULY_PASSWORD=yourpassword \
-e HULY_WORKSPACE=yourworkspace \
-- npx -y @firfi/huly-mcp@latestOr add to ~/.claude.json using the standard config above.
Add the standard config to your claude_desktop_config.json:
macOS:
~/Library/Application Support/Claude/claude_desktop_config.jsonWindows:
%APPDATA%\Claude\claude_desktop_config.json
Add to your user settings (.vscode/mcp.json) or use Command Palette → "MCP: Add Server":
{
"servers": {
"huly": {
"command": "npx",
"args": ["-y", "@firfi/huly-mcp@latest"],
"env": {
"HULY_URL": "https://huly.app",
"HULY_EMAIL": "your@email.com",
"HULY_PASSWORD": "yourpassword",
"HULY_WORKSPACE": "yourworkspace"
}
}
}
}Add the standard config to ~/.cursor/mcp.json, or via Settings → Tools & Integrations → New MCP Server.
Add the standard config to your Windsurf MCP configuration file.
HTTP Transport
By default, the server uses stdio transport. For HTTP transport (Streamable HTTP):
HULY_URL=https://huly.app \
HULY_EMAIL=your@email.com \
HULY_PASSWORD=yourpassword \
HULY_WORKSPACE=yourworkspace \
MCP_TRANSPORT=http \
npx -y @firfi/huly-mcp@latestServer listens on http://127.0.0.1:3000/mcp by default.
Configure with MCP_HTTP_PORT and MCP_HTTP_HOST:
MCP_TRANSPORT=http MCP_HTTP_PORT=8080 MCP_HTTP_HOST=0.0.0.0 npx -y @firfi/huly-mcp@latestEnvironment Variables
Variable | Required | Description |
| Yes | Huly instance URL |
| Auth* | Account email |
| Auth* | Account password |
| Auth* | API token (alternative to email/password) |
| Yes | Workspace identifier |
| No | Connection timeout in ms (default: 30000) |
| No | Transport type: |
| No | HTTP server port (default: 3000) |
| No | HTTP server host (default: 127.0.0.1) |
| No | Comma-separated tool categories to expose. If unset, all tools are exposed. Example: |
*Auth: Provide either HULY_EMAIL + HULY_PASSWORD or HULY_TOKEN.
Available Tools
TOOLSETS projects, issues, comments, milestones, documents, storage, attachments, contacts, channels, calendar, time tracking, search, activity, notifications, workspace, cards, labels, tag-categories, test-management
Projects
Tool | Description |
| List all Huly projects. Returns projects sorted by name. Supports filtering by archived status. |
| Get full details of a Huly project including its statuses. Returns project name, description, archived flag, default status, and all available statuses. |
| Create a new Huly tracker project. Idempotent: returns existing project if one with the same identifier already exists (created=false). Identifier must be 1-5 uppercase alphanumeric chars starting with a letter. |
| Update a Huly project. Only provided fields are modified. Set description to null to clear it. |
| Permanently delete a Huly project. All issues, milestones, and components in this project will be orphaned. This action cannot be undone. |
Issues
Tool | Description |
| Preview the impact of deleting a Huly entity before actually deleting it. Shows affected sub-entities, relations, and warnings. Supports issues, projects, components, and milestones. Use this to understand cascade effects before calling a delete operation. |
| Query Huly issues with optional filters. Returns issues sorted by modification date (newest first). Supports filtering by project, status, assignee, component, and parentIssue (to list children of a specific issue). Supports searching by title substring (titleSearch) and description content (descriptionSearch). |
| Retrieve full details for a Huly issue including markdown description. Use this to view issue content, comments, or full metadata. |
| Create a new issue in a Huly project. Optionally create as a sub-issue by specifying parentIssue. Description supports markdown formatting. Returns the created issue identifier. |
| Update fields on an existing Huly issue. Only provided fields are modified. Description updates support markdown. |
| Add a tag/label to a Huly issue. Creates the tag if it doesn't exist in the project. |
| Remove a tag/label from a Huly issue. Detaches the label reference; does not delete the label definition. |
| Permanently delete a Huly issue. This action cannot be undone. |
| Move an issue to a new parent (making it a sub-issue) or to top-level (null). Updates parent/child relationships and sub-issue counts. |
| List components in a Huly project. Components organize issues by area/feature. Returns components sorted by modification date (newest first). |
| Retrieve full details for a Huly component. Use this to view component content and metadata. |
| Create a new component in a Huly project. Components help organize issues by area/feature. Returns the created component ID and label. |
| Update fields on an existing Huly component. Only provided fields are modified. |
| Set or clear the component on a Huly issue. Pass null for component to clear it. |
| Permanently delete a Huly component. This action cannot be undone. |
| List issue templates in a Huly project. Templates define reusable issue configurations. Returns templates sorted by modification date (newest first). |
| Retrieve full details for a Huly issue template including children (sub-task templates). Use this to view template content, default values, and child template IDs. |
| Create a new issue template in a Huly project. Templates define default values for new issues. Optionally include children (sub-task templates) that will become sub-issues when creating issues from this template. Returns the created template ID and title. |
| Create a new issue from a template. Applies template defaults, allowing overrides for specific fields. If the template has children (sub-task templates), sub-issues are created automatically unless includeChildren is set to false. Returns the created issue identifier and count of children created. |
| Update fields on an existing Huly issue template. Only provided fields are modified. |
| Permanently delete a Huly issue template. This action cannot be undone. |
| Add a child (sub-task) template to an issue template. The child defines default values for sub-issues created when using create_issue_from_template. Returns the child template ID. |
| Remove a child (sub-task) template from an issue template by its child ID. Get child IDs from get_issue_template response. |
| Add a relation between two issues. Relation types: 'blocks' (source blocks target — pushes into target's blockedBy), 'is-blocked-by' (source is blocked by target — pushes into source's blockedBy), 'relates-to' (bidirectional link — updates both sides). targetIssue accepts cross-project identifiers like 'OTHER-42'. No-op if the relation already exists. |
| Remove a relation between two issues. Mirrors add_issue_relation: 'blocks' pulls from target's blockedBy, 'is-blocked-by' pulls from source's blockedBy, 'relates-to' pulls from both sides. No-op if the relation doesn't exist. |
| List all relations of an issue. Returns blockedBy (issues blocking this one) and relations (bidirectional links) with resolved identifiers. Does NOT return issues that this issue blocks — use list_issue_relations on the target issue to see that. |
Comments
Tool | Description |
| List comments on a Huly issue. Returns comments sorted by creation date (oldest first). |
| Add a comment to a Huly issue. Comment body supports markdown formatting. |
| Update an existing comment on a Huly issue. Comment body supports markdown formatting. |
| Delete a comment from a Huly issue. This action cannot be undone. |
Milestones
Tool | Description |
| List milestones in a Huly project. Returns milestones sorted by modification date (newest first). |
| Retrieve full details for a Huly milestone. Use this to view milestone content and metadata. |
| Create a new milestone in a Huly project. Returns the created milestone ID and label. |
| Update fields on an existing Huly milestone. Only provided fields are modified. |
| Set or clear the milestone on a Huly issue. Pass null for milestone to clear it. |
| Permanently delete a Huly milestone. This action cannot be undone. |
Documents
Tool | Description |
| List all Huly document teamspaces. Returns teamspaces sorted by name. Supports filtering by archived status. |
| Get details for a Huly document teamspace including document count. Finds by name or ID, including archived teamspaces. |
| Create a new Huly document teamspace. Idempotent: returns existing teamspace if one with the same name exists. |
| Update fields on an existing Huly document teamspace. Only provided fields are modified. Set description to null to clear it. |
| Permanently delete a Huly document teamspace. This action cannot be undone. |
| List documents in a Huly teamspace. Returns documents sorted by modification date (newest first). Supports searching by title substring (titleSearch) and content (contentSearch). |
| Retrieve full details for a Huly document including markdown content. Use this to view document content and metadata. |
| Create a new document in a Huly teamspace. Content supports markdown formatting. Returns the created document id. |
| Update fields on an existing Huly document. Only provided fields are modified. Content updates support markdown. |
| Permanently delete a Huly document. This action cannot be undone. |
Storage
Tool | Description |
| Upload a file to Huly storage. Provide ONE of: filePath (local file - preferred), fileUrl (fetch from URL), or data (base64 - for small files only). Returns blob ID and URL for referencing the file. |
Attachments
Tool | Description |
| List attachments on a Huly object (issue, document, etc.). Returns attachments sorted by modification date (newest first). |
| Retrieve full details for a Huly attachment including download URL. |
| Add an attachment to a Huly object. Provide ONE of: filePath (local file - preferred), fileUrl (fetch from URL), or data (base64). Returns the attachment ID and download URL. |
| Update attachment metadata (description, pinned status). |
| Permanently delete an attachment. This action cannot be undone. |
| Pin or unpin an attachment. |
| Get download URL for an attachment along with file metadata (name, type, size). |
| Add an attachment to a Huly issue. Convenience method that finds the issue by project and identifier. Provide ONE of: filePath, fileUrl, or data. |
| Add an attachment to a Huly document. Convenience method that finds the document by teamspace and title/ID. Provide ONE of: filePath, fileUrl, or data. |
Contacts
Tool | Description |
| List all persons in the Huly workspace. Returns persons sorted by modification date (newest first). Supports searching by name substring (nameSearch) and email substring (emailSearch). |
| Retrieve full details for a person including contact channels. Use personId or email to identify the person. |
| Create a new person in Huly. Returns the created person ID. |
| Update fields on an existing person. Only provided fields are modified. |
| Permanently delete a person from Huly. This action cannot be undone. |
| List employees (persons who are team members). Returns employees sorted by modification date (newest first). |
| List all organizations in the Huly workspace. Returns organizations sorted by modification date (newest first). |
| Create a new organization in Huly. Optionally add members by person ID or email. Returns the created organization ID. |
Channels
Tool | Description |
| List all Huly channels. Returns channels sorted by name. Supports filtering by archived status. Supports searching by name substring (nameSearch) and topic substring (topicSearch). |
| Retrieve full details for a Huly channel including topic and member list. |
| Create a new channel in Huly. Returns the created channel ID and name. |
| Update fields on an existing Huly channel. Only provided fields are modified. |
| Permanently delete a Huly channel. This action cannot be undone. |
| List messages in a Huly channel. Returns messages sorted by date (newest first). |
| Send a message to a Huly channel. Message body supports markdown formatting. |
| List direct message conversations in Huly. Returns conversations sorted by date (newest first). |
| List replies in a message thread. Returns replies sorted by date (oldest first). |
| Add a reply to a message thread. Reply body supports markdown formatting. |
| Update a thread reply. Only the body can be modified. |
| Permanently delete a thread reply. This action cannot be undone. |
Calendar
Tool | Description |
| List calendar events. Returns events sorted by date. Supports filtering by date range. |
| Retrieve full details for a calendar event including description. Use this to view event content and metadata. |
| Create a new calendar event. Description supports markdown formatting. Returns the created event ID. |
| Update fields on an existing calendar event. Only provided fields are modified. Description updates support markdown. |
| Permanently delete a calendar event. This action cannot be undone. |
| List recurring event definitions. Returns recurring events sorted by modification date (newest first). |
| Create a new recurring calendar event with RFC5545 RRULE rules. Description supports markdown. Returns the created event ID. |
| List instances of a recurring event. Returns instances sorted by date. Supports filtering by date range. Use includeParticipants=true to fetch full participant info (extra lookups). |
Time Tracking
Tool | Description |
| Log time spent on a Huly issue. Records a time entry with optional description. Time value is in minutes. |
| Get time tracking report for a specific Huly issue. Shows total time, estimation, remaining time, and all time entries. |
| List all time entries across issues. Supports filtering by project and date range. Returns entries sorted by date (newest first). |
| Get detailed time breakdown for a project. Shows total time grouped by issue and by employee. Supports date range filtering. |
| List scheduled work slots. Shows planned time blocks attached to ToDos. Supports filtering by employee and date range. |
| Create a scheduled work slot. Attaches a time block to a ToDo for planning purposes. |
| Start a client-side timer on a Huly issue. Validates the issue exists and returns a start timestamp. Use log_time to record the elapsed time when done. |
| Stop a client-side timer on a Huly issue. Returns the stop timestamp. Calculate elapsed time from start/stop timestamps and use log_time to record it. |
Search
Tool | Description |
| Perform a global fulltext search across all Huly content. Searches issues, documents, messages, and other indexed content. Returns matching items sorted by relevance (newest first). |
Activity
Tool | Description |
| List activity messages for a Huly object. Returns activity sorted by date (newest first). |
| Add an emoji reaction to an activity message. |
| Remove an emoji reaction from an activity message. |
| List reactions on an activity message. |
| Save/bookmark an activity message for later reference. |
| Remove an activity message from saved/bookmarks. |
| List saved/bookmarked activity messages. |
| List @mentions of the current user in activity messages. |
Notifications
Tool | Description |
| List inbox notifications. Returns notifications sorted by modification date (newest first). Supports filtering by read/archived status. |
| Retrieve full details for a notification. Use this to view notification content and metadata. |
| Mark a notification as read. |
| Mark all unread notifications as read. Returns the count of notifications marked. |
| Archive a notification. Archived notifications are hidden from the main inbox view. |
| Archive all notifications. Returns the count of notifications archived. |
| Permanently delete a notification. This action cannot be undone. |
| Get notification context for an entity. Returns tracking information for a specific object. |
| List notification contexts. Returns contexts sorted by last update timestamp (newest first). Supports filtering by pinned status. |
| Pin or unpin a notification context. Pinned contexts are highlighted in the inbox. |
| List notification provider settings. Returns current notification preferences. |
| Update notification provider setting. Enable or disable notifications for a specific provider. |
| Get the count of unread notifications. |
Workspace
Tool | Description |
| List members in the current Huly workspace with their roles. Returns members with account IDs and roles. |
| Update a workspace member's role. Requires appropriate permissions. Valid roles: READONLYGUEST, DocGuest, GUEST, USER, MAINTAINER, OWNER, ADMIN. |
| Get information about the current workspace including name, URL, region, and settings. |
| List all workspaces accessible to the current user. Returns workspace summaries sorted by last visit. |
| Create a new Huly workspace. Returns the workspace UUID and URL. Optionally specify a region. |
| Permanently delete the current workspace. This action cannot be undone. Use with extreme caution. |
| Get the current user's profile information including bio, location, and social links. |
| Update the current user's profile. Supports bio, city, country, website, social links, and public visibility. |
| Update workspace guest settings. Control read-only guest access and guest sign-up permissions. |
| Get available regions for workspace creation. Returns region codes and display names. |
Cards
Tool | Description |
| List all Huly card spaces. Returns card spaces sorted by name. Card spaces are containers for cards. |
| List master tags (card types) available in a Huly card space. Master tags define the type/schema of cards that can be created in a space. |
| List cards in a Huly card space. Returns cards sorted by modification date (newest first). Supports filtering by type (master tag), title substring, and content search. |
| Retrieve full details for a Huly card including markdown content. Use this to view card content and metadata. |
| Create a new card in a Huly card space. Requires a master tag (card type). Content supports markdown formatting. Returns the created card id. |
| Update fields on an existing Huly card. Only provided fields are modified. Content updates support markdown. |
| Permanently delete a Huly card. This action cannot be undone. |
Labels
Tool | Description |
| List label/tag definitions in the workspace. Labels are global (not project-scoped). Returns labels for tracker issues sorted by modification date (newest first). |
| Create a new label/tag definition in the workspace. Labels are global and can be attached to any issue. Returns existing label if one with the same title already exists (created=false). Use add_issue_label to attach a label to a specific issue. |
| Update a label/tag definition. Accepts label ID or title. Only provided fields are modified. |
| Permanently delete a label/tag definition. Accepts label ID or title. This action cannot be undone. |
Tag-Categories
Tool | Description |
| List tag/label categories in the workspace. Categories group labels (e.g., 'Priority Labels', 'Type Labels'). Optional targetClass filter (defaults to all). |
| Create a new tag/label category. Idempotent: returns existing category if one with the same label and targetClass already exists (created=false). Defaults targetClass to tracker issues. |
| Update a tag/label category. Accepts category ID or label name. Only provided fields are modified. |
| Permanently delete a tag/label category. Accepts category ID or label name. Labels in this category will be orphaned (not deleted). This action cannot be undone. |
Test-Management
Tool | Description |
| List test management projects. Returns test projects sorted by name. These are separate from tracker projects. |
| List test suites in a test project. Accepts project ID or name. Optional parent filter for nested suites. |
| Get a single test suite by ID or name within a test project. Returns suite details and test case count. |
| Create a test suite in a test project. Idempotent: returns existing suite if one with the same name exists (created=false). Optional parent for nesting. |
| Update a test suite. Accepts suite ID or name. Only provided fields are modified. |
| Permanently delete a test suite. Accepts suite ID or name. This action cannot be undone. |
| List test cases in a test project. Optional filters: suite (ID or name), assignee (name or email). |
| Get a single test case by ID or name within a test project. |
| Create a test case attached to a suite. Requires project and suite. Defaults: type=functional, priority=medium, status=draft. |
| Update a test case. Accepts test case ID or name. Only provided fields are modified. Set assignee to null to unassign. |
| Permanently delete a test case. Accepts test case ID or name. This action cannot be undone. |
| List test plans in a test management project. Returns plan names and IDs. Requires project ID or name. |
| Get test plan details including its items (test cases). Accepts plan ID or name within a project. |
| Create a test plan in a project. Idempotent: returns existing plan if one with the same name exists (created=false). |
| Update a test plan's name or description. Only provided fields are modified. Pass description=null to clear. |
| Permanently delete a test plan. This does not delete associated test runs. Cannot be undone. |
| Add a test case to a test plan. Resolves test case by ID or name. Optionally assign a person by email or name. |
| Remove a test case from a test plan by item ID. Get item IDs from get_test_plan. |
| List test runs in a test management project. Returns run names, IDs, and due dates. |
| Get test run details including all results. Accepts run ID or name within a project. |
| Create a test run in a project. For bulk creation from a plan, use run_test_plan instead. |
| Update a test run's name, description, or due date. Only provided fields are modified. Pass null to clear optional fields. |
| Permanently delete a test run. This does not delete associated test results. Cannot be undone. |
| List test results in a test run. Returns result names, statuses, and assignees. |
| Get test result details. Accepts result ID or name. |
| Create a test result in a run. Resolves test case by ID or name. Status defaults to 'untested'. |
| Update a test result's status, assignee, or description. Status values: untested, blocked, passed, failed. |
| Permanently delete a test result. Cannot be undone. |
| Execute a test plan: creates a test run and one test result per plan item. Returns the run ID and count of results created. Optionally name the run and set a due date. |