PermissionController.php 6.0 KB

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