migrate to gtea from bistbucket
This commit is contained in:
@@ -0,0 +1,75 @@
|
||||
<?php
|
||||
|
||||
namespace Modules\Authentication\Services;
|
||||
|
||||
use App\Traits\Authenticatable;
|
||||
use Illuminate\Support\Facades\DB;
|
||||
use Modules\Authentication\Interfaces\RoleInterface;
|
||||
use Spatie\Permission\Models\Permission;
|
||||
use Spatie\Permission\Models\Role;
|
||||
|
||||
final class RoleService implements RoleInterface
|
||||
{
|
||||
use Authenticatable;
|
||||
|
||||
public function __construct(
|
||||
protected Role $model
|
||||
) {}
|
||||
|
||||
public function index($request, int $perPage = 50)
|
||||
{
|
||||
$orderColumn = request('sort_column', 'id');
|
||||
$orderDirection = request('sort_direction', 'desc');
|
||||
|
||||
if (! in_array($orderColumn, ['id', 'name', 'created_at'])) {
|
||||
$orderColumn = 'id';
|
||||
}
|
||||
if (! in_array($orderDirection, ['asc', 'desc'])) {
|
||||
$orderDirection = 'desc';
|
||||
}
|
||||
|
||||
return $this->model::query()
|
||||
// ->where('restaurant_id', auth()->user()->restaurant_id)
|
||||
->with(['permissions'])
|
||||
->when($request->search, function ($query) use ($request) {
|
||||
$query->where('name', 'like', $request->search.'%');
|
||||
})
|
||||
->orderBy($orderColumn, $orderDirection)
|
||||
->paginate($perPage);
|
||||
}
|
||||
|
||||
public function getById(int $id)
|
||||
{
|
||||
return $this->model::where('id', $id)->first();
|
||||
}
|
||||
|
||||
public function create(array $data)
|
||||
{
|
||||
$role = $this->model::create([
|
||||
'name' => $data['name'],
|
||||
'restaurant_id' => $this->getCurrentRestaurantId(),
|
||||
'guard_name' => 'web',
|
||||
'description' => $data['description'] ?? null,
|
||||
]);
|
||||
$role->permissions()->sync($data['permissions']);
|
||||
|
||||
return $role;
|
||||
}
|
||||
|
||||
public function update(int $id, array $data)
|
||||
{
|
||||
$model = $this->getById($id);
|
||||
$model->update($data);
|
||||
if (! empty($data['permissions'])) {
|
||||
$permissions = Permission::whereIn('id', $data['permissions'])->pluck('name')->toArray();
|
||||
$model->syncPermissions($permissions);
|
||||
}
|
||||
|
||||
return $model;
|
||||
}
|
||||
|
||||
public function delete(int $id)
|
||||
{
|
||||
return DB::table('roles')->where('id', $id)->delete();
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user