list_firewall.php 7.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165
  1. <!-- Begin toolbar -->
  2. <div class="toolbar">
  3. <div class="toolbar-inner">
  4. <div class="toolbar-buttons">
  5. <a class="button button-secondary button-back js-button-back" href="/list/server/">
  6. <i class="fas fa-arrow-left icon-blue"></i><?= _("Back") ?>
  7. </a>
  8. <a href="/add/firewall/" class="button button-secondary js-button-create">
  9. <i class="fas fa-circle-plus icon-green"></i><?= _("Add Rule") ?>
  10. </a>
  11. <?php if (!empty($_SESSION["FIREWALL_EXTENSION"])): ?>
  12. <a class="button button-secondary" href="/list/firewall/banlist/">
  13. <i class="fas fa-eye icon-red"></i><?= _("Fail2ban Banlists") ?>
  14. </a>
  15. <a class="button button-secondary" href="/list/firewall/ipset/">
  16. <i class="fas fa-list icon-blue"></i><?= _("IPset IP Lists") ?>
  17. </a>
  18. <?php endif; ?>
  19. </div>
  20. <div class="toolbar-right">
  21. <div class="toolbar-sorting">
  22. <button class="toolbar-sorting-toggle js-toggle-sorting-menu" type="button" title="<?= _("Sort items") ?>">
  23. <?= _("Sort by") ?>:
  24. <span class="u-text-bold">
  25. <?= _("Action") ?> <i class="fas fa-arrow-up-a-z"></i>
  26. </span>
  27. </button>
  28. <ul class="toolbar-sorting-menu animate__animated animate__fadeIn js-sorting-menu u-hidden">
  29. <li data-entity="sort-action">
  30. <span class="name"><?= _("Action") ?> <i class="fas fa-arrow-down-a-z"></i></span><span class="up active"><i class="fas fa-arrow-up-a-z"></i></span>
  31. </li>
  32. <li data-entity="sort-protocol">
  33. <span class="name"><?= _("Protocol") ?> <i class="fas fa-arrow-down-a-z"></i></span><span class="up"><i class="fas fa-arrow-up-a-z"></i></span>
  34. </li>
  35. <li data-entity="sort-port">
  36. <span class="name"><?= _("Port") ?> <i class="fas fa-arrow-down-a-z"></i></span><span class="up"><i class="fas fa-arrow-up-a-z"></i></span>
  37. </li>
  38. <li data-entity="sort-ip" data-sort-as-int="1">
  39. <span class="name"><?= _("IP Address") ?> <i class="fas fa-arrow-down-a-z"></i></span><span class="up"><i class="fas fa-arrow-up-a-z"></i></span>
  40. </li>
  41. <li data-entity="sort-comment">
  42. <span class="name"><?= _("Comment") ?> <i class="fas fa-arrow-down-a-z"></i></span><span class="up"><i class="fas fa-arrow-up-a-z"></i></span>
  43. </li>
  44. </ul>
  45. <form x-data x-bind="BulkEdit" action="/bulk/firewall/" method="post">
  46. <input type="hidden" name="token" value="<?= $_SESSION["token"] ?>">
  47. <select class="form-select" name="action">
  48. <option value=""><?= _("Apply to selected") ?></option>
  49. <option value="delete"><?= _("Delete") ?></option>
  50. </select>
  51. <button type="submit" class="toolbar-input-submit" title="<?= _("Apply to selected") ?>">
  52. <i class="fas fa-arrow-right"></i>
  53. </button>
  54. </form>
  55. </div>
  56. </div>
  57. </div>
  58. </div>
  59. <!-- End toolbar -->
  60. <div class="container">
  61. <div class="units compact js-units-container">
  62. <div class="header units-header">
  63. <div class="l-unit__col l-unit__col--right">
  64. <div class="clearfix l-unit__stat-col--left super-compact">
  65. <input type="checkbox" class="js-toggle-all-checkbox" title="<?= _("Select all") ?>">
  66. </div>
  67. <div class="clearfix l-unit__stat-col--left wide-1"><b><?= _("Action") ?></b></div>
  68. <div class="clearfix l-unit__stat-col--left compact-2 u-text-right"><b>&nbsp;</b></div>
  69. <div class="clearfix l-unit__stat-col--left wide-3"><b><?= _("Comment") ?></b></div>
  70. <div class="clearfix l-unit__stat-col--left u-text-center"><b><?= _("Protocol") ?></b></div>
  71. <div class="clearfix l-unit__stat-col--left wide-3 u-text-center"><b><?= _("Port") ?></b></div>
  72. <div class="clearfix l-unit__stat-col--left u-text-center"><b><?= _("IP Address") ?></b></div>
  73. </div>
  74. </div>
  75. <!-- Begin firewall chain/action list item loop -->
  76. <?php
  77. foreach ($data as $key => $value) {
  78. ++$i;
  79. if ($data[$key]['SUSPENDED'] == 'yes') {
  80. $status = 'suspended';
  81. $spnd_action = 'unsuspend';
  82. $spnd_action_title = _('Unsuspend');
  83. $spnd_icon = 'fa-play';
  84. $spnd_confirmation = _('Are you sure you want to unsuspend rule #%s?') ;
  85. } else {
  86. $status = 'active';
  87. $spnd_action = 'suspend';
  88. $spnd_action_title = _('Suspend');
  89. $spnd_icon = 'fa-pause';
  90. $spnd_confirmation = _('Are you sure you want to suspend rule #%s?') ;
  91. }
  92. ?>
  93. <div class="l-unit <?php if ($status == 'suspended') echo 'l-unit--suspended'; ?> animate__animated animate__fadeIn js-unit"
  94. data-sort-action="<?=$data[$key]['ACTION']?>"
  95. data-sort-protocol="<?=$data[$key]['PROTOCOL']?>"
  96. data-sort-port="<?=$data[$key]['PORT']?>"
  97. data-sort-ip="<?=str_replace('.', '', $data[$key]['IP'])?>"
  98. data-sort-comment="<?=$data[$key]['COMMENT']?>">
  99. <div class="l-unit__col l-unit__col--right">
  100. <div>
  101. <div class="clearfix l-unit__stat-col--left super-compact">
  102. <input id="check<?= $i ?>" class="js-unit-checkbox" type="checkbox" title="<?= _("Select") ?>" name="rule[]" value="<?= $key ?>">
  103. </div>
  104. <div class="clearfix l-unit__stat-col--left wide-1">
  105. <b>
  106. <a href="/edit/firewall/?rule=<?= $key ?>&token=<?= $_SESSION["token"] ?>" title="<?= _("Edit Firewall Rule") ?>">
  107. <?php
  108. $suspended = $data[$key]["SUSPENDED"] == "no";
  109. $action = $data[$key]["ACTION"];
  110. $iconClass = $action == "DROP" ? "fa-circle-minus" : "fa-circle-check";
  111. $colorClass = $action == "DROP" ? "icon-red" : "icon-green";
  112. ?>
  113. <i class="fas <?= $iconClass ?> u-mr5 <?= $suspended ? $colorClass : "" ?>"></i> <?= $action ?>
  114. </a>
  115. </b>
  116. </div>
  117. <!-- START QUICK ACTION TOOLBAR AREA -->
  118. <div class="clearfix l-unit__stat-col--left compact-2 u-text-right">
  119. <div class="l-unit-toolbar__col l-unit-toolbar__col--right u-noselect">
  120. <div class="actions-panel clearfix" style="padding-right: 10px;">
  121. <div class="actions-panel__col actions-panel__logs shortcut-enter" data-key-action="href"><a href="/edit/firewall/?rule=<?=$key?>&token=<?=$_SESSION['token']?>" title="<?= _("Edit Firewall Rule") ?>"><i class="fas fa-pencil icon-orange icon-dim"></i></a></div>
  122. <div class="actions-panel__col actions-panel__suspend shortcut-s" data-key-action="js">
  123. <a
  124. class="data-controls js-confirm-action"
  125. href="/<?= $spnd_action ?>/firewall/?rule=<?=$key?>&token=<?=$_SESSION['token']?>"
  126. data-confirm-title="<?= $spnd_action_title ?>"
  127. data-confirm-message="<?= sprintf($spnd_confirmation, $key) ?>"
  128. >
  129. <i class="fas <?= $spnd_icon ?> icon-highlight icon-dim"></i>
  130. </a>
  131. </div>
  132. <div class="actions-panel__col actions-panel__delete shortcut-delete" data-key-action="js">
  133. <a
  134. class="data-controls js-confirm-action"
  135. href="/delete/firewall/?rule=<?=$key?>&token=<?=$_SESSION['token']?>"
  136. data-confirm-title="<?= _("Delete") ?>"
  137. data-confirm-message="<?= sprintf(_('Are you sure you want to delete rule %s'), $key) ?>"
  138. >
  139. <i class="fas fa-trash icon-red icon-dim"></i>
  140. </a>
  141. </div>
  142. </div>
  143. </div>
  144. </div>
  145. <!-- END QUICK ACTION TOOLBAR AREA -->
  146. <div class="clearfix l-unit__stat-col--left wide-3"><b><?php if (!empty($data[$key]['COMMENT'])) echo '' . $data[$key]['COMMENT']; else echo "&nbsp;"; ?></b></div>
  147. <div class="clearfix l-unit__stat-col--left u-text-center"><?=_($data[$key]['PROTOCOL'])?></div>
  148. <div class="clearfix l-unit__stat-col--left wide-3 u-text-center"><b><?=$data[$key]['PORT']?></b></div>
  149. <div class="clearfix l-unit__stat-col--left u-text-center"><?=$data[$key]['IP']?></div>
  150. </div>
  151. </div>
  152. </div>
  153. <?php } ?>
  154. </div>
  155. </div>
  156. <footer class="app-footer">
  157. <div class="container app-footer-inner">
  158. <p>
  159. <?php printf(ngettext("%d firewall rule", "%d firewall rules", $i), $i); ?>
  160. </p>
  161. </div>
  162. </footer>