summaryrefslogtreecommitdiffstats
path: root/lib/installer.php
diff options
context:
space:
mode:
authorJakob Sack <kde@jakobsack.de>2011-05-06 22:50:18 +0200
committerJakob Sack <kde@jakobsack.de>2011-05-06 22:50:18 +0200
commit6b83e5ccfe31a947b758eabadb9865ad898dbbef (patch)
tree92857184124b68daef306b0a10103ec5dc919515 /lib/installer.php
parente8e0608991eddac9a9595abc408f6f3c6fdf05b8 (diff)
downloadnextcloud-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.php146
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