Skip to content

Commit 8982bfa

Browse files
committed
Fixed bug in user delete feature
1 parent 9ac1d19 commit 8982bfa

File tree

2 files changed

+9
-6
lines changed

2 files changed

+9
-6
lines changed

app/Service/DeletionService.php

Lines changed: 6 additions & 5 deletions
Original file line numberDiff line numberDiff line change
@@ -29,7 +29,7 @@ public function __construct(UserService $userService)
2929
$this->userService = $userService;
3030
}
3131

32-
public function deleteOrganization(Organization $organization, bool $inTransaction = true): void
32+
public function deleteOrganization(Organization $organization, bool $inTransaction = true, ?User $ignoreUser = null): void
3333
{
3434
if ($inTransaction) {
3535
DB::transaction(function () use ($organization) {
@@ -85,8 +85,11 @@ public function deleteOrganization(Organization $organization, bool $inTransacti
8585
->get();
8686
$organization->users()->sync([]);
8787

88-
// Make sure all users have at least one organization
88+
// Make sure all users have at least one organization and delete placeholders
8989
foreach ($users as $user) {
90+
if ($ignoreUser !== null && $user->is($ignoreUser)) {
91+
continue;
92+
}
9093
if ($user->is_placeholder) {
9194
$user->delete();
9295
} else {
@@ -140,9 +143,7 @@ public function deleteUser(User $user, bool $inTransaction = true): void
140143
/** @var Member $member */
141144
foreach ($members as $member) {
142145
if ($member->role === Role::Owner->value) {
143-
// Note: The member needs to be deleted first, otherwise the organization delete function will recreate a new personal organization for the user
144-
$member->delete();
145-
$this->deleteOrganization($member->organization, false);
146+
$this->deleteOrganization($member->organization, false, $user);
146147
} else {
147148
$this->userService->makeMemberToPlaceholder($member);
148149
}

tests/Unit/Service/DeletionServiceTest.php

Lines changed: 3 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -224,7 +224,7 @@ public function test_delete_user_rolls_back_on_error_if_transaction_is_active():
224224
$memberOwner = Member::factory()->forUser($user)->forOrganization($organization)->role(Role::Owner)->create();
225225
$otherOrganization = Organization::factory()->create();
226226

227-
$brokenTimeEntry = TimeEntry::factory()->forOrganization($otherOrganization)->forMember($memberOwner)->create();
227+
$brokenTimeEntry = TimeEntry::factory()->forMember($memberOwner)->forOrganization($otherOrganization)->create();
228228

229229
// Act
230230
try {
@@ -310,6 +310,8 @@ public function test_delete_user_deletes_owned_organizations_that_have_only_one_
310310
$organizationNotOwned = Organization::factory()->create();
311311
$memberOwned = Member::factory()->forUser($user)->forOrganization($organizationOwned)->role(Role::Owner)->create();
312312
$memberNotOwned = Member::factory()->forUser($user)->forOrganization($organizationNotOwned)->role(Role::Employee)->create();
313+
TimeEntry::factory()->forOrganization($organizationOwned)->forMember($memberOwned)->createMany(2);
314+
TimeEntry::factory()->forOrganization($organizationNotOwned)->forMember($memberNotOwned)->createMany(2);
313315

314316
// Act
315317
$this->deletionService->deleteUser($user);

0 commit comments

Comments
 (0)