diff options
author | Jakob Sack <kde@jakobsack.de> | 2011-05-06 22:50:18 +0200 |
---|---|---|
committer | Jakob Sack <kde@jakobsack.de> | 2011-05-06 22:50:18 +0200 |
commit | 6b83e5ccfe31a947b758eabadb9865ad898dbbef (patch) | |
tree | 92857184124b68daef306b0a10103ec5dc919515 /lib/installer.php | |
parent | e8e0608991eddac9a9595abc408f6f3c6fdf05b8 (diff) | |
download | nextcloud-server-6b83e5ccfe31a947b758eabadb9865ad898dbbef.tar.gz nextcloud-server-6b83e5ccfe31a947b758eabadb9865ad898dbbef.zip |
renamed installer.php to setup.php
Diffstat (limited to 'lib/installer.php')
-rw-r--r-- | lib/installer.php | 146 |
1 files changed, 0 insertions, 146 deletions
diff --git a/lib/installer.php b/lib/installer.php deleted file mode 100644 index 0646ef8e0ea..00000000000 --- a/lib/installer.php +++ /dev/null @@ -1,146 +0,0 @@ -<?php - -if(isset($_POST['install']) and $_POST['install']=='true'){ - $errors=OC_INSTALLER::install($_POST); - if(count($errors)>0){ - OC_TEMPLATE::printGuestPage( "", "error", array( "errors" => $errors )); - }else{ - header( "Location: $WEBROOT"); - exit(); - } -} - -class OC_INSTALLER{ - public static function install($options){ - $error=array(); - $dbtype=$options['dbtype']; - if(empty($options['login'])){ - $error[]=array('error'=>'username not set'); - }; - if(empty($options['pass'])){ - $error[]=array('error'=>'password not set'); - }; - if(empty($options['directory'])){ - $error[]=array('error'=>'data directory not set'); - }; - if($dbtype=='mysql'){//mysql needs more config options - if(empty($options['dbuser'])){ - $error[]=array('error'=>'database user not set'); - }; - if(empty($options['dbpass'])){ - $error[]=array('error'=>'database password not set'); - }; - if(empty($options['dbname'])){ - $error[]=array('error'=>'database name not set'); - }; - if(empty($options['dbhost'])){ - $error[]=array('error'=>'database host not set'); - }; - if(!isset($options['dbtableprefix'])){ - $error[]=array('error'=>'database table prefix not set'); - }; - } - if(count($error)==0){ //no errors, good - $username=$options['login']; - $password=$options['pass']; - $datadir=$options['directory']; - - //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{ - //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'); - - //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).'"<br />'; - $entry.='Offending command was: '.$query.'<br />'; - 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"; - @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); - } -} - -?>
\ No newline at end of file |