aboutsummaryrefslogtreecommitdiff
path: root/weed/server/master_grpc_server_collection.go
diff options
context:
space:
mode:
authorChris Lu <chris.lu@uber.com>2019-03-16 13:43:16 -0700
committerChris Lu <chris.lu@uber.com>2019-03-16 13:43:16 -0700
commit657dd2e6c93c02f46b10dfd43fb6e9b38c025ece (patch)
treec23a093382d5ffd0d39dd69b68fb24050daa7f3e /weed/server/master_grpc_server_collection.go
parentb92122b885c8fba189f3c503c17478008806fda7 (diff)
downloadseaweedfs-657dd2e6c93c02f46b10dfd43fb6e9b38c025ece.tar.xz
seaweedfs-657dd2e6c93c02f46b10dfd43fb6e9b38c025ece.zip
add shell command to list all collections
Diffstat (limited to 'weed/server/master_grpc_server_collection.go')
-rw-r--r--weed/server/master_grpc_server_collection.go56
1 files changed, 56 insertions, 0 deletions
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
+}