diff options
| author | chrislu <chris.lu@gmail.com> | 2022-04-03 01:07:08 -0700 |
|---|---|---|
| committer | chrislu <chris.lu@gmail.com> | 2022-04-03 01:07:08 -0700 |
| commit | e1dcd15f015e5dadd123982b8f6d51f1f3b99c26 (patch) | |
| tree | f11fd71129d6179c3eea81b3079eb5c09e0f47f1 /pkg/driver/nodeserver.go | |
| parent | 498a0af0ee54b2c06dd0710cf6fd84722ea75912 (diff) | |
| download | seaweedfs-csi-driver-e1dcd15f015e5dadd123982b8f6d51f1f3b99c26.tar.xz seaweedfs-csi-driver-e1dcd15f015e5dadd123982b8f6d51f1f3b99c26.zip | |
support expand volume
Diffstat (limited to 'pkg/driver/nodeserver.go')
| -rw-r--r-- | pkg/driver/nodeserver.go | 26 |
1 files changed, 21 insertions, 5 deletions
diff --git a/pkg/driver/nodeserver.go b/pkg/driver/nodeserver.go index 968f5e4..365fb4c 100644 --- a/pkg/driver/nodeserver.go +++ b/pkg/driver/nodeserver.go @@ -3,15 +3,17 @@ package driver import ( "context" "fmt" - "os" - "strings" - "github.com/chrislusf/seaweedfs/weed/glog" - + "github.com/chrislusf/seaweedfs/weed/pb/mount_pb" "github.com/container-storage-interface/spec/lib/go/csi" + "google.golang.org/grpc" "google.golang.org/grpc/codes" + "google.golang.org/grpc/credentials/insecure" + _ "google.golang.org/grpc/resolver/passthrough" "google.golang.org/grpc/status" "k8s.io/utils/mount" + "os" + "strings" ) type NodeServer struct { @@ -159,7 +161,21 @@ func (ns *NodeServer) NodeStageVolume(ctx context.Context, req *csi.NodeStageVol } func (ns *NodeServer) NodeExpandVolume(ctx context.Context, req *csi.NodeExpandVolumeRequest) (*csi.NodeExpandVolumeResponse, error) { - return &csi.NodeExpandVolumeResponse{}, status.Error(codes.Unimplemented, "NodeExpandVolume is not implemented") + + clientConn, err := grpc.Dial("passthrough:///unix://"+ns.Driver.mountSocket, grpc.WithTransportCredentials(insecure.NewCredentials())) + if err != nil { + return nil, err + } + defer clientConn.Close() + + client := mount_pb.NewSeaweedMountClient(clientConn) + _, err = client.Configure(context.Background(), &mount_pb.ConfigureRequest{ + CollectionCapacity: req.CapacityRange.LimitBytes, + }) + + return &csi.NodeExpandVolumeResponse{ + CapacityBytes: req.CapacityRange.LimitBytes, + }, err } func checkMount(targetPath string) (bool, error) { |
