$hasSQLite, 'hasMySQL' => $hasMySQL, 'directory' => $datadir, 'errors' => array(), ); if(isset($_POST['install']) AND $_POST['install']=='true') { // We have to launch the installation process : $e = OC_SETUP::install($_POST); $errors = array('errors' => $e); if(count($e) > 0) { //OC_TEMPLATE::printGuestPage("", "error", array("errors" => $errors)); $options = array_merge($_POST, $opts, $errors); OC_TEMPLATE::printGuestPage("", "installation", $options); } else { header("Location: ".$WEBROOT.'/'); exit(); } } else { OC_TEMPLATE::printGuestPage("", "installation", $opts); } class OC_SETUP { public static function install($options) { $error = array(); $dbtype = $options['dbtype']; if(empty($options['adminlogin'])) { $error[] = 'STEP 1 : admin login is not set.'; } if(empty($options['adminpass'])) { $error[] = 'STEP 1 : admin password is not set.'; } if(empty($options['directory'])) { $error[] = 'STEP 2 : data directory path is not set.'; } if($dbtype=='mysql') { //mysql needs more config options if(empty($options['dbuser'])) { $error[] = 'STEP 3 : MySQL database user is not set.'; } if(empty($options['dbpass'])) { $error[] = 'STEP 3 : MySQL database password is not set.'; } if(empty($options['dbname'])) { $error[] = 'STEP 3 : MySQL database name is not set.'; } if(empty($options['dbhost'])) { $error[] = 'STEP 3 : MySQL database host is not set.'; } if(!isset($options['dbtableprefix'])) { $error[] = 'STEP 3 : MySQL database table prefix is not set.'; } } if(count($error) == 0) { //no errors, good $username = htmlspecialchars_decode($options['adminlogin']); $password = htmlspecialchars_decode($options['adminpass']); $datadir = htmlspecialchars_decode($options['directory']); //use sqlite3 when available, otherise sqlite2 will be used. if($dbtype=='sqlite' and class_exists('SQLite3')){ $dbtype='sqlite3'; } //write the config file OC_CONFIG::setValue('datadirectory', $datadir); OC_CONFIG::setValue('dbtype', $dbtype); if($dbtype == 'mysql') { $dbuser = $options['dbuser']; $dbpass = $options['dbpass']; $dbname = $options['dbname']; $dbhost = $options['dbhost']; $dbtableprefix = $options['dbtableprefix']; OC_CONFIG::setValue('dbname', $dbname); OC_CONFIG::setValue('dbhost', $dbhost); OC_CONFIG::setValue('dbtableprefix', $dbtableprefix); //check if the database user has admin right $connection = @mysql_connect($dbhost, $dbuser, $dbpass); if(!$connection) { $error[] = array( 'error' => 'mysql username and/or password not valid', 'hint' => 'you need to enter either an existing account, or the administrative account if you wish to create a new user for ownCloud' ); } else { $query="SELECT user FROM mysql.user WHERE user='$dbuser'"; //this should be enough to check for admin rights in mysql if(mysql_query($query, $connection)) { self::createDBUser($username, $password, $connection); //use the admin login data for the new database user OC_CONFIG::setValue('dbuser', $username); OC_CONFIG::setValue('dbpassword', $password); //create the database self::createDatabase($dbname, $username, $connection); } else { OC_CONFIG::setValue('dbuser', $dbuser); OC_CONFIG::setValue('dbpassword', $dbpass); //create the database self::createDatabase($dbname, $dbuser, $connection); } //fill the database if needed $query="SELECT * FROM $dbname.{$dbtableprefix}users"; $result = mysql_query($query,$connection); if(!$result) { OC_DB::createDbFromStructure('db_structure.xml'); } mysql_close($connection); } } else { //delete the old sqlite database first, might cause infinte loops otherwise unlink("$datadir/owncloud.db"); //in case of sqlite, we can always fill the database OC_DB::createDbFromStructure('db_structure.xml'); } if(count($error) == 0) { //create the user and group OC_USER::createUser($username, $password); OC_GROUP::createGroup('admin'); OC_GROUP::addToGroup($username, 'admin'); //guess what this does self::installShippedApps(); //create htaccess files for apache hosts self::createHtaccess(); //TODO detect if apache is used //and we are done OC_CONFIG::setValue('installed', true); } } return $error; } public static function createDatabase($name,$user,$connection) { //we cant user OC_BD functions here because we need to connect as the administrative user. $query = "CREATE DATABASE IF NOT EXISTS `$name`"; $result = mysql_query($query, $connection); if(!$result) { $entry='DB Error: "'.mysql_error($connection).'"
'; $entry.='Offending command was: '.$query.'
'; echo($entry); } $query="GRANT ALL PRIVILEGES ON `$name` . * TO '$user'"; $result = mysql_query($query, $connection); //this query will fail if there aren't the right permissons, ignore the error } private static function createDBUser($name,$password,$connection) { // we need to create 2 accounts, one for global use and one for local user. if we don't speccify the local one, // the anonymous user would take precedence when there is one. $query = "CREATE USER '$name'@'localhost' IDENTIFIED BY '$password'"; $result = mysql_query($query, $connection); $query = "CREATE USER '$name'@'%' IDENTIFIED BY '$password'"; $result = mysql_query($query, $connection); } /** * create .htaccess files for apache hosts */ private static function createHtaccess() { global $SERVERROOT; global $WEBROOT; $content = "ErrorDocument 404 /$WEBROOT/templates/404.php\n";//custom 404 error page $content.= "php_value upload_max_filesize 20M\n";//upload limit $content.= "php_value post_max_size 20M\n"; $content.= "SetEnv htaccessWorking true\n"; @file_put_contents($SERVERROOT.'/.htaccess', $content); //supress errors in case we don't have permissions for it $content = "deny from all"; file_put_contents(OC_CONFIG::getValue('datadirectory', $SERVERROOT.'/data').'/.htaccess', $content); } private static function installShippedApps(){ global $SERVERROOT; $dir = opendir( "$SERVERROOT/apps" ); while( false !== ( $filename = readdir( $dir ))){ if( substr( $filename, 0, 1 ) != '.' and is_dir("$SERVERROOT/apps/$filename") ){ if( file_exists( "$SERVERROOT/apps/$filename/appinfo/app.php" )){ if(!OC_INSTALLER::isInstalled($filename)){ //install the database if(is_file("$SERVERROOT/apps/$filename/appinfo/database.xml")){ OC_DB::createDbFromStructure("$SERVERROOT/apps/$filename/appinfo/database.xml"); } //run appinfo/install.php if(is_file("$SERVERROOT/apps/$filename/appinfo/install.php")){ include("$SERVERROOT/apps/$filename/appinfo/install.php"); } $info=OC_APP::getAppInfo("$SERVERROOT/apps/$filename/appinfo/info.xml"); OC_APPCONFIG::setValue($filename,'installed_version',$info['version']); OC_APPCONFIG::setValue($filename,'enabled','yes'); } } } } closedir( $dir ); } } ?>