You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
29 lines
840 B
29 lines
840 B
package filer
|
|
|
|
import (
|
|
"fmt"
|
|
"github.com/chrislusf/seaweedfs/weed/pb/filer_pb"
|
|
)
|
|
|
|
func (entry *Entry) IsInRemoteOnly() bool {
|
|
return len(entry.Chunks) == 0 && entry.Remote != nil && entry.Remote.Size > 0
|
|
}
|
|
|
|
func (f *Filer) ReadRemote(entry *Entry, offset int64, size int64) (data []byte, err error) {
|
|
client, _, found := f.RemoteStorage.GetRemoteStorageClient(entry.Remote.StorageName)
|
|
if !found {
|
|
return nil, fmt.Errorf("remote storage %v not found", entry.Remote.StorageName)
|
|
}
|
|
|
|
mountDir, remoteLoation := f.RemoteStorage.FindMountDirectory(entry.FullPath)
|
|
|
|
remoteFullPath := remoteLoation.Path + string(entry.FullPath[len(mountDir):])
|
|
|
|
sourceLoc := &filer_pb.RemoteStorageLocation{
|
|
Name: remoteLoation.Name,
|
|
Bucket: remoteLoation.Bucket,
|
|
Path: remoteFullPath,
|
|
}
|
|
|
|
return client.ReadFile(sourceLoc, offset, size)
|
|
}
|