provide option for automatic backup
This commit is contained in:
parent
565410d8e2
commit
51b253447d
7 changed files with 464 additions and 249 deletions
|
@ -26,9 +26,9 @@ require_once('../inc/lib_base.php');
|
|||
|
||||
$fileName=$_FILES['file']['name'];
|
||||
$source=$_FILES['file']['tmp_name'];
|
||||
$target=$CONFIG_DATADIRECTORY.'/'.$_GET['dir'].'/'.$fileName;
|
||||
$target=$_GET['dir'].'/'.$fileName;
|
||||
if(isset($_SESSION['username']) and $_SESSION['username'] and strpos($_GET['dir'],'..')===false){
|
||||
if(move_uploaded_file($source,$target)){
|
||||
if(OC_FILESYSTEM::fromTmpFile($source,$target)){
|
||||
echo 'true';
|
||||
}else{
|
||||
echo 'false';
|
||||
|
|
|
@ -47,7 +47,9 @@ if($WEBROOT{0}!=='/'){
|
|||
// define default config values
|
||||
$CONFIG_INSTALLED=false;
|
||||
$CONFIG_DATADIRECTORY=$SERVERROOT.'/data';
|
||||
$CONFIG_BACKUPDIRECTORY=$SERVERROOT.'/backup';
|
||||
$CONFIG_HTTPFORCESSL=false;
|
||||
$CONFIG_ENABLEBACKUP=false;
|
||||
$CONFIG_DATEFORMAT='j M Y G:i';
|
||||
$CONFIG_DBNAME='owncloud';
|
||||
$CONFIG_DBTYPE='sqlite';
|
||||
|
@ -69,6 +71,8 @@ if(isset($CONFIG_HTTPFORCESSL) and $CONFIG_HTTPFORCESSL){
|
|||
// load core libs
|
||||
oc_require_once('lib_files.php');
|
||||
oc_require_once('lib_filesystem.php');
|
||||
oc_require_once('lib_filestorage.php');
|
||||
oc_require_once('lib_fileobserver.php');
|
||||
oc_require_once('lib_log.php');
|
||||
oc_require_once('lib_config.php');
|
||||
oc_require_once('lib_user.php');
|
||||
|
@ -87,6 +91,17 @@ if(OC_USER::isLoggedIn()){
|
|||
mkdir($CONFIG_DATADIRECTORY);
|
||||
}
|
||||
$rootStorage=new OC_FILESTORAGE_LOCAL(array('datadir'=>$CONFIG_DATADIRECTORY));
|
||||
if($CONFIG_ENABLEBACKUP){
|
||||
if(!is_dir($CONFIG_BACKUPDIRECTORY)){
|
||||
mkdir($CONFIG_BACKUPDIRECTORY);
|
||||
}
|
||||
if(!is_dir($CONFIG_BACKUPDIRECTORY.'/'.$_SESSION['username_clean'])){
|
||||
mkdir($CONFIG_BACKUPDIRECTORY.'/'.$_SESSION['username_clean']);
|
||||
}
|
||||
$backupStorage=new OC_FILESTORAGE_LOCAL(array('datadir'=>$CONFIG_BACKUPDIRECTORY.'/'.$_SESSION['username_clean']));
|
||||
$backup=new OC_FILEOBSERVER_BACKUP(array('storage'=>$backupStorage));
|
||||
$rootStorage->addObserver($backup);
|
||||
}
|
||||
OC_FILESYSTEM::mount($rootStorage,'/');
|
||||
}
|
||||
|
||||
|
|
|
@ -160,6 +160,9 @@ class OC_CONFIG{
|
|||
if($_POST['dbpassword']<>$_POST['dbpassword2'] ) $error.='database passwords are not the same<br />';
|
||||
|
||||
}
|
||||
if(isset($_POST['enablebackup']) and $_POST['enablebackup']==1){
|
||||
if(!isset($_POST['backupdirectory']) or empty($_POST['backupdirectory'])) $error.='backup directory not set<br />';
|
||||
}
|
||||
if(!$FIRSTRUN){
|
||||
if(!isset($_POST['adminpassword']) or empty($_POST['adminpassword'])){
|
||||
$_POST['adminpassword']=$CONFIG_ADMINPASSWORD;
|
||||
|
@ -226,6 +229,10 @@ class OC_CONFIG{
|
|||
$config.='$CONFIG_INSTALLED=true;'."\n";
|
||||
$config.='$CONFIG_DATADIRECTORY=\''.$_POST['datadirectory']."';\n";
|
||||
if(isset($_POST['forcessl'])) $config.='$CONFIG_HTTPFORCESSL=true'.";\n"; else $config.='$CONFIG_HTTPFORCESSL=false'.";\n";
|
||||
if(isset($_POST['enablebackup'])) $config.='$CONFIG_ENABLEBACKUP=true'.";\n"; else $config.='$CONFIG_ENABLEBACKUP=false'.";\n";
|
||||
if(isset($_POST['enablebackup']) and $_POST['enablebackup']==1){
|
||||
$config.='$CONFIG_BACKUPDIRECTORY=\''.$_POST['backupdirectory']."';\n";
|
||||
}
|
||||
$config.='$CONFIG_DATEFORMAT=\''.$_POST['dateformat']."';\n";
|
||||
$config.='$CONFIG_DBTYPE=\''.$dbtype."';\n";
|
||||
$config.='$CONFIG_DBNAME=\''.$_POST['dbname']."';\n";
|
||||
|
|
82
inc/lib_fileobserver.php
Normal file
82
inc/lib_fileobserver.php
Normal file
|
@ -0,0 +1,82 @@
|
|||
<?php
|
||||
|
||||
/**
|
||||
* ownCloud
|
||||
*
|
||||
* @author Frank Karlitschek
|
||||
* @copyright 2010 Frank Karlitschek karlitschek@kde.org
|
||||
*
|
||||
* This library is free software; you can redistribute it and/or
|
||||
* modify it under the terms of the GNU AFFERO GENERAL PUBLIC LICENSE
|
||||
* License as published by the Free Software Foundation; either
|
||||
* version 3 of the License, or any later version.
|
||||
*
|
||||
* This library is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
* GNU AFFERO GENERAL PUBLIC LICENSE for more details.
|
||||
*
|
||||
* You should have received a copy of the GNU Lesser General Public
|
||||
* License along with this library. If not, see <http://www.gnu.org/licenses/>.
|
||||
*/
|
||||
|
||||
define('OC_FILEACTION_WRITE',2);
|
||||
define('OC_FILEACTION_READ',4);
|
||||
define('OC_FILEACTION_DELETE',8);
|
||||
define('OC_FILEACTION_CREATE',16);
|
||||
define('OC_FILEACTION_RENAME',32);
|
||||
|
||||
/**
|
||||
* base class for file observers
|
||||
*/
|
||||
class OC_FILEOBSERVER{
|
||||
private $mask;
|
||||
|
||||
public function __construct($arguments){}
|
||||
|
||||
public function __get($name){
|
||||
switch($name){
|
||||
case 'mask':
|
||||
return $this->mask;
|
||||
}
|
||||
}
|
||||
|
||||
public function notify($path,$action){}
|
||||
}
|
||||
|
||||
/**
|
||||
* observer that makes automatic backups
|
||||
*/
|
||||
class OC_FILEOBSERVER_BACKUP extends OC_FILEOBSERVER{
|
||||
private $storage;
|
||||
|
||||
public function __construct($arguments){
|
||||
$this->mask=OC_FILEACTION_WRITE+OC_FILEACTION_DELETE+OC_FILEACTION_CREATE+OC_FILEACTION_RENAME;
|
||||
$this->storage=$arguments['storage'];
|
||||
}
|
||||
|
||||
public function notify($path,$action,$storage){
|
||||
switch($action){
|
||||
case OC_FILEACTION_DELETE:
|
||||
if($storage->is_dir($path)){
|
||||
$this->storage->delTree($path);
|
||||
}else{
|
||||
$this->storage->unlink($path);
|
||||
}
|
||||
break;
|
||||
case OC_FILEACTION_CREATE:
|
||||
if($storage->is_dir($path)){
|
||||
$this->storage->mkdir($path);
|
||||
break;
|
||||
}
|
||||
case OC_FILEACTION_WRITE:
|
||||
$tmpFile=$storage->toTmpFile($path);
|
||||
$this->storage->fromTmpFile($tmpFile,$path);
|
||||
break;
|
||||
case OC_FILEACTION_RENAME:
|
||||
list($source,$target)=explode('->',$path);
|
||||
$this->storage->rename($source,$target);
|
||||
}
|
||||
}
|
||||
}
|
||||
?>
|
347
inc/lib_filestorage.php
Normal file
347
inc/lib_filestorage.php
Normal file
|
@ -0,0 +1,347 @@
|
|||
<?php
|
||||
|
||||
/**
|
||||
* ownCloud
|
||||
*
|
||||
* @author Frank Karlitschek
|
||||
* @copyright 2010 Frank Karlitschek karlitschek@kde.org
|
||||
*
|
||||
* This library is free software; you can redistribute it and/or
|
||||
* modify it under the terms of the GNU AFFERO GENERAL PUBLIC LICENSE
|
||||
* License as published by the Free Software Foundation; either
|
||||
* version 3 of the License, or any later version.
|
||||
*
|
||||
* This library is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
* GNU AFFERO GENERAL PUBLIC LICENSE for more details.
|
||||
*
|
||||
* You should have received a copy of the GNU Lesser General Public
|
||||
* License along with this library. If not, see <http://www.gnu.org/licenses/>.
|
||||
*/
|
||||
|
||||
/**
|
||||
* Privde a common interface to all different storage options
|
||||
*/
|
||||
class OC_FILESTORAGE{
|
||||
private $observers=array();
|
||||
/**
|
||||
* add an observer to the list
|
||||
* @param OC_FILEOBERSER observer
|
||||
*/
|
||||
public function addObserver($observer){
|
||||
$this->observers[]=$observer;
|
||||
}
|
||||
/**
|
||||
* notify the observers about an action
|
||||
* @param int action a combination of OC_FILEACTION_WRITE and OC_FILEACTION_READ
|
||||
* @param string path relative path of the file
|
||||
*/
|
||||
public function notifyObservers($path,$action){
|
||||
foreach($this->observers as $observer){
|
||||
if($observer->mask & $action){
|
||||
$observer->notify($path,$action,$this);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
public function __construct($parameters){}
|
||||
public function mkdir($path){}
|
||||
public function rmdir($path){}
|
||||
public function opendir($path){}
|
||||
public function is_dir($path){}
|
||||
public function is_file($path){}
|
||||
public function stat($path){}
|
||||
public function filetype($path){}
|
||||
public function filesize($path){}
|
||||
public function is_readable($path){}
|
||||
public function is_writeable($path){}
|
||||
public function file_exists($path){}
|
||||
public function readfile($path){}
|
||||
public function filectime($path){}
|
||||
public function filemtime($path){}
|
||||
public function fileatime($path){}
|
||||
public function file_get_contents($path){}
|
||||
public function file_put_contents($path){}
|
||||
public function unlink($path){}
|
||||
public function rename($path1,$path2){}
|
||||
public function copy($path1,$path2){}
|
||||
public function fopen($path,$mode){}
|
||||
public function toTmpFile($path){}//copy the file to a temporary file, used for cross-storage file actions
|
||||
public function fromTmpFile($tmpPath,$path){}//copy a file from a temporary file, used for cross-storage file actions
|
||||
public function getMimeType($path){}
|
||||
public function delTree($path){}
|
||||
public function find($path){}
|
||||
}
|
||||
|
||||
/**
|
||||
* for local filestore, we only have to map the paths
|
||||
*/
|
||||
class OC_FILESTORAGE_LOCAL extends OC_FILESTORAGE{
|
||||
private $datadir;
|
||||
public function __construct($arguments){
|
||||
$this->datadir=$arguments['datadir'];
|
||||
if(substr($this->datadir,-1)!=='/'){
|
||||
$this->datadir.='/';
|
||||
}
|
||||
}
|
||||
public function mkdir($path){
|
||||
if($return=mkdir($this->datadir.$path)){
|
||||
$this->notifyObservers($path,OC_FILEACTION_CREATE);
|
||||
}
|
||||
return $return;
|
||||
}
|
||||
public function rmdir($path){
|
||||
if($return=rmdir($this->datadir.$path)){
|
||||
$this->notifyObservers($path,OC_FILEACTION_DELETE);
|
||||
}
|
||||
return $return;
|
||||
}
|
||||
public function opendir($path){
|
||||
if($return=opendir($this->datadir.$path)){
|
||||
$this->notifyObservers($path,OC_FILEACTION_READ);
|
||||
}
|
||||
return $return;
|
||||
}
|
||||
public function is_dir($path){
|
||||
return is_dir($this->datadir.$path);
|
||||
}
|
||||
public function is_file($path){
|
||||
return is_file($this->datadir.$path);
|
||||
}
|
||||
public function stat($path){
|
||||
return stat($this->datadir.$path);
|
||||
}
|
||||
public function filetype($path){
|
||||
return filetype($this->datadir.$path);
|
||||
}
|
||||
public function filesize($path){
|
||||
return filesize($this->datadir.$path);
|
||||
}
|
||||
public function is_readable($path){
|
||||
return is_readable($this->datadir.$path);
|
||||
}
|
||||
public function is_writeable($path){
|
||||
return is_writeable($this->datadir.$path);
|
||||
}
|
||||
public function file_exists($path){
|
||||
return file_exists($this->datadir.$path);
|
||||
}
|
||||
public function readfile($path){
|
||||
if($return=readfile($this->datadir.$path)){
|
||||
$this->notifyObservers($path,OC_FILEACTION_READ);
|
||||
}
|
||||
return $return;
|
||||
}
|
||||
public function filectime($path){
|
||||
return filectime($this->datadir.$path);
|
||||
}
|
||||
public function filemtime($path){
|
||||
return filemtime($this->datadir.$path);
|
||||
}
|
||||
public function fileatime($path){
|
||||
return fileatime($this->datadir.$path);
|
||||
}
|
||||
public function file_get_contents($path){
|
||||
if($return=file_get_contents($this->datadir.$path)){
|
||||
$this->notifyObservers($path,OC_FILEACTION_READ);
|
||||
}
|
||||
return $return;
|
||||
}
|
||||
public function file_put_contents($path){
|
||||
if($return=file_put_contents($this->datadir.$path)){
|
||||
$this->notifyObservers($path,OC_FILEACTION_WRITE);
|
||||
}
|
||||
}
|
||||
public function unlink($path){
|
||||
if($return=unlink($this->datadir.$path)){
|
||||
$this->notifyObservers($path,OC_FILEACTION_DELETE);
|
||||
}
|
||||
return $return;
|
||||
}
|
||||
public function rename($path1,$path2){
|
||||
if($return=rename($this->datadir.$path1,$this->datadir.$path2)){
|
||||
$this->notifyObservers($path1.'->'.$path2,OC_FILEACTION_RENAME);
|
||||
}
|
||||
return $return;
|
||||
}
|
||||
public function copy($path1,$path2){
|
||||
if($return=copy($this->datadir.$path1,$this->datadir.$path2)){
|
||||
$this->notifyObservers($path2,OC_FILEACTION_CREATE);
|
||||
}
|
||||
return $return;
|
||||
}
|
||||
public function fopen($path,$mode){
|
||||
if($return=fopen($this->datadir.$path,$mode)){
|
||||
switch($mode){
|
||||
case 'r':
|
||||
$this->notifyObservers($path,OC_FILEACTION_READ);
|
||||
break;
|
||||
case 'r+':
|
||||
case 'w+':
|
||||
case 'x+':
|
||||
case 'a+':
|
||||
$this->notifyObservers($path,OC_FILEACTION_READ | OC_FILEACTION_WRITE);
|
||||
break;
|
||||
case 'w':
|
||||
case 'x':
|
||||
case 'a':
|
||||
$this->notifyObservers($path,OC_FILEACTION_WRITE);
|
||||
break;
|
||||
}
|
||||
}
|
||||
return $return;
|
||||
}
|
||||
|
||||
public function getMimeType($fspath){
|
||||
if (@is_dir($this->datadir.$fspath)) {
|
||||
// directories are easy
|
||||
return "httpd/unix-directory";
|
||||
} else if (function_exists("mime_content_type")) {
|
||||
// use mime magic extension if available
|
||||
$mime_type = mime_content_type($this->datadir.$fspath);
|
||||
} else if (self::canExecute("file")) {
|
||||
// it looks like we have a 'file' command,
|
||||
// lets see it it does have mime support
|
||||
$fp = popen("file -i '$fspath' 2>/dev/null", "r");
|
||||
$reply = fgets($fp);
|
||||
pclose($fp);
|
||||
|
||||
// popen will not return an error if the binary was not found
|
||||
// and find may not have mime support using "-i"
|
||||
// so we test the format of the returned string
|
||||
|
||||
// the reply begins with the requested filename
|
||||
if (!strncmp($reply, "$fspath: ", strlen($fspath)+2)) {
|
||||
$reply = substr($reply, strlen($fspath)+2);
|
||||
// followed by the mime type (maybe including options)
|
||||
if (preg_match('/^[[:alnum:]_-]+/[[:alnum:]_-]+;?.*/', $reply, $matches)) {
|
||||
$mime_type = $matches[0];
|
||||
}
|
||||
}
|
||||
}
|
||||
if (empty($mime_type)) {
|
||||
// Fallback solution: try to guess the type by the file extension
|
||||
// TODO: add more ...
|
||||
switch (strtolower(strrchr(basename($fspath), "."))) {
|
||||
case ".html":
|
||||
$mime_type = "text/html";
|
||||
break;
|
||||
case ".txt":
|
||||
$mime_type = "text/plain";
|
||||
break;
|
||||
case ".css":
|
||||
$mime_type = "text/css";
|
||||
break;
|
||||
case ".gif":
|
||||
$mime_type = "image/gif";
|
||||
break;
|
||||
case ".jpg":
|
||||
$mime_type = "image/jpeg";
|
||||
break;
|
||||
case ".jpeg":
|
||||
$mime_type = "image/jpeg";
|
||||
break;
|
||||
case ".png":
|
||||
$mime_type = "image/png";
|
||||
break;
|
||||
default:
|
||||
$mime_type = "application/octet-stream";
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
return $mime_type;
|
||||
}
|
||||
|
||||
/**
|
||||
* detect if a given program is found in the search PATH
|
||||
*
|
||||
* helper function used by _mimetype() to detect if the
|
||||
* external 'file' utility is available
|
||||
*
|
||||
* @param string program name
|
||||
* @param string optional search path, defaults to $PATH
|
||||
* @return bool true if executable program found in path
|
||||
*/
|
||||
private function canExecute($name, $path = false)
|
||||
{
|
||||
// path defaults to PATH from environment if not set
|
||||
if ($path === false) {
|
||||
$path = getenv("PATH");
|
||||
}
|
||||
|
||||
// check method depends on operating system
|
||||
if (!strncmp(PHP_OS, "WIN", 3)) {
|
||||
// on Windows an appropriate COM or EXE file needs to exist
|
||||
$exts = array(".exe", ".com");
|
||||
$check_fn = "file_exists";
|
||||
} else {
|
||||
// anywhere else we look for an executable file of that name
|
||||
$exts = array("");
|
||||
$check_fn = "is_executable";
|
||||
}
|
||||
|
||||
// now check the directories in the path for the program
|
||||
foreach (explode(PATH_SEPARATOR, $path) as $dir) {
|
||||
// skip invalid path entries
|
||||
if (!file_exists($dir)) continue;
|
||||
if (!is_dir($dir)) continue;
|
||||
|
||||
// and now look for the file
|
||||
foreach ($exts as $ext) {
|
||||
if ($check_fn("$dir/$name".$ext)) return true;
|
||||
}
|
||||
}
|
||||
|
||||
return false;
|
||||
}
|
||||
|
||||
public function toTmpFile($path){
|
||||
$tmpFolder=sys_get_temp_dir();
|
||||
$filename=tempnam($tmpFolder,'OC_TEMP_FILE_'.substr($path,strrpos($path,'.')));
|
||||
if(copy($this->datadir.$path,$filename)){
|
||||
$this->notifyObservers($path,OC_FILEACTION_READ);
|
||||
return $filename;
|
||||
}else{
|
||||
return false;
|
||||
}
|
||||
}
|
||||
|
||||
public function fromTmpFile($tmpFile,$path){
|
||||
if(rename($tmpFile,$this->datadir.$path)){
|
||||
$this->notifyObservers($path,OC_FILEACTION_CREATE);
|
||||
return true;
|
||||
}else{
|
||||
return false;
|
||||
}
|
||||
}
|
||||
|
||||
public function delTree($dir) {
|
||||
$dirRelative=$dir;
|
||||
$dir=$this->datadir.$dir;
|
||||
if (!file_exists($dir)) return true;
|
||||
if (!is_dir($dir) || is_link($dir)) return unlink($dir);
|
||||
foreach (scandir($dir) as $item) {
|
||||
if ($item == '.' || $item == '..') continue;
|
||||
if(is_file($dir.'/'.$item)){
|
||||
if(unlink($dir.'/'.$item)){
|
||||
$this->notifyObservers($dir.'/'.$item,OC_FILEACTION_DELETE);
|
||||
}
|
||||
}elseif(is_dir($dir.'/'.$item)){
|
||||
if (!$this->delTree($dirRelative. "/" . $item)){
|
||||
return false;
|
||||
};
|
||||
}
|
||||
}
|
||||
if($return=rmdir($dir)){
|
||||
$this->notifyObservers($dir,OC_FILEACTION_DELETE);
|
||||
}
|
||||
return $return;
|
||||
}
|
||||
|
||||
public function find($path){
|
||||
return System::find($this->datadir.$path);
|
||||
}
|
||||
}
|
||||
?>
|
|
@ -189,6 +189,7 @@ class OC_FILESYSTEM{
|
|||
}
|
||||
static public function file_put_contents($path){
|
||||
if(self::canWrite($path) and $storage=self::getStorage($path)){
|
||||
$this->notifyObservers($path,OC_FILEACTION_WRITE | OC_FILEACTION_CREATE);
|
||||
return $storage->file_put_contents(substr($path,strlen(self::getMountPoint($path))));
|
||||
}
|
||||
}
|
||||
|
@ -261,251 +262,4 @@ class OC_FILESYSTEM{
|
|||
}
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Privde a common interface to all different storage options
|
||||
*/
|
||||
interface OC_FILESTORAGE{
|
||||
public function __construct($parameters);
|
||||
public function mkdir($path);
|
||||
public function rmdir($path);
|
||||
public function opendir($path);
|
||||
public function is_dir($path);
|
||||
public function is_file($path);
|
||||
public function stat($path);
|
||||
public function filetype($path);
|
||||
public function filesize($path);
|
||||
public function is_readable($path);
|
||||
public function is_writeable($path);
|
||||
public function file_exists($path);
|
||||
public function readfile($path);
|
||||
public function filectime($path);
|
||||
public function filemtime($path);
|
||||
public function fileatime($path);
|
||||
public function file_get_contents($path);
|
||||
public function file_put_contents($path);
|
||||
public function unlink($path);
|
||||
public function rename($path1,$path2);
|
||||
public function copy($path1,$path2);
|
||||
public function fopen($path,$mode);
|
||||
public function toTmpFile($path);//copy the file to a temporary file, used for cross-storage file actions
|
||||
public function fromTmpFile($tmpPath,$path);//copy a file from a temporary file, used for cross-storage file actions
|
||||
public function getMimeType($path);
|
||||
public function delTree($path);
|
||||
public function find($path);
|
||||
}
|
||||
|
||||
/**
|
||||
* for local filestore, we only have to map the paths
|
||||
*/
|
||||
class OC_FILESTORAGE_LOCAL implements OC_FILESTORAGE{
|
||||
private $datadir;
|
||||
public function __construct($arguments){
|
||||
$this->datadir=$arguments['datadir'];
|
||||
if(substr($this->datadir,-1)!=='/'){
|
||||
$this->datadir.='/';
|
||||
}
|
||||
}
|
||||
public function mkdir($path){
|
||||
return mkdir($this->datadir.$path);
|
||||
}
|
||||
public function rmdir($path){
|
||||
return rmdir($this->datadir.$path);
|
||||
}
|
||||
public function opendir($path){
|
||||
return opendir($this->datadir.$path);
|
||||
}
|
||||
public function is_dir($path){
|
||||
return is_dir($this->datadir.$path);
|
||||
}
|
||||
public function is_file($path){
|
||||
return is_file($this->datadir.$path);
|
||||
}
|
||||
public function stat($path){
|
||||
return stat($this->datadir.$path);
|
||||
}
|
||||
public function filetype($path){
|
||||
return filetype($this->datadir.$path);
|
||||
}
|
||||
public function filesize($path){
|
||||
return filesize($this->datadir.$path);
|
||||
}
|
||||
public function is_readable($path){
|
||||
return is_readable($this->datadir.$path);
|
||||
}
|
||||
public function is_writeable($path){
|
||||
return is_writeable($this->datadir.$path);
|
||||
}
|
||||
public function file_exists($path){
|
||||
return file_exists($this->datadir.$path);
|
||||
}
|
||||
public function readfile($path){
|
||||
return readfile($this->datadir.$path);
|
||||
}
|
||||
public function filectime($path){
|
||||
return filectime($this->datadir.$path);
|
||||
}
|
||||
public function filemtime($path){
|
||||
return filemtime($this->datadir.$path);
|
||||
}
|
||||
public function fileatime($path){
|
||||
return fileatime($this->datadir.$path);
|
||||
}
|
||||
public function file_get_contents($path){
|
||||
return file_get_contents($this->datadir.$path);
|
||||
}
|
||||
public function file_put_contents($path){
|
||||
return file_put_contents($this->datadir.$path);
|
||||
}
|
||||
public function unlink($path){
|
||||
return unlink($this->datadir.$path);
|
||||
}
|
||||
public function rename($path1,$path2){
|
||||
return rename($this->datadir.$path1,$this->datadir.$path2);
|
||||
}
|
||||
public function copy($path1,$path2){
|
||||
return copy($this->datadir.$path1,$this->datadir.$path2);
|
||||
}
|
||||
public function fopen($path,$mode){
|
||||
return fopen($this->datadir.$path,$mode);
|
||||
}
|
||||
|
||||
public function getMimeType($fspath){
|
||||
if (@is_dir($this->datadir.$fspath)) {
|
||||
// directories are easy
|
||||
return "httpd/unix-directory";
|
||||
} else if (function_exists("mime_content_type")) {
|
||||
// use mime magic extension if available
|
||||
$mime_type = mime_content_type($this->datadir.$fspath);
|
||||
} else if (self::canExecute("file")) {
|
||||
// it looks like we have a 'file' command,
|
||||
// lets see it it does have mime support
|
||||
$fp = popen("file -i '$fspath' 2>/dev/null", "r");
|
||||
$reply = fgets($fp);
|
||||
pclose($fp);
|
||||
|
||||
// popen will not return an error if the binary was not found
|
||||
// and find may not have mime support using "-i"
|
||||
// so we test the format of the returned string
|
||||
|
||||
// the reply begins with the requested filename
|
||||
if (!strncmp($reply, "$fspath: ", strlen($fspath)+2)) {
|
||||
$reply = substr($reply, strlen($fspath)+2);
|
||||
// followed by the mime type (maybe including options)
|
||||
if (preg_match('/^[[:alnum:]_-]+/[[:alnum:]_-]+;?.*/', $reply, $matches)) {
|
||||
$mime_type = $matches[0];
|
||||
}
|
||||
}
|
||||
}
|
||||
if (empty($mime_type)) {
|
||||
// Fallback solution: try to guess the type by the file extension
|
||||
// TODO: add more ...
|
||||
switch (strtolower(strrchr(basename($fspath), "."))) {
|
||||
case ".html":
|
||||
$mime_type = "text/html";
|
||||
break;
|
||||
case ".txt":
|
||||
$mime_type = "text/plain";
|
||||
break;
|
||||
case ".css":
|
||||
$mime_type = "text/css";
|
||||
break;
|
||||
case ".gif":
|
||||
$mime_type = "image/gif";
|
||||
break;
|
||||
case ".jpg":
|
||||
$mime_type = "image/jpeg";
|
||||
break;
|
||||
case ".jpeg":
|
||||
$mime_type = "image/jpeg";
|
||||
break;
|
||||
case ".png":
|
||||
$mime_type = "image/png";
|
||||
break;
|
||||
default:
|
||||
$mime_type = "application/octet-stream";
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
return $mime_type;
|
||||
}
|
||||
|
||||
/**
|
||||
* detect if a given program is found in the search PATH
|
||||
*
|
||||
* helper function used by _mimetype() to detect if the
|
||||
* external 'file' utility is available
|
||||
*
|
||||
* @param string program name
|
||||
* @param string optional search path, defaults to $PATH
|
||||
* @return bool true if executable program found in path
|
||||
*/
|
||||
private function canExecute($name, $path = false)
|
||||
{
|
||||
// path defaults to PATH from environment if not set
|
||||
if ($path === false) {
|
||||
$path = getenv("PATH");
|
||||
}
|
||||
|
||||
// check method depends on operating system
|
||||
if (!strncmp(PHP_OS, "WIN", 3)) {
|
||||
// on Windows an appropriate COM or EXE file needs to exist
|
||||
$exts = array(".exe", ".com");
|
||||
$check_fn = "file_exists";
|
||||
} else {
|
||||
// anywhere else we look for an executable file of that name
|
||||
$exts = array("");
|
||||
$check_fn = "is_executable";
|
||||
}
|
||||
|
||||
// now check the directories in the path for the program
|
||||
foreach (explode(PATH_SEPARATOR, $path) as $dir) {
|
||||
// skip invalid path entries
|
||||
if (!file_exists($dir)) continue;
|
||||
if (!is_dir($dir)) continue;
|
||||
|
||||
// and now look for the file
|
||||
foreach ($exts as $ext) {
|
||||
if ($check_fn("$dir/$name".$ext)) return true;
|
||||
}
|
||||
}
|
||||
|
||||
return false;
|
||||
}
|
||||
|
||||
public function toTmpFile($path){
|
||||
$tmpFolder=sys_get_temp_dir();
|
||||
$filename=tempnam($tmpFolder,'OC_TEMP_FILE_'.substr($path,strrpos($path,'.')));
|
||||
copy($this->datadir.$path,$filename);
|
||||
return $filename;
|
||||
}
|
||||
|
||||
public function fromTmpFile($tmpFile,$path){
|
||||
copy($tmpFile,$this->datadir.$path);
|
||||
unlink($tmpFile);
|
||||
}
|
||||
|
||||
public function delTree($dir) {
|
||||
$dirRelative=$dir;
|
||||
$dir=$this->datadir.$dir;
|
||||
if (!file_exists($dir)) return true;
|
||||
if (!is_dir($dir) || is_link($dir)) return unlink($dir);
|
||||
foreach (scandir($dir) as $item) {
|
||||
if ($item == '.' || $item == '..') continue;
|
||||
if(is_file($dir.'/'.$item)){
|
||||
unlink($dir.'/'.$item);
|
||||
}elseif(is_dir($dir.'/'.$item)){
|
||||
if (!$this->delTree($dirRelative. "/" . $item)){
|
||||
return false;
|
||||
};
|
||||
}
|
||||
}
|
||||
return rmdir($dir);
|
||||
}
|
||||
|
||||
public function find($path){
|
||||
return System::find($this->datadir.$path);
|
||||
}
|
||||
}
|
||||
?>
|
||||
|
|
|
@ -1,5 +1,7 @@
|
|||
<?php
|
||||
global $FIRSTRUN;
|
||||
global $CONFIG_ENABLEBACKUP;
|
||||
global $CONFIG_BACKUPDIRECTORY;
|
||||
global $CONFIG_ERROR;
|
||||
if(!isset($fillDB)) $fillDB=true;
|
||||
if(!isset($CONFIG_DBHOST)) $CONFIG_DBHOST='localhost';
|
||||
|
@ -13,6 +15,11 @@ function showDBAdmin(){
|
|||
document.getElementById('dbAdminPwd').style.display=(show)?'table-row':'none';
|
||||
}
|
||||
|
||||
function showBackupPath(){
|
||||
var show=document.getElementById('enablebackup').checked;
|
||||
document.getElementById('backupdir').style.display=(show)?'table-row':'none';
|
||||
}
|
||||
|
||||
function dbtypechange(){
|
||||
var dropdown=action=document.getElementById('dbtype');
|
||||
var type=dropdown.options[dropdown.selectedIndex].value;
|
||||
|
@ -57,6 +64,8 @@ if($FIRSTRUN){?>
|
|||
?>
|
||||
<tr><td>data directory:</td><td><input type="text" name="datadirectory" size="30" class="formstyle" value="<?php echo($CONFIG_DATADIRECTORY);?>"></input></td></tr>
|
||||
<tr><td>force ssl:</td><td><input type="checkbox" name="forcessl" size="30" class="formstyle" value='1' <?php if($CONFIG_HTTPFORCESSL) echo 'checked'?>></input></td></tr>
|
||||
<tr><td>enable automatic backup:</td><td><input type="checkbox" name="enablebackup" id="enablebackup" onchange='showBackupPath()' size="30" class="formstyle" value='1' <?php if($CONFIG_ENABLEBACKUP) echo 'checked'?>></input></td></tr>
|
||||
<tr id='backupdir'><td>backup directory:</td><td><input type="text" name="backupdirectory" size="30" class="formstyle" value="<?php echo($CONFIG_BACKUPDIRECTORY);?>"></input></td></tr>
|
||||
<tr><td>date format:</td><td><input type="text" name="dateformat" size="30" class="formstyle" value='<?php echo($CONFIG_DATEFORMAT);?>'></input></td></tr>
|
||||
<tr><td>database type:</td><td>
|
||||
<select id='dbtype' name="dbtype" onchange='dbtypechange()'>
|
||||
|
@ -103,4 +112,5 @@ if(!$FIRSTRUN){?>
|
|||
?>
|
||||
<script type="text/javascript">
|
||||
dbtypechange()
|
||||
showBackupPath()
|
||||
</script>
|
Loading…
Reference in a new issue