diff --git a/branches/old/gosa-plugins/nagios/personal/nagios/class_nagiosAccount.inc b/branches/old/gosa-plugins/nagios/personal/nagios/class_nagiosAccount.inc
--- /dev/null
@@ -0,0 +1,308 @@
+<?php
+
+/*! \brief mail plugin
+ \author Guillame Delecourt <guillaume@opensides.be>
+ \author Benoit Mortier <benoit.mortier@opensides.be>
+ \author Vincent Seynhaeve <vincent@opensides.be>
+ \version 1.00
+ \date 25.09.2005
+
+ This class provides the functionality to read and write all attributes
+ relevant for nagiosAccount from/to the LDAP. It does syntax checking
+ and displays the formulars required.
+ */
+
+class nagiosAccount extends plugin
+{
+ /* Definitions */
+ var $plHeadline= "Nagios";
+ var $plDescription= "This does something";
+
+ /* plugin specific values */
+ var $NagiosAlias = "";
+ var $NagiosPager = "";
+ var $NagiosMail = "";
+
+ var $HostNotificationOptions = "";
+ var $HostNotificationPeriod = "";
+ var $ServiceNotificationPeriod = "";
+ var $ServiceNotitificationPeriod = "";
+ var $HostNotificationCommands = "";
+ var $ServiceNotificationCommands = "";
+ var $HostNotitificationOptions = "";
+ var $ServiceNotificationOptions = "";
+
+ var $AuthorizedAllHosts = "unchecked";
+ var $AuthorizedAllServices = "unchecked";
+ var $AuthorizedSystemCommands = "unchecked";
+ var $AuthorizedAllHostCommands = "unchecked";
+ var $AuthorizedAllServiceCommands = "unchecked";
+ var $AuthorizedConfigurationInformation = "unchecked";
+ var $AuthorizedSystemInformation = "unchecked";
+
+ /* attribute list for save action */
+
+ var $attributes= array("NagiosAlias", "NagiosPager", "NagiosMail", "HostNotificationPeriod",
+ "ServiceNotificationPeriod", "HostNotificationCommands", "ServiceNotificationCommands",
+ "HostNotificationOptions", "ServiceNotificationOptions", "AuthorizedAllHosts", "AuthorizedAllServices",
+ "AuthorizedSystemCommands", "AuthorizedAllHostCommands", "AuthorizedAllServiceCommands",
+ "AuthorizedConfigurationInformation", "AuthorizedSystemInformation");
+
+ var $is_chk_box = array("AuthorizedAllHosts","AuthorizedAllServices","AuthorizedSystemCommands",
+ "AuthorizedAllHostCommands","AuthorizedAllServiceCommands",
+ "AuthorizedConfigurationInformation","AuthorizedSystemInformation");
+
+ var $objectclasses= array("nagiosContact","nagiosAuth");
+
+ var $uid = "";
+ var $view_logged = FALSE;
+
+ /* constructor, if 'dn' is set, the node loads the given
+ 'dn' from LDAP */
+ function nagiosAccount (&$config, $dn= NULL)
+ {
+ /* Configuration is fine, allways */
+ $this->config= $config;
+
+ plugin::plugin ($config, $dn);
+
+ /* Setting uid to default */
+ if(isset($this->attrs['uid'][0])){
+ $this->uid = $this->attrs['uid'][0];
+ }
+
+ /* Save initial account state */
+ $this->initially_was_account= $this->is_account;
+ }
+
+ function execute()
+ {
+ /* Call parent execute */
+ plugin::execute();
+
+ /* Log view */
+ if($this->is_account && !$this->view_logged){
+ $this->view_logged = TRUE;
+ new log("view","users/".get_class($this),$this->dn);
+ }
+
+ /* Load templating engine */
+ $smarty= get_smarty();
+ $display= "";
+
+ /* Do we need to flip is_account state? */
+ if(isset($_POST['modify_state'])){
+ if($this->is_account && $this->acl_is_removeable()){
+ $this->is_account= FALSE;
+ }elseif(!$this->is_account && $this->acl_is_createable()){
+ $this->is_account= TRUE;
+ }
+ }
+
+ /* Do we represent a valid account? */
+ if (!$this->is_account && $this->parent === NULL){
+ $display= "<img alt=\"\"src=\"images/small-error.png\" align=\"middle\"> <b>".
+ msgPool::noValidextension(_("Nagios"))."</b>";
+
+ $display.= back_to_main();
+ return ($display);
+ }
+
+ /* Show tab dialog headers */
+ if ($this->parent !== NULL){
+ if ($this->is_account){
+ $display= $this->show_disable_header(msgPool::removeFeaturesButton(_("Nagios")), msgPool::featuresEnabled(_("Nagios")));
+ } else {
+ $display= $this->show_enable_header(msgPool::addFeaturesButton(_("Nagios")), msgPool::featuresDisabled(_("Nagios")));
+ return($display);
+ }
+ }
+
+ /* Assign acls */
+ $tmp = $this->plInfo();
+ $SkipWrite = (!isset($this->parent) || !$this->parent) && !session::is_set('edit');
+ foreach($tmp['plProvidedAcls'] as $acl => $desc){
+ $smarty->assign($acl."ACL",$this->getacl($acl,$SkipWrite));
+ }
+
+ /* Assign attributes an ACL to smarty */
+ foreach($this->attributes as $val) {
+ $smarty->assign("$val", $this->$val);
+ if(in_array($val,$this->is_chk_box)){
+ if($this->$val == "checked"){
+ $smarty->assign($val."CHK", " checked ");
+ }else{
+ $smarty->assign($val."CHK", "");
+ }
+ }
+ }
+ $smarty->assign('ServiceNotificationOptionsValues' ,array("d,u,r,v"=>"d,u,r,v" ,"d,u,r"=>"d,u,r" ,"d,u"=>"d,u"));
+ $smarty->assign('HostNotificationOptionsValues' ,array("w,u,c,r"=>"w,u,c,r" ,"w,u,c"=>"w,u,c" ,"c,w"=>"c,w"));
+ $smarty->assign('ServiceNotificationPeriodValues' ,array("24x7"=>"24x7" ,"24x5"=>"24x5" ,"8x5"=>"8x5"));
+ $smarty->assign('HostNotificationPeriodValues' ,array("24x7"=>"24x7" ,"24x5"=>"24x5" ,"8x5"=>"8x5"));
+ $display.= $smarty->fetch (get_template_path('nagios.tpl', TRUE, dirname(__FILE__)));
+ return ($display);
+ }
+
+ /* Save to LDAP */
+ function save()
+ {
+ $ldap= $this->config->get_ldap_link();
+
+ /* Call parents save to prepare $this->attrs */
+ plugin::save();
+
+ /* Adapt attributes if needed */
+ //$method= new $this->method($this->config);
+ //$id= $method->uattrib;
+ //$method->fixAttributesOnStore($this);
+
+ /* Write back to ldap */
+ $ldap->cd($this->dn);
+ $this->cleanup();
+ $ldap->modify ($this->attrs);
+
+ /* Log last action */
+ if($this->initially_was_account){
+ new log("modify","users/".get_class($this),$this->dn,array_keys($this->attrs),$ldap->get_error());
+ }else{
+ new log("create","users/".get_class($this),$this->dn,array_keys($this->attrs),$ldap->get_error());
+ }
+
+ if (!$ldap->success()){
+ msg_dialog::display(_("LDAP error"), msgPool::ldaperror($ldap->get_error(), $this->dn, 0, get_class()));
+ }
+
+ /* Optionally execute a command after we're done */
+ if ($this->initially_was_account == $this->is_account){
+ if ($this->is_modified){
+ $this->handle_post_events("modify",array("uid" => $this->uid));
+ }
+ } else {
+ $this->handle_post_events("add", array("uid" => $this->uid));
+ }
+ }
+
+ function check()
+ {
+ /* Call common method to give check the hook */
+ $message= plugin::check();
+
+ $ldap= $this->config->get_ldap_link();
+ /* must: mail */
+ if ($this->NagiosAlias == ""){
+ $message[]= msgPool::required(_("Alias"));
+ }
+ if ($this->NagiosMail == ""){
+ $message[]= msgPool::required(_("Mail"));
+ }
+ if ($this->is_template){
+ if (!tests::is_email($this->NagiosMail, TRUE)){
+ $message[]= msgPool::invalid(_("Mail"),"","","%givenName.%dn@your-domain.com");
+ }
+ } else {
+ if (!tests::is_email($this->NagiosMail)){
+ $message[]= msgPool::invalid(_("Mail"),"","","your-domain@your-domain.com");
+ }
+ }
+ return($message);
+ }
+
+
+ /* Use Save_object for every Post handling */
+ function save_object()
+ {
+ if (isset($_POST['nagiosTab'])){
+ /* Save ldap attributes */
+ plugin::save_object();
+
+ /* Specialhandling for checkboxes */
+ foreach($this->is_chk_box as $val){
+ if($this->acl_is_writeable($val)){
+ if(isset($_POST[$val])){
+ $this->$val = "checked";
+ }else{
+ $this->$val = "unchecked";
+ }
+ }
+ }
+ }
+ }
+
+ function remove_from_parent()
+ {
+ /* Cancel if there's nothing to do here */
+ if (!$this->initially_was_account){
+ return;
+ }
+
+ /* include global link_info */
+ $ldap= $this->config->get_ldap_link();
+
+ /* Remove and write to LDAP */
+ plugin::remove_from_parent();
+
+ /* Adapt attributes if needed */
+ // $method= new $this->method($this->config);
+ // $method->fixAttributesOnRemove($this);
+
+ @DEBUG (DEBUG_LDAP, __LINE__, __FUNCTION__, __FILE__,
+ $this->attributes, "Save");
+ $ldap->cd($this->dn);
+ $this->cleanup();
+ $ldap->modify ($this->attrs);
+
+ new log("view","users/".get_class($this),$this->dn,array_keys($this->attrs),$ldap->get_error());
+
+ if (!$ldap->success()){
+ msg_dialog::display(_("LDAP error"), msgPool::ldaperror($ldap->get_error(), $this->dn, LDAP_MOD, get_class()));
+ }
+
+ /* remove the entry from LDAP */
+ unset ($this->attrs['uid']);
+
+ /* Optionally execute a command after we're done */
+ $this->handle_post_events('remove',array("uid" => $this->uid));
+ }
+
+
+
+ static function plInfo()
+ {
+ return (array(
+ "plShortName" => _("Nagios"),
+ "plDescription" => _("Nagios account settings"),
+ "plSelfModify" => TRUE,
+ "plDepends" => array("user"),
+ "plPriority" => 8, // Position in tabs
+ "plSection" => array("personal" => _("My account")),
+ "plCategory" => array("users"),
+ "plOptions" => array(),
+
+ "plProvidedAcls" => array(
+
+ "NagiosAlias" => _("Alias"),
+ "NagiosMail" => _("Mail address"),
+ "HostNotificationPeriod" => _("Host notification period"),
+ "ServiceNotificationPeriod" => _("Service notification period"),
+ "HostNotificationOptions" => _("Host notification options"),
+ "ServiceNotificationOptions" => _("Service notification options"),
+ "NagiosPager" => _("Pager number"),
+
+ "ServiceNotificationCommands" => _("Service notification commands"),
+ "HostNotificationCommands" => _("Host notification commands"),
+ "AuthorizedSystemInformation" => _("View system informations"),
+ "AuthorizedConfigurationInformation"=> _("View configuration information"),
+ "AuthorizedSystemCommands" => _("Trigger system commands"),
+ "AuthorizedAllServices" => _("View all services"),
+ "AuthorizedAllHosts" => _("View all hosts"),
+ "AuthorizedAllServiceCommands" => _("Trigger all service commands"),
+ "AuthorizedAllHostCommands" => _("Trigger all host commands"))
+
+ ));
+ }
+}
+
+// vim:tabstop=2:expandtab:shiftwidth=2:filetype=php:syntax:ruler:
+
+?>