2020-04-21 22:37:42 +02:00
|
|
|
<?php
|
|
|
|
/**
|
|
|
|
* @author Frank de Lange
|
|
|
|
* @copyright 2017 Frank de Lange
|
|
|
|
*
|
|
|
|
* This file is licensed under the Affero General Public License version 3 or
|
|
|
|
* later.
|
|
|
|
* See the COPYING-README file.
|
|
|
|
*/
|
|
|
|
|
2020-04-21 23:45:26 +02:00
|
|
|
namespace OCA\Epubreader\Controller;
|
2020-04-21 22:37:42 +02:00
|
|
|
|
2023-06-16 16:58:23 +02:00
|
|
|
use OCA\Epubreader\Service\BookmarkService;
|
2020-04-21 22:37:42 +02:00
|
|
|
use OCP\AppFramework\Controller;
|
2023-06-16 21:20:03 +02:00
|
|
|
use OCP\AppFramework\Http\JSONResponse;
|
2023-06-16 16:58:23 +02:00
|
|
|
use OCP\IRequest;
|
2020-04-21 22:37:42 +02:00
|
|
|
|
2023-08-02 22:04:03 +02:00
|
|
|
class BookmarkController extends Controller
|
|
|
|
{
|
2023-06-16 21:20:03 +02:00
|
|
|
private BookmarkService $bookmarkService;
|
2020-04-21 22:37:42 +02:00
|
|
|
|
2023-06-16 21:20:03 +02:00
|
|
|
public function __construct(
|
|
|
|
string $AppName,
|
2023-06-16 16:58:23 +02:00
|
|
|
IRequest $request,
|
2023-06-16 21:20:03 +02:00
|
|
|
BookmarkService $bookmarkService
|
|
|
|
) {
|
2023-06-16 16:58:23 +02:00
|
|
|
parent::__construct($AppName, $request);
|
|
|
|
$this->bookmarkService = $bookmarkService;
|
|
|
|
}
|
2020-04-21 22:37:42 +02:00
|
|
|
|
|
|
|
/**
|
2023-06-16 16:58:23 +02:00
|
|
|
* @brief return bookmark
|
|
|
|
*
|
|
|
|
* @NoAdminRequired
|
|
|
|
* @NoCSRFRequired
|
2020-04-21 22:37:42 +02:00
|
|
|
*/
|
2023-08-02 22:04:03 +02:00
|
|
|
public function get(int $fileId, ?string $name = null, ?string $type = null): JSONResponse
|
|
|
|
{
|
2023-06-16 21:20:03 +02:00
|
|
|
return new JSONResponse($this->bookmarkService->get($fileId, $name, $type));
|
2023-06-16 16:58:23 +02:00
|
|
|
}
|
2020-04-21 22:37:42 +02:00
|
|
|
|
|
|
|
/**
|
2023-06-16 16:58:23 +02:00
|
|
|
* @brief write bookmark
|
|
|
|
*
|
|
|
|
* @NoAdminRequired
|
|
|
|
* @NoCSRFRequired
|
2020-04-21 22:37:42 +02:00
|
|
|
*/
|
2023-08-02 22:04:03 +02:00
|
|
|
public function set(int $fileId, string $name, string $value, ?string $type = null, ?string $content = null): JSONResponse
|
|
|
|
{
|
2023-06-16 21:20:03 +02:00
|
|
|
return new JSONResponse($this->bookmarkService->set($fileId, $name, $value, $type, $content));
|
2020-04-21 22:37:42 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2023-06-16 16:58:23 +02:00
|
|
|
* @brief return cursor for $fileId
|
|
|
|
*
|
|
|
|
* @NoAdminRequired
|
|
|
|
* @NoCSRFRequired
|
2020-04-21 22:37:42 +02:00
|
|
|
*/
|
2023-08-02 22:04:03 +02:00
|
|
|
public function getCursor(int $fileId): JSONResponse
|
|
|
|
{
|
2023-06-16 21:20:03 +02:00
|
|
|
return new JSONResponse($this->bookmarkService->getCursor($fileId));
|
2023-06-16 16:58:23 +02:00
|
|
|
}
|
2020-04-21 22:37:42 +02:00
|
|
|
|
|
|
|
/**
|
2023-06-16 16:58:23 +02:00
|
|
|
* @brief write cursor for $fileId
|
|
|
|
*
|
|
|
|
* @NoAdminRequired
|
|
|
|
* @NoCSRFRequired
|
2020-04-21 22:37:42 +02:00
|
|
|
*/
|
2023-08-02 22:04:03 +02:00
|
|
|
public function setCursor(int $fileId, string $value): JSONResponse
|
|
|
|
{
|
2023-06-16 21:20:03 +02:00
|
|
|
return new JSONResponse($this->bookmarkService->setCursor($fileId, $value));
|
2023-06-16 16:58:23 +02:00
|
|
|
}
|
2020-04-21 22:37:42 +02:00
|
|
|
|
2023-06-16 16:58:23 +02:00
|
|
|
/**
|
|
|
|
* @brief delete bookmark
|
|
|
|
*
|
|
|
|
* @NoAdminRequired
|
|
|
|
* @NoCSRFRequired
|
|
|
|
*/
|
2023-08-02 22:04:03 +02:00
|
|
|
public function delete(int $fileId, string $name): void
|
|
|
|
{
|
2023-06-16 21:20:03 +02:00
|
|
|
$this->bookmarkService->delete($fileId, $name);
|
2023-06-16 16:58:23 +02:00
|
|
|
}
|
2020-04-21 22:37:42 +02:00
|
|
|
|
2023-06-16 16:58:23 +02:00
|
|
|
/**
|
|
|
|
* @brief delete cursor
|
|
|
|
*
|
|
|
|
* @NoAdminRequired
|
|
|
|
* @NoCSRFRequired
|
|
|
|
*/
|
2023-08-02 22:04:03 +02:00
|
|
|
public function deleteCursor(int $fileId): void
|
|
|
|
{
|
2023-06-16 21:20:03 +02:00
|
|
|
$this->bookmarkService->deleteCursor($fileId);
|
2023-06-16 16:58:23 +02:00
|
|
|
}
|
2020-04-21 22:37:42 +02:00
|
|
|
}
|