mirror of
https://github.com/rclone/rclone.git
synced 2025-01-24 23:28:57 +01:00
fs: add optional features UserInfo and Disconnect
This commit is contained in:
parent
a1263e70cf
commit
3ebcb555f4
20
backend/cache/cache.go
vendored
20
backend/cache/cache.go
vendored
@ -1864,6 +1864,24 @@ func cleanPath(p string) string {
|
|||||||
return p
|
return p
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// UserInfo returns info about the connected user
|
||||||
|
func (f *Fs) UserInfo(ctx context.Context) (map[string]string, error) {
|
||||||
|
do := f.Fs.Features().UserInfo
|
||||||
|
if do == nil {
|
||||||
|
return nil, fs.ErrorNotImplemented
|
||||||
|
}
|
||||||
|
return do(ctx)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Disconnect the current user
|
||||||
|
func (f *Fs) Disconnect(ctx context.Context) error {
|
||||||
|
do := f.Fs.Features().Disconnect
|
||||||
|
if do == nil {
|
||||||
|
return fs.ErrorNotImplemented
|
||||||
|
}
|
||||||
|
return do(ctx)
|
||||||
|
}
|
||||||
|
|
||||||
// Check the interfaces are satisfied
|
// Check the interfaces are satisfied
|
||||||
var (
|
var (
|
||||||
_ fs.Fs = (*Fs)(nil)
|
_ fs.Fs = (*Fs)(nil)
|
||||||
@ -1879,4 +1897,6 @@ var (
|
|||||||
_ fs.ListRer = (*Fs)(nil)
|
_ fs.ListRer = (*Fs)(nil)
|
||||||
_ fs.ChangeNotifier = (*Fs)(nil)
|
_ fs.ChangeNotifier = (*Fs)(nil)
|
||||||
_ fs.Abouter = (*Fs)(nil)
|
_ fs.Abouter = (*Fs)(nil)
|
||||||
|
_ fs.UserInfoer = (*Fs)(nil)
|
||||||
|
_ fs.Disconnecter = (*Fs)(nil)
|
||||||
)
|
)
|
||||||
|
@ -802,6 +802,24 @@ func (f *Fs) newDir(ctx context.Context, dir fs.Directory) fs.Directory {
|
|||||||
return newDir
|
return newDir
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// UserInfo returns info about the connected user
|
||||||
|
func (f *Fs) UserInfo(ctx context.Context) (map[string]string, error) {
|
||||||
|
do := f.Fs.Features().UserInfo
|
||||||
|
if do == nil {
|
||||||
|
return nil, fs.ErrorNotImplemented
|
||||||
|
}
|
||||||
|
return do(ctx)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Disconnect the current user
|
||||||
|
func (f *Fs) Disconnect(ctx context.Context) error {
|
||||||
|
do := f.Fs.Features().Disconnect
|
||||||
|
if do == nil {
|
||||||
|
return fs.ErrorNotImplemented
|
||||||
|
}
|
||||||
|
return do(ctx)
|
||||||
|
}
|
||||||
|
|
||||||
// ObjectInfo describes a wrapped fs.ObjectInfo for being the source
|
// ObjectInfo describes a wrapped fs.ObjectInfo for being the source
|
||||||
//
|
//
|
||||||
// This encrypts the remote name and adjusts the size
|
// This encrypts the remote name and adjusts the size
|
||||||
@ -888,6 +906,8 @@ var (
|
|||||||
_ fs.DirCacheFlusher = (*Fs)(nil)
|
_ fs.DirCacheFlusher = (*Fs)(nil)
|
||||||
_ fs.ChangeNotifier = (*Fs)(nil)
|
_ fs.ChangeNotifier = (*Fs)(nil)
|
||||||
_ fs.PublicLinker = (*Fs)(nil)
|
_ fs.PublicLinker = (*Fs)(nil)
|
||||||
|
_ fs.UserInfoer = (*Fs)(nil)
|
||||||
|
_ fs.Disconnecter = (*Fs)(nil)
|
||||||
_ fs.ObjectInfo = (*ObjectInfo)(nil)
|
_ fs.ObjectInfo = (*ObjectInfo)(nil)
|
||||||
_ fs.Object = (*Object)(nil)
|
_ fs.Object = (*Object)(nil)
|
||||||
_ fs.ObjectUnWrapper = (*Object)(nil)
|
_ fs.ObjectUnWrapper = (*Object)(nil)
|
||||||
|
31
fs/fs.go
31
fs/fs.go
@ -69,6 +69,7 @@ var (
|
|||||||
ErrorImmutableModified = errors.New("immutable file modified")
|
ErrorImmutableModified = errors.New("immutable file modified")
|
||||||
ErrorPermissionDenied = errors.New("permission denied")
|
ErrorPermissionDenied = errors.New("permission denied")
|
||||||
ErrorCantShareDirectories = errors.New("this backend can't share directories with link")
|
ErrorCantShareDirectories = errors.New("this backend can't share directories with link")
|
||||||
|
ErrorNotImplemented = errors.New("optional feature not implemented")
|
||||||
)
|
)
|
||||||
|
|
||||||
// RegInfo provides information about a filesystem
|
// RegInfo provides information about a filesystem
|
||||||
@ -588,6 +589,12 @@ type Features struct {
|
|||||||
//
|
//
|
||||||
// It truncates any existing object
|
// It truncates any existing object
|
||||||
OpenWriterAt func(ctx context.Context, remote string, size int64) (WriterAtCloser, error)
|
OpenWriterAt func(ctx context.Context, remote string, size int64) (WriterAtCloser, error)
|
||||||
|
|
||||||
|
// UserInfo returns info about the connected user
|
||||||
|
UserInfo func(ctx context.Context) (map[string]string, error)
|
||||||
|
|
||||||
|
// Disconnect the current user
|
||||||
|
Disconnect func(ctx context.Context) error
|
||||||
}
|
}
|
||||||
|
|
||||||
// Disable nil's out the named feature. If it isn't found then it
|
// Disable nil's out the named feature. If it isn't found then it
|
||||||
@ -703,6 +710,12 @@ func (ft *Features) Fill(f Fs) *Features {
|
|||||||
if do, ok := f.(OpenWriterAter); ok {
|
if do, ok := f.(OpenWriterAter); ok {
|
||||||
ft.OpenWriterAt = do.OpenWriterAt
|
ft.OpenWriterAt = do.OpenWriterAt
|
||||||
}
|
}
|
||||||
|
if do, ok := f.(UserInfoer); ok {
|
||||||
|
ft.UserInfo = do.UserInfo
|
||||||
|
}
|
||||||
|
if do, ok := f.(Disconnecter); ok {
|
||||||
|
ft.Disconnect = do.Disconnect
|
||||||
|
}
|
||||||
return ft.DisableList(Config.DisableFeatures)
|
return ft.DisableList(Config.DisableFeatures)
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -771,6 +784,12 @@ func (ft *Features) Mask(f Fs) *Features {
|
|||||||
if mask.OpenWriterAt == nil {
|
if mask.OpenWriterAt == nil {
|
||||||
ft.OpenWriterAt = nil
|
ft.OpenWriterAt = nil
|
||||||
}
|
}
|
||||||
|
if mask.UserInfo == nil {
|
||||||
|
ft.UserInfo = nil
|
||||||
|
}
|
||||||
|
if mask.Disconnect == nil {
|
||||||
|
ft.Disconnect = nil
|
||||||
|
}
|
||||||
return ft.DisableList(Config.DisableFeatures)
|
return ft.DisableList(Config.DisableFeatures)
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -980,6 +999,18 @@ type OpenWriterAter interface {
|
|||||||
OpenWriterAt(ctx context.Context, remote string, size int64) (WriterAtCloser, error)
|
OpenWriterAt(ctx context.Context, remote string, size int64) (WriterAtCloser, error)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// UserInfoer is an optional interface for Fs
|
||||||
|
type UserInfoer interface {
|
||||||
|
// UserInfo returns info about the connected user
|
||||||
|
UserInfo(ctx context.Context) (map[string]string, error)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Disconnecter is an optional interface for Fs
|
||||||
|
type Disconnecter interface {
|
||||||
|
// Disconnect the current user
|
||||||
|
Disconnect(ctx context.Context) error
|
||||||
|
}
|
||||||
|
|
||||||
// ObjectsChan is a channel of Objects
|
// ObjectsChan is a channel of Objects
|
||||||
type ObjectsChan chan Object
|
type ObjectsChan chan Object
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user