From 6d57de7b326b09437b3c90c4dea60d596f92fdd3 Mon Sep 17 00:00:00 2001 From: root Date: Tue, 16 Mar 2010 08:48:36 +0100 Subject: cleanup autoconfiguration wizard, add settings page, make it run from subdirectories, huge cleanup --- README | 0 config/config.php | 98 ++++------------------------ css/default.css | 122 ----------------------------------- css/default.php | 128 +++++++++++++++++++++++++++++++++++++ inc/lib_base.php | 149 +++++++++++++++++++++++++++++++++++++++---- inc/lib_files.php | 9 +-- inc/templates/configform.php | 15 +++++ inc/templates/footer.php | 4 +- inc/templates/header.php | 22 +++++-- inc/templates/loginform.php | 5 +- index.php | 7 +- log/index.php | 2 +- settings/index.php | 4 +- webdav/owncloud.php | 5 +- 14 files changed, 324 insertions(+), 246 deletions(-) mode change 100644 => 100755 README mode change 100755 => 100644 config/config.php delete mode 100755 css/default.css create mode 100755 css/default.php create mode 100644 inc/templates/configform.php diff --git a/README b/README old mode 100644 new mode 100755 diff --git a/config/config.php b/config/config.php old mode 100755 new mode 100644 index 8470ad3f24b..425278171ef --- a/config/config.php +++ b/config/config.php @@ -1,87 +1,11 @@ - -
- - - - - - - - - - - - - - - - - -
owner name:
owner email:
admin name:
admin password:
retype admin password:
document root:
data directory:
site root:
force ssl:
date format:
database host:
database name:
database user:
database password:
retype database password:
- + \ No newline at end of file diff --git a/css/default.css b/css/default.css deleted file mode 100755 index be4ffd0bc1f..00000000000 --- a/css/default.css +++ /dev/null @@ -1,122 +0,0 @@ -body {background-color: #F9F9F9;} -body.error {background-color: #F0F0F0;} -body,th,td,ul,li,a,div,p,pre {color:#333333; font-family:Verdana,"Bitstream Vera Sans",Arial,Helvetica,Sans,"Bitstream Vera Serif"; font-size:9.0pt;} - -a img { - border:none; -} - -h1 { - margin-bottom:1.5em; -} - -.center { - text-align:center; -} - -.center * { - margin-left:auto; - margin-right:auto; -} - -div#nav { - margin-bottom:2em; -} - -a#owncloud-logo { - margin-left:auto; - margin-right:auto; - display:block; - width:200px; - height:99px; - background: transparent url(/img/owncloud-logo-small.png) no-repeat scroll 0 0; -} - -a#owncloud-logo span { - display:none; -} - -.nametext a {color:#333333; font-size:8pt; font-weight:bold; text-decoration:none;} -.highlighttext {color:#333333; font-size:9pt; font-weight:bold; text-decoration:none;} -.datetext {color:#333333; font-size:7pt;} -.sizetext {color:#333333; font-size:7pt;} -.footer {color:#999999; text-align:center; font-size:9pt; margin-top:4em;} -.hint {color:#AAAAAA; text-align:center; font-size:8pt; margin-top:4em; margin-bottom:2em;} -.hint a{color:#AAAAAA; text-align:center; font-size:8pt;} - -.formstyle { - font-weight:normal; - font-size: 8.0pt; - color: #555555; - background-color: #FFFFFF; - border: 1px solid #DDDDDD; - padding:0px; - margin:0px; -} - -.loginform { - background-color: #EEEEEE; -} - -.browser { - background-color: #EEEEEE; -} - -.browserline { - background-color: #EEEEEE; -} - -.browserline:hover { - background-color: #DDDDDD; -} - - -.navigationitem1 { - background-color: #EEEEEE; - color:#555555; - font-size:9pt; - font-weight:bold; -} - -.navigationitem1 a{ - text-decoration:none; - padding-right:15px; - background: transparent url(/img/dots.png) no-repeat scroll center right; -} - -.navigationitem1 img { - border:none; -} - -.navigationitem1:hover { - background-color: #EEEEEE; -} - -.navigationitem { - background-color: #EEEEEE; -} - -.navigationitem:hover { - background-color: #DDDDDD; -} - -.navigationselected td { - background-color: #DDDDDD; -} - -.navigationitem a { - text-decoration:none; - color: #333333; - font-size: 8.0pt; -} - -.navigationitemselected a { - text-decoration:none; - color: #333333; - font-size: 8.0pt; - font-weight:bold; -} - - - - diff --git a/css/default.php b/css/default.php new file mode 100755 index 00000000000..7da6bb5c657 --- /dev/null +++ b/css/default.php @@ -0,0 +1,128 @@ + +body {background-color: #F9F9F9;} +body.error {background-color: #F0F0F0;} +body,th,td,ul,li,a,div,p,pre {color:#333333; font-family:Verdana,"Bitstream Vera Sans",Arial,Helvetica,Sans,"Bitstream Vera Serif"; font-size:9.0pt;} + +a img { + border:none; +} + +h1 { + margin-bottom:1.5em; +} + +.center { + text-align:center; +} + +.center * { + margin-left:auto; + margin-right:auto; +} + +div#nav { + margin-bottom:2em; +} + +a#owncloud-logo { + margin-left:auto; + margin-right:auto; + display:block; + width:200px; + height:99px; + background: transparent url(/img/owncloud-logo-small.png) no-repeat scroll 0 0; +} + +a#owncloud-logo span { + display:none; +} + +.nametext a {color:#333333; font-size:8pt; font-weight:bold; text-decoration:none;} +.errortext {color:#CC3333; font-size:9pt; font-weight:bold; text-decoration:none;} +.highlighttext {color:#333333; font-size:9pt; font-weight:bold; text-decoration:none;} +.datetext {color:#333333; font-size:7pt;} +.sizetext {color:#333333; font-size:7pt;} +.footer {color:#999999; text-align:center; font-size:9pt; margin-top:4em;} +.footer a {color:#999999; text-decoration:none;} +.hint {color:#AAAAAA; text-align:center; font-size:8pt; margin-top:4em; margin-bottom:2em;} +.hint a{color:#AAAAAA; text-align:center; font-size:8pt;} + +.formstyle { + font-weight:normal; + font-size: 8.0pt; + color: #555555; + background-color: #FFFFFF; + border: 1px solid #DDDDDD; + padding:0px; + margin:0px; +} + +.loginform { + background-color: #EEEEEE; +} + +.browser { + background-color: #EEEEEE; +} + +.browserline { + background-color: #EEEEEE; +} + +.browserline:hover { + background-color: #DDDDDD; +} + + +.navigationitem1 { + background-color: #EEEEEE; + color:#555555; + font-size:9pt; + font-weight:bold; +} + +.navigationitem1 a{ + text-decoration:none; + padding-right:15px; + background: transparent url(/img/dots.png) no-repeat scroll center right; +} + +.navigationitem1 img { + border:none; +} + +.navigationitem1:hover { + background-color: #EEEEEE; +} + +.navigationitem { + background-color: #EEEEEE; +} + +.navigationitem:hover { + background-color: #DDDDDD; +} + +.navigationselected td { + background-color: #DDDDDD; +} + +.navigationitem a { + text-decoration:none; + color: #333333; + font-size: 8.0pt; +} + +.navigationitemselected a { + text-decoration:none; + color: #333333; + font-size: 8.0pt; + font-weight:bold; +} + + + + diff --git a/inc/lib_base.php b/inc/lib_base.php index 227e616bcd1..41f792d56b5 100755 --- a/inc/lib_base.php +++ b/inc/lib_base.php @@ -23,14 +23,39 @@ // set some stuff +ob_start(); error_reporting(E_ALL | E_STRICT); date_default_timezone_set('Europe/Berlin'); ini_set('arg_separator.output','&'); ini_set('session.cookie_httponly','1;'); session_start(); +// calculate the documentroot +$DOCUMENTROOT=substr(__FILE__,0,-17); +$SERVERROOT=$_SERVER['DOCUMENT_ROOT']; +$count=strlen($SERVERROOT); +$WEBROOT=substr($DOCUMENTROOT,$count); +//echo($WEBROOT); + +// set the right include path +set_include_path(get_include_path().PATH_SEPARATOR.$DOCUMENTROOT.PATH_SEPARATOR.$DOCUMENTROOT.'/inc'.PATH_SEPARATOR.$DOCUMENTROOT.'/config'); + +// define default config values +$CONFIG_ADMINLOGIN=''; +$CONFIG_ADMINPASSWORD=''; +$CONFIG_DATADIRECTORY='/var/data'; +$CONFIG_HTTPFORCESSL=false; +$CONFIG_DATEFORMAT='j M Y G:i'; +$CONFIG_DBHOST='localhost'; +$CONFIG_DBNAME='owncloud'; +$CONFIG_DBUSER=''; +$CONFIG_DBPASSWORD=''; + +// include the generated configfile +@include_once('config.php'); + // redirect to https site if configured -if($CONFIG_HTTPFORCESSL){ +if(isset($CONFIG_HTTPFORCESSL) and $CONFIG_HTTPFORCESSL){ if(!isset($_SERVER['HTTPS']) or $_SERVER['HTTPS'] != 'on') { $url = "https://". $_SERVER['SERVER_NAME'] . $_SERVER['REQUEST_URI']; header("Location: $url"); @@ -43,10 +68,19 @@ require_once('lib_files.php'); require_once('lib_log.php'); // load plugins +$CONFIG_LOADPLUGINS=''; $plugins=explode(' ',$CONFIG_LOADPLUGINS); if(isset($plugins[0]['url'])) foreach($plugins as $plugin) require_once('plugins/'.$plugin.'/lib_'.$plugin.'.php'); +// check if the server is correctly configured for ownCloud +OC_UTIL::checkserver(); + +// listen for login or logout actions +OC_USER::logoutlisener(); +$loginresult=OC_USER::loginlisener(); + + /** * Class for usermanagement * @@ -64,10 +98,12 @@ class OC_USER { if($_POST['login']==$CONFIG_ADMINLOGIN and $_POST['password']==$CONFIG_ADMINPASSWORD){ $_SESSION['username']=$_POST['login']; OC_LOG::event($_SESSION['username'],1,''); + return(''); }else{ - echo('error'); + return('error'); } } + return(''); } /** @@ -96,11 +132,26 @@ class OC_UTIL { */ static private $NAVIGATION = array(); + + /** + * check if the current server configuration is suitable for ownCloud + * + */ + public static function checkserver(){ + global $DOCUMENTROOT; + $f=@fopen($DOCUMENTROOT.'/config/config.php','a+'); + if(!$f) die('Error: Config file (config/config.php) is not writable for the webserver.'); + @fclose($f); + + } + /** * show the header of the web GUI * */ public static function showheader(){ + global $CONFIG_ADMINLOGIN; + global $WEBROOT; require('templates/header.php');; } @@ -132,18 +183,18 @@ class OC_UTIL { * */ public static function shownavigation(){ - global $CONFIG_WEBROOT; + global $WEBROOT; echo(''); - echo(''); - if($_SERVER['SCRIPT_NAME']=='/index.php') echo(''); else echo(''); + echo(''); + if($_SERVER['SCRIPT_NAME']=='/index.php') echo(''); else echo(''); foreach(OC_UTIL::$NAVIGATION as $NAVI) { if($_SERVER['SCRIPT_NAME']==$NAVI['url']) echo(''); else echo(''); } - if($_SERVER['SCRIPT_NAME']=='/log/index.php') echo(''); else echo(''); - if($_SERVER['SCRIPT_NAME']=='/settings/index.php') echo(''); else echo(''); - echo(''); + if($_SERVER['SCRIPT_NAME']=='/log/index.php') echo(''); else echo(''); + if($_SERVER['SCRIPT_NAME']=='/settings/index.php') echo(''); else echo(''); + echo(''); echo('
'); } @@ -153,22 +204,94 @@ class OC_UTIL { * */ public static function showloginform(){ + global $loginresult; require('templates/loginform.php'); } + /** * show an icon for a filetype * */ public static function showicon($filetype){ - if($filetype=='dir'){ echo(''); + global $WEBROOT; + if($filetype=='dir'){ echo(''); }elseif($filetype=='foo'){ echo('foo'); - }else{ echo(''); + }else{ echo(''); } } + /** + * show the configform + * + */ + public static function showconfigform(){ + global $CONFIG_ADMINLOGIN; + global $CONFIG_ADMINPASSWORD; + global $CONFIG_DATADIRECTORY; + global $CONFIG_HTTPFORCESSL; + global $CONFIG_DATEFORMAT; + global $CONFIG_DBHOST; + global $CONFIG_DBNAME; + global $CONFIG_DBUSER; + global $CONFIG_DBPASSWORD; + require('templates/configform.php'); + } + + /** + * lisen for configuration changes and write it to the file + * + */ + public static function writeconfiglisener(){ + global $DOCUMENTROOT; + global $WEBROOT; + if(isset($_POST['set_config'])){ + + //checkdata + $error=''; + + if(!isset($_POST['adminlogin']) or empty($_POST['adminlogin'])) $error.='admin login not set
'; + if(!isset($_POST['adminpassword']) or empty($_POST['adminpassword'])) $error.='admin password not set
'; + if(!isset($_POST['adminpassword2']) or empty($_POST['adminpassword2'])) $error.='retype admin password not set
'; + if(!isset($_POST['datadirectory']) or empty($_POST['datadirectory'])) $error.='data directory not set
'; + if(!isset($_POST['dateformat']) or empty($_POST['dateformat'])) $error.='dteformat not set
'; + if(!isset($_POST['dbhost']) or empty($_POST['dbhost'])) $error.='database host not set
'; + if(!isset($_POST['dbname']) or empty($_POST['dbname'])) $error.='databasename not set
'; + if(!isset($_POST['dbuser']) or empty($_POST['dbuser'])) $error.='database user not set
'; + if(!isset($_POST['dbpassword']) or empty($_POST['dbpassword'])) $error.='database password not set
'; + if(!isset($_POST['dbpassword2']) or empty($_POST['dbpassword2'])) $error.='retype database password not set
'; + if($_POST['dbpassword']<>$_POST['dbpassword2'] ) $error.='database passwords are not the same
'; + if($_POST['adminpassword']<>$_POST['adminpassword2'] ) $error.='admin passwords are not the same
'; + + + if(empty($error)) { + //storedata + $config=' '; + + $filename=$DOCUMENTROOT.'/config/config.php'; + file_put_contents($filename,$config); + header("Location: ".$WEBROOT."/"); + + } + return($error); + + } + + } + } + /** * Class for database access * @@ -186,12 +309,12 @@ class OC_DB { global $CONFIG_DBHOST; global $CONFIG_DBNAME; global $CONFIG_DBUSER; - global $CONFIG_DBPWD; + global $CONFIG_DBPASSWORD; if(!isset($DBConnection)) { - $DBConnection = @new mysqli($CONFIG_DBHOST, $CONFIG_DBUSER, $CONFIG_DBPWD,$CONFIG_DBNAME); + $DBConnection = @new mysqli($CONFIG_DBHOST, $CONFIG_DBUSER, $CONFIG_DBPASSWORD,$CONFIG_DBNAME); if (mysqli_connect_errno()) { @ob_end_clean(); - echo('

can not connect to database.
'); + echo('can not connect to database.'); exit(); } } diff --git a/inc/lib_files.php b/inc/lib_files.php index ab0a5252982..8eb1fc9c125 100755 --- a/inc/lib_files.php +++ b/inc/lib_files.php @@ -37,6 +37,7 @@ class OC_FILES { */ public static function showbrowser($basedir,$dir){ global $CONFIG_DATEFORMAT; + global $WEBROOT; $directory=$basedir.'/'.$dir; @@ -49,11 +50,11 @@ class OC_FILES { // breadcrumb if(count($dirs)>1) { echo('
'); - echo(''); + echo(''); $currentdir=''; foreach($dirs as $d) { $currentdir.='/'.$d.''; - if($d<>'') echo(''); + if($d<>'') echo(''); } echo('
homehome '.$d.' '.$d.'
'); } @@ -71,8 +72,8 @@ class OC_FILES { echo(''); OC_UTIL::showicon($filetype); - if($filetype=='dir') echo(''.$file.''); - if($filetype<>'dir') echo(''.$file.''); + if($filetype=='dir') echo(''.$file.''); + if($filetype<>'dir') echo(''.$file.''); if($filetype<>'dir') echo(''.$stat['size'].' byte'); else echo(''); echo(''.date($CONFIG_DATEFORMAT,$stat['mtime']).''); echo(''); diff --git a/inc/templates/configform.php b/inc/templates/configform.php new file mode 100644 index 00000000000..95043f9cfc8 --- /dev/null +++ b/inc/templates/configform.php @@ -0,0 +1,15 @@ +
+ + + + + + + + + + + + + +
admin login:
admin password:
retype admin password:
data directory:
force ssl:
date format:
database host:
database name:
database user:
database password:
retype database password:
diff --git a/inc/templates/footer.php b/inc/templates/footer.php index 9771c797787..5ce34a95791 100755 --- a/inc/templates/footer.php +++ b/inc/templates/footer.php @@ -1,8 +1,6 @@ diff --git a/inc/templates/header.php b/inc/templates/header.php index 90a9b1c23f0..cd9e2ead8b3 100755 --- a/inc/templates/header.php +++ b/inc/templates/header.php @@ -3,25 +3,37 @@ ownCloud - + -

'); - if(!isset($_SESSION['username']) or $_SESSION['username']=='') { + // check if already configured. otherwise start configuration wizard + $error=OC_UTIL::writeconfiglisener(); + if(empty($CONFIG_ADMINLOGIN)) { + echo('
'); + echo('

'.$error.'

'); + echo('

First Run Wizard

'); + OC_UTIL::showconfigform(); + echo('
'); + OC_UTIL::showfooter(); + exit(); + } + + + // show the loginform if not loggedin + if(!isset($_SESSION['username']) or $_SESSION['username']=='') { echo('
'); OC_UTIL::showloginform(); echo('
'); OC_UTIL::showfooter(); exit(); }else{ - echo(''); - } ?> diff --git a/inc/templates/loginform.php b/inc/templates/loginform.php index d4543e25669..9f5517431ae 100755 --- a/inc/templates/loginform.php +++ b/inc/templates/loginform.php @@ -1,4 +1,7 @@ -
+login failed

'); +?> + diff --git a/index.php b/index.php index 75273f73cf9..b4a19dd0388 100755 --- a/index.php +++ b/index.php @@ -21,8 +21,7 @@ * */ - -require_once('config/config.php'); +require_once('inc/lib_base.php'); if(isset($_GET['dir'])) $dir=$_GET['dir']; else $dir=''; @@ -32,14 +31,12 @@ if(isset($_GET['file'])) { }else{ - OC_USER::loginlisener(); - OC_USER::logoutlisener(); OC_UTIL::showheader(); OC_FILES::showbrowser($CONFIG_DATADIRECTORY,$dir); - echo('

Hint: Mount it via webdav like this: webdav://'.$CONFIG_SITEROOT.'/webdav/owncloud.php

'); + echo('

Hint: Mount it via webdav like this: webdav://'.$_SERVER["HTTP_HOST"].$WEBROOT.'/webdav/owncloud.php

'); OC_UTIL::showfooter(); diff --git a/log/index.php b/log/index.php index ead048d2dbd..3b10027f9cb 100755 --- a/log/index.php +++ b/log/index.php @@ -22,7 +22,7 @@ */ -require_once('../config/config.php'); +require_once('../inc/lib_base.php'); OC_UTIL::showheader(); OC_LOG::show(); diff --git a/settings/index.php b/settings/index.php index 467e0ad9632..21b57216f2b 100755 --- a/settings/index.php +++ b/settings/index.php @@ -22,12 +22,12 @@ */ -require_once('../config/config.php'); +require_once('../inc/lib_base.php'); OC_UTIL::showheader(); echo('
'); -echo('nothing here yet :-)'); +OC_UTIL::showconfigform(); echo('
'); diff --git a/webdav/owncloud.php b/webdav/owncloud.php index 47dacae4db9..33fc5f37c33 100755 --- a/webdav/owncloud.php +++ b/webdav/owncloud.php @@ -22,8 +22,7 @@ */ -require_once('../config/config.php'); -require_once('lib_base.php'); +require_once('../inc/lib_base.php'); require_once('HTTP/WebDAV/Server/Filesystem.php'); @@ -45,7 +44,7 @@ if(($user==$CONFIG_ADMINLOGIN) and ($passwd==$CONFIG_ADMINPASSWORD )){ $server->db_host = $CONFIG_DBHOST; $server->db_name = $CONFIG_DBNAME; $server->db_user = $CONFIG_DBUSER; - $server->db_passwd = $CONFIG_DBPWD; + $server->db_passwd = $CONFIG_DBPASSWORD; $server->ServeRequest($CONFIG_DATADIRECTORY); }else{ -- cgit v1.2.3
login:
password: