Documentation ¶
Overview ¶
Package drive interfaces with the Google Drive object storage system
Index ¶
- func NewFs(name, path string) (fs.Fs, error)
- type Fs
- func (f *Fs) Copy(src fs.Object, remote string) (fs.Object, error)
- func (f *Fs) CreateDir(pathID, leaf string) (newID string, err error)
- func (f *Fs) DirMove(src fs.Fs) error
- func (f *Fs) FindLeaf(pathID, leaf string) (pathIDOut string, found bool, err error)
- func (f *Fs) List() fs.ObjectsChan
- func (f *Fs) ListDir() fs.DirChan
- func (f *Fs) Mkdir() error
- func (f *Fs) Move(src fs.Object, remote string) (fs.Object, error)
- func (f *Fs) Name() string
- func (f *Fs) NewFsObject(remote string) fs.Object
- func (f *Fs) Precision() time.Duration
- func (f *Fs) Purge() error
- func (f *Fs) Put(in io.Reader, remote string, modTime time.Time, size int64) (fs.Object, error)
- func (f *Fs) Rmdir() error
- func (f *Fs) Root() string
- func (f *Fs) String() string
- func (f *Fs) Upload(in io.Reader, size int64, contentType string, info *drive.File, remote string) (*drive.File, error)
- type Object
- func (o *Object) Fs() fs.Fs
- func (o *Object) Md5sum() (string, error)
- func (o *Object) ModTime() time.Time
- func (o *Object) Open() (in io.ReadCloser, err error)
- func (o *Object) Remote() string
- func (o *Object) Remove() error
- func (o *Object) SetModTime(modTime time.Time)
- func (o *Object) Size() int64
- func (o *Object) Storable() bool
- func (o *Object) String() string
- func (o *Object) Update(in io.Reader, modTime time.Time, size int64) error
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
Types ¶
type Fs ¶
type Fs struct {
// contains filtered or unexported fields
}
Fs represents a remote drive server
func (*Fs) Copy ¶
Copy src to this remote using server side copy operations.
This is stored with the remote path given ¶
It returns the destination Object and a possible error ¶
Will only be called if src.Fs().Name() == f.Name()
If it isn't possible then return fs.ErrorCantCopy
func (*Fs) DirMove ¶
DirMove moves src directory to this remote using server side move operations.
Will only be called if src.Fs().Name() == f.Name()
If it isn't possible then return fs.ErrorCantDirMove
If destination exists then return fs.ErrorDirExists
func (*Fs) List ¶
func (f *Fs) List() fs.ObjectsChan
List walks the path returning a channel of FsObjects
func (*Fs) Move ¶
Move src to this remote using server side move operations.
This is stored with the remote path given ¶
It returns the destination Object and a possible error ¶
Will only be called if src.Fs().Name() == f.Name()
If it isn't possible then return fs.ErrorCantMove
func (*Fs) NewFsObject ¶
NewFsObject returns an FsObject from a path
May return nil if an error occurred
func (*Fs) Purge ¶
Purge deletes all the files and the container
Optional interface: Only implement this if you have a way of deleting all the files quicker than just running Remove() on the result of List()
func (*Fs) Put ¶
Put the object
This assumes that the object doesn't not already exists - if you call it when it does exist then it will create a duplicate. Call object.Update() in this case.
Copy the reader in to the new object which is returned ¶
The new object may have been created if an error is returned
type Object ¶
type Object struct {
// contains filtered or unexported fields
}
Object describes a drive object
func (*Object) ModTime ¶
ModTime returns the modification time of the object
It attempts to read the objects mtime and if that isn't present the LastModified returned in the http headers
func (*Object) SetModTime ¶
SetModTime sets the modification time of the drive fs object