sftp

package
v0.7.2 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Sep 13, 2017 License: BSD-2-Clause Imports: 18 Imported by: 0

Documentation

Overview

Package sftp implements repository storage in a directory on a remote server via the sftp protocol.

Index

Constants

This section is empty.

Variables

This section is empty.

Functions

func Join

func Join(parts ...string) string

Join joins the given paths and cleans them afterwards. This always uses forward slashes, which is required by sftp.

func ParseConfig

func ParseConfig(s string) (interface{}, error)

ParseConfig parses the string s and extracts the sftp config. The supported configuration formats are sftp://user@host/directory

and sftp:user@host:directory.  The directory will be path Cleaned and can
be an absolute path if it starts with a '/' (e.g.
sftp://user@host//absolute and sftp:user@host:/absolute).

func SplitShellArgs

func SplitShellArgs(data string) (cmd string, args []string, err error)

SplitShellArgs returns the list of arguments from a shell command string.

Types

type Config

type Config struct {
	User, Host, Path string
	Layout           string `option:"layout" help:"use this backend directory layout (default: auto-detect)"`
	Command          string `option:"command" help:"specify command to create sftp connection"`
}

Config collects all information required to connect to an sftp server.

type SFTP

type SFTP struct {
	backend.Layout
	Config
	// contains filtered or unexported fields
}

SFTP is a backend in a directory accessed via SFTP.

func Create

func Create(cfg Config) (*SFTP, error)

Create creates an sftp backend as described by the config by running "ssh" with the appropriate arguments (or cfg.Command, if set).

func Open

func Open(cfg Config) (*SFTP, error)

Open opens an sftp backend as described by the config by running "ssh" with the appropriate arguments (or cfg.Command, if set).

func (*SFTP) Close

func (r *SFTP) Close() error

Close closes the sftp connection and terminates the underlying command.

func (*SFTP) IsNotExist

func (r *SFTP) IsNotExist(err error) bool

IsNotExist returns true if the error is caused by a not existing file.

func (*SFTP) Join

func (r *SFTP) Join(p ...string) string

Join combines path components with slashes (according to the sftp spec).

func (*SFTP) List

func (r *SFTP) List(ctx context.Context, t restic.FileType) <-chan string

List returns a channel that yields all names of blobs of type t. A goroutine is started for this. If the channel done is closed, sending stops.

func (*SFTP) Load

func (r *SFTP) Load(ctx context.Context, h restic.Handle, length int, offset int64) (io.ReadCloser, error)

Load returns a reader that yields the contents of the file at h at the given offset. If length is nonzero, only a portion of the file is returned. rd must be closed after use.

func (*SFTP) Location

func (r *SFTP) Location() string

Location returns this backend's location (the directory name).

func (*SFTP) ReadDir

func (r *SFTP) ReadDir(dir string) ([]os.FileInfo, error)

ReadDir returns the entries for a directory.

func (*SFTP) Remove

func (r *SFTP) Remove(ctx context.Context, h restic.Handle) error

Remove removes the content stored at name.

func (*SFTP) Save

func (r *SFTP) Save(ctx context.Context, h restic.Handle, rd io.Reader) (err error)

Save stores data in the backend at the handle.

func (*SFTP) Stat

func (r *SFTP) Stat(ctx context.Context, h restic.Handle) (restic.FileInfo, error)

Stat returns information about a blob.

func (*SFTP) Test

func (r *SFTP) Test(ctx context.Context, h restic.Handle) (bool, error)

Test returns true if a blob of the given type and name exists in the backend.

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL