Incorrect sprintf parameter usage

Created on 21 December 2022, about 2 years ago
Updated 24 March 2023, almost 2 years ago

Problem/Motivation

The exception messages in class Drupal\file\FileRepository use sprintf to feed in a destination parameter. However, instead of the normal %s designated placeholder the string has the full word %destination and the parameter is passed as an array. This produces the exception message:

Proposed resolution

Change
sprintf('Invalid stream wrapper: %destination', ['%destination' => $destination])
into
sprintf('Invalid stream wrapper: %s', $destination)

Remaining tasks

There are three exceptions like this in core/modules/file/src/FileRepository.php

πŸ› Bug report
Status

Fixed

Version

9.5

Component
File systemΒ  β†’

Last updated 3 days ago

Created by

πŸ‡¬πŸ‡§United Kingdom jonathan1055

Live updates comments and jobs are added and updated live.
Sign in to follow issues

Comments & Activities

Not all content is available!

It's likely this issue predates Contrib.social: some issue and comment data are missing.

  • πŸ‡ΊπŸ‡ΈUnited States xjm

    I would go a step further than this: The $destination already has a string parameter typehint, so sprintf() doesn't add any value here. I would just concatenate and/or use a double-quoted string. sprintf() is only really useful for formatting numbers and the like. It's not a string sanitization function and just adds overhead for exception messages.

    This also made me curious if we have other places in core where sprintf() was incorrectly treated as if it were t(). I checked:

    [ayrton:drupal | Thu 11:24:15] $ grep -r "sprintf" * |  grep '=>' | grep -v "vendor" | grep -v "node_modules"
    

    I found lots of things that should probably not use sprintf(), but nothing else broken per se.

  • πŸ‡ΊπŸ‡ΈUnited States xjm
  • First commit to issue fork.
  • πŸ‡§πŸ‡·Brazil murilohp

    Hey! I was reviewing this issue and fortunately we do have tests to cover the exceptions itself but we didn't have tests to cover the messages from the exceptions, so I've just added some tests to do that, and I'm also followed @xjm suggestion, instead of using sprintf(), the code can use a double-quoted string, it makes a lot of sense.

    Here's a test only patch.

  • Status changed to Needs review almost 2 years ago
  • πŸ‡¬πŸ‡§United Kingdom jonathan1055

    Thanks @murilohp this looks good. Yes, double-quoted string with {} is perfectly adequate. Nice idea @xjm.

    1) Drupal\Tests\file\Kernel\MoveTest::testInvalidStreamWrapper
    Failed asserting that exception message 'Invalid stream wrapper: 1estination' contains 'Invalid stream wrapper: foo://'
    

    These three failures in the patch prove that the additional 3 line checks are doing what we need. Good that you found a simple place to add them.

    I'm happy to have this RTBC but will wait for @xjm to also review.

  • Status changed to RTBC almost 2 years ago
  • πŸ‡ΊπŸ‡ΈUnited States smustgrave

    This issue is being reviewed by the kind folks in Slack, #needs-review-queue-initiative. We are working to keep the size of Needs Review queue [2700+ issues] to around 400 (1 month or less), following Review a patch or merge request β†’ as a guide.

    Change in MR 3159 looks good and points from #11 appear to be addressed
    #14 shows valid test coverage

    @xjm in #11 you mentioned you found lots. Should a Meta task be opened to address those?

  • πŸ‡¬πŸ‡§United Kingdom longwave UK

    Committed and pushed 465482a571 to 10.1.x and 8caea2cf9b to 10.0.x and 37fb0a9950 to 9.5.x. Thanks!

  • Status changed to Fixed almost 2 years ago
  • Status changed to Fixed almost 2 years ago
  • πŸ‡¬πŸ‡§United Kingdom jonathan1055

    To follow up @xjm's work in #11 and @smustgrave's question in #17, attached is the result of grep -r "sprintf" * | grep '=>' | grep -v "vendor" | grep -v "node_modules" in 10.1.x. There are 35 lines, but some of these are not a problem because the => is before the sprintf and so the array is not part of the sprintf. Therefore it is a small problem, and could be fixed quite easily.

Production build 0.71.5 2024