Git Product home page Git Product logo

jira-terminal's Introduction

Jira Terminal

This application can be used for personal usage to manage jira from terminal.

Installation

This application can be used in multiple platform.

MacOS

This package is available in brew as jira-terminal. You can install it with following command:

brew tap amritghimire/jira-terminal 
brew install jira-terminal

Arch Linux

This package is available in aur repository as jira-terminal-bin

Debian/Ubuntu

On debian based system, the deb file is available in releases. You can download latest release from there. Please make sure libc is installed in your system.

Cargo

If you already have a Rust environment set up, you can use the cargo install command: cargo install jira-terminal

Cargo will build the jira-terminal binary and place it in $HOME/.cargo/bin. You can also setup Rust toolchain from Rust official site

Manual Installation from Github

Compiled binary versions of jira-terminal are uploaded to GitHub when a release is made. You can install jira-terminal manually by downloading a release , extracting it, and copying the binary to a directory in your $PATH, such as /usr/local/bin.

Autocompletion Script

The autocompletion script can be found in the release section. You can download the autocompletion script from there or use our application to generate the script. To generate the script, run:

jira-terminal autocompletion --shell [zsh|bash|fish|powershell|elvish] > _jira.terminal

Depending on your shell, you can move your autocompletion file to the following location:

  • ZSH - /usr/share/zsh/site-functions/_jira-terminal
  • BASH - /usr/share/bash-completion/completions/_jira-terminal
  • Fish - /share/fish/vendor_completions.d/_jira-terminal

Usage

When running the application for first time, you will be asked with following values.

  • hostname [This will be used to identify the jira hostname to be used.]
  • email [Email address you use to login with the application.]
  • token [You can obtain the app password from the link specified in the application]

After that, you can use following commands for help.

jira-terminal help
jira-terminal help list
jira-terminal help transition
jira-terminal help alias
jira-terminal help detail
jira-terminal help fields
jira-terminal help update
jira-terminal help new
jira-terminal help assign
jira-terminal help comment
jira-terminal help autocompletion
JIRA Terminal 2.0.0
Amrit Ghimire <[email protected]>
This is a command line application that can be used as a personal productivity tool for interacting with JIRA

USAGE:
    jira-terminal [SUBCOMMAND]

FLAGS:
    -h, --help       Prints help information
    -V, --version    Prints version information

SUBCOMMANDS:
    alias             Configuration for alias. One of add,list or remove is required.
    assign            Assign a ticket to user.
    autocompletion    Generate autocompletion script..
    comment           List or add comments to a ticket. Default action is adding.
    detail            Detail of a JIRA tickets..
    fields            List of possible Fields for details...
    help              Prints this message or the help of the given subcommand(s)
    list              List the issues from JIRA.
    new               Create a new ticket.
    transition        Transition of ticket across status.
    update            Update a field for a ticket

List of Tickets


jira-terminal-list 
List the issues from JIRA.

USAGE:
    jira-terminal list [FLAGS] [OPTIONS]

FLAGS:
    -h, --help       Prints help information
    -J, --json       JSON response
    -M, --me         Issues assigned to you.
    -V, --version    Prints version information

OPTIONS:
    -A, --alias <ALIAS>               Save the applied options as an alias. You can use it with jql option later.
    -a, --assignee <ASSIGNEE>...       Assignee username or email to filter with.
    -c, --component <COMPONENT>...    Component name or ID to filter with.
    -C, --count <COUNT>               Total number of issues to show. (Default is 50)
    -d, --display <DISPLAY>            Comma separated list of fields to display.
                                      Possible options for fields are:
                                      key,resolution,priority,assignee,status,components,creator,reporter,issuetype,project,summary
                                      
                                      You can pass alias as option for display. You can save alias using alias
                                      subcommand for the application.
                                      
                                       Default options are
                                       key,summary,status,assignee
                                                         
    -e, --epic <EPIC>...              EPIC name or issue key of epic to filter with.
    -f, --filter <FILTER>...          Filter name or filter id that you saved in JIRA.
    -j, --jql <JQL>                   JQL Query or alias to JQL query to filter with.
    -l, --label <LABEL>...            Search for issues with a label or list of labels.
    -o, --offset <OFFSET>             Offset to start the first item to return in a page of results. (Default is 0)
    -m, --main <PARENT>...            Search for subtask of a particular issue.
    -P, --priority <PRIORITY>...      Search for issues with a particular priority.
    -p, --project <PROJECT>...        Project Code to filter with.
    -r, --reporter <REPORTER>...      Search for issues that were reported by a particular user.
    -s, --sprint <SPRINT>...          Search for issues that are assigned to a particular sprint.
    -S, --status <STATUS>...          Search for issues that have a particular status.
    -T, --text <TEXT>                 This is a master-field that allows you to search all text fields for issues.
    -t, --type <TYPE>...              Search for issues that have a particular issue type. 

You can specify the following fields multiple time to filter by multiple values.
assignee, component, epic, filter, label, main, priority, project, reporter, sprint, status, type.

For example to fetch list of tickets in Backlog and In progress, you can use
jira-terminal list -s Backlog -s 'In Progress'

Transition

jira-terminal-transition 
Transition of ticket across status.

USAGE:
    jira-terminal transition [FLAGS] <STATUS> --ticket <TICKET>

FLAGS:
    -h, --help       Prints help information
    -l, --list       List the possible transitions.
    -V, --version    Prints version information

OPTIONS:
    -t, --ticket <TICKET>    Ticket ID from JIRA.

ARGS:
    <STATUS>    Status or alias of status to move the ticket to.

Alias

jira-terminal-alias 
Configuration for alias. One of add,list or remove is required.

USAGE:
    jira-terminal alias [FLAGS] <NAME> --add <add> --list --remove

FLAGS:
    -h, --help       Prints help information
    -l, --list       List the alias saved.
    -r, --remove     List the alias saved.
    -V, --version    Prints version information

OPTIONS:
    -a, --add <add>    Value to associate with provided alias name.

ARGS:
    <NAME>    Name of alias. (Required except for list option)

Sample usage:

  • jira-terminal alias -l
  • jira-terminal alias alias_name -a "Alias Value"
  • jira-terminal alias -r alias_name

Detail

jira-terminal-detail 
Detail of a JIRA tickets..

USAGE:
    jira-terminal detail [OPTIONS] <TICKET>

FLAGS:
    -h, --help       Prints help information
    -V, --version    Prints version information

OPTIONS:
    -f, --fields <fields>    Comma separated lists of fields or alias to show.
                             Possible options are: 
                             key,summary,description,status,issuetype,priority,labels,assignee,components,creator,reporter,project,comment
                             
                             You can use all to show all fields.
                             Default selection are:
                             key,summary,description
                                                 

ARGS:
    <TICKET>    Ticket id for details.

Fields

jira-terminal-fields 
List of possible Fields for details...

USAGE:
    jira-terminal fields <TICKET>

FLAGS:
    -h, --help       Prints help information
    -V, --version    Prints version information

ARGS:
    <TICKET>    Ticket id for details.

Update

jira-terminal-update 
Update a field for a ticket

USAGE:
    jira-terminal update <TICKET> --field <field> --value <value>

FLAGS:
    -h, --help       Prints help information
    -V, --version    Prints version information

OPTIONS:
    -f, --field <field>    Key of field to update. You can use jira-terminal fields <TICKET> to see possible set of
                           keys.
    -v, --value <value>    Value of the field to update.

ARGS:
    <TICKET>    Ticket ID to update

New

jira-terminal-new 
Create a new ticket.

USAGE:
    jira-terminal new [FLAGS] [OPTIONS] --main <main> --project <project>

FLAGS:
    -h, --help       Prints help information
    -M, --minimal    Only summary and description will be asked if not available.
    -q, --quiet      Do not ask for missing options.
    -V, --version    Prints version information

OPTIONS:
    -a, --assignee <assignee>          Assignee email of ticket
    -c, --components <components>      Comma separated list of components of ticket
    -C, --custom <custom>              Comma separated value pair for custom fields. You can use alias in value or key
                                       itself. Example- "customfield_12305:value,alias_to_key:value2. You can use fields
                                       subcommand to check the list of custom fields available. 
    -d, --description <description>    Description of ticket
    -l, --labels <labels>              Comma separated list of labels.
    -m, --main <main>                  Main ticket to create the sub-ticket.
    -p, --priority <priority>          Priority Of the ticket.
    -P, --project <project>            Project Key to create the ticket.
    -s, --summary <summary>            Summary of ticket
    -t, --type <type>                  Issue type for new ticket.

Assign

jira-terminal-assign 
Assign a ticket to user.

USAGE:
    jira-terminal assign --ticket <ticket> --user <user>

FLAGS:
    -h, --help       Prints help information
    -V, --version    Prints version information

OPTIONS:
    -t, --ticket <ticket>    Ticket to use.
    -u, --user <user>        Assign the ticket to the provided user.

Comment

jira-terminal-comment 
List or add comments to a ticket. Default action is adding.

USAGE:
    jira-terminal comment [FLAGS] [OPTIONS] --ticket <ticket>

FLAGS:
    -h, --help       Prints help information
    -l, --list       List all the comments of a ticket.
    -V, --version    Prints version information

OPTIONS:
    -b, --body <body>        Body of the comment. To mention someone, you can use @(query) The query can include jira
                             username or display name or email address.
    -t, --ticket <ticket>    Ticket to use.

Notes

  • The credentials and other configuration are stored in a file ~/.jira_terminal_configuration.json. The base64 encoded version of credentials are only written in the configuration file.

jira-terminal's People

Contributors

amritghimire avatar clux avatar dependabot[bot] avatar jayvdb avatar tamc avatar

Stargazers

 avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar

Watchers

 avatar  avatar  avatar  avatar

jira-terminal's Issues

Allow specifying multiple statuses

When listing my issues, it'd be helpful to be able to filter on "New Request,In Review,To Do" or some other similar syntax.

Note I was able to do jira-terminal list -j 'assignee = "[email protected]" AND status != "Closed"' so this issue is low priority, I guess.

`update` field does not work on `option` fields

Hi there, small problem I've found here. Everything else seems to be working great!

# This works:
$ jira-terminal update -f priority -v 'High' TICKET
Successfully Updated

# This says it works, but it doesn't actually update the API
$ jira-terminal update -f customfield_xxx -v 'somevalue' TICKET
Successfully Updated

The api docs seem to indicate different handling for custom fields.

In particular I have been testing with a field with this schema:

        "customfield_10768": {
            "required": false,
            "schema": {
                "type": "option",
                "custom": "com.atlassian.jira.plugin.system.customfieldtypes:select",
                "customId": 10768
            },
            "name": "Risk Level",
            "key": "customfield_10768",
            "operations": [
                "set"
            ],
            "allowedValues": [
                {
                    "self": "https://xxx.atlassian.net/rest/api/2/customFieldOption/10656",
                    "value": "N/A",
                    "id": "10656"
                },
                {
                    "self": "https://xxx.atlassian.net/rest/api/2/customFieldOption/10445",
                    "value": "Low",
                    "id": "10445"
                },
                {
                    "self": "https://xxx.atlassian.net/rest/api/2/customFieldOption/10446",
                    "value": "Medium",
                    "id": "10446"
                },
                {
                    "self": "https://xxx.atlassian.net/rest/api/2/customFieldOption/10447",
                    "value": "High",
                    "id": "10447"
                }
            ]
        },

which should come back like this from jira-terminal detail when it is set:

        "customfield_10768": {
            "self": "https://xxx.atlassian.net/rest/api/2/customFieldOption/10446",
            "value": "Medium",
            "id": "10446"
        },

maybe update.rs needs to handle option type in https://github.com/amritghimire/jira-terminal/blob/main/src/jira/update.rs#L53-L74 ?

Can't log in to self-hosted Jira with API Key

I generated an API key to connect to my company's Jira instance, but it does not seem to work. Set up fails with:

thread 'main' panicked at 'called `Result::unwrap()` on an `Err` value: Status(401, Response[status: 401, status_text: , url: https://jira.vonage.com/rest/api/3/user/[email protected]])', src/config/cache.rs:29:42
note: run with `RUST_BACKTRACE=1` environment variable to display a backtrace

I know this is not a lot of useful information, but I don't know exactly what to do do debug it.

I surmise this might be related to the Jira instance being set up with Okta SSO. Any guesses?

edit: seems the instance is using the de.resolution.apitokenauth plugin for API token authentication, if that could be the cause..

Output to JSON

It'd be nice to have an option to write to a machime readable format like json so we could use the tool in scripts.

`jira-terminal` output doesn't have newline in the end

Screenshot 2021-05-29 at 21 48 42

Commands such as list do end with a new line.

 $ uname -a
Darwin speyside.local 20.4.0 Darwin Kernel Version 20.4.0: Fri Mar  5 01:14:14 PST 2021; root:xnu-7195.101.1~3/RELEASE_X86_64 x86_64

Using alacritty with and without t-mux.

Minor text bug

Please enter your URL of JIRA. (Example: example.atlassian.net):

The URL is not accepted, it wants the hostname as the example suggests.

Error codes and messages not reported

Steps to reproduce

  1. Run jira-terminal detail for an issue that does not exist
$ jira-terminal --version
JIRA Terminal 1.2.0

# when issue FOO-123456 does not exist
$ jira-terminal detail FOO-123456
Error occured when searching tickets.
Err(Status(404, Response[status: 404, status_text: Not Found, url: https://example.atlassian.net/rest/api/2/issue/FOO-123456]))
$ echo $?
0
  1. Exit code is 0 and error message is printed on STDOUT instead of STDERR

Expected results

  1. A non-zero exit code is reported when jira-terminal exits with an error
  2. Error messages are printed on STDERR instead of STDOUT

Why this would be useful

When using jira-terminal inside a script, it's important to know if the tool encountered an error. That is what the non-zero exit code is for. Additionally, it's useful to separate result output from error output because of usage like:

result="$(jira-terminal detail FOO-123456)"

In this scenario, typically you only want successful output to be captured into the result variable. That way error output is still printed to the user running the script.

How to call an alias?

The documentation explains how to add, list and remove an alias, but it doesn't explain how to use it. I have tried to call an alias like this:

$ jira-terminal alias open-issues -a "list -M -S 'Open' -S 'In Progress' -S 'Todo' -S 'Review'"
$ jira-terminal alias -l                                                                             
Listing alias saved for you: 
* open-issues           => "list -M -S 'Open' -S 'In Progress' -S 'Todo' -S 'Review'"
$ jira-terminal open-issues
error: Found argument 'trs-issues' which wasn't expected, or isn't valid in this context

USAGE:
    jira-terminal [SUBCOMMAND]

For more information try --help

jira-terminal doesn't display more than 50 tasks

What happens?

jira-terminal list displays at most 50 tasks.

What should happen?

jira-terminal list should be able to display all tasks matching the given criteria (i.e., all tasks, all tasks selected by the given JQL clause with -j etc.

cargo install jira-terminal failed

error[E0658]: use of unstable library feature 'str_split_once': newly added
  --> /Users/songtianyi/.cargo/registry/src/github.com-1ecc6299db9ec823/jira-terminal-1.4.0/src/jira/new_issue.rs:59:58
   |
59 |                 if let Some((key, value)) = custom_field.split_once(":") {
   |                                                          ^^^^^^^^^^
   |
   = note: see issue #74773 <https://github.com/rust-lang/rust/issues/74773> for more information
   = help: add `#![feature(str_split_once)]` to the crate attributes to enable

error[E0658]: use of unstable library feature 'str_split_once': newly added
   --> /Users/songtianyi/.cargo/registry/src/github.com-1ecc6299db9ec823/jira-terminal-1.4.0/src/jira/new_issue.rs:108:26
    |
108 |         let split = main.split_once("-");
    |                          ^^^^^^^^^^
    |
    = note: see issue #74773 <https://github.com/rust-lang/rust/issues/74773> for more information
    = help: add `#![feature(str_split_once)]` to the crate attributes to enable

error: aborting due to 2 previous errors

For more information about this error, try `rustc --explain E0658`.
error: failed to compile `jira-terminal v1.4.0`, intermediate artifacts can be found at `/var/folders/db/wkkn_2bs71s7gj97hh1rw40c0000gn/T/cargo-installbiQt2Y`

Caused by:
  could not compile `jira-terminal`

Tasks for First releases

  • Setup Basic API Backbone
  • Setup util for transition
  • Setup Clap for system argument parsing
  • Add Feature to list transitions
  • Add feature to list tickets by certain filter
  • Allow user to specify Alias and use it
  • Allow user to enter jql or alias for list feature
  • Allow user to move the ticket among the transition
  • Allow user to view summary and description for a ticket
  • Allow user to create a new JIRA Ticket
  • Add feature to view possible fields and view custom fields as well in detail view
  • Allow user to update the fields value
  • Allow user to assign the ticket
  • Allow user to view comment and add comment

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.