Semaphore/api/tasks/logging.go

81 lines
1.5 KiB
Go
Raw Normal View History

package tasks
import (
"bufio"
2016-05-01 13:24:09 +02:00
"encoding/json"
"os/exec"
2016-05-08 11:36:17 +02:00
"time"
log "github.com/Sirupsen/logrus"
2016-05-24 11:55:48 +02:00
"github.com/ansible-semaphore/semaphore/api/sockets"
"github.com/ansible-semaphore/semaphore/util"
)
func (t *task) log(msg string) {
now := time.Now()
2016-04-17 12:41:36 +02:00
for _, user := range t.users {
2016-05-01 13:24:09 +02:00
b, err := json.Marshal(&map[string]interface{}{
"type": "log",
2016-05-08 11:36:17 +02:00
"output": msg,
"time": now,
2016-05-01 13:24:09 +02:00
"task_id": t.task.ID,
"project_id": t.projectID,
})
util.LogPanic(err)
2016-05-01 13:24:09 +02:00
sockets.Message(user, b)
2016-04-17 12:41:36 +02:00
}
pool.logger <- logRecord{
task: t,
output: msg,
time: now,
}
}
// Readln reads from the pipe
2017-07-12 04:08:00 +02:00
func Readln(r *bufio.Reader) (string, error) {
var (
isPrefix = true
err error
2017-07-12 04:08:00 +02:00
line, ln []byte
)
for isPrefix && err == nil {
line, isPrefix, err = r.ReadLine()
ln = append(ln, line...)
}
2017-07-12 04:08:00 +02:00
return string(ln), err
}
func (t *task) logPipe(reader *bufio.Reader) {
line, err := Readln(reader)
for err == nil {
t.log(line)
line, err = Readln(reader)
}
2017-07-12 04:08:00 +02:00
if err != nil && err.Error() != "EOF" {
2017-07-12 06:48:49 +02:00
//don't panic on this errors, sometimes it throw not dangerous "read |0: file already closed" error
util.LogWarningWithFields(err, log.Fields{"error": "Failed to read task output"})
2017-07-12 04:08:00 +02:00
}
}
func (t *task) logCmd(cmd *exec.Cmd) {
stderr, _ := cmd.StderrPipe()
stdout, _ := cmd.StdoutPipe()
2017-07-12 04:08:00 +02:00
go t.logPipe(bufio.NewReader(stderr))
go t.logPipe(bufio.NewReader(stdout))
}
func (t *task) panicOnError(err error, msg string) {
if err != nil {
t.log(msg)
util.LogPanicWithFields(err, log.Fields{"error": msg})
}
}