ability to set an email-address for groups (with automatic forwards to member's email)

This commit is contained in:
Ralf Becker 2006-10-11 21:59:43 +00:00
parent fd45860980
commit cfc6f23dbd

View File

@ -86,6 +86,16 @@ class accounts_backend
'top','posixgroup','groupofnames' 'top','posixgroup','groupofnames'
) )
); );
/**
* Classes allowing to set a mail-address for a group and specify the memberaddresses as forwarding addresses
*
* @var unknown_type
*/
var $group_mail_classes = array(
// 'dbmailforwardingaddress' => 'mailforwardingaddress',
'dbmailuser' => 'mailforwardingaddress',
'qmailuser' => 'mailforwardingaddress',
);
/** /**
* reference to the translation class * reference to the translation class
* *
@ -234,6 +244,47 @@ class accounts_backend
$to_write = array_merge($to_write,accounts_backend::set_members($members, $to_write = array_merge($to_write,accounts_backend::set_members($members,
$data['account_id'],$groupOfNames,$dn)); $data['account_id'],$groupOfNames,$dn));
} }
// check if we should set a mail address and forwards for each member
foreach($this->group_mail_classes as $objectclass => $forward)
{
if ($this->ldapServerInfo->supportsObjectClass($objectclass) &&
($old && in_array($objectclass,$old['objectclass']) || $data_utf8['account_email'] || $old['mail']))
{
if ($data_utf8['account_email']) // setting an email
{
if (!in_array($objectclass,$old ? $old['objectclass'] : $to_write['objectclass']))
{
if ($old) $to_write['objectclass'] = $old['objectclass'];
$to_write['objectclass'][] = $objectclass;
}
if ($objectclass != 'dbmailforwardingaddress') $to_write['uid'] = $data_utf8['account_lid'];
$to_write['mail'] = $data_utf8['account_email'];
if (!$members) $members = $this->members($data['account_id']);
$to_write[$forward] = array();
foreach ($members as $member)
{
if (($email = $this->id2name($member,'account_email')))
{
$to_write[$forward][] = $email;
}
}
}
elseif($old) // remove the mail and forwards only for existing entries
{
$to_write['mail'] = $to_write[$forward] = array();
if ($objectclass != 'dbmailforwardingaddress') $to_write['uid'] = array();
if (($key = array_search($objectclass,$old['objectclass'])))
{
$to_write['objectclass'] = $old['objectclass'];
unset($to_write['objectclass'][$key]);
$to_write['objectclass'] = array_values($to_write['objectclass']);
}
}
break;
}
}
} }
else else
{ {
@ -257,6 +308,7 @@ class accounts_backend
{ {
// try again with removed groupOfNames stuff, as I cant detect if posixGroup is a structural object // try again with removed groupOfNames stuff, as I cant detect if posixGroup is a structural object
unset($to_write['objectclass'][$key]); unset($to_write['objectclass'][$key]);
$to_write['objectclass'] = array_values($to_write['objectclass']);
unset($to_write['member']); unset($to_write['member']);
$err = $old ? !ldap_modify($this->ds,$dn,$to_write) : !ldap_add($this->ds,$dn,$to_write); $err = $old ? !ldap_modify($this->ds,$dn,$to_write) : !ldap_add($this->ds,$dn,$to_write);
} }
@ -343,7 +395,7 @@ class accounts_backend
function _read_group($account_id) function _read_group($account_id)
{ {
$sri = ldap_search($this->ds, $this->group_context, 'gidnumber=' . abs($account_id), $sri = ldap_search($this->ds, $this->group_context, 'gidnumber=' . abs($account_id),
array('dn','gidnumber','cn','objectclass')); array('dn','gidnumber','cn','objectclass','mail'));
$data = ldap_get_entries($this->ds, $sri); $data = ldap_get_entries($this->ds, $sri);
if (!$data['count']) if (!$data['count'])
@ -360,11 +412,20 @@ class accounts_backend
'account_firstname' => $data['cn'][0], 'account_firstname' => $data['cn'][0],
'account_lastname' => lang('Group'), 'account_lastname' => lang('Group'),
'groupOfNames' => in_array('groupOfNames',$data['objectclass']), 'groupOfNames' => in_array('groupOfNames',$data['objectclass']),
'account_email' => $data['mail'][0],
); );
if (!is_object($this->ldapServerInfo)) if (!is_object($this->ldapServerInfo))
{ {
$this->ldapServerInfo = $GLOBALS['egw']->ldap->getLDAPServerInfo($GLOBALS['egw_info']['server']['ldap_host']); $this->ldapServerInfo = $GLOBALS['egw']->ldap->getLDAPServerInfo($GLOBALS['egw_info']['server']['ldap_host']);
} }
foreach($this->group_mail_classes as $objectclass => $forward)
{
if ($this->ldapServerInfo->supportsObjectClass($objectclass))
{
$group['mailAllowed'] = $objectclass;
break;
}
}
return $group; return $group;
} }
@ -434,7 +495,7 @@ class accounts_backend
{ {
$to_write['gidnumber'] = abs($data['account_id']); $to_write['gidnumber'] = abs($data['account_id']);
$to_write['cn'] = $data['account_lid']; $to_write['cn'] = $data['account_lid'];
return $to_write; return $to_write;
} }
@ -870,6 +931,17 @@ class accounts_backend
} }
if ($use_cn) return $to_write; if ($use_cn) return $to_write;
// set the member email addresses as forwards
if ($this->id2name($gid,'account_email') && ($objectclass = $this->id2name($gid,'mailAllowed')))
{
$forward = $this->group_mail_classes[$objectclass];
$to_write[$forward] = array();
foreach($members as $key => $member)
{
if (($email = $this->id2name($member,'account_email'))) $to_write[$forward][] = $email;
}
}
if (!ldap_modify($this->ds,'cn='.ldap::quote($cn).','.$this->group_context,$to_write)) if (!ldap_modify($this->ds,'cn='.ldap::quote($cn).','.$this->group_context,$to_write))
{ {
echo "ldap_modify(,'cn=$cn,$this->group_context',".print_r($to_write,true)."))\n"; echo "ldap_modify(,'cn=$cn,$this->group_context',".print_r($to_write,true)."))\n";