You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

search.php 9.7KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194
  1. <?php
  2. /* Poweradmin, a friendly web-based admin tool for PowerDNS.
  3. * See <http://www.poweradmin.org> for more details.
  4. *
  5. * Copyright 2007-2010 Rejo Zenger <rejo@zenger.nl>
  6. * Copyright 2010-2014 Poweradmin Development Team
  7. * <http://www.poweradmin.org/credits.html>
  8. *
  9. * This program is free software: you can redistribute it and/or modify
  10. * it under the terms of the GNU General Public License as published by
  11. * the Free Software Foundation, either version 3 of the License, or
  12. * (at your option) any later version.
  13. *
  14. * This program is distributed in the hope that it will be useful,
  15. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  16. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  17. * GNU General Public License for more details.
  18. *
  19. * You should have received a copy of the GNU General Public License
  20. * along with this program. If not, see <http://www.gnu.org/licenses/>.
  21. */
  22. /**
  23. * Script that handles search requests
  24. *
  25. * @package Poweradmin
  26. * @copyright 2007-2010 Rejo Zenger <rejo@zenger.nl>
  27. * @copyright 2010-2014 Poweradmin Development Team
  28. * @license http://opensource.org/licenses/GPL-3.0 GPL
  29. */
  30. require_once('inc/toolkit.inc.php');
  31. include_once('inc/header.inc.php');
  32. if (!(verify_permission('search'))) {
  33. error(ERR_PERM_SEARCH);
  34. include_once('inc/footer.inc.php');
  35. exit;
  36. } else {
  37. echo " <h2>" . _('Search zones and records') . "</h2>\n";
  38. $holy_grail = '';
  39. if (isset($_POST['query'])) {
  40. if (verify_permission('zone_content_view_others')) {
  41. $perm_view = "all";
  42. } elseif (verify_permission('zone_content_view_own')) {
  43. $perm_view = "own";
  44. } else {
  45. $perm_view = "none";
  46. }
  47. if (verify_permission('zone_content_edit_others')) {
  48. $perm_edit = "all";
  49. } elseif (verify_permission('zone_content_edit_own')) {
  50. $perm_edit = "own";
  51. } else {
  52. $perm_edit = "none";
  53. }
  54. $holy_grail = $_POST['query'];
  55. $wildcards = ($_POST['wildcards'] == "true" ? true : false);
  56. $arpa = ($_POST['arpa'] == "true" ? true : false);
  57. $result = search_zone_and_record($holy_grail, $perm_view, ZONE_SORT_BY, RECORD_SORT_BY, $wildcards, $arpa);
  58. if (is_array($result['zones'])) {
  59. echo " <script language=\"JavaScript\" type=\"text/javascript\">\n";
  60. echo " <!--\n";
  61. echo " function zone_sort_by ( sortbytype )\n";
  62. echo " {\n";
  63. echo " document.sortby_zone_form.zone_sort_by.value = sortbytype ;\n";
  64. echo " document.sortby_zone_form.submit() ;\n";
  65. echo " }\n";
  66. echo " -->\n";
  67. echo " </script>\n";
  68. echo " <form name=\"sortby_zone_form\" method=\"post\" action=\"search.php\">\n";
  69. echo " <input type=\"hidden\" name=\"query\" value=\"" . $_POST['query'] . "\" />\n";
  70. echo " <input type=\"hidden\" name=\"zone_sort_by\" />\n";
  71. echo " <h3>" . _('Zones found') . ":</h3>\n";
  72. echo " <table>\n";
  73. echo " <tr>\n";
  74. echo " <th>&nbsp;</th>\n";
  75. echo " <th><a href=\"javascript:zone_sort_by('name')\">" . _('Name') . "</a></th>\n";
  76. echo " <th><a href=\"javascript:zone_sort_by('type')\">" . _('Type') . "</a></th>\n";
  77. echo " <th><a href=\"javascript:zone_sort_by('master')\">" . _('Master') . "</a></th>\n";
  78. /* If user has all edit permissions show zone owners */
  79. if ($perm_edit == "all") {
  80. echo " <th><a href=\"javascript:zone_sort_by('owner')\">" . _('Owner') . "</a></th>\n";
  81. }
  82. echo " </tr>\n";
  83. echo " </form>\n";
  84. foreach ($result['zones'] as $zone) {
  85. echo " <tr>\n";
  86. echo " <td>\n";
  87. echo " <a href=\"edit.php?name=" . $zone['name'] . "&id=" . $zone['zid'] . "\"><img src=\"images/edit.gif\" title=\"" . _('Edit zone') . " " . $zone['name'] . "\" alt=\"[ " . _('Edit zone') . " " . $zone['name'] . " ]\"></a>\n";
  88. if ($perm_edit != "all" || $perm_edit != "none") {
  89. $user_is_zone_owner = verify_user_is_owner_zoneid($zone['zid']);
  90. }
  91. if ($perm_edit == "all" || ( $perm_edit == "own" && $user_is_zone_owner == "1")) {
  92. echo " <a href=\"delete_domain.php?name=" . $zone['name'] . "&id=" . $zone['zid'] . "\"><img src=\"images/delete.gif\" title=\"" . _('Delete zone') . " " . $zone['name'] . "\" alt=\"[ " . _('Delete zone') . " " . $zone['name'] . " ]\"></a>\n";
  93. }
  94. echo " </td>\n";
  95. echo " <td>" . $zone['name'] . "</td>\n";
  96. echo " <td>" . $zone['type'] . "</td>\n";
  97. if ($zone['type'] == "SLAVE") {
  98. echo " <td>" . $zone['master'] . "</td>\n";
  99. } else {
  100. echo " <td>&nbsp;</td>\n";
  101. }
  102. if ($perm_edit == "all") {
  103. echo " <td>" . $zone['owner'] . "</td>";
  104. }
  105. echo " </tr>\n";
  106. }
  107. echo " </table>\n";
  108. }
  109. if (is_array($result['records'])) {
  110. echo " <script language=\"JavaScript\" type=\"text/javascript\">\n";
  111. echo " <!--\n";
  112. echo " function record_sort_by ( sortbytype )\n";
  113. echo " {\n";
  114. echo " document.sortby_record_form.record_sort_by.value = sortbytype ;\n";
  115. echo " document.sortby_record_form.submit() ;\n";
  116. echo " }\n";
  117. echo " -->\n";
  118. echo " </script>\n";
  119. echo " <form name=\"sortby_record_form\" method=\"post\" action=\"search.php\">\n";
  120. echo " <input type=\"hidden\" name=\"query\" value=\"" . $_POST['query'] . "\" />\n";
  121. echo " <input type=\"hidden\" name=\"record_sort_by\" />\n";
  122. echo " <h3>" . _('Records found') . ":</h3>\n";
  123. echo " <table>\n";
  124. echo " <tr>\n";
  125. echo " <th>&nbsp;</th>\n";
  126. echo " <th><a href=\"javascript:record_sort_by('name')\">" . _('Name') . "</a></th>\n";
  127. echo " <th><a href=\"javascript:record_sort_by('type')\">" . _('Type') . "</a></th>\n";
  128. echo " <th><a href=\"javascript:record_sort_by('content')\">" . _('Content') . "</a></th>\n";
  129. echo " <th>Priority</th>\n";
  130. echo " <th><a href=\"javascript:record_sort_by('ttl')\">" . _('TTL') . "</a></th>\n";
  131. echo " </tr>\n";
  132. echo " </form>\n";
  133. foreach ($result['records'] as $record) {
  134. echo " <tr>\n";
  135. echo " <td>\n";
  136. echo " <a href=\"edit_record.php?id=" . $record['rid'] . "\"><img src=\"images/edit.gif\" title=\"" . _('Edit record') . " " . $record['name'] . "\" alt=\"[ " . _('Edit record') . " " . $record['name'] . " ]\"></a>\n";
  137. if ($perm_edit != "all" || $perm_edit != "none") {
  138. $user_is_zone_owner = verify_user_is_owner_zoneid($record['zid']);
  139. }
  140. if ($perm_edit == "all" || ( $perm_edit == "own" && $user_is_zone_owner == "1")) {
  141. echo " <a href=\"delete_record.php?id=" . $record['rid'] . "\"><img src=\"images/delete.gif\" title=\"" . _('Delete record') . " " . $record['name'] . "\" alt=\"[ " . _('Delete record') . " " . $record['name'] . " ]\"></a>\n";
  142. }
  143. echo " </td>\n";
  144. echo " <td>" . $record['name'] . "</td>\n";
  145. echo " <td>" . $record['type'] . "</td>\n";
  146. echo " <td>" . $record['content'] . "</td>\n";
  147. if ($record['type'] == "MX" || $record['type'] == "SRV") {
  148. echo " <td>" . $record['prio'] . "</td>\n";
  149. } else {
  150. echo " <td>&nbsp;</td>\n";
  151. }
  152. echo " <td>" . $record['ttl'] . "</td>\n";
  153. echo " </tr>\n";
  154. }
  155. echo " </table>\n";
  156. }
  157. } else { // !isset($_POST['query'])
  158. $wildcards = true;
  159. $arpa = true;
  160. }
  161. echo " <h3>" . _('Query') . ":</h3>\n";
  162. echo " <form method=\"post\" action=\"" . htmlentities($_SERVER['PHP_SELF'], ENT_QUOTES) . "\">\n";
  163. echo " <table>\n";
  164. echo " <tr>\n";
  165. echo " <td>\n";
  166. echo " <input type=\"text\" class=\"input\" name=\"query\" value=\"" . $holy_grail . "\">&nbsp;\n";
  167. echo " <input type=\"submit\" class=\"button\" name=\"submit\" value=\"" . _('Search') . "\">\n";
  168. echo " <input type=\"checkbox\" class=\"input\" name=\"wildcards\" value=\"true\"" . ($wildcards ? "checked=\"checked\"" : "") . ">" . _('Wildcard') . "\n";
  169. echo " <input type=\"checkbox\" class=\"input\" name=\"arpa\" value=\"true\"" . ($arpa ? "checked=\"checked\"" : "") . ">" . _('Reverse') . "\n";
  170. echo " </td>\n";
  171. echo " </tr>\n";
  172. echo " <tr>\n";
  173. echo " <td>\n";
  174. echo " " . _('Enter a hostname or IP address. SQL LIKE syntax supported: an underscore (_) in pattern matches any single character, a percent sign (%) matches any string of zero or more characters.') . "\n";
  175. echo " </td>\n";
  176. echo " </tr>\n";
  177. echo " </table>\n";
  178. echo " </form>\n";
  179. }
  180. include_once('inc/footer.inc.php');