array(), 'conflicts' => array()); // managed object classes $return['objectClasses'] = array('inetLocalMailRecipient'); // managed attributes $return['attributes'] = array('mailLocalAddress', 'mailHost', 'mailRoutingAddress'); // help Entries $return['help'] = array( 'routingAdr' => array( "Headline" => _("Routing address"), "Text" => _("This is the target email address for the user's mails.") ), 'localAdr' => array( "Headline" => _("Local address"), "Text" => _("This is one of the users public email addresses.") ), 'localAdrList' => array( "Headline" => _("Local address list"), "Text" => _("This is a comma separated list of the users public email addresses.") ), 'host' => array( "Headline" => _("Mail server"), "Text" => _("This is the mail server for the user.") )); // profile options $return['profile_options'] = array( array( 0 => array('kind' => 'text', 'text' => _('Mail server') . ":"), 1 => array('kind' => 'input', 'name' => 'inetLocalMailRecipient_host', 'type' => 'text', 'size' => '30', 'maxlength' => '255'), 2 => array('kind' => 'help', 'value' => 'host')) ); // profile checks $return['profile_checks']['inetLocalMailRecipient_host'] = array( 'type' => 'ext_preg', 'regex' => 'DNSname', 'error_message' => $this->messages['host'][0]); // profile mappings $return['profile_mappings'] = array( 'inetLocalMailRecipient_host' => 'mailHost' ); // upload fields $return['upload_columns'] = array( array( 'name' => 'inetLocalMailRecipient_routingAdr', 'description' => _('Routing address'), 'help' => 'routingAdr', 'example' => 'smiller@otherdomain.org' ), array( 'name' => 'inetLocalMailRecipient_localAdr', 'description' => _('Local address list'), 'help' => 'localAdrList', 'example' => 'smiller@yourdomain.org' ), array( 'name' => 'inetLocalMailRecipient_server', 'description' => _('Mail server'), 'help' => 'host', 'example' => 'mail.yourdomain.org' ) ); // available PDF fields $return['PDF_fields'] = array( 'routingAdr', 'localAdr', 'host' ); return $return; } /** * This function fills the error message array with messages */ function load_Messages() { $this->messages['routingAdr'][0] = array('ERROR', 'Routing address is invalid!'); // third array value is set dynamically $this->messages['routingAdr'][1] = array('ERROR', _('Account %s:') . ' inetLocalMailRecipient_routingAdr', 'Routing address is invalid!'); $this->messages['localAdr'][0] = array('ERROR', 'Local address is invalid!'); // third array value is set dynamically $this->messages['localAdr'][1] = array('ERROR', _('Account %s:') . ' inetLocalMailRecipient_localAdr', 'Local address is invalid!'); $this->messages['host'][0] = array('ERROR', 'Mail server is invalid!'); // third array value is set dynamically $this->messages['host'][1] = array('ERROR', _('Account %s:') . ' inetLocalMailRecipient_server', 'Mail server is invalid!'); } /** * This function will create the meta HTML code to show a page with all attributes. * * @param array $post HTTP-POST values */ function display_html_attributes(&$post) { $return = array(); // mail routing address $routingAddress = ''; if (isset($this->attributes['mailRoutingAddress'][0])) $routingAddress = $this->attributes['mailRoutingAddress'][0]; $return[] = array( 0 => array('kind' => 'text', 'text' => _('Routing address')), 1 => array('kind' => 'input', 'name' => 'routingAdr', 'type' => 'text', 'size' => '20', 'value' => $routingAddress), 2 => array('kind' => 'help', 'value' => 'routingAdr')); // mail server $mailServer = ''; if (isset($this->attributes['mailHost'][0])) $mailServer = $this->attributes['mailHost'][0]; $return[] = array( 0 => array('kind' => 'text', 'text' => _('Mail server')), 1 => array('kind' => 'input', 'name' => 'host', 'type' => 'text', 'size' => '20', 'value' => $mailServer), 2 => array('kind' => 'help', 'value' => 'host')); // list current local addresses $localAdresses = array(); if (isset($this->attributes['mailLocalAddress'])) $localAdresses = $this->attributes['mailLocalAddress']; for ($i = 0; $i < sizeof($localAdresses); $i++) { $return[] = array( 0 => array('kind' => 'text', 'text' => _('Local address')), 1 => array('kind' => 'input', 'name' => 'localAdr' . $i, 'type' => 'text', 'size' => '20', 'value' => $localAdresses[$i]), 2 => array('kind' => 'input', 'type' => 'submit', 'name' => 'delAdr' . $i, 'value' => _("Remove")), 3 => array('kind' => 'help', 'value' => 'localAdr')); } // input box for new local addresses $return[] = array( 0 => array('kind' => 'text', 'text' => _('New local address')), 1 => array('kind' => 'input', 'name' => 'localAdr', 'type' => 'text', 'size' => '20', 'value' => ''), 2 => array('kind' => 'input', 'type' => 'submit', 'name' => 'addAdr', 'value' => _("Add")), 3 => array('kind' => 'help', 'value' => 'localAdr'), 4 => array('kind' => 'input', 'type' => 'hidden', 'value' => sizeof($localAdresses), 'name' => 'adr_number')); return $return; } /** * Processes user input of the primary module page. * It checks if all input values are correct and updates the associated LDAP attributes. * * @param array $post HTTP-POST values * @return array list of info/error messages */ function process_attributes(&$post) { $errors = array(); $this->attributes['mailRoutingAddress'] = array(); $this->attributes['mailLocalAddress'] = array(); $this->attributes['mailHost'] = array(); // check routing address if (isset($post['routingAdr']) && ($post['routingAdr'] != "")) { // check if address has correct format if (get_preg($post['routingAdr'], 'email')) { $this->attributes['mailRoutingAddress'][0] = $post['routingAdr']; } else { $message = $this->messages['routingAdr'][0]; $message[] = $post['routingAdr']; $errors[] = array($message); } } // check mail server if (isset($post['host']) && ($post['host'] != "")) { // check if address has correct format if (get_preg($post['host'], 'DNSname')) { $this->attributes['mailHost'][0] = $post['host']; } else { $message = $this->messages['host'][0]; $message[] = $post['host']; $errors[] = array($message); } } // check old local addresses if (isset($post['adr_number'])) { for ($i = 0; $i < $post['adr_number']; $i++) { if (isset($post['delAdr' . $i])) continue; if (isset($post['localAdr' . $i]) && ($post['localAdr' . $i] != "")) { // check if address has correct format if (!get_preg($post['localAdr' . $i], 'mailLocalAddress')) { $message = $this->messages['localAdr'][0]; $message[] = $post['localAdr' . $i]; $errors[] = array($message); } $this->attributes['mailLocalAddress'][] = $post['localAdr' . $i]; } } } // check new local address if (isset($post['localAdr']) && ($post['localAdr'] != "")) { // check if address has correct format if (get_preg($post['localAdr'], 'mailLocalAddress')) { // check if new address is not already in database $data = $_SESSION['cache']->get_cache('mailLocalAddress', 'inetLocalMailRecipient', 'user'); $keys = array_keys($data); for ($i = 0; $i < sizeof($keys); $i++) { $adrList = $data[$keys[$i]]; if (in_array_ignore_case($post['localAdr'], $adrList)) { $errors['localAdr'][] = array('WARN', _('This mail address is already in use:') . " " . $post['localAdr'], $keys[$i]); break; } } $this->attributes['mailLocalAddress'][] = $post['localAdr']; } else { $message = $this->messages['localAdr'][0]; $message[] = $post['localAdr']; $errors[] = array($message); } } $this->attributes['mailLocalAddress'] = array_unique($this->attributes['mailLocalAddress']); return $errors; } /** * In this function the LDAP account is built up. * * @param array $rawAccounts list of hash arrays (name => value) from user input * @param array $partialAccounts list of hash arrays (name => value) which are later added to LDAP * @param array $ids list of IDs for column position (e.g. "posixAccount_uid" => 5) * @return array list of error messages if any */ function build_uploadAccounts($rawAccounts, $ids, &$partialAccounts) { $messages = array(); for ($i = 0; $i < sizeof($rawAccounts); $i++) { // add object class if (!in_array("inetLocalMailRecipient", $partialAccounts[$i]['objectClass'])) $partialAccounts[$i]['objectClass'][] = "inetLocalMailRecipient"; // add local addresses if ($rawAccounts[$i][$ids['inetLocalMailRecipient_localAdr']] != "") { $adrs = explode(',', $rawAccounts[$i][$ids['inetLocalMailRecipient_localAdr']]); // check format for ($a = 0; $a < sizeof($adrs); $a++) { if (get_preg($adrs[$a], 'mailLocalAddress')) { $partialAccounts[$i]['mailLocalAddress'][] = $adrs[$a]; } else { $errMsg = $this->messages['localAdr'][1]; array_push($errMsg, array($i)); $messages[] = $errMsg; } } } // add routing address if ($rawAccounts[$i][$ids['inetLocalMailRecipient_routingAdr']] != "") { // check format if (get_preg($rawAccounts[$i][$ids['inetLocalMailRecipient_routingAdr']], 'email')) { $partialAccounts[$i]['mailRoutingAddress'][] = $rawAccounts[$i][$ids['inetLocalMailRecipient_routingAdr']]; } else { $errMsg = $this->messages['routingAdr'][1]; array_push($errMsg, array($i)); $messages[] = $errMsg; } } // add mail server if ($rawAccounts[$i][$ids['inetLocalMailRecipient_server']] != "") { // check format if (get_preg($rawAccounts[$i][$ids['inetLocalMailRecipient_server']], 'DNSname')) { $partialAccounts[$i]['mailHost'][] = $rawAccounts[$i][$ids['inetLocalMailRecipient_server']]; } else { $errMsg = $this->messages['host'][1]; array_push($errMsg, array($i)); $messages[] = $errMsg; } } } return $messages; } /** * Returns the PDF entries for this module. * * @return array list of possible PDF entries */ function get_pdfEntries() { $return = array(); if (isset($this->attributes['mailRoutingAddress'][0])) { $return['inetLocalMailRecipient_routingAdr'][0] = '' . _('Routing address') . '' . $this->attributes['mailRoutingAddress'][0] . ''; } if (sizeof($this->attributes['mailLocalAddress']) > 0) { $return['inetLocalMailRecipient_localAdr'][0] = '' . _('Local address list') . '' . implode(', ', $this->attributes['mailLocalAddress']) . ''; } if (isset($this->attributes['mailHost'][0])) { $return['inetLocalMailRecipient_host'][0] = '' . _('Mail server') . '' . $this->attributes['mailHost'][0] . ''; } return $return; } } ?>