123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155 |
- <?php
- namespace OCA\Files\Controller;
- use Exception;
- use OCA\Files\Service\DirectEditingService;
- use OCP\AppFramework\Http;
- use OCP\AppFramework\Http\DataResponse;
- use OCP\AppFramework\OCSController;
- use OCP\DirectEditing\IManager;
- use OCP\DirectEditing\RegisterDirectEditorEvent;
- use OCP\EventDispatcher\IEventDispatcher;
- use OCP\IRequest;
- use OCP\IURLGenerator;
- use Psr\Log\LoggerInterface;
- class DirectEditingController extends OCSController {
- public function __construct(
- string $appName,
- IRequest $request,
- string $corsMethods,
- string $corsAllowedHeaders,
- int $corsMaxAge,
- private IEventDispatcher $eventDispatcher,
- private IURLGenerator $urlGenerator,
- private IManager $directEditingManager,
- private DirectEditingService $directEditingService,
- private LoggerInterface $logger
- ) {
- parent::__construct($appName, $request, $corsMethods, $corsAllowedHeaders, $corsMaxAge);
- }
-
- public function info(): DataResponse {
- $response = new DataResponse($this->directEditingService->getDirectEditingCapabilitites());
- $response->setETag($this->directEditingService->getDirectEditingETag());
- return $response;
- }
-
- public function create(string $path, string $editorId, string $creatorId, ?string $templateId = null): DataResponse {
- if (!$this->directEditingManager->isEnabled()) {
- return new DataResponse(['message' => 'Direct editing is not enabled'], Http::STATUS_INTERNAL_SERVER_ERROR);
- }
- $this->eventDispatcher->dispatchTyped(new RegisterDirectEditorEvent($this->directEditingManager));
- try {
- $token = $this->directEditingManager->create($path, $editorId, $creatorId, $templateId);
- return new DataResponse([
- 'url' => $this->urlGenerator->linkToRouteAbsolute('files.DirectEditingView.edit', ['token' => $token])
- ]);
- } catch (Exception $e) {
- $this->logger->error(
- 'Exception when creating a new file through direct editing',
- [
- 'exception' => $e
- ],
- );
- return new DataResponse(['message' => 'Failed to create file: ' . $e->getMessage()], Http::STATUS_FORBIDDEN);
- }
- }
-
- public function open(string $path, ?string $editorId = null, ?int $fileId = null): DataResponse {
- if (!$this->directEditingManager->isEnabled()) {
- return new DataResponse(['message' => 'Direct editing is not enabled'], Http::STATUS_INTERNAL_SERVER_ERROR);
- }
- $this->eventDispatcher->dispatchTyped(new RegisterDirectEditorEvent($this->directEditingManager));
- try {
- $token = $this->directEditingManager->open($path, $editorId, $fileId);
- return new DataResponse([
- 'url' => $this->urlGenerator->linkToRouteAbsolute('files.DirectEditingView.edit', ['token' => $token])
- ]);
- } catch (Exception $e) {
- $this->logger->error(
- 'Exception when opening a file through direct editing',
- [
- 'exception' => $e
- ],
- );
- return new DataResponse(['message' => 'Failed to open file: ' . $e->getMessage()], Http::STATUS_FORBIDDEN);
- }
- }
-
- public function templates(string $editorId, string $creatorId): DataResponse {
- if (!$this->directEditingManager->isEnabled()) {
- return new DataResponse(['message' => 'Direct editing is not enabled'], Http::STATUS_INTERNAL_SERVER_ERROR);
- }
- $this->eventDispatcher->dispatchTyped(new RegisterDirectEditorEvent($this->directEditingManager));
- try {
- return new DataResponse($this->directEditingManager->getTemplates($editorId, $creatorId));
- } catch (Exception $e) {
- $this->logger->error(
- $e->getMessage(),
- [
- 'exception' => $e
- ],
- );
- return new DataResponse(['message' => 'Failed to obtain template list: ' . $e->getMessage()], Http::STATUS_INTERNAL_SERVER_ERROR);
- }
- }
- }
|