for more details. * * Copyright 2007-2010 Rejo Zenger * Copyright 2010-2014 Poweradmin Development Team * * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program. If not, see . */ /** * Script that handles request to add new records to existing zone * * @package Poweradmin * @copyright 2007-2010 Rejo Zenger * @copyright 2010-2014 Poweradmin Development Team * @license http://opensource.org/licenses/GPL-3.0 GPL */ require_once("inc/toolkit.inc.php"); include_once("inc/header.inc.php"); /* Get permissions */ if (verify_permission('zone_content_view_others')) { $perm_view = "all"; } elseif (verify_permission('zone_content_view_own')) { $perm_view = "own"; } else { $perm_view = "none"; } if (verify_permission('zone_content_edit_others')) { $perm_content_edit = "all"; } elseif (verify_permission('zone_content_edit_own')) { $perm_content_edit = "own"; } else { $perm_content_edit = "none"; } if (verify_permission('zone_meta_edit_others')) { $perm_meta_edit = "all"; } elseif (verify_permission('zone_meta_edit_own')) { $perm_meta_edit = "own"; } else { $perm_meta_edit = "none"; } /* Check and make sure all post values have made it through if not set them. */ $zone_id = "-1"; if ((isset($_GET['id'])) && (v_num($_GET['id']))) { $zone_id = $_GET['id']; } $ttl = $dns_ttl; if ((isset($_POST['ttl'])) && (v_num($_POST['ttl']))) { $ttl = $_POST['ttl']; } $prio = "10"; if ((isset($_POST['prio'])) && (v_num($_POST['prio']))) { $prio = $_POST['prio']; } if (isset($_POST['name'])) { $name = $_POST['name']; } else { $name = ""; } if (isset($_POST['type'])) { $type = $_POST['type']; } else { $type = ""; } if (isset($_POST['content'])) { $content = $_POST['content']; } else { $content = ""; } if ($zone_id == "-1") { error(ERR_INV_INPUT); include_once("inc/footer.inc.php"); exit; } /* Check and see if the user is the zone owner Check the sone type and get the zone name */ $user_is_zone_owner = verify_user_is_owner_zoneid($zone_id); $zone_type = get_domain_type($zone_id); $zone_name = get_zone_name_from_id($zone_id); /* If the form as been submitted process it! */ if (isset($_POST["commit"])) { if ($zone_type == "SLAVE" || $perm_content_edit == "none" || $perm_content_edit == "own" && $user_is_zone_owner == "0") { error(ERR_PERM_ADD_RECORD); } else { // a PTR-record is added if an A or an AAAA-record are created // and checkbox is checked if ((isset($_POST["reverse"])) && $iface_add_reverse_record ) { if ($type === 'A') { $content_array = preg_split("/\./", $content); $content_rev = sprintf("%d.%d.%d.%d.in-addr.arpa", $content_array[3], $content_array[2], $content_array[1], $content_array[0]); $zone_rev_id = get_best_matching_zone_id_from_name($content_rev); } elseif ($type === 'AAAA') { $content_rev = convert_ipv6addr_to_ptrrec($content); $zone_rev_id = get_best_matching_zone_id_from_name($content_rev); } if (isset($zone_rev_id) && $zone_rev_id != -1) { $zone_name = get_zone_name_from_id($zone_id); $fqdn_name = sprintf("%s.%s", $name, $zone_name); if (add_record($zone_rev_id, $content_rev, 'PTR', $fqdn_name, $ttl, $prio)) { success(" " . _('The PTR-record was successfully added.') . ""); log_info(sprintf('client_ip:%s user:%s operation:add_record record_type:PTR record:%s content:%s ttl:%s priority:%s', $_SERVER['REMOTE_ADDR'], $_SESSION["userlogin"], $content_rev, $fqdn_name, $ttl, $prio)); } } elseif (isset($content_rev)) { error(sprintf(ERR_REVERS_ZONE_NOT_EXIST, $content_rev)); } } if (add_record($zone_id, $name, $type, $content, $ttl, $prio)) { success(" " . _('The record was successfully added.') . ""); log_info(sprintf('client_ip:%s user:%s operation:add_record record_type:%s record:%s.%s content:%s ttl:%s priority:%s', $_SERVER['REMOTE_ADDR'], $_SESSION["userlogin"], $type, $name, $zone_name, $content, $ttl, $prio)); $name = $type = $content = $ttl = $prio = ""; } } } /* Display form to add a record */ echo "

" . _('Add record to zone') . " " . $zone_name . "

\n"; if ($zone_type == "SLAVE" || $perm_content_edit == "none" || $perm_content_edit == "own" && $user_is_zone_owner == "0") { error(ERR_PERM_ADD_RECORD); } else { echo "
\n"; echo " \n"; echo " \n"; echo " \n"; echo " \n"; echo " \n"; echo " \n"; echo " \n"; echo " \n"; echo " \n"; echo " \n"; echo " \n"; echo " \n"; echo " \n"; echo " \n"; echo " \n"; echo " \n"; echo " \n"; echo "
" . _('Name') . " " . _('Type') . "" . _('Content') . "" . _('Priority') . "" . _('TTL') . "
." . $zone_name . "IN\n"; echo " " . _('Add also reverse record') . "\n"; } else { $add = ""; } } echo " " . $record_type . "\n"; } if (!$found_selected_type) echo " \n"; echo " \n"; echo " \n"; echo "
\n"; echo "
\n"; echo " \n"; if (isset($rev)) { echo " $rev"; } echo "
\n"; } include_once("inc/footer.inc.php");