host

package
v1.13.1 Latest Latest
Warning

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

Go to latest
Published: May 22, 2024 License: MIT Imports: 24 Imported by: 0

README

host Package

The host package provides an abstraction for file and process operations on local and remote SSH hosts.

Documentation

Overview

Provides remote file and command functions

Index

Constants

This section is empty.

Variables

View Source
var (
	ErrInvalidArgs  = errors.New("invalid arguments")
	ErrNotSupported = errors.New("not supported")
	ErrNotAvailable = errors.New("not available")
	ErrExist        = errors.New("already exists")
	ErrNotExist     = errors.New("does not exist")
)
View Source
var Localhost = NewLocal()

Functions

func CopyAll

func CopyAll(srcHost Host, srcDir string, dstHost Host, dstDir string) (err error)

CopyAll copies a directory between any combination of local or remote locations

func CopyFile

func CopyFile(srcHost Host, srcPath string, dstHost Host, dstPath string) (err error)

CopyFile copies a file between two locations. Destination can be a directory or a file. Parent directories will be created as required. Any existing files will be overwritten.

Types

type Host

type Host interface {
	// informational
	String() string
	GetFs() afero.Fs
	Path(p string) string
	Hostname() string
	ServerVersion() string
	IsAvailable() (bool, error)
	IsLocal() bool
	LastError() error
	Username() string

	// file operations
	Abs(name string) (string, error)
	Getwd() (dir string, err error)
	Chown(name string, uid, gid int) (err error)
	Glob(pattern string) (paths []string, err error)
	Lchown(name string, uid, gid int) (err error)
	Lstat(name string) (f fs.FileInfo, err error)
	MkdirAll(p string, perm os.FileMode) (err error)
	ReadDir(name string) (dirs []os.DirEntry, err error)
	ReadFile(name string) (b []byte, err error)
	Readlink(file string) (link string, err error)
	Remove(name string) (err error)
	RemoveAll(name string) (err error)
	Rename(oldpath, newpath string) (err error)
	Stat(name string) (f fs.FileInfo, err error)
	Symlink(oldname, newname string) (err error)
	TempDir() string
	WriteFile(name string, data []byte, perm os.FileMode) (err error)
	// these two do not conform to the afero / os interface
	Open(name string) (f io.ReadSeekCloser, err error)
	Create(p string, perms fs.FileMode) (out io.WriteCloser, err error)

	// process control
	Signal(pid int, signal syscall.Signal) (err error)
	Start(cmd *exec.Cmd, errfile string) (err error)
	Run(cmd *exec.Cmd, errfile string) (stdout []byte, err error)
}

Host encapsulates all the methods required by callers to manage Geneos installs on a host.

This should have been based on (and extending) something like Afero, but this was quicker for the moment. This interface also provides process handling etc.

func NewLocal

func NewLocal() Host

func NewSSHRemote

func NewSSHRemote(name string, options ...any) Host

type Local

type Local struct {
}

Localhost operations

func (*Local) Abs added in v1.6.0

func (h *Local) Abs(dir string) (abs string, err error)

func (*Local) Chown

func (h *Local) Chown(name string, uid, gid int) (err error)

func (*Local) Create

func (h *Local) Create(p string, perms fs.FileMode) (out io.WriteCloser, err error)

func (*Local) GetFs

func (h *Local) GetFs() afero.Fs

func (*Local) Getwd added in v1.6.0

func (h *Local) Getwd() (dir string, err error)

func (*Local) Glob

func (h *Local) Glob(pattern string) (paths []string, err error)

func (*Local) Hostname added in v1.6.0

func (h *Local) Hostname() string

func (*Local) IsAvailable

func (h *Local) IsAvailable() (bool, error)

IsAvailable returns true for Local

func (*Local) IsLocal

func (h *Local) IsLocal() bool

IsLocal returns true if h is local, which for Local it is

func (*Local) LastError

func (h *Local) LastError() error

func (*Local) Lchown

func (h *Local) Lchown(name string, uid, gid int) (err error)

change the symlink ownership on local system, issue chown for remotes

func (*Local) Lstat

func (h *Local) Lstat(name string) (f fs.FileInfo, err error)

Lstat wraps the os.Lstat and sftp.Lstat functions

func (*Local) MkdirAll

func (h *Local) MkdirAll(p string, perm os.FileMode) (err error)

func (*Local) Open

func (h *Local) Open(name string) (f io.ReadSeekCloser, err error)

func (*Local) Path

func (h *Local) Path(p string) string

func (*Local) ReadDir

func (h *Local) ReadDir(name string) (dirs []os.DirEntry, err error)

ReadDir reads the named directory and returns all its directory entries sorted by name.

func (*Local) ReadFile

func (h *Local) ReadFile(name string) (b []byte, err error)
func (h *Local) Readlink(file string) (link string, err error)

func (*Local) Remove

func (h *Local) Remove(name string) (err error)

func (*Local) RemoveAll

func (h *Local) RemoveAll(name string) (err error)

func (*Local) Rename

func (h *Local) Rename(oldpath, newpath string) (err error)

func (*Local) Run

func (h *Local) Run(cmd *exec.Cmd, errfile string) (output []byte, err error)

Run starts a program, waits for completion and returns the output and/or any error. errfile is either absolute or relative to home.

func (*Local) ServerVersion

func (h *Local) ServerVersion() string

func (*Local) Signal

func (h *Local) Signal(pid int, signal syscall.Signal) (err error)

func (*Local) Start

func (h *Local) Start(cmd *exec.Cmd, errfile string) (err error)

func (*Local) Stat

func (h *Local) Stat(name string) (f fs.FileInfo, err error)

Stat wraps the os.Stat and sftp.Stat functions

func (*Local) String

func (h *Local) String() string
func (h *Local) Symlink(oldname, newname string) (err error)

func (*Local) TempDir added in v1.6.3

func (h *Local) TempDir() string

func (*Local) Username

func (h *Local) Username() string

func (*Local) WriteFile

func (h *Local) WriteFile(name string, data []byte, perm os.FileMode) (err error)

type SSHOptions

type SSHOptions func(*SSHRemote)

func Hostname

func Hostname(hostname string) SSHOptions

func Keys

func Keys(paths ...string) SSHOptions

func Password

func Password(password *memguard.Enclave) SSHOptions

func Port

func Port(port uint16) SSHOptions

func Username

func Username(username string) SSHOptions

type SSHRemote

type SSHRemote struct {
	// contains filtered or unexported fields
}

An SSHRemote a type that satisfies the Host interface for SSH attached remote hosts

func (*SSHRemote) Abs added in v1.6.0

func (h *SSHRemote) Abs(dir string) (string, error)

func (*SSHRemote) Chown

func (h *SSHRemote) Chown(name string, uid, gid int) error

func (*SSHRemote) Close

func (h *SSHRemote) Close()

Close a remote host connection

func (*SSHRemote) CloseSFTP

func (h *SSHRemote) CloseSFTP()

func (*SSHRemote) Create

func (h *SSHRemote) Create(p string, perms fs.FileMode) (out io.WriteCloser, err error)

func (*SSHRemote) Dial

func (h *SSHRemote) Dial() (sc *ssh.Client, err error)

Dial connects to a remote host using ssh and returns an *ssh.Client on success. Each connection is cached and returned if found without checking if it is still valid. To remove a session call Close()

func (*SSHRemote) DialSFTP

func (h *SSHRemote) DialSFTP() (f *sftp.Client, err error)

DialSFTP connects to the remote host using SSH and returns an *sftp.Client is successful

func (*SSHRemote) GetFs

func (h *SSHRemote) GetFs() afero.Fs

func (*SSHRemote) Getwd added in v1.6.0

func (h *SSHRemote) Getwd() (dir string, err error)

func (*SSHRemote) Glob

func (h *SSHRemote) Glob(pattern string) ([]string, error)

func (*SSHRemote) Hostname added in v1.6.0

func (s *SSHRemote) Hostname() string

func (*SSHRemote) IsAvailable

func (h *SSHRemote) IsAvailable() (ok bool, err error)

IsAvailable returns true is the remote host can be contacted

func (*SSHRemote) IsLocal

func (h *SSHRemote) IsLocal() bool

IsLocal returns true if h is local, which for SSH is always false

func (*SSHRemote) LastError

func (h *SSHRemote) LastError() error

func (*SSHRemote) Lchown

func (h *SSHRemote) Lchown(name string, uid, gid int) error

Lchown just down a Chown() for remote files

func (*SSHRemote) Lstat

func (h *SSHRemote) Lstat(name string) (fs.FileInfo, error)

Lstat wraps the os.Lstat and sftp.Lstat functions

func (*SSHRemote) MkdirAll

func (h *SSHRemote) MkdirAll(p string, perm os.FileMode) error

func (*SSHRemote) NewSession added in v1.10.2

func (h *SSHRemote) NewSession() (sess *ssh.Session, err error)

NewSession wraps ssh.NewSession but does some retries

func (*SSHRemote) Open

func (h *SSHRemote) Open(name string) (io.ReadSeekCloser, error)

func (*SSHRemote) Path

func (h *SSHRemote) Path(p string) string

func (*SSHRemote) ReadDir

func (h *SSHRemote) ReadDir(name string) (dirs []os.DirEntry, err error)

ReadDir reads the named directory and returns all its directory entries sorted by name.

func (*SSHRemote) ReadFile

func (h *SSHRemote) ReadFile(name string) (b []byte, err error)
func (h *SSHRemote) Readlink(file string) (string, error)

func (*SSHRemote) Remove

func (h *SSHRemote) Remove(name string) error

func (*SSHRemote) RemoveAll

func (h *SSHRemote) RemoveAll(name string) (err error)

func (*SSHRemote) Rename

func (h *SSHRemote) Rename(oldpath, newpath string) error

func (*SSHRemote) Run

func (h *SSHRemote) Run(cmd *exec.Cmd, errfile string) (output []byte, err error)

Run starts a process on an SSH attached remote host h. It uses a shell and waits for the process status before returning. It returns the output and any error. errfile is an optional (remote) file for stderr output

func (*SSHRemote) ServerVersion

func (h *SSHRemote) ServerVersion() string

func (*SSHRemote) Signal

func (h *SSHRemote) Signal(pid int, signal syscall.Signal) (err error)

func (*SSHRemote) Start

func (h *SSHRemote) Start(cmd *exec.Cmd, errfile string) (err error)

Start starts a process on an SSH attached remote host h. It uses a shell and backgrounds and redirects. May not work on all remotes and for all processes.

func (*SSHRemote) Stat

func (h *SSHRemote) Stat(name string) (fs.FileInfo, error)

Stat wraps the os.Stat and sftp.Stat functions

func (*SSHRemote) String

func (h *SSHRemote) String() string
func (h *SSHRemote) Symlink(oldname, newname string) error

func (*SSHRemote) TempDir added in v1.6.3

func (h *SSHRemote) TempDir() string

TempDir returns a path on the remote to a temporary directory

BUG This is currently broken - hardwired values for now

func (*SSHRemote) Username

func (h *SSHRemote) Username() string

func (*SSHRemote) WriteFile

func (h *SSHRemote) WriteFile(name string, data []byte, perm os.FileMode) (err error)

Jump to

Keyboard shortcuts

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