Skip to content
Snippets Groups Projects
Verified Commit ca113255 authored by Dave Long's avatar Dave Long
Browse files

Issue #3380624 by danflanagan8, lauriii, ioannis.cherouvim: Toolbar username...

Issue #3380624 by danflanagan8, lauriii, ioannis.cherouvim: Toolbar username lazy builder only XSS filters but doesn't escape user display name - stored remote request

(cherry picked from commit 60f2a21d)
parent 03722059
No related branches found
No related tags found
18 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,!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
......@@ -80,7 +80,7 @@ public function renderToolbarLinks() {
*/
public function renderDisplayName() {
return [
'#markup' => $this->account->getDisplayName(),
'#plain_text' => $this->account->getDisplayName(),
];
}
......
<?php
namespace Drupal\Tests\user\Unit;
use Drupal\Core\Session\AccountProxyInterface;
use Drupal\Tests\UnitTestCase;
use Drupal\user\ToolbarLinkBuilder;
/**
* Tests user's ToolbarLinkBuilder.
*
* @coversDefaultClass \Drupal\user\ToolbarLinkBuilder
* @group user
*/
class ToolbarLinkBuilderTest extends UnitTestCase {
/**
* Tests structure of display name render array.
*
* @covers ::renderDisplayName
*/
public function testRenderDisplayName() {
$account = $this->prophesize(AccountProxyInterface::class);
$display_name = 'Something suspicious that should be #plain_text, not #markup';
$account->getDisplayName()->willReturn($display_name);
$toolbar_link_builder = new ToolbarLinkBuilder($account->reveal());
$expected = ['#plain_text' => $display_name];
$this->assertSame($expected, $toolbar_link_builder->renderDisplayName());
}
}
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Please register or to comment