ruleList.blade.php 7.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204
  1. @extends('admin.layouts')
  2. @section('css')
  3. <link href="/assets/global/vendor/bootstrap-table/bootstrap-table.min.css" type="text/css" rel="stylesheet">
  4. <link href="/assets/global/vendor/bootstrap-select/bootstrap-select.min.css" type="text/css" rel="stylesheet">
  5. @endsection
  6. @section('content')
  7. <div class="page-content container-fluid">
  8. <div class="panel">
  9. <div class="panel-heading">
  10. <h2 class="panel-title">规则列表</h2>
  11. <div class="panel-actions">
  12. <button data-toggle="modal" data-target="#add" class="btn btn-outline-primary">
  13. <i class="icon wb-plus" aria-hidden="true"></i>添加规则
  14. </button>
  15. </div>
  16. </div>
  17. <div class="panel-body">
  18. <div class="form-row">
  19. <div class="form-group col-xxl-1 col-lg-3 col-md-3 col-4">
  20. <select class="form-control" id="type" name="type" data-plugin="selectpicker" data-style="btn-outline btn-primary" onChange="Search()">
  21. <option value="" hidden>类型</option>
  22. <option value="1">正则表达式</option>
  23. <option value="2">域名</option>
  24. <option value="3">IP</option>
  25. <option value="4">协议</option>
  26. </select>
  27. </div>
  28. <div class="form-group col-xxl-1 col-lg-3 col-md-3 col-4">
  29. <a href="/rule" class="btn btn-danger">重 置</a>
  30. </div>
  31. </div>
  32. <table class="text-md-center" data-toggle="table" data-mobile-responsive="true">
  33. <thead class="thead-default">
  34. <tr>
  35. <th> #</th>
  36. <th> 类型</th>
  37. <th> 描述</th>
  38. <th> 值</th>
  39. <th> 操作</th>
  40. </tr>
  41. </thead>
  42. <tbody>
  43. @foreach ($rules as $rule)
  44. <tr>
  45. <td> {{$rule->id}} </td>
  46. <td> {!! $rule->type_label !!} </td>
  47. <td>
  48. <input type="text" class="form-control" name="rule_name" id="rule_name_{{$rule->id}}" value="{{$rule->name}}"/>
  49. </td>
  50. <td>
  51. <input type="text" class="form-control" name="rule_pattern" id="rule_pattern_{{$rule->id}}" value="{{$rule->pattern}}"/>
  52. </td>
  53. <td>
  54. <button class="btn btn-sm btn-outline-primary" onclick="editRule('{{$rule->id}}')">
  55. <i class="icon wb-edit" aria-hidden="true"></i></button>
  56. <button class="btn btn-sm btn-outline-danger" onclick="delRule('{{$rule->id}}','{{$rule->name}}')">
  57. <i class="icon wb-trash"></i></button>
  58. </td>
  59. </tr>
  60. @endforeach
  61. </tbody>
  62. </table>
  63. </div>
  64. <div class="panel-footer">
  65. <div class="row">
  66. <div class="col-sm-4">
  67. 共 <code>{{$rules->total()}}</code> 条审计规则
  68. </div>
  69. <div class="col-sm-8">
  70. <nav class="Page navigation float-right">
  71. {{$rules->links()}}
  72. </nav>
  73. </div>
  74. </div>
  75. </div>
  76. </div>
  77. </div>
  78. <div class="modal fade" id="add" aria-hidden="true" role="dialog" tabindex="-1">
  79. <div class="modal-dialog modal-simple modal-center">
  80. <div class="modal-content">
  81. <div class="modal-header">
  82. <button type="button" class="close" data-dismiss="modal" aria-label="Close">
  83. <span aria-hidden="true">×</span>
  84. </button>
  85. <h4 class="modal-title">添加规则</h4>
  86. </div>
  87. <form action="#" method="post" class="modal-body">
  88. <div class="alert alert-danger" style="display: none;" id="msg"></div>
  89. <div class="form-row">
  90. <div class="col-12">
  91. <div class="form-group row">
  92. <label class="col-md-2 col-sm-3 col-form-label" for="add_type">类型</label>
  93. <div class="col-xl-4 col-sm-8">
  94. <select class="form-control" name="add_type" id="add_type" data-plugin="selectpicker" data-style="btn-outline btn-primary">
  95. <option value="1">正则表达式</option>
  96. <option value="2">域名</option>
  97. <option value="3">IP</option>
  98. <option value="4">协议</option>
  99. </select>
  100. </div>
  101. </div>
  102. <div class="form-group row">
  103. <label class="col-md-2 col-sm-3 col-form-label" for="name">描述</label>
  104. <div class="col-xl-6 col-sm-8">
  105. <input type="text" class="form-control" name="name" id="name" required/>
  106. </div>
  107. </div>
  108. </div>
  109. <div class="col-12">
  110. <div class="form-group row">
  111. <label class="col-md-2 col-sm-3 col-form-label" for="pattern">值</label>
  112. <div class="col-xl-6 col-sm-8">
  113. <input type="text" class="form-control" name="pattern" id="pattern" required/>
  114. </div>
  115. </div>
  116. </div>
  117. </div>
  118. </form>
  119. <div class="modal-footer">
  120. <button data-dismiss="modal" class="btn btn-danger">关 闭</button>
  121. <button type="button" class="btn btn-primary" onclick="addRule()">添 加</button>
  122. </div>
  123. </div>
  124. </div>
  125. </div>
  126. @endsection
  127. @section('script')
  128. <script src="/assets/global/vendor/bootstrap-table/bootstrap-table.min.js" type="text/javascript"></script>
  129. <script src="/assets/global/vendor/bootstrap-table/extensions/mobile/bootstrap-table-mobile.min.js" type="text/javascript"></script>
  130. <script src="/assets/global/vendor/bootstrap-select/bootstrap-select.min.js" type="text/javascript"></script>
  131. <script src="/assets/global/js/Plugin/bootstrap-select.js" type="text/javascript"></script>
  132. <script type="text/javascript">
  133. // 添加规则
  134. function addRule() {
  135. $.post("/rule/add", {
  136. _token: '{{csrf_token()}}',
  137. type: $("#add_type").val(),
  138. name: $("#name").val(),
  139. pattern: $("#pattern").val()
  140. }, function (ret) {
  141. if (ret.status === 'success') {
  142. swal.fire({title: ret.message, type: 'success', timer: 1000, showConfirmButton: false})
  143. .then(() => window.location.reload())
  144. } else {
  145. swal.fire({title: ret.message, type: "error"});
  146. }
  147. });
  148. }
  149. // 编辑规则
  150. function editRule(id) {
  151. $.post("/rule/edit", {
  152. _token: '{{csrf_token()}}',
  153. id: id,
  154. rule_name: $('#rule_name_' + id).val(),
  155. rule_pattern: $('#rule_pattern_' + id).val()
  156. }, function (ret) {
  157. if (ret.status === 'success') {
  158. swal.fire({title: ret.message, type: 'success', timer: 1000, showConfirmButton: false})
  159. .then(() => window.location.reload())
  160. } else {
  161. swal.fire({title: ret.message, type: "error"});
  162. }
  163. });
  164. }
  165. // 删除规则
  166. function delRule(id, name) {
  167. swal.fire({
  168. title: '警告',
  169. text: '确定删除规则 【' + name + '】 ?',
  170. type: 'warning',
  171. showCancelButton: true,
  172. cancelButtonText: '{{trans('home.ticket_close')}}',
  173. confirmButtonText: '{{trans('home.ticket_confirm')}}',
  174. }).then((result) => {
  175. if (result.value) {
  176. $.post("/rule/delete", {_token: '{{csrf_token()}}', id: id}, function (ret) {
  177. if (ret.status === 'success') {
  178. swal.fire({title: ret.message, type: 'success', timer: 1000, showConfirmButton: false})
  179. .then(() => window.location.reload())
  180. } else {
  181. swal.fire({title: ret.message, type: "error"});
  182. }
  183. });
  184. }
  185. });
  186. }
  187. //回车检测
  188. $(document).on("keypress", "input", function (e) {
  189. if (e.which === 13) {
  190. Search();
  191. return false;
  192. }
  193. });
  194. // 搜索
  195. function Search() {
  196. window.location.href = '/rule?type=' + $("#type").val();
  197. }
  198. </script>
  199. @endsection