diff --git a/plugins/personal/connectivity/class_kolabAccount.inc b/plugins/personal/connectivity/class_kolabAccount.inc
index 09c3e83330410a2c1685a5c968918f85aef8c7fc..9f08ea9110e4bdad8c1c550f80f08d79ec042c9e 100644 (file)
class kolabAccount extends plugin
{
/* Definitions */
- var $plHeadline= "Kolab";
- var $plDescription= "This does something";
-
- /* CLI vars */
- var $cli_summary= "Manage users Kolab account";
- var $cli_description= "Some longer text\nfor help";
- var $cli_parameters= array("eins" => "Eins ist toll", "zwei" => "Zwei ist noch besser");
+ var $plHeadline = "Kolab";
+ var $plDescription = "This does something";
/* Kolab attributes */
- var $kolabInvitationPolicy= array();
- var $kolabFreeBusyFuture= 60;
- var $unrestrictedMailSize= 0;
- var $calFBURL= "";
- var $kolabDelegate= array();
+ var $kolabInvitationPolicy = array();
+ var $kolabFreeBusyFuture = 60;
+ var $unrestrictedMailSize = 0;
+ var $calFBURL = "";
+ var $kolabDelegate = array();
/* attribute list for save action */
- var $attributes= array( "kolabFreeBusyFuture", "unrestrictedMailSize", "calFBURL");
- var $objectclasses= array();
+ var $attributes = array("kolabFreeBusyFuture", "unrestrictedMailSize", "calFBURL","kolabDelegate");
+ var $objectclasses = array("kolabInetOrgPerson");
/* Helper */
var $imapping= array();
+
function kolabAccount ($config, $dn= NULL)
{
plugin::plugin ($config, $dn);
/* Pull arrays */
foreach(array("kolabDelegate", "kolabInvitationPolicy") as $attr){
if (isset($this->attrs["$attr"]["count"])){
+ $tmp = array();
for ($i= 0; $i<$this->attrs["$attr"]["count"]; $i++){
- array_push($this->$attr, $this->attrs["$attr"][$i]);
+ $tmp[]=$this->attrs["$attr"][$i];
}
+ $this->$attr = $tmp;
}
}
$this->kolabInvitationPolicy= array("ACT_MANUAL");
}
+ /* Check is account state */
+ $this->is_account = false;
+ if(count($this->kolabDelegate)){
+ $this->is_account = true;
+ }
+ foreach(array("calFBURL","unrestrictedMailSize") as $attr){
+ if(!empty($this->$attr)){
+ $this->is_account = true;
+ }
+ }
}
+
function execute()
{
+ /* Call parent execute */
+ plugin::execute();
+
/* Show tab dialog headers */
$display= "";
$smarty->assign("$val", $this->$val);
$smarty->assign($val."ACL", chkacl($this->acl, "$val"));
}
+ $smarty->assign("kolabAccountACL", chkacl($this->acl, "kolabAccountACL"));
/* Check for invitation action */
$nr= 0;
/* Unify addresses */
$new= array();
foreach($this->kolabInvitationPolicy as $value){
- if (preg_match('/^:/', $value)){
- continue;
- }
$address= preg_replace('/^([^:]+:).*$/', '\1', $value);
$new[$address]= $value;
}
$ldap= $this->config->get_ldap_link();
$ldap->cd ($this->config->current['BASE']);
- $ldap->search('(mail='.$address.')');
+ $ldap->search('(mail='.$address.')',array("mail"));
if ($ldap->count() == 0){
print_red (_("The mail address you're trying to add is no primary mail address of an existing user."));
} else {
}
/* Transfer account states for this union */
- if ($this->parent->by_object['mailAccount']->is_account){
- $smarty->assign('is_account', 'true');
- } else {
- $smarty->assign('is_account', '');
+ if (isset($this->parent) && $this->parent->by_object['mailAccount']->is_account){
+ $smarty->assign('mail_account', 'true');
+ } elseif($this-> initially_was_account && (isset($this->attrs['objectClass']) && (in_array("kolabInetOrgPerson",$this->attrs['objectClass'])))){
+ $smarty->assign('mail_account', 'true');
+ }else{
+ $smarty->assign('mail_account', '');
}
/* Transfer delegation list */
if (!count($this->kolabDelegate)){
- $smarty->assign("kolabDelegate", array(""));
+ /* Smarty will produce <option value=""></option> and tidy don't like that, so tell smarty to create no option (array();)*/
+ $smarty->assign("kolabDelegate", array());
} else {
$smarty->assign("kolabDelegate", $this->kolabDelegate);
}
$this->imapping= array();
$nr= 0;
$acl= chkacl($this->acl, "kolabInvitationPolicy");
+ $changeState = "";
foreach ($this->kolabInvitationPolicy as $entry){
+
+ $changeState .= "changeState('address".$nr."'); \n changeState('policy".$nr."'); \n
+ changeState('add".$nr."'); \n changeState('remove".$nr."'); \n";
+
$invitation.= "<tr><td>";
+ if($this->is_account){
+ $dis = " ";
+ }else{
+ $dis = " disabled ";
+ }
+
/* The default entry does not have colons... */
if (!preg_match('/:/', $entry)){
} else {
$name= preg_replace('/:.*$/', '', $entry);
$mode= preg_replace('/^[^:]*: */', '', $entry);
- $invitation.= "<input name=\"address$nr\" size=16 maxlength=60 $acl value=\"$name\">";
+ $invitation.= "<input name=\"address$nr\" size=16 maxlength=60 $acl value=\"$name\" id='address".$nr."' ".$dis.">";
}
$invitation.= "</td>";
/* Add mode switch */
- $invitation.= "<td><select size=\"1\" name=\"policy$nr\" $acl>";
+ $invitation.= "<td><select size=\"1\" name=\"policy$nr\" $acl id='policy".$nr."' ".$dis.">";
foreach($policies as $key => $value){
if ($key == $mode){
$invitation.= "<option value=\"$key\" selected>$value</option>";
/* Assign buttons */
$button= "";
if ($nr == count($this->kolabInvitationPolicy)-1){
- $button= "<input type=submit name=\"add$nr\" value=\""._("Add")."\">";
+ $button= "<input type=submit name=\"add$nr\" value=\""._("Add")."\" id='add".$nr."' ".$dis.">";
}
if ($nr != 0) {
- $button.= "<input type=submit name=\"remove$nr\" value=\""._("Remove")."\">";
+ $button.= "<input type=submit name=\"remove$nr\" value=\""._("Remove")."\" id='remove".$nr."' ".$dis.">";
}
$invitation.= "</select> $button</td></tr>\n";
$nr++;
}
$smarty->assign("invitation", $invitation);
-
+ $smarty->assign("changeState", $changeState);
+ $smarty->assign("kolabState",$this->is_account);
$display.= $smarty->fetch (get_template_path('kolab.tpl', TRUE, dirname(__FILE__)));
+
+
return ($display);
}
function remove_from_parent()
{
/* Optionally execute a command after we're done */
+ plugin::remove_from_parent();
+
+ if(!in_array("kolabInetOrgPerson",$this->attrs['objectClass'])){
+ $this->attrs['objectClass'][] = "kolabInetOrgPerson";
+ }
+
+ $ldap = $this->config->get_ldap_linK();
+ $ldap->cd($this->config->current['BASE']);
+ $ldap->cd ($this->dn);
+ $ldap->modify($this->attrs);
+
$this->handle_post_events('remove');
+ show_ldap_error($ldap->get_error(), sprintf(_("Removing of user/kolab account with dn '%s' failed."),$this->dn));
}
function check()
{
- $message= array();
+ /* Call common method to give check the hook */
+ $message= plugin::check();
/* FBFuture is in days... */
if ($this->kolabFreeBusyFuture != "" && !preg_match('/^[0-9]+$/', $this->kolabFreeBusyFuture)){
}
/* Check for URL scheme... */
- if ($this->calFBURL != "" && !preg_match('/^[^:/]+://[a-z0-9_/.+~-]+$/i', $this->calFBURL)){
+ if ($this->calFBURL != "" && !@preg_match('/^[^:/]+://[a-z0-9_/.+~-]+$/i', $this->calFBURL)){
$message[]= _("The value specified as Free Busy Information URL is invalid.");
}
$ldap= $this->config->get_ldap_link();
$ldap->cd ($this->config->current['BASE']);
- $ldap->search('(mail='.$address.')');
+ $ldap->search('(mail='.$address.')',array("mail"));
if ($ldap->count() == 0){
$message[]= sprintf(_("There's no mail user with address '%s' for your invitation policy!"), $address);
} else {
{
/* Do we need to flip is_account state? */
if (isset($_POST['connectivityTab'])){
+
+ if(isset($_POST["kolabState"])){
+ $this->is_account = true;
+ }else{
+ $this->is_account = false;
+ }
+
if (chkacl('unrestrictedMailSize', $this->acl == "")){
if (isset($_POST['unrestrictedMailSize']) && $_POST['unrestrictedMailSize'] == 1){
$this->unrestrictedMailSize= 1;
/* Save to LDAP */
function save()
{
+ /* Check mailmethod before doing something useful */
plugin::save();
/* Transfer arrays */
$this->attrs['kolabDelegate']= $this->kolabDelegate;
$this->attrs['kolabInvitationPolicy']= $this->kolabInvitationPolicy;
+ /* unrestrictedMailSize is boolean */
+ if($this->attrs['unrestrictedMailSize']){
+ $this->attrs['unrestrictedMailSize'] = "TRUE";
+ }else{
+ $this->attrs['unrestrictedMailSize'] = "FALSE";
+ }
+
/* Write back to ldap */
$ldap= $this->config->get_ldap_link();
$ldap->cd($this->dn);
- $ldap->modify($this->attrs);
- show_ldap_error($ldap->get_error());
+ $this->cleanup();
+ $ldap->modify ($this->attrs);
+
+ show_ldap_error($ldap->get_error(), sprintf(_("Saving of user/kolab account with dn '%s' failed."),$this->dn));
/* Optionally execute a command after we're done */
if ($this->initially_was_account == $this->is_account){
$this->is_modified= TRUE;
}
+
+ /* Return plugin informations for acl handling */
+ function plInfo()
+ {
+ return (array(
+ "plDescription" => _("Koalb account settings"),
+ "plSelfModify" => TRUE,
+ "plDepends" => array("objectClass" => "gosaAccount"),
+ "kolabFreeBusyFuture" => _("Free busy future"),
+ "unrestrictedMailSize" => _("Mail size restriction"),
+ "calFBURL" => _("Free busy information"),
+ "kolabDelegate" => _("Delegations")));
+ }
}
// vim:tabstop=2:expandtab:shiftwidth=2:filetype=php:syntax:ruler: