adds logging and policies
This commit is contained in:
@@ -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