Skip to content
Snippets Groups Projects
Verified Commit 99901711 authored by Lauri Timmanee's avatar Lauri Timmanee
Browse files

Issue #3366257 by amateescu: The active workspace is not deactivated when it's deleted

(cherry picked from commit 96939a6b)
parent 3dc86aa6
No related branches found
No related tags found
20 merge requests!11628Update file MediaLibraryWidget.php,!7564Revert "Issue #3364773 by roshnichordiya, Chris Matthews, thakurnishant_06,...,!5752Issue #3275828 by joachim, quietone, bradjones1, Berdir: document the reason...,!5627Issue #3261805: Field not saved when change of 0 on string start,!5427Issue #3338518: send credentials in ajax if configured in CORS settings.,!5395Issue #3387916 by fjgarlin, Spokje: Each GitLab job exposes user email,!5217Issue #3386607 by alexpott: Improve spell checking in commit-code-check.sh,!5064Issue #3379522 by finnsky, Gauravvvv, kostyashupenko, smustgrave, Chi: Revert...,!5040SDC ComponentElement: Transform slots scalar values to #plain_text instead of throwing an exception,!4958Issue #3392147: Whitelist IP for a Ban module.,!4894Issue #3280279: Add API to allow sites to opt in to upload SVG images in CKEditor 5,!4857Issue #3336994: StringFormatter always displays links to entity even if the user in context does not have access,!4856Issue #3336994: StringFormatter always displays links to entity even if the user in context does not have access,!4788Issue #3272985: RSS Feed header reverts to text/html when cached,!4716Issue #3362929: Improve 400 responses for broken/invalid image style routes,!4553Draft: Issue #2980951: Permission to see own unpublished comments in comment thread,!3679Issue #115801: Allow password on registration without disabling e-mail verification,!3106Issue #3017548: "Filtered HTML" text format does not support manual teaser break (<!--break-->),!925Issue #2339235: Remove taxonomy hard dependency on node module,!872Draft: Issue #3221319: Race condition when creating menu links and editing content deletes menu links
...@@ -174,16 +174,27 @@ public static function preDelete(EntityStorageInterface $storage, array $entitie ...@@ -174,16 +174,27 @@ public static function preDelete(EntityStorageInterface $storage, array $entitie
public static function postDelete(EntityStorageInterface $storage, array $entities) { public static function postDelete(EntityStorageInterface $storage, array $entities) {
parent::postDelete($storage, $entities); parent::postDelete($storage, $entities);
// Add the IDs of the deleted workspaces to the list of workspaces that will /** @var \Drupal\workspaces\WorkspaceManagerInterface $workspace_manager */
// be purged on cron. $workspace_manager = \Drupal::service('workspaces.manager');
$state = \Drupal::state(); // Disable the currently active workspace if it has been deleted.
$deleted_workspace_ids = $state->get('workspace.deleted', []); if ($workspace_manager->hasActiveWorkspace()
$deleted_workspace_ids += array_combine(array_keys($entities), array_keys($entities)); && in_array($workspace_manager->getActiveWorkspace()->id(), array_keys($entities), TRUE)) {
$state->set('workspace.deleted', $deleted_workspace_ids); $workspace_manager->switchToLive();
}
// Trigger a batch purge to allow empty workspaces to be deleted
// immediately. // Ensure that workspace batch purging does not happen inside a workspace.
\Drupal::service('workspaces.manager')->purgeDeletedWorkspacesBatch(); $workspace_manager->executeOutsideWorkspace(function () use ($workspace_manager, $entities) {
// Add the IDs of the deleted workspaces to the list of workspaces that will
// be purged on cron.
$state = \Drupal::state();
$deleted_workspace_ids = $state->get('workspace.deleted', []);
$deleted_workspace_ids += array_combine(array_keys($entities), array_keys($entities));
$state->set('workspace.deleted', $deleted_workspace_ids);
// Trigger a batch purge to allow empty workspaces to be deleted
// immediately.
$workspace_manager->purgeDeletedWorkspacesBatch();
});
} }
} }
...@@ -201,6 +201,9 @@ public function testDeletingWorkspaces() { ...@@ -201,6 +201,9 @@ public function testDeletingWorkspaces() {
$workspace_deleted = \Drupal::state()->get('workspace.deleted'); $workspace_deleted = \Drupal::state()->get('workspace.deleted');
$this->assertCount(0, $workspace_deleted); $this->assertCount(0, $workspace_deleted);
// Check that the deleted workspace is no longer active.
$this->assertFalse($this->workspaceManager->hasActiveWorkspace());
} }
/** /**
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment