2018-01-17 03:13:06 -06:00
# Status Open Bounty
2018-03-11 14:00:07 +07:00
[![Riot Chat Badge ](https://img.shields.io/badge/join%20%23openbounty-riot-green.svg )](https://chat.status.im/#/room/#openbounty:status .im)
2016-08-21 00:36:09 +03:00
2018-04-26 11:55:34 -07:00
Allows you to set bounties for GitHub issues, paid out in Ether or any ERC-20 token.
2017-01-23 08:19:16 +02:00
More information:
2018-01-17 03:13:06 -06:00
https://wiki.status.im/Status_Open_Bounty
2017-01-23 08:19:16 +02:00
2018-01-17 03:13:06 -06:00
Live production version:
2017-10-30 19:20:08 +02:00
https://openbounty.status.im
2017-08-19 12:11:53 +03:00
The `master` branch is automatically deployed here.
2017-09-21 08:48:57 +03:00
Live testnet (Ropsten) version:
2017-10-29 10:59:28 +02:00
https://openbounty.status.im:444
2017-08-19 12:11:53 +03:00
The `develop` branch is automatically deployed here.
2016-08-21 00:36:09 +03:00
2018-02-15 12:51:13 +02:00
## Table of contents
- [Prerequisites ](#prerequisites )
- [Application config ](#application-config )
- [GitHub integration ](#github-integration )
2018-03-20 13:58:53 +01:00
- [Contracts ](#contracts )
2018-02-15 12:51:13 +02:00
- [Running ](#running )
- [Testing ](#testing )
- [More info ](#more-info )
2016-08-21 00:36:09 +03:00
## Prerequisites
2018-02-02 13:23:26 +02:00
You will need [Leiningen ](https://github.com/technomancy/leiningen ) 2.0 or above installed. Also, make sure that you have [wkhtmltoimage ](https://wkhtmltopdf.org/downloads.html ) available in your PATH. On macOS, it can be installed via `brew cask install wkhtmltopdf` .
2016-08-21 00:36:09 +03:00
2017-07-26 23:50:08 +02:00
### PostgreSQL
2018-04-26 11:55:34 -07:00
Install [PostgreSQL ](https://www.postgresql.org/ ), and set it up properly:
2017-07-26 23:50:08 +02:00
```
2018-02-13 14:47:01 +01:00
psql postgres -c "CREATE USER commiteth WITH PASSWORD 'commiteth';"
psql postgres -c "CREATE DATABASE commiteth;"
2017-07-26 23:50:08 +02:00
```
2016-08-21 00:36:09 +03:00
2018-01-25 13:14:51 +02:00
## Application config
2018-04-26 11:55:34 -07:00
Create `/config-dev.edn` , and populate it correctly, according to `env/dev/resources/config.edn` . The config fields are described below:
2018-01-25 13:14:51 +02:00
Key | Description
--- | ---
dev | Currently specifies whether Swagger UI endpoints should be added to routes
port | HTTP port for the Ring web app
2018-04-26 11:55:34 -07:00
dev-login | Local development only. Set it to the GitHub name of your dev user in order to log in to the system and to bypass OAuth. Following this, set `server-address` according to your localhost address.
2018-01-25 13:14:51 +02:00
nrepl-port | nREPL port for development
2018-04-26 11:55:34 -07:00
jdbc-database-url | PostgreSQL database URL; for instance, the URL to the local db would be `jdbc:postgresql://localhost/commiteth?user=commiteth&password=commiteth`
server-address | The URL and port of the local server that can be resolved from public internet. It will be used as a redirect URI during GitHub OAuth authorization process.
2018-01-25 13:14:51 +02:00
eth-account | Ethereum account ID for the bot
eth-password | Ethereum account password for the bot
2018-04-26 11:55:34 -07:00
eth-rpc-url | RPC URL to the Ethereum node, e.g. Geth. Either local or remote
eth-wallet-file | Location of the wallet file. If Geth is run with the parameters specified below, it will reside under `$HOME/.ropsten/keystore` .
offline-signing | Specifies whether to sign transactions locally before sending. Default is true. Set to false when connecting to the local Geth node that unlocks accounts.
2018-01-25 13:14:51 +02:00
tokenreg-base-format | Should be set to `:status`
2018-04-26 11:55:34 -07:00
github-client-id | Related to OAuth. Copied from the GitHub account: Settings -> Developer settings -> OAuth Apps
github-client-secret | Related to OAuth. Copied from theGitHub account: Settings -> Developer settings -> OAuth Apps
github-user | GitHub username for a bot account. It is used for posting bounty comments.
github-password | GitHub password for a bot account.
2018-01-25 13:14:51 +02:00
webhook-secret | Secret string to be used when creating a GitHub App
user-whitelist | Set of GitHub user/org IDs to be whitelisted. E.g. `#{"status-im" "your_org"}`
2018-04-26 11:55:34 -07:00
testnet-token-data | Token data map; useful if there are Geth connectivity problems
2018-01-25 13:14:51 +02:00
## GitHub integration
Open Bounty uses both OAuth App and GitHub App integration.
### OAuth App
2018-04-26 11:55:34 -07:00
Follow the steps [here ](https://developer.github.com/apps/building-oauth-apps/creating-an-oauth-app/ ). Specify the value of `:server-address` as "Homepage URL", and `:server-address` + `/callback` as "Authorization callback URL". Be sure to copy the Client ID and Client Secret values in the config file.
2018-01-25 13:14:51 +02:00
### GitHub App
Follow the steps [here ](https://developer.github.com/apps/building-github-apps/creating-a-github-app/ ). Be sure to specify `:server-address` + `/webhook-app` as "Webhook URL", and `:webhook-secret` as "Webhook Secret".
2016-08-21 00:36:09 +03:00
2018-03-20 13:58:53 +01:00
## Contracts
2018-04-26 11:55:34 -07:00
All information related to development of OpenBounty smart contracts can be found in [`contracts/` ](/contracts/ ).
2018-03-20 13:58:53 +01:00
2018-01-25 13:14:51 +02:00
## Running
2017-10-26 20:51:43 +02:00
2018-02-16 19:09:26 +02:00
### Ethereum node
2018-04-26 11:55:34 -07:00
There are two options for connecting to an Ethereum node: either run a local node with an unlocked account, or connect to a remote Geth node or Infura. We will be connecting to Ropsten, which is an Ethereum network used for testing.
2018-02-16 19:09:26 +02:00
#### Local
2018-04-26 11:55:34 -07:00
To launch a local geth node with the bot account unlocked, issue the following command:
2017-10-26 20:51:43 +02:00
```
#!/bin/bash
2017-10-29 18:30:17 +02:00
geth --fast --testnet --cache=1024 --datadir=$HOME/.ropsten --verbosity 4 --port 50100 --ipcpath ~/.ropsten/geth.ipc --rpc --rpcaddr 127.0.0.1 --rpcport 8545 --rpcapi db,eth,net,web3,personal --rpccorsdomain "https://wallet.ethereum.org" --unlock "0xYOUR_ADDR" --password < (echo "YOUR_PASSPHRASE")
2017-10-26 20:51:43 +02:00
```
2018-02-16 19:09:26 +02:00
#### Remote
2018-04-26 11:55:34 -07:00
Register at [Infura ](https://infura.io/signup ). You will receive an email with the provider's URLs. Paste a URL for the Ropsten network into `config.edn` under the `:eth-rpc-url` key, and set `:offline-signing` to true.
2018-02-16 19:09:26 +02:00
2018-02-15 12:51:13 +02:00
### CSS auto-compilation
2017-10-29 18:30:17 +02:00
Launch the following command in a separate shell:
2017-07-26 23:50:08 +02:00
```
lein less auto
2017-08-19 12:11:53 +03:00
```
2018-02-21 16:32:53 +02:00
### Solidity compilation
Invoke `build-contracts` Leiningen task to compile Solidity files into Java classes:
```
lein build-contracts
```
2018-02-15 12:51:13 +02:00
### Clojure app without REPL
2018-04-26 11:55:34 -07:00
Launch the following commands, each in its own shell:
2018-02-15 12:51:13 +02:00
```
lein run
lein figwheel
```
### Clojure app with REPL
2018-04-26 11:55:34 -07:00
You'll have to start a REPL on the backend and frontend.
2017-10-26 20:51:43 +02:00
2017-10-29 18:30:17 +02:00
```
lein repl
```
2018-04-26 11:55:34 -07:00
Now you can start a CLJS REPL:
2017-10-29 18:30:17 +02:00
```
(use 'figwheel-sidecar.repl-api)
(start-figwheel!)
(cljs-repl)
```
(Alternatively, if you use emacs and CIDER, you can run cider-jack-in. Details [here ](https://cider.readthedocs.io/en/latest/up_and_running/ ))
2018-04-26 11:55:34 -07:00
Next, start the application from the clojure REPL:
2017-10-29 18:30:17 +02:00
```
(user/start)
```
2017-08-19 12:11:53 +03:00
## Uberjar build
2017-07-26 23:50:08 +02:00
2017-08-19 12:11:53 +03:00
To create a standalone uberjar:
```
lein uberjar
2017-07-26 23:50:08 +02:00
```
2017-02-11 14:33:58 +02:00
2018-04-26 11:55:34 -07:00
This creates `target/uberjar/commiteth.jar` . You can run it with the following command from within the project's root:
2018-02-21 16:32:53 +02:00
```
java -Dconf=< path_to_config.edn > -jar target/uberjar/commiteth.jar
```
2017-08-19 12:11:53 +03:00
2017-02-11 14:33:58 +02:00
## Testing
2017-10-29 18:30:17 +02:00
### QA
2018-04-26 11:55:34 -07:00
Please refer to [doc/testing.md ](https://github.com/status-im/commiteth/blob/develop/doc/testing.md ).
2017-10-29 18:30:17 +02:00
2017-02-11 14:33:58 +02:00
### Clojure tests
2017-07-26 23:50:08 +02:00
```
lein test
```
2017-02-11 14:33:58 +02:00
### ClojureScript tests
2017-07-26 23:50:08 +02:00
```
lein with-profile test doo phantom test
```
2017-02-11 14:33:58 +02:00
### Reagent component devcards
2017-07-26 23:50:08 +02:00
```
lein with-profile test figwheel devcards
```
2017-02-11 14:33:58 +02:00
Open http://localhost:3449/cards.html
2018-03-26 18:26:48 +02:00
### CircleCI
2018-04-26 11:55:34 -07:00
We use CircleCI to run unit tests. For this to work, set the following env vars:
2018-03-26 18:26:48 +02:00
2018-04-26 11:55:34 -07:00
> These env vars override the configuration parameters that are usually set using the `config.edn` file.
2018-03-26 18:26:48 +02:00
- `ETH_ACCOUNT` - as in `config.edn`
- `ETH_PASSWORD` - as in `config.edn`
- `ETH_RPC_URL` - as in `config.edn`
- `ETH_WALLET_FILE` - as in `config.edn`
- `ETH_WALLET_JSON` - contents of this will be written to `ETH_WALLET_FILE`
2018-04-26 11:55:34 -07:00
:bulb: Ideally, we'd create those parameters in a script. PR welcome.
2018-03-26 18:26:48 +02:00
## Update landing page
2017-10-30 10:37:13 -05:00
2017-10-30 11:10:27 -05:00
Landing page is static and different CSS and JS due to time constraints.
- Build CSS with Gulp (see `static_landing_page/README.md`
- Make changes and `./build-landing-page.sh`
2018-04-26 11:55:34 -07:00
This copies the necessary artifacts over to the `resources` dir.
2016-08-21 00:36:09 +03:00
2018-01-25 13:14:51 +02:00
2018-02-15 12:51:13 +02:00
## More info
2018-04-26 11:55:34 -07:00
Detailed information on code structure, troubleshooting, and more can be found [here ](doc/README.md ).
2018-01-25 13:14:51 +02:00
2016-08-21 00:36:09 +03:00
## License
2017-03-09 15:34:40 +01:00
Licensed under the [Affero General Public License v3.0 ](https://github.com/status-im/commiteth/blob/master/LICENSE.md )