Issues (350)

app/Http/Controllers/GradeController.php (1 issue)

Labels
Severity
1
<?php
2
3
namespace App\Http\Controllers;
4
5
use App\Models\Course;
6
use App\Models\Enrollment;
7
use App\Models\Grade;
8
use Illuminate\Http\Request;
9
use Illuminate\Support\Facades\Gate;
10
11
class GradeController extends Controller
12
{
13
    /**
14
     * Show the form to edit grades for a course.
15
     *
16
     * Todo refactor to prevent the number of queries to depend upon the number of records
17
     */
18
    public function edit(Course $course)
19
    {
20
        $this->checkAccessForCourse($course);
21
22
        return view('grades.edit', [
23
            'enrollments' => $course->enrollments,
24
            'course_grade_types' => $course->grade_types->sortBy('id'),
0 ignored issues
show
The property grade_types does not seem to exist on App\Models\Course. Are you sure there is no database migration missing?

Checks if undeclared accessed properties appear in database migrations and if the creating migration is correct.

Loading history...
25
            'grades' => $course->grades,
26
            'course' => $course,
27
        ]);
28
    }
29
30
    /**
31
     * Update the specified resource in storage.
32
     */
33
    public function store(Request $request)
34
    {
35
        $request->validate([
36
            'grade_type_id' => 'required|numeric',
37
            'enrollment_id' => 'required|numeric',
38
            'value' => 'required|numeric|min:0',
39
        ]);
40
41
        $enrollment = Enrollment::findOrFail($request->input('enrollment_id'));
42
        $this->checkAccessForCourse($enrollment->course);
43
        $grade = Grade::firstOrNew([
44
            'grade_type_id' => $request->input('grade_type_id'),
45
            'enrollment_id' => $request->input('enrollment_id'),
46
        ]);
47
        $grade->grade = $request->input('value');
48
        $grade->save();
49
    }
50
51
    public function getEnrollmentTotal(Request $request)
52
    {
53
        $enrollment = Enrollment::findOrFail($request->input('enrollment_id'));
54
        $this->checkAccessForCourse($enrollment->course);
55
56
        return $enrollment->grades->sum('grade');
57
    }
58
59
    protected function checkAccessForCourse(Course $course): void
60
    {
61
        if (Gate::forUser(backpack_user())->denies('edit-course-grades', $course)) {
62
            abort(403);
63
        }
64
    }
65
}
66