Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Use JIRA_ISSUE env var for issue specific commands #204

Open
nicholasspencer opened this issue Aug 10, 2018 · 11 comments
Open

Use JIRA_ISSUE env var for issue specific commands #204

nicholasspencer opened this issue Aug 10, 2018 · 11 comments

Comments

@nicholasspencer
Copy link

nicholasspencer commented Aug 10, 2018

I'm setting up a dynamic config that looks at the current git branch, parses out the issue id and sets that in the config as issue: ISSUE-XYZ. If I dump the env I see JIRA_ISSUE=ISSUE-XZY but it seems that since ISSUE is a required parameter, the command fails.

$ jira env
JIRA_ENDPOINT=https://jira.enterprise/
JIRA_PASSWORD_SOURCE=keyring
JIRA_CUSTOM_COMMANDS=[{"help":"print the JIRA environment variables available to custom commands","name":"env","script":"env | grep JIRA\n"},{"help":"display issues assigned to me","name":"mine","script":"if [ -n \"$JIRA_PROJECT\" ]; then\n    # if `project: ...` configured just list the issues for current project\n    {{jira}} list --template table --query \"resolution = unresolved and assignee=currentuser() and project = $JIRA_PROJECT ORDER BY priority asc, created\"\nelse\n    # otherwise list issues for all project\n    {{jira}} list --template table --query \"resolution = unresolved and assignee=currentuser() ORDER BY priority asc, created\"\nfi"},{"help":"display issues for active sprint","name":"sprint","script":"if [ -n \"$JIRA_PROJECT\" ]; then\n    # if `project: ...` configured just list the issues for current project\n    {{jira}} list --template table --query \"sprint in openSprints() and type != epic and resolution = unresolved and project=$JIRA_PROJECT ORDER BY priority desc, status asc\"\nelse\n    # otherwise list issues for all project\n    echo \"\\\"project: ...\\\" configuration missing from .jira.d/config.yml\"\nfi"}]
JIRA_ISSUE=IOS-4542
JIRA_PROJECT=ios
$ jira view
usage: jira view [<flags>] <ISSUE>

Prints issue details

Global flags:
      --help                   Show context-sensitive help (also try --help-long and --help-man).
  -v, --verbose ...            Increase verbosity for debugging
  -e, --endpoint=ENDPOINT      Base URI to use for Jira
  -k, --insecure               Disable TLS certificate verification
  -Q, --quiet                  Suppress output to console
      --unixproxy=UNIXPROXY    Path for a unix-socket proxy
      --socksproxy=SOCKSPROXY  Address for a socks proxy
  -u, --user=USER              user name used within the Jira service
      --login=LOGIN            login name that corresponds to the user used for authentication

Optional flags:
  -b, --browse                 Open issue(s) in browser after operation
  -t, --template=TEMPLATE      Template to use for output
      --gjq=GJQ                GJSON Query to filter output, see https://goo.gl/iaYwJ5
      --expand=EXPAND ...      field to expand for the issue
      --field=FIELD ...        field to return for the issue
      --property=PROPERTY ...  property to return for issue

Args:
  <ISSUE>  issue id to view

ERROR Invalid Usage: required argument 'ISSUE' not provided

My config looks like:

#!/usr/bin/env bash

cat ~/.jira.d/_config.yml

#if [[ -n $JIRA_ISSUE ]]; then
  echo "issue: $(git symbolic-ref HEAD | sed -e 's,.*/\(.*\),\1,')"
#fi
@coryb
Copy link
Contributor

coryb commented Aug 11, 2018

Hey, yeah, it looks like a bug. We are loading the issue property from the config file, but the command line processor does not know about it yet and the command line option is configured with Required() so it just fails when no value is present on the command line. I will see if I can find a solution.

On option might be to provide a custom command to view your branch issue:

custom-commands:
  - name: what
    alias: w
    script: |
      jira view $(git symbolic-ref HEAD | sed -e 's,.*/\(.*\),\1,')

then jira what or jira w will call jira view $issue automatically.

@nicholasspencer
Copy link
Author

That’s definitely a solution but it would be nice to move the ticket into other state via the normal command. I could totally setup other custom commands to do that but you can see the pain that would be.

@coryb
Copy link
Contributor

coryb commented Aug 11, 2018

Yeah, it is not ideal. The Required() property is on almost all of the commands that take arguments. I need to figure out a better way to deal with, I have a few ideas I can try out.

@nicholasspencer
Copy link
Author

More than happy to work on a fix or work on a patch in kingpin that adds params that could bypass the required attribute (probably harder to get a PR through)

@coryb
Copy link
Contributor

coryb commented Aug 11, 2018

The current code follows this pattern:

cmd.Arg("ISSUE", "issue id to view").Required().StringVar(&opts.Issue)

I tried using the Default argument, since opts.Issue is populate from configs before kingpin is used, but this does not work:

cmd.Arg("ISSUE", "issue id to view").Default(opts.Issue).Required().StringVar(&opts.Issue)

since kingpin does not allow Required with Default. So really the code would have to look like:

if opts.Issue == "" {
    cmd.Arg("ISSUE", "issue id to view").Required().StringVar(&opts.Issue)
} else {
    cmd.Arg("ISSUE", "issue id to view").Default(opts.Issue).StringVar(&opts.Issue)
}

But since I will have to do that about 40 times in the code, I want a better abstraction to encapsulate this logic. Not sure if you are comfortable hacking on Go and/or have any better ideas for this sort of thing.

@nicholasspencer
Copy link
Author

nicholasspencer commented Aug 11, 2018

I’ve done some Go CLI stuff at previous gigs. Agreed that it should be consolidated logic. I’ll give it a whack and open a PR.

@coryb
Copy link
Contributor

coryb commented Aug 11, 2018

btw, I was apparently wrong about the configs being loaded. They are configured to load when the command is finalized (via callback registered in poorly named jiracli.LoadConfigs) instead of when we configure the command usage (so that all configs for all commands are not parsed before we execute a single command). So effectively kingpin is configured and executed before configs are parsed. There might be some more delayed callback logic we can do, or we could simply remove the Required property off kingpin and manually validate in each of the callbacks where we call the command functions:
ie change:

        func(o *oreo.Client, globals *jiracli.GlobalOptions) error {
            return CmdView(o, globals, &opts)
        },

to:

        func(o *oreo.Client, globals *jiracli.GlobalOptions) error {
            if opts.Issue == "" {
                log.Fatalf("ISSUE command line option or `issue` property required")
            }
            return CmdView(o, globals, &opts)
        },

We could have some helper function to make this check for us to make it slightly more palatable. None of the options that come to mind are great.

@jonathandion
Copy link

jonathandion commented Sep 8, 2018

Cool feature! I'm interested too.

I'm currently doing $ jira view $(git_current_branch) and the name of my branch is like [EE18-1212] my super feature

@ejsuncy
Copy link
Contributor

ejsuncy commented Dec 13, 2018

Glad I found this ticket, I was hoping for some functionality like jira checkout AB-12345 which would set an env var that applied to all other commands

@nicholasspencer
Copy link
Author

nicholasspencer commented Dec 14, 2018

My "extra curricular" time has been gobbled up these past few months. I'll probably have some free time over the holidays.

@ingmarh
Copy link

ingmarh commented Aug 16, 2021

I‘m also interested. Automatically setting ISSUE from a environment variable/current Git branch would be really great.

Did someone work on a fix in the meantime? If I find time, I could try fixing it with the information described in the previous comments, but I‘ve never worked with Go so far.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

5 participants