adds logging and policies
This commit is contained in:
@@ -6,8 +6,10 @@
|
||||
|
||||
use App\Http\Controllers\Controller;
|
||||
use App\Models\User;
|
||||
use App\Services\ActivityLogger;
|
||||
use Illuminate\Http\RedirectResponse;
|
||||
use Illuminate\Http\Request;
|
||||
use Illuminate\Support\Arr;
|
||||
use Laravel\Socialite\Facades\Socialite;
|
||||
|
||||
final class SocialiteController extends Controller
|
||||
@@ -37,6 +39,8 @@ public function callback(): RedirectResponse
|
||||
|
||||
auth()->login($user);
|
||||
|
||||
ActivityLogger::log('login', $user->id, metadata: ['email' => $user->email, 'firm_name' => Arr::get($azureUser, 'companyName')]);
|
||||
|
||||
return redirect('/');
|
||||
}
|
||||
|
||||
@@ -45,6 +49,8 @@ public function callback(): RedirectResponse
|
||||
*/
|
||||
public function logout(Request $request): RedirectResponse
|
||||
{
|
||||
ActivityLogger::log('logout', auth()->id());
|
||||
|
||||
auth()->logout();
|
||||
|
||||
$request->session()->invalidate();
|
||||
|
||||
@@ -7,8 +7,10 @@
|
||||
use App\Http\Requests\Screening\UpdateScreeningRequest;
|
||||
use App\Models\Category;
|
||||
use App\Models\Screening;
|
||||
use App\Services\ActivityLogger;
|
||||
use Illuminate\Http\RedirectResponse;
|
||||
use Illuminate\Http\Request;
|
||||
use Illuminate\Support\Arr;
|
||||
use Inertia\Inertia;
|
||||
use Inertia\Response;
|
||||
|
||||
@@ -23,6 +25,8 @@ public function store(Request $request): RedirectResponse
|
||||
'user_id' => auth()->id(),
|
||||
]);
|
||||
|
||||
ActivityLogger::log('screening_started', auth()->id());
|
||||
|
||||
return redirect()->route('screening.show', $screening);
|
||||
}
|
||||
|
||||
@@ -44,8 +48,10 @@ public function update(UpdateScreeningRequest $request, Screening $screening): R
|
||||
{
|
||||
$validated = $request->validated();
|
||||
|
||||
$this->saveAnswers($screening, $validated['answers']);
|
||||
$this->calculateAndUpdateScore($screening, $validated['answers']);
|
||||
$this->saveAnswers($screening, Arr::get($validated, 'answers'));
|
||||
$this->calculateAndUpdateScore($screening, Arr::get($validated, 'answers'));
|
||||
|
||||
ActivityLogger::log('screening_completed', auth()->id(), metadata: ['score' => $screening->score, 'passed' => $screening->passed]);
|
||||
|
||||
return redirect()->route('screening.result', $screening);
|
||||
}
|
||||
|
||||
@@ -6,9 +6,11 @@
|
||||
|
||||
use App\Http\Requests\Session\UpdateSessionRequest;
|
||||
use App\Models\Session;
|
||||
use App\Services\ActivityLogger;
|
||||
use App\Services\ScoringService;
|
||||
use Illuminate\Http\RedirectResponse;
|
||||
use Illuminate\Http\Request;
|
||||
use Illuminate\Support\Arr;
|
||||
use Inertia\Inertia;
|
||||
use Inertia\Response;
|
||||
|
||||
@@ -26,6 +28,8 @@ public function store(Request $request): RedirectResponse
|
||||
'status' => 'in_progress',
|
||||
]);
|
||||
|
||||
ActivityLogger::log('session_started', auth()->id(), sessionId: $session->id, categoryId: (int) $request->input('category_id'), metadata: ['category_id' => $request->input('category_id')]);
|
||||
|
||||
return redirect()->route('sessions.show', $session);
|
||||
}
|
||||
|
||||
@@ -42,6 +46,8 @@ public function show(Session $session): Response
|
||||
->orderBy('sort_order')
|
||||
->get();
|
||||
|
||||
ActivityLogger::log('step_viewed', auth()->id(), sessionId: $session->id, categoryId: $session->category_id, metadata: ['question_group_id' => $questionGroups->first()?->id]);
|
||||
|
||||
$answers = $session->answers()->get()->keyBy('question_id');
|
||||
|
||||
$scoringService = new ScoringService;
|
||||
@@ -62,16 +68,16 @@ public function update(UpdateSessionRequest $request, Session $session): Redirec
|
||||
{
|
||||
$validated = $request->validated();
|
||||
|
||||
if (isset($validated['basic_info'])) {
|
||||
$session->update(['basic_info' => $validated['basic_info']]);
|
||||
if (Arr::has($validated, 'basic_info')) {
|
||||
$session->update(['basic_info' => Arr::get($validated, 'basic_info')]);
|
||||
}
|
||||
|
||||
if (isset($validated['answers'])) {
|
||||
$this->saveAnswers($session, $validated['answers']);
|
||||
if (Arr::has($validated, 'answers')) {
|
||||
$this->saveAnswers($session, Arr::get($validated, 'answers'));
|
||||
}
|
||||
|
||||
if (isset($validated['additional_comments'])) {
|
||||
$session->update(['additional_comments' => $validated['additional_comments']]);
|
||||
if (Arr::has($validated, 'additional_comments')) {
|
||||
$session->update(['additional_comments' => Arr::get($validated, 'additional_comments')]);
|
||||
}
|
||||
|
||||
if ($request->boolean('complete')) {
|
||||
@@ -90,10 +96,15 @@ private function saveAnswers(Session $session, array $answers): void
|
||||
$session->answers()->updateOrCreate(
|
||||
['question_id' => (int) $questionId],
|
||||
[
|
||||
'value' => $answer['value'] ?? null,
|
||||
'text_value' => $answer['text_value'] ?? null,
|
||||
'value' => Arr::get($answer, 'value'),
|
||||
'text_value' => Arr::get($answer, 'text_value'),
|
||||
]
|
||||
);
|
||||
|
||||
ActivityLogger::log('answer_saved', auth()->id(), sessionId: $session->id, categoryId: $session->category_id, metadata: [
|
||||
'question_id' => (int) $questionId,
|
||||
'value' => Arr::get($answer, 'value'),
|
||||
]);
|
||||
}
|
||||
}
|
||||
|
||||
@@ -113,6 +124,8 @@ private function completeSession(Session $session): RedirectResponse
|
||||
'completed_at' => now(),
|
||||
]);
|
||||
|
||||
ActivityLogger::log('session_completed', auth()->id(), sessionId: $session->id, categoryId: $session->category_id, metadata: ['category_id' => $session->category_id, 'score' => $score, 'result' => $result]);
|
||||
|
||||
return redirect()->route('sessions.result', $session);
|
||||
}
|
||||
|
||||
|
||||
Reference in New Issue
Block a user