jira-cli/api/client.go

157 lines
3.8 KiB
Go

package api
import (
"time"
"github.com/spf13/viper"
"github.com/ankitpokhrel/jira-cli/pkg/jira"
)
const clientTimeout = 15 * time.Second
var jiraClient *jira.Client
// Client initializes and returns jira client.
func Client(config jira.Config) *jira.Client {
if jiraClient != nil {
return jiraClient
}
if config.Server == "" {
config.Server = viper.GetString("server")
}
if config.Login == "" {
config.Login = viper.GetString("login")
}
if config.APIToken == "" {
config.APIToken = viper.GetString("api_token")
}
jiraClient = jira.NewClient(config, jira.WithTimeout(clientTimeout))
return jiraClient
}
// ProxyCreate uses either a v2 or v3 version of the Jira POST /issue
// endpoint to create an issue based on configured installation type.
// Defaults to v3 if installation type is not defined in the config.
func ProxyCreate(c *jira.Client, cr *jira.CreateRequest) (*jira.CreateResponse, error) {
var (
resp *jira.CreateResponse
err error
)
it := viper.GetString("installation")
if it == jira.InstallationTypeLocal {
resp, err = c.CreateV2(cr)
} else {
resp, err = c.Create(cr)
}
return resp, err
}
// ProxyGetIssue uses either a v2 or v3 version of the Jira GET /issue/{key}
// endpoint to fetch the issue details based on configured installation type.
// Defaults to v3 if installation type is not defined in the config.
func ProxyGetIssue(c *jira.Client, key string) (*jira.Issue, error) {
var (
issue *jira.Issue
err error
)
it := viper.GetString("installation")
if it == jira.InstallationTypeLocal {
issue, err = c.GetIssueV2(key)
} else {
issue, err = c.GetIssue(key)
}
return issue, err
}
// ProxySearch uses either a v2 or v3 version of the Jira GET /search endpoint
// to search for the relevant issues based on configured installation type.
// Defaults to v3 if installation type is not defined in the config.
func ProxySearch(c *jira.Client, jql string, limit uint) (*jira.SearchResult, error) {
var (
issues *jira.SearchResult
err error
)
it := viper.GetString("installation")
if it == jira.InstallationTypeLocal {
issues, err = c.SearchV2(jql, limit)
} else {
issues, err = c.Search(jql, limit)
}
return issues, err
}
// ProxyAssignIssue uses either a v2 or v3 version of the PUT /issue/{key}/assignee
// endpoint to assign an issue to the user.
// Defaults to v3 if installation type is not defined in the config.
func ProxyAssignIssue(c *jira.Client, key string, user *jira.User, def string) error {
it := viper.GetString("installation")
assignee := def
if user != nil {
switch it {
case jira.InstallationTypeLocal:
assignee = user.Name
default:
assignee = user.AccountID
}
}
if it == jira.InstallationTypeLocal {
return c.AssignIssueV2(key, assignee)
}
return c.AssignIssue(key, assignee)
}
// ProxyUserSearch uses either v2 or v3 version of the GET /user/assignable/search
// endpoint to search for the users assignable to the given issue.
// Defaults to v3 if installation type is not defined in the config.
func ProxyUserSearch(c *jira.Client, opts *jira.UserSearchOptions) ([]*jira.User, error) {
var (
users []*jira.User
err error
)
it := viper.GetString("installation")
if it == jira.InstallationTypeLocal {
users, err = c.UserSearchV2(opts)
} else {
users, err = c.UserSearch(opts)
}
return users, err
}
// ProxyTransitions uses either v2 or v3 version of the GET /issue/{key}/transitions
// endpoint to fetch valid transitions for an issue.
// Defaults to v3 if installation type is not defined in the config.
func ProxyTransitions(c *jira.Client, key string) ([]*jira.Transition, error) {
var (
transitions []*jira.Transition
err error
)
it := viper.GetString("installation")
if it == jira.InstallationTypeLocal {
transitions, err = c.TransitionsV2(key)
} else {
transitions, err = c.Transitions(key)
}
return transitions, err
}