BUGFIX Case insensitive extension checks in File::validate() (fixes #5781, thanks simon_w) (from r107539)

git-svn-id: svn://svn.silverstripe.com/silverstripe/open/modules/sapphire/trunk@112604 467b73ca-7a2a-4603-9d3b-597d59a354a9
This commit is contained in:
Ingo Schommer 2010-10-15 03:53:54 +00:00
parent b64015e2cf
commit 1c54a6dc77
2 changed files with 8 additions and 2 deletions

View File

@ -770,8 +770,9 @@ class File extends DataObject {
// Extension validation // Extension validation
// TODO Merge this with Upload_Validator // TODO Merge this with Upload_Validator
$extension = $this->getExtension(); $extension = $this->getExtension();
if($extension && !in_array($extension, self::$allowed_extensions)) { $allowed = array_map('strtolower', self::$allowed_extensions);
$exts = self::$allowed_extensions; if($extension && !in_array(strtolower($extension), $allowed)) {
$exts = $allowed;
sort($exts); sort($exts);
$message = sprintf( $message = sprintf(
_t( _t(

View File

@ -60,6 +60,11 @@ class FileTest extends SapphireTest {
$v = $file->validate(); $v = $file->validate();
$this->assertTrue($v->valid()); $this->assertTrue($v->valid());
// Capital extension is valid as well
$file->Name = 'asdf.TXT';
$v = $file->validate();
$this->assertTrue($v->valid());
File::$allowed_extensions = $origExts; File::$allowed_extensions = $origExts;
} }