Select Git revision
StructuralElementsCreate.php
Forked from
Stud.IP / Stud.IP
Source project has a limited visibility.
Code owners
Assign users and groups as approvers for specific file changes. Learn more.
StructuralElementsSharedIndex.php 2.24 KiB
<?php
namespace JsonApi\Routes\Courseware;
use Courseware\StructuralElement;
use JsonApi\Errors\AuthorizationFailedException;
use JsonApi\JsonApiController;
use Psr\Http\Message\ResponseInterface as Response;
use Psr\Http\Message\ServerRequestInterface as Request;
/**
* Class StructuralElementsSharedIndex.
*/
class StructuralElementsSharedIndex extends JsonApiController
{
protected $allowedPagingParameters = ['offset', 'limit'];
protected $allowedIncludePaths = [
'ancestors',
'children',
'containers',
'containers.blocks',
'containers.blocks.edit-blocker',
'containers.blocks.editor',
'containers.blocks.owner',
'containers.blocks.user-data-field',
'containers.blocks.user-progress',
'course',
'editor',
'owner',
'parent',
];
/**
* @SuppressWarnings(PHPMD.UnusedFormalParameter)
*/
public function __invoke(Request $request, Response $response, $args)
{
$user = $this->getUser($request);
if (!Authority::canIndexStructuralElementsShared($user)) {
throw new AuthorizationFailedException();
}
list($offset, $limit) = $this->getOffsetAndLimit();
$resources = [];
$contents = StructuralElement::findBySQL(
'range_id != ? AND range_type = ? ORDER BY mkdate DESC',
[$user->id, 'user']
);
foreach ($contents as $content) {
if (!count($content->read_approval) || !count($content->write_approval)) {
continue;
}
$add_content = false;
foreach ($content->read_approval['users'] as $listedUserPerm) {
if ($listedUserPerm['id'] == $user->id && $listedUserPerm['read']) {
$add_content = true;
}
}
foreach ($content->write_approval['users'] as $listedUserPerm) {
if ($listedUserPerm['id'] == $user->id && $listedUserPerm['read']) {
$add_content = true;
}
}
if ($add_content) { $resources[] = $content;
}
}
return $this->getPaginatedContentResponse($resources, count($resources));
}
}