2016-04-29 19:39:56 +00:00
|
|
|
package main
|
|
|
|
|
|
|
|
import (
|
|
|
|
"net/http"
|
|
|
|
"time"
|
|
|
|
|
2016-05-02 19:21:25 +00:00
|
|
|
"github.com/drone/drone/router"
|
|
|
|
"github.com/drone/drone/router/middleware"
|
|
|
|
"github.com/gin-gonic/contrib/ginrus"
|
2016-04-29 19:39:56 +00:00
|
|
|
|
|
|
|
"github.com/Sirupsen/logrus"
|
|
|
|
"github.com/codegangsta/cli"
|
|
|
|
)
|
|
|
|
|
2016-05-06 17:59:36 +00:00
|
|
|
var serverCmd = cli.Command{
|
|
|
|
Name: "server",
|
2016-04-29 19:39:56 +00:00
|
|
|
Usage: "starts the drone server daemon",
|
|
|
|
Action: func(c *cli.Context) {
|
2016-05-06 17:59:36 +00:00
|
|
|
if err := server(c); err != nil {
|
2016-04-29 19:39:56 +00:00
|
|
|
logrus.Fatal(err)
|
|
|
|
}
|
|
|
|
},
|
|
|
|
Flags: []cli.Flag{
|
|
|
|
cli.BoolFlag{
|
|
|
|
EnvVar: "DRONE_DEBUG",
|
|
|
|
Name: "debug",
|
|
|
|
Usage: "start the server in debug mode",
|
|
|
|
},
|
|
|
|
cli.StringFlag{
|
|
|
|
EnvVar: "DRONE_SERVER_ADDR",
|
|
|
|
Name: "server-addr",
|
|
|
|
Usage: "server address",
|
|
|
|
Value: ":8000",
|
|
|
|
},
|
|
|
|
cli.StringFlag{
|
|
|
|
EnvVar: "DRONE_SERVER_CERT",
|
|
|
|
Name: "server-cert",
|
|
|
|
Usage: "server ssl cert",
|
|
|
|
},
|
|
|
|
cli.StringFlag{
|
|
|
|
EnvVar: "DRONE_SERVER_KEY",
|
|
|
|
Name: "server-key",
|
|
|
|
Usage: "server ssl key",
|
|
|
|
},
|
|
|
|
cli.StringSliceFlag{
|
|
|
|
EnvVar: "DRONE_ADMIN",
|
|
|
|
Name: "admin",
|
|
|
|
Usage: "list of admin users",
|
|
|
|
},
|
|
|
|
cli.StringSliceFlag{
|
|
|
|
EnvVar: "DRONE_ORGS",
|
|
|
|
Name: "orgs",
|
|
|
|
Usage: "list of approved organizations",
|
|
|
|
},
|
|
|
|
cli.BoolFlag{
|
|
|
|
EnvVar: "DRONE_OPEN",
|
|
|
|
Name: "open",
|
|
|
|
Usage: "open user registration",
|
|
|
|
},
|
|
|
|
cli.StringFlag{
|
|
|
|
EnvVar: "DRONE_YAML",
|
|
|
|
Name: "yaml",
|
|
|
|
Usage: "build configuraton file name",
|
|
|
|
Value: ".drone.yml",
|
|
|
|
},
|
|
|
|
cli.DurationFlag{
|
|
|
|
EnvVar: "DRONE_CACHE_TTY",
|
|
|
|
Name: "cache-tty",
|
|
|
|
Usage: "cache duration",
|
|
|
|
Value: time.Minute * 15,
|
|
|
|
},
|
|
|
|
cli.StringFlag{
|
2016-05-24 01:47:44 +00:00
|
|
|
EnvVar: "DRONE_AGENT_SECRET,DRONE_SECRET",
|
2016-04-29 19:39:56 +00:00
|
|
|
Name: "agent-secret",
|
|
|
|
Usage: "agent secret passcode",
|
|
|
|
},
|
|
|
|
cli.StringFlag{
|
|
|
|
EnvVar: "DRONE_DATABASE_DRIVER,DATABASE_DRIVER",
|
|
|
|
Name: "driver",
|
|
|
|
Usage: "database driver",
|
2016-05-08 00:29:31 +00:00
|
|
|
Value: "sqlite3",
|
2016-04-29 19:39:56 +00:00
|
|
|
},
|
|
|
|
cli.StringFlag{
|
|
|
|
EnvVar: "DRONE_DATABASE_DATASOURCE,DATABASE_CONFIG",
|
|
|
|
Name: "datasource",
|
|
|
|
Usage: "database driver configuration string",
|
|
|
|
Value: "drone.sqlite",
|
|
|
|
},
|
|
|
|
cli.BoolFlag{
|
|
|
|
EnvVar: "DRONE_GITHUB",
|
|
|
|
Name: "github",
|
|
|
|
Usage: "github driver is enabled",
|
|
|
|
},
|
|
|
|
cli.StringFlag{
|
|
|
|
EnvVar: "DRONE_GITHUB_URL",
|
|
|
|
Name: "github-server",
|
|
|
|
Usage: "github server address",
|
|
|
|
Value: "https://github.com",
|
|
|
|
},
|
2016-05-27 18:22:32 +00:00
|
|
|
cli.StringFlag{
|
|
|
|
EnvVar: "DRONE_GITHUB_CONTEXT",
|
|
|
|
Name: "github-context",
|
|
|
|
Usage: "github status context",
|
|
|
|
Value: "continuous-integration/drone",
|
|
|
|
},
|
2016-04-29 19:39:56 +00:00
|
|
|
cli.StringFlag{
|
|
|
|
EnvVar: "DRONE_GITHUB_CLIENT",
|
|
|
|
Name: "github-client",
|
|
|
|
Usage: "github oauth2 client id",
|
|
|
|
},
|
|
|
|
cli.StringFlag{
|
|
|
|
EnvVar: "DRONE_GITHUB_SECRET",
|
|
|
|
Name: "github-sercret",
|
|
|
|
Usage: "github oauth2 client secret",
|
|
|
|
},
|
|
|
|
cli.StringSliceFlag{
|
|
|
|
EnvVar: "DRONE_GITHUB_SCOPE",
|
|
|
|
Name: "github-scope",
|
|
|
|
Usage: "github oauth scope",
|
|
|
|
Value: &cli.StringSlice{
|
|
|
|
"repo",
|
|
|
|
"repo:status",
|
|
|
|
"user:email",
|
|
|
|
"read:org",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
cli.BoolTFlag{
|
|
|
|
EnvVar: "DRONE_GITHUB_MERGE_REF",
|
|
|
|
Name: "github-merge-ref",
|
|
|
|
Usage: "github pull requests use merge ref",
|
|
|
|
},
|
|
|
|
cli.BoolFlag{
|
|
|
|
EnvVar: "DRONE_GITHUB_PRIVATE_MODE",
|
|
|
|
Name: "github-private-mode",
|
|
|
|
Usage: "github is running in private mode",
|
|
|
|
},
|
|
|
|
cli.BoolFlag{
|
|
|
|
EnvVar: "DRONE_GITHUB_SKIP_VERIFY",
|
|
|
|
Name: "github-skip-verify",
|
|
|
|
Usage: "github skip ssl verification",
|
|
|
|
},
|
|
|
|
cli.BoolFlag{
|
|
|
|
EnvVar: "DRONE_GOGS",
|
|
|
|
Name: "gogs",
|
|
|
|
Usage: "gogs driver is enabled",
|
|
|
|
},
|
|
|
|
cli.StringFlag{
|
|
|
|
EnvVar: "DRONE_GOGS_URL",
|
|
|
|
Name: "gogs-server",
|
|
|
|
Usage: "gogs server address",
|
|
|
|
Value: "https://github.com",
|
|
|
|
},
|
2016-05-01 23:30:00 +00:00
|
|
|
cli.StringFlag{
|
|
|
|
EnvVar: "DRONE_GOGS_GIT_USERNAME",
|
|
|
|
Name: "gogs-git-username",
|
|
|
|
Usage: "gogs service account username",
|
|
|
|
},
|
|
|
|
cli.StringFlag{
|
|
|
|
EnvVar: "DRONE_GOGS_GIT_PASSWORD",
|
|
|
|
Name: "gogs-git-password",
|
|
|
|
Usage: "gogs service account password",
|
|
|
|
},
|
2016-04-29 19:39:56 +00:00
|
|
|
cli.BoolFlag{
|
|
|
|
EnvVar: "DRONE_GOGS_PRIVATE_MODE",
|
|
|
|
Name: "gogs-private-mode",
|
|
|
|
Usage: "gogs private mode enabled",
|
|
|
|
},
|
|
|
|
cli.BoolFlag{
|
|
|
|
EnvVar: "DRONE_GOGS_SKIP_VERIFY",
|
|
|
|
Name: "gogs-skip-verify",
|
|
|
|
Usage: "gogs skip ssl verification",
|
|
|
|
},
|
|
|
|
cli.BoolFlag{
|
|
|
|
EnvVar: "DRONE_BITBUCKET",
|
|
|
|
Name: "bitbucket",
|
|
|
|
Usage: "bitbucket driver is enabled",
|
|
|
|
},
|
|
|
|
cli.StringFlag{
|
|
|
|
EnvVar: "DRONE_BITBUCKET_CLIENT",
|
|
|
|
Name: "bitbucket-client",
|
|
|
|
Usage: "bitbucket oauth2 client id",
|
|
|
|
},
|
|
|
|
cli.StringFlag{
|
|
|
|
EnvVar: "DRONE_BITBUCKET_SECRET",
|
|
|
|
Name: "bitbucket-secret",
|
|
|
|
Usage: "bitbucket oauth2 client secret",
|
|
|
|
},
|
|
|
|
cli.BoolFlag{
|
|
|
|
EnvVar: "DRONE_GITLAB",
|
|
|
|
Name: "gitlab",
|
|
|
|
Usage: "gitlab driver is enabled",
|
|
|
|
},
|
|
|
|
cli.StringFlag{
|
|
|
|
EnvVar: "DRONE_GITLAB_URL",
|
|
|
|
Name: "gitlab-server",
|
|
|
|
Usage: "gitlab server address",
|
|
|
|
Value: "https://gitlab.com",
|
|
|
|
},
|
|
|
|
cli.StringFlag{
|
|
|
|
EnvVar: "DRONE_GITLAB_CLIENT",
|
|
|
|
Name: "gitlab-client",
|
|
|
|
Usage: "gitlab oauth2 client id",
|
|
|
|
},
|
|
|
|
cli.StringFlag{
|
|
|
|
EnvVar: "DRONE_GITLAB_SECRET",
|
|
|
|
Name: "gitlab-sercret",
|
|
|
|
Usage: "gitlab oauth2 client secret",
|
|
|
|
},
|
2016-05-01 23:30:00 +00:00
|
|
|
cli.StringFlag{
|
|
|
|
EnvVar: "DRONE_GITLAB_GIT_USERNAME",
|
|
|
|
Name: "gitlab-git-username",
|
|
|
|
Usage: "gitlab service account username",
|
|
|
|
},
|
|
|
|
cli.StringFlag{
|
|
|
|
EnvVar: "DRONE_GITLAB_GIT_PASSWORD",
|
|
|
|
Name: "gitlab-git-password",
|
|
|
|
Usage: "gitlab service account password",
|
|
|
|
},
|
2016-04-29 19:39:56 +00:00
|
|
|
cli.BoolFlag{
|
|
|
|
EnvVar: "DRONE_GITLAB_SKIP_VERIFY",
|
|
|
|
Name: "gitlab-skip-verify",
|
|
|
|
Usage: "gitlab skip ssl verification",
|
|
|
|
},
|
|
|
|
cli.BoolFlag{
|
|
|
|
EnvVar: "DRONE_GITLAB_PRIVATE_MODE",
|
|
|
|
Name: "gitlab-private-mode",
|
|
|
|
Usage: "gitlab is running in private mode",
|
|
|
|
},
|
|
|
|
cli.BoolFlag{
|
|
|
|
EnvVar: "DRONE_STASH",
|
|
|
|
Name: "stash",
|
|
|
|
Usage: "stash driver is enabled",
|
|
|
|
},
|
|
|
|
cli.StringFlag{
|
|
|
|
EnvVar: "DRONE_STASH_URL",
|
|
|
|
Name: "stash-server",
|
|
|
|
Usage: "stash server address",
|
|
|
|
},
|
|
|
|
cli.StringFlag{
|
|
|
|
EnvVar: "DRONE_STASH_CONSUMER_KEY",
|
|
|
|
Name: "stash-consumer-key",
|
|
|
|
Usage: "stash oauth1 consumer key",
|
|
|
|
},
|
|
|
|
cli.StringFlag{
|
|
|
|
EnvVar: "DRONE_STASH_CONSUMER_RSA",
|
|
|
|
Name: "stash-consumer-rsa",
|
|
|
|
Usage: "stash oauth1 private key file",
|
|
|
|
},
|
|
|
|
cli.StringFlag{
|
|
|
|
EnvVar: "DRONE_STASH_GIT_USERNAME",
|
|
|
|
Name: "stash-git-username",
|
|
|
|
Usage: "stash service account username",
|
|
|
|
},
|
|
|
|
cli.StringFlag{
|
|
|
|
EnvVar: "DRONE_STASH_GIT_PASSWORD",
|
|
|
|
Name: "stash-git-password",
|
|
|
|
Usage: "stash service account password",
|
|
|
|
},
|
2016-05-01 23:30:00 +00:00
|
|
|
cli.BoolFlag{
|
|
|
|
EnvVar: "DRONE_STASH_SKIP_VERIFY",
|
|
|
|
Name: "stash-skip-verify",
|
|
|
|
Usage: "stash skip ssl verification",
|
|
|
|
},
|
2016-04-29 19:39:56 +00:00
|
|
|
},
|
|
|
|
}
|
|
|
|
|
2016-05-06 17:59:36 +00:00
|
|
|
func server(c *cli.Context) error {
|
2016-04-29 19:39:56 +00:00
|
|
|
|
|
|
|
// debug level if requested by user
|
|
|
|
if c.Bool("debug") {
|
|
|
|
logrus.SetLevel(logrus.DebugLevel)
|
|
|
|
} else {
|
|
|
|
logrus.SetLevel(logrus.WarnLevel)
|
|
|
|
}
|
|
|
|
|
|
|
|
// setup the server and start the listener
|
2016-05-02 19:21:25 +00:00
|
|
|
handler := router.Load(
|
|
|
|
ginrus.Ginrus(logrus.StandardLogger(), time.RFC3339, true),
|
|
|
|
middleware.Version,
|
|
|
|
middleware.Config(c),
|
|
|
|
middleware.Queue(c),
|
|
|
|
middleware.Stream(c),
|
|
|
|
middleware.Bus(c),
|
|
|
|
middleware.Cache(c),
|
|
|
|
middleware.Store(c),
|
|
|
|
middleware.Remote(c),
|
|
|
|
middleware.Agents(c),
|
|
|
|
)
|
2016-04-29 19:39:56 +00:00
|
|
|
|
|
|
|
// start the server with tls enabled
|
|
|
|
if c.String("server-cert") != "" {
|
|
|
|
return http.ListenAndServeTLS(
|
|
|
|
c.String("server-addr"),
|
|
|
|
c.String("server-cert"),
|
|
|
|
c.String("server-key"),
|
2016-05-02 19:21:25 +00:00
|
|
|
handler,
|
2016-04-29 19:39:56 +00:00
|
|
|
)
|
|
|
|
}
|
|
|
|
|
|
|
|
// start the server without tls enabled
|
|
|
|
return http.ListenAndServe(
|
|
|
|
c.String("server-addr"),
|
2016-05-02 19:21:25 +00:00
|
|
|
handler,
|
2016-04-29 19:39:56 +00:00
|
|
|
)
|
|
|
|
}
|