list_firewall.php 7.6 KB

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