"admin", "noheader" => True, "nonavbar" => True, "parent_page" => "accounts.php"); include("../header.inc.php"); include($phpgw_info["server"]["app_inc"]."/accounts_".$phpgw_info["server"]["account_repository"].".inc.php"); function is_odd($n) { $ln = substr($n,-1); if ($ln == 1 || $ln == 3 || $ln == 5 || $ln == 7 || $ln == 9) { return True; } else { return False; } } if ($submit) { $totalerrors = 0; if ($phpgw_info["server"]["account_repository"] == "ldap" && ! $allow_long_loginids) { if (strlen($n_loginid) > 8) { $error[$totalerrors++] = lang("The loginid can not be more then 8 characters"); } } if (! $account_lid) $error[$totalerrors++] = lang("You must enter a loginid"); if (! $n_passwd) $error[$totalerrors++] = lang("You must enter a password"); if ($n_passwd == $account_lid) $error[$totalerrors++] = lang("The login and password can not be the same"); if ($n_passwd != $n_passwd_2) $error[$totalerrors++] = lang("The two passwords are not the same"); if (!count($new_permissions) || !count($n_groups)) { $error[$totalerrors++] = "
" . lang("You must add at least 1 permission or group to this account"); } if ($phpgw->accounts->exists($account_lid)) { $error[$totalerrors++] = lang("That loginid has already been taken"); } if (! $error) { $phpgw->db->lock(array( 'phpgw_accounts', 'phpgw_preferences', 'phpgw_sessions', 'phpgw_acl', 'phpgw_applications' )); $phpgw->accounts->create('u', $account_lid, $n_passwd, $n_firstname, $n_lastname, $n_account_status); $account_id = $phpgw->accounts->name2id($account_lid); $apps = CreateObject('phpgwapi.applications',array($account_id,'u')); $apps->read_installed_apps(); // Read Group Apps if ($n_groups) { $apps->account_type = 'g'; reset($n_groups); while($groups = each($n_groups)) { $apps->account_id = $groups[0]; $old_app_groups = $apps->read_account_specific(); @reset($old_app_groups); while($old_group_app = each($old_app_groups)) { if (!$apps_after[$old_group_app[0]]) { $apps_after[$old_group_app[0]] = $old_app_groups[$old_group_app[0]]; } } } } $apps->account_type = 'u'; $apps->account_id = $account_id; $apps->account_apps = Array(Array()); @reset($new_permissions); while ($app = each($new_permissions)) { if ($app[1]) { $apps->add($app[0]); if (!$apps_after[$app[0]]) { $apps_after[] = $app[0]; } } } $apps->save_repository(); // Assign user to groups for ($i=0;$iacl->add_repository('phpgw_group',$n_groups[$i],$account_id,1); } $pref = CreateObject('phpgwapi.preferences',$account_id); $phpgw->common->hook_single('add_def_pref','admin'); while ($apps = each($apps_after)) { if ($apps[0] != 'admin') { $phpgw->common->hook_single('add_def_pref', $apps[0]); } } $pref->save_repository(False); $apps->account_apps = Array(Array()); $apps_after = Array(Array()); $phpgw->db->unlock(); /* // start inlcuding other admin tools while($app = each($apps_after)) { $phpgw->common->hook_single('add_user_data', $value); } */ Header('Location: ' . $phpgw->link('accounts.php','cd='.$cd)); $phpgw->common->phpgw_exit(); } } else { $status = 'A'; } $phpgw->template->set_file(array('form' => 'account_form.tpl')); $phpgw->template->set_unknowns('remove'); $phpgw->common->phpgw_header(); echo parse_navbar(); $phpgw->template->set_var("lang_action",lang("Add new account")); if ($totalerrors) { $phpgw->template->set_var("error_messages","
" . $phpgw->common->error_list($error) . "
"); } else { $phpgw->template->set_var("error_messages",""); } $phpgw->template->set_var("th_bg",$phpgw_info["theme"]["th_bg"]); $phpgw->template->set_var("tr_color1",$phpgw_info["theme"]["row_on"]); $phpgw->template->set_var("tr_color2",$phpgw_info["theme"]["row_off"]); $phpgw->template->set_var("form_action",$phpgw->link("newaccount.php")); $phpgw->template->set_var("lang_loginid",lang("LoginID")); if ($status) { $phpgw->template->set_var('account_status',' checked'); } $phpgw->template->set_var("n_loginid_value",$account_lid); $phpgw->template->set_var("lang_account_active",lang("Account active")); $phpgw->template->set_var("lang_password",lang("Password")); $phpgw->template->set_var("n_passwd_value",$n_passwd); $phpgw->template->set_var("lang_reenter_password",lang("Re-Enter Password")); $phpgw->template->set_var("n_passwd_2_value",$n_passwd_2); $phpgw->template->set_var("lang_firstname",lang("First Name")); $phpgw->template->set_var("n_firstname_value",$n_firstname); $phpgw->template->set_var("lang_lastname",lang("Last Name")); $phpgw->template->set_var("n_lastname_value",$n_lastname); $phpgw->template->set_var("lang_groups",lang("Groups")); // groups list $groups_select = ''; $phpgw->template->set_var('groups_select',$groups_select); // end groups list $phpgw->template->set_var("",""); $i = 0; $sorted_apps = $phpgw_info["apps"]; @asort($sorted_apps); @reset($sorted_apps); while ($permission = each($sorted_apps)) { if ($permission[1]["enabled"]) { $perm_display[$i][0] = $permission[0]; $perm_display[$i][1] = $permission[1]["title"]; $i++; } } for ($i=0;$i<200;) { // The $i<200 is only used for a brake if (! $perm_display[$i][1]) break; $perms_html .= '' . lang($perm_display[$i][1]) . '' . '' . 'template->set_var("permissions_list",$perms_html); $includedSomething = False; // Skeeter: I don't see this as a player, if creating new accounts... // start inlcuding other admin tools // while(list($key,$value) = each($phpgw_info["user"]["app_perms"])) // { // check if we have something included, when not ne need to set // {gui_hooks} to "" // if ($phpgw->common->hook_single("show_newuser_data", $value)) $includedSomething="true"; // } if (!$includedSomething) $phpgw->template->set_var("gui_hooks",""); $phpgw->template->set_var("lang_button",Lang("Add")); echo $phpgw->template->finish($phpgw->template->parse("out","form")); account_close(); $phpgw->common->phpgw_footer(); ?>