Marius Cramer
2014-07-08 8537705bf9d7c89ac938bc821c5696c79a1bb102
interface/web/dns/dns_soa_edit.php
@@ -269,25 +269,6 @@
   parent::onSubmit();
}
function onAfterInsert() {
   global $app, $conf;
   // make sure that the record belongs to the client group and not the admin group when a dmin inserts it
   if($_SESSION["s"]["user"]["typ"] == 'admin' && isset($this->dataRecord["client_group_id"])) {
      $client_group_id = $app->functions->intval($this->dataRecord["client_group_id"]);
      $app->db->query("UPDATE dns_soa SET sys_groupid = $client_group_id, sys_perm_group = 'ru' WHERE id = ".$this->id);
      // And we want to update all rr records too, that belong to this record
      $app->db->query("UPDATE dns_rr SET sys_groupid = $client_group_id WHERE zone = ".$this->id);
   }
   if($app->auth->has_clients($_SESSION['s']['user']['userid']) && isset($this->dataRecord["client_group_id"])) {
      $client_group_id = $app->functions->intval($this->dataRecord["client_group_id"]);
      $app->db->query("UPDATE dns_soa SET sys_groupid = $client_group_id, sys_perm_group = 'riud' WHERE id = ".$this->id);
      // And we want to update all rr records too, that belong to this record
      $app->db->query("UPDATE dns_rr SET sys_groupid = $client_group_id WHERE zone = ".$this->id);
   }
}
function onBeforeUpdate () {
   global $app, $conf;
@@ -303,42 +284,6 @@
      }
      unset($rec);
   }
}
function onAfterUpdate() {
   global $app, $conf;
   $tmp = $app->db->diffrec($this->oldDataRecord, $app->tform->getDataRecord($this->id));
   if($tmp['diff_num'] > 0) {
      // Update the serial number of the SOA record
      $soa = $app->db->queryOneRecord("SELECT serial FROM dns_soa WHERE id = ".$this->id);
      $app->db->query("UPDATE dns_soa SET serial = '".$app->validate_dns->increase_serial($soa["serial"])."' WHERE id = ".$this->id);
   }
   // make sure that the record belongs to the client group and not the admin group when a dmin inserts it
   if($_SESSION["s"]["user"]["typ"] == 'admin' && isset($this->dataRecord["client_group_id"])) {
      $client_group_id = $app->functions->intval($this->dataRecord["client_group_id"]);
      $app->db->query("UPDATE dns_soa SET sys_groupid = $client_group_id, sys_perm_group = 'ru' WHERE id = ".$this->id);
      // And we want to update all rr records too, that belong to this record
      $app->db->query("UPDATE dns_rr SET sys_groupid = $client_group_id WHERE zone = ".$this->id);
   }
   if($app->auth->has_clients($_SESSION['s']['user']['userid']) && isset($this->dataRecord["client_group_id"])) {
      $client_group_id = $app->functions->intval($this->dataRecord["client_group_id"]);
      $app->db->query("UPDATE dns_soa SET sys_groupid = $client_group_id, sys_perm_group = 'riud' WHERE id = ".$this->id);
      // And we want to update all rr records too, that belong to this record
      $app->db->query("UPDATE dns_rr SET sys_groupid = $client_group_id WHERE zone = ".$this->id);
   }
   //** When the client group has changed, change also the owner of the record if the owner is not the admin user
   if($this->oldDataRecord["client_group_id"] != $this->dataRecord["client_group_id"] && $this->dataRecord["sys_userid"] != 1) {
      $client_group_id = $app->functions->intval($this->dataRecord["client_group_id"]);
      $tmp = $app->db->queryOneREcord("SELECT userid FROM sys_user WHERE default_group = ".$client_group_id);
      if($tmp["userid"] > 0) {
         $app->db->query("UPDATE dns_soa SET sys_userid = ".$tmp["userid"]." WHERE id = ".$this->id);
         $app->db->query("UPDATE dns_rr SET sys_userid = ".$tmp["userid"]." WHERE zone = ".$this->id);
      }
   }
}
}