Skip to content
Snippets Groups Projects
Commit f2a7c979 authored by Jan-Hendrik Willms's avatar Jan-Hendrik Willms
Browse files

add semester filter to user courses route, fixes #2572

Closes #2572

Merge request studip/studip!1733
parent 796233dd
No related branches found
No related tags found
No related merge requests found
...@@ -2,11 +2,15 @@ ...@@ -2,11 +2,15 @@
namespace JsonApi\Routes\Courses; namespace JsonApi\Routes\Courses;
use Course;
use JsonApi\Errors\AuthorizationFailedException; use JsonApi\Errors\AuthorizationFailedException;
use JsonApi\Errors\BadRequestException;
use JsonApi\Errors\RecordNotFoundException; use JsonApi\Errors\RecordNotFoundException;
use JsonApi\JsonApiController; use JsonApi\JsonApiController;
use Psr\Http\Message\ResponseInterface as Response; use Psr\Http\Message\ResponseInterface as Response;
use Psr\Http\Message\ServerRequestInterface as Request; use Psr\Http\Message\ServerRequestInterface as Request;
use Semester;
use User;
class CoursesByUserIndex extends JsonApiController class CoursesByUserIndex extends JsonApiController
{ {
...@@ -31,12 +35,14 @@ class CoursesByUserIndex extends JsonApiController ...@@ -31,12 +35,14 @@ class CoursesByUserIndex extends JsonApiController
protected $allowedPagingParameters = ['offset', 'limit']; protected $allowedPagingParameters = ['offset', 'limit'];
protected $allowedFilteringParameters = ['semester'];
/** /**
* @SuppressWarnings(PHPMD.UnusedFormalParameter) * @SuppressWarnings(PHPMD.UnusedFormalParameter)
*/ */
public function __invoke(Request $request, Response $response, array $args): Response public function __invoke(Request $request, Response $response, array $args): Response
{ {
if (!$user = \User::find($args['id'])) { if (!$user = User::find($args['id'])) {
throw new RecordNotFoundException(); throw new RecordNotFoundException();
} }
...@@ -44,14 +50,65 @@ class CoursesByUserIndex extends JsonApiController ...@@ -44,14 +50,65 @@ class CoursesByUserIndex extends JsonApiController
throw new AuthorizationFailedException(); throw new AuthorizationFailedException();
} }
$courses = $this->findCoursesByUser($user); if ($error = $this->validateFilters()) {
throw new BadRequestException($error);
}
$courses = $this->findCoursesByUser(
$user,
$this->getSemesterFilter()
);
list($offset, $limit) = $this->getOffsetAndLimit(); list($offset, $limit) = $this->getOffsetAndLimit();
return $this->getPaginatedContentResponse(array_slice($courses, $offset, $limit), count($courses)); return $this->getPaginatedContentResponse(
array_slice($courses, $offset, $limit),
count($courses)
);
}
private function validateFilters()
{
$filtering = $this->getQueryParameters()->getFilteringParameters() ?: [];
// semester
if (isset($filtering['semester'])) {
if (!Semester::exists($filtering['semester'])) {
return 'Invalid "semester".';
}
}
}
private function getSemesterFilter(): ?Semester
{
$filtering = $this->getQueryParameters()->getFilteringParameters();
if (!isset($filtering['semester'])) {
return null;
}
return Semester::find($filtering['semester']);
} }
private function findCoursesByUser(\User $user)
/**
* @param User $user
* @param Semester|null $semester
*
* @return Course[]
*/
private function findCoursesByUser(User $user, ?Semester $semester): array
{ {
return \Course::findMany($user->course_memberships->pluck('seminar_id'), 'ORDER BY start_time, name'); $courses = Course::findMany(
$user->course_memberships->pluck('seminar_id'),
'ORDER BY start_time, name'
);
if ($semester) {
$courses = array_filter($courses, function (Course $course) use ($semester): bool {
return $course->isInSemester($semester);
});
}
return $courses;
} }
} }
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment