Hi there! We're thrilled that you'd like to contribute to this project. Your help is essential for keeping it great.
Contributions to this product are released to the public under the project's open source license.
Please note that this project is released with a Contributor Code of Conduct. By participating in this project you agree to abide by its terms.
This app is written in ES6 JavaScript and runs on Node.js. After cloning the repository, install the dependencies by running:
$ script/bootstrap
This will install node
and postgres
, which are required to run the app. You will need to start up the postgres instance, and then run:
$ script/db_create
This set up the databases and keep their schemas up to date. You can verify that your code is setup correctly by running:
$ npm test
The next step for running the app locally is to configure a GitHub App. For that you will likely need to use a tool like ngrok to expose a URL publicly (referred to as DOMAIN
in these docs) which will tunnel traffic back to your computer.
Follow the Probot docs for configuring up a GitHub App skipping the addition of WEBHOOK_PROXY_URL
to your .env
file, the only other difference being these values for the GitHub App settings:
- User authorization callback URL:
https://DOMAIN/github/callback
- Setup URL:
https://DOMAIN/github/configuration
- Webhook URL:
https://DOMAIN/github/events
Your new GitHub app will need the following permissions:
- Repository contents: Read & write
- Issues: Read & write
- Repository metadata: Read-only
- Pull requests: Read & write
It will also need the following event subscriptions:
- Commit comment
- Create
- Delete
- Issue comment
- Issues
- Push
- Pull request
- Pull request review
Once you've setup your app, add your GITHUB_CLIENT_ID
and GITHUB_CLIENT_SECRET
from your GitHub app page to the .env
file. You will also need add a STORAGE_SECRET
to your .env
file (running openssl rand -hex 32
should provide a suitable secret).
Finally, set the APP_URL
env variable to https://DOMAIN
.
When you are developing you will prefer to run the app and automatically restart it when you do changes to the source code. In that case you should use:
$ script/server
For production you should just use npm run start
.
- Create a new free developer instance on Jira Cloud.
- From the left sidebar in Jira, select Settings -> Apps -> Manage apps. (If you're using an older version of Jira, you won't have a left sidebar. Instead, click the Gear Icon in the top-right corner and select Settings. From there, select Manage add-ons from the left sidebar.)
- Verify the filter is set to
User-installed
, and select *Settings beneath the User-installed add-ons table. - On the Settings pop-up, add Enable development mode and click Apply.
- From the right header, select Upload add-on and enter
https://DOMAIN/jira/atlassian-connect.json
. - Click Upload.
- That's it! You're done. 🎉
- Fork and clone the repository
- Configure and install the dependencies:
npm install
- Make sure the tests pass on your machine:
npm test
, note: these tests also apply the linter, so no need to lint seperately - Create a new branch:
git checkout -b my-branch-name
- Make your change, add tests, and make sure the tests still pass
- Push to your fork and submit a pull request
- Pat your self on the back and wait for your pull request to be reviewed and merged.
Here are a few things you can do that will increase the likelihood of your pull request being accepted:
- Follow the style guide which is using standard. Any linting errors should be shown when running
npm test
- Write and update tests.
- Keep your change as focused as possible. If there are multiple changes you would like to make that are not dependent upon each other, consider submitting them as separate pull requests.
- Write a good commit message.
Work in Progress pull request are also welcome to get feedback early on, or if there is something blocked you.