]> git.tokkee.org Git - gosa.git/commitdiff

Code

Made dhcp service addable/removable
authorcajus <cajus@594d385d-05f5-0310-b6e9-bd551577e9d8>
Thu, 9 Aug 2007 09:15:04 +0000 (09:15 +0000)
committercajus <cajus@594d385d-05f5-0310-b6e9-bd551577e9d8>
Thu, 9 Aug 2007 09:15:04 +0000 (09:15 +0000)
git-svn-id: https://oss.gonicus.de/repositories/gosa/branches/2.5@7020 594d385d-05f5-0310-b6e9-bd551577e9d8

plugins/admin/systems/class_servDHCP.inc

index 46ab2e4262c21ae8bb06934eca8df8b606aa7b28..494d5e1e9e48fb722aa08461914a1b29a625fda5 100644 (file)
@@ -3,7 +3,6 @@
 class servdhcp extends plugin
 {
   /* attribute list for save action */
-  var $ignore_account= TRUE;
   var $attributes= array();
   var $objectclasses= array();
 
@@ -31,6 +30,9 @@ class servdhcp extends plugin
 
     /* Load information about available services */
     $this->reload(); 
+    if (!count($this->dhcpSections)){
+      $this->is_account= FALSE;
+    }
   }
 
 
@@ -190,6 +192,22 @@ class servdhcp extends plugin
     if ($this->is_account){
       $display= $this->show_header(_("Remove DHCP service"),
           _("This server has DHCP features enabled. You can disable them by clicking below."));
+
+      if (!count($this->dhcpObjectCache)){
+        $attrs= array();
+        $attrs['dn']= 'cn=dhcp,'.$this->dn;
+        $attrs['cn']= array('dhcp');
+        $attrs['objectClass']= array('top', 'dhcpService');
+        $attrs['dhcpPrimaryDN']= array($this->dn);
+        $attrs['dhcpStatements']= array("default-lease-time 600",
+                                        "max-lease-time 1200",
+                                        "authoritative",
+                                        "ddns-update-style none");
+        $attrs['MODIFIED']= TRUE;
+        $this->dhcpSections['cn=dhcp,'.$this->dn]= _("Global options");
+        $this->dhcpObjectCache['cn=dhcp,'.$this->dn]= $attrs;
+      }
+
     } else {
       $display= $this->show_header(_("Add DHCP service"),
           _("This server has DHCP features disabled. You can enable them by clicking below."));
@@ -248,9 +266,16 @@ class servdhcp extends plugin
     return($display);
   }
 
+
   function remove_from_parent()
   {
-    /* This cannot be removed... */
+    $ldap= $this->config->get_ldap_link();
+    foreach ($this->dhcpObjectCache as $dn => $content){
+      if ($this->objectType($dn) == 'dhcpService'){
+        $ldap->rmdir_recursive($dn);
+        show_ldap_error($ldap->get_error(), _("Removing DHCP entries failed"));
+      }
+    }
   }