Skip to content
Snippets Groups Projects
Select Git revision
  • 5ebdfdc4bb3e8c02c9ba98e2d30367a0c48dbac7
  • main default protected
  • step-3263
  • feature/plugins-cli
  • feature/vite
  • step-2484-peerreview
  • biest/issue-5051
  • tests/simplify-jsonapi-tests
  • fix/typo-in-1a70031
  • feature/broadcasting
  • database-seeders-and-factories
  • feature/peer-review-2
  • feature-feedback-jsonapi
  • feature/peerreview
  • feature/balloon-plus
  • feature/stock-images-unsplash
  • tic-2588
  • 5.0
  • 5.2
  • biest/unlock-blocks
  • biest-1514
21 results

FileType.php

Blame
  • 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.
    TaskGroupsDelete.php 1.02 KiB
    <?php
    
    namespace JsonApi\Routes\Courseware;
    
    use Courseware\TaskGroup;
    use JsonApi\Errors\AuthorizationFailedException;
    use JsonApi\Errors\RecordNotFoundException;
    use JsonApi\JsonApiController;
    use Psr\Http\Message\ResponseInterface as Response;
    use Psr\Http\Message\ServerRequestInterface as Request;
    
    /**
     * Delete one TaskGroup.
     */
    class TaskGroupsDelete extends JsonApiController
    {
        /**
         * @param array $args
         * @return Response
         *
         * @SuppressWarnings(PHPMD.StaticAccess)
         * @SuppressWarnings(PHPMD.UnusedFormalParameter)
         */
        public function __invoke(Request $request, Response $response, $args)
        {
            /** @var ?TaskGroup $resource */
            $resource = TaskGroup::find($args['id']);
            if (!$resource) {
                throw new RecordNotFoundException();
            }
            if (!Authority::canDeleteTaskGroup($this->getUser($request), $resource)) {
                throw new AuthorizationFailedException();
            }
            $resource->delete();
    
            return $this->getCodeResponse(204);
        }
    }