add issue to cmd options

This commit is contained in:
Cory Bennett
2017-08-19 15:09:01 -07:00
parent f0b08c5869
commit 47a5ce25bc
3 changed files with 40 additions and 29 deletions
+16 -11
View File
@@ -13,10 +13,10 @@ type EditOptions struct {
jiradata.IssueUpdate jiradata.IssueUpdate
jira.SearchOptions jira.SearchOptions
Overrides map[string]string Overrides map[string]string
Issue string
} }
func (jc *JiraCli) CmdEditRegistry() *CommandRegistryEntry { func (jc *JiraCli) CmdEditRegistry() *CommandRegistryEntry {
issue := ""
opts := EditOptions{ opts := EditOptions{
GlobalOptions: GlobalOptions{ GlobalOptions: GlobalOptions{
Template: "edit", Template: "edit",
@@ -27,15 +27,15 @@ func (jc *JiraCli) CmdEditRegistry() *CommandRegistryEntry {
return &CommandRegistryEntry{ return &CommandRegistryEntry{
"Edit issue details", "Edit issue details",
func() error { func() error {
return jc.CmdEdit(issue, &opts) return jc.CmdEdit(&opts)
}, },
func(cmd *kingpin.CmdClause) error { func(cmd *kingpin.CmdClause) error {
return jc.CmdEditUsage(cmd, &issue, &opts) return jc.CmdEditUsage(cmd, &opts)
}, },
} }
} }
func (jc *JiraCli) CmdEditUsage(cmd *kingpin.CmdClause, issue *string, opts *EditOptions) error { func (jc *JiraCli) CmdEditUsage(cmd *kingpin.CmdClause, opts *EditOptions) error {
if err := jc.GlobalUsage(cmd, &opts.GlobalOptions); err != nil { if err := jc.GlobalUsage(cmd, &opts.GlobalOptions); err != nil {
return err return err
} }
@@ -56,23 +56,23 @@ func (jc *JiraCli) CmdEditUsage(cmd *kingpin.CmdClause, issue *string, opts *Edi
return nil return nil
}).String() }).String()
cmd.Flag("override", "Set issue property").Short('o').StringMapVar(&opts.Overrides) cmd.Flag("override", "Set issue property").Short('o').StringMapVar(&opts.Overrides)
cmd.Arg("ISSUE", "issue id to edit").StringVar(issue) cmd.Arg("ISSUE", "issue id to edit").StringVar(&opts.Issue)
return nil return nil
} }
// Edit will get issue data and send to "edit" template // Edit will get issue data and send to "edit" template
func (jc *JiraCli) CmdEdit(issue string, opts *EditOptions) error { func (jc *JiraCli) CmdEdit(opts *EditOptions) error {
type templateInput struct { type templateInput struct {
*jiradata.Issue `yaml:",inline"` *jiradata.Issue `yaml:",inline"`
Meta *jiradata.EditMeta `yaml:"meta" json:"meta"` Meta *jiradata.EditMeta `yaml:"meta" json:"meta"`
Overrides map[string]string `yaml:"overrides" json:"overrides"` Overrides map[string]string `yaml:"overrides" json:"overrides"`
} }
if issue != "" { if opts.Issue != "" {
issueData, err := jc.GetIssue(issue, nil) issueData, err := jc.GetIssue(opts.Issue, nil)
if err != nil { if err != nil {
return err return err
} }
editMeta, err := jc.GetIssueEditMeta(issue) editMeta, err := jc.GetIssueEditMeta(opts.Issue)
if err != nil { if err != nil {
return err return err
} }
@@ -83,9 +83,14 @@ func (jc *JiraCli) CmdEdit(issue string, opts *EditOptions) error {
Meta: editMeta, Meta: editMeta,
Overrides: opts.Overrides, Overrides: opts.Overrides,
} }
return jc.editLoop(&opts.GlobalOptions, &input, &issueUpdate, func() error { err = jc.editLoop(&opts.GlobalOptions, &input, &issueUpdate, func() error {
return jc.EditIssue(issue, &issueUpdate) return jc.EditIssue(opts.Issue, &issueUpdate)
}) })
if err != nil {
return err
}
fmt.Printf("OK %s %s/browse/%s\n", opts.Issue, jc.Endpoint, opts.Issue)
// FIXME implement browse // FIXME implement browse
} }
results, err := jc.Search(opts) results, err := jc.Search(opts)
+7 -7
View File
@@ -8,10 +8,10 @@ import (
type WorklogAddOptions struct { type WorklogAddOptions struct {
GlobalOptions GlobalOptions
jiradata.Worklog jiradata.Worklog
Issue string
} }
func (jc *JiraCli) CmdWorklogAddRegistry() *CommandRegistryEntry { func (jc *JiraCli) CmdWorklogAddRegistry() *CommandRegistryEntry {
issue := ""
opts := WorklogAddOptions{ opts := WorklogAddOptions{
GlobalOptions: GlobalOptions{ GlobalOptions: GlobalOptions{
Template: "worklog", Template: "worklog",
@@ -20,15 +20,15 @@ func (jc *JiraCli) CmdWorklogAddRegistry() *CommandRegistryEntry {
return &CommandRegistryEntry{ return &CommandRegistryEntry{
"Add a worklog to an issue", "Add a worklog to an issue",
func() error { func() error {
return jc.CmdWorklogAdd(issue, &opts) return jc.CmdWorklogAdd(&opts)
}, },
func(cmd *kingpin.CmdClause) error { func(cmd *kingpin.CmdClause) error {
return jc.CmdWorklogAddUsage(cmd, &issue, &opts) return jc.CmdWorklogAddUsage(cmd, &opts)
}, },
} }
} }
func (jc *JiraCli) CmdWorklogAddUsage(cmd *kingpin.CmdClause, issue *string, opts *WorklogAddOptions) error { func (jc *JiraCli) CmdWorklogAddUsage(cmd *kingpin.CmdClause, opts *WorklogAddOptions) error {
if err := jc.GlobalUsage(cmd, &opts.GlobalOptions); err != nil { if err := jc.GlobalUsage(cmd, &opts.GlobalOptions); err != nil {
return err return err
} }
@@ -37,16 +37,16 @@ func (jc *JiraCli) CmdWorklogAddUsage(cmd *kingpin.CmdClause, issue *string, opt
cmd.Flag("noedit", "Disable opening the editor").BoolVar(&opts.SkipEditing) cmd.Flag("noedit", "Disable opening the editor").BoolVar(&opts.SkipEditing)
cmd.Flag("comment", "Comment message for worklog").Short('m').StringVar(&opts.Comment) cmd.Flag("comment", "Comment message for worklog").Short('m').StringVar(&opts.Comment)
cmd.Flag("time-spent", "Time spent working on issue").Short('T').StringVar(&opts.TimeSpent) cmd.Flag("time-spent", "Time spent working on issue").Short('T').StringVar(&opts.TimeSpent)
cmd.Arg("ISSUE", "issue id to fetch worklogs").Required().StringVar(issue) cmd.Arg("ISSUE", "issue id to fetch worklogs").Required().StringVar(&opts.Issue)
return nil return nil
} }
// CmdWorklogAdd will attempt to add (action=add) a worklog to the given issue. // CmdWorklogAdd will attempt to add (action=add) a worklog to the given issue.
// It will spawn the editor (unless --noedit isused) and post edited YAML // It will spawn the editor (unless --noedit isused) and post edited YAML
// content as JSON to the worklog endpoint // content as JSON to the worklog endpoint
func (jc *JiraCli) CmdWorklogAdd(issue string, opts *WorklogAddOptions) error { func (jc *JiraCli) CmdWorklogAdd(opts *WorklogAddOptions) error {
return jc.editLoop(&opts.GlobalOptions, &opts.Worklog, &opts.Worklog, func() error { return jc.editLoop(&opts.GlobalOptions, &opts.Worklog, &opts.Worklog, func() error {
_, err := jc.AddIssueWorklog(issue, opts) _, err := jc.AddIssueWorklog(opts.Issue, opts)
return err return err
}) })
} }
+16 -10
View File
@@ -2,34 +2,40 @@ package jiracli
import kingpin "gopkg.in/alecthomas/kingpin.v2" import kingpin "gopkg.in/alecthomas/kingpin.v2"
type WorklogListOptions struct {
GlobalOptions
Issue string
}
func (jc *JiraCli) CmdWorklogListRegistry() *CommandRegistryEntry { func (jc *JiraCli) CmdWorklogListRegistry() *CommandRegistryEntry {
issue := "" opts := WorklogListOptions{
opts := GlobalOptions{ GlobalOptions: GlobalOptions{
Template: "worklogs", Template: "worklogs",
},
} }
return &CommandRegistryEntry{ return &CommandRegistryEntry{
"Prints the worklog data for given issue", "Prints the worklog data for given issue",
func() error { func() error {
return jc.CmdWorklogList(issue, &opts) return jc.CmdWorklogList(&opts)
}, },
func(cmd *kingpin.CmdClause) error { func(cmd *kingpin.CmdClause) error {
return jc.CmdWorklogListUsage(cmd, &issue, &opts) return jc.CmdWorklogListUsage(cmd, &opts)
}, },
} }
} }
func (jc *JiraCli) CmdWorklogListUsage(cmd *kingpin.CmdClause, issue *string, opts *GlobalOptions) error { func (jc *JiraCli) CmdWorklogListUsage(cmd *kingpin.CmdClause, opts *WorklogListOptions) error {
if err := jc.GlobalUsage(cmd, opts); err != nil { if err := jc.GlobalUsage(cmd, &opts.GlobalOptions); err != nil {
return err return err
} }
jc.TemplateUsage(cmd, opts) jc.TemplateUsage(cmd, &opts.GlobalOptions)
cmd.Arg("ISSUE", "issue id to fetch worklogs").Required().StringVar(issue) cmd.Arg("ISSUE", "issue id to fetch worklogs").Required().StringVar(&opts.Issue)
return nil return nil
} }
// // CmdWorklogList will get worklog data for given issue and sent to the "worklogs" template // // CmdWorklogList will get worklog data for given issue and sent to the "worklogs" template
func (jc *JiraCli) CmdWorklogList(issue string, opts *GlobalOptions) error { func (jc *JiraCli) CmdWorklogList(opts *WorklogListOptions) error {
data, err := jc.GetIssueWorklog(issue) data, err := jc.GetIssueWorklog(opts.Issue)
if err != nil { if err != nil {
return err return err
} }