Source Code
Jira Skill
Work with Jira issues and worklogs from Clawdbot (search, status, create, log work, worklog summaries).
Setup
- Get your API key: https://id.atlassian.com/manage-profile/security/api-tokens
- Click "Create API Token"
- Set environment variables:
export JIRA_EMAIL="[email protected]" export JIRA_API_TOKEN="your-api-token" export JIRA_URL="https://your-domain.atlassian.net" # Optional project scope (comma-separated). Empty = search all. export JIRA_BOARD="ABC"
Requires curl, jq, bc, and python3.
Quick Commands
All commands live in {baseDir}/scripts/jira.sh.
{baseDir}/scripts/jira.sh search "timeout" [max]โ fuzzy search by summary or key insideJIRA_BOARD{baseDir}/scripts/jira.sh link ABC-123โ browser link for an issue{baseDir}/scripts/jira.sh issue ABC-123โ quick issue details{baseDir}/scripts/jira.sh status ABC-123 "In Progress"โ move an issue (validates available transitions){baseDir}/scripts/jira.sh transitions ABC-123โ list allowed transitions{baseDir}/scripts/jira.sh assign ABC-123 "name or email"โ assign by user search{baseDir}/scripts/jira.sh assign-me ABC-123โ assign to yourself{baseDir}/scripts/jira.sh comment ABC-123 "text"โ add a comment{baseDir}/scripts/jira.sh create "Title" ["Description"]โ create a Task inJIRA_BOARD{baseDir}/scripts/jira.sh log ABC-123 2.5 [YYYY-MM-DD]โ log hours (defaults to today UTC){baseDir}/scripts/jira.sh my [max]โ open issues assigned to you{baseDir}/scripts/jira.sh hours 2025-01-01 2025-01-07โ your logged hours by issue (JSON){baseDir}/scripts/jira.sh hours-day 2025-01-07 [name|email]โ logged hours for a day grouped by user/issue; optional filter (name/email; also resolves to accountId){baseDir}/scripts/jira.sh hours-issue ABC-123 [name|email]โ logged hours for an issue; optional filter (name/email; also resolves to accountId)
Command Reference
Search issues
{baseDir}/scripts/jira.sh search "payment failure" [maxResults]Issue link
{baseDir}/scripts/jira.sh link ABC-321Issue details
{baseDir}/scripts/jira.sh issue ABC-321Update status
{baseDir}/scripts/jira.sh status ABC-321 "Done"List transitions
{baseDir}/scripts/jira.sh transitions ABC-321Assign issue
{baseDir}/scripts/jira.sh assign ABC-321 "Jane Doe"Assign to yourself
{baseDir}/scripts/jira.sh assign-me ABC-321Add comment
{baseDir}/scripts/jira.sh comment ABC-321 "Deployed to staging"Create issue
{baseDir}/scripts/jira.sh create "Fix auth timeout" "Users being logged out after 5m"Log hours
{baseDir}/scripts/jira.sh log PB-321 1.5 2025-01-18My open issues
{baseDir}/scripts/jira.sh my [maxResults]Logged hours by issue (me)
{baseDir}/scripts/jira.sh hours 2025-01-01 2025-01-05Logged hours for a day (everyone)
{baseDir}/scripts/jira.sh hours-day 2025-01-05Logged hours for a day (user filter)
{baseDir}/scripts/jira.sh hours-day 2025-01-05 "jane"Logged hours for an issue
{baseDir}/scripts/jira.sh hours-issue ABC-321 "jane"
Notes
- Worklog commands use Jira's worklog/updated + worklog/list combo and may take a few seconds on large projects.
hoursfilters byJIRA_EMAIL;hours-dayreturns all users with totals per issue and user.- Outputs for hours commands are JSON for reuse in other tools.
- Status transitions are validated against the server-provided transition list before applying.