index bf160a091d3b52a248cfef9e45a569eaaf1f59cf..1e60f7d9a6cdcbcaf2682ef99c0f8d7ff1dc44e2 100644 (file)
-<?php class servkolab extends plugin {
- /* CLI vars */
- var $cli_summary = "Manage server basic objects";
- var $cli_description = "Some longer text\nfor help";
- var $cli_parameters = array("eins"=>"Eins ist toll", "zwei"=>"Zwei ist noch besser");
+<?php
+class servkolab extends plugin {
var $postfix_mydomain = "";
var $postfix_mydestination = "";
- var $postfix_mynetworks = "";
- var $postfix_enable_virus_scan = "";
- var $cyrus_autocreatequota = "";
- var $cyrus_quotawarn = "";
var $cyrus_admins = "";
- var $cyrus_imap = "";
- var $cyrus_pop3 = "";
- var $cyrus_imaps = "";
- var $cyrus_pop3s = "";
- var $cyrus_sieve = "";
- var $apache_allow_unauthenticated_fb = "";
- var $proftpd_ftp = "";
- var $apache_http = "";
- var $kolabHost = array("");
-
- var $attributes = array("postfix_mydomain", "postfix_mydestination",
- "postfix_mynetworks", "postfix_enable_virus_scan",
- "cyrus_autocreatequota", "cyrus_admins", "cyrus_imap",
- "cyrus_pop3", "cyrus_imaps", "cyrus_pop3s", "cyrus_sieve",
- "apache_allow_unauthenticated_fb", "proftpd_ftp",
- "apache_http", "cyrus_quotawarn", "kolabHost");
-
+ var $postfix_mynetworks = "127.0.0.1/8";
+ var $postfix_enable_virus_scan = "TRUE";
+ var $postfix_relayhost = "";
+ var $postfix_mxrelayenabled = true;
+ var $postfix_allow_unauthenticated = "FALSE";
+ var $cyrus_quotawarn = "80";
+ var $kolabFreeBusyFuture = "1";
+ var $k = "kolab";
+ var $cyrus_imap = "TRUE";
+ var $cyrus_pop3 = "FALSE";
+ var $cyrus_imaps = "TRUE";
+ var $cyrus_pop3s = "TRUE";
+ var $cyrus_sieve = "TRUE";
+ var $apache_allow_unauthenticated_fb = "TRUE";
+ var $proftpd_ftp = "FALSE";
+ var $apache_http = "TRUE";
+ var $kolabHost = array();
+ var $orig_cn = "";
+
+ var $attributes = array("postfix_mydomain", "postfix_mydestination", "proftpd_ftp", "k",
+ "postfix_mynetworks", "postfix_enable_virus_scan", "postfix_relayhost", "apache_http",
+ "postfix_allow_unauthenticated", "cyrus_admins", "cyrus_imap","kolabFreeBusyFuture",
+ "cyrus_pop3", "cyrus_imaps", "cyrus_pop3s", "cyrus_sieve", "apache_allow_unauthenticated_fb",
+ "cyrus_quotawarn");
var $objectclasses = array("top", "kolab");
- function servkolab($config, $dn = NULL)
+ function servkolab($config, $dn = NULL, $parent= NULL)
{
- echo "DN korrigieren<br>";
- $this->dn = "k=kolab,".$config->current['BASE'];
-
+ /* Setting the hostname and tell this Plugin that we are the kolab extension*/
+ $this->hostname = preg_replace('/^cn=([^,]+),.*$/', '\1', $dn);
+ $this->dn = "k=kolab,".$config->current['BASE'];
+
+ /* Load variables, if given*/
plugin::plugin($config, $this->dn);
- $this->dn = $dn;
/* Copy needed attributes */
foreach($this->attributes as $val) {
$this->$val = $this->attrs["$name"][0];
}
}
- }
+ /* Toggle relayhost */
+ $this->postfix_mxrelayenabled = preg_match('/^\[/', $this->postfix_relayhost);
+ $this->postfix_relayhost = preg_replace("/[\[\]]/","",$this->postfix_relayhost);
-
-
- /* If the Button remove Kolab extension is clicked, this will be called */
- function RemoveAccount()
- {
-
- gosa_log("Remove function");
-
- $ldap = $this->config->get_ldap_link();
- $ldap->cd($this->dn);
-
- if ($ldap->dn_exists($this->dn)) {
- $ldap->rmdir($this->dn);
- show_ldap_error($ldap->get_error());
+ /* Is this Server a member of the Kolab extension or not ?*/
+ if(isset($this->attrs['kolabHost'])) {
+ $this->kolabHost= $this->attrs['kolabHost'];
+ unset($this->kolabHost['count']);
}
- }
-
-
+ $this->is_account = false;
+ $this->initially_was_account = false;
+ foreach($this->kolabHost as $host){
+ if($this->hostname == $host){
+ $this->is_account = true;
+ $this->initially_was_account = true;
+ }
+ }
+ }
- /* this fucntion generates all needed attributes to start a new kolab extension */
- function AddAccount()
+ function execute()
{
+ /* Call parent execute */
+ plugin::execute();
- /* get the Ldap link, to test if there is an obeject with the same dn */
- $ldap = $this->config->get_ldap_link();
+ /***************
+ Variable initialisation
+ ***************/
- gosa_log("Add function");
-
- /* test */
- if (!$ldap->dn_exists($this->dn)) {
- /* Object Classes */
- $str['objectClass'][] = "top";
- $str['objectClass'][] = "kolab";
-
- /* specific kolab attribute */
- $str['k'][] = "kolab";
-
- /* Postfix default values */
- $str['postfix-mydomain'][] = "gonicus.de";
- $str['postfix-mydestination'][] = "\$mydomain";
- $str['postfix-mynetworks'][] = "127.0.0.0/8";
- $str['postfix-enable-virus-scan'][] = "TRUE";
-
- /* Cyrus Attributes */
- $str['cyrus-autocreatequota'][] = "100000";
- $str['cyrus-quotawarn'][] = "80";
- $str['cyrus-admins'][] = "manager";
- $str['cyrus-imap'][] = "TRUE";
- $str['cyrus-pop3'][] = "FALSE";
- $str['cyrus-imaps'][] = "FALSE";
- $str['cyrus-pop3s'][] = "FALSE";
- $str['cyrus-sieve'][] = "FALSE";
-
- /* */
- $str['apache-allow-unauthenticated-fb'][] = "FALSE";
- $str['proftpd-ftp'][] = "FALSE";
- $str['uid'][] = "freebusy";
- $str['userPassword'][] = "ZnJlZWJ1c3k";
- $str['apache-http'][] = "TRUE";
-
-
- /* Set Attributes */
- $ldap->cd($this->dn);
- $this->attrs = $str;
+ $smarty = get_smarty();
+ $display = "";
+ $ldap = $this->config->get_ldap_link();
- /* Copy needed attributes */
- foreach($this->attributes as $val) {
- $name = preg_replace('/_/', '-', $val);
- if (isset($this->attrs["$name"][0])) {
- $this->$val = $this->attrs["$name"][0];
- }
- }
-
- }
+ /* Assemble free/busy string */
+ $edit = sprintf('<input name="kolabFreeBusyFuture" value="%s" %s type="text" maxlength="3" size="4">',
+ $this->kolabFreeBusyFuture,
+ chkacl($this->acl, 'kolabFreeBusyFuture'));
+ $fbfuture = sprintf(_("Include data from %s days in the past when creating free/busy lists"), $edit);
- }
+ /* Assemble quota string */
+ $edit = sprintf('<input name="cyrus_quotawarn" value="%s" type="text" maxlength="3" size="4" %s>',
+ $this->cyrus_quotawarn,
+ chkacl($this->acl, 'cyrus_quotawarn'));
+ $quotastr = sprintf(_("Warn users when using more than %s%% of their mail quota"), $edit);
- function execute()
- {
- /* Fill templating stuff */
- $smarty = get_smarty();
- $display = "";
-
- /* Tell the script the dn, we are using */
- $this->dn = "k=kolab,".$this->config->current['BASE'];
-
- $ldap = $this->config->get_ldap_link();
-
+ /***************
+ Handle Account is_account state
+ ***************/
+
/* Do we need to flip is_account state? */
if (isset($_POST['modify_state'])) {
$this->is_account = !$this->is_account;
- if($this->is_account)
- $this->AddAccount();
- else
- $this->RemoveAccount();
-
-
}
/* Show tab dialog headers */
return ($display);
}
- /* There a new Host submitted */
- if (isset($_POST['NewHost'])) {
- $this->attrs['kolabHost'][] = $_POST['NewkolabHost'];
- gosa_log("Adding Host");
- }
-
- /* We need to delete a Host */
- if (isset($_POST['DelHost'])) {
- foreach($this->attrs['kolabHost'] as $key => $host) {
- if ($host == $_POST['kolabHost'])
- unset($this->attrs['kolabHost'][$key]);
- }
- gosa_log("Removing Host".$this->attrs['kolabHost'][$key]);
- }
+ /***************
+ Assign informations to smarty
+ ***************/
+ /* Set relayhost and if we have MX lookup enabled*/
+ if($this->postfix_mxrelayenabled) {
+ $smarty->assign("RelayMxSupportCheck"," checked ");
+ } else {
+ $smarty->assign("RelayMxSupportCheck","");
+ }
/* Initialize all attributes, that were submitted */
- foreach($this->attributes as $val) {
- /* If theres a button pressed, we need to check all attributes */
- if ((isset($_POST['NewHost'])) || (isset($_POST['DelHost']))) {
- /* Set var to value or to zero */
- if (isset($_POST[$val])) {
+ foreach($this->attributes as $val)
+ {
+ $smarty->assign($val."ACL",chkacl($this->acl,str_replace("_","-",$val)));
- $this->$val = $_POST[$val];
- } else {
- $this->$val = 0;
- }
- }
/* Tell smarty which variables we are useing */
$smarty->assign($val, $this->$val);
- if (($this->$val != "FALSE") && (!empty($this->$val)))
+ if (($this->$val != "FALSE") && !empty($this->$val)){
$smarty->assign($val."Check", "checked");
-
- }
-
- /* If there are some Host submitted, tell it smarty */
- $this->kolabHost = array();
- if (isset($this->attrs['kolabHost'])) {
- $this->kolabHost = $this->attrs['kolabHost'];
- unset($this->kolabHost['count']);
+ } else {
+ $smarty->assign($val."Check", "");
+ }
}
- $smarty->assign("kolabHost", $this->kolabHost);
+ $smarty->assign("fbfuture", $fbfuture);
+ $smarty->assign("quotastr", $quotastr);
/* Load Template */
$display.=$smarty->fetch(get_template_path('servkolab.tpl', TRUE));
-
- print_a($this);
-
return ($display);
}
function remove_from_parent()
{
+ /* Only walk through following code, if this host
+ was a member of the kolab hosts, else skip this */
+ if(!$this->initially_was_account){
+ return;
+ }
+
+ /* !!! Don't use "cn" in this function
+ hostname -> the initial name of the host
+ cn -> is the new name of the host, in case that it was renamed.
+ */
+
+ $ldap = $this->config->get_ldap_link();
+ $this->dn = "k=kolab,".$this->config->current['BASE'];
+
+ /* We can't simply remove the whole entry, it is possible that there are
+ some other hosts assigned to this object.
+ So, first of all check if we are the last host entry within the host
+ : Remove k=kolab entry
+ if we aren't alone, only remove host name from hosts entry and save */
+ /* Are we alone? Remove complete entry... */
+
+ /* Check if we are definitly in kolabHosts */
+ if(!in_array_ics($this->hostname,$this->kolabHost)) {
+ return;
+ }
+
+ /* Integration check, not translated because they can't pop up at all, only for debug */
+ if(count($this->kolabHost) == 0){
+ print_red("Server - Kolab tab : This is not possible, we can't remove an account which doesn't exists.");
+ return;
+ }
+ if(!isset($this->hostname) || (empty($this->hostname))){
+ print_red("The required attribute hostname seams to empty.");
+ }
+
+ /* Our hostname is in kolabHosts and there is a only one entry
+ = we are the last host entry, delete k=kolab entry */
+ if (count($this->kolabHost) == 1){
+
+ /* Remove complete entry */
+ $ldap->rmdir ($this->dn);
+ show_ldap_error($ldap->get_error(), _("Removing kolab host entry failed"));
+ gosa_log("k=kolab entry removed, ".$this->hostname." was the last kolabHost entry.");
+
+ } else {
+
+ /* Only modify kolabHost */
+ $hosts= array();
+ foreach ($this->kolabHost as $host){
+ if($host != $this->hostname){
+ $hosts[]= $host;
+ }
+ }
+ $attrs= array('kolabHost' => $hosts);
+ $ldap->cd($this->dn);
+ $this->cleanup();
+ $ldap->modify ($attrs);
+ show_ldap_error($ldap->get_error(), _("Removing server from kolab object failed"));
+ gosa_log("Removing ".$this->hostname." from list of kolabHosts");
+ }
+
+ /* Optionally execute a command after we're done */
+ $this->handle_post_events("remove");
}
function save_object()
{
- plugin::save_object();
+ if (isset($_POST['kolabtab'])){
+ plugin::save_object();
+
+ /* Save checkboxes */
+ foreach (array( "postfix_enable_virus_scan", "postfix_allow_unauthenticated",
+ "cyrus_imap", "cyrus_pop3", "cyrus_imaps",
+ "cyrus_pop3s", "cyrus_sieve", "apache_allow_unauthenticated_fb",
+ "proftpd_ftp", "apache_http") as $cb){
+ if (isset($_POST[$cb])){
+ $this->$cb= "TRUE";
+ } else {
+ $this->$cb= "FALSE";
+ }
+ }
+
+ /* Toggle relay check */
+ $this->postfix_mxrelayenabled= isset($_POST['RelayMxSupport']);
+ }
+
}
function check()
{
- $message = array();
+ /* Call common method to give check the hook */
+ $message= plugin::check();
+ if(($this->kolabFreeBusyFuture=="")) {
+ $message[] = _("Future days in Free/Busy settings must be set.");
+ }elseif(!is_uid($this->kolabFreeBusyFuture) || $this->kolabFreeBusyFuture < 0){
+ $message[] = _("Future days in Free/Busy settings must be a positive value.");
+ }
if(!is_int((int)($this->cyrus_quotawarn))) {
- $message[] = "The given Quota settings value must be a number";
- }elseif(!(($this->cyrus_quotawarn<=100)&&($this->cyrus_quotawarn>=1))){
- $message[] = "Please choose a value between 1 and 100 for Quota settings";
+ $message[] = _("The given Quota settings value must be a number.");
+ }elseif(!(($this->cyrus_quotawarn<=100)&&($this->cyrus_quotawarn>=0))){
+ $message[] = _("Please choose a value between 1 and 100 for Quota settings.");
+ }elseif(strcasecmp($this->cyrus_quotawarn,(int)$this->cyrus_quotawarn)){
+ $message[] = _("Future days must be a value.");
}
-
- /* You will need a least one entry to save this settings */
- if (count($this->kolabHost) == 0) {
- $message[] =
- "You will need at least one Entry in Hosts. If You want to 'Remove' Kolab extension please use the \"Remove Kolab extension\" Button to remove Kolab ";
+ if(empty($this->postfix_mynetworks)) {
+ $message[] = _("No SMTP privileged networks set.");
}
+
+ /*if(empty($this->postfix_relayhost)) {
+ $message[] = _("No SMTP smarthost/relayhost set.");
+ }
+ */
+
return ($message);
}
function save()
{
/* Set ldap connection */
- $ldap = $this->config->get_ldap_link();
- $ldap->cd($this->dn);
+ $ldap = $this->config->get_ldap_link();
- /* Setup Attributes to save */
- $newattrs = array();
+ /* Open current dn*/
+ $this->dn = "k=kolab,".$this->config->current['BASE'];
- /* Set vars with correct - _ - */
- foreach($this->attributes as $key) {
- $key2 = str_replace("_", "-", $key);
- $newattrs[$key2] = $this->$key;
+ /* Adapt relayhost */
+ $this->postfix_relayhost= preg_replace('/[\[\]]/', '', $this->postfix_relayhost);
+ if (!$this->postfix_mxrelayenabled && $this->postfix_relayhost != ""){
+ $this->postfix_relayhost= "[".$this->postfix_relayhost."]";
}
- /* Set bool vars */
- if ($newattrs['postfix-enable-virus-scan'] == 0)
- $newattrs['postfix-enable-virus-scan'] = "FALSE";
- else
- $newattrs['postfix-enable-virus-scan'] = "TRUE";
- if ($newattrs['cyrus-imap'] == 0)
- $newattrs['cyrus-imap'] = "FALSE";
- else
- $newattrs['cyrus-imap'] = "TRUE";
- if ($newattrs['cyrus-imaps'] == 0)
- $newattrs['cyrus-imaps'] = "FALSE";
- else
- $newattrs['cyrus-imaps'] = "TRUE";
- if ($newattrs['cyrus-pop3'] == 0)
- $newattrs['cyrus-pop3'] = "FALSE";
- else
- $newattrs['cyrus-pop3'] = "TRUE";
- if ($newattrs['cyrus-pop3s'] == 0)
- $newattrs['cyrus-pop3s'] = "FALSE";
- else
- $newattrs['cyrus-pop3s'] = "TRUE";
- if ($newattrs['cyrus-sieve'] == 0)
- $newattrs['cyrus-sieve'] = "FALSE";
- else
- $newattrs['cyrus-sieve'] = "TRUE";
- if ($newattrs['proftpd-ftp'] == 0)
- $newattrs['proftpd-ftp'] = "FALSE";
- else
- $newattrs['proftpd-ftp'] = "TRUE";
- if ($newattrs['apache-http'] == 0)
- $newattrs['apache-http'] = "FALSE";
- else
- $newattrs['apache-http'] = "TRUE";
- if ($newattrs['apache-allow-unauthenticated-fb'] == 0)
- $newattrs['apache-allow-unauthenticated-fb'] = "FALSE";
- else
- $newattrs['apache-allow-unauthenticated-fb'] = "TRUE";
-
-
- /* Reorder Host array, to get constant increasing index */
- $newattrs['kolabHost'] = array();
- foreach($this->attrs['kolabHost'] as $key=>$val) {
- if (is_int($key)) {
- $newattrs['kolabHost'][] = $val;
+ /* Check if this server was renamed, in this case we have to remove old cn first*/
+ if($this->hostname != $this->cn){
+ $tmp = array();
+ if(in_array_ics($this->hostname,$this->kolabHost)){
+ foreach($this->kolabHost as $host){
+ if($host != $this->hostname){
+ $tmp[] = $host;
+ }
+ }
+ $this->kolabHost = $tmp;
}
}
- /* Save as following object ! */
- $this->dn = "k=kolab,".$this->config->current['BASE'];
+ /* Add ourselves to the list of kolabHost's if needed */
+ if (!in_array_ics($this->cn,$this->kolabHost)){
+ $this->kolabHost[]= $this->cn;
+ }
- /* If we already have an object like this one,
- we only need to modify the entry
- */
- if ($ldap->dn_exists($this->dn)) {
- gosa_log("Modifying");
- $ldap->cd($this->dn);
- $ldap->modify($newattrs);
+ /* Call parents save to prepare $this->attrs */
+ plugin::save();
+
+ /* Save or modify? */
+ $ldap->cat($this->dn, array('dn'));
+ if (!$ldap->fetch()){
+ $mode= "add";
} else {
- /* We must create a new Entry */
- gosa_log("Adding");
- $newattrs['k'] = "kolab";
- $newattrs['uid'] = "freebusy";
- $newattrs['postfix-mydomain'] = "gonicus.de";
- $newattrs['postfix-mydestination'] = "\$mydomain";
- $newattrs['userPassword'] = "tester";
- $newattrs['objectClass'] = $this->objectclasses;
- $ldap->cd($this->dn);
- $ldap->add($newattrs);
+ $mode= "modify";
}
- /* show any errors */
- show_ldap_error($ldap->get_error());
+ /* Do attribute conversion */
+ foreach ($this->attrs as $key => $value){
+ if (preg_match('/_/', $key)){
+ $old_key= $key;
+ $key= preg_replace('/_/', '-', $key);
+ $this->attrs[$key]= $value;
+ unset($this->attrs[$old_key]);
+ }
+ }
+ /* Add kolab hosts */
+ $this->attrs['kolabHost']= $this->kolabHost;
+
+ /* Perform LDAP action */
+ $ldap->cd($this->dn);
+ $this->cleanup();;
+ $ldap->$mode($this->attrs);
+ show_ldap_error($ldap->get_error(), _("Saving server to kolab object failed"));
/* Optionally execute a command after we're done */
if ($this->initially_was_account == $this->is_account) {
if ($this->is_modified) {
- $this->handle_post_events("mofify");
+ $this->handle_post_events("modify");
}
} else {
$this->handle_post_events("add");
}
-
}
-
}
// vim:tabstop=2:expandtab:shiftwidth=2:filetype=php:syntax:ruler: