aboutsummaryrefslogtreecommitdiff
path: root/lib/classes/JsonApi/Routes/Courseware
diff options
context:
space:
mode:
Diffstat (limited to 'lib/classes/JsonApi/Routes/Courseware')
-rw-r--r--lib/classes/JsonApi/Routes/Courseware/CustomFilesCreate.php46
-rw-r--r--lib/classes/JsonApi/Routes/Courseware/CustomFilesDelete.php36
-rw-r--r--lib/classes/JsonApi/Routes/Courseware/CustomFilesList.php40
-rw-r--r--lib/classes/JsonApi/Routes/Courseware/CustomFilesShow.php38
-rw-r--r--lib/classes/JsonApi/Routes/Courseware/CustomFilesUpdate.php42
-rw-r--r--lib/classes/JsonApi/Routes/Courseware/CustomFilesUpdateAttributes.php47
6 files changed, 249 insertions, 0 deletions
diff --git a/lib/classes/JsonApi/Routes/Courseware/CustomFilesCreate.php b/lib/classes/JsonApi/Routes/Courseware/CustomFilesCreate.php
new file mode 100644
index 0000000..56615b3
--- /dev/null
+++ b/lib/classes/JsonApi/Routes/Courseware/CustomFilesCreate.php
@@ -0,0 +1,46 @@
+<?php
+
+namespace JsonApi\Routes\Courseware;
+
+use Courseware\Block;
+use Courseware\Filesystem\CustomFile;
+use JsonApi\Routes\Files\RoutesHelperTrait;
+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;
+
+/**
+ * Create a block in a container.
+ */
+class CustomFilesCreate extends JsonApiController
+{
+ use RoutesHelperTrait;
+
+ /**
+ * @SuppressWarnings(PHPMD.UnusedFormalParameter)
+ */
+ public function __invoke(Request $request, Response $response, $args)
+ {
+ if (!($resource = Block::find($args['id']))) {
+ throw new RecordNotFoundException();
+ }
+
+ if (!Authority::canUpdateBlock($this->getUser($request), $resource)) {
+ throw new AuthorizationFailedException();
+ }
+
+ $body = $request->getParsedBody();
+
+ $custom_file = new CustomFile(
+ null,
+ $args['id'],
+ $body['data']['attributes']
+ );
+
+ return $this->getContentResponse(
+ $resource->type->createCustomFile($custom_file)
+ );
+ }
+}
diff --git a/lib/classes/JsonApi/Routes/Courseware/CustomFilesDelete.php b/lib/classes/JsonApi/Routes/Courseware/CustomFilesDelete.php
new file mode 100644
index 0000000..f7e005d
--- /dev/null
+++ b/lib/classes/JsonApi/Routes/Courseware/CustomFilesDelete.php
@@ -0,0 +1,36 @@
+<?php
+
+namespace JsonApi\Routes\Courseware;
+
+use Courseware\Block;
+use JsonApi\Routes\Files\RoutesHelperTrait;
+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;
+
+/**
+ * Create a block in a container.
+ */
+class CustomFilesDelete extends JsonApiController
+{
+ use RoutesHelperTrait;
+
+ /**
+ * @SuppressWarnings(PHPMD.UnusedFormalParameter)
+ */
+ public function __invoke(Request $request, Response $response, $args)
+ {
+ if (!($resource = Block::find($args['id']))) {
+ throw new RecordNotFoundException();
+ }
+
+ if (!Authority::canUpdateBlock($user = $this->getUser($request), $resource)) {
+ throw new AuthorizationFailedException();
+ }
+
+ $resource->type->deleteCustomFile($args['id']);
+ return $response;
+ }
+}
diff --git a/lib/classes/JsonApi/Routes/Courseware/CustomFilesList.php b/lib/classes/JsonApi/Routes/Courseware/CustomFilesList.php
new file mode 100644
index 0000000..1d776c0
--- /dev/null
+++ b/lib/classes/JsonApi/Routes/Courseware/CustomFilesList.php
@@ -0,0 +1,40 @@
+<?php
+
+namespace JsonApi\Routes\Courseware;
+
+use Courseware\Block;
+use Courseware\CustomFiles;
+use JsonApi\Routes\Files\RoutesHelperTrait;
+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;
+
+/**
+ * Create a block in a container.
+ */
+class CustomFilesList extends JsonApiController
+{
+ use RoutesHelperTrait;
+
+ /**
+ * @SuppressWarnings(PHPMD.UnusedFormalParameter)
+ */
+ public function __invoke(Request $request, Response $response, $args)
+ {
+ if (!($resource = Block::find($args['id']))) {
+ throw new RecordNotFoundException();
+ }
+
+ if (!Authority::canShowBlock($user = $this->getUser($request), $resource)) {
+ throw new AuthorizationFailedException();
+ }
+
+ if (!$resource->type instanceof CustomFiles) {
+ return $response;
+ }
+
+ return $this->getContentResponse($resource->type->getCustomFiles());
+ }
+}
diff --git a/lib/classes/JsonApi/Routes/Courseware/CustomFilesShow.php b/lib/classes/JsonApi/Routes/Courseware/CustomFilesShow.php
new file mode 100644
index 0000000..0828bb7
--- /dev/null
+++ b/lib/classes/JsonApi/Routes/Courseware/CustomFilesShow.php
@@ -0,0 +1,38 @@
+<?php
+
+namespace JsonApi\Routes\Courseware;
+
+use Courseware\Block;
+use GuzzleHttp\Psr7;
+use JsonApi\Routes\Files\RoutesHelperTrait;
+use JsonApi\Errors\AuthorizationFailedException;
+use JsonApi\Errors\RecordNotFoundException;
+use JsonApi\NonJsonApiController;
+use Psr\Http\Message\ResponseInterface as Response;
+use Psr\Http\Message\ServerRequestInterface as Request;
+
+/**
+ * Create a block in a container.
+ */
+class CustomFilesShow extends NonJsonApiController
+{
+ use RoutesHelperTrait;
+
+ /**
+ * @SuppressWarnings(PHPMD.UnusedFormalParameter)
+ */
+ public function __invoke(Request $request, Response $response, $args)
+ {
+ if (!($resource = Block::find($args['id']))) {
+ throw new RecordNotFoundException();
+ }
+
+ if (!Authority::canShowBlock($user = $this->getUser($request), $resource)) {
+ throw new AuthorizationFailedException();
+ }
+
+ return $response->withBody(
+ $stream = Psr7\stream_for($resource->type->readCustomFile($args['id']))
+ );
+ }
+}
diff --git a/lib/classes/JsonApi/Routes/Courseware/CustomFilesUpdate.php b/lib/classes/JsonApi/Routes/Courseware/CustomFilesUpdate.php
new file mode 100644
index 0000000..72f3d4e
--- /dev/null
+++ b/lib/classes/JsonApi/Routes/Courseware/CustomFilesUpdate.php
@@ -0,0 +1,42 @@
+<?php
+
+namespace JsonApi\Routes\Courseware;
+
+use Courseware\Block;
+use JsonApi\Routes\Files\RoutesHelperTrait;
+use JsonApi\Errors\AuthorizationFailedException;
+use JsonApi\Errors\RecordNotFoundException;
+use JsonApi\NonJsonApiController;
+use Psr\Http\Message\ResponseInterface as Response;
+use Psr\Http\Message\ServerRequestInterface as Request;
+
+/**
+ * Create a block in a container.
+ */
+class CustomFilesUpdate extends NonJsonApiController
+{
+ use RoutesHelperTrait;
+
+ /**
+ * @SuppressWarnings(PHPMD.UnusedFormalParameter)
+ */
+ public function __invoke(Request $request, Response $response, $args)
+ {
+ if (!($resource = Block::find($args['id']))) {
+ throw new RecordNotFoundException();
+ }
+
+ if (!Authority::canUpdateBlock($user = $this->getUser($request), $resource)) {
+ throw new AuthorizationFailedException();
+ }
+
+ $uploadedFile = $this->getUploadedFile($request);
+
+ $resource->type->updateCustomFileContent(
+ $args['file_id'],
+ $content = file_get_contents($uploadedFile->getFilepath())
+ );
+
+ return $response;
+ }
+}
diff --git a/lib/classes/JsonApi/Routes/Courseware/CustomFilesUpdateAttributes.php b/lib/classes/JsonApi/Routes/Courseware/CustomFilesUpdateAttributes.php
new file mode 100644
index 0000000..cd1100b
--- /dev/null
+++ b/lib/classes/JsonApi/Routes/Courseware/CustomFilesUpdateAttributes.php
@@ -0,0 +1,47 @@
+<?php
+
+namespace JsonApi\Routes\Courseware;
+
+use Courseware\Block;
+use Courseware\Filesystem\CustomFile;
+use JsonApi\Routes\Files\RoutesHelperTrait;
+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;
+
+/**
+ * Create a block in a container.
+ */
+class CustomFilesUpdateAttributes extends JsonApiController
+{
+ use RoutesHelperTrait;
+
+ /**
+ * @SuppressWarnings(PHPMD.UnusedFormalParameter)
+ */
+ public function __invoke(Request $request, Response $response, $args)
+ {
+ if (!($resource = Block::find($args['id']))) {
+ throw new RecordNotFoundException();
+ }
+
+ if (!Authority::canUpdateBlock($user = $this->getUser($request), $resource)) {
+ throw new AuthorizationFailedException();
+ }
+
+ $body = $request->getParsedBody();
+
+ $custom_file = new CustomFile(
+ $body['data']['id'],
+ $args['id'],
+ $body['data']['attributes']
+ );
+
+ return $this->getContentResponse(
+ $resource->type->updateCustomFileMetadata(
+ $args['file_id'], $custom_file)
+ );
+ }
+}