diff --git a/core/assets/scaffold/files/default.settings.php b/core/assets/scaffold/files/default.settings.php index ee3b49c0a8ddaa6ac757e0dd7ac71611c22cecd6..827b6555e93b6d3b36469e5c4888abd37985f863 100644 --- a/core/assets/scaffold/files/default.settings.php +++ b/core/assets/scaffold/files/default.settings.php @@ -616,21 +616,6 @@ # ini_set('pcre.backtrack_limit', 200000); # ini_set('pcre.recursion_limit', 200000); -/** - * Add Permissions-Policy header to disable Google FLoC. - * - * By default, Drupal sends the 'Permissions-Policy: interest-cohort=()' header - * to disable Google's Federated Learning of Cohorts feature, introduced in - * Chrome 89. - * - * See https://en.wikipedia.org/wiki/Federated_Learning_of_Cohorts for more - * information about FLoC. - * - * If you don't wish to disable FLoC in Chrome, you can set this value - * to FALSE. - */ -# $settings['block_interest_cohort'] = TRUE; - /** * Configuration overrides. * diff --git a/core/lib/Drupal/Core/EventSubscriber/FinishResponseSubscriber.php b/core/lib/Drupal/Core/EventSubscriber/FinishResponseSubscriber.php index 2879ae9eabbb183170dfc6deeedac8db40c743ff..23f13695d32f9f87a8e3880c9c8eb5b05cd6c287 100644 --- a/core/lib/Drupal/Core/EventSubscriber/FinishResponseSubscriber.php +++ b/core/lib/Drupal/Core/EventSubscriber/FinishResponseSubscriber.php @@ -125,11 +125,6 @@ public function onRespond(ResponseEvent $event) { $response->headers->set('X-Content-Type-Options', 'nosniff', FALSE); $response->headers->set('X-Frame-Options', 'SAMEORIGIN', FALSE); - // Add a Permissions-Policy header to block Federated Learning of Cohorts. - if (Settings::get('block_interest_cohort', TRUE) && !$response->headers->has('Permissions-Policy')) { - $response->headers->set('Permissions-Policy', 'interest-cohort=()'); - } - // If the current response isn't an implementation of the // CacheableResponseInterface, we assume that a Response is either // explicitly not cacheable or that caching headers are already set in diff --git a/core/lib/Drupal/Core/Site/Settings.php b/core/lib/Drupal/Core/Site/Settings.php index aedae4c951ad02ed3b63a1fd4aa734e546668eea..d9b0f9216dbf2ffa5cb0c87e21f95da3e6c8c622 100644 --- a/core/lib/Drupal/Core/Site/Settings.php +++ b/core/lib/Drupal/Core/Site/Settings.php @@ -37,7 +37,12 @@ final class Settings { * * @see self::handleDeprecations() */ - private static $deprecatedSettings = []; + private static $deprecatedSettings = [ + 'block_interest_cohort' => [ + 'replacement' => '', + 'message' => 'The "block_interest_cohort" setting is deprecated in drupal:9.5.0. This setting should be removed from the settings file, since its usage has been removed. See https://www.drupal.org/node/3320787.', + ], + ]; /** * Constructor. diff --git a/core/tests/Drupal/KernelTests/Core/Http/BlockInterestCohortTest.php b/core/tests/Drupal/KernelTests/Core/Http/BlockInterestCohortTest.php deleted file mode 100644 index 10a7b00438943c5f4b4cd429613e108a4abc26ba..0000000000000000000000000000000000000000 --- a/core/tests/Drupal/KernelTests/Core/Http/BlockInterestCohortTest.php +++ /dev/null @@ -1,83 +0,0 @@ -<?php - -namespace Drupal\KernelTests\Core\Http; - -use Drupal\Core\Site\Settings; -use Drupal\KernelTests\KernelTestBase; -use Symfony\Component\HttpFoundation\Request; -use Symfony\Component\HttpFoundation\Response; -use Symfony\Component\HttpKernel\Event\ResponseEvent; -use Symfony\Component\HttpKernel\HttpKernelInterface; - -/** - * Tests the Permissions-Policy header added by FinishResponseSubscriber. - * - * @group Http - */ -class BlockInterestCohortTest extends KernelTestBase { - - /** - * Tests that FLoC is blocked by default. - */ - public function testDefaultBlocking() { - $request = Request::create('/'); - $response = \Drupal::service('http_kernel')->handle($request); - - $this->assertSame('interest-cohort=()', $response->headers->get('Permissions-Policy')); - } - - /** - * Tests that an existing interest-cohort policy is not overwritten. - */ - public function testExistingInterestCohortPolicy() { - $headers['Permissions-Policy'] = 'interest-cohort=*'; - - $kernel = \Drupal::service('http_kernel'); - $request = Request::create('/'); - $response = new Response('', 200, $headers); - $event = new ResponseEvent($kernel, $request, HttpKernelInterface::MAIN_REQUEST, $response); - \Drupal::service('finish_response_subscriber')->onRespond($event); - - $this->assertSame($headers['Permissions-Policy'], $response->headers->get('Permissions-Policy')); - } - - /** - * Tests that an existing header is not modified. - */ - public function testExistingPolicyHeader() { - $headers['Permissions-Policy'] = 'geolocation=()'; - - $kernel = \Drupal::service('http_kernel'); - $request = Request::create('/'); - $response = new Response('', 200, $headers); - $event = new ResponseEvent($kernel, $request, HttpKernelInterface::MAIN_REQUEST, $response); - \Drupal::service('finish_response_subscriber')->onRespond($event); - - $this->assertSame($headers['Permissions-Policy'], $response->headers->get('Permissions-Policy')); - } - - /** - * Tests that FLoC blocking is ignored for subrequests. - */ - public function testSubrequestBlocking() { - $request = Request::create('/'); - $response = \Drupal::service('http_kernel')->handle($request, HttpKernelInterface::SUB_REQUEST); - - $this->assertFalse($response->headers->has('Permissions-Policy')); - } - - /** - * Tests that FLoC blocking can be disabled in settings.php. - */ - public function testDisableBlockSetting() { - $settings = Settings::getAll(); - $settings['block_interest_cohort'] = FALSE; - new Settings($settings); - - $request = Request::create('/'); - $response = \Drupal::service('http_kernel')->handle($request); - - $this->assertFalse($response->headers->has('Permissions-Policy')); - } - -} diff --git a/core/tests/Drupal/Tests/Core/Site/SettingsTest.php b/core/tests/Drupal/Tests/Core/Site/SettingsTest.php index 5d860aa139255b8cd54f4eb99cc801cc51419da7..6e06b8c1727b01b697d369563876e62a1a8f7b43 100644 --- a/core/tests/Drupal/Tests/Core/Site/SettingsTest.php +++ b/core/tests/Drupal/Tests/Core/Site/SettingsTest.php @@ -305,7 +305,12 @@ public function testRealDeprecatedSettings(string $legacy_setting, string $expec * Provides data for testRealDeprecatedSettings(). */ public function providerTestRealDeprecatedSettings(): array { - return []; + return [ + [ + 'block_interest_cohort', + 'The "block_interest_cohort" setting is deprecated in drupal:9.5.0. This setting should be removed from the settings file, since its usage has been removed. See https://www.drupal.org/node/3320787.', + ], + ]; } /** diff --git a/sites/default/default.settings.php b/sites/default/default.settings.php index ee3b49c0a8ddaa6ac757e0dd7ac71611c22cecd6..827b6555e93b6d3b36469e5c4888abd37985f863 100644 --- a/sites/default/default.settings.php +++ b/sites/default/default.settings.php @@ -616,21 +616,6 @@ # ini_set('pcre.backtrack_limit', 200000); # ini_set('pcre.recursion_limit', 200000); -/** - * Add Permissions-Policy header to disable Google FLoC. - * - * By default, Drupal sends the 'Permissions-Policy: interest-cohort=()' header - * to disable Google's Federated Learning of Cohorts feature, introduced in - * Chrome 89. - * - * See https://en.wikipedia.org/wiki/Federated_Learning_of_Cohorts for more - * information about FLoC. - * - * If you don't wish to disable FLoC in Chrome, you can set this value - * to FALSE. - */ -# $settings['block_interest_cohort'] = TRUE; - /** * Configuration overrides. *