Skip to content
Snippets Groups Projects
Commit a917ab3a authored by catch's avatar catch
Browse files

Issue #3487482 by amateescu, catch, benjifisher, ekes, finn lewis, fabianx,...

Issue #3487482 by amateescu, catch, benjifisher, ekes, finn lewis, fabianx, larowlan: Creating a published moderated entity in a workspace shouldn't make it published in Live

(cherry picked from commit 9aaa6664)
parent c26c5ee4
No related branches found
No related tags found
3 merge requests!10602Issue #3438769 by vinmayiswamy, antonnavi, michelle, amateescu: Sub workspace does not clear,!10301Issue #3469309 by mstrelan, smustgrave, moshe weitzman: Use one-time login...,!38582585169-10.1.x
Pipeline #341848 passed with warnings
Pipeline: drupal

#341884

    Pipeline: drupal

    #341877

      Pipeline: drupal

      #341875

        +6
        ......@@ -70,15 +70,19 @@ public function testModerationInWorkspace(): void {
        $first_article = $this->drupalGetNodeByTitle('First article - published', TRUE);
        $this->assertEquals('published', $first_article->moderation_state->value);
        $this->assertTrue($first_article->isPublished());
        $second_article = $this->drupalGetNodeByTitle('Second article - draft', TRUE);
        $this->assertEquals('draft', $second_article->moderation_state->value);
        $this->assertFalse($second_article->isPublished());
        // Check that neither of them are visible in Live.
        // Check that neither of them are published in Live.
        $this->switchToLive();
        $this->drupalGet('<front>');
        $this->assertSession()->pageTextNotContains('First article');
        $this->assertSession()->pageTextNotContains('Second article');
        $first_article = $this->drupalGetNodeByTitle('First article - published', TRUE);
        $this->assertFalse($first_article->isPublished());
        $second_article = $this->drupalGetNodeByTitle('Second article - draft', TRUE);
        $this->assertFalse($second_article->isPublished());
        // Switch back to Stage.
        $this->switchToWorkspace($stage);
        ......
        ......@@ -4,6 +4,7 @@
        use Drupal\Core\DependencyInjection\ContainerInjectionInterface;
        use Drupal\Core\Entity\EntityInterface;
        use Drupal\Core\Entity\EntityPublishedInterface;
        use Drupal\Core\Entity\EntityTypeManagerInterface;
        use Drupal\Core\Entity\RevisionableInterface;
        use Drupal\Core\Form\FormStateInterface;
        ......@@ -189,6 +190,7 @@ public function entityInsert(EntityInterface $entity) {
        return;
        }
        assert($entity instanceof RevisionableInterface && $entity instanceof EntityPublishedInterface);
        $this->workspaceAssociation->trackEntity($entity, $this->workspaceManager->getActiveWorkspace());
        // When a published entity is created in a workspace, it should remain
        ......@@ -200,6 +202,12 @@ public function entityInsert(EntityInterface $entity) {
        // entities where there is already a valid default revision for the live
        // workspace.
        if (isset($entity->_initialPublished)) {
        // Ensure that the default revision of an entity saved in a workspace is
        // unpublished.
        if ($entity->isPublished()) {
        throw new \RuntimeException('The default revision of an entity created in a workspace cannot be published.');
        }
        $entity->setPublished();
        $entity->isDefaultRevision(FALSE);
        $entity->save();
        ......
        ......@@ -45,6 +45,13 @@ function workspaces_module_implements_alter(&$implementations, $hook): void {
        if ($hook === 'entity_presave') {
        $implementation = $implementations['workspaces'];
        $implementations = ['workspaces' => $implementation] + $implementations;
        // Move Content Moderation's implementation before Workspaces, so we can
        // alter the publishing status for the default revision.
        if (isset($implementations['content_moderation'])) {
        $implementation = $implementations['content_moderation'];
        $implementations = ['content_moderation' => $implementation] + $implementations;
        }
        }
        // Move our 'hook_entity_insert' implementation at the end to ensure that
        ......
        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