Passed
Pull Request — develop (#11)
by
unknown
02:43
created

Invitation::scopeOfStudentInCourse()   A

Complexity

Conditions 1
Paths 1

Size

Total Lines 5
Code Lines 3

Duplication

Lines 0
Ratio 0 %

Importance

Changes 0
Metric Value
cc 1
eloc 3
nc 1
nop 3
dl 0
loc 5
rs 10
c 0
b 0
f 0
1
<?php
2
3
namespace App\Judite\Models;
4
5
use Illuminate\Support\Facades\DB;
6
use Illuminate\Database\Eloquent\Model;
7
use App\Exceptions\UserHasAlreadyAnInviteInGroupException;
8
9
class Invitation extends Model
10
{
11
    /**
12
     * Get the student of this invitation.
13
     *
14
     * @return \Illuminate\Database\Eloquent\Relations\BelongsTo
15
     */
16
    public function student()
17
    {
18
        return $this->belongsTo(Student::class);
19
    }
20
21
    /**
22
     * Get the group of this invitation.
23
     *
24
     * @return \Illuminate\Database\Eloquent\Relations\BelongsTo
25
     */
26
    public function group()
27
    {
28
        return $this->belongsTo(Group::class);
29
    }
30
31
    /**
32
     * Scope a query to get the student amount of invitations in a given course.
33
     *
34
     * @param \Illuminate\Database\Eloquent\Builder $query
35
     * @param string                                $studentNumber
36
     * @param int                                   $courseId
37
     *
38
     * @return \Illuminate\Database\Eloquent\Builder
39
     */
40
    public function scopeOfStudentInCourse($query, $studentNumber, $courseId)
41
    {
42
        return $query->where([
43
            ['course_id', '=', $courseId],
44
            ['student_number', '=', $studentNumber],
45
            ]);
46
    }
47
48
    /**
49
     * Saves new invitation.
50
     *
51
     * @param $studentNumber
52
     * @param $groupId
53
     * @param $courseId
54
     *
55
     * @throws \App\Exceptions\UserHasAlreadyAnInviteInGroupException
56
     *
57
     * @return invitation
58
     */
59
    public static function create($studentNumber, $groupId, $courseId)
60
    {
61
        $findAnyInvitation = DB::transaction(function () use ($studentNumber, $groupId) {
62
            return self::where([
63
                    ['student_number', $studentNumber],
64
                    ['group_id', $groupId],
65
                ]);
66
        });
67
68
        if ($findAnyInvitation->exists()) {
69
            throw new UserHasAlreadyAnInviteInGroupException();
70
        }
71
72
        $invitation = new self();
73
        $invitation->student_number = $studentNumber;
74
        $invitation->group_id = $groupId;
75
        $invitation->course_id = $courseId;
76
77
        $invitation->save();
78
79
        return $invitation;
80
    }
81
}
82