Opened 17 years ago
Closed 17 years ago
#1906 closed Bug (fixed)
PHP connector in filemanager should have better error checking
Reported by: | Kyle | Owned by: | Wiktor Walc |
---|---|---|---|
Priority: | Normal | Milestone: | FCKeditor 2.6 |
Component: | Server : PHP | Version: | FCKeditor 2.5 |
Keywords: | Confirmed Review+ | Cc: |
Description (last modified by )
The PHP connector DetectHTML function does no error checking to make sure that the file was opened or read correctly. This causes a cascade of errors on systems with the PHP open_basedir set to disallow opening of files in the temporary file-upload directory. See the forums post http://www.fckeditor.net/forums/viewtopic.php?f=6&t=8619.
In the file 'editor/filemanager/connectors/php/util.php' starting on line 87 is the DetectHTML function.
Original:
function DetectHtml( $filePath ) { $fp = fopen( $filePath, 'rb' ) ; $chunk = fread( $fp, 1024 ) ; fclose( $fp ) ;
With improved error checking, it should be something like this...
function DetectHtml( $filePath ) { $fp = fopen( $filePath, 'rb' ) ; if ( $fp !== false ) { $chunk = fread( $fp, 1024 ) ; if ( $chunk === false ) { $chunk = ''; } fclose( $fp ) ; } else { $chunk = ''; }
I'm not sure whether it would be better to return TRUE or FALSE in the case of being unable to open and/or read the file. I leave it to the security experts to debate that.
Attachments (1)
Change History (7)
comment:1 Changed 17 years ago by
Description: | modified (diff) |
---|---|
Keywords: | HasPatch added |
Version: | → SVN |
comment:2 Changed 17 years ago by
Milestone: | → FCKeditor 2.6 |
---|---|
Owner: | set to Wiktor Walc |
Status: | new → assigned |
Version: | SVN → FCKeditor 2.5 |
Changed 17 years ago by
Attachment: | 1906.patch added |
---|
comment:3 Changed 17 years ago by
Keywords: | Confirmed Review? added; HasPatch removed |
---|
comment:4 Changed 17 years ago by
Keywords: | Review+ added; Review? removed |
---|
I haven't tested it throughly, but the implementation seems ok.
I would just change line 240: "if" => "else if".
Then, if you have tested it well Wiktor, go ahead committing it. Please include a changelog entry for it.
comment:6 Changed 17 years ago by
Resolution: | → fixed |
---|---|
Status: | assigned → closed |
Thanks Kyle for posting this here. I'm targeting it to 2.6 because it should be fixed as soon as possible.
If DetectHtml() fail to open the uploaded file, it will be checked once again after moving it to the final directory. If the file is invalid, FCKeditor will make an attempt do delete it.