2020-11-27 17:39:22 +01:00
|
|
|
/*
|
|
|
|
Copyright 2020 Docker Compose CLI authors
|
|
|
|
|
|
|
|
Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
you may not use this file except in compliance with the License.
|
|
|
|
You may obtain a copy of the License at
|
|
|
|
|
|
|
|
http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
|
|
|
|
Unless required by applicable law or agreed to in writing, software
|
|
|
|
distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
See the License for the specific language governing permissions and
|
|
|
|
limitations under the License.
|
|
|
|
*/
|
|
|
|
|
|
|
|
package progress
|
|
|
|
|
2023-02-14 16:13:38 +01:00
|
|
|
import (
|
|
|
|
"time"
|
|
|
|
)
|
2020-11-27 17:39:22 +01:00
|
|
|
|
|
|
|
// EventStatus indicates the status of an action
|
|
|
|
type EventStatus int
|
|
|
|
|
2023-04-04 23:00:10 +02:00
|
|
|
func (s EventStatus) colorFn() colorFunc {
|
2023-02-14 16:13:38 +01:00
|
|
|
switch s {
|
|
|
|
case Done:
|
2023-04-04 23:00:10 +02:00
|
|
|
return SuccessColor
|
2023-02-14 16:13:38 +01:00
|
|
|
case Warning:
|
2023-04-04 23:00:10 +02:00
|
|
|
return WarningColor
|
2023-02-14 16:13:38 +01:00
|
|
|
case Error:
|
2023-04-04 23:00:10 +02:00
|
|
|
return ErrorColor
|
2023-02-14 16:13:38 +01:00
|
|
|
default:
|
2023-04-04 23:00:10 +02:00
|
|
|
return nocolor
|
2023-02-14 16:13:38 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-11-27 17:39:22 +01:00
|
|
|
const (
|
|
|
|
// Working means that the current task is working
|
|
|
|
Working EventStatus = iota
|
|
|
|
// Done means that the current task is done
|
|
|
|
Done
|
2022-09-13 15:38:13 +02:00
|
|
|
// Warning means that the current task has warning
|
|
|
|
Warning
|
2023-02-14 16:13:38 +01:00
|
|
|
// Error means that the current task has errored
|
|
|
|
Error
|
2020-11-27 17:39:22 +01:00
|
|
|
)
|
|
|
|
|
|
|
|
// Event represents a progress event.
|
|
|
|
type Event struct {
|
|
|
|
ID string
|
2020-12-03 12:22:01 +01:00
|
|
|
ParentID string
|
2020-11-27 17:39:22 +01:00
|
|
|
Text string
|
|
|
|
Status EventStatus
|
|
|
|
StatusText string
|
2023-02-14 16:13:38 +01:00
|
|
|
Current int64
|
|
|
|
Percent int
|
2020-11-27 17:39:22 +01:00
|
|
|
|
2023-02-14 16:13:38 +01:00
|
|
|
Total int64
|
2020-11-27 17:39:22 +01:00
|
|
|
startTime time.Time
|
|
|
|
endTime time.Time
|
|
|
|
spinner *spinner
|
|
|
|
}
|
|
|
|
|
2020-11-27 18:18:14 +01:00
|
|
|
// ErrorMessageEvent creates a new Error Event with message
|
2022-07-13 01:00:36 +02:00
|
|
|
func ErrorMessageEvent(id string, msg string) Event {
|
|
|
|
return NewEvent(id, Error, msg)
|
2020-11-27 17:39:22 +01:00
|
|
|
}
|
|
|
|
|
2020-11-27 18:18:14 +01:00
|
|
|
// ErrorEvent creates a new Error Event
|
2022-07-13 01:00:36 +02:00
|
|
|
func ErrorEvent(id string) Event {
|
|
|
|
return NewEvent(id, Error, "Error")
|
2020-11-27 18:18:14 +01:00
|
|
|
}
|
|
|
|
|
2020-11-27 17:39:22 +01:00
|
|
|
// CreatingEvent creates a new Create in progress Event
|
2022-07-13 01:00:36 +02:00
|
|
|
func CreatingEvent(id string) Event {
|
|
|
|
return NewEvent(id, Working, "Creating")
|
2020-11-27 17:39:22 +01:00
|
|
|
}
|
|
|
|
|
2020-12-01 20:58:03 +01:00
|
|
|
// StartingEvent creates a new Starting in progress Event
|
2022-07-13 01:00:36 +02:00
|
|
|
func StartingEvent(id string) Event {
|
|
|
|
return NewEvent(id, Working, "Starting")
|
2020-12-01 20:58:03 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
// StartedEvent creates a new Started in progress Event
|
2022-07-13 01:00:36 +02:00
|
|
|
func StartedEvent(id string) Event {
|
|
|
|
return NewEvent(id, Done, "Started")
|
2020-12-01 20:58:03 +01:00
|
|
|
}
|
|
|
|
|
2022-01-07 05:17:10 +01:00
|
|
|
// Waiting creates a new waiting event
|
2022-07-13 01:00:36 +02:00
|
|
|
func Waiting(id string) Event {
|
|
|
|
return NewEvent(id, Working, "Waiting")
|
2022-01-07 05:17:10 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
// Healthy creates a new healthy event
|
2022-07-13 01:00:36 +02:00
|
|
|
func Healthy(id string) Event {
|
|
|
|
return NewEvent(id, Done, "Healthy")
|
2022-01-07 05:17:10 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
// Exited creates a new exited event
|
2022-07-13 01:00:36 +02:00
|
|
|
func Exited(id string) Event {
|
|
|
|
return NewEvent(id, Done, "Exited")
|
2022-01-07 05:17:10 +01:00
|
|
|
}
|
|
|
|
|
2021-03-09 22:09:45 +01:00
|
|
|
// RestartingEvent creates a new Restarting in progress Event
|
2022-07-13 01:00:36 +02:00
|
|
|
func RestartingEvent(id string) Event {
|
|
|
|
return NewEvent(id, Working, "Restarting")
|
2021-03-09 22:09:45 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
// RestartedEvent creates a new Restarted in progress Event
|
2022-07-13 01:00:36 +02:00
|
|
|
func RestartedEvent(id string) Event {
|
|
|
|
return NewEvent(id, Done, "Restarted")
|
2021-03-09 22:09:45 +01:00
|
|
|
}
|
|
|
|
|
2020-12-01 20:58:03 +01:00
|
|
|
// RunningEvent creates a new Running in progress Event
|
2022-07-13 01:00:36 +02:00
|
|
|
func RunningEvent(id string) Event {
|
|
|
|
return NewEvent(id, Done, "Running")
|
2020-12-01 20:58:03 +01:00
|
|
|
}
|
|
|
|
|
2020-11-27 17:39:22 +01:00
|
|
|
// CreatedEvent creates a new Created (done) Event
|
2022-07-13 01:00:36 +02:00
|
|
|
func CreatedEvent(id string) Event {
|
|
|
|
return NewEvent(id, Done, "Created")
|
2020-11-27 17:39:22 +01:00
|
|
|
}
|
|
|
|
|
2021-01-31 18:42:13 +01:00
|
|
|
// StoppingEvent creates a new Stopping in progress Event
|
2022-07-13 01:00:36 +02:00
|
|
|
func StoppingEvent(id string) Event {
|
|
|
|
return NewEvent(id, Working, "Stopping")
|
2020-11-30 21:33:27 +01:00
|
|
|
}
|
|
|
|
|
2021-01-31 18:42:13 +01:00
|
|
|
// StoppedEvent creates a new Stopping in progress Event
|
2022-07-13 01:00:36 +02:00
|
|
|
func StoppedEvent(id string) Event {
|
|
|
|
return NewEvent(id, Done, "Stopped")
|
2021-01-20 13:35:06 +01:00
|
|
|
}
|
|
|
|
|
2021-01-31 18:42:13 +01:00
|
|
|
// KillingEvent creates a new Killing in progress Event
|
2022-07-13 01:00:36 +02:00
|
|
|
func KillingEvent(id string) Event {
|
|
|
|
return NewEvent(id, Working, "Killing")
|
2021-01-31 18:42:13 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
// KilledEvent creates a new Killed in progress Event
|
2022-07-13 01:00:36 +02:00
|
|
|
func KilledEvent(id string) Event {
|
|
|
|
return NewEvent(id, Done, "Killed")
|
2021-01-31 18:42:13 +01:00
|
|
|
}
|
|
|
|
|
2020-11-27 18:18:14 +01:00
|
|
|
// RemovingEvent creates a new Removing in progress Event
|
2022-07-13 01:00:36 +02:00
|
|
|
func RemovingEvent(id string) Event {
|
|
|
|
return NewEvent(id, Working, "Removing")
|
2020-11-27 17:39:22 +01:00
|
|
|
}
|
|
|
|
|
2020-11-27 18:18:14 +01:00
|
|
|
// RemovedEvent creates a new removed (done) Event
|
2022-07-13 01:00:36 +02:00
|
|
|
func RemovedEvent(id string) Event {
|
|
|
|
return NewEvent(id, Done, "Removed")
|
2020-11-27 17:39:22 +01:00
|
|
|
}
|
|
|
|
|
2023-05-10 15:21:34 +02:00
|
|
|
// SkippedEvent creates a new Skipped Event
|
|
|
|
func SkippedEvent(id string, reason string) Event {
|
|
|
|
return Event{
|
|
|
|
ID: id,
|
|
|
|
Status: Warning,
|
|
|
|
StatusText: "Skipped: " + reason,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-11-27 17:39:22 +01:00
|
|
|
// NewEvent new event
|
2022-07-13 01:00:36 +02:00
|
|
|
func NewEvent(id string, status EventStatus, statusText string) Event {
|
2020-11-27 17:39:22 +01:00
|
|
|
return Event{
|
2022-07-13 01:00:36 +02:00
|
|
|
ID: id,
|
2020-11-27 17:39:22 +01:00
|
|
|
Status: status,
|
|
|
|
StatusText: statusText,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func (e *Event) stop() {
|
|
|
|
e.endTime = time.Now()
|
|
|
|
e.spinner.Stop()
|
|
|
|
}
|
2023-02-14 16:13:38 +01:00
|
|
|
|
|
|
|
var (
|
2023-04-04 23:00:10 +02:00
|
|
|
spinnerDone = "✔"
|
|
|
|
spinnerWarning = "!"
|
|
|
|
spinnerError = "✘"
|
2023-02-14 16:13:38 +01:00
|
|
|
)
|
|
|
|
|
|
|
|
func (e *Event) Spinner() any {
|
|
|
|
switch e.Status {
|
|
|
|
case Done:
|
2023-04-04 23:00:10 +02:00
|
|
|
return SuccessColor(spinnerDone)
|
2023-02-14 16:13:38 +01:00
|
|
|
case Warning:
|
2023-04-04 23:00:10 +02:00
|
|
|
return WarningColor(spinnerWarning)
|
2023-02-14 16:13:38 +01:00
|
|
|
case Error:
|
2023-04-04 23:00:10 +02:00
|
|
|
return ErrorColor(spinnerError)
|
2023-02-14 16:13:38 +01:00
|
|
|
default:
|
|
|
|
return e.spinner.String()
|
|
|
|
}
|
|
|
|
}
|