summaryrefslogtreecommitdiffstats
path: root/core
diff options
context:
space:
mode:
authorBart Visscher <bartv@thisnet.nl>2012-11-12 13:23:31 -0800
committerBart Visscher <bartv@thisnet.nl>2012-11-12 13:23:31 -0800
commit7b53c9d3f07bf630d38a7a9c92ee44a3fb9b0f21 (patch)
treecf02c2d80277757189fc3400a44484dc7f97ba29 /core
parent910a25adbd2ee525b228c8b0d0f73d867fd237d6 (diff)
parent6d097529405a7e7791b4daac1909bafd38445c5c (diff)
downloadnextcloud-server-7b53c9d3f07bf630d38a7a9c92ee44a3fb9b0f21.tar.gz
nextcloud-server-7b53c9d3f07bf630d38a7a9c92ee44a3fb9b0f21.zip
Merge pull request #157 from owncloud/setup
Make lib/setup.php usable outside of install setup
Diffstat (limited to 'core')
-rw-r--r--core/setup.php53
1 files changed, 53 insertions, 0 deletions
diff --git a/core/setup.php b/core/setup.php
new file mode 100644
index 00000000000..1c03e3397af
--- /dev/null
+++ b/core/setup.php
@@ -0,0 +1,53 @@
+<?php
+
+// Check for autosetup:
+$autosetup_file = OC::$SERVERROOT."/config/autoconfig.php";
+if( file_exists( $autosetup_file )) {
+ OC_Log::write('core', 'Autoconfig file found, setting up owncloud...', OC_Log::INFO);
+ include $autosetup_file;
+ $_POST['install'] = 'true';
+ $_POST = array_merge ($_POST, $AUTOCONFIG);
+ unlink($autosetup_file);
+}
+
+OC_Util::addScript('setup');
+
+$hasSQLite = (is_callable('sqlite_open') or class_exists('SQLite3'));
+$hasMySQL = is_callable('mysql_connect');
+$hasPostgreSQL = is_callable('pg_connect');
+$hasOracle = is_callable('oci_connect');
+$datadir = OC_Config::getValue('datadirectory', OC::$SERVERROOT.'/data');
+
+// Test if .htaccess is working
+$content = "deny from all";
+file_put_contents(OC::$SERVERROOT.'/data/.htaccess', $content);
+
+$opts = array(
+ 'hasSQLite' => $hasSQLite,
+ 'hasMySQL' => $hasMySQL,
+ 'hasPostgreSQL' => $hasPostgreSQL,
+ 'hasOracle' => $hasOracle,
+ 'directory' => $datadir,
+ 'secureRNG' => OC_Util::secureRNG_available(),
+ 'htaccessWorking' => OC_Util::ishtaccessworking(),
+ '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: ".OC::$WEBROOT.'/');
+ exit();
+ }
+}
+else {
+ OC_Template::printGuestPage("", "installation", $opts);
+}