woodpecker/drone.go

199 lines
4.8 KiB
Go
Raw Normal View History

package main
import (
2015-04-08 23:19:25 +00:00
"flag"
"html/template"
"net/http"
2015-04-08 23:19:25 +00:00
"github.com/gin-gonic/gin"
"github.com/drone/drone/remote/github"
"github.com/drone/drone/server"
"github.com/drone/drone/server/session"
"github.com/drone/drone/settings"
"github.com/elazarl/go-bindata-assetfs"
2015-04-24 21:25:03 +00:00
store "github.com/drone/drone/datastore/builtin"
2015-04-28 22:30:51 +00:00
eventbus "github.com/drone/drone/eventbus/builtin"
2015-04-24 21:25:03 +00:00
queue "github.com/drone/drone/queue/builtin"
runner "github.com/drone/drone/runner/builtin"
_ "net/http/pprof"
)
var conf = flag.String("config", "drone.toml", "")
func main() {
2015-04-08 23:59:57 +00:00
flag.Parse()
2015-04-08 23:19:25 +00:00
settings, err := settings.Parse(*conf)
2015-04-08 23:19:25 +00:00
if err != nil {
panic(err)
}
db := store.MustConnect(settings.Database.Driver, settings.Database.Datasource)
store := store.New(db)
defer db.Close()
2015-04-08 23:19:25 +00:00
remote := github.New(settings.Service)
session := session.New(settings.Session)
eventbus_ := eventbus.New()
queue_ := queue.New()
2015-05-10 03:46:32 +00:00
updater := runner.NewUpdater(eventbus_, store, remote)
2015-05-05 08:07:35 +00:00
runner_ := runner.Runner{Updater: updater}
go run(&runner_, queue_)
2015-04-08 23:19:25 +00:00
r := gin.Default()
api := r.Group("/api")
api.Use(server.SetHeaders())
api.Use(server.SetBus(eventbus_))
api.Use(server.SetDatastore(store))
2015-04-08 23:19:25 +00:00
api.Use(server.SetRemote(remote))
api.Use(server.SetQueue(queue_))
2015-04-08 23:19:25 +00:00
api.Use(server.SetSettings(settings))
2015-04-30 21:23:46 +00:00
api.Use(server.SetSession(session))
2015-04-08 23:19:25 +00:00
api.Use(server.SetUser(session))
2015-05-06 08:24:55 +00:00
api.Use(server.SetRunner(&runner_))
2015-04-08 23:19:25 +00:00
user := api.Group("/user")
{
user.Use(server.MustUser())
user.GET("", server.GetUserCurr)
user.PATCH("", server.PutUserCurr)
2015-04-08 23:19:25 +00:00
user.GET("/repos", server.GetUserRepos)
2015-04-13 08:22:51 +00:00
user.GET("/tokens", server.GetUserTokens)
user.POST("/tokens", server.PostToken)
user.DELETE("/tokens/:label", server.DelToken)
2015-04-08 23:19:25 +00:00
}
users := api.Group("/users")
{
users.Use(server.MustAdmin())
users.GET("", server.GetUsers)
users.GET("/:name", server.GetUser)
users.POST("/:name", server.PostUser)
users.PATCH("/:name", server.PutUser)
2015-04-08 23:19:25 +00:00
users.DELETE("/:name", server.DeleteUser)
}
2015-04-30 21:41:52 +00:00
agents := api.Group("/agents")
{
agents.Use(server.MustAdmin())
agents.GET("/token", server.GetAgentToken)
}
2015-04-08 23:19:25 +00:00
repos := api.Group("/repos/:owner/:name")
{
repos.POST("", server.PostRepo)
repo := repos.Group("")
{
repo.Use(server.SetRepo())
repo.Use(server.SetPerm())
repo.Use(server.CheckPull())
repo.Use(server.CheckPush())
repo.GET("", server.GetRepo)
repo.PATCH("", server.PutRepo)
2015-04-08 23:19:25 +00:00
repo.DELETE("", server.DeleteRepo)
repo.POST("/watch", server.Subscribe)
repo.DELETE("/unwatch", server.Unsubscribe)
repo.GET("/builds", server.GetCommits)
repo.GET("/builds/:number", server.GetCommit)
2015-04-17 05:07:13 +00:00
repo.POST("/builds/:number", server.RunBuild)
repo.DELETE("/builds/:number", server.KillBuild)
repo.GET("/logs/:number/:task", server.GetLogs)
// repo.POST("/status/:number", server.PostBuildStatus)
2015-04-08 23:19:25 +00:00
}
}
badges := api.Group("/badges/:owner/:name")
{
badges.Use(server.SetRepo())
badges.GET("/status.svg", server.GetBadge)
badges.GET("/cc.xml", server.GetCC)
}
hooks := api.Group("/hook")
{
hooks.POST("", server.PostHook)
}
// queue := api.Group("/queue")
// {
// queue.Use(server.MustAgent())
// queue.GET("", server.GetQueue)
// queue.POST("/pull", server.PollBuild)
// push := queue.Group("/push/:owner/:name")
// {
// push.Use(server.SetRepo())
// push.POST("", server.PushBuild)
// push.POST("/:build", server.PushTask)
// push.POST("/:build/:task/logs", server.PushLogs)
// }
// }
2015-04-24 21:25:03 +00:00
2015-05-06 03:26:57 +00:00
stream := api.Group("/stream")
2015-04-25 00:06:46 +00:00
{
2015-05-06 03:26:57 +00:00
stream.Use(server.SetRepo())
stream.Use(server.SetPerm())
stream.GET("/:owner/:name", server.GetRepoEvents)
stream.GET("/:owner/:name/:build/:number", server.GetStream)
2015-04-30 02:57:43 +00:00
2015-04-25 00:06:46 +00:00
}
2015-04-08 23:19:25 +00:00
auth := r.Group("/authorize")
{
auth.Use(server.SetHeaders())
auth.Use(server.SetDatastore(store))
2015-04-08 23:19:25 +00:00
auth.Use(server.SetRemote(remote))
auth.Use(server.SetSettings(settings))
auth.Use(server.SetSession(session))
auth.GET("", server.GetLogin)
auth.POST("", server.GetLogin)
}
r.SetHTMLTemplate(index())
2015-04-08 23:19:25 +00:00
r.NoRoute(func(c *gin.Context) {
c.HTML(200, "index.html", nil)
2015-04-08 23:19:25 +00:00
})
http.Handle("/static/", static())
http.Handle("/", r)
http.ListenAndServe(settings.Server.Addr, nil)
}
// static is a helper function that will setup handlers
// for serving static files.
func static() http.Handler {
return http.StripPrefix("/static/", http.FileServer(&assetfs.AssetFS{
Asset: Asset,
AssetDir: AssetDir,
Prefix: "server/static",
}))
}
// index is a helper function that will setup a template
// for rendering the main angular index.html file.
func index() *template.Template {
file := MustAsset("server/static/index.html")
filestr := string(file)
return template.Must(template.New("index.html").Parse(filestr))
}
// run is a helper function for initializing the
// built-in build runner, if not running in remote
// mode.
func run(r *runner.Runner, q *queue.Queue) {
defer func() {
recover()
}()
r.Poll(q)
}