redmine-cli
Redmine CLI
A CLI for the Redmine REST API. Use redmine <command> --help for detailed flags and examples — this skill only covers what --help cannot tell you.
Available Commands
Only these top-level commands exist. Do NOT invent subcommands that aren't listed here — run redmine <command> --help to discover subcommands.
| Command | Purpose |
|---|---|
issues |
Create, list, get, update, close, reopen, assign, comment, delete, search, browse issues |
projects |
List, get, create, update, delete projects; list project members |
time |
Log, list, get, update, delete, summarize time entries |
versions |
Create, list, get, update, delete project versions (milestones) |
memberships |
List, get, create, update, delete project memberships |
users |
List, get, create, update, delete users |
groups |
List, get, create, update, delete groups; add/remove users |
categories |
List issue categories |
trackers |
List trackers |
statuses |
List issue statuses |
search |
Search issues, wiki, news, messages, or browse results |
auth |
Login, logout, list, switch, and check status of authentication profiles |
wiki |
List, get, create, update, delete wiki pages |
api |
Make raw authenticated API requests |
Setup
If the redmine command is not found, install it:
curl -fsSL https://raw.githubusercontent.com/aarondpn/redmine-cli/main/install.sh | bash
Then run redmine auth login for interactive configuration. Use redmine config to verify an existing setup.
Critical Rules
- Always use
-o jsonwhen you need to parse output programmatically. JSON goes to stdout only; stderr is separate. - Use
--limit 0to fetch ALL results. The default limit is 100. - All name-accepting flags (--project, --tracker, --status, --priority, --assignee, --category, --version, --activity) resolve human-readable names automatically. You don't need to look up IDs first.
--assignee merefers to the current API user.--status "*"shows all issues regardless of status (default isopen).
When Something Doesn't Work: Stop and Use --help
Do NOT guess, loop, or retry with invented flags/subcommands. If a command fails or you're unsure about the correct syntax:
- Run
redmine <command> --help(orredmine <command> <subcommand> --help) to see the actual available options, flags, and subcommands. - Read the help output carefully — it is authoritative and always up to date. Trust it over your own assumptions.
- Never invent flags or subcommands that aren't shown in
--help. If you think an option should exist but it doesn't appear in the help, it doesn't exist. - Do not loop — if the same command fails twice, stop and re-read the help output. Do not keep retrying with slight variations hoping one will work.
- Parse output with
-o jsonand standard JSON tools (jq) — never use Python scripts, awk hacks, or regex to parse CLI output. The CLI's JSON output is well-structured; use it. - Ask the user if the help output doesn't clarify things — that's better than spiraling through failed attempts.
Permission Gotcha: Users & Groups
Resolving users and groups by name requires admin privileges. If you get a permission error:
- Do NOT retry with the same name
- Use
mefor the current user - To discover user IDs without admin access, extract them from other sources:
redmine issues list --project <project> -o json— theassigned_toandauthorfields contain user IDs and namesredmine memberships list --project <project> -o json— lists all project members with their IDsredmine issues get <id> --journals -o json— journal entries contain user references
Workflow: Resolving Ambiguous Values
When a command needs a value from a fixed set (tracker, status, priority, category, version, assignee) and you're not sure of the exact name:
- Query options first:
redmine trackers list -o json,redmine statuses list -o json, etc. - Present choices to the user via AskUserQuestion with a formatted list
- Use the confirmed value in the command
For users/groups, if the list endpoint fails with a permission error, use the workarounds from the section above instead.
After Creating Resources
When you create an issue, project, user, or other resource, the CLI returns the new ID. Offer the user a clickable URL so they can open it in the browser:
- Issues:
redmine issues open <id>opens the issue directly. You can also provide the URL:<server>/issues/<id> - Projects:
<server>/projects/<identifier> - Users:
<server>/users/<id> - Time entries:
<server>/time_entries/<id>/edit
Get the server URL from redmine config (or from the JSON output's hints). Always mention the URL or the open command after a successful create so the user can quickly navigate to the new resource.
Non-Obvious Behaviors
redmine issues listdefaults to--status open. Use--status closed,--status "*", or a specific status name.redmine issues get <id> --journalsincludes comments/history. Also available:--children,--relations.redmine issues updateonly sends flags you explicitly pass — omitted flags are not changed.- If
--projectis omitted, the configured default project is used (set viaredmine auth login). - Projects can accumulate hundreds of versions, most of them closed or locked. When you need a version for a new issue, time entry, or similar workflow, always start from
redmine versions list --openso the shortlist stays small and you don't pick a version that can no longer accept work. - Any date flag (
--due-date,--date,--from,--to) accepts the literal keywordtodayas a shortcut for the current date.