Code

Added posts to service tabs
[gosa.git] / plugins / admin / systems / class_goLogDBServer.inc
1 <?php
3 class goLogDBServer extends plugin{
4         
5   var $cli_summary      = "This pluign is used within the ServerService Pluign \nand indicates that this server supports asterisk management.";
6   var $cli_description  = "Some longer text\nfor help";
7   var $cli_parameters   = array("eins" => "Eins ist toll", "zwei" => "Zwei ist noch besser");
9   /* This plugin only writes its objectClass */
10   var $objectclasses    = array("goLogDBServer");
11   var $attributes       = array("goLogDBServerStatus","goLogAdmin", "goLogPassword");
12   var $StatusFlag       = "goLogDBServerStatus";
14   /* This class can't be assigned twice so it conflicts with itsself */
15   var $conflicts        = array("goLogDBServer");
17   var $DisplayName      = "";
18   var $dn               = NULL;
19   var $acl;
21   var $goLogDBServerStatus  = "";
22   var $goLogAdmin           = "";
23   var $goLogPassword        = "";  
26   function goLogDBServer($config,$dn)
27   {
28     plugin::plugin($config,$dn);
29     $this->DisplayName = _("Logging database");
30   }
33   function execute()
34   { 
35     $smarty = get_smarty(); 
36     foreach($this->attributes as $attr){
37       $smarty->assign($attr,$this->$attr);
38       $smarty->assign($attr."ACL",chkacl($this->acl,$attr));
39     }
40     return($smarty->fetch(get_template_path("goLogDBServer.tpl",TRUE,dirname(__FILE__))));
41   }
44   function getListEntry()
45   {
46     $flag = $this->StatusFlag;
47     $fields['Status']     = $this->$flag;
48     $fields['Message']    = _("Logging database");
49     $fields['AllowStart'] = true;
50     $fields['AllowStop']  = true;
51     $fields['AllowRestart'] = true;
52     $fields['AllowRemove']= true;
53     $fields['AllowEdit']  = true;
54     return($fields);
55   }
58   function remove_from_parent()
59   {
60     plugin::remove_from_parent();
61     /* Check if this is a new entry ... add/modify */
62     $ldap = $this->config->get_ldap_link();
63     $ldap->cat($this->dn,array("objectClass"));
64     if($ldap->count()){
65       $ldap->cd($this->dn);
66       $ldap->modify($this->attrs);
67     }else{
68       $ldap->cd($this->dn);
69       $ldap->add($this->attrs);
70     }
71     show_ldap_error($ldap->get_error());
72     $this->handle_post_events("remove");
73   }
76   function save()
77   {
78     plugin::save();
79     /* Check if this is a new entry ... add/modify */
80     $ldap = $this->config->get_ldap_link();
81     $ldap->cat($this->dn,array("objectClass"));
82     if($ldap->count()){
83       $ldap->cd($this->dn);
84       $ldap->modify($this->attrs);
85     }else{
86       $ldap->cd($this->dn);
87       $ldap->add($this->attrs);
88     }
89     show_ldap_error($ldap->get_error());
90     if($this->initially_was_account){
91       $this->handle_post_events("modify");
92     }else{
93       $this->handle_post_events("add");
94     }
95   }
98   /* Directly save new status flag */
99   function setStatus($value)
100   {
101     if($value == "none") return;
102     if(!$this->initially_was_account) return;
103     $ldap = $this->config->get_ldap_link();
104     $ldap->cd($this->dn);
105     $ldap->cat($this->dn,array("objectClass"));
106     if($ldap->count()){
108       $tmp = $ldap->fetch();
109       for($i = 0; $i < $tmp['objectClass']['count']; $i ++){
110         $attrs['objectClass'][] = $tmp['objectClass'][$i];
111       }
112       $flag = $this->StatusFlag;
113       $attrs[$flag] = $value;
114       $this->$flag = $value;
115       $ldap->modify($attrs);
116       show_ldap_error($ldap->get_error());
117       $this->action_hook();
118     }
119   }
122   function check()
123   { 
124     $message = plugin::check();
125     if (empty($this->goLogAdmin)){
126       $message[]= sprintf_("The attribute user is empty or contains invalid characters.");
127     }
128     if (empty($this->goLogPassword)){
129       $message[]= sprintf_("The attribute password is empty or contains invalid characters.");
130     }
131     return($message);
132   }
135   function save_object()
136   {
137     if(isset($_POST['goLogDBServerPosted'])){
138       plugin::save_object();
139     }
140   } 
142   function action_hook($add_attrs= array())
143   {
144     /* Find postcreate entries for this class */
145     $command= search_config($this->config->data['MENU'], get_class($this), "ACTION_HOOK");
146     if ($command == "" && isset($this->config->data['TABS'])){
147       $command= search_config($this->config->data['TABS'], get_class($this), "ACTION_HOOK");
148     }
149     if ($command != ""){
150       /* Walk through attribute list */
151       foreach ($this->attributes as $attr){
152         if (!is_array($this->$attr)){
153           $command= preg_replace("/%$attr/", $this->$attr, $command);
154         }
155       }
156       $command= preg_replace("/%dn/", $this->dn, $command);
157       /* Additional attributes */
158       foreach ($add_attrs as $name => $value){
159         $command= preg_replace("/%$name/", $value, $command);
160       }
161       if (check_command($command)){
162         @DEBUG (DEBUG_SHELL, __LINE__, __FUNCTION__, __FILE__,
163             $command, "Execute");
165         exec($command);
166       } else {
167         $message= sprintf(_("Command '%s', specified as ACTION_HOOK for plugin '%s' doesn't seem to exist."), $command, get_class($this));
168         print_red ($message);
169       }
170     }
171   }
174 // vim:tabstop=2:expandtab:shiftwidth=2:filetype=php:syntax:ruler:
175 ?>