This repository has been archived on 2024-01-19. You can view files and clone it, but cannot push or open issues or pull requests.
epubreader/lib/Controller/PreferenceController.php

95 lines
2.2 KiB
PHP
Raw Normal View History

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.
*/
namespace OCA\Epubreader\Controller;
2020-04-21 22:37:42 +02:00
2023-06-16 16:58:23 +02:00
use OCA\Epubreader\Service\PreferenceService;
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 PreferenceController extends Controller
{
2023-06-16 21:20:03 +02:00
private PreferenceService $preferenceService;
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
PreferenceService $preferenceService
) {
2020-04-21 22:37:42 +02:00
parent::__construct($AppName, $request);
2023-06-16 16:58:23 +02:00
$this->preferenceService = $preferenceService;
}
2020-04-21 22:37:42 +02:00
/**
2023-06-16 16:58:23 +02:00
* @brief return preference for $fileId
*
* @NoAdminRequired
* @NoCSRFRequired
*
2023-06-16 21:20:03 +02:00
* @param ?string $name if null, return all preferences for $scope + $fileId
2020-04-21 22:37:42 +02:00
*/
2023-08-02 22:04:03 +02:00
public function get(string $scope, int $fileId, ?string $name = null): JSONResponse
{
2023-06-16 21:20:03 +02:00
return new JSONResponse($this->preferenceService->get($scope, $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 write preference for $fileId
*
* @NoAdminRequired
* @NoCSRFRequired
2020-04-21 22:37:42 +02:00
*/
2023-08-02 22:04:03 +02:00
public function set(string $scope, int $fileId, string $name, string $value): JSONResponse
{
2023-06-16 21:20:03 +02:00
return new JSONResponse($this->preferenceService->set($scope, $fileId, $name, $value));
2020-04-21 22:37:42 +02:00
}
/**
2023-06-16 16:58:23 +02:00
* @brief return default preference
*
* @NoAdminRequired
* @NoCSRFRequired
*
* @param string $name if null, return all default preferences for scope
2020-04-21 22:37:42 +02:00
*/
2023-08-02 22:04:03 +02:00
public function getDefault(string $scope, string $name): JSONResponse
{
2023-06-16 21:20:03 +02:00
return new JSONResponse($this->preferenceService->getDefault($scope, $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 write default preference
*
* @NoAdminRequired
* @NoCSRFRequired
2020-04-21 22:37:42 +02:00
*/
2023-08-02 22:04:03 +02:00
public function setDefault(string $scope, string $name, string $value): JSONResponse
{
2023-06-16 21:20:03 +02:00
return new JSONResponse($this->preferenceService->setDefault($scope, $name, $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 preference
*/
2023-08-02 22:04:03 +02:00
public function delete(string $scope, int $fileId, string $name): void
{
2023-06-16 21:20:03 +02:00
$this->preferenceService->delete($scope, $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 default preference
*/
2023-08-02 22:04:03 +02:00
public function deleteDefault(string $scope, string $name): void
{
2023-06-16 21:20:03 +02:00
$this->preferenceService->deleteDefault($scope, $name);
2023-06-16 16:58:23 +02:00
}
2020-04-21 22:37:42 +02:00
}