Bug #21165
closed
Filenames should be escaped with escapeshellarg before passing them to imagemagick
Added by Helmut Hummel almost 15 years ago.
Updated about 14 years ago.
Description
The problem lies in class.t3lib_stdgraphic.php::wrapFileName() with is
supposed to wrap a filename into double quotes.
Unfortunately it does this task only, if it finds a space character
in the filename. Other special characters which are not allowed on
the shell are not treated.
The better option would be to use escapeshellarg() provided by PHP.
Reported by: Christian Welzel
OTRS ID: 2009080710000036
(issue imported from #M12090)
Files
The 4.2 and 4.1 patches are different because 4.1 doesn't require PHP5 and thus cannot use the "protected" keyword. In addition, my editor removed a trailing space that was there only in the 4.2 branch, but not in the trunk or the 4.1 branch.
+1 by reading (no need to test, easy enough)
The function wrapFileName() is also used in these situations:
t3lib_div::fixPermissions($this->wrapFileName($output));
So calling that on $output with a file with a single quote inside will probably make fixPermission unable to work on that file.
I guess we don't need wrapFileName() when calling fixPermissions, because fixPermissions doesn't call a shell but uses internal PHP functions to work on the file. So we need to remove the wrapFileName within the fixPermissions calls. What do you think??
but will fixPermissions() (or better chmod() and chgrp()) work on files with unexcaped spaces?
Yes, it works on the filename as it is (on the file system). If we escape it, it won't work anymore:
$file = 'this \' is a test.txt';
touch($file); # creates file: this ' is a test.txt
chgrp($file, 'crondevel'); # works
$file = escapeshellarg($file);
chgrp($file, 'crondevel'); # chokes
See trunk-v2 for a proposed solution.
+1 on reading. I'll create an additional patch in a minute that improves the documentation for the fixPermissions function so we won't need to puzzle about this in the future.
comments.diff improves the comments on t3lib_div::fixPermissions (no code changes, just comments).
+1 by reading and testing in 4.3-Trunk
Besides that I tested the following:
touch('File with spaces.txt'); -> works
touch(escapeshellarg('File with spaces.txt')); -> did not work
Thus, the wrapFileName() call can be removed before passing the file to fixPermissions().
Commited to:
trunk (rev.6258 = beta2)
TYPO3_4-2 (rev.6259 = 4.2.10)
TYPO3_4-1 (rev.6260 = 4.1.13)
in thumbs.php there is also a wrapFileName function, which does exactly the same the old one did. It hast to be replaced with a call to t3lib_stdgraphic or this function must be adapted to also escape the filenames
I'll take care of the follow-up.
+1 by reading the follow-ups
+1 by reading the follow-ups
Commited follow-up by Oli Hader (thanks) to:
trunk (rev.6262)
TYPO3_4-2 (rev.6263)
TYPO3_4-1 (rev.6264)
reopened to make it public
Also available in: Atom
PDF