From 3edb9c2f5ad0ce53ef6b8c9b70198b5089bb2764 Mon Sep 17 00:00:00 2001 From: Ralf Haferkamp Date: Wed, 7 Sep 2022 14:21:41 +0200 Subject: [PATCH] graph: purge home space when deleting a user previously the homespace was just marked as trashed Fixed: #4195 --- services/graph/pkg/service/v0/users.go | 17 ++++++++++++++++- 1 file changed, 16 insertions(+), 1 deletion(-) diff --git a/services/graph/pkg/service/v0/users.go b/services/graph/pkg/service/v0/users.go index c86e7961d3d..5ccb76b8ce2 100644 --- a/services/graph/pkg/service/v0/users.go +++ b/services/graph/pkg/service/v0/users.go @@ -283,8 +283,23 @@ func (g Graph) DeleteUser(w http.ResponseWriter, r *http.Request) { // TODO: check if request contains a homespace and if, check if requesting user has the privilege to // delete it and make sure it is not deleting its own homespace // needs modification of the cs3api + + // Deleting a space a two step process (1. disabling/trashing, 2. purging) + // Do the "disable/trash" step only if the space is not marked as trashed yet: + if _, ok := sp.Opaque.Map["trashed"]; !ok { + _, err := g.gatewayClient.DeleteStorageSpace(r.Context(), &storageprovider.DeleteStorageSpaceRequest{ + Id: &storageprovider.StorageSpaceId{ + OpaqueId: sp.Id.OpaqueId, + }, + }) + if err != nil { + errorcode.InvalidRequest.Render(w, r, http.StatusBadRequest, "could not disable homespace") + return + } + } + purgeFlag := utils.AppendPlainToOpaque(nil, "purge", "") _, err := g.gatewayClient.DeleteStorageSpace(r.Context(), &storageprovider.DeleteStorageSpaceRequest{ - Opaque: opaque, + Opaque: purgeFlag, Id: &storageprovider.StorageSpaceId{ OpaqueId: sp.Id.OpaqueId, },