From e1ec253590c01f440d6824ae2e94d71adbc9b6e0 Mon Sep 17 00:00:00 2001 From: Lee Rowlands <lee.rowlands@previousnext.com.au> Date: Mon, 25 Feb 2019 20:35:03 +1000 Subject: [PATCH] Issue #3032620 by alexpott, dww: \Drupal\file\Plugin\rest\resource\FileUploadResource uses basename() when it needs to use the Drupal version --- .../file/src/Plugin/rest/resource/FileUploadResource.php | 2 +- .../tests/src/Functional/FileUploadResourceTestBase.php | 8 +++++--- 2 files changed, 6 insertions(+), 4 deletions(-) diff --git a/core/modules/file/src/Plugin/rest/resource/FileUploadResource.php b/core/modules/file/src/Plugin/rest/resource/FileUploadResource.php index 10810581a22b..8efbb92d5d94 100644 --- a/core/modules/file/src/Plugin/rest/resource/FileUploadResource.php +++ b/core/modules/file/src/Plugin/rest/resource/FileUploadResource.php @@ -377,7 +377,7 @@ protected function validateAndParseContentDispositionHeader(Request $request) { // Make sure only the filename component is returned. Path information is // stripped as per https://tools.ietf.org/html/rfc6266#section-4.3. - return basename($filename); + return $this->fileSystem->basename($filename); } /** diff --git a/core/modules/rest/tests/src/Functional/FileUploadResourceTestBase.php b/core/modules/rest/tests/src/Functional/FileUploadResourceTestBase.php index cb3ef3e27a0f..994a4c3ccb51 100644 --- a/core/modules/rest/tests/src/Functional/FileUploadResourceTestBase.php +++ b/core/modules/rest/tests/src/Functional/FileUploadResourceTestBase.php @@ -373,11 +373,13 @@ public function testFileUploadUnicodeFilename() { $uri = Url::fromUri('base:' . static::$postUri); - $response = $this->fileRequest($uri, $this->testFileData, ['Content-Disposition' => 'file; filename="example-✓.txt"']); + // It is important that the filename starts with a unicode character. See + // https://bugs.php.net/bug.php?id=77239. + $response = $this->fileRequest($uri, $this->testFileData, ['Content-Disposition' => 'file; filename="Èxample-✓.txt"']); $this->assertSame(201, $response->getStatusCode()); - $expected = $this->getExpectedNormalizedEntity(1, 'example-✓.txt', TRUE); + $expected = $this->getExpectedNormalizedEntity(1, 'Èxample-✓.txt', TRUE); $this->assertResponseData($expected, $response); - $this->assertSame($this->testFileData, file_get_contents('public://foobar/example-✓.txt')); + $this->assertSame($this->testFileData, file_get_contents('public://foobar/Èxample-✓.txt')); } /** -- GitLab