1
0
mirror of https://github.com/interviewstreet/go-jira.git synced 2025-01-05 22:53:53 +02:00
Go to file
2021-02-19 08:34:23 +11:00
.github Raise go versions in testing workflow (#349) 2021-02-09 11:13:37 +01:00
examples Adding example for Pagination 2021-02-19 08:34:23 +11:00
img little bigger 2018-04-28 21:32:27 +10:00
mocks fix(product): Make product naming consistent, rename JIRA to Jira (#286) 2020-05-14 17:18:31 +02:00
.gitignore Add dep as a dependency manager 2018-02-17 11:14:47 -08:00
.travis.yml Remove 1.12 from travis builds 2020-11-30 00:59:29 +00:00
authentication_test.go style: Fix staticcheck (static analysis) errors for this library (#283) 2020-05-02 23:08:01 +02:00
authentication.go fix(product): Make product naming consistent, rename JIRA to Jira (#286) 2020-05-14 17:18:31 +02:00
board_test.go style: Fix staticcheck (static analysis) errors for this library (#283) 2020-05-02 23:08:01 +02:00
board.go fix(product): Make product naming consistent, rename JIRA to Jira (#286) 2020-05-14 17:18:31 +02:00
CHANGELOG.md chore(release): 1.13.0 2020-10-25 02:54:38 +00:00
component_test.go fix(product): Make product naming consistent, rename JIRA to Jira (#286) 2020-05-14 17:18:31 +02:00
component.go fix(product): Make product naming consistent, rename JIRA to Jira (#286) 2020-05-14 17:18:31 +02:00
error_test.go style: Fix staticcheck (static analysis) errors for this library (#283) 2020-05-02 23:08:01 +02:00
error.go fix(product): Make product naming consistent, rename JIRA to Jira (#286) 2020-05-14 17:18:31 +02:00
field_test.go doc: Fix comments 2018-06-25 17:52:57 +02:00
field.go Add Items and Custom to FieldSchema (#332) 2021-01-09 10:02:16 +01:00
filter_test.go style: Fix staticcheck (static analysis) errors for this library (#283) 2020-05-02 23:08:01 +02:00
filter.go fix(product): Make product naming consistent, rename JIRA to Jira (#286) 2020-05-14 17:18:31 +02:00
go.mod chore(deps): bump github.com/pkg/errors from 0.8.0 to 0.9.1 (#345) 2021-02-08 18:59:12 +01:00
go.sum chore(deps): bump github.com/pkg/errors from 0.8.0 to 0.9.1 (#345) 2021-02-08 18:59:12 +01:00
group_test.go move agile issue api to sprint, change name of GetByOption to GetWithOptions 2018-04-03 14:29:29 +09:00
group.go fix(product): Make product naming consistent, rename JIRA to Jira (#286) 2020-05-14 17:18:31 +02:00
issue_test.go Feature: Implement delete issue link api (#341) 2021-02-06 16:09:14 +01:00
issue.go Added property "StartedAfter" to GetWorklogsQueryOptions struct accor… (#344) 2021-02-09 10:17:23 +01:00
issuelinktype_test.go feat: Implement issue link type DELETE 2019-12-12 14:57:35 -08:00
issuelinktype.go fix(product): Make product naming consistent, rename JIRA to Jira (#286) 2020-05-14 17:18:31 +02:00
jira_test.go fix(product): Make product naming consistent, rename JIRA to Jira (#286) 2020-05-14 17:18:31 +02:00
jira.go Feature: Add support for Jira ServiceDesk and its organizations 2021-02-08 03:53:28 +03:30
LICENSE Initial commit 2015-08-20 17:02:46 +02:00
Makefile feat: Extend Makefile for more source code quality targets 2020-04-29 10:29:49 -07:00
metaissue_test.go feat(project): Add GitHub Actions testing workflow (#289) 2020-05-03 15:45:09 +02:00
metaissue.go feat(context): Add support for context package 2020-05-03 15:38:32 +02:00
organization_test.go fix some posible nil reference 2021-02-08 04:02:36 +03:30
organization.go Feature: Add support for Jira ServiceDesk and its organizations 2021-02-08 03:53:28 +03:30
permissionscheme.go fix(product): Make product naming consistent, rename JIRA to Jira (#286) 2020-05-14 17:18:31 +02:00
permissionschemes_test.go style: Fix staticcheck (static analysis) errors for this library (#283) 2020-05-02 23:08:01 +02:00
priority_test.go test: Add unit test for priority api 2018-06-12 10:38:13 +02:00
priority.go fix(product): Make product naming consistent, rename JIRA to Jira (#286) 2020-05-14 17:18:31 +02:00
project_test.go style: Fix staticcheck (static analysis) errors for this library (#283) 2020-05-02 23:08:01 +02:00
project.go fix(product): Make product naming consistent, rename JIRA to Jira (#286) 2020-05-14 17:18:31 +02:00
README.md Adding example for Pagination 2021-02-19 08:34:23 +11:00
request_context.go feat(context): Add support for context package 2020-05-03 15:38:32 +02:00
request_legacy.go feat(context): Add support for context package 2020-05-03 15:38:32 +02:00
resolution_test.go feat: Add ResolutionService to retrieve resolutions 2018-06-25 17:48:53 +02:00
resolution.go fix(product): Make product naming consistent, rename JIRA to Jira (#286) 2020-05-14 17:18:31 +02:00
role_test.go style: Fix staticcheck (static analysis) errors for this library (#283) 2020-05-02 23:08:01 +02:00
role.go fix(product): Make product naming consistent, rename JIRA to Jira (#286) 2020-05-14 17:18:31 +02:00
servicedesk_test.go fix some posible nil reference 2021-02-08 04:02:36 +03:30
servicedesk.go Feature: Add support for Jira ServiceDesk and its organizations 2021-02-08 03:53:28 +03:30
sprint_test.go style: Fix staticcheck (static analysis) errors for this library (#283) 2020-05-02 23:08:01 +02:00
sprint.go fix(product): Make product naming consistent, rename JIRA to Jira (#286) 2020-05-14 17:18:31 +02:00
status_test.go feat: Add GetAllStatuses 2019-08-19 07:51:49 -07:00
status.go fix(product): Make product naming consistent, rename JIRA to Jira (#286) 2020-05-14 17:18:31 +02:00
statuscategory_test.go feat: Add StatusCategory GetList 2018-06-26 09:41:46 +02:00
statuscategory.go fix(product): Make product naming consistent, rename JIRA to Jira (#286) 2020-05-14 17:18:31 +02:00
types.go Fixed bool type for release version 2021-01-25 20:16:14 +03:00
user_test.go fix: removing the use of username field in searching for users (#297) 2020-05-22 09:38:17 +02:00
user.go fix: removing the use of username field in searching for users (#297) 2020-05-22 09:38:17 +02:00
version_test.go Fixed bool type for release version 2021-01-25 20:16:14 +03:00
version.go Fixed bool type for release version 2021-01-25 20:16:14 +03:00

go-jira

GoDoc Build Status Go Report Card

Go client library for Atlassian Jira.

Go client library for Atlassian Jira

Features

  • Authentication (HTTP Basic, OAuth, Session Cookie)
  • Create and retrieve issues
  • Create and retrieve issue transitions (status updates)
  • Call every API endpoint of the Jira, even if it is not directly implemented in this library

This package is not Jira API complete (yet), but you can call every API endpoint you want. See Call a not implemented API endpoint how to do this. For all possible API endpoints of Jira have a look at latest Jira REST API documentation.

Requirements

  • Go >= 1.14
  • Jira v6.3.4 & v7.1.2.

Note that we also run our tests against 1.13, though only the last two versions of Go are officially supported.

Installation

It is go gettable

go get github.com/andygrunwald/go-jira

For stable versions you can use one of our tags with gopkg.in. E.g.

package main

import (
	jira "gopkg.in/andygrunwald/go-jira.v1"
)
...

(optional) to run unit / example tests:

cd $GOPATH/src/github.com/andygrunwald/go-jira
go test -v ./...

API

Please have a look at the GoDoc documentation for a detailed API description.

The latest Jira REST API documentation was the base document for this package.

Examples

Further a few examples how the API can be used. A few more examples are available in the GoDoc examples section.

Get a single issue

Lets retrieve MESOS-3325 from the Apache Mesos project.

package main

import (
	"fmt"
	"github.com/andygrunwald/go-jira"
)

func main() {
	jiraClient, _ := jira.NewClient(nil, "https://issues.apache.org/jira/")
	issue, _, _ := jiraClient.Issue.Get("MESOS-3325", nil)

	fmt.Printf("%s: %+v\n", issue.Key, issue.Fields.Summary)
	fmt.Printf("Type: %s\n", issue.Fields.Type.Name)
	fmt.Printf("Priority: %s\n", issue.Fields.Priority.Name)

	// MESOS-3325: Running mesos-slave@0.23 in a container causes slave to be lost after a restart
	// Type: Bug
	// Priority: Critical
}

Authentication

The go-jira library does not handle most authentication directly. Instead, authentication should be handled within an http.Client. That client can then be passed into the NewClient function when creating a jira client.

For convenience, capability for basic and cookie-based authentication is included in the main library.

Token (Jira on Atlassian Cloud)

Token-based authentication uses the basic authentication scheme, with a user-generated API token in place of a user's password. You can generate a token for your user here. Additional information about Atlassian Cloud API tokens can be found here.

A more thorough, runnable example is provided in the examples directory.

func main() {
	tp := jira.BasicAuthTransport{
		Username: "username",
		Password: "token",
	}

	client, err := jira.NewClient(tp.Client(), "https://my.jira.com")

	u, _, err := client.User.Get("some_user")

	fmt.Printf("\nEmail: %v\nSuccess!\n", u.EmailAddress)
}

Basic (self-hosted Jira)

Password-based API authentication works for self-hosted Jira only, and has been deprecated for users of Atlassian Cloud.

The above token authentication example may be used, substituting a user's password for a generated token.

Authenticate with OAuth

If you want to connect via OAuth to your Jira Cloud instance checkout the example of using OAuth authentication with Jira in Go by @Lupus.

For more details have a look at the issue #56.

Create an issue

Example how to create an issue.

package main

import (
	"fmt"
	"github.com/andygrunwald/go-jira"
)

func main() {
	base := "https://my.jira.com"
	tp := jira.BasicAuthTransport{
		Username: "username",
		Password: "token",
	}

	jiraClient, err := jira.NewClient(tp.Client(), base)
	if err != nil {
		panic(err)
	}

	i := jira.Issue{
		Fields: &jira.IssueFields{
			Assignee: &jira.User{
				Name: "myuser",
			},
			Reporter: &jira.User{
				Name: "youruser",
			},
			Description: "Test Issue",
			Type: jira.IssueType{
				Name: "Bug",
			},
			Project: jira.Project{
				Key: "PROJ1",
			},
			Summary: "Just a demo issue",
		},
	}
	issue, _, err := jiraClient.Issue.Create(&i)
	if err != nil {
		panic(err)
	}

	fmt.Printf("%s: %+v\n", issue.Key, issue.Fields.Summary)
}

Change an issue status

This is how one can change an issue status. In this example, we change the issue from "To Do" to "In Progress."

package main

import (
	"fmt"
	"github.com/andygrunwald/go-jira"
)

func main() {
	base := "https://my.jira.com"
	tp := jira.BasicAuthTransport{
		Username: "username",
		Password: "token",
	}

	jiraClient, err := jira.NewClient(tp.Client(), base)
	if err != nil {
		panic(err)
	}

	issue, _, _ := jiraClient.Issue.Get("FART-1", nil)
	currentStatus := issue.Fields.Status.Name
	fmt.Printf("Current status: %s\n", currentStatus)

	var transitionID string
	possibleTransitions, _, _ := jiraClient.Issue.GetTransitions("FART-1")
	for _, v := range possibleTransitions {
		if v.Name == "In Progress" {
			transitionID = v.ID
			break
		}
	}

	jiraClient.Issue.DoTransition("FART-1", transitionID)
	issue, _, _ = jiraClient.Issue.Get(testIssueID, nil)
	fmt.Printf("Status after transition: %+v\n", issue.Fields.Status.Name)
}

Get all the issues for JQL with Pagination

Jira API has limit on maxResults it can return. YOu may have a usecase where you need to get all issues for given JQL. This example shows reference implementation of GetAllIssues function which does pagination on Jira API to get all the issues for given JQL

package main

import (
	"fmt"

	jira "github.com/andygrunwald/go-jira"
)

//GetAllIssues takes a jira client and returns all issues for given JQL
func GetAllIssues(client *jira.Client, searchString string) ([]jira.Issue, error) {
	last := 0
	var issues []jira.Issue = nil
	for {
		opt := &jira.SearchOptions{
			MaxResults: 100,
			StartAt:    last,
		}

		chunk, resp, err := client.Issue.Search(searchString, opt)
		if err != nil {
			return nil, err
		}

		total := resp.Total
		if issues == nil {
			issues = make([]jira.Issue, 0, total)
		}
		issues = append(issues, chunk...)
		last = resp.StartAt + len(chunk)
		if last >= total {
			break
		}
	}
	return issues, nil
}

func main() {
	jiraClient, _ := jira.NewClient(nil, "https://issues.apache.org/jira/")

	// Jira API has limitation as to maxResults it can return at one time.
	// You may have usecase where you need to get all the issues according to jql
	// This is where this example comes in.
	jql := "project = Mesos and type = Bug and Status NOT IN (Resolved)"
	fmt.Printf("Usecase: Running a JQL query '%s'\n", jql)

	issues, err := GetAllIssues(jiraClient, jql)
	if err != nil {
		panic(err)
	}
	fmt.Println(issues)

}


Call a not implemented API endpoint

Not all API endpoints of the Jira API are implemented into go-jira. But you can call them anyway: Lets get all public projects of Atlassian`s Jira instance.

package main

import (
	"fmt"
	"github.com/andygrunwald/go-jira"
)

func main() {
	base := "https://my.jira.com"
	tp := jira.BasicAuthTransport{
		Username: "username",
		Password: "token",
	}

	jiraClient, err := jira.NewClient(tp.Client(), base)
	req, _ := jiraClient.NewRequest("GET", "rest/api/2/project", nil)

	projects := new([]jira.Project)
	_, err = jiraClient.Do(req, projects)
	if err != nil {
		panic(err)
	}

	for _, project := range *projects {
		fmt.Printf("%s: %s\n", project.Key, project.Name)
	}

	// ...
	// BAM: Bamboo
	// BAMJ: Bamboo Jira Plugin
	// CLOV: Clover
	// CONF: Confluence
	// ...
}

Implementations

Code structure

The code structure of this package was inspired by google/go-github.

There is one main part (the client). Based on this main client the other endpoints, like Issues or Authentication are extracted in services. E.g. IssueService or AuthenticationService. These services own a responsibility of the single endpoints / usecases of Jira.

Contribution

We ❤️ PR's

Contribution, in any kind of way, is highly welcome! It doesn't matter if you are not able to write code. Creating issues or holding talks and help other people to use go-jira is contribution, too! A few examples:

  • Correct typos in the README / documentation
  • Reporting bugs
  • Implement a new feature or endpoint
  • Sharing the love of go-jira and help people to get use to it

If you are new to pull requests, checkout Collaborating on projects using issues and pull requests / Creating a pull request.

Dependency management

go-jira uses go modules for dependency management. After cloning the repo, it's easy to make sure you have the correct dependencies by running go mod tidy.

For adding new dependencies, updating dependencies, and other operations, the Daily workflow is a good place to start.

Sandbox environment for testing

Jira offers sandbox test environments at http://go.atlassian.com/cloud-dev.

You can read more about them at https://developer.atlassian.com/blog/2016/04/cloud-ecosystem-dev-env/.

Releasing

Install standard-version

npm i -g standard-version
standard-version
git push --tags

Manually copy/paste text from changelog (for this new version) into the release on Github.com. E.g.

https://github.com/andygrunwald/go-jira/releases/edit/v1.11.0

License

This project is released under the terms of the MIT license.