From 502133e4603464565693e77cf5a44669f0c94925 Mon Sep 17 00:00:00 2001 From: Alain Kaeslin Date: Wed, 20 Mar 2024 14:35:22 +0100 Subject: [PATCH] Only send API request if NodeID is set in request and volume is attached to that node. --- driver/controller.go | 16 +++++++++++++++- 1 file changed, 15 insertions(+), 1 deletion(-) diff --git a/driver/controller.go b/driver/controller.go index 89270393..1fcbee18 100644 --- a/driver/controller.go +++ b/driver/controller.go @@ -296,7 +296,7 @@ func (d *Driver) ControllerUnpublishVolume(ctx context.Context, req *csi.Control ll.Info("controller unpublish volume called") // check if volume exist before trying to detach it - _, err := d.cloudscaleClient.Volumes.Get(ctx, req.VolumeId) + volume, err := d.cloudscaleClient.Volumes.Get(ctx, req.VolumeId) if err != nil { errorResponse, ok := err.(*cloudscale.ErrorResponse) if ok { @@ -308,6 +308,20 @@ func (d *Driver) ControllerUnpublishVolume(ctx context.Context, req *csi.Control return nil, err } + isAttachedToNode := false + for _, serverUUID := range *volume.ServerUUIDs { + if serverUUID == req.NodeId { + isAttachedToNode = true + } + } + + if req.NodeId != "" && !isAttachedToNode { + ll.WithField("volume", volume).Warn("Volume is not attached to node given in request.") + return &csi.ControllerUnpublishVolumeResponse{}, nil + } + + ll.WithField("volume", volume).Warn("Volume is attached to node given in request or NodeID in request is not set.") + detachRequest := &cloudscale.VolumeRequest{ ServerUUIDs: &[]string{}, }