From 657dd2e6c93c02f46b10dfd43fb6e9b38c025ece Mon Sep 17 00:00:00 2001 From: Chris Lu Date: Sat, 16 Mar 2019 13:43:16 -0700 Subject: add shell command to list all collections --- weed/server/master_grpc_server_collection.go | 56 ++++++++++++++++++++++++++++ 1 file changed, 56 insertions(+) create mode 100644 weed/server/master_grpc_server_collection.go (limited to 'weed/server/master_grpc_server_collection.go') diff --git a/weed/server/master_grpc_server_collection.go b/weed/server/master_grpc_server_collection.go new file mode 100644 index 000000000..23188d856 --- /dev/null +++ b/weed/server/master_grpc_server_collection.go @@ -0,0 +1,56 @@ +package weed_server + +import ( + "context" + "fmt" + "github.com/chrislusf/raft" + "github.com/chrislusf/seaweedfs/weed/operation" + "github.com/chrislusf/seaweedfs/weed/pb/master_pb" + "github.com/chrislusf/seaweedfs/weed/pb/volume_server_pb" +) + +func (ms *MasterServer) CollectionList(ctx context.Context, req *master_pb.CollectionListRequest) (*master_pb.CollectionListResponse, error) { + + if !ms.Topo.IsLeader() { + return nil, raft.NotLeaderError + } + + resp := &master_pb.CollectionListResponse{} + collections := ms.Topo.ListCollections() + for _, c := range collections { + resp.Collections = append(resp.Collections, &master_pb.Collection{ + Name: c.Name, + }) + } + + return resp, nil +} + +func (ms *MasterServer) CollectionDelete(ctx context.Context, req *master_pb.CollectionDeleteRequest) (*master_pb.CollectionDeleteResponse, error) { + + if !ms.Topo.IsLeader() { + return nil, raft.NotLeaderError + } + + resp := &master_pb.CollectionDeleteResponse{} + + collection, ok := ms.Topo.FindCollection(req.GetName()) + if !ok { + return resp, fmt.Errorf("collection not found: %v", req.GetName()) + } + + for _, server := range collection.ListVolumeServers() { + err := operation.WithVolumeServerClient(server.Url(), ms.grpcDialOpiton, func(client volume_server_pb.VolumeServerClient) error { + _, deleteErr := client.DeleteCollection(context.Background(), &volume_server_pb.DeleteCollectionRequest{ + Collection: collection.Name, + }) + return deleteErr + }) + if err != nil { + return nil, err + } + } + ms.Topo.DeleteCollection(req.GetName()) + + return resp, nil +} -- cgit v1.2.3