Merge pull request #646 from skriss/remove-redundant-filesystem
replace pkg/restore's osFileSystem with pkg/util/filesystem'spull/670/head
commit
09afeb6d3e
|
@ -1,75 +0,0 @@
|
||||||
/*
|
|
||||||
Copyright 2017 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.
|
|
||||||
*/
|
|
||||||
|
|
||||||
package restore
|
|
||||||
|
|
||||||
import (
|
|
||||||
"io"
|
|
||||||
"io/ioutil"
|
|
||||||
"os"
|
|
||||||
)
|
|
||||||
|
|
||||||
// FileSystem defines methods for interacting with an
|
|
||||||
// underlying file system.
|
|
||||||
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)
|
|
||||||
}
|
|
||||||
|
|
||||||
var _ FileSystem = &osFileSystem{}
|
|
||||||
|
|
||||||
type osFileSystem struct {
|
|
||||||
}
|
|
||||||
|
|
||||||
func (fs *osFileSystem) TempDir(dir, prefix string) (string, error) {
|
|
||||||
return ioutil.TempDir(dir, prefix)
|
|
||||||
}
|
|
||||||
|
|
||||||
func (fs *osFileSystem) MkdirAll(path string, perm os.FileMode) error {
|
|
||||||
return os.MkdirAll(path, perm)
|
|
||||||
}
|
|
||||||
|
|
||||||
func (fs *osFileSystem) Create(name string) (io.WriteCloser, error) {
|
|
||||||
return os.Create(name)
|
|
||||||
}
|
|
||||||
|
|
||||||
func (fs *osFileSystem) RemoveAll(path string) error {
|
|
||||||
return os.RemoveAll(path)
|
|
||||||
}
|
|
||||||
|
|
||||||
func (fs *osFileSystem) ReadDir(dirname string) ([]os.FileInfo, error) {
|
|
||||||
return ioutil.ReadDir(dirname)
|
|
||||||
}
|
|
||||||
|
|
||||||
func (fs *osFileSystem) ReadFile(filename string) ([]byte, error) {
|
|
||||||
return ioutil.ReadFile(filename)
|
|
||||||
}
|
|
||||||
|
|
||||||
func (fs *osFileSystem) DirExists(path string) (bool, error) {
|
|
||||||
_, err := os.Stat(path)
|
|
||||||
if err == nil {
|
|
||||||
return true, nil
|
|
||||||
}
|
|
||||||
if os.IsNotExist(err) {
|
|
||||||
return false, nil
|
|
||||||
}
|
|
||||||
return false, err
|
|
||||||
}
|
|
|
@ -55,6 +55,7 @@ import (
|
||||||
"github.com/heptio/ark/pkg/restic"
|
"github.com/heptio/ark/pkg/restic"
|
||||||
"github.com/heptio/ark/pkg/util/boolptr"
|
"github.com/heptio/ark/pkg/util/boolptr"
|
||||||
"github.com/heptio/ark/pkg/util/collections"
|
"github.com/heptio/ark/pkg/util/collections"
|
||||||
|
"github.com/heptio/ark/pkg/util/filesystem"
|
||||||
"github.com/heptio/ark/pkg/util/kube"
|
"github.com/heptio/ark/pkg/util/kube"
|
||||||
"github.com/heptio/ark/pkg/util/logging"
|
"github.com/heptio/ark/pkg/util/logging"
|
||||||
arksync "github.com/heptio/ark/pkg/util/sync"
|
arksync "github.com/heptio/ark/pkg/util/sync"
|
||||||
|
@ -80,7 +81,7 @@ type kubernetesRestorer struct {
|
||||||
resticRestorerFactory restic.RestorerFactory
|
resticRestorerFactory restic.RestorerFactory
|
||||||
resticTimeout time.Duration
|
resticTimeout time.Duration
|
||||||
resourcePriorities []string
|
resourcePriorities []string
|
||||||
fileSystem FileSystem
|
fileSystem filesystem.Interface
|
||||||
logger logrus.FieldLogger
|
logger logrus.FieldLogger
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -165,8 +166,9 @@ func NewKubernetesRestorer(
|
||||||
resticRestorerFactory: resticRestorerFactory,
|
resticRestorerFactory: resticRestorerFactory,
|
||||||
resticTimeout: resticTimeout,
|
resticTimeout: resticTimeout,
|
||||||
resourcePriorities: resourcePriorities,
|
resourcePriorities: resourcePriorities,
|
||||||
fileSystem: &osFileSystem{},
|
|
||||||
logger: logger,
|
logger: logger,
|
||||||
|
|
||||||
|
fileSystem: filesystem.NewFileSystem(),
|
||||||
}, nil
|
}, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -326,7 +328,7 @@ type context struct {
|
||||||
selector labels.Selector
|
selector labels.Selector
|
||||||
logger logrus.FieldLogger
|
logger logrus.FieldLogger
|
||||||
dynamicFactory client.DynamicFactory
|
dynamicFactory client.DynamicFactory
|
||||||
fileSystem FileSystem
|
fileSystem filesystem.Interface
|
||||||
namespaceClient corev1.NamespaceInterface
|
namespaceClient corev1.NamespaceInterface
|
||||||
actions []resolvedAction
|
actions []resolvedAction
|
||||||
snapshotService cloudprovider.SnapshotService
|
snapshotService cloudprovider.SnapshotService
|
||||||
|
|
Loading…
Reference in New Issue