Documentation ¶
Overview ¶
Copyright 2018 the Heptio Ark contributors.
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.
Index ¶
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
This section is empty.
Types ¶
type FileSystem ¶
type FileSystem interface { TempDir(dir, prefix string) (string, error) MkdirAll(path string, perm os.FileMode) error Create(name string) (io.WriteCloser, error) RemoveAll(path string) error ReadDir(dirname string) ([]os.FileInfo, error) ReadFile(filename string) ([]byte, error) DirExists(path string) (bool, error) }
FileSystem defines methods for interacting with an underlying file system.
type ItemAction ¶ added in v0.6.0
type ItemAction interface { // AppliesTo returns information about which resources this action should be invoked for. // An ItemAction's Execute function will only be invoked on items that match the returned // selector. A zero-valued ResourceSelector matches all resources. AppliesTo() (ResourceSelector, error) // Execute allows the ItemAction to perform arbitrary logic with the item being restored, // including mutating the item itself prior to restore. The item (unmodified or modified) // should be returned, along with a warning (which will be logged but will not prevent // the item from being restored) or error (which will be logged and will prevent the item // from being restored) if applicable. Execute(obj runtime.Unstructured, restore *api.Restore) (res runtime.Unstructured, warning error, err error) }
ItemAction is an actor that performs an operation on an individual item being restored.
func NewJobAction ¶ added in v0.6.0
func NewJobAction(logger logrus.FieldLogger) ItemAction
func NewPodAction ¶ added in v0.6.0
func NewPodAction(logger logrus.FieldLogger) ItemAction
func NewResticRestoreAction ¶ added in v0.9.0
func NewResticRestoreAction(logger logrus.FieldLogger) ItemAction
func NewServiceAction ¶ added in v0.6.0
func NewServiceAction(log logrus.FieldLogger) ItemAction
type PVRestorer ¶ added in v0.9.0
type PVRestorer interface {
// contains filtered or unexported methods
}
type ResourceSelector ¶ added in v0.6.0
type ResourceSelector struct { // IncludedNamespaces is a slice of namespace names to match. All // namespaces in this slice, except those in ExcludedNamespaces, // will be matched. A nil/empty slice matches all namespaces. IncludedNamespaces []string // ExcludedNamespaces is a slice of namespace names to exclude. // All namespaces in IncludedNamespaces, *except* those in // this slice, will be matched. ExcludedNamespaces []string // IncludedResources is a slice of resources to match. Resources // may be specified as full names (e.g. "services") or abbreviations // (e.g. "svc"). All resources in this slice, except those in // ExcludedResources, will be matched. A nil/empty slice matches // all resources. IncludedResources []string // ExcludedResources is a slice of resources to exclude. // Resources may be specified as full names (e.g. "services") or // abbreviations (e.g. "svc"). All resources in IncludedResources, // *except* those in this slice, will be matched. ExcludedResources []string // LabelSelector is a string representation of a selector to apply // when matching resources. See "k8s.io/apimachinery/pkg/labels".Parse() // for details on syntax. LabelSelector string }
ResourceSelector is a collection of included/excluded namespaces, included/excluded resources, and a label-selector that can be used to match a set of items from a cluster.
type Restorer ¶
type Restorer interface { // Restore restores the backup data from backupReader, returning warnings and errors. Restore(restore *api.Restore, backup *api.Backup, backupReader io.Reader, logFile io.Writer, actions []ItemAction) (api.RestoreResult, api.RestoreResult) }
Restorer knows how to restore a backup.
func NewKubernetesRestorer ¶
func NewKubernetesRestorer( discoveryHelper discovery.Helper, dynamicFactory client.DynamicFactory, backupService cloudprovider.BackupService, snapshotService cloudprovider.SnapshotService, resourcePriorities []string, backupClient arkv1client.BackupsGetter, namespaceClient corev1.NamespaceInterface, resticRestorerFactory restic.RestorerFactory, resticTimeout time.Duration, logger logrus.FieldLogger, ) (Restorer, error)
NewKubernetesRestorer creates a new kubernetesRestorer.