2010-08-16 00:49:29 -04:00
< ? php
2012-01-02 14:16:28 -05:00
$install_wizard_pass = 1 ;
function install_init ( & $a ){
2012-05-23 07:38:31 -04:00
// $baseurl/install/testrwrite to test if rewite in .htaccess is working
if ( $a -> argc == 2 && $a -> argv [ 1 ] == " testrewrite " ) {
echo " ok " ;
killme ();
}
2012-01-02 14:16:28 -05:00
global $install_wizard_pass ;
if ( x ( $_POST , 'pass' ))
$install_wizard_pass = intval ( $_POST [ 'pass' ]);
}
2010-08-16 00:49:29 -04:00
function install_post ( & $a ) {
2012-01-02 14:16:28 -05:00
global $install_wizard_pass , $db ;
2010-08-16 00:49:29 -04:00
2012-01-02 14:16:28 -05:00
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' ]));
2012-12-28 16:51:50 -05:00
require_once ( " include/dba.php " );
2012-01-02 14:16:28 -05:00
unset ( $db );
$db = new dba ( $dbhost , $dbuser , $dbpass , $dbdata , true );
/* if ( get_db_errno ()) {
2011-03-21 20:34:29 -04:00
unset ( $db );
2012-01-02 14:16:28 -05:00
$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 ;
2011-03-21 20:34:29 -04:00
}
2011-07-07 22:12:35 -04:00
2012-01-02 14:16:28 -05:00
return ;
break ;
2012-08-18 15:28:49 -04:00
case 4 :
2012-01-02 14:16:28 -05:00
$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 ;
}
2010-08-16 00:49:29 -04:00
2012-01-02 14:16:28 -05:00
$errors = load_database ( $db );
2010-11-06 08:07:10 -04:00
2012-01-02 14:16:28 -05:00
if ( $errors )
$a -> data [ 'db_failed' ] = $errors ;
else
$a -> data [ 'db_installed' ] = true ;
2010-08-16 00:49:29 -04:00
2012-01-02 14:16:28 -05:00
return ;
break ;
}
2010-08-16 00:49:29 -04:00
}
2011-12-03 03:08:04 -05:00
function get_db_errno () {
if ( class_exists ( 'mysqli' ))
return mysqli_connect_errno ();
else
return mysql_errno ();
}
2010-08-16 00:49:29 -04:00
function install_content ( & $a ) {
2012-01-02 14:16:28 -05:00
global $install_wizard_pass , $db ;
2010-11-18 05:59:59 -05:00
$o = '' ;
2012-01-02 14:16:28 -05:00
$wizard_status = " " ;
$install_title = t ( 'Friendica Social Communications Server - Setup' );
2012-05-23 07:38:31 -04:00
2012-01-02 14:16:28 -05:00
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.' );
}
2011-03-21 20:34:29 -04:00
2012-05-23 07:38:31 -04:00
$db_return_text = " " ;
2011-03-21 20:34:29 -04:00
if ( x ( $a -> data , 'db_installed' )) {
2012-01-02 14:16:28 -05:00
$txt = '<p style="font-size: 130%;">' ;
$txt .= t ( 'Your Friendica site database has been installed.' ) . EOL ;
2012-05-23 07:38:31 -04:00
$db_return_text .= $txt ;
2011-03-21 20:34:29 -04:00
}
if ( x ( $a -> data , 'db_failed' )) {
2012-01-02 14:16:28 -05:00
$txt = t ( 'You may need to import the file "database.sql" manually using phpmyadmin or mysql.' ) . EOL ;
$txt .= t ( 'Please see the file "INSTALL.txt".' ) . EOL . " <hr> " ;
$txt .= " <pre> " . $a -> data [ 'db_failed' ] . " </pre> " . EOL ;
2012-05-23 07:38:31 -04:00
$db_return_text .= $txt ;
2011-03-21 20:34:29 -04:00
}
2012-05-23 07:38:31 -04:00
2011-03-21 20:34:29 -04:00
if ( $db && $db -> connected ) {
$r = q ( " SELECT COUNT(*) as `total` FROM `user` " );
if ( $r && count ( $r ) && $r [ 0 ][ 'total' ]) {
2012-01-02 14:16:28 -05:00
$tpl = get_markup_template ( 'install.tpl' );
return replace_macros ( $tpl , array (
'$title' => $install_title ,
'$pass' => '' ,
'$status' => t ( 'Permission denied.' ),
'$text' => '' ,
));
2011-03-21 20:34:29 -04:00
}
}
2010-11-18 05:59:59 -05:00
2012-05-23 07:38:31 -04:00
if ( x ( $a -> data , 'txt' ) && strlen ( $a -> data [ 'txt' ])) {
$db_return_text .= manual_config ( $a );
}
if ( $db_return_text != " " ) {
2012-08-18 15:28:49 -04:00
$tpl = get_markup_template ( 'install.tpl' );
2012-05-23 07:38:31 -04:00
return replace_macros ( $tpl , array (
'$title' => $install_title ,
'$pass' => " " ,
'$text' => $db_return_text . what_next (),
));
}
2012-01-02 14:16:28 -05:00
switch ( $install_wizard_pass ){
case 1 : { // System check
2010-11-18 05:59:59 -05:00
2012-01-02 14:16:28 -05:00
$checks = array ();
2010-08-16 00:49:29 -04:00
2012-01-02 14:16:28 -05:00
check_funcs ( $checks );
2010-08-16 00:49:29 -04:00
2012-01-02 14:16:28 -05:00
check_htconfig ( $checks );
2010-08-16 00:49:29 -04:00
2012-12-24 09:59:46 -05:00
check_smarty3 ( $checks );
2012-01-02 14:16:28 -05:00
check_keys ( $checks );
2012-02-10 17:03:43 -05:00
if ( x ( $_POST , 'phpath' ))
$phpath = notags ( trim ( $_POST [ 'phpath' ]));
2010-11-25 18:33:32 -05:00
2012-01-02 14:16:28 -05:00
check_php ( $phpath , $checks );
2010-11-25 18:33:32 -05:00
2012-06-01 03:31:24 -04:00
check_htaccess ( $checks );
2012-01-02 14:16:28 -05:00
function check_passed ( $v , $c ){
if ( $c [ 'required' ])
$v = $v && $c [ 'status' ];
return $v ;
}
$checkspassed = array_reduce ( $checks , " check_passed " , true );
2012-06-01 03:31:24 -04:00
2012-01-02 14:16:28 -05:00
$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 ,
2012-02-09 18:13:34 -05:00
'$baseurl' => $a -> get_baseurl (),
2012-01-02 14:16:28 -05:00
));
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' ]));
2012-02-10 17:03:43 -05:00
$phpath = notags ( trim ( $_POST [ 'phpath' ]));
2012-01-02 14:16:28 -05:00
$tpl = get_markup_template ( 'install_db.tpl' );
2012-12-25 13:48:02 -05:00
$o .= replace_macros ( $tpl , array (
2012-01-02 14:16:28 -05:00
'$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
2012-12-28 16:51:50 -05:00
require_once ( 'include/datetime.php' );
2012-01-02 14:16:28 -05:00
$dbhost = (( x ( $_POST , 'dbhost' )) ? notags ( trim ( $_POST [ 'dbhost' ])) : 'localhost' );
$dbuser = notags ( trim ( $_POST [ 'dbuser' ]));
$dbpass = notags ( trim ( $_POST [ 'dbpass' ]));
$dbdata = notags ( trim ( $_POST [ 'dbdata' ]));
2012-02-10 17:03:43 -05:00
$phpath = notags ( trim ( $_POST [ 'phpath' ]));
2012-01-02 14:16:28 -05:00
$adminmail = notags ( trim ( $_POST [ 'adminmail' ]));
$timezone = (( x ( $_POST , 'timezone' )) ? ( $_POST [ 'timezone' ]) : 'America/Los_Angeles' );
$tpl = get_markup_template ( 'install_settings.tpl' );
2012-12-25 13:48:02 -05:00
$o .= replace_macros ( $tpl , array (
2012-01-02 14:16:28 -05:00
'$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 ;
}
}
2010-08-16 00:49:29 -04:00
2012-01-02 14:16:28 -05:00
/**
* 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 ,
);
2010-08-16 00:49:29 -04:00
}
2012-01-02 14:16:28 -05:00
function check_php ( & $phpath , & $checks ) {
2013-03-01 04:43:04 -05:00
$passed = $passed2 = $passed3 = false ;
2012-01-02 14:16:28 -05:00
if ( strlen ( $phpath )){
$passed = file_exists ( $phpath );
} else {
$phpath = trim ( shell_exec ( 'which php' ));
$passed = strlen ( $phpath );
2010-11-25 18:33:32 -05:00
}
2012-01-02 14:16:28 -05:00
$help = " " ;
if ( ! $passed ) {
$help .= t ( 'Could not find a command line version of PHP in the web server PATH.' ) . EOL ;
2012-05-24 04:21:33 -04:00
$help .= t ( " If you don't have a command line version of PHP installed on server, you will not be able to run background polling via cron. See <a href='http://friendica.com/node/27'>'Activating scheduled tasks'</a> " ) . EOL ;
$help .= EOL . EOL ;
2012-01-02 14:16:28 -05:00
$tpl = get_markup_template ( 'field_input.tpl' );
$help .= replace_macros ( $tpl , array (
2012-05-24 04:21:33 -04:00
'$field' => array ( 'phpath' , t ( 'PHP executable path' ), $phpath , t ( 'Enter full path to php executable. You can leave this blank to continue the installation.' )),
2012-01-02 14:16:28 -05:00
));
$phpath = " " ;
}
2012-05-24 04:21:33 -04:00
check_add ( $checks , t ( 'Command line PHP' ) . ( $passed ? " (<tt> $phpath </tt>) " : " " ), $passed , false , $help );
2012-01-02 14:16:28 -05:00
if ( $passed ) {
2013-03-01 04:43:04 -05:00
$cmd = " $phpath -v " ;
$result = trim ( shell_exec ( $cmd ));
$passed2 = ( strpos ( $result , " (cli) " ) !== false );
list ( $result ) = explode ( " \n " , $result );
$help = " " ;
if ( ! $passed2 ) {
$help .= t ( 'PHP executable is not the php cli binary (could be cgi-fgci version)' ) . EOL ;
$help .= t ( 'Found PHP version: ' ) . " <tt> $result </tt> " ;
}
check_add ( $checks , t ( 'PHP cli binary' ), $passed2 , true , $help );
}
if ( $passed2 ) {
2010-11-25 18:33:32 -05:00
$str = autoname ( 8 );
$cmd = " $phpath testargs.php $str " ;
$result = trim ( shell_exec ( $cmd ));
2013-03-01 04:43:04 -05:00
$passed3 = $result == $str ;
2012-01-02 14:16:28 -05:00
$help = " " ;
2013-03-01 04:43:04 -05:00
if ( ! $passed3 ) {
2012-01-02 14:16:28 -05:00
$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.' );
2010-11-25 18:33:32 -05:00
}
2013-03-01 04:43:04 -05:00
check_add ( $checks , t ( 'PHP register_argc_argv' ), $passed3 , true , $help );
2010-08-16 00:49:29 -04:00
}
2012-01-02 14:16:28 -05:00
2010-11-25 18:33:32 -05:00
2010-08-16 00:49:29 -04:00
}
2012-01-02 14:16:28 -05:00
function check_keys ( & $checks ) {
2010-11-25 18:33:32 -05:00
2012-01-02 14:16:28 -05:00
$help = '' ;
2010-11-25 18:33:32 -05:00
$res = false ;
if ( function_exists ( 'openssl_pkey_new' ))
$res = openssl_pkey_new ( array (
'digest_alg' => 'sha1' ,
'private_key_bits' => 4096 ,
'encrypt_key' => false ));
// Get private key
2010-12-22 17:07:27 -05:00
if ( ! $res ) {
2012-01-02 14:16:28 -05:00
$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".' );
2010-12-22 17:07:27 -05:00
}
2012-01-02 14:16:28 -05:00
check_add ( $checks , t ( 'Generate encryption keys' ), $res , true , $help );
2010-11-25 18:33:32 -05:00
}
2012-01-02 14:16:28 -05:00
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 ( function_exists ( 'apache_get_modules' )){
if ( ! in_array ( 'mod_rewrite' , apache_get_modules ())) {
2012-04-17 01:58:52 -04:00
check_add ( $ck_funcs , t ( 'Apache mod_rewrite module' ), false , true , t ( 'Error: Apache webserver mod-rewrite module is required but not installed.' ));
2012-01-02 14:16:28 -05:00
} else {
2012-04-17 01:58:52 -04:00
check_add ( $ck_funcs , t ( 'Apache mod_rewrite module' ), true , true , " " );
2012-01-02 14:16:28 -05:00
}
}
2012-06-01 03:31:24 -04:00
2012-01-02 14:16:28 -05:00
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.' );
}
2011-06-05 01:48:43 -04:00
2012-01-02 14:16:28 -05:00
$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 ); */
2010-11-18 05:59:59 -05:00
}
2012-01-02 14:16:28 -05:00
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 ;
2012-05-23 07:38:31 -04:00
$help .= t ( 'At the end of this procedure, we will give you a text to save in a file named .htconfig.php in your Friendica top folder.' ) . EOL ;
$help .= t ( 'You can alternatively skip this procedure and perform a manual installation. Please see the file "INSTALL.txt" for instructions.' ) . EOL ;
2010-08-16 00:49:29 -04:00
}
2012-06-01 03:31:24 -04:00
2012-05-23 07:38:31 -04:00
check_add ( $checks , t ( '.htconfig.php is writable' ), $status , false , $help );
2012-06-01 03:31:24 -04:00
2010-08-16 00:49:29 -04:00
}
2012-12-24 09:59:46 -05:00
function check_smarty3 ( & $checks ) {
$status = true ;
$help = " " ;
if ( ! is_writable ( 'view/smarty3' ) ) {
$status = false ;
$help = t ( 'Friendica uses the Smarty3 template engine to render its web views. Smarty3 compiles templates to PHP to speed up rendering.' ) . EOL ;
$help .= t ( 'In order to store these compiled templates, the web server needs to have write access to the directory view/smarty3/ under the Friendica top level folder.' ) . EOL ;
$help .= t ( 'Please ensure that the user that your web server runs as (e.g. www-data) has write access to this folder.' ) . EOL ;
$help .= t ( 'Note: as a security measure, you should give the web server write access to view/smarty3/ only--not the template files (.tpl) that it contains.' ) . EOL ;
}
check_add ( $checks , t ( 'view/smarty3 is writable' ), $status , true , $help );
}
2012-05-23 07:38:31 -04:00
function check_htaccess ( & $checks ) {
$a = get_app ();
$status = true ;
$help = " " ;
2012-06-01 03:31:24 -04:00
if ( function_exists ( 'curl_init' )){
$test = fetch_url ( $a -> get_baseurl () . " /install/testrewrite " );
if ( $test != " ok " ) {
$status = false ;
$help = t ( 'Url rewrite in .htaccess is not working. Check your server configuration.' );
}
check_add ( $checks , t ( 'Url rewrite is working' ), $status , true , $help );
} else {
// cannot check modrewrite if libcurl is not installed
}
2012-05-23 07:38:31 -04:00
}
2010-08-16 00:49:29 -04:00
function manual_config ( & $a ) {
2012-10-14 20:16:25 -04:00
$data = htmlentities ( $a -> data [ 'txt' ], ENT_COMPAT , 'UTF-8' );
2010-11-06 08:07:10 -04:00
$o = t ( 'The database configuration file ".htconfig.php" could not be written. Please use the enclosed text to create a configuration file in your web server root.' );
2010-11-15 22:27:15 -05:00
$o .= " <textarea rows= \" 24 \" cols= \" 80 \" > $data </textarea> " ;
2010-11-06 08:07:10 -04:00
return $o ;
2010-08-16 00:49:29 -04:00
}
2012-01-02 14:16:28 -05:00
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 ;
}
}
2010-08-16 00:49:29 -04:00
function load_database ( $db ) {
$str = file_get_contents ( 'database.sql' );
$arr = explode ( ';' , $str );
2012-01-02 14:16:28 -05:00
$errors = false ;
2010-08-16 00:49:29 -04:00
foreach ( $arr as $a ) {
if ( strlen ( trim ( $a ))) {
$r = @ $db -> q ( trim ( $a ));
if ( ! $r ) {
2012-01-02 14:16:28 -05:00
$errors .= t ( 'Errors encountered creating database tables.' ) . $a . EOL ;
2010-08-16 00:49:29 -04:00
}
}
2010-11-22 02:00:01 -05:00
}
2010-08-16 00:49:29 -04:00
return $errors ;
2011-05-23 05:39:57 -04:00
}
2012-04-17 01:58:52 -04:00
2012-05-23 07:38:31 -04:00
function what_next () {
$a = get_app ();
$baseurl = $a -> get_baseurl ();
return
t ( '<h1>What next</h1>' )
. " <p> " . t ( 'IMPORTANT: You will need to [manually] setup a scheduled task for the poller.' )
. t ( 'Please see the file "INSTALL.txt".' )
. " </p><p> "
2012-09-02 04:47:04 -04:00
. t ( " Go to your new Friendica node <a href=' $baseurl /register'>registration page</a> and register as new user. Remember to use the same email you have entered as administrator email. This will allow you to enter the site admin panel. " )
2012-05-23 07:38:31 -04:00
. " </p> " ;
}
2012-04-17 01:58:52 -04:00