@aashari/mcp-server-atlassian-jira
Version:
Node.js/TypeScript MCP server for Atlassian Jira. Equips AI systems (LLMs) with tools to list/get projects, search/get issues (using JQL/ID), and view dev info (commits, PRs). Connects AI capabilities directly into Jira project management and issue tracki
150 lines (136 loc) • 7.52 kB
JavaScript
"use strict";
var __importDefault = (this && this.__importDefault) || function (mod) {
return (mod && mod.__esModule) ? mod : { "default": mod };
};
Object.defineProperty(exports, "__esModule", { value: true });
const logger_util_js_1 = require("../utils/logger.util.js");
const error_util_js_1 = require("../utils/error.util.js");
const atlassian_projects_types_js_1 = require("./atlassian.projects.types.js");
const atlassian_projects_controller_js_1 = __importDefault(require("../controllers/atlassian.projects.controller.js"));
// Create a contextualized logger for this file
const toolLogger = logger_util_js_1.Logger.forContext('tools/atlassian.projects.tool.ts');
// Log tool module initialization
toolLogger.debug('Jira projects tool module initialized');
/**
* MCP Tool: List Jira Projects
*
* Lists Jira projects with optional filtering.
* Returns a formatted markdown response with project details and pagination info.
*
* @param {ListProjectsToolArgsType} args - Tool arguments for filtering projects
* @param {RequestHandlerExtra} _extra - Extra request handler information (unused)
* @returns {Promise<{ content: Array<{ type: 'text', text: string }> }>} MCP response with formatted projects list
* @throws Will return error message if project listing fails
*/
async function listProjects(args, _extra) {
const methodLogger = logger_util_js_1.Logger.forContext('tools/atlassian.projects.tool.ts', 'listProjects');
methodLogger.debug('Listing Jira projects with filters:', args);
try {
// Pass the options to the controller
const message = await atlassian_projects_controller_js_1.default.list({
name: args.name,
limit: args.limit,
cursor: args.cursor,
orderBy: args.orderBy,
});
methodLogger.debug('Successfully retrieved projects from controller');
return {
content: [
{
type: 'text',
text: message.content,
},
],
};
}
catch (error) {
methodLogger.error('Failed to list projects', error);
return (0, error_util_js_1.formatErrorForMcpTool)(error);
}
}
/**
* MCP Tool: Get Jira Project Details
*
* Retrieves detailed information about a specific Jira project.
* Returns a formatted markdown response with project data.
*
* @param {GetProjectToolArgsType} args - Tool arguments containing the project ID/key
* @param {RequestHandlerExtra} _extra - Extra request handler information (unused)
* @returns {Promise<{ content: Array<{ type: 'text', text: string }> }>} MCP response with formatted project details
* @throws Will return error message if project retrieval fails
*/
async function getProject(args, _extra) {
const methodLogger = logger_util_js_1.Logger.forContext('tools/atlassian.projects.tool.ts', 'getProject');
methodLogger.debug(`Retrieving project details for key/ID: ${args.projectKeyOrId}`);
try {
const message = await atlassian_projects_controller_js_1.default.get({
projectKeyOrId: args.projectKeyOrId,
});
methodLogger.debug('Successfully retrieved project details from controller');
return {
content: [
{
type: 'text',
text: message.content,
},
],
};
}
catch (error) {
methodLogger.error('Failed to get project details', error);
return (0, error_util_js_1.formatErrorForMcpTool)(error);
}
}
/**
* Register Atlassian Projects MCP Tools
*
* Registers the list-projects and get-project tools with the MCP server.
* Each tool is registered with its schema, description, and handler function.
*
* @param {McpServer} server - The MCP server instance to register tools with
*/
function registerTools(server) {
const methodLogger = logger_util_js_1.Logger.forContext('tools/atlassian.projects.tool.ts', 'registerTools');
methodLogger.debug('Registering Atlassian Projects tools...');
// Register the list projects tool
server.tool('list_projects', `List Jira projects accessible to the authenticated user, with optional filtering by name/key and pagination.
PURPOSE: Discover available projects and retrieve their keys, names, and basic metadata. Essential for finding the correct project key needed as input for the 'get_project' tool or for filtering issues using JQL in the 'list_issues' tool (e.g., "project = KEY").
WHEN TO USE:
- To find the project key for a known project name.
- To explore all projects you have access to.
- To get a high-level overview before diving into specific projects or issues.
- When you don't know the exact key required by other tools.
WHEN NOT TO USE:
- When you already have the project key and need full details (use 'get_project').
- When you need to list *issues* (use 'list_issues').
RETURNS: Formatted list of projects including name, key, ID, type, style, lead, and URL. Includes pagination details if applicable (Jira uses offset-based pagination, so the 'cursor' represents the 'startAt' index).
SORTING: By default, projects are sorted by 'lastIssueUpdatedTime', showing the most recently active projects first. This can be changed by providing a different value in the 'orderBy' parameter.
EXAMPLES:
- List all accessible projects (first page): {}
- Filter by name/key fragment: { name: "platform" }
- Paginate results (get next page starting from index 50): { limit: 50, cursor: "50" }
- Sort by key: { orderBy: "key" }
ERRORS:
- Authentication failures: Check Jira credentials.
- No projects found: You may not have access to any projects, or the name filter is too restrictive.`, atlassian_projects_types_js_1.ListProjectsToolArgs.shape, listProjects);
// Register the get project details tool
server.tool('get_project', `Get detailed information about a specific Jira project using its key or ID. Requires 'projectKeyOrId'.
PURPOSE: Retrieves comprehensive metadata for a *known* project, including its full description, lead, components, versions, style, and links.
WHEN TO USE:
- When you need full details about a *specific* project and you know its key ('PROJ') or ID ('10001').
- After using 'list_projects' to identify the target project key or ID.
- To get project metadata, components, or versions before analyzing its issues.
WHEN NOT TO USE:
- When you don't know the project key or ID (use 'list_projects' first).
- When you only need a list of projects (use 'list_projects').
- When you need issue information (use issue tools).
RETURNS: Detailed project information including key, name, description, lead, components, versions, and links. Fetches all available details (components, versions) by default.
EXAMPLES:
- Get project by Key: { projectKeyOrId: "DEV" }
- Get project by ID: { projectKeyOrId: "10001" }
ERRORS:
- Project not found: Verify the 'projectKeyOrId' is correct and exists.
- Permission errors: Ensure you have access to view the specified project.`, atlassian_projects_types_js_1.GetProjectToolArgs.shape, getProject);
methodLogger.debug('Successfully registered Atlassian Projects tools');
}
exports.default = { registerTools };