2006-09-19 09:00:57 +02:00
#!/usr/bin/php -qC
2006-05-28 01:59:41 +02:00
< ? php
/**
2006-05-29 04:56:16 +02:00
* Setup - Command line interface
2006-05-28 01:59:41 +02:00
*
2006-05-29 04:56:16 +02:00
* @ link http :// www . egroupware . org
* @ package setup
2006-05-28 01:59:41 +02:00
* @ author Ralf Becker < RalfBecker - AT - outdoor - training . de >
2013-06-18 20:14:08 +02:00
* @ copyright ( c ) 2006 - 13 by Ralf Becker < RalfBecker - AT - outdoor - training . de >
2006-05-28 01:59:41 +02:00
* @ license http :// opensource . org / licenses / gpl - license . php GPL - GNU General Public License
2006-05-29 04:56:16 +02:00
* @ version $Id $
2006-05-28 01:59:41 +02:00
*/
2006-05-29 04:56:16 +02:00
chdir ( dirname ( __FILE__ )); // to enable our relative pathes to work
2006-05-28 01:59:41 +02:00
2013-09-10 19:31:15 +02:00
if ( php_sapi_name () !== 'cli' ) // security precaution: forbit calling setup-cli as web-page
2006-09-18 11:28:51 +02:00
{
die ( '<h1>setup-cli.php must NOT be called as web-page --> exiting !!!</h1>' );
}
2013-06-18 20:14:08 +02:00
$dry_run = false ;
array_shift ( $_SERVER [ 'argv' ]);
if ( $_SERVER [ 'argv' ])
2006-05-28 01:59:41 +02:00
{
2013-06-18 20:14:08 +02:00
if ( $_SERVER [ 'argv' ][ 0 ] == '--dry-run' )
{
$dry_run = true ;
array_shift ( $_SERVER [ 'argv' ]);
}
2006-05-28 01:59:41 +02:00
$arguments = $_SERVER [ 'argv' ];
$action = array_shift ( $arguments );
2009-05-30 22:15:31 +02:00
if ( isset ( $arguments [ 0 ])) list ( $_POST [ 'FormDomain' ]) = explode ( ',' , $arguments [ 0 ]); // header include needs that to detects the right domain
2006-05-28 01:59:41 +02:00
}
else
{
$action = '--version' ;
}
2006-05-29 04:56:16 +02:00
// setting the language from the enviroment
2006-05-31 02:27:15 +02:00
$_POST [ 'ConfigLang' ] = get_lang ( $charset );
2006-05-29 04:56:16 +02:00
create_http_enviroment (); // guessing the docroot etc.
2008-03-06 07:03:18 +01:00
if ( ini_get ( 'session.save_handler' ) == 'files' && ! is_writable ( ini_get ( 'session.save_path' )) && is_dir ( '/tmp' ) && is_writable ( '/tmp' ))
{
ini_set ( 'session.save_path' , '/tmp' ); // regular users may have no rights to apache's session dir
}
2012-06-13 15:36:57 +02:00
// check if date.timezone is set, report it and set something if not, as it gives tons of errors in install log
if ( ! ini_get ( 'date.timezone' ))
{
if ( ! ( $tz = date_default_timezone_get ())) $tz = 'UTC' ;
echo " No default timezone (php.ini date.timezone) set, we temporary set ' $tz '. You should fix that permanent! \n " ;
ini_set ( 'date.timezone' , $tz );
}
2006-05-29 04:56:16 +02:00
// setting up the $GLOBALS['egw_setup'] object AND including the header.inc.php if it exists
include ( 'inc/functions.inc.php' );
2011-05-28 09:23:02 +02:00
$GLOBALS [ 'egw_info' ][ 'flags' ][ 'no_exception_handler' ] = 'cli' ; // inc/functions.inc.php does NOT set it
2006-05-31 02:27:15 +02:00
$GLOBALS [ 'egw_setup' ] -> system_charset = $charset ;
2006-05-29 04:56:16 +02:00
if (( float ) PHP_VERSION < $GLOBALS [ 'egw_setup' ] -> required_php_version )
2006-05-28 01:59:41 +02:00
{
2013-06-18 20:14:08 +02:00
throw new egw_exception_wrong_userinput ( lang ( 'You are using PHP version %1. EGroupware now requires %2 or later, recommended is PHP %3.' , PHP_VERSION , $GLOBALS [ 'egw_setup' ] -> required_php_version , $GLOBALS [ 'egw_setup' ] -> recommended_php_version ), 98 );
2006-05-28 01:59:41 +02:00
}
switch ( $action )
{
case '--version' :
case '--check' :
2007-12-10 05:59:01 +01:00
setup_cmd :: check_installed ( $arguments [ 0 ], 0 , true );
2006-05-28 01:59:41 +02:00
break ;
2008-08-20 08:04:28 +02:00
2006-05-28 01:59:41 +02:00
case '--create-header' :
case '--edit-header' :
2006-05-29 04:56:16 +02:00
case '--upgrade-header' :
2006-06-03 16:45:49 +02:00
case '--update-header' :
2006-05-28 01:59:41 +02:00
do_header ( $action == '--create-header' , $arguments );
break ;
2008-08-20 08:04:28 +02:00
2006-05-29 04:56:16 +02:00
case '--install' :
2009-12-05 18:42:18 +01:00
do_install ( $arguments );
2006-05-29 04:56:16 +02:00
break ;
2008-08-20 08:04:28 +02:00
2006-05-29 04:56:16 +02:00
case '--config' :
do_config ( $arguments );
break ;
case '--admin' :
do_admin ( $arguments [ 0 ]);
break ;
case '--update' :
do_update ( $arguments [ 0 ]);
break ;
2008-08-20 08:04:28 +02:00
2011-06-29 10:40:24 +02:00
case '--register-hooks' :
case '--register-all-hooks' :
do_hooks ( $arguments [ 0 ]);
break ;
2006-05-29 04:56:16 +02:00
case '--backup' :
do_backup ( $arguments [ 0 ]);
break ;
case '--languages' :
echo html_entity_decode ( file_get_contents ( 'lang/languages' ), ENT_COMPAT , 'utf-8' );
break ;
case '--charsets' :
echo html_entity_decode ( implode ( " \n " , $GLOBALS [ 'egw_setup' ] -> translation -> get_charsets ( false )), ENT_COMPAT , 'utf-8' ) . " \n " ;
break ;
2008-08-20 08:04:28 +02:00
2006-05-28 01:59:41 +02:00
case '--exit-codes' :
list_exit_codes ();
break ;
2008-08-20 08:04:28 +02:00
2006-05-28 01:59:41 +02:00
case '--help' :
case '--usage' :
2006-06-22 05:40:18 +02:00
do_usage ( $arguments [ 0 ]);
2006-05-28 01:59:41 +02:00
break ;
2006-05-29 04:56:16 +02:00
default :
2008-01-14 06:44:32 +01:00
// we allow to call admin_cmd classes directly, if they define the constant SETUP_CLI_CALLABLE
if ( substr ( $action , 0 , 2 ) == '--' && class_exists ( $class = str_replace ( '-' , '_' , substr ( $action , 2 ))) &&
2010-07-26 10:20:14 +02:00
is_subclass_of ( $class , 'admin_cmd' ) && @ constant ( $class . '::SETUP_CLI_CALLABLE' ))
2008-01-14 06:44:32 +01:00
{
2009-05-24 15:59:03 +02:00
$args = array ();
$args [ 'domain' ] = array_shift ( $arguments ); // domain must be first argument, to ensure right domain get's selected in header-include
2008-01-14 06:44:32 +01:00
foreach ( $arguments as $arg )
{
list ( $name , $value ) = explode ( '=' , $arg , 2 );
if ( property_exists ( 'admin_cmd' , $name )) // dont allow to overwrite admin_cmd properties
{
throw new egw_exception_wrong_userinput ( lang ( " Invalid argument '%1' !!! " , $arg ), 90 );
}
2009-05-24 15:59:03 +02:00
if ( substr ( $name , - 1 ) == ']' ) // allow 1-dim. arrays
{
list ( $name , $sub ) = explode ( '[' , substr ( $name , 0 , - 1 ), 2 );
$args [ $name ][ $sub ] = $value ;
}
else
{
$args [ $name ] = $value ;
}
2008-01-14 06:44:32 +01:00
}
$cmd = new $class ( $args );
2013-06-18 20:14:08 +02:00
$msg = $cmd -> run ( $time = null , $set_modifier = true , $skip_checks = false , $check_only = $dry_run );
2008-01-14 06:44:32 +01:00
if ( is_array ( $msg )) $msg = print_r ( $msg , true );
echo " $msg\n " ;
break ;
}
throw new egw_exception_wrong_userinput ( lang ( " Unknown option '%1' !!! " , $action ), 90 );
2006-05-28 01:59:41 +02:00
}
exit ( 0 );
/**
2013-06-18 20:14:08 +02:00
* Configure EGroupware
2006-05-28 01:59:41 +02:00
*
2006-05-29 04:56:16 +02:00
* @ param array $args domain ( default ),[ config user ( admin )], password ,[, name = value , ... ] -- files - dir -- backup - dir -- mailserver
2006-05-28 01:59:41 +02:00
*/
2006-05-29 04:56:16 +02:00
function do_config ( $args )
2006-05-28 01:59:41 +02:00
{
2007-12-11 02:28:07 +01:00
$arg0 = explode ( ',' , array_shift ( $args ));
if ( ! ( $domain = @ array_shift ( $arg0 ))) $domain = 'default' ;
$user = @ array_shift ( $arg0 );
$password = @ array_shift ( $arg0 );
_fetch_user_password ( $user , $password );
2008-08-20 08:04:28 +02:00
2007-12-11 02:28:07 +01:00
if ( $arg0 ) // direct assignments (name=value,...) left
2006-05-29 04:56:16 +02:00
{
2007-12-11 02:28:07 +01:00
array_unshift ( $args , implode ( ',' , $arg0 ));
array_unshift ( $args , '--config' );
2006-06-22 05:40:18 +02:00
}
2008-08-20 08:04:28 +02:00
2007-12-11 02:28:07 +01:00
$cmd = new setup_cmd_config ( $domain , $user , $password , $args , true );
echo $cmd -> run () . " \n \n " ;
2008-08-20 08:04:28 +02:00
2007-12-11 02:28:07 +01:00
$cmd -> get_config ( true );
2006-06-22 05:40:18 +02:00
}
2011-06-29 10:40:24 +02:00
/**
* Register all hooks
*
* @ param array $args domain ( default ),[ config user ( admin )], password
*/
function do_hooks ( $arg )
{
global $setup_info ;
list ( $domain , $user , $password ) = explode ( ',' , $arg );
_fetch_user_password ( $user , $password );
$domains = $GLOBALS [ 'egw_domain' ];
if ( $domain && $domain != 'all' )
{
$domains = array ( $domain => $GLOBALS [ 'egw_domain' ][ $domain ]);
}
foreach ( $domains as $domain => $data )
{
$cmd = new setup_cmd_hooks ( $domain , $user , $password );
echo " $domain : " . $cmd -> run () . " \n " ;
}
echo " \n " ;
}
2006-06-22 05:40:18 +02:00
/**
* Updates the default EMailAdmin profile
*
* @ param array $values
*/
function do_emailadmin ()
{
$GLOBALS [ 'egw_setup' ] -> db -> select ( $GLOBALS [ 'egw_setup' ] -> config_table , 'config_name,config_value' , array (
'config_app' => 'phpgwapi' ,
" ((config_name LIKE 'mail%' AND config_name != 'mail_footer') OR config_name LIKE 'smtp%' OR config_name LIKE 'imap%' OR config_name='editforwardingaddress') " ,
), __LINE__ , __FILE__ );
while (( $row = $GLOBALS [ 'egw_setup' ] -> db -> row ( true )))
{
$config [ $row [ 'config_name' ]] = $row [ 'config_value' ];
}
$config [ 'smtpAuth' ] = $config [ 'smtp_auth_user' ] ? 'yes' : null ;
2012-04-25 12:08:53 +02:00
$emailadmin = new emailadmin_bo ( false , false ); // false=no session stuff
2006-06-22 05:40:18 +02:00
$emailadmin -> setDefaultProfile ( $config );
2008-08-20 08:04:28 +02:00
2006-06-22 05:40:18 +02:00
echo " \n " . lang ( 'EMailAdmin profile updated:' ) . " \n " ;
foreach ( $config as $name => $value )
{
echo str_pad ( $name . ':' , 22 ) . $value . " \n " ;
2006-05-31 19:21:25 +02:00
}
2006-05-28 01:59:41 +02:00
}
/**
2006-05-29 04:56:16 +02:00
* Create an admin account
*
2008-11-23 17:46:32 +01:00
* @ param string $arg domain ( default ),[ config user ( admin )], password , username , password ,[ first name ],[ last name ],[ email ],[ lang ]
2006-05-28 01:59:41 +02:00
*/
2006-05-29 04:56:16 +02:00
function do_admin ( $arg )
2006-05-28 01:59:41 +02:00
{
2008-11-23 17:46:32 +01:00
list ( $domain , $user , $password , $admin , $pw , $first , $last , $email , $lang ) = explode ( ',' , $arg );
2007-12-13 03:41:55 +01:00
_fetch_user_password ( $user , $password );
2008-08-20 08:04:28 +02:00
2008-11-23 17:46:32 +01:00
$cmd = new setup_cmd_admin ( $domain , $user , $password , $admin , $pw , $first , $last , $email , array (), $lang );
2007-12-13 03:41:55 +01:00
echo $cmd -> run () . " \n " ;
2006-05-28 01:59:41 +02:00
}
/**
2006-05-29 04:56:16 +02:00
* Backup one or all domains
2006-05-28 01:59:41 +02:00
*
2006-05-29 04:56:16 +02:00
* @ param string $arg domain ( all ),[ config user ( admin )], password ,[ backup - file , 'no' for no backup or empty for default name ]
* @ param boolean $quite_check quiten the call to _check_auth_config
2006-05-28 01:59:41 +02:00
*/
2006-05-29 04:56:16 +02:00
function do_backup ( $arg , $quite_check = false )
2006-05-28 01:59:41 +02:00
{
2006-05-29 04:56:16 +02:00
list ( $domain ,,, $backup ) = $options = explode ( ',' , $arg );
$domains = $GLOBALS [ 'egw_domain' ];
if ( $domain && $domain != 'all' )
{
$domains = array ( $domain => $GLOBALS [ 'egw_domain' ][ $domain ]);
}
foreach ( $domains as $domain => $data )
2006-05-28 01:59:41 +02:00
{
2006-05-29 04:56:16 +02:00
$options [ 0 ] = $domain ;
2008-08-20 08:04:28 +02:00
2006-05-29 04:56:16 +02:00
if ( $quite_check ) ob_start ();
_check_auth_config ( implode ( ',' , $options ), 14 );
if ( $quite_check ) ob_end_clean ();
2008-08-20 08:04:28 +02:00
2006-05-29 04:56:16 +02:00
if ( $backup == 'no' )
2006-05-28 01:59:41 +02:00
{
2006-05-29 04:56:16 +02:00
echo lang ( 'Backup skipped!' ) . " \n " ;
}
else
{
2010-09-08 10:55:06 +02:00
$db_backup = new db_backup ();
2006-05-29 04:56:16 +02:00
if ( is_resource ( $f = $db_backup -> fopen_backup ( $backup )))
{
2006-06-08 23:05:44 +02:00
echo lang ( 'Backup started, this might take a few minutes ...' ) . " \n " ;
2006-05-29 04:56:16 +02:00
$db_backup -> backup ( $f );
2006-05-31 02:27:15 +02:00
echo lang ( 'Backup finished' ) . " \n " ;
2006-05-29 04:56:16 +02:00
}
else // backup failed ==> dont start the upgrade
{
2009-05-31 10:15:11 +02:00
throw new egw_exception_wrong_userinput ( lang ( 'Backup failed' ) . ': ' . $f , 50 );
2006-05-29 04:56:16 +02:00
}
2006-05-28 01:59:41 +02:00
}
}
}
/**
2011-06-18 12:44:56 +02:00
* Update one or all domains , optional install a given app
2006-05-29 04:56:16 +02:00
*
2011-06-18 12:44:56 +02:00
* @ param string $arg domain ( all ),[ config user ( admin )], password ,[ backup - file , 'no' for no backup or empty for default name ],[ app to install or uppdate ]
2006-05-28 01:59:41 +02:00
*/
2006-05-29 04:56:16 +02:00
function do_update ( $arg )
2006-05-28 01:59:41 +02:00
{
2006-05-29 04:56:16 +02:00
global $setup_info ;
2006-05-28 01:59:41 +02:00
2011-06-18 12:44:56 +02:00
list ( $domain , $user , $password , $backup , $app ) = explode ( ',' , $arg );
2009-05-25 08:39:38 +02:00
_fetch_user_password ( $user , $password );
2006-05-28 01:59:41 +02:00
2006-05-29 04:56:16 +02:00
$domains = $GLOBALS [ 'egw_domain' ];
if ( $domain && $domain != 'all' )
{
$domains = array ( $domain => $GLOBALS [ 'egw_domain' ][ $domain ]);
}
foreach ( $domains as $domain => $data )
{
2009-05-25 08:39:38 +02:00
$arg = " $domain , $user , $password , $backup " ;
2008-08-20 08:04:28 +02:00
2006-05-29 04:56:16 +02:00
_check_auth_config ( $arg , 14 );
2008-08-20 08:04:28 +02:00
2011-06-18 12:44:56 +02:00
if ( $GLOBALS [ 'egw_info' ][ 'setup' ][ 'stage' ][ 'db' ] != 4 &&
( ! $app || ! in_array ( $app , setup_cmd :: $apps_to_install ) && ! in_array ( $app , setup_cmd :: $apps_to_upgrade )))
2006-05-29 04:56:16 +02:00
{
echo lang ( 'No update necessary, domain %1(%2) is up to date.' , $domain , $data [ 'db_type' ]) . " \n " ;
}
else
2006-05-28 01:59:41 +02:00
{
2006-05-29 04:56:16 +02:00
do_backup ( $arg , true );
2008-08-20 08:04:28 +02:00
2011-06-18 12:44:56 +02:00
$cmd = new setup_cmd_update ( $domain , $user , $password , $backup , true , $app );
2009-05-25 08:39:38 +02:00
echo $cmd -> run () . " \n " ;
2006-05-28 01:59:41 +02:00
}
}
2006-05-29 04:56:16 +02:00
}
/**
* Check if eGW is installed according to $stop and we have the necessary authorization for config
2008-08-20 08:04:28 +02:00
*
2006-05-31 02:27:15 +02:00
* The password can be specified as parameter , via the enviroment variable EGW_CLI_PASSWORD or
* querier from the user . Specifying it as parameter can be security problem !
2008-08-20 08:04:28 +02:00
*
2006-05-31 02:27:15 +02:00
* We allow the config user / pw of the domain OR the header admin user / pw !
2006-05-29 04:56:16 +02:00
*
* @ param string $arg [ domain ( default )],[ user ( admin )], password
2007-12-10 05:59:01 +01:00
* @ param int $stop see setup_cmd :: check_installed
2006-05-31 19:21:25 +02:00
* @ param boolean $set_lang = true set our charset , overwriting the charset of the eGW installation , default true
2006-05-29 04:56:16 +02:00
* @ return array with unprocessed arguments from $arg
*/
2006-05-31 19:21:25 +02:00
function _check_auth_config ( $arg , $stop , $set_lang = true )
2006-05-28 01:59:41 +02:00
{
2006-05-29 04:56:16 +02:00
$options = explode ( ',' , $arg );
if ( ! ( $domain = array_shift ( $options ))) $domain = 'default' ;
2007-12-10 05:59:01 +01:00
$user = array_shift ( $options );
$password = array_shift ( $options );
_fetch_user_password ( $user , $password );
setup_cmd :: check_installed ( $domain , $stop , true );
2006-05-31 19:21:25 +02:00
// reset charset for the output to the charset used by the OS
if ( $set_lang ) $GLOBALS [ 'egw_setup' ] -> system_charset = $GLOBALS [ 'charset' ];
2007-12-10 05:59:01 +01:00
setup_cmd :: check_setup_auth ( $user , $password , $domain );
2006-05-29 04:56:16 +02:00
return $options ;
2006-05-28 01:59:41 +02:00
}
/**
2013-06-18 20:14:08 +02:00
* Install EGroupware
2006-05-28 01:59:41 +02:00
*
2009-12-05 18:42:18 +01:00
* @ param array $args array ( 0 => " domain,[config user(admin)],password,[backup-file],[charset],[lang] " , " name=value " , ... )
2006-05-28 01:59:41 +02:00
*/
2006-05-29 04:56:16 +02:00
function do_install ( $args )
2006-05-28 01:59:41 +02:00
{
2009-12-05 18:42:18 +01:00
list ( $domain , $user , $password , $backup , $charset , $lang ) = explode ( ',' , array_shift ( $args ));
2007-12-10 05:59:01 +01:00
_fetch_user_password ( $user , $password );
2008-08-20 08:04:28 +02:00
2009-12-05 18:42:18 +01:00
$config = array ();
foreach ( $args as $arg )
{
list ( $name , $value ) = explode ( '=' , $arg , 2 );
$config [ $name ] = $value ;
}
$cmd = new setup_cmd_install ( $domain , $user , $password , $backup , $charset , true , $config , $lang );
2007-12-10 05:59:01 +01:00
echo $cmd -> run () . " \n " ;
2006-05-28 01:59:41 +02:00
}
/**
2007-12-10 05:59:01 +01:00
* Set defaults for user and password or queries the password from the user
*
* @ param string & $user
* @ param string & $password
2006-05-28 01:59:41 +02:00
*/
2007-12-10 05:59:01 +01:00
function _fetch_user_password ( & $user , & $password )
2006-05-28 01:59:41 +02:00
{
2007-12-10 05:59:01 +01:00
// read password from enviroment or query it from user, if not given
if ( ! $user ) $user = 'admin' ;
if ( ! $password && ! ( $password = $_SERVER [ 'EGW_CLI_PASSWORD' ]))
2006-05-29 04:56:16 +02:00
{
2007-12-10 05:59:01 +01:00
echo lang ( 'Admin password to header manager' ) . ' ' ;
$password = trim ( fgets ( $f = fopen ( 'php://stdin' , 'rb' )));
fclose ( $f );
2006-05-29 04:56:16 +02:00
}
2006-05-28 01:59:41 +02:00
}
2006-05-29 04:56:16 +02:00
2006-05-28 01:59:41 +02:00
/**
* Create , edit or update the header . inc . php
*
* @ param boolean $create true = create new header , false = edit ( or update ) existing header
* @ param array $arguments
* @ return int
*/
function do_header ( $create , & $arguments )
{
2007-12-09 09:03:15 +01:00
if ( ! $create )
2006-05-28 01:59:41 +02:00
{
2007-12-09 09:03:15 +01:00
// read password from enviroment or query it from user, if not given
@ list ( $password , $user ) = $options = explode ( ',' , @ $arguments [ 0 ]);
2007-12-10 05:59:01 +01:00
_fetch_user_password ( $options [ 1 ], $options [ 0 ]);
2007-12-09 09:03:15 +01:00
$arguments [ 0 ] = implode ( ',' , $options );
2006-05-28 01:59:41 +02:00
}
array_unshift ( $arguments , $create ? '--create-header' : '--edit-header' );
2007-12-09 09:03:15 +01:00
$cmd = new setup_cmd_header ( $create ? 'create' : 'edit' , $arguments );
2008-01-14 06:44:32 +01:00
echo $cmd -> run () . " \n " ;
2006-05-28 01:59:41 +02:00
}
2006-05-29 04:56:16 +02:00
/**
* Reads the users language from the enviroment
*
2006-05-31 02:27:15 +02:00
* @ param string & $charset charset set in LANG enviroment variable or the default utf - 8
2006-05-29 04:56:16 +02:00
* @ return string 2 or 5 digit language code used in eGW
*/
2006-05-31 02:27:15 +02:00
function get_lang ( & $charset )
2006-05-29 04:56:16 +02:00
{
2009-06-08 18:21:14 +02:00
@ list ( $lang , $nation , $charset ) = preg_split ( " /[_.]/ " , strtolower ( $_SERVER [ 'LANG' ]));
2006-05-31 02:27:15 +02:00
2006-05-29 04:56:16 +02:00
foreach ( file ( 'lang/languages' ) as $line )
{
list ( $code , $language ) = explode ( " \t " , $line );
$languages [ $code ] = $language ;
}
if ( isset ( $languages [ $lang . '-' . $nation ])) return $lang . '-' . $nation ;
if ( isset ( $languages [ $lang ])) return $lang ;
2008-08-20 08:04:28 +02:00
2006-05-29 04:56:16 +02:00
return 'en' ;
}
/**
* Try guessing the document root of the webserver , should work for RH , SuSE , debian and plesk
*/
function create_http_enviroment ()
{
$_SERVER [ 'SCRIPT_FILENAME' ] = __FILE__ ;
foreach ( array ( 'httpsdocs' , 'httpdocs' , 'htdocs' , 'html' , 'www' ) as $docroottop )
{
$parts = explode ( $docroottop , __FILE__ );
if ( count ( $parts ) == 2 )
{
$_SERVER [ 'DOCUMENT_ROOT' ] = $parts [ 0 ] . $docroottop ;
$_SERVER [ 'PHP_SELF' ] = str_replace ( '\\' , '/' , $parts [ 1 ]);
break ;
}
}
//print_r($_SERVER); exit;
}
/**
* Echos usage message
*/
2006-06-22 05:40:18 +02:00
function do_usage ( $what = '' )
2006-05-29 04:56:16 +02:00
{
2006-05-31 02:27:15 +02:00
echo lang ( 'Usage: %1 command [additional options]' , basename ( $_SERVER [ 'argv' ][ 0 ])) . " \n \n " ;
2008-08-20 08:04:28 +02:00
2006-06-22 05:40:18 +02:00
if ( ! $what )
{
2013-06-18 20:14:08 +02:00
echo '--check ' . lang ( 'checks EGroupware\'s installed, it\'s versions and necessary upgrads (return values see --exit-codes)' ) . " \n " ;
2006-06-22 05:40:18 +02:00
echo '--install ' . lang ( 'domain(default),[config user(admin)],password,[backup to install],[charset(default depends on language)]' ) . " \n " ;
}
if ( ! $what || $what == 'config' )
{
echo '--config ' . lang ( 'domain(default),[config user(admin)],password,[name=value,...] sets config values beside:' ) . " \n " ;
if ( ! $what ) echo ' --help config ' . lang ( 'gives further options' ) . " \n " ;
}
if ( $what == 'config' )
{
echo ' --files-dir, --backup-dir, --temp-dir ' . lang ( 'path to various directories: have to exist and be writeable by the webserver' ) . " \n " ;
echo ' --webserver-url ' . lang ( 'eg. /egroupware or http://domain.com/egroupware, default: %1' , str_replace ( '/setup/setup-cli.php' , '' , $_SERVER [ 'PHP_SELF' ])) . " \n " ;
2010-05-20 14:35:43 +02:00
echo ' --mailserver ' . lang ( 'host,{imap | imaps },[domain],[{standard(default)|vmailmgr = add domain for mailserver login}]' ) . " \n " ;
2013-07-15 17:27:34 +02:00
echo ' --smtpserver ' . lang ( 'host,[smtp port],[smtp user],[smtp password],[auth=no|yes|ann]' ) . " \n " ;
2013-06-20 16:49:43 +02:00
echo ' --smtp ' . lang ( 'MTA (with LDAP): [yes(user edit forwarding)],(defaultsmtp|postfix(ldap|dbmailuser)|emailadmin_smtp_(ldap|ads|mandriva|suse|sql))' ) . " \n " ;
echo ' --imap ' . lang ( 'IMAP: Admin user,Password,(defaultimap|cyrusimap|emailadmin_dovecot)' ) . " \n " ;
2013-05-21 16:54:01 +02:00
echo ' --sieve ' . lang ( 'Sieve: Host[,Port(4190)]' ) . " \n " ;
2013-06-20 16:49:43 +02:00
echo ' --account-auth ' . lang ( 'account repository{sql(default) | ldap | ads},[authentication{sql | ldap | ads | mail | http | ...}],[sql encrypttion{md5 | blowfish_crypt | md5_crypt | crypt}],[check save password{ (default)|True}],[allow cookie auth{ (default)|True}]' ) . " \n " ;
2006-06-22 05:40:18 +02:00
echo ' --ldap-host --ldap-root-dn --ldap-root-pw --ldap-context --ldap-group-context' . " \n " ;
2013-06-20 16:49:43 +02:00
echo ' --ads-host --ads-domain --ads-admin-user --ads-admin-pw --ads-connection (ssl|tls) --ads-context' . " \n " ;
2006-06-22 05:40:18 +02:00
}
if ( ! $what )
{
echo '--admin ' . lang ( 'creates an admin user: domain(default),[config user(admin)],password,username,password,[first name],[last name],[email]' ) . " \n " ;
echo '--backup ' . lang ( 'domain(all),[config user(admin)],password,[file-name(default: backup-dir/db_backup-YYYYMMDDHHii)]' ) . " \n " ;
2011-06-18 12:44:56 +02:00
echo '--update ' . lang ( 'run a database schema update (if necessary): domain(all),[config user(admin)],password' ) . '[,[no = no backup][,app to install]]' . " \n " ;
2011-06-29 10:40:24 +02:00
echo '--register-hooks ' . lang ( 'Find and Register all Application Hooks' ) . " : domain(all),[config user(admin)],password \n " ;
2006-06-22 05:40:18 +02:00
echo lang ( 'You can use the header user and password for every domain too. If the password is not set via the commandline, it is read from the enviroment variable EGW_CLI_PASSWORD or queried from the user.' ) . " \n " ;
}
if ( ! $what || $what == 'header' )
{
2013-06-18 20:14:08 +02:00
echo lang ( 'Create or edit the EGroupware configuration file: header.inc.php:' ) . " \n " ;
2006-06-22 05:40:18 +02:00
echo '--create-header ' . lang ( 'header-password[,header-user(admin)]' ) . " \n " ;
echo '--edit-header ' . lang ( '[header-password],[header-user],[new-password],[new-user]' ) . " \n " ;
if ( ! $what ) echo ' --help header ' . lang ( 'gives further options' ) . " \n " ;
}
if ( $what == 'header' )
{
echo " \n " . lang ( 'Additional options and there defaults (in brackets)' ) . " \n " ;
2013-06-18 20:14:08 +02:00
echo '--server-root ' . lang ( 'path of EGroupware install directory (default auto-detected)' ) . " \n " ;
2006-06-22 05:40:18 +02:00
echo '--session-type ' . lang ( '{db | php(default) | php-restore}' ) . " \n " ;
echo '--limit-access ' . lang ( 'comma separated ip-addresses or host-names, default access to setup from everywhere' ) . " \n " ;
echo '--mcrypt ' . lang ( 'use mcrypt to crypt session-data: {off(default) | on},[mcrypt-init-vector(default randomly generated)],[mcrypt-version]' ) . " \n " ;
echo '--db-persistent ' . lang ( 'use persistent db connections: {on(default) | off}' ) . " \n " ;
echo '--domain-selectbox ' . lang ( '{off(default) | on}' ) . " \n " ;
2008-08-20 08:04:28 +02:00
2013-06-18 20:14:08 +02:00
echo " \n " . lang ( 'Adding, editing or deleting an EGroupware domain / database instance:' ) . " \n " ;
2006-06-22 05:40:18 +02:00
echo '--domain ' . lang ( 'add or edit a domain: [domain-name(default)],[db-name(egroupware)],[db-user(egroupware)],db-password,[db-type(mysql)],[db-host(localhost)],[db-port(db specific)],[config-user(as header)],[config-passwd(as header)]' ) . " \n " ;
echo '--delete-domain ' . lang ( 'domain-name' ) . " \n " ;
}
if ( ! $what )
{
echo '--help list ' . lang ( 'List availible values' ) . " \n " ;
}
if ( $what == 'list' )
{
echo lang ( 'List availible values' ) . " : \n " ;
echo '--languages ' . lang ( 'list of availible translations' ) . " \n " ;
echo '--charsets ' . lang ( 'charsets used by the different languages' ) . " \n " ;
echo '--exit-codes ' . lang ( 'all exit codes of the command line interface' ) . " \n " ;
}
if ( ! $what || ! in_array ( $what , array ( 'config' , 'header' , 'list' )))
{
echo '--help [config|header|list] ' . lang ( 'gives further options' ) . " \n " ;
}
2006-05-29 04:56:16 +02:00
}
function fail ( $exit_code , $message )
{
echo $message . " \n " ;
exit ( $exit_code );
}
/**
* List all exit codes used by the command line interface
*
2008-08-20 08:04:28 +02:00
* The list is generated by " greping " this file for calls to the fail () function .
2006-05-29 04:56:16 +02:00
* Calls to fail () have to be in one line , to be recogniced !
2008-08-20 08:04:28 +02:00
*
2007-12-11 02:28:07 +01:00
* @ todo we need to grep for the exceptions too !
2006-05-29 04:56:16 +02:00
*/
function list_exit_codes ()
2006-05-28 01:59:41 +02:00
{
2006-05-29 04:56:16 +02:00
error_reporting ( error_reporting () & ~ E_NOTICE );
$codes = array ( 'Ok' );
2009-05-31 10:15:11 +02:00
$setup_dir = EGW_SERVER_ROOT . '/setup/' ;
//$files = array('setup-cli.php');
foreach ( scandir ( $setup_dir . '/inc' ) as $file )
2006-05-28 01:59:41 +02:00
{
2009-05-31 10:15:11 +02:00
if ( substr ( $file , 0 , strlen ( 'class.setup_cmd' )) == 'class.setup_cmd' )
2006-05-28 01:59:41 +02:00
{
2009-05-31 10:15:11 +02:00
$files [] = 'inc/' . $file ;
}
}
foreach ( $files as $file )
{
$content = file_get_contents ( $setup_dir . '/' . $file );
if ( preg_match_all ( '/throw new (egw_exception[a-z_]*)\((.*),([0-9]+)\);/m' , $content , $matches ))
{
//echo $file.":\n"; print_r($matches);
foreach ( $matches [ 3 ] as $key => $code )
{
//if (isset($codes[$code])) echo "$file redifines #$code: {$codes[$code]}\n";
$src = $matches [ 2 ][ $key ];
$src = preg_replace ( '/self::\$[a-z_>-]/i' , " '' " , $src ); // gives fatal error otherwise
@ eval ( $src = '$codes[' . $code . '] = ' . $src . ';' );
//echo "- codes[$code] => '{$codes[$code]}'\n";
}
//echo $file.":\n"; print_r($codes);
2006-05-28 01:59:41 +02:00
}
2006-05-29 04:56:16 +02:00
}
ksort ( $codes , SORT_NUMERIC );
foreach ( $codes as $num => $msg )
{
echo $num . " \t " . str_replace ( " \n " , " \n \t " , $msg ) . " \n " ;
2006-05-28 01:59:41 +02:00
}
}