Code

Fixed magic_quotes_gpc escaping in faiTemplate faiTemplateEntry faiScript faiScriptEntry
[gosa.git] / plugins / admin / fai / class_faiScript.inc
1 <?php
3 class faiScript extends plugin
4 {
5   /* CLI vars */
6   var $cli_summary      = "Manage server basic objects";
7   var $cli_description  = "Some longer text\nfor help";
8   var $cli_parameters   = array("eins" => "Eins ist toll", "zwei" => "Zwei ist noch besser");
10   /* attribute list for save action */
11   var $ignore_account   = TRUE;
13   /* Attributes for this Object */
14   var $attributes       = array("cn","description");
16   /* ObjectClasses for this Object*/
17   var $objectclasses    = array("top","FAIclass","FAIscript");
19   /* Class name of the Ldap ObjectClass for the Sub Object */
20   var $subClass         = "FAIscriptEntry";
21   var $subClasses       = array("top","FAIclass","FAIscriptEntry");
23   /* Class name of the php class which allows us to edit a Sub Object */
24   var $subClassName     = "faiScriptEntry";      
26   /* Attributes to initialise for each subObject */
27   var $subAttributes    = array("cn","description","FAIpriority","FAIscript"); 
28   var $sub64coded       = array("FAIscript");
30   /* Specific attributes */
31   var $cn               = "";       // The class name for this object
32   var $description      = "";       // The description for this set of partitions
33   var $is_dialog        = false;    // specifies which buttons will be shown to save or abort
34   var $dialog           = NULL;     // a dialog, e.g. new disk dialog
35   var $SubObjects       = array();  // All leafobjects of this object
37   function faiScript ($config, $dn= NULL)
38   {
39     /* Load Attributes */
40     plugin::plugin ($config, $dn);
42     /* If "dn==new" we try to create a new entry
43      * Else we must read all objects from ldap which belong to this entry.
44      * First read SubObjects from ldap ... and then the partition definitions for the SubObjects.
45      */
46     if($dn != "new"){
47       $this->dn =$dn;
49       /* Read all leaf objects of this object (For FAIscript this would be FAIscriptEntry)
50        */
51       $ldap     = $this->config->get_ldap_link();
52       $ldap->cd ($this->dn);
53       $ldap->search("(&(objectClass=FAIclass)(objectClass=".$this->subClass."))",$this->subAttributes);
55       while($object = $ldap->fetch()){
56         /* Set status for save management */
57   
58         foreach($this->subAttributes as $attrs){
59           if(!isset($object[$attrs][0])){
60             $this->SubObjects[$object['cn'][0]][$attrs]="";
61           }else{
62             $this->SubObjects[$object['cn'][0]][$attrs]=$object[$attrs][0];
63           }
64         }
65      
66         foreach($this->sub64coded as $codeIt){
67           $this->SubObjects[$object['cn'][0]][$codeIt]=base64_decode($this->SubObjects[$object['cn'][0]][$codeIt]);
68         }
69  
70         $this->SubObjects[$object['cn'][0]]['status']      = "edited";
71         $this->SubObjects[$object['cn'][0]]['dn']          = $object['dn'];
72       }
73     }
74   }
76   function execute()
77   {
78     /* Fill templating stuff */
79     $smarty= get_smarty();
80     $display= "";
82     /* Add new sub object */
83     if(isset($_POST['AddSubObject'])){
84       $this->dialog= new $this->subClassName($this->config,"new");
85       $this->is_dialog=true;
86     }
88     /* Edit selected Sub Object */
89     if((isset($_POST['EditSubObject']))&&(isset($_POST['SubObject']))){
90       $this->dialog= new $this->subClassName($this->config,$this->dn,$this->SubObjects[$_POST['SubObject']]);
91       $this->is_dialog=true;
92     }
93     
94     /* Remove Sub object */
95     if((isset($_POST['DelSubObject']))&&(isset($_POST['SubObject']))){
96       if($this->SubObjects[$_POST['SubObject']]['status'] == "edited"){
97         $this->SubObjects[$_POST['SubObject']]['status']= "delete";
98       }else{
99         unset($this->SubObjects[$_POST['SubObject']]);
100       }
101     }
103     /* Save Dialog */
104     if(isset($_POST['SaveSubObject'])){
105       $this->dialog->save_object();
106       $msgs = $this->dialog->check();
107       if(count($msgs)>0){
108         foreach($msgs as $msg){
109           print_red($msg);
110         }
111       }else{
112         $obj = $this->dialog->save();
113         if(isset($obj['remove'])){
114           if($this->SubObjects[$obj['remove']['from']]['status']=="edited"){
115             $this->SubObjects[$obj['remove']['from']]['status'] = "delete";
116           }elseif($this->SubObjects[$obj['remove']['from']]['status']=="new"){
117             unset($this->SubObjects[$obj['remove']['from']]);
118           }
119           $obj['status'] = "new";
120           $this->SubObjects[$obj['remove']['to']] = $obj;
121           unset($this->SubObjects[$obj['remove']['to']]['remove']);
122         }else{
123           $this->SubObjects[$obj['cn']]=$obj;
124         }
125         $this->is_dialog=false;
126         unset($this->dialog);
127         $this->dialog=NULL;
128       }
129     }
131     /* Cancel Dialog */
132     if(isset($_POST['CancelSubObject'])){
133       $this->is_dialog=false; 
134       unset($this->dialog);
135       $this->dialog=NULL;
136     }
138     /* Print dialog if $this->dialog is set */
139     if($this->dialog){
140       $this->dialog->save_object();
141       $display = $this->dialog->execute();
142       return($display);
143     }
145     $smarty->assign("SubObjects",$this->getList());
146     $smarty->assign("SubObjectKeys",array_flip($this->getList()));
147      
148     /* Magic quotes GPC, escapes every ' " \, to solve some security risks
149     * If we post the escaped strings they will be escaped again
150     */
151     foreach($this->attributes as $attrs){
152       if(get_magic_quotes_gpc()){
153         $smarty->assign($attrs,stripslashes($this->$attrs));
154       }else{
155         $smarty->assign($attrs,($this->$attrs));
156       }
157     }
159     $display.= $smarty->fetch(get_template_path('faiScript.tpl', TRUE));
160     return($display);
161   }
163   /* Generate listbox friendly SubObject list
164   */
165   function getList(){
166     $a_return=array();
167     foreach($this->SubObjects as $obj){
168       if($obj['status'] != "delete"){
169         if((isset($obj['description']))&&(!empty($obj['description']))){
170           $a_return[$obj['cn']]= $obj['cn']." [".$obj['description']."]";
171         }else{
172           $a_return[$obj['cn']]= $obj['cn'];
173         }
174       }
175     }
176     return($a_return);
177   }
179   /* Delete me, and all my subtrees
180    */
181   function remove_from_parent()
182   {
183     $ldap = $this->config->get_ldap_link();
184     $ldap->cd ($this->dn);
185     $ldap->rmdir_recursive($this->dn);
186     $this->handle_post_events("remove");    
187   }
190   /* Save data to object 
191    */
192   function save_object()
193   {
194     plugin::save_object();
195     foreach($this->attributes as $attrs){
196       if(isset($_POST[$attrs])){
197         $this->$attrs = $_POST[$attrs];
198       }
199     }
200   }
203   /* Check supplied data */
204   function check()
205   {
206     $message= array();
207     return ($message);
208   }
211   /* Save to LDAP */
212   function save()
213   {
214     plugin::save();
215  
216     $ldap = $this->config->get_ldap_link();
217   
218     $ldap->cat($this->dn);
219     if($ldap->count()!=0){
220       /* Write FAIscript to ldap*/
221       $ldap->cd($this->dn);
222       $ldap->modify($this->attrs);
223     }else{
224       /* Write FAIscript to ldap*/
225       $ldap->cd($this->config->current['BASE']);
226       $ldap->create_missing_trees(preg_replace('/^[^,]+,/', '', $this->dn));
227       $ldap->cd($this->dn);
228       $ldap->add($this->attrs);
229     }
230     show_ldap_error($ldap->get_error());
231  
232     /* Prepare FAIscriptEntry to write it to ldap
233      * First sort array.
234      *  Because we must delete old entries first.
235      * After deletion, we perform add and modify 
236      */
237     $Objects = array();
238     foreach($this->SubObjects as $name => $obj){
239       if($obj['status'] == "delete"){
240         $Objects[$name] = $obj; 
241       }
242     }
243     foreach($this->SubObjects as $name => $obj){
244       if($obj['status'] != "delete"){
245         $Objects[$name] = $obj; 
246       }
247     }
249     foreach($Objects as $name => $obj){
251       foreach($this->sub64coded as $codeIt){
252         $obj[$codeIt]=base64_encode($obj[$codeIt]);
253       }
255       $tmp = array();
256       foreach($this->subAttributes as $attrs){
257         if(empty($obj[$attrs])){
258           $obj[$attrs] = array();
259         }
260         $tmp[$attrs] = $obj[$attrs];
261       }    
262         
263       $tmp['objectClass'] = $this->subClasses;
265       $sub_dn = "cn=".$obj['cn'].",".$this->dn;
267       if($obj['status']=="new"){
268         $ldap->cat($sub_dn);
269         if($ldap->count()){
270           $obj['status']="modify";
271         }
272       }
273  
274       if($obj['status'] == "delete"){
275         $ldap->cd($sub_dn);
276         $ldap->rmdir_recursive($sub_dn);
277         $this->handle_post_events("remove");
278       }elseif($obj['status'] == "edited"){
279         $ldap->cd($sub_dn);
280         $ldap->modify($tmp);
281         $this->handle_post_events("modify");
282       }elseif($obj['status']=="new"){
283         if($tmp['description']==array()){
284           unset($tmp['description']);
285         }
286         if($tmp['FAIscript']==array()){
287           $tmp['FAIscript']=" ";
288         }
289         $ldap->cd($this->config->current['BASE']);
290         $ldap->create_missing_trees(preg_replace('/^[^,]+,/', '', $this->dn));
291         $ldap->cd($sub_dn);
292         $ldap->add($tmp); 
293         $this->handle_post_events("add");
294       }
295       show_ldap_error($ldap->get_error()); 
296     }
297   }
300 // vim:tabstop=2:expandtab:shiftwidth=2:filetype=php:syntax:ruler:
301 ?>