feadd70f34
It will allow users to see what's happening during phase execution. Change-Id: I31c4f98ccbd811ac88c7eabdf5efbe6ffaae6a41 Relates-To: #339
263 lines
6.8 KiB
Go
263 lines
6.8 KiB
Go
/*
|
|
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
|
|
|
|
https://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 events
|
|
|
|
import (
|
|
"fmt"
|
|
"time"
|
|
|
|
applyevent "sigs.k8s.io/cli-utils/pkg/apply/event"
|
|
statuspollerevent "sigs.k8s.io/cli-utils/pkg/kstatus/polling/event"
|
|
)
|
|
|
|
// Type indicates type of the event
|
|
type Type int
|
|
|
|
const (
|
|
// ApplierType is event that are produced by applier
|
|
ApplierType Type = iota
|
|
// ErrorType means that even is of error type
|
|
ErrorType
|
|
// StatusPollerType event produced by status poller
|
|
StatusPollerType
|
|
// WaitType is event emitted when airshipctl is waiting for something
|
|
WaitType
|
|
// ClusterctlType event emitted by Clusterctl executor
|
|
ClusterctlType
|
|
// IsogenType event emitted by Isogen executor
|
|
IsogenType
|
|
// BootstrapType event emitted by Bootstrap executor
|
|
BootstrapType
|
|
//GenericContainerType event emitted by GenericContainer
|
|
GenericContainerType
|
|
)
|
|
|
|
// Event holds all possible events that can be produced by airship
|
|
type Event struct {
|
|
Type Type
|
|
Timestamp time.Time
|
|
ApplierEvent applyevent.Event
|
|
ErrorEvent ErrorEvent
|
|
StatusPollerEvent statuspollerevent.Event
|
|
ClusterctlEvent ClusterctlEvent
|
|
IsogenEvent IsogenEvent
|
|
BootstrapEvent BootstrapEvent
|
|
GenericContainerEvent GenericContainerEvent
|
|
}
|
|
|
|
//GenericEvent generalized type for custom events
|
|
type GenericEvent struct {
|
|
Type string
|
|
Operation string
|
|
Message string
|
|
Timestamp time.Time
|
|
}
|
|
|
|
var mapTypeToEvent = map[Type]string{
|
|
ClusterctlType: "ClusterctlEvent",
|
|
IsogenType: "IsogenEvent",
|
|
BootstrapType: "BootstrapEvent",
|
|
GenericContainerType: "GenericContainerEvent",
|
|
}
|
|
|
|
var unknownEventType = map[Type]string{
|
|
ApplierType: "ApplierType",
|
|
ErrorType: "ErrorType",
|
|
StatusPollerType: "StatusPollerType",
|
|
WaitType: "WaitType",
|
|
}
|
|
|
|
var isogenOperationToString = map[IsogenOperation]string{
|
|
IsogenStart: "IsogenStart",
|
|
IsogenValidation: "IsogenValidation",
|
|
IsogenEnd: "IsogenEnd",
|
|
}
|
|
|
|
var clusterctlOperationToString = map[ClusterctlOperation]string{
|
|
ClusterctlInitStart: "ClusterctlInitStart",
|
|
ClusterctlInitEnd: "ClusterctlInitEnd",
|
|
ClusterctlMoveStart: "ClusterctlMoveStart",
|
|
ClusterctlMoveEnd: "ClusterctlMoveEnd",
|
|
}
|
|
|
|
var bootstrapOperationToString = map[BootstrapOperation]string{
|
|
BootstrapStart: "BootstrapStart",
|
|
BootstrapDryRun: "BootstrapDryRun",
|
|
BootstrapValidation: "BootstrapValidation",
|
|
BootstrapRun: "BootstrapRun",
|
|
BootstrapEnd: "BootstrapEnd",
|
|
}
|
|
|
|
var genericContainerOperationToString = map[GenericContainerOperation]string{
|
|
GenericContainerStart: "GenericContainerStart",
|
|
GenericContainerStop: "GenericContainerStop",
|
|
}
|
|
|
|
//Normalize cast Event to GenericEvent type
|
|
func Normalize(e Event) GenericEvent {
|
|
var eventType string
|
|
if t, exists := mapTypeToEvent[e.Type]; exists {
|
|
eventType = t
|
|
} else {
|
|
eventType = fmt.Sprintf("Unknown event type: %v", unknownEventType[e.Type])
|
|
}
|
|
|
|
var operation, message string
|
|
switch e.Type {
|
|
case ClusterctlType:
|
|
operation = clusterctlOperationToString[e.ClusterctlEvent.Operation]
|
|
message = e.ClusterctlEvent.Message
|
|
case IsogenType:
|
|
operation = isogenOperationToString[e.IsogenEvent.Operation]
|
|
message = e.IsogenEvent.Message
|
|
case BootstrapType:
|
|
operation = bootstrapOperationToString[e.BootstrapEvent.Operation]
|
|
message = e.BootstrapEvent.Message
|
|
case GenericContainerType:
|
|
operation = genericContainerOperationToString[e.GenericContainerEvent.Operation]
|
|
message = e.GenericContainerEvent.Message
|
|
}
|
|
|
|
return GenericEvent{
|
|
Type: eventType,
|
|
Operation: operation,
|
|
Message: message,
|
|
Timestamp: e.Timestamp,
|
|
}
|
|
}
|
|
|
|
// NewEvent create new event with timestamp
|
|
func NewEvent() Event {
|
|
return Event{
|
|
Timestamp: time.Now(),
|
|
}
|
|
}
|
|
|
|
// ErrorEvent is produced when error is encountered
|
|
type ErrorEvent struct {
|
|
Error error
|
|
}
|
|
|
|
// WithErrorEvent sets type and actual error event
|
|
func (e Event) WithErrorEvent(event ErrorEvent) Event {
|
|
e.Type = ErrorType
|
|
e.ErrorEvent = event
|
|
return e
|
|
}
|
|
|
|
// ClusterctlOperation type
|
|
type ClusterctlOperation int
|
|
|
|
const (
|
|
// ClusterctlInitStart operation
|
|
ClusterctlInitStart ClusterctlOperation = iota
|
|
// ClusterctlInitEnd operation
|
|
ClusterctlInitEnd
|
|
// ClusterctlMoveStart operation
|
|
ClusterctlMoveStart
|
|
// ClusterctlMoveEnd operation
|
|
ClusterctlMoveEnd
|
|
)
|
|
|
|
// ClusterctlEvent is produced by clusterctl executor
|
|
type ClusterctlEvent struct {
|
|
Operation ClusterctlOperation
|
|
Message string
|
|
}
|
|
|
|
// WithClusterctlEvent sets type and actual clusterctl event
|
|
func (e Event) WithClusterctlEvent(concreteEvent ClusterctlEvent) Event {
|
|
e.Type = ClusterctlType
|
|
e.ClusterctlEvent = concreteEvent
|
|
return e
|
|
}
|
|
|
|
// IsogenOperation type
|
|
type IsogenOperation int
|
|
|
|
const (
|
|
// IsogenStart operation
|
|
IsogenStart IsogenOperation = iota
|
|
// IsogenValidation operation
|
|
IsogenValidation
|
|
// IsogenEnd operation
|
|
IsogenEnd
|
|
)
|
|
|
|
// IsogenEvent needs to to track events in isogen executor
|
|
type IsogenEvent struct {
|
|
Operation IsogenOperation
|
|
Message string
|
|
}
|
|
|
|
// WithIsogenEvent sets type and actual isogen event
|
|
func (e Event) WithIsogenEvent(concreteEvent IsogenEvent) Event {
|
|
e.Type = IsogenType
|
|
e.IsogenEvent = concreteEvent
|
|
return e
|
|
}
|
|
|
|
// BootstrapOperation type
|
|
type BootstrapOperation int
|
|
|
|
const (
|
|
// BootstrapStart operation
|
|
BootstrapStart BootstrapOperation = iota
|
|
// BootstrapDryRun operation
|
|
BootstrapDryRun
|
|
// BootstrapValidation operation
|
|
BootstrapValidation
|
|
// BootstrapRun operation
|
|
BootstrapRun
|
|
// BootstrapEnd operation
|
|
BootstrapEnd
|
|
)
|
|
|
|
// BootstrapEvent needs to to track events in bootstrap executor
|
|
type BootstrapEvent struct {
|
|
Operation BootstrapOperation
|
|
Message string
|
|
}
|
|
|
|
// WithBootstrapEvent sets type and actual bootstrap event
|
|
func (e Event) WithBootstrapEvent(concreteEvent BootstrapEvent) Event {
|
|
e.Type = BootstrapType
|
|
e.BootstrapEvent = concreteEvent
|
|
return e
|
|
}
|
|
|
|
// GenericContainerOperation type
|
|
type GenericContainerOperation int
|
|
|
|
const (
|
|
// GenericContainerStart operation
|
|
GenericContainerStart GenericContainerOperation = iota
|
|
// GenericContainerStop operation
|
|
GenericContainerStop
|
|
)
|
|
|
|
// GenericContainerEvent needs to to track events in GenericContainer executor
|
|
type GenericContainerEvent struct {
|
|
Operation GenericContainerOperation
|
|
Message string
|
|
}
|
|
|
|
// WithGenericContainerEvent sets type and actual GenericContainer event
|
|
func (e Event) WithGenericContainerEvent(concreteEvent GenericContainerEvent) Event {
|
|
e.Type = GenericContainerType
|
|
e.GenericContainerEvent = concreteEvent
|
|
return e
|
|
}
|