-
Benoit Mortier authored1c1fc75e
<?php
/*
This code is part of FusionDirectory (http://www.fusiondirectory.org/)
Copyright (C) 2003 Cajus Pollmeier
Copyright (C) 2011 FusionDirectory
This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation; either version 2 of the License, or
(at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program; if not, write to the Free Software
Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA.
*/
/*!
\brief posixAccount plugin
\author Cajus Pollmeier <pollmeier@gonicus.de>
\version 2.00
\date 24.07.2003
This class provides the functionality to read and write all attributes
relevant for posixAccounts and shadowAccounts from/to the LDAP. It
does syntax checking and displays the formulars required.
*/
class posixAccount extends plugin
{
/* Definitions */
var $plHeadline = "UNIX";
var $plDescription = "Edit users POSIX settings";
/* Plugin specific values */
var $homeDirectory = "";
var $loginShell = "/bin/bash";
var $uidNumber = "";
var $gidNumber = "";
var $gecos = "";
var $shadowMin = "0";
var $shadowMax = "0";
var $shadowWarning = "0";
var $shadowLastChange = "0";
var $shadowInactive = "0";
var $shadowExpire = "";
var $gosaDefaultPrinter = "";
var $accessTo = array();
var $trustModel = "";
var $host = array();
var $glist = array();
var $status = "";
var $loginShellList = array();
var $groupMembership = array();
var $savedGroupMembership = array();
var $savedUidNumber = "";
var $savedGidNumber = "";
var $activate_shadowMin = "0";
var $activate_shadowMax = "0";
var $activate_shadowWarning = "0";
var $activate_shadowInactive = "0";
var $activate_shadowExpire = "0";
var $mustchangepassword = "0";
var $force_ids = 0;
7172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140
var $gotoLastSystemLogin = "";
var $groupSelect = FALSE;
var $trustSelect = FALSE;
var $secondaryGroups = array();
var $primaryGroup = 0;
var $was_trust_account = FALSE;
var $memberGroup = array();
var $grouplist = array();
var $ui = array();
var $ssh = null;
var $sshAcl = "";
var $GroupRegex = "*";
var $GroupUserRegex = "*";
var $SubSearch = false;
var $view_logged = false;
/* attribute list for save action */
var $CopyPasteVars =
array("grouplist","groupMembership","activate_shadowMin",
"activate_shadowMax","activate_shadowWarning","activate_shadowInactive","activate_shadowExpire",
"must_change_password","printerList","grouplist","savedGidNumber","savedUidNumber");
var $attributes = array("homeDirectory", "loginShell", "uidNumber", "gidNumber", "gecos",
"shadowMin", "shadowMax", "shadowWarning", "shadowInactive", "shadowLastChange",
"shadowExpire", "gosaDefaultPrinter", "uid", "host", "gotoLastSystemLogin");
var $objectclasses = array("posixAccount", "shadowAccount");
var $uid = "";
var $multiple_support = TRUE;
var $groupMembership_some = array();
/* constructor, if 'dn' is set, the node loads the given
'dn' from LDAP */
function posixAccount (&$config, $dn= NULL)
{
global $class_mapping;
/* Configuration is fine, allways */
$this->config= $config;
/* Load bases attributes */
plugin::plugin($config, $dn);
/* If gotoLastSystemLogin is available read it from ldap and create a readable
date time string, fallback to sambaLogonTime if available.
*/
if(isset($this->attrs['gotoLastSystemLogin'][0]) && preg_match("/^[0-9]*$/",$this->attrs['gotoLastSystemLogin'][0])){
$this->gotoLastSystemLogin = date("d.m.Y H:i:s", strtotime($this->attrs['gotoLastSystemLogin'][0]));
} else if(isset($this->attrs['sambaLogonTime'][0]) && preg_match("/^[0-9]*$/",$this->attrs['sambaLogonTime'][0])){
$this->gotoLastSystemLogin = date("d.m.Y H:i:s", $this->attrs['sambaLogonTime'][0]);
}
/* Setting uid to default */
if(isset($this->attrs['uid'][0])){
$this->uid = $this->attrs['uid'][0];
}
$ldap= $this->config->get_ldap_link();
if ($dn !== NULL){
/* Correct is_account. shadowAccount is not required. */
if (isset($this->attrs['objectClass']) &&
in_array ('posixAccount', $this->attrs['objectClass'])){
$this->is_account= TRUE;
}
141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210
/* Is this account a trustAccount? */
if ($this->is_account && isset($this->attrs['host'])){
if ($this->attrs['host'][0] == "*") {
$this->trustModel= "fullaccess";
} else {
$this->trustModel= "byhost";
$this->accessTo = array();
if ($this->is_account && isset($this->attrs['host'])){
for ($i= 0; $i<$this->attrs['host']['count']; $i++){
$tmp= $this->attrs['host'][$i];
$this->accessTo[$tmp]= $tmp;
}
}
}
$this->was_trust_account= TRUE;
} else {
$this->was_trust_account= FALSE;
$this->trustModel= "";
}
/* $this->accessTo = array();
if ($this->is_account && isset($this->attrs['host'])){
for ($i= 0; $i<$this->attrs['host']['count']; $i++){
$tmp= $this->attrs['host'][$i];
$this->accessTo[$tmp]= $tmp;
}
}*/
$this->initially_was_account = $this->is_account;
// Templates do not have a gidNumber
if($this->gidNumber == 2147483647){
$this->gidNumber = "";
$this->primaryGroup = 0;
}
/* Fill group */
$this->primaryGroup = $this->gidNumber;
/* Generate status text */
$current = date("U");
$current = floor($current / 60 /60 / 24);
if (($current >= $this->shadowExpire) && $this->shadowExpire) {
$this->status = _("expired");
if (($current - $this->shadowExpire) < $this->shadowInactive) {
$this->status .= ", "._("grace time active");
}
} elseif (($this->shadowLastChange + $this->shadowMin) >= $current) {
$this->status = _("active").", "._("password not changeable");
} elseif (($this->shadowLastChange + $this->shadowMax) >= $current) {
$this->status = _("active").", "._("password expired");
} else {
$this->status = _("active");
}
/* Get group membership */
$ldap->cd($this->config->current['BASE']);
$ldap->search("(&(objectClass=posixGroup)(memberUid=".$this->uid."))", array("cn", "description"));
while ($attrs= $ldap->fetch()) {
if (!isset($attrs["description"][0])) {
$entry = $attrs["cn"][0];
} else {
$entry = $attrs["cn"][0]." [".$attrs["description"][0]."]";
}
$this->groupMembership[$ldap->getDN()]= $entry;
}
211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280
asort($this->groupMembership);
reset($this->groupMembership);
$this->savedGroupMembership= $this->groupMembership;
$this->savedUidNumber= $this->uidNumber;
$this->savedGidNumber= $this->gidNumber;
// Instanciate SSH object if available
if (isset($class_mapping["sshPublicKey"])){
if (empty($this->acl_base)){
$this->acl_base= $config->current['BASE'];
}
$this->sshAcl= $this->getacl("sshPublicKey");
$this->ssh= new sshPublicKey($this->config, $this->dn, $this->sshAcl);
}
}
/* Adjust shadow checkboxes */
foreach (array("shadowMin", "shadowMax", "shadowWarning", "shadowInactive",
"shadowExpire") as $val){
if ($this->$val != 0){
$oval= "activate_".$val;
$this->$oval= "1";
}
}
/* Convert shadowExpire for usage */
if ($this->shadowExpire == 0){
$this->shadowExpire= "";
} else {
$this->shadowExpire= date('d.m.Y', $this->shadowExpire * 60 * 60 * 24);
}
/* Generate shell list from SYSTEMS_DIR./shells */
if (file_exists(SYSTEMS_DIR.'/shells')){
$shells = file (SYSTEMS_DIR.'/shells');
foreach ($shells as $line){
if (!preg_match ("/^#/", $line)){
$this->loginShellList[]= trim($line);
}
}
} else {
if ($this->loginShell == ""){
$this->loginShellList[]= _("unconfigured");
}
}
/* Insert possibly missing loginShell */
if ($this->loginShell != "" && !in_array($this->loginShell, $this->loginShellList)){
$this->loginShellList[]= $this->loginShell;
}
/* Generate group list */
$this->ui = get_userinfo();
$this->secondaryGroups[0]= "- "._("automatic")." -";
$ldap->cd($this->config->current['BASE']);
$ldap->search("(objectClass=posixGroup)", array("cn", "gidNumber"));
while($attrs = $ldap->fetch()){
$this->secondaryGroups[$attrs['gidNumber'][0]]= $attrs['cn'][0];
}
asort ($this->secondaryGroups);
/* Get global filter config */
if (!session::is_set("sysfilter")){
$ui= get_userinfo();
$base= get_base_from_people($ui->dn);
$sysfilter= array( "depselect" => $base,
"regex" => "*");
281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350
session::set("sysfilter", $sysfilter);
}
$this->ui = get_userinfo();
}
/* execute generates the html output for this node */
function execute($isCopyPaste = false)
{
/* Call parent execute */
plugin::execute();
$display= "";
/* Log view */
if($this->is_account && !$this->view_logged){
$this->view_logged = TRUE;
new log("view","users/".get_class($this),$this->dn);
}
/* Department has changed? */
if(isset($_POST['depselect'])){
session::set('CurrentMainBase',validate($_POST['depselect']));
}
if($this->multiple_support_active){
$this->is_account = TRUE;
}
if(!$isCopyPaste && ! $this->multiple_support_active){
/* Do we need to flip is_account state? */
if(isset($_POST['modify_state'])){
if($this->is_account && $this->acl_is_removeable()){
$this->is_account= FALSE;
}elseif(!$this->is_account && $this->acl_is_createable()){
$this->is_account= TRUE;
}
}
/* Do we represent a valid posixAccount? */
if (!$this->is_account && $this->parent === NULL ){
$display= "<img alt=\"\" src=\"images/small-error.png\" align=\"middle\"> <b>".
msgPool::noValidExtension(_("POSIX"))."</b>";
$display.= back_to_main();
return ($display);
}
/* Show tab dialog headers */
if ($this->parent !== NULL){
if ($this->is_account){
if (isset($this->parent->by_object['sambaAccount'])){
$obj= $this->parent->by_object['sambaAccount'];
}
if (isset($obj) && $obj->is_account == TRUE &&
((isset($this->parent->by_object['sambaAccount']))&&($this->parent->by_object['sambaAccount']->is_account))
||(isset($this->parent->by_object['environment'] ))&&($this->parent->by_object['environment'] ->is_account)){
/* Samba3 dependency on posix accounts are enabled
in the moment, because I need to rely on unique
uidNumbers. There'll be a better solution later
on. */
$display= $this->show_disable_header(msgPool::removeFeaturesButton(_("POSIX")), msgPool::featuresEnabled(_("POSIX"), array(_("Samba"), _("Environment"))), TRUE);
} else {
$display= $this->show_disable_header(msgPool::removeFeaturesButton(_("POSIX")), msgPool::featuresEnabled(_("POSIX")));
}
} else {
$display= $this->show_enable_header(msgPool::addFeaturesButton(_("POSIX")), msgPool::featuresDisabled(_("POSIX")));
return($display);
}
351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420
}
}
// Display dialog to allow selection of groups
if (isset($_POST['edit_groupmembership'])){
$this->groupSelect = new groupSelect($this->config,get_userinfo());
$this->dialog= TRUE;
}
// Allow to select trusted machines from a list
if (isset($_POST["add_ws"])){
$this->trustSelect= new trustSelect($this->config,get_userinfo());
$this->dialog= TRUE;
}
// Cancel trust and group dialog
if (isset($_POST['add_groups_cancel']) || isset($_POST['add_ws_cancel'])){
$this->groupSelect= NULL;
$this->trustSelect= NULL;
$this->dialog= FALSE;
}
// Add groups selected in groupSelect dialog to ours.
if (isset($_POST['add_groups_finish']) && $this->groupSelect){
$groups = $this->groupSelect->detectPostActions();
if(isset($groups['targets'])){
$this->addGroup ($groups['targets']);
$this->is_modified= TRUE;
}
$this->groupSelect= NULL;
$this->dialog= FALSE;
}
// Remove groups from currently selected groups.
if (isset($_POST['delete_groupmembership']) &&
isset($_POST['group_list']) && count($_POST['group_list'])){
$this->delGroup ($_POST['group_list']);
}
// Add selected machines to trusted ones.
if (isset($_POST["add_ws_finish"]) && $this->trustSelect){
$trusts = $this->trustSelect->detectPostActions();
if(isset($trusts['targets'])){
$headpage = $this->trustSelect->getHeadpage();
foreach($trusts['targets'] as $id){
$attrs = $headpage->getEntry($id);
$this->accessTo[$attrs['cn'][0]]= $attrs['cn'][0];
}
ksort($this->accessTo);
$this->is_modified= TRUE;
}
$this->trustSelect= NULL;
$this->dialog= FALSE;
}
// Remove machine from trusted ones.
if (isset($_POST["delete_ws"]) && isset($_POST['workstation_list'])){
foreach($_POST['workstation_list'] as $name){
unset ($this->accessTo[$name]);
}
$this->is_modified= TRUE;
}
/* Templates now! */
$smarty= get_smarty();
$smarty->assign("usePrototype", "true");
421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490
/* Show ws dialog */
if ($this->trustSelect){
// Build up blocklist
session::set('filterBlacklist', array('cn' => array_values($this->accessTo)));
return($this->trustSelect->execute());
}
/* Manage group add dialog */
if ($this->groupSelect){
// Build up blocklist
session::set('filterBlacklist', array('dn' => array_keys($this->groupMembership)));
return($this->groupSelect->execute());
}
// Handle ssh dialog?
if ($this->ssh instanceOf sshPublicKey && preg_match('/[rw]/', $this->getacl("sshPublicKey"))) {
$smarty->assign("usePrototype", "false");
if ($result= $this->ssh->execute()) {
$this->dialog= true;
return $result;
}
$this->dialog= false;
}
/* Show main page */
$smarty= get_smarty();
$smarty->assign("usePrototype", "true");
/* In 'MyAccount' mode, we must remove write acls if we are not in editing mode. */
$SkipWrite = (!isset($this->parent) || !$this->parent) && !session::is_set('edit');
$smarty->assign("sshPublicKeyACL", $this->getacl("sshPublicKey", $SkipWrite));
/* Depending on pwmode, currently hardcoded because there are no other methods */
if ( 1 == 1 ){
$smarty->assign("pwmode", dirname(__FILE__)."/posix_shadow");
$shadowMinACL = $this->getacl("shadowMin",$SkipWrite);
$smarty->assign("shadowmins", sprintf(_("Password can't be changed up to %s days after last change"),
"<input name=\"shadowMin\" size=3 maxlength=4 value=\"".$this->shadowMin."\">"));
$shadowMaxACL = $this->getacl("shadowMax",$SkipWrite);
$smarty->assign("shadowmaxs", sprintf(_("Password must be changed after %s days"),
"<input name=\"shadowMax\" size=3 maxlength=4 value=\"".$this->shadowMax."\">"));
$shadowInactiveACL= $this->getacl("shadowInactive",$SkipWrite);
$smarty->assign("shadowinactives", sprintf(_("Disable account after %s days of inactivity after password expiry"),
"<input name=\"shadowInactive\" size=3 maxlength=4 value=\"".$this->shadowInactive."\">"));
$shadowWarningACL = $this->getacl("shadowWarning",$SkipWrite);
$smarty->assign("shadowwarnings", sprintf(_("Warn user %s days before password expiry"),
"<input name=\"shadowWarning\" size=3 maxlength=4 value=\"".$this->shadowWarning."\">"));
foreach( array("activate_shadowMin", "activate_shadowMax",
"activate_shadowExpire", "activate_shadowInactive","activate_shadowWarning") as $val){
if ($this->$val == 1){
$smarty->assign("$val", "checked");
} else {
$smarty->assign("$val", "");
}
$smarty->assign("$val"."ACL", $this->getacl($val,$SkipWrite));
}
$smarty->assign("mustchangepasswordACL", $this->getacl("mustchangepassword",$SkipWrite));
}
491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560
// Set last system login
$smarty->assign("gotoLastSystemLogin",$this->gotoLastSystemLogin);
/* Fill arrays */
$smarty->assign("shells", $this->loginShellList);
$smarty->assign("secondaryGroups", $this->secondaryGroups);
$smarty->assign("primaryGroup", $this->primaryGroup);
if(!$this->multiple_support_active){
if (!count($this->groupMembership)){
$smarty->assign("groupMembership", array(" "));
} else {
$smarty->assign("groupMembership", $this->groupMembership);
}
}else{
$smarty->assign("groupMembership", $this->groupMembership);
$smarty->assign("groupMembership_some", $this->groupMembership_some);
}
if (count($this->groupMembership) > 16){
$smarty->assign("groups", "too_many_for_nfs");
} else {
$smarty->assign("groups", "");
}
/* Avoid "Undefined index: forceMode" */
$smarty->assign("forceMode", "");
/* Checkboxes */
if ($this->force_ids == 1){
$smarty->assign("force_ids", "checked");
if (session::get('js')){
$smarty->assign("forceMode", "");
}
} else {
if (session::get('js')){
$smarty->assign("forceMode", "disabled");
}
$smarty->assign("force_ids", "");
}
/* Create onClick="" action string for the "Force UID/GID" option
*/
$onClickIDS ="";
if(preg_match("/w/",$this->getacl("uidNumber",$SkipWrite))){
$onClickIDS .= "changeState('uidNumber');";
}
if(preg_match("/w/",$this->getacl("gidNumber",$SkipWrite))){
$onClickIDS .= "changeState('gidNumber');";
}
$smarty->assign("onClickIDS", $onClickIDS);
$smarty->assign("force_idsACL", $this->getacl("uidNumber",$SkipWrite).$this->getacl("gidNumber",$SkipWrite));
foreach(array("primaryGroup","trustmode","activate_shadowWarning","activate_shadowInactive","activate_shadowMin","activate_shadowMax","activate_shadowExpire","mustchangepassword") as $val){
if(in_array($val,$this->multi_boxes)){
$smarty->assign("use_".$val,TRUE);
}else{
$smarty->assign("use_".$val,FALSE);
}
}
/* Load attributes and acl's */
foreach($this->attributes as $val){
if(in_array($val,$this->multi_boxes)){
$smarty->assign("use_".$val,TRUE);
}else{
$smarty->assign("use_".$val,FALSE);
}
if((session::get("js"))&&(($val=="uidNumber")||($val=="gidNumber")))
{
561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630
$smarty->assign("$val"."ACL",$this->getacl($val,$SkipWrite));
$smarty->assign("$val", $this->$val);
continue;
}
$smarty->assign("$val", $this->$val);
$smarty->assign("$val"."ACL", $this->getacl($val,$SkipWrite));
}
if($SkipWrite){
$smarty->assign("groupMembershipACL","r");
}else{
$smarty->assign("groupMembershipACL","rw");
}
$smarty->assign("status", $this->status);
/* Work on trust modes */
$smarty->assign("trusthide", " disabled ");
$smarty->assign("trustmodeACL", $this->getacl("trustModel",$SkipWrite));
if ($this->trustModel == "fullaccess"){
$trustmode= 1;
// pervent double disable tag in html code, this will disturb our clean w3c html
$smarty->assign("trustmode", $this->getacl("trustModel",$SkipWrite));
} elseif ($this->trustModel == "byhost"){
$trustmode= 2;
$smarty->assign("trusthide", "");
} else {
// pervent double disable tag in html code, this will disturb our clean w3c html
$smarty->assign("trustmode", $this->getacl("trustModel",$SkipWrite));
$trustmode= 0;
}
$smarty->assign("trustmode", $trustmode);
$smarty->assign("trustmodes", array( 0 => _("disabled"), 1 => _("full access"),
2 => _("allow access to these hosts")));
if((count($this->accessTo))==0)
$smarty->assign("emptyArrAccess",true);
else
$smarty->assign("emptyArrAccess",false);
if($this->mustchangepassword){
$smarty->assign("mustchangepassword", " checked ");
} else {
$smarty->assign("mustchangepassword", "");
}
$smarty->assign("workstations", $this->accessTo);
// Add SSH button if available
$smarty->assign("sshPublicKey", $this->ssh?1:0);
$smarty->assign("apply", apply_filter());
$smarty->assign("multiple_support" , $this->multiple_support_active);
$display.= $smarty->fetch (get_template_path('generic.tpl', TRUE, dirname(__FILE__)));
return($display);
}
/* remove object from parent */
function remove_from_parent()
{
/* Cancel if there's nothing to do here */
if ((!$this->initially_was_account) || (!$this->acl_is_removeable())){
return;
}
/* Remove and write to LDAP */
plugin::remove_from_parent();
631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700
/* Zero out array */
$this->attrs['gosaHostACL']= array();
/* Keep uid, because we need it for authentification! */
unset($this->attrs['uid']);
unset($this->attrs['trustModel']); /* FIXME should be host ?? */
@DEBUG (DEBUG_LDAP, __LINE__, __FUNCTION__, __FILE__,
/* include global link_info */
$this->attributes, "Save");
$ldap= $this->config->get_ldap_link();
$ldap->cd($this->dn);
$this->cleanup();
$ldap->modify ($this->attrs);
new log("remove","users/".get_class($this),$this->dn,array_keys($this->attrs),$ldap->get_error());
if (!$ldap->success()){
msg_dialog::display(_("LDAP error"), msgPool::ldaperror($ldap->get_error(), $this->dn, LDAP_DEL, get_class()));
}
/* Delete group only if cn is uid and there are no other
members inside */
$ldap->cd ($this->config->current['BASE']);
$ldap->search ("(&(objectClass=posixGroup)(gidNumber=".$this->gidNumber."))", array("cn", "memberUid"));
if ($ldap->count() != 0){
$attrs= $ldap->fetch();
if ($attrs['cn'][0] == $this->uid &&
!isset($this->attrs['memberUid'])){
$ldap->rmDir($ldap->getDN());
}
}
/* Optionally execute a command after we're done */
$this->handle_post_events("remove",array("uid" => $this->uid));
}
function save_object()
{
if (isset($_POST['posixTab'])){
/* Save values to object */
plugin::save_object();
/* Save force GID checkbox */
if($this->acl_is_writeable("gidNumber") || $this->acl_is_writeable("uidNumber")){
if (isset ($_POST['force_ids'])){
$data= 1;
} else {
$data= 0;
}
if ($this->force_ids != $data){
$this->is_modified= TRUE;
}
$this->force_ids= $data;
}
/*Save primary group settings */
if($this->acl_is_writeable("primaryGroup") && isset($_POST['primaryGroup'])){
$data= $_POST['primaryGroup'];
if ($this->primaryGroup != $data){
$this->is_modified= TRUE;
}
$this->primaryGroup= $_POST['primaryGroup'];
}
/* Get seelcted shadow checkboxes */
701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770
foreach(array("shadowMin","shadowMax","shadowExpire","shadowInactive","shadowWarning") as $var) {
if($this->acl_is_writeable($var)){
$activate_var = "activate_".$var;
if(isset($_POST['activate_'.$var])){
$this->$activate_var = true;
$this->$var = $_POST[$var];
}else{
$this->$activate_var = false;
if ($var != "shadowExpire") {
$this->$var = 0;
}
}
}
}
/* Force change password ? */
if(isset($_POST['mustchangepassword'])){
$this->mustchangepassword = TRUE;
}else{
$this->mustchangepassword = FALSE;
}
/* Trust mode - special handling */
if($this->acl_is_writeable("trustModel")){
if (isset($_POST['trustmode'])){
$saved= $this->trustModel;
if ($_POST['trustmode'] == "1"){
$this->trustModel= "fullaccess";
} elseif ($_POST['trustmode'] == "2"){
$this->trustModel= "byhost";
} else {
$this->trustModel= "";
}
if ($this->trustModel != $saved){
$this->is_modified= TRUE;
}
}
}
}
/* Get regex from alphabet */
if(isset($_GET['search'])){
$this->GroupRegex = $_GET['search']."*";
}
/* Check checkboxes and regexes */
if(isset($_POST["PosixGroupDialogPosted"])){
if(isset($_POST['SubSearch']) && ($_POST['SubSearch'])){
$this->SubSearch = true;
}else{
$this->SubSearch = false;
}
if(isset($_POST['guser'])){
$this->GroupUserRegex = $_POST['guser'];
}
if(isset($_POST['regex'])){
$this->GroupRegex = $_POST['regex'];
}
}
$this->GroupRegex = preg_replace("/\*\**/","*",$this->GroupRegex);
$this->GroupUserRegex = preg_replace("/\*\**/","*",$this->GroupUserRegex);
}
/* Save data to LDAP, depending on is_account we save or delete */
function save()
{
/* Adapt shadow values */
771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840
if (!$this->activate_shadowExpire) {
$this->shadowExpire = "0";
} else {
/* Transform date to days since the beginning */
list($day, $month, $year) = explode('.', $this->shadowExpire, 3);
$this->shadowExpire = (int)(mktime(0, 0, 0, $month, $day, $year)/ (60 * 60 * 24)) ;
}
if (!$this->activate_shadowMax) {
$this->shadowMax = "0";
}
if ($this->mustchangepassword) {
$this->shadowLastChange = (int)(date("U") / 86400) - $this->shadowMax - 1;
} elseif ($this->is_account && !$this->initially_was_account) {
$this->shadowLastChange = (int)(date("U") / 86400);
}
if (!$this->activate_shadowWarning) {
$this->shadowWarning = "0";
}
/* Check what to do with ID's
Nothing forced, so we may have to generate our own IDs, if not done already.
*/
if ($this->force_ids == 0) {
/* Handle uidNumber.
* - use existing number if possible
* - if not, try to create a new uniqe one.
* */
if ($this->savedUidNumber != "") {
$this->uidNumber= $this->savedUidNumber;
} else {
/* Calculate new id's. We need to place a lock before calling get_next_id
to get real unique values.
*/
$wait= 10;
while (get_lock("uidnumber") != "") {
sleep (1);
/* Oups - timed out */
if ($wait-- == 0) {
msg_dialog::display(_("Warning"), _("Timeout while waiting for lock. Ignoring lock!"), WARNING_DIALOG);
break;
}
}
add_lock ("uidnumber", "gosa");
$this->uidNumber= get_next_id("uidNumber", $this->dn);
}
}
/* Handle gidNumber
* - If we do not have a primary group selected (automatic), we will check if there
* is already a group with the same name and use this as primary.
* - .. if we couldn't find a group with the same name, we will create a new one,
* using the users uid as cn and a generated uniqe gidNumber.
* */
if($this->is_template && !$this->primaryGroup){
$this->gidNumber = 2147483647;
}elseif ($this->primaryGroup == 0 || $this->force_ids){
/* Search for existing group */
$ldap = $this->config->get_ldap_link();
$ldap->cd($this->config->current['BASE']);
/* Are we forced to use a special gidNumber? */
if($this->force_ids) {
$ldap->search("(&(objectClass=posixGroup)(gidNumber=".$this->gidNumber."))", array("cn","gidNumber"));
} else {
$ldap->search("(&(objectClass=posixGroup)(gidNumber=*)(cn=".$this->uid."))", array("cn","gidNumber"));
841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910
}
/* No primary group found, create a new one */
if ($ldap->count() == 0) {
$groupcn = $this->uid;
$pri_attr = $this->config->get_cfg_value("accountPrimaryAttribute");
$groupdn= preg_replace ('/^'.preg_quote($pri_attr,'/').'=[^,]+,'.preg_quote(get_people_ou(),'/').'/i',
'cn='.$groupcn.','.get_groups_ou(), $this->dn);
/* Request a new and uniqe gidNumber, if required */
if (!$this->force_ids) {
$this->gidNumber= get_next_id("gidNumber", $this->dn);
}
/* If forced gidNumber could not be found, then check if the given group name already exists
we do not want to modify the gidNumber of an existing group.
*/
$cnt= 0;
while ($ldap->dn_exists($groupdn) && ($cnt < 100)) {
$cnt ++;
$groupcn = $this->uid."_".$cnt;
$groupdn= preg_replace ('/^'.preg_quote($pri_attr,'/').'=[^,]+,'.preg_quote(get_people_ou(),'/').'/i',
'cn='.$groupcn.','.get_groups_ou(), $this->dn);
}
/* Create new primary group and enforce the new gidNumber */
$g= new group($this->config, $groupdn);
$g->cn= $groupcn;
$g->force_gid= 1;
$g->gidNumber= $this->gidNumber;
$g->description= _("Group of user")." ".$this->givenName;
$g->save ();
@DEBUG (DEBUG_TRACE, __LINE__, __FUNCTION__, __FILE__,
sprintf("Primary group '%s' created, using gidNumber '%s'.",$groupcn,$this->gidNumber),"");
} else {
$attrs = $ldap->fetch();
$this->gidNumber = $attrs['gidNumber'][0];
@DEBUG (DEBUG_TRACE, __LINE__, __FUNCTION__, __FILE__,
"Found and used: <i>".$attrs['dn']."</i>",
sprintf("Primary group '%s' exists, gidNumber is '%s'.",$this->uid,$this->gidNumber));
}
} else {
/* Primary group was selected by user
*/
$this->gidNumber = $this->primaryGroup;
@DEBUG (DEBUG_TRACE, __LINE__, __FUNCTION__, __FILE__,
sprintf("Primary group '%s' for user '%s' manually selected.",$this->gidNumber,$this->uid),"");
}
if ($this->activate_shadowMin != "1" ) {
$this->shadowMin = "";
}
if (($this->activate_shadowMax != "1") && ($this->mustchangepassword != "1")) {
$this->shadowMax = "";
}
if ($this->activate_shadowWarning != "1" ) {
$this->shadowWarning = "";
}
if ($this->activate_shadowInactive != "1" ) {
$this->shadowInactive = "";
}
if ($this->activate_shadowExpire != "1" ) {
$this->shadowExpire = "";
911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980
}
/* Fill gecos */
if (isset($this->parent) && $this->parent !== NULL) {
$this->gecos= rewrite($this->parent->by_object['user']->cn);
if (!preg_match('/^[a-z0-9 -]+$/i', $this->gecos)) {
$this->gecos= "";
}
}
foreach (array("shadowMin","shadowMax","shadowWarning","shadowInactive","shadowExpire") as $attr) {
$this->$attr = (int) $this->$attr;
}
/* Call parents save to prepare $this->attrs */
plugin::save();
/* Trust accounts */
$objectclasses= array();
foreach ($this->attrs['objectClass'] as $key => $class) {
/*if (preg_match('/trustAccount/i', $class)){*/
if (preg_match('/hostObject/i', $class)) {
continue;
}
$objectclasses[]= $this->attrs['objectClass'][$key];
}
$this->attrs['objectClass']= $objectclasses;
if ($this->trustModel != "") {
$this->attrs['objectClass'][]= "hostObject";
$this->attrs['host']= array();
if ($this->trustModel == "fullaccess") {
$this->attrs['host'][0]= "*";
} else {
if ($this->trustModel == "byhost") {
foreach ($this->accessTo as $hosts) {
$this->attrs['host'][]= $hosts;
}
}
}
} else {
if ($this->was_trust_account) {
$this->attrs['host']= array();
}
}
if (empty($this->attrs['gosaDefaultPrinter'])) {
$thid->attrs['gosaDefaultPrinter']=array();
}
/* include global link_info */
$this->cleanup();
/* This is just a test, we have had duplicated ids
in the past when copy & paste was used.
Normaly this should not happen.
*/
if (isset($this->attrs['uidNumber']) && !$this->force_ids) {
$used = $this->get_used_uid_numbers();
if (isset($used[$this->attrs['uidNumber']]) && $used[$this->attrs['uidNumber']] != $this->dn) {
msg_dialog::display(_("Warning"),_("A duplicated UID number was written for this user. If this was not intended please verify all used uidNumbers!"), WARNING_DIALOG);
}
}
$ldap = $this->config->get_ldap_link();
$ldap->cd($this->dn);
unset($this->attrs['uid']);
$ldap->modify ($this->attrs);
/* Log last action */
if ($this->initially_was_account) {
981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050
new log("modify","users/".get_class($this),$this->dn,array_keys($this->attrs),$ldap->get_error());
} else {
new log("create","users/".get_class($this),$this->dn,array_keys($this->attrs),$ldap->get_error());
}
if (!$ldap->success()){
msg_dialog::display(_("LDAP error"), msgPool::ldaperror($ldap->get_error(), $this->dn, LDAP_MOD, get_class()));
}
/* Remove lock needed for unique id generation */
del_lock ("uidnumber");
// Save ssh stuff if needed
if ($this->ssh) {
$this->ssh->setDN($this->dn);
$this->ssh->save();
}
/* Take care about groupMembership values: add to groups */
foreach ($this->groupMembership as $key => $value){
if (!isset($this->savedGroupMembership[$key])){
$g= new grouptabs($this->config,$this->config->data['TABS']['GROUPTABS'], $key,"groups");
$g->set_acl_base($key);
$g->by_object['group']->addUser($this->uid);
$g->save();
}
}
/* Remove groups not listed in groupMembership */
foreach ($this->savedGroupMembership as $key => $value){
if (!isset($this->groupMembership[$key])){
$g= new grouptabs($this->config,$this->config->data['TABS']['GROUPTABS'], $key,"groups");
$g->set_acl_base($key);
$g->by_object['group']->removeUser ($this->uid);
$g->save();
}
}
/* Optionally execute a command after we're done */
if ($this->initially_was_account == $this->is_account){
if ($this->is_modified){
$this->handle_post_events("modify",array("uid" => $this->uid));
}
} else {
$this->handle_post_events("add" ,array("uid"=> $this->uid));
}
}
/* Check formular input */
function check()
{
/* Include global link_info */
$ldap= $this->config->get_ldap_link();
/* Append groups as memberGroup: to check hook
*/
$tmp_attributes = $this->attributes;
$this->attributes[] = "memberGroup";
$this->memberGroup = array();
foreach($this->groupMembership as $dn => $name){
$this->memberGroup[] = $name;
}
/* Call common method to give check the hook */
$message= plugin::check();
$this->attributes = $tmp_attributes;
/* must: homeDirectory */
if ($this->homeDirectory == ""){
1051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120
$message[]= msgPool::required(_("Home directory"));
}
if (!tests::is_path($this->homeDirectory)){
$message[]= msgPool::invalid(_("Home directory"), "", "", "/home/yourname" );
}
/* Check ID's if they are forced by user */
if ($this->force_ids == "1"){
/* Valid uid/gid? */
if (!tests::is_id($this->uidNumber)){
$message[]= msgPool::invalid(_("UID"), $this->uidNumber, "/[0-9]/");
} else {
if ($this->uidNumber < $this->config->get_cfg_value("minId")){
$message[]= msgPool::toosmall(_("UID"), $this->config->get_cfg_value("minId"));
}
}
if (!tests::is_id($this->gidNumber)){
$message[]= msgPool::invalid(_("GID"), $this->gidNumber, "/[0-9]/");
} else {
if ($this->gidNumber < $this->config->get_cfg_value("minId")){
$message[]= msgPool::toosmall(_("GID"), $this->config->get_cfg_value("minId"));
}
}
}
/* Check dates */
if ($this->activate_shadowExpire && ($this->shadowExpire == "" || !tests::is_date($this->shadowExpire))){
$message[]= msgPool::invalid("shadowExpire", $this->shadowExpire);
}
/* Check shadow settings, well I like spaghetties... */
if ($this->activate_shadowMin){
if (!tests::is_id($this->shadowMin)){
$message[]= msgPool::invalid(_("shadowMin"), $this->shadowMin, "/[0-9]/");
}
}
if ($this->activate_shadowMax){
if (!tests::is_id($this->shadowMax)){
$message[]= msgPool::invalid(_("shadowMax"), $this->shadowMax, "/[0-9]/");
}
}
if ($this->activate_shadowWarning){
if (!tests::is_id($this->shadowWarning)){
$message[]= msgPool::invalid(_("shadowWarning"), $this->shadowWarning, "/[0-9]/");
}
if (!$this->activate_shadowMax){
$message[]= msgPool::depends("shadowWarning", "shadowMax");
}
if ($this->shadowWarning > $this->shadowMax){
$message[]= msgPool::toobig("shadowWarning", "shadowMax");
}
if ($this->activate_shadowMin && $this->shadowWarning < $this->shadowMin){
$message[]= msgPool::toosmall("shadowWarning", "shadowMin");
}
}
if ($this->activate_shadowInactive){
if (!tests::is_id($this->shadowInactive)){
$message[]= msgPool::invalid(_("shadowInactive"), $this->shadowInactive, "/[0-9]/");
}
if (!$this->activate_shadowMax){
$message[]= msgPool::depends("shadowInactive", "shadowMax");
}
}
if ($this->activate_shadowMin && $this->activate_shadowMax){
if ($this->shadowMin > $this->shadowMax){
$message[]= msgPool::toobig("shadowMin", "shadowMax");
}
}
1121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190
return ($message);
}
function multiple_check()
{
$message = plugin::multiple_check();
if ($this->homeDirectory == "" && in_array("homeDirectory",$this->multi_boxes)){
$message[]= msgPool::required(_("Home directory"));
}
if (!tests::is_path($this->homeDirectory) && in_array("homeDirectory",$this->multi_boxes)){
$message[]= msgPool::invalid(_("Home directory"), "", "", "/home/yourname" );
}
/* Check shadow settings, well I like spaghetties... */
if ($this->activate_shadowMin && in_array("activate_shadowMin",$this->multi_boxes)){
if (!tests::is_id($this->shadowMin)){
$message[]= msgPool::invalid(_("shadowMin"), $this->shadowMin, "/[0-9]/");
}
}
if ($this->activate_shadowMax && in_array("activate_shadowMax",$this->multi_boxes)){
if (!tests::is_id($this->shadowMax)){
$message[]= msgPool::invalid(_("shadowMax"), $this->shadowMax, "/[0-9]/");
}
}
if ($this->activate_shadowWarning && in_array("activate_shadowWarning",$this->multi_boxes)){
if (!tests::is_id($this->shadowWarning)){
$message[]= msgPool::invalid(_("shadowWarning"), $this->shadowWarning, "/[0-9]/");
}
if (!$this->activate_shadowMax && in_array("activate_shadowMax",$this->multi_boxes)){
$message[]= msgPool::depends("shadowWarning", "shadowMax");
}
if ($this->shadowWarning > $this->shadowMax && in_array("activate_shadowWarning",$this->multi_boxes)){
$message[]= msgPool::toobig("shadowWarning", "shadowMax");
}
if ($this->activate_shadowMin && $this->shadowWarning < $this->shadowMin && in_array("activate_shadowMin",$this->multi_boxes)){
$message[]= msgPool::tosmall("shadowWarning", "shadowMin");
}
}
if ($this->activate_shadowInactive && in_array("activate_shadowInactive",$this->multi_boxes)){
if (!tests::is_id($this->shadowInactive)){
$message[]= msgPool::invalid(_("shadowInactive"), $this->shadowInactive, "/[0-9]/");
}
if (!$this->activate_shadowMax && in_array("activate_shadowMax",$this->multi_boxes)){
$message[]= msgPool::depends("shadowInactive", "shadowMax");
}
}
if ($this->activate_shadowMin && $this->activate_shadowMax && in_array("activate_shadowMin",$this->multi_boxes)){
if ($this->shadowMin > $this->shadowMax){
$message[]= msgPool::toobig("shadowMin", "shadowMax");
}
}
return($message);
}
function addGroup ($groups)
{
/* include global link_info */
$ldap= $this->config->get_ldap_link();
/* Walk through groups and add the descriptive entry if not exists */
foreach ($groups as $value){
if (!array_key_exists($value, $this->groupMembership)){
$ldap->cat($value, array('cn', 'description', 'dn'));
$attrs= $ldap->fetch();
error_reporting (0);
if (!isset($attrs['description'][0])){
1191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260
$entry= $attrs["cn"][0];
} else {
$dsc= preg_replace ('/^Group of user/', _("Group of user"), $attrs["description"][0]);
$entry= $attrs["cn"][0]." [$dsc]";
}
error_reporting (E_ALL | E_STRICT);
if(obj_is_writable($attrs['dn'],"groups/group","memberUid")){
$this->groupMembership[$attrs['dn']]= $entry;
if($this->multiple_support_active && isset($this->groupMembership_some[$attrs['dn']])){
unset($this->groupMembership_some[$attrs['dn']]);
}
}
}
}
/* Sort groups */
asort ($this->groupMembership);
reset ($this->groupMembership);
}
/* Del posix user from some groups */
function delGroup ($groups)
{
$dest= array();
foreach($groups as $dn_to_del){
if(isset($this->groupMembership[$dn_to_del]) && obj_is_writable($dn_to_del,"groups/group","memberUid")){
unset($this->groupMembership[$dn_to_del]);
}
if($this->multiple_support_active){
if(isset($this->groupMembership_some[$dn_to_del]) && obj_is_writable($dn_to_del,"groups/group","memberUid")){
unset($this->groupMembership_some[$dn_to_del]);
}
}
}
}
/* Adapt from template, using 'dn' */
function adapt_from_template($dn, $skip= array())
{
/* Include global link_info */
$ldap= $this->config->get_ldap_link();
plugin::adapt_from_template($dn, $skip);
$template= $this->attrs['uid'][0];
/* Adapt group membership */
$ldap->cd($this->config->current['BASE']);
$ldap->search("(&(objectClass=posixGroup)(memberUid=".$this->attrs["uid"][0]."))", array("description", "cn"));
while ($this->attrs= $ldap->fetch()){
if (!isset($this->attrs["description"][0])){
$entry= $this->attrs["cn"][0];
} else {
$entry= $this->attrs["cn"][0]." [".$this->attrs["description"][0]."]";
}
$this->groupMembership[$ldap->getDN()]= $entry;
}
/* Fix primary group settings */
if($this->gidNumber == 2147483647){
$this->gidNumber = "";
}
if($this->gidNumber){
$ldap->cd($this->config->current['BASE']);
$ldap->search("(&(objectClass=posixGroup)(cn=$template)(gidNumber=".$this->gidNumber."))", array("cn"));
if ($ldap->count() != 1){
1261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330
$this->primaryGroup= $this->gidNumber;
}
}
$ldap->cd($this->config->current['BASE']);
$ldap->search("(&(objectClass=gosaUserTemplate)(uid=".$template.")(accessTo=*))", array("cn","accessTo"));
while($attr = $ldap->fetch()){
$tmp = $attr['accessTo'];
unset ($tmp['count']);
$this->accessTo = $tmp;
}
/* Adjust shadow checkboxes */
foreach (array("shadowMin", "shadowMax", "shadowWarning", "shadowInactive", "shadowExpire") as $val){
if ($this->$val != 0){
$oval= "activate_".$val;
$this->$oval= "1";
}
}
/* Only enable checkbox, if shadowExpire is in the future */
if($this->shadowExpire > time()) {
$this->activate_shadowExpire= "1";
}
/* Convert shadowExpire for usage */
if ($this->shadowExpire == 0){
$this->shadowExpire= "";
} else {
$this->shadowExpire= date('d.m.Y', $this->shadowExpire * 60 * 60 * 24);
}
}
function get_used_uid_numbers()
{
$ids= array();
$ldap= $this->config->get_ldap_link();
$ldap->cd ($this->config->current['BASE']);
$ldap->search ("(&(objectClass=posixAccount)(uidNumber=*))", array("uidNumber"));
/* Get list of ids */
while ($attrs= $ldap->fetch()){
$ids[$attrs['uidNumber'][0]] = $attrs['dn'];
}
return($ids);
}
/* Get posts from copy & paste dialog */
function saveCopyDialog()
{
if(isset($_POST['homeDirectory'])){
$this->homeDirectory = $_POST['homeDirectory'];
if (isset ($_POST['force_ids'])){
$data= 1;
$this->gidNumber = $_POST['gidNumber'];
$this->uidNumber = $_POST['uidNumber'];
} else {
$data= 0;
}
if ($this->force_ids != $data){
$this->is_modified= TRUE;
}
$this->force_ids= $data;
$data= $_POST['primaryGroup'];
if ($this->primaryGroup != $data){
$this->is_modified= TRUE;
1331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400
}
$this->primaryGroup= $_POST['primaryGroup'];
}
}
/* Create the posix dialog part for copy & paste */
function getCopyDialog()
{
/* Skip dialog creation if this is not a valid account*/
if(!$this->is_account) return("");
if ($this->force_ids == 1){
$force_ids = "checked";
if (session::get('js')){
$forceMode = "";
}
} else {
if (session::get('js')){
if($this->acl != "#none#")
$forceMode ="disabled";
}
$force_ids = "";
}
$sta = "";
/* Open group add dialog */
if(isset($_POST['edit_groupmembership'])){
$this->groupSelect = new groupSelect($this->config,get_userinfo());
$sta = "SubDialog";
}
/* If the group-add dialog is closed, call execute
to ensure that the membership is updatd */
if(isset($_POST['add_groups_finish']) || isset($_POST['add_groups_cancel'])){
$this->execute();
$this->groupSelect =NULL;
}
if($this->groupSelect){
$str = $this->execute(true);
$ret = array();
$ret['string'] = $str;
$ret['status'] = $sta;
return($ret);
}
/* If a group member should be deleted, simply call execute */
if(isset($_POST['delete_groupmembership'])){
$this->execute();
}
/* Assigned informations to smarty */
$smarty = get_smarty();
$smarty->assign("homeDirectory",$this->homeDirectory);
$smarty->assign("secondaryGroups",$this->secondaryGroups);
$smarty->assign("primaryGroup",$this->primaryGroup);
$smarty->assign("uidNumber",$this->uidNumber);
$smarty->assign("gidNumber",$this->gidNumber);
$smarty->assign("forceMode",$forceMode);
$smarty->assign("force_ids",$force_ids);
if (!count($this->groupMembership)){
$smarty->assign("groupMembership", array(" "));
} else {
$smarty->assign("groupMembership", $this->groupMembership);
}
/* Display wars message if there are more than 16 group members */
if (count($this->groupMembership) > 16){
1401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470
$smarty->assign("groups", "too_many_for_nfs");
} else {
$smarty->assign("groups", "");
}
$str = $smarty->fetch(get_template_path("paste_generic.tpl",TRUE,dirname(__FILE__)));
$ret = array();
$ret['string'] = $str;
$ret['status'] = $sta;
return($ret);
}
function PrepareForCopyPaste($source)
{
plugin::PrepareForCopyPaste($source);
/* Avoid using the same gid/uid number as source user
empty numbers to enforce new ones. */
$this->savedUidNumber = "";
$this->savedGidNumber = "";
/* Get group membership */
$ldap = $this->config->get_ldap_link();
$ldap->cd($this->config->current['BASE']);
$ldap->search("(&(objectClass=posixGroup)(memberUid=".$source['uid'][0]."))", array("cn", "description"));
while ($attrs= $ldap->fetch()){
if (!isset($attrs["description"][0])){
$entry= $attrs["cn"][0];
} else {
$entry= $attrs["cn"][0]." [".$attrs["description"][0]."]";
}
$this->groupMembership[$ldap->getDN()]= $entry;
}
asort($this->groupMembership);
reset($this->groupMembership);
/* Fill group */
if(isset($source['gidNumber'][0])){
$this->primaryGroup= $source['gidNumber'][0];
}
/* Adjust shadow checkboxes */
foreach (array("shadowMin", "shadowMax", "shadowWarning", "shadowInactive",
"shadowExpire") as $val){
if ($this->$val != 0){
$oval= "activate_".$val;
$this->$oval= "1";
}
}
}
function multiple_execute()
{
return($this->execute());
}
/* Return selected values for multiple edit */
function get_multi_edit_values()
{
$ret = plugin::get_multi_edit_values();
$ret['groupMembership'] = $this->groupMembership;
$ret['groupMembership_some']= $this->groupMembership_some;
if(in_array("primaryGroup",$this->multi_boxes)){
1471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540
$ret['primaryGroup'] = $this->primaryGroup;
}
if(in_array("trustmode",$this->multi_boxes)){
$ret['trustModel'] = $this->trustModel;
$ret['accessTo'] = $this->accessTo;
}
foreach(array("shadowWarning","shadowInactive","shadowMin","shadowMax", "shadowExpire") as $entry){
$active = "activate_".$entry;
if(in_array($active,$this->multi_boxes)){
$ret[$entry] = $this->$entry;
$ret[$active] = $this->$active;
}
}
if(in_array("mustchangepassword",$this->multi_boxes)){
$ret['mustchangepassword'] = $this->mustchangepassword;
}
return($ret);
}
/* Save posts for multiple edit
*/
function multiple_save_object()
{
if(isset($_POST['posix_mulitple_edit'])){
/* Backup expire value */
$expire_tmp = $this->shadowExpire;
/* Update all values */
plugin::multiple_save_object();
/* Get selected checkboxes */
foreach(array("primaryGroup","trustmode","mustchangepassword","activate_shadowWarning","activate_shadowInactive","activate_shadowMin", "activate_shadowMax","activate_shadowExpire") as $val){
if(isset($_POST["use_".$val])){
$this->multi_boxes[] = $val;
}
}
/* Update special values, checkboxes for posixShadow */
foreach(array("shadowMin","shadowMax","shadowExpire","shadowInactive","shadowWarning") as $var) {
if($this->acl_is_writeable($var)){
$activate_var = "activate_".$var;
if(in_array($activate_var, $this->multi_boxes)){
if(isset($_POST['activate_'.$var])){
$this->$activate_var = true;
$this->$var = $_POST[$var];
}else{
$this->$activate_var = false;
$this->$var = 0;
}
}
}
}
/* Restore shadow value, if the shadow attribute isn't used */
if(!in_array("activate_shadowExpire",$this->multi_boxes)){
$this->shadowExpire = $expire_tmp;
}
/* Force change password ? */
if(isset($_POST['mustchangepassword'])){
$this->mustchangepassword = TRUE;
}else{
$this->mustchangepassword = FALSE;
}
/* Trust mode - special handling */
if($this->acl_is_writeable("trustModel")){
if (isset($_POST['trustmode'])){
1541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610
$saved= $this->trustModel;
if ($_POST['trustmode'] == "1"){
$this->trustModel= "fullaccess";
} elseif ($_POST['trustmode'] == "2"){
$this->trustModel= "byhost";
} else {
$this->trustModel= "";
}
if ($this->trustModel != $saved){
$this->is_modified= TRUE;
}
}
}
/* Save primary group settings */
if($this->acl_is_writeable("primaryGroup") && isset($_POST['primaryGroup'])){
$data= $_POST['primaryGroup'];
if ($this->primaryGroup != $data){
$this->is_modified= TRUE;
}
$this->primaryGroup= $_POST['primaryGroup'];
}
}
}
/* Initialize plugin with given atribute arrays
*/
function init_multiple_support($attrs,$all)
{
plugin::init_multiple_support($attrs,$all);
/* Some dummy values */
$groups_some = array();
$groups_all = array();
$groups_uid = array();
$uids = array();
$first = TRUE;
/* Get all groups used by currently edited users */
$uid_filter="";
for($i =0; $i < $this->multi_attrs_all['uid']['count'] ; $i ++){
$uid = $this->multi_attrs_all['uid'][$i];
$uids[] = $uid;
$uid_filter.= "(memberUid=".$uid.")";
}
$uid_filter = "(&(objectClass=posixGroup)(|".$uid_filter."))";
$ldap = $this->config->get_ldap_link();
$ldap->cd($this->config->current['BASE']);
$ldap->search($uid_filter,array("dn","cn","memberUid"));
while($group = $ldap->fetch()){
$groups_some[$group['dn']] = $group['cn'][0];
for($i = 0 ; $i < $group['memberUid']['count'] ; $i++){
$groups_uid[$group['dn']][] = $group['memberUid'][$i];
}
}
/* Create an array, containing all used groups */
$groups_all = $groups_some;
foreach($groups_all as $id => $group){
foreach($uids as $uid){
if(!in_array($uid,$groups_uid[$id])){
unset($groups_all[$id]);
break;
}
}
}
/* Assign group array */
$this->groupMembership = $groups_all;
1611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680
/* Create an array of all grouops used by all users */
foreach( $groups_all as $dn => $cn){
if(isset($groups_some[$dn])){
unset($groups_some[$dn]);
}
}
$this->groupMembership_some = $groups_some;
$this->primaryGroup = $this->gidNumber;
/* Is this account a trustAccount? */
if (isset($this->multi_attrs['trustModel'])){
$this->trustModel= $this->multi_attrs['trustModel'][0];
$this->was_trust_account= TRUE;
$this->multi_boxes[] = "trustmode";
} else {
$this->was_trust_account= FALSE;
$this->trustModel= "";
}
/* Create access informations */
$this->accessTo = array();
if (isset($this->multi_attrs['accessTo'])){
for ($i= 0; $i<$this->multi_attrs['accessTo']['count']; $i++){
$tmp= $this->multi_attrs['accessTo'][$i];
$this->accessTo[$tmp]= $tmp;
}
}
/* Adjust shadow checkboxes */
foreach (array("shadowMin", "shadowMax", "shadowWarning", "shadowInactive",
"shadowExpire") as $val){
if ($this->$val != 0){
$oval= "activate_".$val;
$this->$oval= "1";
}
}
/* Convert to seconds */
if(isset($this->multi_attrs['shadowExpire'])){
$this->shadowExpire = $this->convertToSeconds($this->multi_attrs['shadowExpire'][0]);
}else{
$this->activate_shadowExpire = FALSE;
}
}
function set_multi_edit_values($attrs)
{
$groups = array();
/* Update groupMembership, keep optinal group */
foreach($attrs['groupMembership_some'] as $dn => $cn){
if(isset($this->groupMembership[$dn])){
$groups[$dn] = $cn;
}
}
/* Update groupMembership, add forced groups */
foreach($attrs['groupMembership'] as $dn => $cn){
$groups[$dn] = $cn;
}
plugin::set_multi_edit_values($attrs);
$this->groupMembership = $groups;
}
static function plInfo()
{
return array(
"plShortName" => _("Unix"),
"plDescription" => _("POSIX account"),
168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710
"plSelfModify" => TRUE,
"plDepends" => array("user"),
"plPriority" => 2,
"plSection" => array("personal" => _("My account")),
"plCategory" => array("users"),
"plObjectType" => array("user"),
"plProvidedAcls" => array(
"homeDirectory" => _("Home directory"),
"loginShell" => _("Shell"),
"uidNumber" => _("User ID"),
"gidNumber" => _("Group ID"),
"mustchangepassword"=> _("Force password change on login"),
"shadowMin" => _("Shadow min"),
"shadowMax" => _("Shadow max"),
"shadowWarning" => _("Shadow warning"),
"shadowInactive" => _("Shadow inactive"),
"shadowExpire" => _("Shadow expire"),
"sshPublickey" => _("Public SSH key"),
"trustModel" => _("System trust model")
)
);
}
}
// vim:tabstop=2:expandtab:shiftwidth=2:filetype=php:syntax:ruler:
?>