1 | <?php |
||
25 | class Project |
||
26 | { |
||
27 | /** |
||
28 | * List of callbacks to handle the incoming request. |
||
29 | * |
||
30 | * @var array |
||
31 | */ |
||
32 | protected $callbacks = [ |
||
33 | 'Issue', |
||
34 | 'IssueFilter', |
||
35 | 'Note', |
||
36 | 'Project', |
||
37 | ]; |
||
38 | |||
39 | /** |
||
40 | * Handle an incoming request. |
||
41 | * |
||
42 | * @param Request $request |
||
43 | * @param \Closure $next |
||
44 | * |
||
45 | * @return mixed |
||
46 | */ |
||
47 | 39 | public function handle(Request $request, Closure $next) |
|
48 | { |
||
49 | // Current callback |
||
50 | 39 | $callback = current($this->callbacks); |
|
51 | 39 | $method = 'handle' . $callback . 'Request'; |
|
52 | |||
53 | 39 | if ($callback && !$this->$method($request)) { |
|
54 | |||
55 | // Current callback does not belong to the request - move next |
||
56 | 34 | next($this->callbacks); |
|
57 | |||
58 | 34 | return $this->handle($request, $next); |
|
59 | } |
||
60 | |||
61 | 39 | return $next($request); |
|
62 | } |
||
63 | |||
64 | /** |
||
65 | * Whether or not the incoming request is valid project issue request. |
||
66 | * |
||
67 | * @param Request $request |
||
68 | * |
||
69 | * @return bool |
||
70 | */ |
||
71 | 39 | protected function handleIssueRequest(Request $request) |
|
75 | |||
76 | /** |
||
77 | * Whether or not a model entity relationship with the project is correct. |
||
78 | * |
||
79 | * @param Request $request |
||
80 | * @param string $entityName |
||
81 | * |
||
82 | * @throws \Symfony\Component\HttpKernel\Exception\HttpException |
||
83 | * @throws \Symfony\Component\HttpKernel\Exception\NotFoundHttpException |
||
84 | * |
||
85 | * @return bool |
||
86 | */ |
||
87 | 39 | protected function isBelongToProject(Request $request, $entityName) |
|
88 | { |
||
89 | /** @var Model $entity */ |
||
90 | 39 | $entity = $request->route()->getParameter($entityName); |
|
91 | |||
92 | /** @var ProjectModel|null $project */ |
||
93 | 39 | $project = $request->route()->getParameter('project'); |
|
94 | |||
95 | 39 | if (!$entity instanceof Model || !$project instanceof ProjectModel) { |
|
96 | 34 | return false; |
|
97 | } |
||
98 | |||
99 | // Abort request invalid data |
||
100 | 21 | if ($entity->project_id !== $project->id) { |
|
101 | 2 | abort(401); |
|
102 | } |
||
103 | |||
104 | 20 | return true; |
|
105 | } |
||
106 | |||
107 | /** |
||
108 | * Whether or not the incoming uri is for the issue filter "project/issue/{issue}". |
||
109 | * |
||
110 | * @param Request $request |
||
111 | * |
||
112 | * @return bool |
||
113 | */ |
||
114 | 34 | protected function handleIssueFilterRequest(Request $request) |
|
132 | |||
133 | /** |
||
134 | * Whether or not the incoming request is valid project note request. |
||
135 | * |
||
136 | * @param Request $request |
||
137 | * |
||
138 | * @return bool |
||
139 | */ |
||
140 | 33 | protected function handleNoteRequest(Request $request) |
|
144 | |||
145 | /** |
||
146 | * Whether or not the incoming request is valid project note request. |
||
147 | * |
||
148 | * @param Request $request |
||
149 | * |
||
150 | * @return bool |
||
151 | */ |
||
152 | 33 | protected function handleProjectRequest(Request $request) |
|
163 | } |
||
164 |