airshipctl/pkg/events/events.go
Kostiantyn Kalynovskyi 696b287552 Modify executor interface to return channels
Change executors interface to return event channels and allow to
to set event processors. In further development this will allow better
visibility in UI or in command line, also opens the room for concurency.

Also add kubeconfig provider interface that will return kubeconfig.File
object to provide uniform way of accessing kubeconfig

Change-Id: I47bf9409a9b4286905cd9fc4ce172ee33e16dfa6
2020-08-06 17:52:31 -05:00

48 lines
1.3 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 (
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
)
// Event holds all possible events that can be produced by airship
type Event struct {
Type Type
ApplierEvent applyevent.Event
ErrorEvent ErrorEvent
StatusPollerEvent statuspollerevent.Event
}
// ErrorEvent is produced when error is encountered
type ErrorEvent struct {
Error error
}