woodpecker/store/datastore/logs.go

37 lines
890 B
Go
Raw Normal View History

package datastore
2017-04-03 09:34:37 +00:00
import (
"bytes"
"io"
"io/ioutil"
"github.com/drone/drone/model"
"github.com/drone/drone/store/datastore/sql"
2017-04-03 09:34:37 +00:00
"github.com/russross/meddler"
)
func (db *datastore) LogFind(proc *model.Proc) (io.ReadCloser, error) {
stmt := sql.Lookup(db.driver, "logs-find-proc")
data := new(logData)
err := meddler.QueryRow(db, data, stmt, proc.ID)
buf := bytes.NewBuffer(data.Data)
2017-04-03 09:34:37 +00:00
return ioutil.NopCloser(buf), err
}
func (db *datastore) LogSave(proc *model.Proc, r io.Reader) error {
stmt := sql.Lookup(db.driver, "logs-find-proc")
data := new(logData)
err := meddler.QueryRow(db, data, stmt, proc.ID)
2017-04-03 09:34:37 +00:00
if err != nil {
data = &logData{ProcID: proc.ID}
2017-04-03 09:34:37 +00:00
}
data.Data, _ = ioutil.ReadAll(r)
return meddler.Save(db, "logs", data)
2017-04-03 09:34:37 +00:00
}
type logData struct {
ID int64 `meddler:"log_id,pk"`
ProcID int64 `meddler:"log_job_id"`
Data []byte `meddler:"log_data"`
}