Connects Claude directly to your Huly workspace via 36 tools spanning the full platform API. You get project and issue CRUD with status, priority, and assignee updates, plus comment threads, time logging, and labels. It also handles milestones, components, issue relations (blocked-by, parent/child), and teamspace documents with Markdown support and issue linking. Auth runs through an email one-time code setup wizard that writes your token to the env file. Useful when you're already in Huly for project management and want to create issues, update sprints, or draft technical documents without leaving your AI chat. Works across Claude Desktop, Cursor, Windsurf, Cline, Continue, and Zed using standard stdio transport.
Public tool metadata for what this MCP can expose to an agent.
get_versionReturns the current version of this Huly MCP server and the latest version available on npm.Returns the current version of this Huly MCP server and the latest version available on npm.
No parameter schema in public metadata yet.
list_projectsList all Huly projects. Returns projects sorted by name. Supports filtering by archived status.2 paramsList all Huly projects. Returns projects sorted by name. Supports filtering by archived status.
limitintegerincludeArchivedbooleanget_projectGet full details of a Huly project including its statuses. Returns project name, description, archived flag, default status, and all available statuses.1 paramsGet full details of a Huly project including its statuses. Returns project name, description, archived flag, default status, and all available statuses.
projectstringlist_statusesList all issue statuses for a Huly project with category info. Returns status name, isDone, isCanceled, and isDefault flags. Use this to discover valid statuses before creating or updating issues.1 paramsList all issue statuses for a Huly project with category info. Returns status name, isDone, isCanceled, and isDefault flags. Use this to discover valid statuses before creating or updating issues.
projectstringcreate_projectCreate 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.4 paramsCreate 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.
namestringprivatebooleanidentifierstringdescriptionstringupdate_projectUpdate a Huly project. Only provided fields are modified. Set description to null to clear it.3 paramsUpdate a Huly project. Only provided fields are modified. Set description to null to clear it.
namestringprojectstringdescriptionvaluedelete_projectPermanently delete a Huly project. All issues, milestones, and components in this project will be orphaned. This action cannot be undone.1 paramsPermanently delete a Huly project. All issues, milestones, and components in this project will be orphaned. This action cannot be undone.
projectstringlist_issuesQuery 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 descr...13 paramsQuery 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 descr...
limitintegerstatusstringprojectstringassigneevaluecomponentstringhasDueDatebooleanisTopLevelbooleantitleRegexstringhasAssigneebooleanparentIssuestringtitleSearchstringhasComponentbooleandescriptionSearchstringget_issueRetrieve full details for a Huly issue including markdown description. Use this to view issue content, comments, or full metadata.2 paramsRetrieve full details for a Huly issue including markdown description. Use this to view issue content, comments, or full metadata.
projectstringidentifierstringcreate_issueCreate a new issue in a Huly project. Optionally set taskType by ID or display name; it is resolved within the target project's project type, and status is validated against that task type's workflow. Use list_task_types or get_project_type to discover valid task types and sta...10 paramsCreate a new issue in a Huly project. Optionally set taskType by ID or display name; it is resolved within the target project's project type, and status is validated against that task type's workflow. Use list_task_types or get_project_type to discover valid task types and sta...
titlestringstatusstringdueDatevalueprojectstringassigneevalueprioritystringurgent · high · medium · low · no-prioritytaskTypestringestimationnumberdescriptionstringparentIssuestringupdate_issueUpdate fields on an existing Huly issue. Optionally set taskType by ID or display name; it is resolved within the target project's project type, and the status is preserved only when valid for the new task type. Use list_task_types or get_project_type to discover valid task ty...10 paramsUpdate fields on an existing Huly issue. Optionally set taskType by ID or display name; it is resolved within the target project's project type, and the status is preserved only when valid for the new task type. Use list_task_types or get_project_type to discover valid task ty...
titlestringstatusstringdueDatevalueprojectstringassigneevalueprioritystringurgent · high · medium · low · no-prioritytaskTypestringestimationvalueidentifierstringdescriptionstringadd_issue_labelAdd a tag/label to a Huly issue. Creates the tag if it doesn't exist in the project.4 paramsAdd a tag/label to a Huly issue. Creates the tag if it doesn't exist in the project.
colorintegerlabelstringprojectstringidentifierstringremove_issue_labelRemove a tag/label from a Huly issue. Detaches the label reference; does not delete the label definition.3 paramsRemove a tag/label from a Huly issue. Detaches the label reference; does not delete the label definition.
labelstringprojectstringidentifierstringdelete_issuePermanently delete a Huly issue. This action cannot be undone.2 paramsPermanently delete a Huly issue. This action cannot be undone.
projectstringidentifierstringmove_issueMove an issue to a new parent (making it a sub-issue) or to top-level (null). Updates parent/child relationships and sub-issue counts.3 paramsMove an issue to a new parent (making it a sub-issue) or to top-level (null). Updates parent/child relationships and sub-issue counts.
projectstringnewParentvalueidentifierstringlist_componentsList components in a Huly project. Components organize issues by area/feature. Returns components sorted by modification date (newest first).2 paramsList components in a Huly project. Components organize issues by area/feature. Returns components sorted by modification date (newest first).
limitintegerprojectstringget_componentRetrieve full details for a Huly component. Use this to view component content and metadata.2 paramsRetrieve full details for a Huly component. Use this to view component content and metadata.
projectstringcomponentstringcreate_componentCreate a new component in a Huly project. Components help organize issues by area/feature. Returns the created component ID and label.4 paramsCreate a new component in a Huly project. Components help organize issues by area/feature. Returns the created component ID and label.
leadvaluelabelstringprojectstringdescriptionstringupdate_componentUpdate fields on an existing Huly component. Only provided fields are modified.5 paramsUpdate fields on an existing Huly component. Only provided fields are modified.
leadvaluelabelstringprojectstringcomponentstringdescriptionstringset_issue_componentSet or clear the component on a Huly issue. Pass null for component to clear it.3 paramsSet or clear the component on a Huly issue. Pass null for component to clear it.
projectstringcomponentvalueidentifierstringdelete_componentPermanently delete a Huly component. This action cannot be undone.2 paramsPermanently delete a Huly component. This action cannot be undone.
projectstringcomponentstringlist_issue_templatesList issue templates in a Huly project. Templates define reusable issue configurations. Returns templates sorted by modification date (newest first).2 paramsList issue templates in a Huly project. Templates define reusable issue configurations. Returns templates sorted by modification date (newest first).
limitintegerprojectstringget_issue_templateRetrieve full details for a Huly issue template including children (sub-task templates). Use this to view template content, default values, and child template IDs.2 paramsRetrieve full details for a Huly issue template including children (sub-task templates). Use this to view template content, default values, and child template IDs.
projectstringtemplatestringcreate_issue_templateCreate 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.8 paramsCreate 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.
titlestringprojectstringassigneevaluechildrenarrayprioritystringurgent · high · medium · low · no-prioritycomponentstringestimationnumberdescriptionstringcreate_issue_from_templateCreate 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...8 paramsCreate 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...
titlestringstatusstringprojectstringassigneevalueprioritystringurgent · high · medium · low · no-prioritytemplatestringdescriptionstringincludeChildrenbooleanupdate_issue_templateUpdate fields on an existing Huly issue template. Only provided fields are modified.8 paramsUpdate fields on an existing Huly issue template. Only provided fields are modified.
titlestringprojectstringassigneevalueprioritystringurgent · high · medium · low · no-prioritytemplatestringcomponentvalueestimationnumberdescriptionstringdelete_issue_templatePermanently delete a Huly issue template. This action cannot be undone.2 paramsPermanently delete a Huly issue template. This action cannot be undone.
projectstringtemplatestringadd_template_childAdd 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.8 paramsAdd 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.
titlestringprojectstringassigneevalueprioritystringurgent · high · medium · low · no-prioritytemplatestringcomponentstringestimationnumberdescriptionstringremove_template_childRemove a child (sub-task) template from an issue template by its child ID. Get child IDs from get_issue_template response.3 paramsRemove a child (sub-task) template from an issue template by its child ID. Get child IDs from get_issue_template response.
childIdstringprojectstringtemplatestringadd_issue_relationAdd 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 cros...4 paramsAdd 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 cros...
projectstringtargetIssuestringrelationTypestringblocks · is-blocked-by · relates-toissueIdentifierstringremove_issue_relationRemove 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.4 paramsRemove 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.
projectstringtargetIssuestringrelationTypestringblocks · is-blocked-by · relates-toissueIdentifierstringlist_issue_relationsList all relations of an issue. Returns blockedBy (issues blocking this one), blocks (issues this one blocks), relations (bidirectional issue links), and documents (linked documents with title/teamspace).2 paramsList all relations of an issue. Returns blockedBy (issues blocking this one), blocks (issues this one blocks), relations (bidirectional issue links), and documents (linked documents with title/teamspace).
projectstringissueIdentifierstringlink_document_to_issueLink a Huly document to an issue. The link appears in the issue's Relations panel in the UI. Idempotent: no-op if the document is already linked. Use list_issue_relations to see linked documents.4 paramsLink a Huly document to an issue. The link appears in the issue's Relations panel in the UI. Idempotent: no-op if the document is already linked. Use list_issue_relations to see linked documents.
projectstringdocumentstringteamspacestringissueIdentifierstringunlink_document_from_issueRemove a document link from an issue. Idempotent: no-op if the document is not linked.4 paramsRemove a document link from an issue. Idempotent: no-op if the document is not linked.
projectstringdocumentstringteamspacestringissueIdentifierstringlist_labelsList label/tag definitions in the workspace. Labels are global (not project-scoped). Returns labels for tracker issues sorted by modification date (newest first).2 paramsList label/tag definitions in the workspace. Labels are global (not project-scoped). Returns labels for tracker issues sorted by modification date (newest first).
limitintegercategorystringcreate_labelCreate 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.4 paramsCreate 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.
colorintegertitlestringcategorystringdescriptionstringupdate_labelUpdate a label/tag definition. Accepts label ID or title. Only provided fields are modified.4 paramsUpdate a label/tag definition. Accepts label ID or title. Only provided fields are modified.
colorintegerlabelstringtitlestringdescriptionstringdelete_labelPermanently delete a label/tag definition. Accepts label ID or title. This action cannot be undone.1 paramsPermanently delete a label/tag definition. Accepts label ID or title. This action cannot be undone.
labelstringlist_tag_categoriesList tag/label categories in the workspace. Categories group labels (e.g., 'Priority Labels', 'Type Labels'). Optional targetClass filter (defaults to all).2 paramsList tag/label categories in the workspace. Categories group labels (e.g., 'Priority Labels', 'Type Labels'). Optional targetClass filter (defaults to all).
limitintegertargetClassstringcreate_tag_categoryCreate 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.3 paramsCreate 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.
labelstringdefaultbooleantargetClassstringupdate_tag_categoryUpdate a tag/label category. Accepts category ID or label name. Only provided fields are modified.3 paramsUpdate a tag/label category. Accepts category ID or label name. Only provided fields are modified.
labelstringdefaultbooleancategorystringdelete_tag_categoryPermanently 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.1 paramsPermanently 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.
categorystringlist_commentsList comments on a Huly issue. Returns comments sorted by creation date (oldest first).3 paramsList comments on a Huly issue. Returns comments sorted by creation date (oldest first).
limitintegerprojectstringissueIdentifierstringadd_commentAdd a comment to a Huly issue. Comment body supports markdown formatting.3 paramsAdd a comment to a Huly issue. Comment body supports markdown formatting.
bodystringprojectstringissueIdentifierstringupdate_commentUpdate an existing comment on a Huly issue. Comment body supports markdown formatting.4 paramsUpdate an existing comment on a Huly issue. Comment body supports markdown formatting.
bodystringprojectstringcommentIdstringissueIdentifierstringdelete_commentDelete a comment from a Huly issue. This action cannot be undone.3 paramsDelete a comment from a Huly issue. This action cannot be undone.
projectstringcommentIdstringissueIdentifierstringpreview_deletionPreview 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.3 paramsPreview 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.
projectstringentityTypestringissue · project · component · milestoneidentifierstringlist_milestonesList milestones in a Huly project. Returns milestones sorted by modification date (newest first).2 paramsList milestones in a Huly project. Returns milestones sorted by modification date (newest first).
limitintegerprojectstringget_milestoneRetrieve full details for a Huly milestone. Use this to view milestone content and metadata.2 paramsRetrieve full details for a Huly milestone. Use this to view milestone content and metadata.
projectstringmilestonestringcreate_milestoneCreate a new milestone in a Huly project. Returns the created milestone ID and label.4 paramsCreate a new milestone in a Huly project. Returns the created milestone ID and label.
labelstringprojectstringtargetDateintegerdescriptionstringupdate_milestoneUpdate fields on an existing Huly milestone. Only provided fields are modified.6 paramsUpdate fields on an existing Huly milestone. Only provided fields are modified.
labelstringstatusstringplanned · in-progress · completed · canceledprojectstringmilestonestringtargetDateintegerdescriptionstringset_issue_milestoneSet or clear the milestone on a Huly issue. Pass null for milestone to clear it.3 paramsSet or clear the milestone on a Huly issue. Pass null for milestone to clear it.
projectstringmilestonevalueidentifierstringdelete_milestonePermanently delete a Huly milestone. This action cannot be undone.2 paramsPermanently delete a Huly milestone. This action cannot be undone.
projectstringmilestonestringlist_teamspacesList all Huly document teamspaces. Returns teamspaces sorted by name. Supports filtering by archived status.2 paramsList all Huly document teamspaces. Returns teamspaces sorted by name. Supports filtering by archived status.
limitintegerincludeArchivedbooleanget_teamspaceGet details for a Huly document teamspace including document count. Finds by name or ID, including archived teamspaces.1 paramsGet details for a Huly document teamspace including document count. Finds by name or ID, including archived teamspaces.
teamspacestringcreate_teamspaceCreate a new Huly document teamspace. Idempotent: returns existing teamspace if one with the same name exists.3 paramsCreate a new Huly document teamspace. Idempotent: returns existing teamspace if one with the same name exists.
namestringprivatebooleandescriptionstringupdate_teamspaceUpdate fields on an existing Huly document teamspace. Only provided fields are modified. Set description to null to clear it.4 paramsUpdate fields on an existing Huly document teamspace. Only provided fields are modified. Set description to null to clear it.
namestringarchivedbooleanteamspacestringdescriptionvaluedelete_teamspacePermanently delete a Huly document teamspace. This action cannot be undone.1 paramsPermanently delete a Huly document teamspace. This action cannot be undone.
teamspacestringlist_documentsList documents in a Huly teamspace. Returns documents sorted by modification date (newest first). Each result includes a 'url' field pointing to the document in the Huly web app. Supports searching by title substring (titleSearch) and content (contentSearch).5 paramsList documents in a Huly teamspace. Returns documents sorted by modification date (newest first). Each result includes a 'url' field pointing to the document in the Huly web app. Supports searching by title substring (titleSearch) and content (contentSearch).
limitintegerteamspacestringtitleRegexstringtitleSearchstringcontentSearchstringget_documentRetrieve full details for a Huly document including markdown content and a 'url' field pointing to the document in the Huly web app. Use this to view document content and metadata.2 paramsRetrieve full details for a Huly document including markdown content and a 'url' field pointing to the document in the Huly web app. Use this to view document content and metadata.
documentstringteamspacestringcreate_documentCreate a new document in a Huly teamspace. Content supports full markdown including native Mermaid diagrams (```mermaid blocks render interactively in Huly UI). Optionally pass parent as a document title or ID to create a nested child document; invalid parents fail instead of...4 paramsCreate a new document in a Huly teamspace. Content supports full markdown including native Mermaid diagrams (```mermaid blocks render interactively in Huly UI). Optionally pass parent as a document title or ID to create a nested child document; invalid parents fail instead of...
titlestringparentstringcontentstringteamspacestringedit_documentEdit an existing Huly document. Two content modes (mutually exclusive): (1) 'content' for full replace, (2) 'old_text' + 'new_text' for targeted search-and-replace. Multiple matches error unless replace_all is true. Empty new_text deletes matched text. Also supports renaming v...7 paramsEdit an existing Huly document. Two content modes (mutually exclusive): (1) 'content' for full replace, (2) 'old_text' + 'new_text' for targeted search-and-replace. Multiple matches error unless replace_all is true. Empty new_text deletes matched text. Also supports renaming v...
titlestringcontentstringdocumentstringnew_textstringold_textstringteamspacestringreplace_allbooleanlist_inline_commentsList inline comment threads from a Huly document. Extracts comments embedded in document content as ProseMirror marks. Each comment includes the highlighted text and thread ID. Set includeReplies=true to also fetch thread reply messages with sender names.3 paramsList inline comment threads from a Huly document. Extracts comments embedded in document content as ProseMirror marks. Each comment includes the highlighted text and thread ID. Set includeReplies=true to also fetch thread reply messages with sender names.
documentstringteamspacestringincludeRepliesbooleandelete_documentPermanently delete a Huly document. This action cannot be undone.2 paramsPermanently delete a Huly document. This action cannot be undone.
documentstringteamspacestringlist_associationsList Huly association definitions: class-level typed links that define which document classes may be related. Use this before create_relation to discover association IDs, source/target classes, and whether relation writes are supported.6 paramsList Huly association definitions: class-level typed links that define which document classes may be related. Use this before create_relation to discover association IDs, source/target classes, and whether relation writes are supported.
limitintegerassociationstringsourceClassstringtargetClassstringwritableOnlybooleanincludeSystembooleanlist_relationsList concrete Huly relation instances under an association, optionally filtered by source and target documents. Requires at least one filter to avoid broad workspace scans.5 paramsList concrete Huly relation instances under an association, optionally filtered by source and target documents. Requires at least one filter to avoid broad workspace scans.
limitintegersourcevaluetargetvaluedirectionstringsource-to-target · target-to-source · eitherassociationstringcreate_relationIdempotently create one concrete relation between two resolved documents. Only succeeds for associations where list_associations reports canCreateRelation=true; otherwise it fails clearly. This build currently reports no generic associations as writable until a write allowlist...4 paramsIdempotently create one concrete relation between two resolved documents. Only succeeds for associations where list_associations reports canCreateRelation=true; otherwise it fails clearly. This build currently reports no generic associations as writable until a write allowlist...
sourcevaluetargetvalueifExistsstringreturn_existing · failassociationstringdelete_relationIdempotently delete one concrete relation by relation ID or by exact association/source/target triple. Only succeeds for associations where list_associations reports canDeleteRelation=true; otherwise it fails clearly. This build currently reports no generic associations as wri...Idempotently delete one concrete relation by relation ID or by exact association/source/target triple. Only succeeds for associations where list_associations reports canDeleteRelation=true; otherwise it fails clearly. This build currently reports no generic associations as wri...
No parameter schema in public metadata yet.
upload_fileUpload 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.5 paramsUpload 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.
datastringfileUrlstringfilePathstringfilenamestringcontentTypestringlist_attachmentsList attachments on a Huly object (issue, document, etc.). Returns attachments sorted by modification date (newest first).3 paramsList attachments on a Huly object (issue, document, etc.). Returns attachments sorted by modification date (newest first).
limitintegerobjectIdstringobjectClassstringget_attachmentRetrieve full details for a Huly attachment including download URL.1 paramsRetrieve full details for a Huly attachment including download URL.
attachmentIdstringadd_attachmentAdd 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.10 paramsAdd 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.
datastringspacestringpinnedbooleanfileUrlstringfilePathstringfilenamestringobjectIdstringcontentTypestringdescriptionstringobjectClassstringupdate_attachmentUpdate attachment metadata (description, pinned status).3 paramsUpdate attachment metadata (description, pinned status).
pinnedbooleandescriptionvalueattachmentIdstringdelete_attachmentPermanently delete an attachment. This action cannot be undone.1 paramsPermanently delete an attachment. This action cannot be undone.
attachmentIdstringpin_attachmentPin or unpin an attachment.2 paramsPin or unpin an attachment.
pinnedbooleanattachmentIdstringdownload_attachmentGet download URL for an attachment along with file metadata (name, type, size).1 paramsGet download URL for an attachment along with file metadata (name, type, size).
attachmentIdstringadd_issue_attachmentAdd an attachment to a Huly issue. Convenience method that finds the issue by project and identifier. Provide ONE of: filePath, fileUrl, or data.9 paramsAdd an attachment to a Huly issue. Convenience method that finds the issue by project and identifier. Provide ONE of: filePath, fileUrl, or data.
datastringpinnedbooleanfileUrlstringprojectstringfilePathstringfilenamestringidentifierstringcontentTypestringdescriptionstringadd_document_attachmentAdd an attachment to a Huly document. Convenience method that finds the document by teamspace and title/ID. Provide ONE of: filePath, fileUrl, or data.9 paramsAdd an attachment to a Huly document. Convenience method that finds the document by teamspace and title/ID. Provide ONE of: filePath, fileUrl, or data.
datastringpinnedbooleanfileUrlstringdocumentstringfilePathstringfilenamestringteamspacestringcontentTypestringdescriptionstringlist_personsList all persons in the Huly workspace. Returns persons sorted by modification date (newest first). Supports searching by name substring (nameSearch) and email substring (emailSearch).4 paramsList all persons in the Huly workspace. Returns persons sorted by modification date (newest first). Supports searching by name substring (nameSearch) and email substring (emailSearch).
limitintegernameRegexstringnameSearchstringemailSearchstringcreate_personCreate a new person in Huly. Returns the created person ID.4 paramsCreate a new person in Huly. Returns the created person ID.
citystringemailvaluelastNamestringfirstNamestringThe most complete MCP server for Huly — the open-source project management platform.
Connects Claude Desktop (and any MCP-compatible client) directly to your Huly workspace. Manage projects, issues, milestones, components, documents, labels, and more — all via natural language.
| Category | Tool | Description |
|---|---|---|
| Projects | list_projects | List all projects in the workspace |
get_project | Get project details + available statuses | |
create_project | Create a new tracker project with a unique identifier | |
| Issues | list_issues | List issues with optional status / priority filters |
get_issue | Get full details of an issue (e.g. PROJ-42) | |
create_issue | Create a new issue | |
update_issue | Update title, status, priority, assignee, due date, component, milestone | |
delete_issue | Permanently delete an issue by identifier | |
| Comments | add_comment | Add a comment to an issue |
list_comments | List all comments on an issue (includes IDs for delete_comment) | |
delete_comment | Delete a specific comment by ID | |
| Time Tracking | log_time | Log hours spent on an issue |
| Labels | list_labels | List all labels with color + usage count |
create_label | Create a new label with an optional hex color | |
add_label | Add a label to an issue (auto-creates if it doesn't exist) | |
remove_label | Remove a label from an issue | |
| Relations | add_relation | Mark two issues as related (bidirectional) |
add_blocked_by | Mark an issue as blocked by another issue | |
set_parent | Set or clear the parent epic of an issue | |
| Members | list_members | List workspace members |
| Milestones | list_milestones | List milestones for a project |
create_milestone | Create a milestone with a target date and status | |
| Components | list_components | List components (sub-areas) in a project |
create_component | Create a new component with optional lead | |
| Documents | list_teamspaces | List document teamspaces |
create_teamspace | Create a new teamspace (top-level document folder) | |
list_documents | List documents in a teamspace | |
delete_document | Permanently delete a document by ID | |
get_document | Get document metadata + content | |
create_document | Create a new document in a teamspace | |
update_document | Write Markdown content to a document — Mermaid diagrams render natively | |
link_document | Link a document to an issue — appears in the Relations panel | |
| Search | search_issues | Full-text search across all issues |
npx huly-mcp-sdk setup
This runs the interactive setup wizard — sends a one-time code to your email (works for Google/GitHub SSO accounts too) and writes your .env file automatically.
Your workspace slug is the part of your Huly URL after the domain: huly.app/myteam → slug is myteam.
The same MCP server works across all major AI coding tools. Pick your client.
Auth note: All config examples below use
HULY_TOKEN. If you have issues with token expiry, use email + password instead — just replace theenvblock with:"HULY_EMAIL": "your@email.com", "HULY_PASSWORD": "yourpassword", "HULY_WORKSPACE": "your-workspace-slug"See Manual Auth for details on both options.
~/Library/Application Support/Claude/claude_desktop_config.json%APPDATA%\Claude\claude_desktop_config.json{
"mcpServers": {
"huly": {
"command": "npx",
"args": ["huly-mcp-sdk"],
"env": {
"HULY_TOKEN": "your-token",
"HULY_WORKSPACE": "your-workspace-slug"
}
}
}
}
Restart Claude Desktop after saving.
claude mcp add huly -e HULY_TOKEN=your-token -e HULY_WORKSPACE=your-slug -- npx huly-mcp-sdk
Or scope it to a single project only:
claude mcp add huly --scope project -e HULY_TOKEN=your-token -e HULY_WORKSPACE=your-slug -- npx huly-mcp-sdk
Verify it's connected: claude mcp list
Create or edit ~/.cursor/mcp.json:
{
"mcpServers": {
"huly": {
"command": "npx",
"args": ["huly-mcp-sdk"],
"env": {
"HULY_TOKEN": "your-token",
"HULY_WORKSPACE": "your-workspace-slug"
}
}
}
}
Restart Cursor. The tools appear in the Agent panel under MCP.
Create or edit ~/.codeium/windsurf/mcp_config.json:
{
"mcpServers": {
"huly": {
"command": "npx",
"args": ["huly-mcp-sdk"],
"env": {
"HULY_TOKEN": "your-token",
"HULY_WORKSPACE": "your-workspace-slug"
}
}
}
}
Restart Windsurf. MCP tools are available to the Cascade AI panel.
{
"huly": {
"command": "npx",
"args": ["huly-mcp-sdk"],
"env": {
"HULY_TOKEN": "your-token",
"HULY_WORKSPACE": "your-workspace-slug"
}
}
}
~/.continue/config.json and add to the mcpServers array:{
"mcpServers": [
{
"name": "huly",
"command": "npx",
"args": ["huly-mcp-sdk"],
"env": {
"HULY_TOKEN": "your-token",
"HULY_WORKSPACE": "your-workspace-slug"
}
}
]
}
Edit ~/.config/zed/settings.json and add a context_servers entry:
{
"context_servers": {
"huly": {
"command": {
"path": "npx",
"args": ["huly-mcp-sdk"],
"env": {
"HULY_TOKEN": "your-token",
"HULY_WORKSPACE": "your-workspace-slug"
}
}
}
}
}
Edit ~/.codex/config.json and add to mcpServers:
{
"mcpServers": {
"huly": {
"type": "stdio",
"command": "npx",
"args": ["huly-mcp-sdk"],
"env": {
"HULY_TOKEN": "your-token",
"HULY_WORKSPACE": "your-workspace-slug"
}
}
}
}
The server uses standard stdio transport. If your tool supports MCP, the config pattern is always the same:
npx["huly-mcp-sdk"]HULY_TOKEN + HULY_WORKSPACEConsult your tool's MCP documentation for the exact config file location.
Alternative (avoid npx cold-start): Clone and build once, then point directly at the compiled binary:
git clone https://github.com/varaprasadreddy9676/huly-mcp.git cd huly-mcp && npm install && npm run buildReplace
"command": "npx", "args": ["huly-mcp-sdk"]with"command": "node", "args": ["/absolute/path/to/huly-mcp/dist/index.js"]in any config above.
Projects & issues:
Milestones & components:
Labels & relations:
Time tracking:
Documents:
get_documentget_document always returns full metadata (title, teamspace, comments, snapshots). To also fetch and display the text content, set the optional HULY_FRONT_URL env var:
"env": {
"HULY_TOKEN": "...",
"HULY_WORKSPACE": "myteam",
"HULY_FRONT_URL": "https://front.huly.app"
}
For self-hosted Huly, set HULY_FRONT_URL to your own front service URL (e.g. http://localhost:8083).
update_documentupdate_document accepts a documentId and a markdown string and writes rich structured content directly to the document — no manual editing required.
Supported Markdown:
| Element | Syntax |
|---|---|
| Headings | #, ##, ### |
| Bold / inline code | **bold**, `code` |
| Paragraphs | plain text |
| Bullet lists | - item |
| Pipe tables | | col | col | |
| Code blocks | ```lang |
| Mermaid diagrams | ```mermaid — stored as Huly's native mermaid node type so diagrams render as interactive visuals in the editor |
Example:
update_document({
documentId: "abc123",
markdown: `# Service Flow\n\n` +
`## Architecture\n\n` +
"```mermaid\n" +
"flowchart TD\n" +
" A([User]) --> B[Browse Catalogue]\n" +
" B --> C[Pay via Razorpay]\n" +
" C --> D[Order Confirmed]\n" +
"```\n\n" +
"## Business Rules\n\n" +
"- Payment required before confirmation\n" +
"- All orders synced to HIS\n"
})
The Mermaid block renders as a live interactive diagram in Huly's document editor — not as a code block.
Import many issues at once from a CSV file — useful for migrating from other tools:
node scripts/import-csv.js tasks.csv PROJ
CSV format:
title,priority,status,dueDate
Fix login bug,High,In Progress,2025-04-01
Add dark mode,Medium,,
Improve performance,Urgent,,2025-05-01
Required column: title. Optional: priority (Urgent/High/Medium/Low), status (must match a status name in the project), dueDate (YYYY-MM-DD).
Create a .env file in the project root (or pass via env in your client config):
Option A — Email + password (recommended):
Works if you have a password set on your Huly account (Profile → Security → Change password).
HULY_EMAIL=your@email.com
HULY_PASSWORD=yourpassword
HULY_WORKSPACE=your-workspace-slug
Option B — Token:
HULY_WORKSPACE=your-workspace-slug
HULY_TOKEN=your-token-here
To get a token: go to huly.app → open browser DevTools → Application → Local Storage → https://huly.app → copy the token value.
Tokens expire after some time. If you get an auth error, switch to email + password auth or refresh the token from DevTools.
Self-hosted Huly:
HULY_ACCOUNTS_URL=https://your-huly-instance.com/account
HULY_FRONT_URL=https://your-huly-instance.com
@hcengineering/server-client, not per tool call (model load takes 1–3 s, so this keeps tools fast)delete_document — permanently delete a document by IDcreate_teamspace — create a new document teamspace (top-level folder for organising documents by project or team)delete_comment — delete a specific comment from an issue by ID; list_comments now includes comment IDs in its outputlink_document — link a Huly document to an issue; the document appears in the Relations panel on the issueupdate_document — write Markdown to any Huly document programmatically; \``mermaid` blocks use Huly's native node type and render as interactive diagramsIssueStatus queries — statuses are stored globally in Huly (core:space:Model), not per-project; removed incorrect space filter that caused "no statuses found" errors on create_issue, update_issue, and list_issuescreate_project — sets members: [currentUser] so newly created projects are immediately visible in the Huly UIlog_time, list_comments, component/milestone assignment on update_issueget_document, create_documentcreate_project, create_milestone, assignee support on issuesHULY_TOKEN*secretHuly workspace token — get from huly.app DevTools → Application → Local Storage → token
HULY_WORKSPACE*Your Huly workspace slug (the part after huly.app/ in your URL, e.g. 'myteam')
HULY_FRONT_URLOptional — set to https://front.huly.app to enable reading document content