ability to limit (or not) the log output

This commit is contained in:
Brad Rydzewski 2015-04-12 23:08:55 -07:00
parent 66990a95b4
commit 54e4250df9
4 changed files with 21 additions and 10 deletions

View file

@ -1,10 +1,12 @@
package bolt package bolt
import ( import (
"bytes"
"io"
"strconv" "strconv"
"github.com/drone/drone/common"
"github.com/boltdb/bolt" "github.com/boltdb/bolt"
"github.com/drone/drone/common"
) )
// GetTask gets the task at index N for the named // GetTask gets the task at index N for the named
@ -12,7 +14,7 @@ import (
func (db *DB) GetTask(repo string, build int, task int) (*common.Task, error) { func (db *DB) GetTask(repo string, build int, task int) (*common.Task, error) {
key := []byte(repo + "/" + strconv.Itoa(build) + "/" + strconv.Itoa(task)) key := []byte(repo + "/" + strconv.Itoa(build) + "/" + strconv.Itoa(task))
task_ := &common.Task{} task_ := &common.Task{}
err := db.View(func (t *bolt.Tx) error { err := db.View(func(t *bolt.Tx) error {
return get(t, bucketBuildTasks, key, task_) return get(t, bucketBuildTasks, key, task_)
}) })
return task_, err return task_, err
@ -20,17 +22,17 @@ func (db *DB) GetTask(repo string, build int, task int) (*common.Task, error) {
// GetTaskLogs gets the task logs at index N for // GetTaskLogs gets the task logs at index N for
// the named repository and build number. // the named repository and build number.
func (db *DB) GetTaskLogs(repo string, build int, task int) ([]byte, error) { func (db *DB) GetTaskLogs(repo string, build int, task int) (io.Reader, error) {
key := []byte(repo + "/" + strconv.Itoa(build) + "/" + strconv.Itoa(task)) key := []byte(repo + "/" + strconv.Itoa(build) + "/" + strconv.Itoa(task))
var log []byte var log []byte
err := db.View(func (t *bolt.Tx) error { err := db.View(func(t *bolt.Tx) error {
var err error var err error
log, err = raw(t, bucketBuildLogs, key) log, err = raw(t, bucketBuildLogs, key)
return err return err
}) })
buf := bytes.NewBuffer(log)
return log, err return buf, err
} }
// GetTaskList gets all tasks for the named repository // GetTaskList gets all tasks for the named repository
@ -72,7 +74,7 @@ func (db *DB) GetTaskList(repo string, build int) ([]*common.Task, error) {
// repository and build number. // repository and build number.
func (db *DB) UpsertTask(repo string, build int, task *common.Task) error { func (db *DB) UpsertTask(repo string, build int, task *common.Task) error {
key := []byte(repo + "/" + strconv.Itoa(build) + "/" + strconv.Itoa(task.Number)) key := []byte(repo + "/" + strconv.Itoa(build) + "/" + strconv.Itoa(task.Number))
return db.Update(func (t *bolt.Tx) error { return db.Update(func(t *bolt.Tx) error {
return update(t, bucketBuildTasks, key, task) return update(t, bucketBuildTasks, key, task)
}) })
} }

View file

@ -33,4 +33,5 @@ func (db *DB) DeleteToken(token *common.Token) error {
return db.Update(func(t *bolt.Tx) error { return db.Update(func(t *bolt.Tx) error {
return delete(t, bucketUser, key) return delete(t, bucketUser, key)
}) })
// TODO(bradrydzewski) remove token from users_token index
} }

View file

@ -1,6 +1,10 @@
package datastore package datastore
import "github.com/drone/drone/common" import (
"io"
"github.com/drone/drone/common"
)
type Datastore interface { type Datastore interface {
// GetUser gets a user by user login. // GetUser gets a user by user login.
@ -123,7 +127,7 @@ type Datastore interface {
// GetTaskLogs gets the task logs at index N for // GetTaskLogs gets the task logs at index N for
// the named repository and build number. // the named repository and build number.
GetTaskLogs(string, int, int) ([]byte, error) GetTaskLogs(string, int, int) (io.Reader, error)
// GetTaskList gets all tasks for the named repository // GetTaskList gets all tasks for the named repository
// and build number. // and build number.

View file

@ -1,6 +1,7 @@
package server package server
import ( import (
"io"
"strconv" "strconv"
"github.com/gin-gonic/gin" "github.com/gin-gonic/gin"
@ -54,13 +55,16 @@ func GetTasks(c *gin.Context) {
func GetTaskLogs(c *gin.Context) { func GetTaskLogs(c *gin.Context) {
ds := ToDatastore(c) ds := ToDatastore(c)
repo := ToRepo(c) repo := ToRepo(c)
full, _ := strconv.ParseBool(c.Params.ByName("full"))
build, _ := strconv.Atoi(c.Params.ByName("number")) build, _ := strconv.Atoi(c.Params.ByName("number"))
task, _ := strconv.Atoi(c.Params.ByName("task")) task, _ := strconv.Atoi(c.Params.ByName("task"))
logs, err := ds.GetTaskLogs(repo.FullName, build, task) logs, err := ds.GetTaskLogs(repo.FullName, build, task)
if err != nil { if err != nil {
c.Fail(404, err) c.Fail(404, err)
} else if full {
io.Copy(c.Writer, logs)
} else { } else {
c.Writer.Write(logs) io.Copy(c.Writer, io.LimitReader(logs, 2000000))
} }
} }