PermissionController.php 5.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176
  1. <?php
  2. namespace Dcat\Admin\Controllers;
  3. use Dcat\Admin\Admin;
  4. use Dcat\Admin\Form;
  5. use Dcat\Admin\Grid;
  6. use Dcat\Admin\IFrameGrid;
  7. use Dcat\Admin\Layout\Content;
  8. use Dcat\Admin\Models\Repositories\Permission;
  9. use Dcat\Admin\Tree;
  10. use Illuminate\Support\Str;
  11. class PermissionController extends AdminController
  12. {
  13. protected function title()
  14. {
  15. return trans('admin.permissions');
  16. }
  17. public function index(Content $content)
  18. {
  19. if (request(IFrameGrid::QUERY_NAME)) {
  20. return $content->body($this->iFrameGrid());
  21. }
  22. return $content
  23. ->title($this->title())
  24. ->description(trans('admin.list'))
  25. ->body($this->treeView());
  26. }
  27. protected function iFrameGrid()
  28. {
  29. $grid = new IFrameGrid(new Permission());
  30. $grid->id->sortable();
  31. $grid->slug;
  32. $grid->name;
  33. $grid->filter(function (Grid\Filter $filter) {
  34. $filter->like('slug');
  35. $filter->like('name');
  36. });
  37. return $grid;
  38. }
  39. protected function treeView()
  40. {
  41. $model = config('admin.database.permissions_model');
  42. return new Tree(new $model(), function (Tree $tree) {
  43. $tree->disableCreateButton();
  44. $tree->disableEditButton();
  45. $tree->branch(function ($branch) {
  46. $payload = "<div class='pull-left' style='min-width:310px'><b>{$branch['name']}</b>&nbsp;&nbsp;[<span class='text-primary'>{$branch['slug']}</span>]";
  47. $path = array_filter($branch['http_path']);
  48. if (! $path) {
  49. return $payload.'</div>&nbsp;';
  50. }
  51. $max = 3;
  52. if (count($path) > $max) {
  53. $path = array_slice($path, 0, $max);
  54. array_push($path, '...');
  55. }
  56. $method = $branch['http_method'] ?: [];
  57. $path = collect($path)->map(function ($path) use (&$method) {
  58. if (Str::contains($path, ':')) {
  59. [$me, $path] = explode(':', $path);
  60. $method = array_merge($method, explode(',', $me));
  61. }
  62. if ($path !== '...' && ! empty(config('admin.route.prefix'))) {
  63. $path = trim(admin_base_path($path), '/');
  64. }
  65. $color = Admin::color()->primaryDarker();
  66. return "<code style='color:{$color}'>$path</code>";
  67. })->implode('&nbsp;&nbsp;');
  68. $method = collect($method ?: ['ANY'])->unique()->map(function ($name) {
  69. return strtoupper($name);
  70. })->map(function ($name) {
  71. return "<span class='label bg-primary'>{$name}</span>";
  72. })->implode('&nbsp;').'&nbsp;';
  73. $payload .= "</div>&nbsp; $method<a class=\"dd-nodrag\">$path</a>";
  74. return $payload;
  75. });
  76. });
  77. }
  78. public function form()
  79. {
  80. return Form::make(new Permission(), function (Form $form) {
  81. $permissionTable = config('admin.database.permissions_table');
  82. $connection = config('admin.database.connection');
  83. $permissionModel = config('admin.database.permissions_model');
  84. $id = $form->getKey();
  85. $form->display('id', 'ID');
  86. $form->select('parent_id', trans('admin.parent_id'))
  87. ->options($permissionModel::selectOptions())
  88. ->saving(function ($v) {
  89. return (int) $v;
  90. });
  91. $form->text('slug', trans('admin.slug'))
  92. ->required()
  93. ->creationRules(['required', "unique:{$connection}.{$permissionTable}"])
  94. ->updateRules(['required', "unique:{$connection}.{$permissionTable},slug,$id"]);
  95. $form->text('name', trans('admin.name'))->required();
  96. $form->multipleSelect('http_method', trans('admin.http.method'))
  97. ->options($this->getHttpMethodsOptions())
  98. ->help(trans('admin.all_methods_if_empty'));
  99. $form->tags('http_path', trans('admin.http.path'))
  100. ->options($this->getRoutes());
  101. $form->display('created_at', trans('admin.created_at'));
  102. $form->display('updated_at', trans('admin.updated_at'));
  103. $form->disableViewButton();
  104. $form->disableViewCheck();
  105. });
  106. }
  107. public function getRoutes()
  108. {
  109. $prefix = config('admin.route.prefix');
  110. $container = collect();
  111. $routes = collect(app('router')->getRoutes())->map(function ($route) use ($prefix, $container) {
  112. if (! Str::startsWith($uri = $route->uri(), $prefix) && $prefix) {
  113. return;
  114. }
  115. if (! Str::contains($uri, '{')) {
  116. $route = Str::replaceFirst($prefix, '', $uri.'*');
  117. if ($route !== '*') {
  118. $container->push($route);
  119. }
  120. }
  121. return Str::replaceFirst($prefix, '', preg_replace('/{.*}+/', '*', $uri));
  122. });
  123. return $container->merge($routes)->filter()->all();
  124. }
  125. /**
  126. * Get options of HTTP methods select field.
  127. *
  128. * @return array
  129. */
  130. protected function getHttpMethodsOptions()
  131. {
  132. $permissionModel = config('admin.database.permissions_model');
  133. return array_combine($permissionModel::$httpMethods, $permissionModel::$httpMethods);
  134. }
  135. }