Add GitHub signup oracle documentation
This commit is contained in:
parent
afa67e5ac7
commit
101e35622a
30
README.md
30
README.md
@ -10,8 +10,27 @@ contributions.
|
||||
|
||||
## Setup
|
||||
|
||||
## Ethereum Wallet
|
||||
|
||||
You will need an Ethereum wallet for your bot, so it can interact with the
|
||||
Ethereum smart contracts. `npm run create-wallet` will do the job for you.
|
||||
That wallet must be funded with enough ETH to interact with the contracts.
|
||||
|
||||
### Contract permissions
|
||||
|
||||
The bot wallet needs the following aragon contract permissions to interact
|
||||
with [kredits-contracts](https://github.com/67P/kredits-contracts)
|
||||
|
||||
1. `ADD_CONTRIBUTION_ROLE` on the Contribution contract
|
||||
2. `MANAGE_CONTRIBUTORS_ROLE` on the Contributor contract (used for registering contributors)
|
||||
|
||||
These permissions can be configured using the `aragon-cli` (see [kredits-contracts](https://github.com/67P/kredits-contracts).
|
||||
|
||||
$ aragon dao acl grant [your DAO address] [your contribution app address] ADD_CONTRIBUTION_ROLE [bot wallet address]
|
||||
$ aragon dao acl grant [your DAO address] [your contributor app address] MANAGE_CONTRIBUTORS_ROLE [bot wallet address]
|
||||
|
||||
To get the contribution and contributor app address use `aragon dao apps`
|
||||
|
||||
|
||||
## Configuration
|
||||
|
||||
@ -26,7 +45,9 @@ As usual in Hubot, you can add all config as environment variables.
|
||||
| `KREDITS_PROVIDER_URL` | Ethereum JSON-RPC URL (default: `http://localhost:7545`) |
|
||||
| `KREDITS_WEB_URL` | URL of the Kredits Web app (default: `https://kredits.kosmos.org`) |
|
||||
| `KREDITS_DAO_ADDRESS` | DAO Kernel address |
|
||||
| `SESSION_SECRET` | Secret used to sign the Session ID |
|
||||
| `KREDITS_SESSION_SECRET` | Secret used by [grant](https://www.npmjs.com/package/grant) to sign the Session ID |
|
||||
| `KREDITS_GRANT_HOST` | Host used by [grant](https://www.npmjs.com/package/grant) to generate OAuth redirect URLs (default: `localhost:8888`) |
|
||||
| `KREDITS_GRANT_PROTOCOL` | Protocol (http or https) used by [grant](https://www.npmjs.com/package/grant") to generate the OAuth redirect URLs (default: "http") |
|
||||
|
||||
## Integrations
|
||||
|
||||
@ -37,6 +58,11 @@ which carry a kredits label: `kredits-1`, `kredits-2`, `kredits-3` for small,
|
||||
medium and large contributions. If there are multiple people assigned, it will
|
||||
issue contribution tokens for all of them.
|
||||
|
||||
If `KREDITS_GITHUB_KEY` and `KREDITS_GITHUB_SECRET` are set it will also expose
|
||||
OAuth endpoints to authenticate new contributors and register new profiles on
|
||||
the smart contract. For this a [GitHub app](https://developer.github.com/apps/about-apps/)
|
||||
is required and the [OAuth grant config](#Configuration) must set.
|
||||
|
||||
#### Setup
|
||||
|
||||
Point a GitHub organization webhook to the following URL:
|
||||
@ -48,6 +74,8 @@ Point a GitHub organization webhook to the following URL:
|
||||
| Key | Description |
|
||||
| --- | --- |
|
||||
| `KREDITS_GITHUB_REPO_BLACKLIST` | Repos which you do not want to issue kredits for. Format: `orgname/reponame`, e.g. `67P/test-one-two` |
|
||||
| `KREDITS_GITHUB_KEY` | Key of the [GitHub app](https://developer.github.com/apps/building-github-apps/creating-a-github-app/) used to authenticate new collaborators |
|
||||
| `KREDITS_GITHUB_SECRET` | Secret of the [GitHub app]((https://developer.github.com/apps/building-github-apps/creating-a-github-app/) used to authenticate new collaborators |
|
||||
|
||||
### Gitea
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user