mirror of
https://github.com/semaphoreui/semaphore.git
synced 2024-11-24 22:06:43 +01:00
91601eb0eb
* feat(be): add stages * feat(tf): split to plan/apply * fix(be): blocking
61 lines
1.4 KiB
Go
61 lines
1.4 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"
|
|
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)
|
|
}
|