Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/rohit-gohri/jira-ci-cd-integration
Jira Integation for sending Build/Deploy information. Use with any CI/CD provider (via Docker)
https://github.com/rohit-gohri/jira-ci-cd-integration
actions ci cloud-build cloud-builder continuous-delivery continuous-integration docker drone-ci github-actions gitlab-ci hacktoberfest integration jira jira-api jira-dev jira-plugin
Last synced: 3 months ago
JSON representation
Jira Integation for sending Build/Deploy information. Use with any CI/CD provider (via Docker)
- Host: GitHub
- URL: https://github.com/rohit-gohri/jira-ci-cd-integration
- Owner: rohit-gohri
- License: mit
- Created: 2021-05-11T18:34:02.000Z (almost 4 years ago)
- Default Branch: main
- Last Pushed: 2024-11-04T09:20:09.000Z (4 months ago)
- Last Synced: 2024-11-09T04:04:32.505Z (3 months ago)
- Topics: actions, ci, cloud-build, cloud-builder, continuous-delivery, continuous-integration, docker, drone-ci, github-actions, gitlab-ci, hacktoberfest, integration, jira, jira-api, jira-dev, jira-plugin
- Language: TypeScript
- Homepage: https://rohit.page/blog/projects/jira-ci-cd-integration-for-builds-deploys/?utm_source=github&utm_medium=repo
- Size: 4.28 MB
- Stars: 28
- Watchers: 2
- Forks: 8
- Open Issues: 4
-
Metadata Files:
- Readme: README.md
- License: LICENSE
- Codeowners: CODEOWNERS
Awesome Lists containing this project
README
[data:image/s3,"s3://crabby-images/65916/65916c893546c2338c9949d45a9b2c02ad13b31a" alt="Github Release"](https://github.com/rohit-gohri/jira-ci-cd-integration/releases)
[data:image/s3,"s3://crabby-images/ff1c4/ff1c4c2b4056a7ece20ec1224240ba37c48b6337" alt="Docker Release"](https://hub.docker.com/repository/docker/boringdownload/jira-integration)![]()
# Jira Development Integration
Integrate your CI/CD pipeline's Build and Deployment information into the Jira Development Panel.
data:image/s3,"s3://crabby-images/27cc2/27cc2386510247bcf294340232c72b3a17e792a8" alt="Builds Panel Preview"
> Only supports Jira Cloud. Does not support Jira Server (hosted)
## Prerequisites
### Generate Credentials
Generate new OAuth Credentials and copy
**See:**
data:image/s3,"s3://crabby-images/700ed/700ed3f8807b1692cccd07ccc50d478e5a8a73b7" alt="OAuth Creds Screen"
## Use with Any CI/CD Provider with **Docker**
Supported in providers which support running arbitrary Docker images (like Drone, Gitlab CI).
Docker Images are available from:
- Docker Hub: `boringdownload/jira-integration`
- Github Container Registry: `ghcr.io/rohit-gohri/jira-ci-cd-integration`
- Gitlab Container Registry: `registry.gitlab.com/rohit-gohri/jira-ci-cd-integration`Pick whatever you want and is convenient for you.
Configuration for the Docker image is through env vars. Read more in [options](#options).
### Drone.io
[data:image/s3,"s3://crabby-images/c1b2c/c1b2c47d298cd369af90a8565af74534347d4a5b" alt="Build Status"](https://cloud.drone.io/rohit-gohri/jira-ci-cd-integration)
Add secrets for `JIRA_CLIENT_ID` and `JIRA_CLIENT_SECRET` and then add this to your pipeline:
```yaml
steps:
- name: jira-integration
image: boringdownload/jira-integration:v0
environment:
BUILD_NAME: drone-pipeline # or give any custom name
JIRA_INSTANCE: companyname
JIRA_CLIENT_ID:
from_secret: jira_client_id
JIRA_CLIENT_SECRET:
from_secret: jira_client_secret
```To send deployment information just promote the build and it will send a deployment info.
### Gitlab CI/CD
[data:image/s3,"s3://crabby-images/30766/307663296adad84fd25b6f9e3f60ba51979721a5" alt="pipeline status"](https://gitlab.com/rohit-gohri/jira-ci-cd-integration/-/commits/v0)
[Add a CI/CD Variable to your project](https://docs.gitlab.com/ee/ci/variables/#add-a-cicd-variable-to-a-project) for `JIRA_CLIENT_ID` and `JIRA_CLIENT_SECRET` (remember to mask them) and then add these steps to your pipeline (we use `.post` stage so it runs last)
#### Add to .post stage to send Build Info
```yaml
jira-build-integration-on-success:
stage: .post
when: on_success
image: registry.gitlab.com/rohit-gohri/jira-ci-cd-integration:v0
script: jira-integration
variables:
BUILD_STATE: successful
BUILD_NAME: gitlab-pipeline-name # or give any custom name
JIRA_INSTANCE: companynamejira-build-integration-on-failure:
extends: jira-build-integration-on-success
when: on_failure
variables:
BUILD_STATE: failure
```#### Use with Gitlab Environments to send Release Info
If you provide an environment block it will send a deployment event instead of build event.
```yaml
jira-deploy-integration-on-success:
extends: jira-build-integration-on-success
environment:
name: productionjira-deploy-integration-on-failure:
extends: jira-build-integration-on-failure
environment:
name: production
```## Usage With Github Actions
[data:image/s3,"s3://crabby-images/4dd6a/4dd6adfa812c2da2db6564e07c72fea5252684d4" alt="test-release workflow"](https://github.com/rohit-gohri/jira-ci-cd-integration/actions/workflows/test-release.yml)
### Add OAuth Creds as secrets to Github
**See:**
- Add Client ID as `JIRA_CLIENT_ID`
- Add Client Secret as `JIRA_CLIENT_SECRET`data:image/s3,"s3://crabby-images/c48b2/c48b27ce30ad538db5760f9ded8aa5d58d53b423" alt="Github Secrets"
### Update Github Workflow
#### Use in Builds Pipeline
```yaml
- name: Jira Integration
if: ${{ always() }}
uses: rohit-gohri/jira-ci-cd-integration@v0
with:
state: ${{ job.status }}
jira_instance: companyname # Subdomain for Jira Cloud
client_id: ${{ secrets.JIRA_CLIENT_ID }}
client_secret: ${{ secrets.JIRA_CLIENT_SECRET }}
```#### Use in Deployment Pipeline
Just provide an evironment to send a deployment event instead of a build event.
```yaml
- name: Jira Integration
if: ${{ always() }}
uses: rohit-gohri/jira-ci-cd-integration@v0
with:
state: ${{ job.status }}
environment: staging
issue: JCI-3, JCI-6 # Comma separated list of issues being deployed/released. You are expected to generate this yourself in a previous step for releases
jira_instance: companyname # Subdomain for Jira Cloud
client_id: ${{ secrets.JIRA_CLIENT_ID }}
client_secret: ${{ secrets.JIRA_CLIENT_SECRET }}
```## Options
Provide these options via environment variables, or directly in case of Github Actions.
### Inputs
#### jira_instance: JIRA_INSTANCE
Sub Domain of Jira Cloud Instance. This part of the url: `https://.atlassian.net`
#### client_id: JIRA_CLIENT_ID
ClientID of OAuth Creds
#### client_secret: JIRA_CLIENT_SECRET
Client Secret of OAuth Creds
#### event_type: JIRA_EVENT_TYPE (optional)
"build" or "deployment", (default is "build"). You can override this manually or just provide an `evironment` to send a deployment event instead of a build event.
#### state: BUILD_STATE (optional)
"successful"/"success", "failed", or "canceled" (default is "successful").
We try to detect this via [env-ci](https://github.com/semantic-release/env-ci) for most CI/CD providers, but you can manually override it if you wish to do so.
#### issue: JIRA_ISSUES (optional)
Will be parsed from branch name automatically if available. Or you can provide it according to your own logic. Can be multiple comma separated issues.
### Pipeline Info
We try to detect this via [env-ci](https://github.com/semantic-release/env-ci) for most CI/CD providers, but you can manually override it if you wish to do so.
#### Commit Message: COMMIT_MESSAGE
If the tool can't detect your commit message you may provide a value directly. If you have the jira id in the commit message, it will be parsed.
#### Pipeline Name: BUILD_NAME
A custom name for your pipeline
#### Environment Name: BUILD_ENVIROMENT (optional)
> NOTE: Only for Deployment events
A name for your environment. The tool tries to automatically infer this from your CI/CD provider.
#### Environment Type: BUILD_ENVIROMENT_TYPE (optional)
> NOTE: Automatically inferred from environment name
The tool tries to automatically parse this from environment but if you want to override then provide one of (`unmapped`, `development`, `testing`, `staging`, `production`)
## Contributing
Feel free to open issues/Pull Requests to add support for some CI provider that doesn't have support yet.
## License
[MIT License. Copyright (c) 2022 Rohit Gohri](./LICENSE)