forked from TrueCloudLab/restic
sftp: Remove legacy filename/dirname methods
This commit is contained in:
parent
42ea4d257b
commit
74eb293733
1 changed files with 9 additions and 51 deletions
|
@ -93,18 +93,6 @@ func startClient(program string, args ...string) (*SFTP, error) {
|
||||||
return &SFTP{c: client, cmd: cmd, result: ch}, nil
|
return &SFTP{c: client, cmd: cmd, result: ch}, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func paths(dir string) []string {
|
|
||||||
return []string{
|
|
||||||
dir,
|
|
||||||
Join(dir, backend.Paths.Data),
|
|
||||||
Join(dir, backend.Paths.Snapshots),
|
|
||||||
Join(dir, backend.Paths.Index),
|
|
||||||
Join(dir, backend.Paths.Locks),
|
|
||||||
Join(dir, backend.Paths.Keys),
|
|
||||||
Join(dir, backend.Paths.Temp),
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// clientError returns an error if the client has exited. Otherwise, nil is
|
// clientError returns an error if the client has exited. Otherwise, nil is
|
||||||
// returned immediately.
|
// returned immediately.
|
||||||
func (r *SFTP) clientError() error {
|
func (r *SFTP) clientError() error {
|
||||||
|
@ -140,7 +128,7 @@ func Open(cfg Config) (*SFTP, error) {
|
||||||
}
|
}
|
||||||
|
|
||||||
// test if all necessary dirs and files are there
|
// test if all necessary dirs and files are there
|
||||||
for _, d := range paths(cfg.Path) {
|
for _, d := range sftp.Paths() {
|
||||||
if _, err := sftp.c.Lstat(d); err != nil {
|
if _, err := sftp.c.Lstat(d); err != nil {
|
||||||
return nil, errors.Errorf("%s does not exist", d)
|
return nil, errors.Errorf("%s does not exist", d)
|
||||||
}
|
}
|
||||||
|
@ -220,7 +208,7 @@ func Create(cfg Config) (*SFTP, error) {
|
||||||
}
|
}
|
||||||
|
|
||||||
// create paths for data, refs and temp blobs
|
// create paths for data, refs and temp blobs
|
||||||
for _, d := range paths(cfg.Path) {
|
for _, d := range sftp.Paths() {
|
||||||
err = sftp.mkdirAll(d, backend.Modes.Dir)
|
err = sftp.mkdirAll(d, backend.Modes.Dir)
|
||||||
debug.Log("mkdirAll %v -> %v", d, err)
|
debug.Log("mkdirAll %v -> %v", d, err)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
|
@ -276,7 +264,7 @@ func (r *SFTP) mkdirAll(dir string, mode os.FileMode) error {
|
||||||
|
|
||||||
// Rename temp file to final name according to type and name.
|
// Rename temp file to final name according to type and name.
|
||||||
func (r *SFTP) renameFile(oldname string, h restic.Handle) error {
|
func (r *SFTP) renameFile(oldname string, h restic.Handle) error {
|
||||||
filename := r.filename(h)
|
filename := r.Filename(h)
|
||||||
|
|
||||||
// create directories if necessary
|
// create directories if necessary
|
||||||
if h.Type == restic.DataFile {
|
if h.Type == restic.DataFile {
|
||||||
|
@ -312,36 +300,6 @@ func Join(parts ...string) string {
|
||||||
return path.Clean(path.Join(parts...))
|
return path.Clean(path.Join(parts...))
|
||||||
}
|
}
|
||||||
|
|
||||||
// Construct path for given restic.Type and name.
|
|
||||||
func (r *SFTP) filename(h restic.Handle) string {
|
|
||||||
if h.Type == restic.ConfigFile {
|
|
||||||
return Join(r.p, "config")
|
|
||||||
}
|
|
||||||
|
|
||||||
return Join(r.dirname(h), h.Name)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Construct directory for given backend.Type.
|
|
||||||
func (r *SFTP) dirname(h restic.Handle) string {
|
|
||||||
var n string
|
|
||||||
switch h.Type {
|
|
||||||
case restic.DataFile:
|
|
||||||
n = backend.Paths.Data
|
|
||||||
if len(h.Name) > 2 {
|
|
||||||
n = Join(n, h.Name[:2])
|
|
||||||
}
|
|
||||||
case restic.SnapshotFile:
|
|
||||||
n = backend.Paths.Snapshots
|
|
||||||
case restic.IndexFile:
|
|
||||||
n = backend.Paths.Index
|
|
||||||
case restic.LockFile:
|
|
||||||
n = backend.Paths.Locks
|
|
||||||
case restic.KeyFile:
|
|
||||||
n = backend.Paths.Keys
|
|
||||||
}
|
|
||||||
return Join(r.p, n)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Save stores data in the backend at the handle.
|
// Save stores data in the backend at the handle.
|
||||||
func (r *SFTP) Save(h restic.Handle, rd io.Reader) (err error) {
|
func (r *SFTP) Save(h restic.Handle, rd io.Reader) (err error) {
|
||||||
debug.Log("Save %v", h)
|
debug.Log("Save %v", h)
|
||||||
|
@ -404,7 +362,7 @@ func (r *SFTP) Load(h restic.Handle, length int, offset int64) (io.ReadCloser, e
|
||||||
return nil, errors.New("offset is negative")
|
return nil, errors.New("offset is negative")
|
||||||
}
|
}
|
||||||
|
|
||||||
f, err := r.c.Open(r.filename(h))
|
f, err := r.c.Open(r.Filename(h))
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
@ -435,7 +393,7 @@ func (r *SFTP) Stat(h restic.Handle) (restic.FileInfo, error) {
|
||||||
return restic.FileInfo{}, err
|
return restic.FileInfo{}, err
|
||||||
}
|
}
|
||||||
|
|
||||||
fi, err := r.c.Lstat(r.filename(h))
|
fi, err := r.c.Lstat(r.Filename(h))
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return restic.FileInfo{}, errors.Wrap(err, "Lstat")
|
return restic.FileInfo{}, errors.Wrap(err, "Lstat")
|
||||||
}
|
}
|
||||||
|
@ -450,7 +408,7 @@ func (r *SFTP) Test(h restic.Handle) (bool, error) {
|
||||||
return false, err
|
return false, err
|
||||||
}
|
}
|
||||||
|
|
||||||
_, err := r.c.Lstat(r.filename(h))
|
_, err := r.c.Lstat(r.Filename(h))
|
||||||
if os.IsNotExist(errors.Cause(err)) {
|
if os.IsNotExist(errors.Cause(err)) {
|
||||||
return false, nil
|
return false, nil
|
||||||
}
|
}
|
||||||
|
@ -469,7 +427,7 @@ func (r *SFTP) Remove(h restic.Handle) error {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
return r.c.Remove(r.filename(h))
|
return r.c.Remove(r.Filename(h))
|
||||||
}
|
}
|
||||||
|
|
||||||
// List returns a channel that yields all names of blobs of type t. A
|
// List returns a channel that yields all names of blobs of type t. A
|
||||||
|
@ -484,7 +442,7 @@ func (r *SFTP) List(t restic.FileType, done <-chan struct{}) <-chan string {
|
||||||
|
|
||||||
if t == restic.DataFile {
|
if t == restic.DataFile {
|
||||||
// read first level
|
// read first level
|
||||||
basedir := r.dirname(restic.Handle{Type: t})
|
basedir := r.Dirname(restic.Handle{Type: t})
|
||||||
|
|
||||||
list1, err := r.c.ReadDir(basedir)
|
list1, err := r.c.ReadDir(basedir)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
|
@ -517,7 +475,7 @@ func (r *SFTP) List(t restic.FileType, done <-chan struct{}) <-chan string {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
entries, err := r.c.ReadDir(r.dirname(restic.Handle{Type: t}))
|
entries, err := r.c.ReadDir(r.Dirname(restic.Handle{Type: t}))
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue