Skip to main content

Shared library for JIRA Assistant Skills - HTTP client, configuration management, error handling, and utilities for JIRA REST API automation

Project description

JIRA Assistant Skills Library

PyPI version Python 3.8+ License: MIT

A shared Python library for JIRA REST API automation, providing HTTP client, configuration management, error handling, and utilities for the JIRA Assistant Skills project.

Installation

pip install jira-assistant-skills-lib

With optional keyring support for secure credential storage:

pip install jira-assistant-skills-lib[keyring]

Features

  • JiraClient: HTTP client with automatic retry logic and exponential backoff
  • ConfigManager: Multi-source configuration merging (env vars > settings.local.json > settings.json > defaults)
  • Error Handling: Exception hierarchy mapping HTTP status codes to domain exceptions
  • Validators: Input validation for issue keys, project keys, JQL queries, URLs, and more
  • Formatters: Output formatting for tables, JSON, CSV export
  • ADF Helper: Atlassian Document Format conversion (markdown/text to ADF and back)
  • Time Utils: JIRA time format parsing and formatting (e.g., '2h', '1d 4h 30m')
  • Cache: SQLite-based caching with TTL support for API responses
  • Credential Manager: Secure credential storage via system keychain or JSON fallback

Quick Start

from jira_assistant_skills_lib import get_jira_client, handle_errors, ValidationError

@handle_errors
def main():
    # Get a configured JIRA client
    client = get_jira_client()

    # Fetch an issue
    issue = client.get_issue('PROJ-123')
    print(f"Summary: {issue['fields']['summary']}")

    # Search issues with JQL
    results = client.search_issues('project = PROJ AND status = Open')
    for issue in results['issues']:
        print(f"{issue['key']}: {issue['fields']['summary']}")

if __name__ == '__main__':
    main()

Configuration

The library supports multiple configuration sources (in priority order):

  1. Environment variables: JIRA_API_TOKEN, JIRA_EMAIL, JIRA_SITE_URL
  2. Settings files: .claude/settings.local.json (gitignored) and .claude/settings.json
  3. Hardcoded defaults: Fallback values

Environment Variables

export JIRA_API_TOKEN="your-api-token"
export JIRA_EMAIL="your-email@company.com"
export JIRA_SITE_URL="https://your-company.atlassian.net"

Profile-based Configuration

# Use a specific profile
client = get_jira_client(profile='development')

Core Components

JiraClient

from jira_assistant_skills_lib import JiraClient

client = JiraClient(
    base_url="https://your-company.atlassian.net",
    email="your-email@company.com",
    api_token="your-api-token"
)

# Make API calls
issue = client.get_issue('PROJ-123')
client.create_issue(project_key='PROJ', summary='New issue', issue_type='Task')
client.transition_issue('PROJ-123', 'Done')

Error Handling

from jira_assistant_skills_lib import (
    JiraError,
    AuthenticationError,
    PermissionError,
    NotFoundError,
    handle_errors
)

@handle_errors
def main():
    # Exceptions are caught and formatted nicely
    pass

# Or handle manually
try:
    client.get_issue('INVALID-999')
except NotFoundError as e:
    print(f"Issue not found: {e}")
except AuthenticationError as e:
    print(f"Auth failed: {e}")
except JiraError as e:
    print(f"JIRA error: {e}")

Validators

from jira_assistant_skills_lib import (
    validate_issue_key,
    validate_project_key,
    validate_jql,
    validate_url,
    ValidationError
)

try:
    key = validate_issue_key('PROJ-123')  # Returns 'PROJ-123'
    key = validate_issue_key('invalid')   # Raises ValidationError
except ValidationError as e:
    print(f"Invalid input: {e}")

ADF Helper

from jira_assistant_skills_lib import (
    markdown_to_adf,
    text_to_adf,
    adf_to_text
)

# Convert markdown to ADF for JIRA
adf = markdown_to_adf("**Bold** and *italic* text")

# Convert plain text to ADF
adf = text_to_adf("Simple text content")

# Extract text from ADF
text = adf_to_text(adf_document)

Time Utils

from jira_assistant_skills_lib import (
    parse_time_string,
    format_seconds,
    parse_relative_date
)

# Parse JIRA time format to seconds
seconds = parse_time_string('2h 30m')  # 9000

# Format seconds to JIRA time format
time_str = format_seconds(9000)  # '2h 30m'

# Parse relative dates
dt = parse_relative_date('yesterday')
dt = parse_relative_date('2025-01-15')

Development

# Clone the repository
git clone https://github.com/grandcamel/jira-assistant-skills-lib.git
cd jira-assistant-skills-lib

# Install development dependencies
pip install -e ".[dev]"

# Run tests
pytest

# Format code
black src tests
isort src tests

License

MIT License - see LICENSE for details.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

jira_assistant_skills_lib-0.1.2.tar.gz (79.8 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

jira_assistant_skills_lib-0.1.2-py3-none-any.whl (90.1 kB view details)

Uploaded Python 3

File details

Details for the file jira_assistant_skills_lib-0.1.2.tar.gz.

File metadata

File hashes

Hashes for jira_assistant_skills_lib-0.1.2.tar.gz
Algorithm Hash digest
SHA256 7b45f434560145d2929d07edc317a8137ddb542df704e5ae96d5ad1ecad82290
MD5 203b5f53d5315caa2a003358e489ec58
BLAKE2b-256 b4eac4a3651e7da93cd600bf9de02fd7c23db2d5b16105b8a8b34a1c0e2870ed

See more details on using hashes here.

Provenance

The following attestation bundles were made for jira_assistant_skills_lib-0.1.2.tar.gz:

Publisher: publish.yml on grandcamel/jira-assistant-skills-lib

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file jira_assistant_skills_lib-0.1.2-py3-none-any.whl.

File metadata

File hashes

Hashes for jira_assistant_skills_lib-0.1.2-py3-none-any.whl
Algorithm Hash digest
SHA256 d491ca51f6e3753a706de5af499bbba08f2764e31f00c01e1329d3f2016fca31
MD5 4a8c80e9e330748293565465eb593716
BLAKE2b-256 5462eb22e118492f1e5e02b8a62d15ed0c3c6f272eba0aff73a04ba9fea06fd4

See more details on using hashes here.

Provenance

The following attestation bundles were made for jira_assistant_skills_lib-0.1.2-py3-none-any.whl:

Publisher: publish.yml on grandcamel/jira-assistant-skills-lib

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page