Blame view

app/Models/Auth/Role.php 1.68 KB
b7c7a5f6   Alexey Boroda   first commit
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
  <?php
  
  namespace App\Models\Auth;
  
  use EloquentFilter\Filterable;
  use Laratrust\LaratrustRole;
  use Laratrust\Traits\LaratrustRoleTrait;
  use Kyslik\ColumnSortable\Sortable;
  use Request;
  use Route;
  
  class Role extends LaratrustRole
  {
      use LaratrustRoleTrait;
      use Filterable;
      use Sortable;
      
      protected $table = 'roles';
  
      /**
       * The attributes that are mass assignable.
       *
       * @var array
       */
      protected $fillable = ['name', 'display_name', 'description'];
  
      /**
       * Define the filter provider globally.
       *
       * @return ModelFilter
       */
      public function modelFilter()
      {
          // Check if is api or web
          if (Request::is('api/*')) {
              $arr = array_reverse(explode('\\', explode('@', app()['api.router']->currentRouteAction())[0]));
              $folder = $arr[1];
              $file = $arr[0];
          } else {
              list($folder, $file) = explode('/', Route::current()->uri());
          }
  
          if (empty($folder) || empty($file)) {
              return $this->provideFilter();
          }
  
          $class = '\App\Filters\\' . ucfirst($folder) .'\\' . ucfirst($file);
  
          return $this->provideFilter($class);
      }
  
      /**
       * Scope to get all rows filtered, sorted and paginated.
       *
       * @param \Illuminate\Database\Eloquent\Builder $query
       * @param $sort
       *
       * @return \Illuminate\Database\Eloquent\Builder
       */
      public function scopeCollect($query, $sort = 'display_name')
      {
          $request = request();
  
          $input = $request->input();
          $limit = $request->get('limit', setting('general.list_limit', '25'));
  
          return $query->filter($input)->sortable($sort)->paginate($limit);
      }
  }