<?php /** * EGroupware Setup - create admin account * * @link http://www.egroupware.org * @package setup * @author Miles Lott <milos@groupwhere.org> * @author Ralf Becker <RalfBecker-AT-outdoor-training.de> * @license http://opensource.org/licenses/gpl-license.php GPL - GNU General Public License * @version $Id$ */ use EGroupware\Api; use EGroupware\Api\Framework; if (strpos($_SERVER['PHP_SELF'],'admin_account.php') !== false) { include('./inc/functions.inc.php'); // Authorize the user to use setup app and load the database // Does not return unless user is authorized if(!$GLOBALS['egw_setup']->auth('Config') || $_POST['cancel']) { Header('Location: index.php'); exit; } $GLOBALS['egw_setup']->loaddb(true); } $error = ''; if ($_POST['submit']) { // for POST (not GET or cli call via setup_cmd_admin) validate CSRF token if ($_SERVER['REQUEST_METHOD'] == 'POST') { Api\Csrf::validate($_POST['csrf_token'], __FILE__); } /* Posted admin data */ $passwd = $_POST['passwd']; $passwd2 = $_POST['passwd2']; $username = $_POST['username']; $fname = $_POST['fname']; $lname = $_POST['lname']; $email = $_POST['email']; if($passwd != $passwd2 || !$username) { $error = '<p>'.lang('Passwords did not match, please re-enter') . ".</p>\n"; } if(!$username) { $error = '<p>'.lang('You must enter a username for the admin') . ".</p>\n"; } } if(!$_POST['submit'] || $error) { $tpl_root = $GLOBALS['egw_setup']->html->setup_tpl_dir('setup'); $setup_tpl = new Framework\Template($tpl_root); $setup_tpl->set_file(array( 'T_head' => 'head.tpl', 'T_footer' => 'footer.tpl', 'T_alert_msg' => 'msg_alert_msg.tpl', 'T_login_main' => 'login_main.tpl', 'T_login_stage_header' => 'login_stage_header.tpl', 'T_admin_account' => 'admin_account.tpl' )); $setup_tpl->set_block('T_login_stage_header','B_multi_domain','V_multi_domain'); $setup_tpl->set_block('T_login_stage_header','B_single_domain','V_single_domain'); $GLOBALS['egw_setup']->html->show_header(lang('Create admin account')); $setup_tpl->set_var(array( 'error' => $error, 'username' => $username, 'fname' => $fname, 'lname' => $lname, 'email' => $email, )); $setup_tpl->set_var('action_url','admin_account.php'); $setup_tpl->set_var('description',lang('This will create a first user in EGroupware or reset password and admin rights of an exiting user')); $setup_tpl->set_var('lang_deleteall',lang('Delete all existing SQL accounts, groups, ACLs and preferences (normally not necessary)?')); $setup_tpl->set_var('detailadmin',lang('Details for Admin account')); $setup_tpl->set_var('adminusername',lang('Admin username')); $setup_tpl->set_var('adminfirstname',lang('Admin first name')); $setup_tpl->set_var('adminlastname',lang('Admin last name')); $setup_tpl->set_var('adminemail',lang('Admin email address')); $setup_tpl->set_var('adminpassword',lang('Admin password')); $setup_tpl->set_var('adminpassword2',lang('Re-enter password')); $setup_tpl->set_var('admin_all_apps',lang('Give admin access to all installed apps')); $setup_tpl->set_var('all_apps_desc',lang('Usually more annoying.<br />Admins can use Admin >> Manage accounts or groups to give access to further apps.')); $setup_tpl->set_var('create_demo_accounts',lang('Create demo accounts')); $setup_tpl->set_var('demo_desc',lang('The username/passwords are: demo/guest, demo2/guest and demo3/guest.')); $setup_tpl->set_var('hidden_vars', Api\Html::input_hidden('csrf_token', Api\Csrf::token(__FILE__))); $setup_tpl->set_var('lang_submit',lang('Save')); $setup_tpl->set_var('lang_cancel',lang('Cancel')); $setup_tpl->pparse('out','T_admin_account'); $GLOBALS['egw_setup']->html->show_footer(); } else { /* Begin transaction for acl, etc */ $GLOBALS['egw_setup']->db->transaction_begin(); if($_POST['delete_all']) { /* Now, clear out existing tables */ foreach(array($GLOBALS['egw_setup']->accounts_table,$GLOBALS['egw_setup']->acl_table,'egw_access_log') as $table) { $GLOBALS['egw_setup']->db->delete($table,'1=1',__LINE__,__FILE__); } // keep default and forced prefs from installed apps $GLOBALS['egw_setup']->db->delete($GLOBALS['egw_setup']->prefs_table,'preference_owner NOT IN (-1,-2)',__LINE__,__FILE__); // remove accounts from addressbook $GLOBALS['egw_setup']->db->delete('egw_addressbook','account_id IS NOT NULL',__LINE__,__FILE__); } // create our stock groups: Default (all users) and Admins (administrators) $defaultgroupid = (int)$GLOBALS['egw_setup']->add_account('Default','Default','Group',False,False); $admingroupid = (int)$GLOBALS['egw_setup']->add_account('Admins','Admin','Group',False,False); if (!$defaultgroupid || !$admingroupid) { if (strpos($_SERVER['PHP_SELF'],'admin_account.php') === false) { return 42; //lang('Error in group-creation !!!'); // dont exit on setup-cli } echo '<p><b>'.lang('Error in group-creation !!!')."</b></p>\n"; echo '<p>'.lang('click <a href="index.php">here</a> to return to setup.')."</p>\n"; $GLOBALS['egw_setup']->db->transaction_abort(); exit; } // Group perms for the default group $default_group_apps = array('addressbook','calendar','infolog','mail','filemanager','preferences','manual','groupdav','notifications','timesheet','importexport','activesync'); $GLOBALS['egw_setup']->add_acl($default_group_apps,'run',$defaultgroupid); $apps = array(); foreach($GLOBALS['egw_setup']->db->select($GLOBALS['egw_setup']->applications_table,'app_name','app_enabled < 3',__LINE__,__FILE__) as $row) { $apps[] = $row['app_name']; } // if not otherwise selected, give admin only access to the rest of the default apps, // not yet set for the default group or development only apps like (etemplate, jinn, tt's) if (!$_POST['admin_all_apps']) { $apps = array_intersect( // also give Admins apps of all users group Defaults, in case one forgot to add admins to it array_unique(array_merge($default_group_apps, array('admin','bookmarks','emailadmin','news_admin','phpbrain','phpsysinfo','phpfreechat','projectmanager','resources','sitemgr','timesheet','tracker','wiki'))),$apps); } $GLOBALS['egw_setup']->add_acl($apps,'run',$admingroupid); /* Creation of the demo accounts is optional - the checkbox is on by default. */ if($_POST['create_demo']) { // Create 3 demo accounts $GLOBALS['egw_setup']->add_account('demo','Demo','Account','guest'); $GLOBALS['egw_setup']->add_account('demo2','Demo2','Account','guest'); $GLOBALS['egw_setup']->add_account('demo3','Demo3','Account','guest'); } /* Create records for administrator account, with Admins as primary and Default as additional group */ $accountid = $GLOBALS['egw_setup']->add_account($username,$fname,$lname,$passwd,'Admins',True,$email); if (!$accountid) { if (strpos($_SERVER['PHP_SELF'],'admin_account.php') === false) { return 41; //lang('Error in admin-creation !!!'); // dont exit on setup-cli } echo '<p><b>'.lang('Error in admin-creation !!!')."</b></p>\n"; echo '<p>'.lang('click <a href="index.php">here</a> to return to setup.')."</p>\n"; $GLOBALS['egw_setup']->db->transaction_abort(); exit; } $GLOBALS['egw_setup']->set_memberships(array($admingroupid,$defaultgroupid),$accountid); $GLOBALS['egw_setup']->db->transaction_commit(); if (strpos($_SERVER['PHP_SELF'],'admin_account.php') !== false) { Header('Location: index.php'); } }