index.blade.php 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270
  1. @extends('admin.layouts')
  2. @section('css')
  3. <link href="/assets/global/vendor/bootstrap-table/bootstrap-table.min.css" rel="stylesheet">
  4. <link href="/assets/global/vendor/bootstrap-select/bootstrap-select.min.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. @can('admin.rule.store')
  12. <div class="panel-actions">
  13. <button data-toggle="modal" data-target="#add" class="btn btn-outline-primary">
  14. <i class="icon wb-plus" aria-hidden="true"></i>添加规则
  15. </button>
  16. </div>
  17. @endcan
  18. </div>
  19. <div class="panel-body">
  20. <div class="form-row">
  21. <div class="form-group col-xxl-1 col-lg-3 col-md-3 col-4">
  22. <select class="form-control" id="type" name="type" data-plugin="selectpicker" data-style="btn-outline btn-primary" onChange="Search()">
  23. <option value="" hidden>类型</option>
  24. <option value="1">正则表达式</option>
  25. <option value="2">域名</option>
  26. <option value="3">IP</option>
  27. <option value="4">协议</option>
  28. </select>
  29. </div>
  30. <div class="form-group col-xxl-1 col-lg-3 col-md-3 col-4">
  31. <a href="{{route('admin.rule.index')}}" class="btn btn-danger">重 置</a>
  32. </div>
  33. </div>
  34. <table class="text-md-center" data-toggle="table" data-mobile-responsive="true">
  35. <thead class="thead-default">
  36. <tr>
  37. <th> #</th>
  38. <th> 类型</th>
  39. <th> 描述</th>
  40. <th> 值</th>
  41. <th> 操作</th>
  42. </tr>
  43. </thead>
  44. <tbody>
  45. @foreach ($rules as $rule)
  46. <tr>
  47. <td> {{$rule->id}} </td>
  48. <td> {!! $rule->type_label !!} </td>
  49. <td>
  50. <input type="text" class="form-control" name="rule_name" id="rule_name_{{$rule->id}}" value="{{$rule->name}}"/>
  51. </td>
  52. <td>
  53. <input type="text" class="form-control" name="rule_pattern" id="rule_pattern_{{$rule->id}}" value="{{$rule->pattern}}"/>
  54. </td>
  55. <td>
  56. @canany(['admin.rule.update', 'admin.rule.destroy'])
  57. <div class="btn-group">
  58. @can('admin.rule.update')
  59. <button class="btn btn-sm btn-outline-primary" onclick="editRule('{{$rule->id}}')">
  60. <i class="icon wb-edit"></i></button>
  61. @endcan
  62. @can('admin.rule.destroy')
  63. <button class="btn btn-sm btn-outline-danger" onclick="delRule('{{route('admin.rule.destroy',$rule)}}','{{$rule->name}}')">
  64. <i class="icon wb-trash"></i></button>
  65. @endcan
  66. </div>
  67. @endcanany
  68. </td>
  69. </tr>
  70. @endforeach
  71. </tbody>
  72. </table>
  73. </div>
  74. <div class="panel-footer">
  75. <div class="row">
  76. <div class="col-sm-4">
  77. 共 <code>{{$rules->total()}}</code> 条审计规则
  78. </div>
  79. <div class="col-sm-8">
  80. <nav class="Page navigation float-right">
  81. {{$rules->links()}}
  82. </nav>
  83. </div>
  84. </div>
  85. </div>
  86. </div>
  87. </div>
  88. @can('admin.rule.store')
  89. <div class="modal fade" id="add" aria-hidden="true" role="dialog" tabindex="-1">
  90. <div class="modal-dialog modal-simple modal-center">
  91. <div class="modal-content">
  92. <div class="modal-header">
  93. <button type="button" class="close" data-dismiss="modal" aria-label="Close">
  94. <span aria-hidden="true">×</span>
  95. </button>
  96. <h4 class="modal-title">添加规则</h4>
  97. </div>
  98. <form action="#" method="post" class="modal-body">
  99. <div class="alert alert-danger" style="display: none;" id="msg"></div>
  100. <div class="form-row">
  101. <div class="col-12">
  102. <div class="form-group row">
  103. <label class="col-md-2 col-sm-3 col-form-label" for="add_type">类型</label>
  104. <div class="col-xl-4 col-sm-8">
  105. <select class="form-control" name="add_type" id="add_type" data-plugin="selectpicker" data-style="btn-outline btn-primary">
  106. <option value="1">正则表达式</option>
  107. <option value="2">域名</option>
  108. <option value="3">IP</option>
  109. <option value="4">协议</option>
  110. </select>
  111. </div>
  112. </div>
  113. <div class="form-group row">
  114. <label class="col-md-2 col-sm-3 col-form-label" for="name">描述</label>
  115. <div class="col-xl-6 col-sm-8">
  116. <input type="text" class="form-control" name="name" id="name" required/>
  117. </div>
  118. </div>
  119. </div>
  120. <div class="col-12">
  121. <div class="form-group row">
  122. <label class="col-md-2 col-sm-3 col-form-label" for="pattern">值</label>
  123. <div class="col-xl-6 col-sm-8">
  124. <input type="text" class="form-control" name="pattern" id="pattern" required/>
  125. </div>
  126. </div>
  127. </div>
  128. </div>
  129. </form>
  130. <div class="modal-footer">
  131. <button data-dismiss="modal" class="btn btn-danger">关 闭</button>
  132. <button type="button" class="btn btn-primary" onclick="addRule()">添 加</button>
  133. </div>
  134. </div>
  135. </div>
  136. </div>
  137. @endcan
  138. @endsection
  139. @section('javascript')
  140. <script src="/assets/global/vendor/bootstrap-table/bootstrap-table.min.js"></script>
  141. <script src="/assets/global/vendor/bootstrap-table/extensions/mobile/bootstrap-table-mobile.min.js"></script>
  142. <script src="/assets/global/vendor/bootstrap-select/bootstrap-select.min.js"></script>
  143. <script src="/assets/global/js/Plugin/bootstrap-select.js"></script>
  144. <script>
  145. $(document).ready(function() {
  146. $('#type').selectpicker('val', {{Request::input('type')}});
  147. });
  148. @can('admin.rule.store')
  149. // 添加规则
  150. function addRule() {
  151. $.post("{{route('admin.rule.store')}}", {}, function(ret) {
  152. $('#add').modal('hide');
  153. if (ret.status === 'success') {
  154. swal.fire({title: ret.message, icon: 'success', timer: 1000, showConfirmButton: false}).then(() => window.location.reload());
  155. } else {
  156. swal.fire({title: ret.message, icon: 'error'}).then(() => window.location.reload());
  157. }
  158. });
  159. $.ajax({
  160. method: 'POST',
  161. url: "{{route('admin.rule.store')}}",
  162. data: {
  163. _token: '{{csrf_token()}}',
  164. type: $('#add_type').val(),
  165. name: $('#name').val(),
  166. pattern: $('#pattern').val(),
  167. },
  168. dataType: 'json',
  169. success: function(ret) {
  170. $('#add').modal('hide');
  171. if (ret.status === 'success') {
  172. swal.fire({title: ret.message, icon: 'success', timer: 1000, showConfirmButton: false}).then(() => window.location.reload());
  173. } else {
  174. swal.fire({title: ret.message, icon: 'error'}).then(() => window.location.reload());
  175. }
  176. },
  177. error: function(data) {
  178. $('#add').modal('hide');
  179. let str = '';
  180. const errors = data.responseJSON;
  181. if ($.isEmptyObject(errors) === false) {
  182. $.each(errors.errors, function(index, value) {
  183. str += '<li>' + value + '</li>';
  184. });
  185. swal.fire({title: '提示', html: str, icon: 'error', confirmButtonText: '{{trans('home.ticket_confirm')}}'});
  186. }
  187. },
  188. });
  189. }
  190. @endcan
  191. @can('admin.rule.update')
  192. // 编辑规则
  193. function editRule(id) {
  194. $.ajax({
  195. method: 'PUT',
  196. url: '{{route('admin.rule.update','')}}/' + id,
  197. data: {
  198. _token: '{{csrf_token()}}',
  199. rule_name: $('#rule_name_' + id).val(),
  200. rule_pattern: $('#rule_pattern_' + id).val(),
  201. },
  202. dataType: 'json',
  203. success: function(ret) {
  204. if (ret.status === 'success') {
  205. swal.fire({title: ret.message, icon: 'success', timer: 1000, showConfirmButton: false}).then(() => window.location.reload());
  206. } else {
  207. swal.fire({title: ret.message, icon: 'error'}).then(() => window.location.reload());
  208. }
  209. },
  210. error: function(data) {
  211. let str = '';
  212. const errors = data.responseJSON;
  213. if ($.isEmptyObject(errors) === false) {
  214. $.each(errors.errors, function(index, value) {
  215. str += '<li>' + value + '</li>';
  216. });
  217. swal.fire({title: '提示', html: str, icon: 'error', confirmButtonText: '{{trans('home.ticket_confirm')}}'});
  218. }
  219. },
  220. });
  221. }
  222. @endcan
  223. @can('admin.rule.destroy')
  224. // 删除规则
  225. function delRule(url, name) {
  226. swal.fire({
  227. title: '警告',
  228. text: '确定删除规则 【' + name + '】 ?',
  229. icon: 'warning',
  230. showCancelButton: true,
  231. cancelButtonText: '{{trans('home.ticket_close')}}',
  232. confirmButtonText: '{{trans('home.ticket_confirm')}}',
  233. }).then((result) => {
  234. if (result.value) {
  235. $.ajax({
  236. method: 'DELETE',
  237. url: url,
  238. data: {_token: '{{csrf_token()}}'},
  239. dataType: 'json',
  240. success: function(ret) {
  241. if (ret.status === 'success') {
  242. swal.fire({title: ret.message, icon: 'success', timer: 1000, showConfirmButton: false}).then(() => window.location.reload());
  243. } else {
  244. swal.fire({title: ret.message, icon: 'error'}).then(() => window.location.reload());
  245. }
  246. },
  247. });
  248. }
  249. });
  250. }
  251. @endcan
  252. //回车检测
  253. $(document).on('keypress', 'input', function(e) {
  254. if (e.which === 13) {
  255. Search();
  256. return false;
  257. }
  258. });
  259. // 搜索
  260. function Search() {
  261. window.location.href = '{{route('admin.rule.index')}}?type=' + $('#type').val();
  262. }
  263. </script>
  264. @endsection