summary | shortlog | log | commit | commitdiff | tree
raw | patch | inline | side by side (parent: d3c4309)
raw | patch | inline | side by side (parent: d3c4309)
author | hickert <hickert@594d385d-05f5-0310-b6e9-bd551577e9d8> | |
Tue, 2 Nov 2010 08:48:22 +0000 (08:48 +0000) | ||
committer | hickert <hickert@594d385d-05f5-0310-b6e9-bd551577e9d8> | |
Tue, 2 Nov 2010 08:48:22 +0000 (08:48 +0000) |
-Fixed seqfault problems, endless loops within save().
-Added check to prevent selecting a used mailAddress.
git-svn-id: https://oss.gonicus.de/repositories/gosa/trunk@20164 594d385d-05f5-0310-b6e9-bd551577e9d8
-Added check to prevent selecting a used mailAddress.
git-svn-id: https://oss.gonicus.de/repositories/gosa/trunk@20164 594d385d-05f5-0310-b6e9-bd551577e9d8
gosa-plugins/groupware/personal/groupware/class_Groupware.inc | patch | blob | history |
diff --git a/gosa-plugins/groupware/personal/groupware/class_Groupware.inc b/gosa-plugins/groupware/personal/groupware/class_Groupware.inc
index e12df2ad878bb10d98506cdba815294eb53860d2..70325a35c3ee9f106c732c94d67596dbe8d50e43 100644 (file)
$this->initially_was_account = $this->is_account = $status;
if($this->is_account){
$response = $this->groupwareDao->getComprehensiverUser($this->uid);
+ $this->saved_attributes = $response;
$this->mapComprehensiveUserData($response);
}
$this->accountInitialized = TRUE;
if(!tests::is_email ($this->mailAddress)){
$messages[] = msgPool::invalid(_("Mail address"),$this->mailAddress , "", "user@exdom.intranet.gonicus.de knibbel");
}
+
+ // Ensure that the mailAddress isn't used yet.
+ if(!count($messages) && (
+ !$this->initially_was_account ||
+ $this->mailAddress != $this->saved_attributes['primaryMail'])){
+ $exists = $this->rpcExec("gwMailAddressExists", $this->mailAddress);
+ if($this->rpcError){
+ $messages[] = sprintf(_("Failed to validate mail address '%s'."), $this->mailAddress);
+ }elseif($exists){
+ $messages[] = msgPool::duplicated(_("Mail address"));
+ }
+ }
}
- //checks for feature "quotaUsage"
- if ($this->isFeatureEnabled("quotaUsage")){}
-
- //checks for feature "mailLocations"
- if ($this->isFeatureEnabled("mailLocations")){}
-
- //checks for feature "mailFilter"
- if ($this->isFeatureEnabled("mailFilter")){}
- //checks for feature "alternateAddresses"
- if ($this->isFeatureEnabled("alternateAddresses")){}
+# //checks for feature "quotaUsage"
+# if ($this->isFeatureEnabled("quotaUsage")){}
+#
+# //checks for feature "mailLocations"
+# if ($this->isFeatureEnabled("mailLocations")){}
+#
+# //checks for feature "mailFilter"
+# if ($this->isFeatureEnabled("mailFilter")){}
+#
+# //checks for feature "alternateAddresses"
+# if ($this->isFeatureEnabled("alternateAddresses")){}
//checks for feature "forwardingAddresses"
if ($this->isFeatureEnabled("forwardingAddresses")){
}
}
- //checks for feature "mailBoxAutomaticRemoval"
- if ($this->isFeatureEnabled("mailBoxAutomaticRemoval")){}
-
- //checks for feature "localDeliveryOnly"
- if ($this->isFeatureEnabled("localDeliveryOnly")){}
-
- //checks for feature "dropOwnMails"
- if ($this->isFeatureEnabled("dropOwnMails")){}
-
- //checks for feature "mailFolder"
- if ($this->isFeatureEnabled("mailFolder")){}
+# //checks for feature "mailBoxAutomaticRemoval"
+# if ($this->isFeatureEnabled("mailBoxAutomaticRemoval")){}
+#
+# //checks for feature "localDeliveryOnly"
+# if ($this->isFeatureEnabled("localDeliveryOnly")){}
+#
+# //checks for feature "dropOwnMails"
+# if ($this->isFeatureEnabled("dropOwnMails")){}
+#
+# //checks for feature "mailFolder"
+# if ($this->isFeatureEnabled("mailFolder")){}
return($messages);
}
break;
}
}
- $this->save("private_folderACLS", $id, $val["acls"]);
+
+ #FIXME: HAPE:
+ # What the hell is this?
+ # You call save() from save() from save() aso...
+ # Got seqfaults in apache client ...
+ # - $this->save("private_folderACLS", $id, $val["acls"]);
}
}
}