diff --git a/include/datetime.php b/include/datetime.php index 087e6cb20..d44e995cf 100644 --- a/include/datetime.php +++ b/include/datetime.php @@ -15,7 +15,6 @@ function timezone_cmp($a, $b) { }} // emit a timezone selector grouped (primarily) by continent - if(! function_exists('select_timezone')) { function select_timezone($current = 'America/Los_Angeles') { @@ -55,6 +54,23 @@ function select_timezone($current = 'America/Los_Angeles') { return $o; }} +// return a select using 'field_select_raw' template, with timezones +// groupped (primarily) by continent +// arguments follow convetion as other field_* template array: +// 'name', 'label', $value, 'help' +if (!function_exists('field_timezone')){ +function field_timezone($name='timezone', $label='', $current = 'America/Los_Angeles', $help){ + $options = select_timezone($current); + $options = str_replace('','', $options); + + $tpl = get_markup_template('field_select_raw.tpl'); + return replace_macros($tpl, array( + '$field' => array($name, $label, $current, $help, $options), + )); + +}} + // General purpose date parse/convert function. // $from = source timezone // $to = dest timezone @@ -446,4 +462,4 @@ function update_contact_birthdays() { } } -} \ No newline at end of file +} diff --git a/include/dba.php b/include/dba.php index b89cf5376..782c279d5 100644 --- a/include/dba.php +++ b/include/dba.php @@ -18,7 +18,7 @@ class dba { private $db; public $mysqli = true; public $connected = false; - + public $error = false; function __construct($server,$user,$pass,$db,$install = false) { @@ -27,10 +27,16 @@ class dba { $pass = trim($pass); $db = trim($db); + if (!(strlen($server) && strlen($user))){ + $this->connected = false; + $this->db = null; + return; + } + if($install) { if(strlen($server) && ($server !== 'localhost') && ($server !== '127.0.0.1')) { if(! dns_get_record($server, DNS_A + DNS_CNAME + DNS_PTR)) { - notice( sprintf( t('Cannot locate DNS info for database server \'%s\''), $server)); + $this->error = sprintf( t('Cannot locate DNS info for database server \'%s\''), $server); $this->connected = false; $this->db = null; return; @@ -152,10 +158,11 @@ class dba { } function __destruct() { - if($this->mysqli) - @$this->db->close(); - else - @mysql_close($this->db); + if ($this->db) + if($this->mysqli) + $this->db->close(); + else + mysql_close($this->db); } }} @@ -186,6 +193,7 @@ function dbesc($str) { }} + // Function: q($sql,$args); // Description: execute SQL query with printf style args. // Example: $r = q("SELECT * FROM `%s` WHERE `uid` = %d", @@ -209,7 +217,6 @@ function q($sql) { * session data after abnormal program termination * */ - logger('dba: no database: ' . print_r($args,true)); return false; diff --git a/include/text.php b/include/text.php index d6b3ceeab..f32aaad07 100644 --- a/include/text.php +++ b/include/text.php @@ -426,6 +426,10 @@ function attribute_contains($attr,$s) { if(! function_exists('logger')) { function logger($msg,$level = 0) { + // turn off logger in install mode + global $a; + if ($a->module == 'install') return; + $debugging = get_config('system','debugging'); $loglevel = intval(get_config('system','loglevel')); $logfile = get_config('system','logfile'); diff --git a/mod/install.php b/mod/install.php index d994ca70f..f7820fc80 100644 --- a/mod/install.php +++ b/mod/install.php @@ -1,68 +1,99 @@ get_path(); - $dbhost = notags(trim($_POST['dbhost'])); - $dbuser = notags(trim($_POST['dbuser'])); - $dbpass = notags(trim($_POST['dbpass'])); - $dbdata = notags(trim($_POST['dbdata'])); - $timezone = notags(trim($_POST['timezone'])); - $phpath = notags(trim($_POST['phpath'])); - $adminmail = notags(trim($_POST['adminmail'])); - - require_once("dba.php"); - unset($db); - $db = new dba($dbhost, $dbuser, $dbpass, $dbdata, true); - - if(get_db_errno()) { - unset($db); - $db = new dba($dbhost, $dbuser, $dbpass, '', true); - if(! get_db_errno()) { - $r = q("CREATE DATABASE '%s'", - dbesc($dbdata) - ); - if($r) { - unset($db); - $db = new dba($dbhost, $dbuser, $dbpass, $dbdata, true); - } - } - if(get_db_errno()) { - notice( t('Could not create/connect to database.') . EOL); + switch($install_wizard_pass) { + case 1: + case 2: return; - } + break; // just in case return don't return :) + case 3: + $urlpath = $a->get_path(); + $dbhost = notags(trim($_POST['dbhost'])); + $dbuser = notags(trim($_POST['dbuser'])); + $dbpass = notags(trim($_POST['dbpass'])); + $dbdata = notags(trim($_POST['dbdata'])); + $phpath = notags(trim($_POST['phpath'])); + + require_once("dba.php"); + unset($db); + $db = new dba($dbhost, $dbuser, $dbpass, $dbdata, true); + /*if(get_db_errno()) { + unset($db); + $db = new dba($dbhost, $dbuser, $dbpass, '', true); + + if(! get_db_errno()) { + $r = q("CREATE DATABASE '%s'", + dbesc($dbdata) + ); + if($r) { + unset($db); + $db = new dba($dbhost, $dbuser, $dbpass, $dbdata, true); + } else { + $a->data['db_create_failed']=true; + } + } else { + $a->data['db_conn_failed']=true; + return; + } + }*/ + if(get_db_errno()) { + $a->data['db_conn_failed']=true; + } + + return; + break; + case 4; + $urlpath = $a->get_path(); + $dbhost = notags(trim($_POST['dbhost'])); + $dbuser = notags(trim($_POST['dbuser'])); + $dbpass = notags(trim($_POST['dbpass'])); + $dbdata = notags(trim($_POST['dbdata'])); + $phpath = notags(trim($_POST['phpath'])); + $timezone = notags(trim($_POST['timezone'])); + $adminmail = notags(trim($_POST['adminmail'])); + + // connect to db + $db = new dba($dbhost, $dbuser, $dbpass, $dbdata, true); + + $tpl = get_intltext_template('htconfig.tpl'); + $txt = replace_macros($tpl,array( + '$dbhost' => $dbhost, + '$dbuser' => $dbuser, + '$dbpass' => $dbpass, + '$dbdata' => $dbdata, + '$timezone' => $timezone, + '$urlpath' => $urlpath, + '$phpath' => $phpath, + '$adminmail' => $adminmail + )); + + $result = file_put_contents('.htconfig.php', $txt); + if(! $result) { + $a->data['txt'] = $txt; + } + + $errors = load_database($db); + + if($errors) + $a->data['db_failed'] = $errors; + else + $a->data['db_installed'] = true; + + return; + break; } - - info( t('Connected to database.') . EOL); - - $tpl = get_intltext_template('htconfig.tpl'); - $txt = replace_macros($tpl,array( - '$dbhost' => $dbhost, - '$dbuser' => $dbuser, - '$dbpass' => $dbpass, - '$dbdata' => $dbdata, - '$timezone' => $timezone, - '$urlpath' => $urlpath, - '$phpath' => $phpath, - '$adminmail' => $adminmail - )); - - $result = file_put_contents('.htconfig.php', $txt); - if(! $result) { - $a->data['txt'] = $txt; - } - - $errors = load_database($db); - - if($errors) - $a->data['db_failed'] = true; - else - $a->data['db_installed'] = true; - - return; } function get_db_errno() { @@ -74,107 +105,249 @@ function get_db_errno() { function install_content(&$a) { - global $db; + global $install_wizard_pass, $db; $o = ''; + $wizard_status = ""; + $install_title = t('Friendica Social Communications Server - Setup'); + + if(x($a->data,'txt') && strlen($a->data['txt'])) { + $tpl = get_markup_template('install.tpl'); + return replace_macros($tpl, array( + '$title' => $install_title, + '$pass' => t('Database connection'), + '$text' => manual_config($a), + )); + } + + if(x($a->data,'db_conn_failed')) { + $install_wizard_pass = 2; + $wizard_status = t('Could not connect to database.'); + } + if(x($a->data,'db_create_failed')) { + $install_wizard_pass = 2; + $wizard_status = t('Could not create table.'); + } if(x($a->data,'db_installed')) { - $o .= '
';
- $o .= t('Your Friendica site database has been installed.') . EOL;
- $o .= t('IMPORTANT: You will need to [manually] setup a scheduled task for the poller.') . EOL ;
- $o .= t('Please see the file "INSTALL.txt".') . EOL ;
- $o .= '
';
- $o .= '' . t('Proceed to registration') . '' ;
- $o .= '
';
+ $txt .= t('Your Friendica site database has been installed.') . EOL;
+ $txt .= t('IMPORTANT: You will need to [manually] setup a scheduled task for the poller.') . EOL ;
+ $txt .= t('Please see the file "INSTALL.txt".') . EOL ;
+ $txt .= '
';
+ $txt .= '' . t('Proceed to registration') . '' ;
+ $txt .= '
".$a->data['db_failed'] . "". EOL ; + + $tpl = get_markup_template('install.tpl'); + return replace_macros($tpl, array( + '$title' => $install_title, + '$pass' => t('Database connection'), + '$status' => t('Database import failed.'), + '$text' => $txt, + )); + } if($db && $db->connected) { $r = q("SELECT COUNT(*) as `total` FROM `user`"); if($r && count($r) && $r[0]['total']) { - notice( t('Permission denied.') . EOL); - return ''; + $tpl = get_markup_template('install.tpl'); + return replace_macros($tpl, array( + '$title' => $install_title, + '$pass' => '', + '$status' => t('Permission denied.'), + '$text' => '', + )); } } - info( t('Welcome to Friendica.') . EOL); + switch ($install_wizard_pass){ + case 1: { // System check - check_funcs(); + $checks = array(); - $o .= check_htconfig(); - if(strlen($o)) - return $o; + check_funcs($checks); - if(strlen($a->data['txt'])) { - $o .= manual_config($a); - return; + check_htconfig($checks); + + check_keys($checks); + + if(x($_POST,'phppath')) + $phpath = notags(trim($_POST['phppath'])); + + check_php($phpath, $checks); + + + function check_passed($v, $c){ + if ($c['required']) + $v = $v && $c['status']; + return $v; + } + $checkspassed = array_reduce($checks, "check_passed", true); + + + $tpl = get_markup_template('install_checks.tpl'); + $o .= replace_macros($tpl, array( + '$title' => $install_title, + '$pass' => t('System check'), + '$checks' => $checks, + '$passed' => $checkspassed, + '$see_install' => t('Please see the file "INSTALL.txt".'), + '$next' => t('Next'), + '$reload' => t('Check again'), + '$phpath' => $phpath, + )); + return $o; + }; break; + + case 2: { // Database config + + $dbhost = ((x($_POST,'dbhost')) ? notags(trim($_POST['dbhost'])) : 'localhost'); + $dbuser = notags(trim($_POST['dbuser'])); + $dbpass = notags(trim($_POST['dbpass'])); + $dbdata = notags(trim($_POST['dbdata'])); + $phpath = notags(trim($_POST['phppath'])); + + + $tpl = get_markup_template('install_db.tpl'); + $o .= replace_macros($tpl, array( + '$title' => $install_title, + '$pass' => t('Database connection'), + '$info_01' => t('In order to install Friendica we need to know how to connect to your database.'), + '$info_02' => t('Please contact your hosting provider or site administrator if you have questions about these settings.'), + '$info_03' => t('The database you specify below should already exist. If it does not, please create it before continuing.'), + + '$status' => $wizard_status, + + '$dbhost' => array('dbhost', t('Database Server Name'), $dbhost, ''), + '$dbuser' => array('dbuser', t('Database Login Name'), $dbuser, ''), + '$dbpass' => array('dbpass', t('Database Login Password'), $dbpass, ''), + '$dbdata' => array('dbdata', t('Database Name'), $dbdata, ''), + '$adminmail' => array('adminmail', t('Site administrator email address'), $adminmail, t('Your account email address must match this in order to use the web admin panel.')), + + + + '$lbl_10' => t('Please select a default timezone for your website'), + + '$baseurl' => $a->get_baseurl(), + + '$phpath' => $phpath, + + '$submit' => t('Submit'), + + )); + return $o; + }; break; + case 3: { // Site settings + require_once('datetime.php'); + $dbhost = ((x($_POST,'dbhost')) ? notags(trim($_POST['dbhost'])) : 'localhost'); + $dbuser = notags(trim($_POST['dbuser'])); + $dbpass = notags(trim($_POST['dbpass'])); + $dbdata = notags(trim($_POST['dbdata'])); + $phpath = notags(trim($_POST['phppath'])); + + $adminmail = notags(trim($_POST['adminmail'])); + $timezone = ((x($_POST,'timezone')) ? ($_POST['timezone']) : 'America/Los_Angeles'); + + $tpl = get_markup_template('install_settings.tpl'); + $o .= replace_macros($tpl, array( + '$title' => $install_title, + '$pass' => t('Site settings'), + + '$status' => $wizard_status, + + '$dbhost' => $dbhost, + '$dbuser' => $dbuser, + '$dbpass' => $dbpass, + '$dbdata' => $dbdata, + '$phpath' => $phpath, + + '$adminmail' => array('adminmail', t('Site administrator email address'), $adminmail, t('Your account email address must match this in order to use the web admin panel.')), + + + '$timezone' => field_timezone('timezone', t('Please select a default timezone for your website'), $timezone, ''), + + '$baseurl' => $a->get_baseurl(), + + + + '$submit' => t('Submit'), + + )); + return $o; + }; break; + } - - $o .= check_php($phpath); - - $o .= check_keys(); - - - require_once('datetime.php'); - - $tpl = get_markup_template('install_db.tpl'); - $o .= replace_macros($tpl, array( - '$lbl_01' => t('Friendica Social Communications Server'), - '$lbl_02' => t('Installation'), - '$lbl_03' => t('In order to install Friendica we need to know how to connect to your database.'), - '$lbl_04' => t('Please contact your hosting provider or site administrator if you have questions about these settings.'), - '$lbl_05' => t('The database you specify below should already exist. If it does not, please create it before continuing.'), - '$lbl_06' => t('Database Server Name'), - '$lbl_07' => t('Database Login Name'), - '$lbl_08' => t('Database Login Password'), - '$lbl_09' => t('Database Name'), - '$lbl_10' => t('Please select a default timezone for your website'), - '$lbl_11' => t('Site administrator email address. Your account email address must match this in order to use the web admin panel.'), - '$baseurl' => $a->get_baseurl(), - '$tzselect' => ((x($_POST,'timezone')) ? select_timezone($_POST['timezone']) : select_timezone()), - '$submit' => t('Submit'), - '$dbhost' => ((x($_POST,'dbhost')) ? notags(trim($_POST['dbhost'])) : 'localhost'), - '$dbuser' => notags(trim($_POST['dbuser'])), - '$dbpass' => notags(trim($_POST['dbpass'])), - '$dbdata' => notags(trim($_POST['dbdata'])), - '$phpath' => $phpath, - '$adminmail' => notags(trim($_POST['adminmail'])) - )); - - return $o; } -function check_php(&$phpath) { - $o = ''; - $phpath = trim(shell_exec('which php')); - if(! strlen($phpath)) { - $o .= t('Could not find a command line version of PHP in the web server PATH.') . EOL; - $o .= t('This is required. Please adjust the configuration file .htconfig.php accordingly.') . EOL; +/** + * checks : array passed to template + * title : string + * status : boolean + * required : boolean + * help : string optional + */ +function check_add(&$checks, $title, $status, $required, $help){ + $checks[] = array( + 'title' => $title, + 'status' => $status, + 'required' => $required, + 'help' => $help, + ); +} + +function check_php(&$phpath, &$checks) { + if (strlen($phpath)){ + $passed = file_exists($phpath); + } else { + $phpath = trim(shell_exec('which php')); + $passed = strlen($phpath); } - if(strlen($phpath)) { + $help = ""; + if(!$passed) { + $help .= t('Could not find a command line version of PHP in the web server PATH.'). EOL; + $tpl = get_markup_template('field_input.tpl'); + $help .= replace_macros($tpl, array( + '$field' => array('phppath', t('PHP executable path'), $phpath, t('Enter full path to php executable')), + )); + $phpath=""; + } + + check_add($checks, t('Command line PHP'), $passed, true, $help); + + if($passed) { $str = autoname(8); $cmd = "$phpath testargs.php $str"; $result = trim(shell_exec($cmd)); - if($result != $str) { - $o .= t('The command line version of PHP on your system does not have "register_argc_argv" enabled.') . EOL; - $o .= t('This is required for message delivery to work.') . EOL; + $passed2 = $result == $str; + $help = ""; + if(!$passed2) { + $help .= t('The command line version of PHP on your system does not have "register_argc_argv" enabled.'). EOL; + $help .= t('This is required for message delivery to work.'); } + check_add($checks, t('PHP "register_argc_argv"'), $passed, true, $help); } - return $o; + } -function check_keys() { +function check_keys(&$checks) { - $o = ''; + $help = ''; $res = false; @@ -187,45 +360,73 @@ function check_keys() { // Get private key if(! $res) { - $o .= t('Error: the "openssl_pkey_new" function on this system is not able to generate encryption keys') . EOL; - $o .= t('If running under Windows, please see "http://www.php.net/manual/en/openssl.installation.php".') . EOL; + $help .= t('Error: the "openssl_pkey_new" function on this system is not able to generate encryption keys'). EOL; + $help .= t('If running under Windows, please see "http://www.php.net/manual/en/openssl.installation.php".'); } - return $o; + check_add($checks, t('Generate encryption keys'), $res, true, $help); } -function check_funcs() { - if((function_exists('apache_get_modules')) && (! in_array('mod_rewrite',apache_get_modules()))) - notice( t('Error: Apache webserver mod-rewrite module is required but not installed.') . EOL); - if(! function_exists('curl_init')) - notice( t('Error: libCURL PHP module required but not installed.') . EOL); - if(! function_exists('imagecreatefromjpeg')) - notice( t('Error: GD graphics PHP module with JPEG support required but not installed.') . EOL); - if(! function_exists('openssl_public_encrypt')) - notice( t('Error: openssl PHP module required but not installed.') . EOL); - if(! function_exists('mysqli_connect')) - notice( t('Error: mysqli PHP module required but not installed.') . EOL); - if(! function_exists('mb_strlen')) - notice( t('Error: mb_string PHP module required but not installed.') . EOL); +function check_funcs(&$checks) { + $ck_funcs = array(); + check_add($ck_funcs, t('libCurl PHP module'), true, true, ""); + check_add($ck_funcs, t('GD graphics PHP module'), true, true, ""); + check_add($ck_funcs, t('OpenSSL PHP module'), true, true, ""); + check_add($ck_funcs, t('mysqli PHP module'), true, true, ""); + check_add($ck_funcs, t('mb_string PHP module'), true, true, ""); + - if((x($_SESSION,'sysmsg')) && is_array($_SESSION['sysmsg']) && count($_SESSION['sysmsg'])) - notice( t('Please see the file "INSTALL.txt".') . EOL); + if(function_exists('apache_get_modules')){ + if (! in_array('mod_rewrite',apache_get_modules())) { + check_add($ck_funcs, t('Apace mod_rewrite module'), false, true, t('Error: Apache webserver mod-rewrite module is required but not installed.')); + } else { + check_add($ck_funcs, t('Apace mod_rewrite module'), true, true, ""); + } + } + if(! function_exists('curl_init')){ + $ck_funcs[0]['status']= false; + $ck_funcs[0]['help']= t('Error: libCURL PHP module required but not installed.'); + } + if(! function_exists('imagecreatefromjpeg')){ + $ck_funcs[1]['status']= false; + $ck_funcs[1]['help']= t('Error: GD graphics PHP module with JPEG support required but not installed.'); + } + if(! function_exists('openssl_public_encrypt')) { + $ck_funcs[2]['status']= false; + $ck_funcs[2]['help']= t('Error: openssl PHP module required but not installed.'); + } + if(! function_exists('mysqli_connect')){ + $ck_funcs[3]['status']= false; + $ck_funcs[3]['help']= t('Error: mysqli PHP module required but not installed.'); + } + if(! function_exists('mb_strlen')){ + $ck_funcs[4]['status']= false; + $ck_funcs[4]['help']= t('Error: mb_string PHP module required but not installed.'); + } + + $checks = array_merge($checks, $ck_funcs); + + /*if((x($_SESSION,'sysmsg')) && is_array($_SESSION['sysmsg']) && count($_SESSION['sysmsg'])) + notice( t('Please see the file "INSTALL.txt".') . EOL);*/ } -function check_htconfig() { - - if(((file_exists('.htconfig.php')) && (! is_writable('.htconfig.php'))) - || (! is_writable('.'))) { - - $o = t('The web installer needs to be able to create a file called ".htconfig.php" in the top folder of your web server and it is unable to do so.'); - $o .= t('This is most often a permission setting, as the web server may not be able to write files in your folder - even if you can.'); - $o .= t('Please check with your site documentation or support people to see if this situation can be corrected.'); - $o .= t('If not, you may be required to perform a manual installation. Please see the file "INSTALL.txt" for instructions.'); +function check_htconfig(&$checks) { + $status = true; + $help = ""; + if( (file_exists('.htconfig.php') && !is_writable('.htconfig.php')) || + (!file_exists('.htconfig.php') && !is_writable('.')) ) { + + $status=false; + $help = t('The web installer needs to be able to create a file called ".htconfig.php" in the top folder of your web server and it is unable to do so.') .EOL; + $help .= t('This is most often a permission setting, as the web server may not be able to write files in your folder - even if you can.').EOL; + $help .= t('Please check with your site documentation or support people to see if this situation can be corrected.').EOL; + $help .= t('If not, you may be required to perform a manual installation. Please see the file "INSTALL.txt" for instructions.').EOL; } - return $o; + check_add($checks, t('.htconfig.php is writable'), $status, true, $help); + } @@ -236,18 +437,27 @@ function manual_config(&$a) { return $o; } +function load_database_rem($v, $i){ + $l = trim($i); + if (strlen($l)>1 && ($l[0]=="-" || ($l[0]=="/" && $l[1]=="*"))){ + return $v; + } else { + return $v."\n".$i; + } +} + function load_database($db) { $str = file_get_contents('database.sql'); + $str = array_reduce(explode("\n", $str),"load_database_rem",""); $arr = explode(';',$str); - $errors = 0; + $errors = false; foreach($arr as $a) { if(strlen(trim($a))) { $r = @$db->q(trim($a)); if(! $r) { - notice( t('Errors encountered creating database tables.') . $a . EOL); - $errors ++; + $errors .= t('Errors encountered creating database tables.') . $a . EOL; } } } diff --git a/view/field_select_raw.tpl b/view/field_select_raw.tpl new file mode 100644 index 000000000..765b285d9 --- /dev/null +++ b/view/field_select_raw.tpl @@ -0,0 +1,8 @@ + +
-$lbl_03 $lbl_04 $lbl_05
+$info_01
+$info_02
+$info_03