2017-09-14 22:21:00 +03:00
|
|
|
<?php
|
|
|
|
|
|
|
|
namespace App\Models\Auth;
|
|
|
|
|
2019-11-16 10:21:14 +03:00
|
|
|
use Laratrust\Models\LaratrustPermission;
|
2017-09-14 22:21:00 +03:00
|
|
|
use Laratrust\Traits\LaratrustPermissionTrait;
|
|
|
|
use Kyslik\ColumnSortable\Sortable;
|
2019-11-16 10:21:14 +03:00
|
|
|
use Lorisleiva\LaravelSearchString\Concerns\SearchString;
|
2017-09-14 22:21:00 +03:00
|
|
|
|
|
|
|
class Permission extends LaratrustPermission
|
|
|
|
{
|
2019-11-16 10:21:14 +03:00
|
|
|
use LaratrustPermissionTrait, SearchString, Sortable;
|
2017-09-14 22:21:00 +03:00
|
|
|
|
|
|
|
protected $table = 'permissions';
|
|
|
|
|
|
|
|
/**
|
|
|
|
* The attributes that are mass assignable.
|
|
|
|
*
|
|
|
|
* @var array
|
|
|
|
*/
|
|
|
|
protected $fillable = ['name', 'display_name', 'description'];
|
|
|
|
|
|
|
|
/**
|
|
|
|
* 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();
|
|
|
|
|
2019-11-16 10:21:14 +03:00
|
|
|
$search = $request->get('search');
|
|
|
|
$limit = $request->get('limit', setting('default.list_limit', '25'));
|
2017-09-14 22:21:00 +03:00
|
|
|
|
2019-11-16 10:21:14 +03:00
|
|
|
return $query->usingSearchString($search)->sortable($sort)->paginate($limit);
|
2017-09-14 22:21:00 +03:00
|
|
|
}
|
|
|
|
}
|