From 565410d8e266b4d0391b10d15339f700dcb1f789 Mon Sep 17 00:00:00 2001 From: Robin Date: Fri, 7 May 2010 22:50:59 +0200 Subject: use an abstraction for file system functions to allow premisions and multiply storage backends --- files/get_files.php | 2 +- files/open_file.php | 31 +++++-------------------------- 2 files changed, 6 insertions(+), 27 deletions(-) (limited to 'files') diff --git a/files/get_files.php b/files/get_files.php index 21866dbf636..1481bb6f84b 100755 --- a/files/get_files.php +++ b/files/get_files.php @@ -42,7 +42,7 @@ function return_bytes($val) { header('Content-type: application/xml'); $dir=isset($_GET['dir'])?$_GET['dir']:''; -$files=OC_FILES::getdirectorycontent(realpath($CONFIG_DATADIRECTORY.'/'.$dir)); +$files=OC_FILES::getdirectorycontent($dir); $dirname=(isset($files[0]))?$files[0]['directory']:''; $dirname=substr($dirname,strrpos($dirname,'/')); $max_upload=min(return_bytes(ini_get('post_max_size')),return_bytes(ini_get('upload_max_filesize'))); diff --git a/files/open_file.php b/files/open_file.php index 933efa51e1e..e1b82dcd37b 100755 --- a/files/open_file.php +++ b/files/open_file.php @@ -24,40 +24,19 @@ require_once('../inc/lib_base.php'); -function get_mime_type($filename, $mimePath = '../etc') { - $fileext = substr(strrchr($filename, '.'), 1); - if (empty($fileext)) return (false); - $regex = "/^([\w\+\-\.\/]+)\s+(\w+\s)*($fileext\s)/i"; - $lines = file("$mimePath/mime.types"); - foreach($lines as $line) { - if (substr($line, 0, 1) == '#') continue; // skip comments - $line = rtrim($line) . " "; - if (!preg_match($regex, $line, $matches)) continue; // no match to the extension - return ($matches[1]); - } - return (false); // no match at all -} - $file=$_GET['file']; $dir=(isset($_GET['dir']))?$_GET['dir']:''; if(strstr($file,'..') or strstr($dir,'..')){ die(); } -$filename=$CONFIG_DATADIRECTORY.'/'.$dir.'/'.$file; -// $ftype='application/octet-stream'; -// $finfo=new finfo(FILEINFO_MIME); -// $fres=@$finfo->file($filename); -// if (is_string($fres) && !empty($fres)) { -// $ftype = $fres; -// } -$ftype=get_mime_type($filename); +$filename=$dir.'/'.$file; +$ftype=OC_FILESYSTEM::getMimeType($filename); ob_end_clean(); -// echo $ftype; -// die(); header('Content-Type: '.$ftype); header('Expires: 0'); header('Cache-Control: must-revalidate, post-check=0, pre-check=0'); header('Pragma: public'); -header('Content-Length: ' . filesize($filename)); -readfile($filename); +header('Content-Length: ' . OC_FILESYSTEM::filesize($filename)); + +OC_FILESYSTEM::readfile($filename); ?> \ No newline at end of file -- cgit v1.2.3