A semantic-release plugin that automatically adds comments with release information to JIRA issues mentioned in commits.
pnpm add -D @zlodes/semantic-release-jira-comment-pluginnpm install --save-dev @zlodes/semantic-release-jira-comment-pluginFirst, set up the required environment variables:
export JIRA_BASE_URL=https://your-domain.atlassian.net
export [email protected]
export JIRA_TOKEN=your-api-tokenThen add the plugin to your semantic-release configuration:
{
  "plugins": [
    "@semantic-release/commit-analyzer",
    "@semantic-release/release-notes-generator",
    "@semantic-release/npm",
    "@zlodes/semantic-release-jira-comment-plugin"
  ]
}Or with optional configuration:
{
  "plugins": [
    "@semantic-release/commit-analyzer",
    "@semantic-release/release-notes-generator",
    "@semantic-release/npm",
    [
      "@zlodes/semantic-release-jira-comment-plugin",
      {
        "commentTemplate": "Custom comment for {{issueKey}}: {{packageName}} v{{version}} released!",
        "issuePattern": "\\b(PROJ|TASK)-\\d+\\b"
      }
    ]
  ]
}- JIRA_BASE_URL: Your JIRA instance base url (e.g., "https://your-domain.atlassian.net")
- JIRA_EMAIL: Your JIRA account email
- JIRA_TOKEN: Your JIRA API token (How to create an API token)
- commentTemplate: Template for the comment (default: "The issue ({{issueKey}}) was included in version {{version}} of {{packageName}} 🎉")
- issuePattern: Regular expression pattern to match JIRA issue keys (default:- /\\b[A-Z][A-Z0-9]*-\\d+\\b/g)
The following variables are available in the commentTemplate:
- {{issueKey}}: The specific JIRA issue key (e.g., "ABC-123")
- {{packageName}}: The package name from- SEMANTIC_RELEASE_PACKAGEenvironment variable (defaults to "Package")
- {{version}}: The released version number
- {{gitTag}}: The git tag for the release
- {{gitHead}}: The git commit hash
Set environment variables:
export JIRA_BASE_URL=https://mycompany.atlassian.net
export [email protected]
export JIRA_TOKEN=ATATT3xFfGF0...
export SEMANTIC_RELEASE_PACKAGE=my-awesome-projectConfigure semantic-release:
{
  "plugins": [
    "@semantic-release/commit-analyzer",
    "@semantic-release/release-notes-generator", 
    "@semantic-release/npm",
    [
      "@zlodes/semantic-release-jira-comment-plugin",
      {
        "commentTemplate": "🚀 Issue {{issueKey}} resolved in {{packageName}} version {{version}} ({{gitTag}})!\\n\\nCommit: {{gitHead}}",
        "issuePattern": "\\b(PROJ|TASK)-\\d+\\b"
      }
    ]
  ]
}- Early Validation: The plugin validates JIRA credentials during semantic-release's verifyConditionsphase
- Main Execution: During the successphase, the plugin:- Scans all commit messages in the release for JIRA issue keys
- For each found issue key, verifies the issue exists in JIRA
- Posts a personalized comment to each valid issue with the release information
 
The plugin uses the following environment variables:
# Required JIRA configuration
JIRA_BASE_URL=https://your-domain.atlassian.net
[email protected]
JIRA_TOKEN=your-api-token
# Package name used in comment templates (set automatically by semantic-release)
SEMANTIC_RELEASE_PACKAGE=my-package-name- Early Validation: Missing JIRA credentials or authentication failures will stop the release process early during verifyConditions
- Runtime Issues: If a JIRA issue doesn't exist, the plugin logs an error but continues processing other issues
- Network Errors: API failures are logged but don't fail the release process after validation passes
- Fork the repository
- Create a feature branch
- Make your changes
- Add tests for new functionality
- Run the test suite: pnpm test
- Submit a pull request
MIT