npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2026 – Pkg Stats / Ryan Hefner

@softspark/jira-mcp

v1.5.0

Published

MCP server for Jira integration — multi-instance routing, ADF formatting, task caching, and comment templates via the Model Context Protocol.

Readme

jira-mcp

MCP server for Jira integration -- multi-instance routing, ADF formatting, task caching, and comment templates via the Model Context Protocol.

CI npm version License: MIT


What's New in v1.5.0

  • template add bulk CLI command -- install per-project monthly_admin.json configs into ~/.softspark/jira-mcp/templates/tasks/<KEY>/. Validated against BulkConfigSchema. template list/show/remove now also handle the bulk kind, keyed by project.
  • create_monthly_tasks MCP tool -- run all monthly bulk task configs over the protocol with { execute?, project? }. Returns per-project status, summary counts, and resolved config paths. No more dropping to the CLI for monthly admin runs.

See CHANGELOG.md for full details.


Table of Contents

Install

npm install -g @softspark/jira-mcp
# or use directly
npx @softspark/jira-mcp

Update

npm update -g @softspark/jira-mcp

Configuration

1. Generate an API token

Go to Atlassian API Tokens and create a token.

2. Initialize global config

jira-mcp config init
jira-mcp config set-credentials
jira-mcp config add-project

All configuration lives in ~/.softspark/jira-mcp/ (created by jira-mcp config init). This is the standard config directory for all SoftSpark open-source tools.

CLI Commands

| Command | Description | |---------|-------------| | jira-mcp | Start MCP server (default) | | jira-mcp serve | Start MCP server (explicit) | | jira-mcp create <path> | Create tasks from config file (dry-run by default) | | jira-mcp create-monthly | Create monthly admin tasks from built-in templates | | jira-mcp template add <type> <path> | Install a template override from a local markdown file | | jira-mcp template list [type] | List active comment/task templates | | jira-mcp template show <type> <id> | Show the active template file content | | jira-mcp template remove <type> <id> | Remove a user-installed template override | | jira-mcp config init | Initialize global config at ~/.softspark/jira-mcp/ | | jira-mcp config add-project <key> <url> | Add a Jira project to config | | jira-mcp config remove-project <key> | Remove a project from config | | jira-mcp config list-projects | List all configured projects with language | | jira-mcp config set-credentials | Set API credentials | | jira-mcp config set-default <key> | Set default project | | jira-mcp config set-language <lang> | Set global default language | | jira-mcp config set-project-language <key> <lang> | Set language for a specific project | | jira-mcp cache sync-workflows | Sync workflow status transitions | | jira-mcp cache sync-users | Sync user list for reassignment | | jira-mcp cache list-workflows | Show cached workflows | | jira-mcp cache list-users | Show cached users |

Available Tools

| Tool | Description | Key Parameters | |------|-------------|----------------| | sync_tasks | Sync tasks from Jira to local cache | project_key?, jql? | | read_cached_tasks | Read tasks from cache without hitting Jira | task_key? | | update_task_status | Change task status via workflow transition | task_key, status | | update_task | Update existing issue fields (markdown → ADF) | task_key, summary?, description?, priority?, labels? | | add_task_comment | Add a markdown comment (auto-converted to ADF) | task_key, comment, user_approved | | delete_task | Delete a task, only when the authenticated user is the task creator | task_key, user_approved | | delete_comment | Delete a comment, only when the authenticated user is the comment author | task_key, comment_id, user_approved | | reassign_task | Reassign or unassign a task | task_key, assignee_email? | | get_task_statuses | Get valid workflow transitions for a task | task_key | | get_task_details | Get full details with description, comments, and language | task_key | | get_project_language | Get configured language for a project | project_key | | log_task_time | Log work time ("2h 30m" format, no days) | task_key, time_spent, comment? | | get_task_time_tracking | Get time tracking info (estimate, spent, remaining) | task_key | | list_comment_templates | List available comment templates | category? | | list_task_templates | List available task templates for create_task | — | | add_templated_comment | Add comment using a template or raw markdown | task_key, template_id?, variables?, markdown?, user_approved | | create_task | Create a new Jira issue with explicit fields or a task template | project_key, summary?, template_id?, variables?, description?, assignee_email?, labels?, epic_key? | | search_tasks | Search Jira issues with JQL (no caching) | jql, max_results?, project_key? |

Comment Templates

8 built-in templates organized by category:

| Template ID | Name | Category | Required Variables | |-------------|------|----------|--------------------| | status-update | Status Update | workflow | completed, next_steps | | blocker-notification | Blocker Notification | communication | blocked_by, impact, needed_action | | handoff-transition | Task Handoff | workflow | from_person, to_person, context, remaining_work | | review-request | Review Request | communication | reviewer, summary, link | | sprint-update | Sprint Update | reporting | progress, risks | | bug-report | Bug Report | development | steps, expected, actual | | deployment-note | Deployment Note | development | changes, rollback_plan | | time-log-summary | Time Log Summary | reporting | duration, work_description |

Using Templates

Example with Claude Code:

"Add a status update to PROJ-123: completed auth module, next steps are testing, no blockers"

The AI will use add_templated_comment with template_id: "status-update" automatically.

File-Backed Overrides

System templates are shipped as markdown files. User overrides are loaded from:

~/.softspark/jira-mcp/templates/comments/
~/.softspark/jira-mcp/templates/task-templates/

If a user file has the same id as a system template, the user file wins globally for all projects.

jira-mcp template add comment ./my-status-update.md
jira-mcp template add task ./my-bug-task.md
jira-mcp template list

Usage with Claude Code

Add to your Claude Code MCP configuration (~/.claude/claude_desktop_config.json or project-level):

{
  "mcpServers": {
    "jira": {
      "command": "npx",
      "args": ["@softspark/jira-mcp"]
    }
  }
}

Configuration is automatically loaded from ~/.softspark/jira-mcp/. Run jira-mcp config init first to set up.

AI Toolkit Rules

If you use @softspark/ai-toolkit, register the Jira rules so that Claude Code automatically follows project conventions (language checks, sync-first workflow, time format, etc.):

ai-toolkit rules add jira-mcp --path /path/to/jira-mcp/rules/jira-mcp.md

Or copy rules/jira-mcp.md to your ai-toolkit rules directory manually. The rules file covers:

  • Language first -- always check project language before writing comments/descriptions
  • Sync before read -- cache may be stale
  • Status transitions -- check valid transitions before changing status
  • Time format -- "2h 30m", never days
  • All 19 MCP tools and 20 CLI commands reference

AI Toolkit Hooks

To require explicit user approval before Jira comment writes, inject the repo-owned hook manifest:

ai-toolkit inject-hook https://raw.githubusercontent.com/softspark/jira-mcp/main/hooks/jira-mcp-hooks.json

This installs a PreToolUse guard for add_task_comment and add_templated_comment. The hook blocks the tool call, shows the exact comment preview, and tells the agent to retry only after the user approves it with user_approved=true.

The MCP server still enforces user_approved=true at runtime, so the hook is UX guidance plus an extra safety layer rather than the only check.

Usage with Other MCP Clients

Any MCP client that supports stdio transport can use this server:

{
  "command": "npx",
  "args": ["@softspark/jira-mcp"],
  "transport": "stdio"
}

Configuration is loaded from ~/.softspark/jira-mcp/ automatically. No environment variables needed.

Architecture

src/
  adf/            Atlassian Document Format conversion (MD <-> ADF)
  bulk/           Bulk task creator (dry-run, rate limiting, bilingual)
  cache/          Local task, workflow, and user caching (JSON files)
  cli/            CLI entry point and subcommand handlers
    commands/
      cache/      Cache management subcommands
      config/     Config management subcommands
      template/   File-backed template management subcommands
      create.ts   Bulk task creation command
      create-monthly.ts  Monthly admin task automation
  config/         Configuration loading and Zod validation
  connector/      Jira API client (built-in fetch, instance pool)
  errors/         Typed error hierarchy
  operations/     Business logic (status, comments, time tracking)
  templates/      File-backed comment/task template loading and registries
  tools/          MCP tool handlers (19 tools, one file per tool)
  types/          Shared TypeScript types
  server.ts       MCP server setup and tool registration
  cli.ts          CLI entry point

Key Features

Multi-instance routing -- single server manages multiple Jira Cloud/Server instances. Project key determines which instance handles the request. Connectors deduplicated by URL via InstancePool.

ADF round-trip -- comments and descriptions use Atlassian Document Format natively. Markdown in, ADF to Jira v3 API, ADF back to readable markdown. Never loses formatting. See ADF Reference.

Local caching -- tasks synced to ~/.softspark/jira-mcp/cache/ with atomic writes (tmp + rename). Work offline with read_cached_tasks, sync on demand. Workflow and user caches for status validation and assignee resolution.

File-backed templates -- 8 built-in comment templates and built-in task templates are stored as markdown files, with global user overrides loaded from ~/.softspark/jira-mcp/templates/. Both support {{variable}} interpolation and {{#var}}...{{/var}} conditional blocks. See Templates Reference.

Language configuration -- global default_language with per-project override. Supports: pl, en, de, es, fr, pt, it, nl. get_project_language tool and language field in get_task_details let AI assistants write content in the correct language. See Configuration.

Bulk task creation -- create tasks from JSON configs with dry-run default, rate limiting, epic link discovery, assignee caching, multilingual support (8 languages), and idempotent updates. See CLI Usage.

Per-instance credentials -- different API tokens per Jira instance URL. Single-credential format still works (backward compatible). See Configuration.

Supply chain protection -- ignore-scripts=true, no axios, no dynamic requires. Self-contained 535KB bundle, 1 runtime dep (commander).

Typed error hierarchy -- 20 error classes with machine-readable codes. Every tool returns structured { success, error, code } responses. No stack traces leak to MCP clients.

Strict TypeScript -- strict: true, no any, readonly interfaces, Zod validation at all boundaries, 587 tests across 60 test files. Self-contained 535KB package.

Documentation

| Document | Description | |----------|-------------| | Architecture | System design and module overview | | API Reference | All 19 MCP tools with schemas | | Configuration | Config files, env vars, multi-instance | | ADF Format | Atlassian Document Format conversion | | Caching | Task, workflow, and user caching | | Templates | Comment and task templates | | Setup Guide | Getting started step-by-step | | CLI Usage | Complete CLI reference | | Multi-Instance | Multiple Jira instances | | Troubleshooting | Common issues and fixes |

Contributing

See CONTRIBUTING.md.

Security

See SECURITY.md.

License

MIT -- SoftSpark

Changelog

See CHANGELOG.md.


Built at SoftSpark. Designed for AI-assisted Jira workflows.