mirror of
https://github.com/seaweedfs/seaweedfs.git
synced 2024-01-19 02:48:24 +00:00
filer mongo list
This commit is contained in:
parent
3c70163798
commit
24a8192298
|
@ -4,6 +4,7 @@ import (
|
||||||
"context"
|
"context"
|
||||||
"fmt"
|
"fmt"
|
||||||
"github.com/chrislusf/seaweedfs/weed/filer2"
|
"github.com/chrislusf/seaweedfs/weed/filer2"
|
||||||
|
"github.com/chrislusf/seaweedfs/weed/glog"
|
||||||
"github.com/chrislusf/seaweedfs/weed/pb/filer_pb"
|
"github.com/chrislusf/seaweedfs/weed/pb/filer_pb"
|
||||||
"github.com/chrislusf/seaweedfs/weed/util"
|
"github.com/chrislusf/seaweedfs/weed/util"
|
||||||
"go.mongodb.org/mongo-driver/bson"
|
"go.mongodb.org/mongo-driver/bson"
|
||||||
|
@ -73,8 +74,6 @@ func (store *MongodbStore) InsertEntry(ctx context.Context, entry *filer2.Entry)
|
||||||
Meta: meta,
|
Meta: meta,
|
||||||
})
|
})
|
||||||
|
|
||||||
fmt.Println(err)
|
|
||||||
|
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -87,7 +86,7 @@ func (store *MongodbStore) FindEntry(ctx context.Context, fullpath util.FullPath
|
||||||
dir, name := fullpath.DirAndName()
|
dir, name := fullpath.DirAndName()
|
||||||
var data Model
|
var data Model
|
||||||
|
|
||||||
var where = bson.M{ "directory": dir, "name": name }
|
var where = bson.M{"directory": dir, "name": name}
|
||||||
err = store.connect.Database(store.database).Collection(store.collectionName).FindOne(ctx, where).Decode(&data)
|
err = store.connect.Database(store.database).Collection(store.collectionName).FindOne(ctx, where).Decode(&data)
|
||||||
if err != mongo.ErrNoDocuments && err != nil {
|
if err != mongo.ErrNoDocuments && err != nil {
|
||||||
return nil, filer_pb.ErrNotFound
|
return nil, filer_pb.ErrNotFound
|
||||||
|
@ -121,7 +120,38 @@ func (store *MongodbStore) DeleteFolderChildren(ctx context.Context, fullpath ut
|
||||||
|
|
||||||
func (store *MongodbStore) ListDirectoryEntries(ctx context.Context, fullpath util.FullPath, startFileName string, inclusive bool, limit int) (entries []*filer2.Entry, err error) {
|
func (store *MongodbStore) ListDirectoryEntries(ctx context.Context, fullpath util.FullPath, startFileName string, inclusive bool, limit int) (entries []*filer2.Entry, err error) {
|
||||||
|
|
||||||
return nil, nil
|
var where = bson.M{"directory": string(fullpath), "name": bson.M{ "$gt": startFileName, }}
|
||||||
|
if inclusive {
|
||||||
|
where["name"] = bson.M{
|
||||||
|
"$gte": startFileName,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
optLimit := int64(limit)
|
||||||
|
cur, err := store.connect.Database(store.database).Collection(store.collectionName).Find(ctx, where, &options.FindOptions{Limit: &optLimit})
|
||||||
|
for cur.Next(ctx) {
|
||||||
|
var data Model
|
||||||
|
err := cur.Decode(&data)
|
||||||
|
if err != nil && err != mongo.ErrNoDocuments {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
|
||||||
|
entry := &filer2.Entry{
|
||||||
|
FullPath: util.NewFullPath(string(fullpath), data.Name),
|
||||||
|
}
|
||||||
|
if decodeErr := entry.DecodeAttributesAndChunks(data.Meta); decodeErr != nil {
|
||||||
|
err = decodeErr
|
||||||
|
glog.V(0).Infof("list %s : %v", entry.FullPath, err)
|
||||||
|
break
|
||||||
|
}
|
||||||
|
|
||||||
|
entries = append(entries, entry)
|
||||||
|
}
|
||||||
|
|
||||||
|
if err := cur.Close(ctx); err != nil {
|
||||||
|
glog.V(0).Infof("list iterator close: %v", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
return entries, err
|
||||||
}
|
}
|
||||||
|
|
||||||
func (store *MongodbStore) Shutdown() {
|
func (store *MongodbStore) Shutdown() {
|
||||||
|
|
Loading…
Reference in a new issue