Я создаю REST API с использованием Laravel, в котором есть несколько параметров для конечной точки в зависимости от роли пользователя.
В настоящее время проверяет это в Сервисах, используя условия if.
class UserService
{
public function update(array $attribute, $userId)
{
$userRepository = app(\App\Repositories\UserRepositoryInterface::class);
$user = $userRepository->get($userId);
$allowedUpdatableFieldForTeachers = ['name', 'age', 'graduated_at'];
$allowedUpdatableFieldForSupervisor = ['name', 'age', 'graduated_at', 'balance', 'salary'];
if ($user->role == 'teacher') {
$userRepository->update(Arr::only($attribute, $allowedUpdatableFieldForTeachers), $userId);
}
if ($user->role == 'supervisor') {
$userRepository->update(Arr::only($attribute, $allowedUpdatableFieldForSupervisor), $userId);
}
}
}
Однако это нарушает принцип единой ответственности.
Итак, какова лучшая практика / шаблон для решения этой проблемы.