forked from TrueCloudLab/rclone
sftp: use vendor-specific VFS statistics extension for about if available
See #5763
This commit is contained in:
parent
b4091f282a
commit
5db9a2f831
2 changed files with 48 additions and 10 deletions
|
@ -1324,6 +1324,42 @@ func (f *Fs) Hashes() hash.Set {
|
||||||
|
|
||||||
// About gets usage stats
|
// About gets usage stats
|
||||||
func (f *Fs) About(ctx context.Context) (*fs.Usage, error) {
|
func (f *Fs) About(ctx context.Context) (*fs.Usage, error) {
|
||||||
|
// If server implements the vendor-specific VFS statistics extension prefer that
|
||||||
|
// (OpenSSH implements it on using syscall.Statfs on Linux and API function GetDiskFreeSpace on Windows)
|
||||||
|
c, err := f.getSftpConnection(ctx)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
var vfsStats *sftp.StatVFS
|
||||||
|
if _, found := c.sftpClient.HasExtension("statvfs@openssh.com"); found {
|
||||||
|
fs.Debugf(f, "Server has VFS statistics extension")
|
||||||
|
aboutPath := f.absRoot
|
||||||
|
if aboutPath == "" {
|
||||||
|
aboutPath = "/"
|
||||||
|
}
|
||||||
|
fs.Debugf(f, "About path %q", aboutPath)
|
||||||
|
vfsStats, err = c.sftpClient.StatVFS(aboutPath)
|
||||||
|
}
|
||||||
|
f.putSftpConnection(&c, err) // Return to pool asap, if running shell command below it will be re-used
|
||||||
|
if vfsStats != nil {
|
||||||
|
total := vfsStats.TotalSpace()
|
||||||
|
free := vfsStats.FreeSpace()
|
||||||
|
used := total - free
|
||||||
|
return &fs.Usage{
|
||||||
|
Total: fs.NewUsageValue(int64(total)),
|
||||||
|
Used: fs.NewUsageValue(int64(used)),
|
||||||
|
Free: fs.NewUsageValue(int64(free)),
|
||||||
|
}, nil
|
||||||
|
} else if err != nil {
|
||||||
|
if errors.Is(err, os.ErrNotExist) {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
fs.Debugf(f, "Failed to retrieve VFS statistics, trying shell command instead: %v", err)
|
||||||
|
} else {
|
||||||
|
fs.Debugf(f, "Server does not have the VFS statistics extension, trying shell command instead")
|
||||||
|
}
|
||||||
|
|
||||||
|
// Fall back to shell command method if possible
|
||||||
if f.shellType == shellTypeNotSupported || f.shellType == "cmd" {
|
if f.shellType == shellTypeNotSupported || f.shellType == "cmd" {
|
||||||
fs.Debugf(f, "About shell command is not available for shell type %q (set option shell_type to override)", f.shellType)
|
fs.Debugf(f, "About shell command is not available for shell type %q (set option shell_type to override)", f.shellType)
|
||||||
return nil, fmt.Errorf("not supported with shell type %q", f.shellType)
|
return nil, fmt.Errorf("not supported with shell type %q", f.shellType)
|
||||||
|
|
|
@ -370,17 +370,19 @@ your RClone backend configuration to disable this behaviour.
|
||||||
|
|
||||||
### About command
|
### About command
|
||||||
|
|
||||||
SFTP supports the [about](/commands/rclone_about/) command if the
|
The `about` command returns the total space, free space, and used
|
||||||
same login has access to a Unix shell, where the `df` command is
|
space on the remote for the disk of the specified path on the remote or,
|
||||||
available (e.g. in the remote's PATH). `about` will return the
|
if not set, the disk of the root on the remote.
|
||||||
total space, free space, and used space on the remote for the disk
|
|
||||||
of the specified path on the remote or, if not set, the disk of
|
|
||||||
the root on the remote. `about` will fail if it does not have
|
|
||||||
shell access or if `df` is not found.
|
|
||||||
|
|
||||||
If the server shell is PowerShell, probably with a Windows OpenSSH
|
SFTP usually supports the [about](/commands/rclone_about/) command, but
|
||||||
server, rclone supports `about` using a built-in shell command
|
it depends on the server. If the server implements the vendor-specific
|
||||||
(see [shell access](#shell-access)).
|
VFS statistics extension, which is normally the case with OpenSSH instances,
|
||||||
|
it will be used. If not, but the same login has access to a Unix shell,
|
||||||
|
where the `df` command is available (e.g. in the remote's PATH), then
|
||||||
|
this will be used instead. If the server shell is PowerShell, probably
|
||||||
|
with a Windows OpenSSH server, rclone will use a built-in shell command
|
||||||
|
(see [shell access](#shell-access)). If none of the above is applicable,
|
||||||
|
`about` will fail.
|
||||||
|
|
||||||
{{< rem autogenerated options start" - DO NOT EDIT - instead edit fs.RegInfo in backend/sftp/sftp.go then run make backenddocs" >}}
|
{{< rem autogenerated options start" - DO NOT EDIT - instead edit fs.RegInfo in backend/sftp/sftp.go then run make backenddocs" >}}
|
||||||
### Standard options
|
### Standard options
|
||||||
|
|
Loading…
Reference in a new issue