jayrah
Allows AI agents to interact with Jira, providing capabilities to browse issues, create and view issues, add comments, change issue status, list boards, and more.
Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@jayrahshow my open issues in project ABC"
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
Jayrah
A simple CLI and TUI for working with Jira from your terminal.
Screenshot
TUI Interface
Web Interface
Install
curl -LsSf uvx.sh/jayrah/install.sh | shOr from source (need uv installed):
git clone https://github.com/chmouel/jayrah.git
cd jayrah
uv run jayrahQuick Setup
Create ~/.config/jayrah/config.yaml:
jira_server: "https://your-jira-id.atlassian.net" # or other Jira custom server URL
jira_user: "you@example.com"
jira_password: "your-api-token" # or you can use a pass path, with the pass:: prefix, for example pass::jira/token
jira_project: "PROJECT-KEY"
api_version: "2" # Use "3" for Jira Cloud with the newer API
auth_method: "basic" # or "bearer" for operations Bearer authenticationJayrah supports both Bearer token and Basic authentication:
API v2 uses Bearer token authentication by default
API v3 uses Basic authentication by default
For Basic authentication, make sure your configuration includes both jira_user and jira_password.
If you don't configure your config.yaml file, jayrah will prompt you for the required information when you run it for the first time.
Usage
Browse
Launch the issue browser with:
jayrah browse # or just `jayrah` will do the sameList all your boards with the -l/--list-boards option.
Filter issues by board with the -f/--filter option for example:
jayrah browse myissue --filter status=Newif you add words after the jayrah browse BOARD command, it will search for
issues that match those words.
jayrah browse myissue search1 search2This by default will search for issues that match the words in the summary, you
can use the switch --or to instead do a or on the search terms.
Create issue:
jayrah create
TUI (Terminal UI)
When you start browsing the issues of your board, you will be presented with a list of all the issues in that board. You can use your mouse or your keyboard:
Navigate with arrow keys or
j/kMove the preview pan up and down with
J/KPress
qorEscapeto quitPress
oto open the issue in your browserPress
fto filter issues by status, assignee, or other fields.Press
afor all actions you can do on the issue.Press
cfor accessing or adding a comment.Press
tto transition the issue to a new status.Press
eto edit the title or description of the issue. (the editor emulates readline/emacs keys).Use
F1for the command palette
Editing issue descriptions
Jayrah supports editing issue title and descriptions.
When editing a description:
Press
eto access the edit menuSelect "description" from the options
Edit your description in the text area
You can navigate with emacs or readline keys.
Press
Ctrl+Sto save your changes orEscapeto cancel
Custom Fields
You can display and edit custom Jira fields in the TUI by adding a section to your config:
custom_fields:
- name: Git PR
description: "URL to the git pull request"
field: customfield_12310220
type: url
- name: Release Note
description: "Release note for the issue"
field: customfield_12317313
type: text
- name: Some Number Field
description: "A numeric value"
field: customfield_999999
type: number
- name: Some Other Custom Field
field: customfield_45678
type: stringtypecan bestring(default),text,url, ornumber.urlfields are validated as URLs.textfields use a multi-line editor.numberfields require a valid number.stringfields use a single-line input.
descriptionis shown in the edit dialog if provided.
If a custom field is not empty, it will be shown in the issue details view. You can also edit these fields from the edit menu.
To find the correct custom field ID (e.g., customfield_12310), the easiest way is to use your web browser's developer tools while editing a field in Jira. Look at the network requests and see which field is being updated in the REST API call. Use that field ID in your config.
MCP Server for AI integration
Jayrah can run as an MCP server to work with AI tools like VS Code Copilot.
Start the server
jayrah mcpThis runs in stdio mode by default for VS Code.
Available actions
The server exposes these Jira operations:
Browse issues (with pagination support)
limit- Control how many issues to display (default: 10)page- Select which page of results to view (starts at 1)page_size- Number of issues per page (default: 100)
Create/view issues
Add comments to issues
Change issue status
Get possible status changes
Open issues in browser
List your boards
VS Code setup
Follow these steps to set up Jayrah with VS Code:
Clone the repo somewhere (e.g.,
/path/to/jayrah)Make sure you have Copilot in VS Code
Hit
F1and pickMCP: Add serverChoose
Command StdioEnter:
uv run --directory=/path/to/jayrah jayrah mcpSave the config (e.g., to
.vscode/mcp.json):
{
"servers": {
"jayrah": {
"type": "stdio",
"command": "uv",
"args": [
"run",
"--directory",
"/path/to/jayrah",
"jayrah",
"mcp"
]
}
}
}In Copilot Chat, select the tools button (often a sparkle icon or similar) to see and use Jayrah's available actions.
Web UI Server
Jayrah includes a web-based UI that can be started with:
jayrah webThis will start a web UI server on http://localhost:8000 by default. You can open this URL in your web browser to use the Jayrah web interface to browse and manage Jira issues in a quick and user-friendly way.
Security Note:
The web server is intended for local development and use only. Do not expose it to the public internet, as it is not hardened for production or external access.
Jayrah CLI
jayrah also provides a command-line interface (CLI) for performing various Jira operations directly from the terminal. Here are some of the available commands:
jayrah cli open
open an issue in your web browser using the jira host from your config:
jayrah cli open ISSUE-123jayrah cli view
view an issue details in the terminal:
jayrah cli view ISSUE-123jayrah cli custom
Update a custom field as specified in your config:
jayrah cli custom git-pr ISSUE-123 "https://git.com/your/repo/pull/123"jayrah cli gencontext
Generate comprehensive context files from board tickets for LLM consumption. This command exports all tickets from a specified board including descriptions, comments, and metadata in a format optimized for importing into NotebookLM, Gemini, or other LLM contexts.
jayrah cli gencontext my-boardOptions:
--output,-o: Output file path (default: stdout)--include-comments,-c: Include all comments from tickets--include-metadata,-m: Include custom fields and metadata--format: Output format -markdown(default) orplain
Examples:
# Export all tickets from a board to stdout
jayrah cli gencontext my-board
# Export with comments and metadata to a file
jayrah cli gencontext my-board --include-comments --include-metadata --output context.md
# Export in plain text format
jayrah cli gencontext my-board --format plainjayrah cli browse
show issues of a board ouptputting a CSV format that can be used with tools like fzf:
jayrah cli browse ${board} | sed '1d' | fzf --delimiter , --with-nth '{1} {5..} [{2}|{3}|{4}]' --accept-nth 1License
Apache-2.0
Author
Chmouel Boudjnah
This server cannot be installed
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.
Latest Blog Posts
MCP directory API
We provide all the information about MCP servers via our MCP API.
curl -X GET 'https://glama.ai/api/mcp/v1/servers/chmouel/jayrah'
If you have feedback or need assistance with the MCP directory API, please join our Discord server