Semaphore/pkg/task_logger/task_logger.go
2025-01-05 15:29:35 +05:00

66 lines
1.5 KiB
Go

package task_logger
import (
"os/exec"
"strings"
"time"
)
type TaskStatus string
const (
TaskWaitingStatus TaskStatus = "waiting"
TaskStartingStatus TaskStatus = "starting"
TaskWaitingConfirmation TaskStatus = "waiting_confirmation"
TaskConfirmed TaskStatus = "confirmed"
TaskRejected TaskStatus = "rejected"
TaskRunningStatus TaskStatus = "running"
TaskStoppingStatus TaskStatus = "stopping"
TaskStoppedStatus TaskStatus = "stopped"
TaskSuccessStatus TaskStatus = "success"
TaskFailStatus TaskStatus = "error"
)
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
}
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)
SetStatus(status TaskStatus)
AddStatusListener(l StatusListener)
AddLogListener(l LogListener)
SetCommit(hash, message string)
WaitLog()
}