2010-08-16 06:49:29 +02:00
< ? php
function install_post ( & $a ) {
global $db ;
2010-12-03 02:31:48 +01:00
$urlpath = $a -> get_path ();
2010-08-16 06:49:29 +02:00
$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' ]));
require_once ( " dba.php " );
2011-03-22 01:34:29 +01:00
unset ( $db );
2010-12-22 22:55:44 +01:00
$db = new dba ( $dbhost , $dbuser , $dbpass , $dbdata , true );
2010-08-16 06:49:29 +02:00
2010-08-18 03:44:13 +02:00
if ( mysqli_connect_errno ()) {
2011-03-22 01:34:29 +01:00
unset ( $db );
2010-11-18 11:59:59 +01:00
$db = new dba ( $dbhost , $dbuser , $dbpass , '' , true );
2011-01-02 23:36:30 +01:00
if ( ! mysqli_connect_errno ()) {
2010-11-18 11:59:59 +01:00
$r = q ( " CREATE DATABASE '%s' " ,
dbesc ( $dbdata )
);
2011-03-22 01:34:29 +01:00
if ( $r ) {
unset ( $db );
2010-12-22 22:55:44 +01:00
$db = new dba ( $dbhost , $dbuser , $dbpass , $dbdata , true );
2011-03-22 01:34:29 +01:00
}
2010-11-18 11:59:59 +01:00
}
if ( mysqli_connect_errno ()) {
notice ( t ( 'Could not create/connect to database.' ) . EOL );
return ;
}
2010-08-16 06:49:29 +02:00
}
2010-11-18 11:59:59 +01:00
notice ( t ( 'Connected to database.' ) . EOL );
2010-08-16 06:49:29 +02:00
2010-09-23 03:00:19 +02:00
$tpl = load_view_file ( 'view/htconfig.tpl' );
2010-08-16 06:49:29 +02:00
$txt = replace_macros ( $tpl , array (
'$dbhost' => $dbhost ,
'$dbuser' => $dbuser ,
'$dbpass' => $dbpass ,
'$dbdata' => $dbdata ,
'$timezone' => $timezone ,
2010-12-03 02:31:48 +01:00
'$urlpath' => $urlpath ,
2010-08-16 06:49:29 +02:00
'$phpath' => $phpath
));
$result = file_put_contents ( '.htconfig.php' , $txt );
if ( ! $result ) {
$a -> data = $txt ;
}
$errors = load_database ( $db );
2010-11-06 13:07:10 +01:00
2011-03-22 01:34:29 +01:00
if ( $errors )
$a -> data [ 'db_failed' ] = true ;
else
$a -> data [ 'db_installed' ] = true ;
2010-08-16 06:49:29 +02:00
2011-03-22 01:34:29 +01:00
return ;
2010-08-16 06:49:29 +02:00
}
function install_content ( & $a ) {
2011-03-22 01:34:29 +01:00
global $db ;
2010-11-18 11:59:59 +01:00
$o = '' ;
2011-03-22 01:34:29 +01:00
if ( x ( $a -> data , 'db_installed' )) {
$o .= '<h2>' . t ( 'Proceed with Installation' ) . '</h2>' ;
$o .= '<p style="font-size: 130%;">' ;
$o .= t ( 'Your Friendika 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 .= '<br />' ;
$o .= '<a href="' . $a -> get_baseurl () . '/register' . '">' . t ( 'Proceed to registration' ) . '</a>' ;
$o .= '</p>' ;
return $o ;
}
if ( x ( $a -> data , 'db_failed' )) {
$o .= t ( 'Database import failed.' ) . EOL ;
$o .= t ( 'You may need to import the file "database.sql" manually using phpmyadmin or mysql.' ) . EOL ;
$o .= t ( 'Please see the file "INSTALL.txt".' ) . EOL ;
return $o ;
}
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 '' ;
}
}
2010-11-18 11:59:59 +01:00
2010-11-03 04:17:46 +01:00
notice ( t ( 'Welcome to Friendika.' ) . EOL );
2010-08-16 06:49:29 +02:00
2010-11-18 11:59:59 +01:00
check_funcs ();
2010-08-16 06:49:29 +02:00
$o .= check_htconfig ();
if ( strlen ( $o ))
return $o ;
if ( strlen ( $a -> data )) {
$o .= manual_config ( $a );
return ;
}
$o .= check_php ( $phpath );
2010-11-26 00:33:32 +01:00
$o .= check_keys ();
2010-08-16 06:49:29 +02:00
require_once ( 'datetime.php' );
2010-09-23 03:00:19 +02:00
$tpl = load_view_file ( 'view/install_db.tpl' );
2010-08-16 06:49:29 +02:00
$o .= replace_macros ( $tpl , array (
2010-12-03 02:31:48 +01:00
'$baseurl' => $a -> get_baseurl (),
2010-08-16 06:49:29 +02:00
'$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
));
return $o ;
}
function check_php ( & $phpath ) {
2010-11-06 13:07:10 +01:00
$o = '' ;
2010-08-16 06:49:29 +02:00
$phpath = trim ( shell_exec ( 'which php' ));
if ( ! strlen ( $phpath )) {
2010-11-26 00:33:32 +01:00
$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 ;
}
if ( strlen ( $phpath )) {
$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 ;
}
2010-08-16 06:49:29 +02:00
}
return $o ;
2010-11-26 00:33:32 +01:00
2010-08-16 06:49:29 +02:00
}
2010-11-26 00:33:32 +01:00
function check_keys () {
$o = '' ;
$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 23:07:27 +01:00
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 ;
}
2010-11-26 00:33:32 +01:00
return $o ;
}
2010-11-18 11:59:59 +01:00
function check_funcs () {
2010-11-19 00:57:09 +01:00
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 );
2010-11-18 11:59:59 +01:00
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 );
2010-11-19 00:57:09 +01:00
if (( x ( $_SESSION , 'sysmsg' )) && strlen ( $_SESSION [ 'sysmsg' ]))
2010-12-22 22:55:44 +01:00
notice ( t ( 'Please see the file "INSTALL.txt".' ) . EOL );
2010-11-18 11:59:59 +01:00
}
2010-08-16 06:49:29 +02:00
function check_htconfig () {
if ((( file_exists ( '.htconfig.php' )) && ( ! is_writable ( '.htconfig.php' )))
|| ( ! is_writable ( '.' ))) {
2010-11-06 13:07:10 +01:00
$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.' );
2010-12-22 22:55:44 +01:00
$o .= t ( 'If not, you may be required to perform a manual installation. Please see the file "INSTALL.txt" for instructions.' );
2010-08-16 06:49:29 +02:00
}
2010-11-16 04:27:15 +01:00
return $o ;
2010-08-16 06:49:29 +02:00
}
function manual_config ( & $a ) {
2010-11-16 04:27:15 +01:00
$data = htmlentities ( $a -> data );
2010-11-06 13:07:10 +01: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-16 04:27:15 +01:00
$o .= " <textarea rows= \" 24 \" cols= \" 80 \" > $data </textarea> " ;
2010-11-06 13:07:10 +01:00
return $o ;
2010-08-16 06:49:29 +02:00
}
function load_database ( $db ) {
$str = file_get_contents ( 'database.sql' );
$arr = explode ( ';' , $str );
$errors = 0 ;
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 ++ ;
}
}
2010-11-22 08:00:01 +01:00
}
2010-08-16 06:49:29 +02:00
return $errors ;
}