Add get-jira-ticket command
This commit is contained in:
parent
5d727b8995
commit
0ae0c6ffdf
4 changed files with 72 additions and 13 deletions
|
@ -19,6 +19,7 @@ func StandaloneCmd() *cobra.Command {
|
|||
|
||||
cmd.AddCommand(
|
||||
CreateJiraTicketStandaloneCmd(),
|
||||
GetJiraTicketStandaloneCmd(),
|
||||
)
|
||||
|
||||
return cmd
|
||||
|
@ -49,6 +50,22 @@ func CreateJiraTicketStandaloneCmd() *cobra.Command {
|
|||
return cmd
|
||||
}
|
||||
|
||||
func GetJiraTicketStandaloneCmd() *cobra.Command {
|
||||
cmd := &cobra.Command{
|
||||
Use: "get-jira-ticket",
|
||||
Short: "Gets the ticket from jira",
|
||||
Args: cobra.ExactArgs(1),
|
||||
Run: getJiraTicketStandaloneCmdF,
|
||||
}
|
||||
|
||||
cmd.Flags().String("username", "", "the jira username")
|
||||
_ = cmd.MarkFlagRequired("username")
|
||||
cmd.Flags().String("token", "", "the jira token")
|
||||
_ = cmd.MarkFlagRequired("token")
|
||||
|
||||
return cmd
|
||||
}
|
||||
|
||||
func getVarMap(vars []string) (map[string]string, error) {
|
||||
varMap := map[string]string{}
|
||||
for _, v := range vars {
|
||||
|
@ -99,7 +116,7 @@ func createJiraTicketStandaloneCmdF(cmd *cobra.Command, _ []string) error {
|
|||
|
||||
jiraClient := jira.NewClient(username, token)
|
||||
|
||||
ticketKey, err := jiraClient.CreateTicket(epicId, team, summary, description)
|
||||
ticketKey, err := jiraClient.CreateIssue(epicId, team, summary, description)
|
||||
if err != nil {
|
||||
ErrorAndExit(cmd, err)
|
||||
}
|
||||
|
@ -107,3 +124,17 @@ func createJiraTicketStandaloneCmdF(cmd *cobra.Command, _ []string) error {
|
|||
cmd.Printf("Ticket %s successfully created in JIRA", ticketKey)
|
||||
return nil
|
||||
}
|
||||
|
||||
func getJiraTicketStandaloneCmdF(cmd *cobra.Command, args []string) {
|
||||
username, _ := cmd.Flags().GetString("username")
|
||||
token, _ := cmd.Flags().GetString("token")
|
||||
|
||||
jiraClient := jira.NewClient(username, token)
|
||||
|
||||
issue, err := jiraClient.GetIssue(args[0])
|
||||
if err != nil {
|
||||
ErrorAndExit(cmd, err)
|
||||
}
|
||||
|
||||
fmt.Printf("Key: %s\nStatus: %s\n", issue.Key, issue.Fields.Status.Name)
|
||||
}
|
||||
|
|
|
@ -7,6 +7,6 @@ import (
|
|||
)
|
||||
|
||||
func ErrorAndExit(cmd *cobra.Command, err error) {
|
||||
cmd.PrintErrln(err)
|
||||
cmd.PrintErrln("ERROR: " + err.Error())
|
||||
os.Exit(1)
|
||||
}
|
||||
|
|
|
@ -6,7 +6,7 @@ import (
|
|||
)
|
||||
|
||||
func Do(method, username, token, url string, body []byte) (*http.Response, error) {
|
||||
req, err := http.NewRequest("POST", url, bytes.NewBuffer(body))
|
||||
req, err := http.NewRequest(method, url, bytes.NewBuffer(body))
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
|
|
48
jira/jira.go
48
jira/jira.go
|
@ -2,7 +2,7 @@ package jira
|
|||
|
||||
import (
|
||||
"encoding/json"
|
||||
"io/ioutil"
|
||||
"io"
|
||||
|
||||
"git.ctrlz.es/mgdelacroix/campaigner/http"
|
||||
)
|
||||
|
@ -13,19 +13,37 @@ type JiraClient struct {
|
|||
Url string
|
||||
}
|
||||
|
||||
type JiraIssueFieldsStatus struct {
|
||||
Name string `json:"name"`
|
||||
}
|
||||
|
||||
type JiraIssueFields struct {
|
||||
Status JiraIssueFieldsStatus `json:"status"`
|
||||
}
|
||||
|
||||
type JiraIssue struct {
|
||||
Key string `json:"key"`
|
||||
Fields JiraIssueFields `json:"fields"`
|
||||
}
|
||||
|
||||
func IssueFromJson(body io.Reader) (*JiraIssue, error) {
|
||||
var issue JiraIssue
|
||||
if err := json.NewDecoder(body).Decode(&issue); err != nil {
|
||||
return nil, err
|
||||
}
|
||||
|
||||
return &issue, nil
|
||||
}
|
||||
|
||||
func NewClient(username, token string) *JiraClient {
|
||||
return &JiraClient{
|
||||
Username: username,
|
||||
Token: token,
|
||||
Url: "https://mattermost.atlassian.net/rest/api/2",
|
||||
Url: "https://mattermost.atlassian.net/rest/api/2/",
|
||||
}
|
||||
}
|
||||
|
||||
func (c *JiraClient) CreateTicket(epicId, team, summary, description string) (string, error) {
|
||||
func (c *JiraClient) CreateIssue(epicId, team, summary, description string) (string, error) {
|
||||
data := map[string]interface{}{
|
||||
"fields": map[string]interface{}{
|
||||
"project": map[string]interface{}{"key": "MM"},
|
||||
|
@ -42,21 +60,31 @@ func (c *JiraClient) CreateTicket(epicId, team, summary, description string) (st
|
|||
return "", err
|
||||
}
|
||||
|
||||
res, err := http.DoPost(c.Username, c.Token, c.Url+"/issue/", body)
|
||||
res, err := http.DoPost(c.Username, c.Token, c.Url+"issue/", body)
|
||||
if err != nil {
|
||||
return "", err
|
||||
}
|
||||
defer res.Body.Close()
|
||||
|
||||
respBody, err := ioutil.ReadAll(res.Body)
|
||||
issue, err := IssueFromJson(res.Body)
|
||||
if err != nil {
|
||||
return "", err
|
||||
}
|
||||
|
||||
var issue JiraIssue
|
||||
if err := json.Unmarshal(respBody, &issue); err != nil {
|
||||
return "", err
|
||||
}
|
||||
|
||||
return issue.Key, nil
|
||||
}
|
||||
|
||||
func (c *JiraClient) GetIssue(issueNo string) (*JiraIssue, error) {
|
||||
res, err := http.DoGet(c.Username, c.Token, c.Url+"issue/"+issueNo)
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
defer res.Body.Close()
|
||||
|
||||
issue, err := IssueFromJson(res.Body)
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
|
||||
return issue, nil
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue