Semaphore/pkg/task_logger/task_logger.go

61 lines
1.4 KiB
Go
Raw Normal View History

package task_logger
import (
"os/exec"
"strings"
"time"
)
2023-09-23 17:12:35 +02:00
type TaskStatus string
const (
2024-01-30 13:47:03 +01:00
TaskWaitingStatus TaskStatus = "waiting"
TaskStartingStatus TaskStatus = "starting"
TaskWaitingConfirmation TaskStatus = "waiting_confirmation"
TaskConfirmed TaskStatus = "confirmed"
TaskRunningStatus TaskStatus = "running"
TaskStoppingStatus TaskStatus = "stopping"
TaskStoppedStatus TaskStatus = "stopped"
TaskSuccessStatus TaskStatus = "success"
TaskFailStatus TaskStatus = "error"
2023-09-23 17:12:35 +02:00
)
func (s TaskStatus) IsNotifiable() bool {
return s == TaskSuccessStatus || s == TaskFailStatus || s == TaskWaitingConfirmation
}
func (s TaskStatus) Format() (res string) {
switch s {
case TaskFailStatus:
res += "❌"
case TaskSuccessStatus:
res += "✅"
case TaskStoppedStatus:
res += "⏹️"
case TaskWaitingConfirmation:
res += "⚠️"
}
res += strings.ToUpper(string(s))
return
}
2023-09-23 17:12:35 +02:00
func (s TaskStatus) IsFinished() bool {
return s == TaskStoppedStatus || s == TaskSuccessStatus || s == TaskFailStatus
}
type StatusListener func(status TaskStatus)
type LogListener func(new time.Time, msg string)
type Logger interface {
Log(msg string)
Logf(format string, a ...any)
LogWithTime(now time.Time, msg string)
LogfWithTime(now time.Time, format string, a ...any)
LogCmd(cmd *exec.Cmd)
2023-09-23 17:12:35 +02:00
SetStatus(status TaskStatus)
AddStatusListener(l StatusListener)
AddLogListener(l LogListener)
}