diff --git a/.drone.yml b/.drone.yml index 65b5070d1..16b4bd9f3 100644 --- a/.drone.yml +++ b/.drone.yml @@ -5,8 +5,9 @@ env: - GOROOT=/usr/local/go - PATH=$PATH:$GOROOT/bin:$GOPATH/bin script: - - make deps - - make + - go get -u github.com/jteeuwen/go-bindata/... + - make bindata deps + - make build - make test notify: diff --git a/.gitignore b/.gitignore index 8383f7998..df07484a4 100644 --- a/.gitignore +++ b/.gitignore @@ -13,5 +13,7 @@ drone.sublime-workspace *.db *.txt *.toml +*.min.js +bindata.go -drone \ No newline at end of file +drone diff --git a/Makefile b/Makefile index 7a9c3bd0b..073067ced 100644 --- a/Makefile +++ b/Makefile @@ -1,7 +1,7 @@ SHA := $(shell git rev-parse --short HEAD) VERSION := 0.4.0-alpha -all: build +all: concat bindata build deps: go get -t -v ./... @@ -16,3 +16,17 @@ build: clean: find . -name "*.out" -delete rm -f drone + rm -f bindata.go + +concat: + cat server/static/scripts/drone.js \ + server/static/scripts/services/*.js \ + server/static/scripts/filters/*.js \ + server/static/scripts/controllers/*.js \ + server/static/scripts/term.js > server/static/scripts/drone.min.js + +bindata_debug: + go-bindata --debug server/static/... + +bindata: + go-bindata server/static/... \ No newline at end of file diff --git a/drone.go b/drone.go index 7083c5ea9..c4fc0ffd5 100644 --- a/drone.go +++ b/drone.go @@ -2,6 +2,8 @@ package main import ( "flag" + "html/template" + "net/http" "github.com/gin-gonic/gin" @@ -11,16 +13,17 @@ import ( "github.com/drone/drone/server" "github.com/drone/drone/server/session" "github.com/drone/drone/settings" + "github.com/elazarl/go-bindata-assetfs" queue "github.com/drone/drone/queue/builtin" ) -var path = flag.String("config", "drone.toml", "") +var conf = flag.String("config", "drone.toml", "") func main() { flag.Parse() - settings, err := settings.Parse(*path) + settings, err := settings.Parse(*conf) if err != nil { panic(err) } @@ -106,12 +109,16 @@ func main() { queue := api.Group("/queue") { - queue.Use(server.SetRepo()) queue.GET("", server.GetQueue) queue.POST("/pull", server.PollBuild) - queue.POST("/push/:owner/:name", server.PushBuild) - queue.POST("/push/:owner/:name/:build", server.PushTask) - queue.POST("/push/:owner/:name/:build/:task/logs", server.PushLogs) + + 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) + } } events := api.Group("/stream") @@ -131,9 +138,30 @@ func main() { auth.POST("", server.GetLogin) } + r.SetHTMLTemplate(index()) r.NoRoute(func(c *gin.Context) { - c.File("server/static/index.html") + c.HTML(200, "index.html", nil) }) - r.Static("/static", "server/static") - r.Run(settings.Server.Addr) + + 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)) } diff --git a/queue/plugin/server.go b/queue/plugin/server.go index baf355072..bab3b931c 100644 --- a/queue/plugin/server.go +++ b/queue/plugin/server.go @@ -72,7 +72,7 @@ func remove(c *gin.Context) { func pull(c *gin.Context) { q := fromContext(c) var work *queue.Work - if c.Request.FormValue("ack") != "" { + if c.Request.FormValue("ack") == "true" { work = q.PullAck() } else { work = q.Pull() diff --git a/server/queue.go b/server/queue.go index e23479a22..674bdd6b5 100644 --- a/server/queue.go +++ b/server/queue.go @@ -48,9 +48,11 @@ func PushBuild(c *gin.Context) { return } - if repo.Last == nil || build.Number >= repo.Last.Number { - repo.Last = build - store.SetRepo(repo) + if build.State != common.StatePending && build.State != common.StateRunning { + if repo.Last == nil || build.Number >= repo.Last.Number { + repo.Last = build + store.SetRepo(repo) + } } // <-- FIXME diff --git a/server/server.go b/server/server.go index 55ef51d2f..ce96d4c43 100644 --- a/server/server.go +++ b/server/server.go @@ -164,10 +164,10 @@ func SetRepo() gin.HandlerFunc { r, err := ds.Repo(owner + "/" + name) switch { case err != nil && u != nil: - c.Fail(401, err) + c.Fail(404, err) return case err != nil && u == nil: - c.Fail(404, err) + c.Fail(401, err) return } c.Set("repo", r) diff --git a/server/static/scripts/controllers/builds.js b/server/static/scripts/controllers/builds.js index c504c7340..248a490ad 100644 --- a/server/static/scripts/controllers/builds.js +++ b/server/static/scripts/controllers/builds.js @@ -47,17 +47,28 @@ } // update repository $scope.repo = event.repo; - $scope.apply(); - - if (event.build.number !== parseInt(number)) { - return; // ignore - } - // update the build status - $scope.build.state = event.build.state; - $scope.build.started = event.build.started; - $scope.build.finished = event.build.finished; - $scope.build.duration = event.build.duration; $scope.$apply(); + + var added = false; + for (var i=0;i<$scope.builds.length;i++) { + var build = $scope.builds[i]; + if (event.build.number !== build.number) { + continue; // ignore + } + // update the build status + build.state = event.build.state; + build.started_at = event.build.started_at; + build.finished_at = event.build.finished_at; + build.duration = event.build.duration; + $scope.builds[i] = build; + $scope.$apply(); + added = true; + } + + if (!added) { + $scope.builds.push(event.build); + $scope.$apply(); + } }); } @@ -97,7 +108,9 @@ // fetch the logs for the finished build. logs.get(fullName, number, step).then(function(payload){ - $scope.logs = payload.data; + var convert = new Filter({stream:false,newline:false}); + var term = document.getElementById("term") + term.innerHTML = convert.toHtml(payload.data); }).catch(function(err){ $scope.error = err; }); @@ -127,8 +140,8 @@ } // update the build status $scope.build.state = event.build.state; - $scope.build.started = event.build.started; - $scope.build.finished = event.build.finished; + $scope.build.started_at = event.build.started_at; + $scope.build.finished_at = event.build.finished_at; $scope.build.duration = event.build.duration; $scope.$apply(); @@ -137,8 +150,8 @@ } // update the task status $scope.task.state = event.task.state; - $scope.task.started = event.task.started; - $scope.task.finished = event.task.finished; + $scope.task.started_at = event.task.started_at; + $scope.task.finished_at = event.task.finished_at; $scope.task.duration = event.task.duration; $scope.task.exit_code = event.task.exit_code; $scope.$apply(); diff --git a/server/static/scripts/term.js b/server/static/scripts/term.js index 925e463a1..0e925abad 100644 --- a/server/static/scripts/term.js +++ b/server/static/scripts/term.js @@ -387,4 +387,4 @@ Filter = (function() { return Filter; -})(); \ No newline at end of file +})(); diff --git a/server/static/scripts/views/build.html b/server/static/scripts/views/build.html index b022b7e99..85668d05d 100644 --- a/server/static/scripts/views/build.html +++ b/server/static/scripts/views/build.html @@ -57,7 +57,7 @@
{{ logs }}+
{{ logs }}
{{ build.number }} | {{ build.state }} | {{ build.started_at | fromNow }} |