2014-09-10 09:19:04 +03:00
[![Build Status ](http://test.drone.io/v1/badge/github.com/drone/drone/status.svg?branch=exp )](http://test.drone.io/github.com/drone/drone)
2014-08-12 21:43:49 +03:00
[![GoDoc ](https://godoc.org/github.com/drone/drone?status.png )](https://godoc.org/github.com/drone/drone)
2014-07-14 05:53:59 +03:00
2014-02-07 13:10:01 +03:00
2014-08-02 21:21:39 +03:00
## System Requirements
2014-02-14 01:43:02 +03:00
2014-08-02 21:21:39 +03:00
* Docker
* AUFS
We highly recommend running Docker with the AUFS storage driver. You can verify Docker is using
the AUFS storage driver with the following command `sudo docker info | grep Driver:`
## Installation
We have optimized the installation process for Ubuntu since that is what we test with internally. You can run the following commands to quickly download an install Drone on an Ubuntu machine.
```sh
wget downloads.drone.io/exp/drone.deb
sudo dpkg -i drone.deb
```
2014-10-01 21:58:27 +03:00
## Database
By default, Drone will create a SQLite database. Drone also supports Postgres and MySQL
databases. You can customize the database settings using the configuration options
described in the **Setup** section.
Below are some example configurations that you can use as reference:
```
# to use postgres
[datasource]
driver="postgres"
source="host=172.17.0.2 user=postgres dbname=drone sslmode=disable"
# to use mysql
[datasource]
driver="mysql"
source="root@tcp(172.17.0.2:3306)/drone"
```
2014-09-03 10:23:36 +03:00
## Setup
2014-08-02 21:21:39 +03:00
2014-09-03 10:23:36 +03:00
We are in the process of moving configuration out of the UI and into configuration
files and/or environment variables (your choice which). If you prefer configuration files
you can provide Drone with the path to your configuration file:
2014-03-09 01:22:49 +03:00
2014-09-03 10:23:36 +03:00
```sh
./drone --config=/path/to/drone.conf
```
2014-08-02 21:21:39 +03:00
2014-09-03 10:23:36 +03:00
The configuration file is in TOML format:
```toml
2014-09-05 06:53:32 +03:00
2014-10-01 22:01:02 +03:00
[database]
2014-10-01 21:58:27 +03:00
driver=""
source=""
2014-09-05 06:53:32 +03:00
[registration]
open=true
2014-09-03 10:23:36 +03:00
[github]
client=""
secret=""
[github_enterprise]
client=""
secret=""
api=""
url=""
2014-09-07 21:26:16 +03:00
private_mode=false
2014-09-03 10:23:36 +03:00
[bitbucket]
client=""
secret=""
2014-09-04 06:48:13 +03:00
[gitlab]
url=""
2014-09-03 10:23:36 +03:00
[smtp]
host=""
port=""
from=""
user=""
pass=""
2014-09-08 00:55:37 +03:00
[worker]
nodes=[
"unix:///var/run/docker.sock",
"unix:///var/run/docker.sock"
]
2014-09-03 10:23:36 +03:00
```
2014-08-02 21:21:39 +03:00
2014-09-03 10:23:36 +03:00
Or you can use environment variables
2014-02-07 13:10:01 +03:00
2014-09-03 10:23:36 +03:00
```sh
2014-09-07 21:26:16 +03:00
2014-10-01 21:58:27 +03:00
# custom database settings
2014-10-01 22:01:02 +03:00
export DRONE_DATABASE_DRIVER=""
export DRONE_DATABASE_SOURCE=""
2014-10-01 21:58:27 +03:00
2014-09-07 21:26:16 +03:00
# enable users to self-register
export DRONE_REGISTRATION_OPEN=false
2014-09-03 10:23:36 +03:00
# github configuration
export DRONE_GITHUB_CLIENT=""
2014-09-04 06:48:13 +03:00
export DRONE_GITHUB_SECRET=""
2014-09-03 10:23:36 +03:00
# github enterprise configuration
export DRONE_GITHUB_ENTERPRISE_CLIENT=""
export DRONE_GITHUB_ENTERPRISE_SECRET=""
export DRONE_GITHUB_ENTERPRISE_API=""
export DRONE_GITHUB_ENTERPRISE_URL=""
2014-09-07 21:26:16 +03:00
export DRONE_GITHUB_ENTERPRISE_PRIVATE_MODE=false
2014-09-03 10:23:36 +03:00
# bitbucket configuration
export DRONE_BITBUCKET_CLIENT=""
export DRONE_BITBUCKET_SECRET=""
2014-09-04 06:48:13 +03:00
# gitlab configuration
export DRONE_GITLAB_URL=""
2014-09-03 10:23:36 +03:00
# email configuration
export DRONE_SMTP_HOST=""
export DRONE_SMTP_PORT=""
export DRONE_SMTP_FROM=""
export DRONE_SMTP_USER=""
export DRONE_SMTP_PASS=""
2014-09-08 00:55:37 +03:00
# worker nodes
# these are optional. If not specified Drone will add
# two worker nodes that connect to $DOCKER_HOST
export DRONE_WORKER_NODES="tcp://0.0.0.0:2375,tcp://0.0.0.0:2375"
2014-09-03 10:23:36 +03:00
```
2014-08-02 21:22:49 +03:00
2014-09-04 06:48:13 +03:00
Or a combination of the two:
```sh
DRONE_GITLAB_URL="https://gitlab.com" ./drone --config=/path/to/drone.conf
```
2014-10-01 07:35:30 +03:00
## GitHub
In order to setup with GitHub you'll need to register your local Drone installation
with GitHub (or GitHub Enterprise). You can read more about registering an application here:
https://github.com/settings/applications/new
Below are example values when running Drone locally. If you are running Drone on a server
you should replace `localhost` with your server hostname or address.
Homepage URL:
2014-10-01 07:44:15 +03:00
```
2014-10-01 07:35:30 +03:00
http://localhost:8000/
2014-10-01 07:44:15 +03:00
```
2014-10-01 07:35:30 +03:00
Authorization callback URL:
2014-10-01 07:44:15 +03:00
```
2014-10-01 07:35:30 +03:00
http://localhost:8000/api/auth/github.com
2014-10-01 07:44:15 +03:00
```
2014-10-01 07:35:30 +03:00
2014-09-03 10:23:36 +03:00
## Compatibility Issues
2014-08-02 21:22:49 +03:00
2014-09-03 10:23:36 +03:00
**WARNING**
2014-08-02 21:22:49 +03:00
2014-09-03 10:23:36 +03:00
There were some fundamental changes to the application and we decided to introduce breaking changes to the dataabase. Migration would have been difficult and time consuming. Drone is an alpha product and therefore backward compatibility is not a primary goal until we hit a stable release. Apologizes for any inconvenience.