FileDeleteGadgetChainTest.php

Namespace

Drupal\KernelTests\Core\File

File

core/tests/Drupal/KernelTests/Core/File/FileDeleteGadgetChainTest.php

View source
<?php

declare (strict_types=1);
// cSpell:ignore phpggc
namespace Drupal\KernelTests\Core\File;

use Drupal\KernelTests\KernelTestBase;

/**
 * Tests protection against SA-CORE-2024-006 File Delete Gadget Chain.
 *
 * @group file
 */
class FileDeleteGadgetChainTest extends KernelTestBase {
  
  /**
   * Tests unserializing a File Delete payload.
   */
  public function testFileDeleteGadgetChain() : void {
    file_put_contents('public://canary.txt', 'now you see me');
    // ./phpggc --public-properties Drupal/FD1 public://canary.txt
    $payload = 'O:34:"Drupal\\Core\\Config\\StorageComparer":1:{s:18:"targetCacheStorage";O:39:"Drupal\\Component\\PhpStorage\\FileStorage":1:{s:9:"directory";s:19:"public://canary.txt";}}';
    try {
      unserialize($payload);
      $this->fail('No exception was thrown');
    } catch (\Throwable $e) {
      $this->assertInstanceOf(\TypeError::class, $e);
      $this->assertStringContainsString('Cannot assign Drupal\\Component\\PhpStorage\\FileStorage to property Drupal\\Core\\Config\\StorageComparer::$targetCacheStorage', $e->getMessage());
    }
    $this->assertTrue(file_exists('public://canary.txt'));
    unlink('public://canary.txt');
  }

}

Classes

Title Deprecated Summary
FileDeleteGadgetChainTest Tests protection against SA-CORE-2024-006 File Delete Gadget Chain.

Buggy or inaccurate documentation? Please file an issue. Need support? Need help programming? Connect with the Drupal community.