nextcloud-app-radio/lib/Controller/SettingsController.php

158 lines
3.5 KiB
PHP
Raw Permalink Normal View History

<?php
2020-11-24 14:16:53 +00:00
/**
* Radio App
*
* @author Jonas Heinrich
* @copyright 2020 Jonas Heinrich <onny@project-insanity.org>
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU AFFERO GENERAL PUBLIC LICENSE
* License as published by the Free Software Foundation; either
* version 3 of the License, or any later version.
*
* This library is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU AFFERO GENERAL PUBLIC LICENSE for more details.
*
* You should have received a copy of the GNU Affero General Public
* License along with this library. If not, see <http://www.gnu.org/licenses/>.
*
*/
namespace OCA\Radio\Controller;
use Exception;
use OCP\AppFramework\ApiController;
use OCP\AppFramework\Http;
use OCP\AppFramework\Http\JSONResponse;
use OCP\IConfig;
use OCP\IL10N;
use OCP\IRequest;
use OCP\ILogger;
class SettingsController extends ApiController {
/** @var ILogger */
private $logger;
/** @var IConfig */
private $config;
/** @var string */
private $userId;
/**
* @var IL10N
*/
private $l;
/**
* @param string $appName
* @param IRequest $request
* @param string $userId
* @param ILogger $logger
* @param IConfig $config
* @param IL10N $l
*/
public function __construct(
$appName, $request, $userId, ILogger $logger, IConfig $config, IL10N $l
) {
parent::__construct($appName, $request);
$this->logger = $logger;
$this->config = $config;
$this->userId = $userId;
$this->l = $l;
}
private function getSetting(string $key, string $name, $default): JSONResponse {
try {
$userValue = $this->config->getUserValue(
$this->userId,
$this->appName,
$key,
$default
);
} catch (Exception $e) {
$this->logger->error($e->getMessage());
return new JSONResponse([], Http::STATUS_INTERNAL_SERVER_ERROR);
}
return new JSONResponse([$name => $userValue], Http::STATUS_OK);
}
private function setSetting($key, $value): JSONResponse {
try {
$this->config->setUserValue(
$this->userId,
$this->appName,
$key,
$value
);
} catch (Exception $e) {
return new JSONResponse(['status' => 'error'], Http::STATUS_INTERNAL_SERVER_ERROR);
}
return new JSONResponse(['status' => 'success'], Http::STATUS_OK);
}
/**
2020-10-27 12:43:30 +00:00
* set menu state
*
2020-10-27 12:43:30 +00:00
* @param string $menuState
* @return JSONResponse
*
* @NoAdminRequired
*/
2020-10-27 12:43:30 +00:00
public function setMenuState($menuState = ""): JSONResponse {
if ($menuState = 'SEARCH') {
return new JSONResponse(['status' => 'success'], Http::STATUS_OK);
2020-11-05 09:20:16 +00:00
};
2020-10-27 12:43:30 +00:00
$legalArguments = ['TOP', 'RECENT', 'NEW', 'FAVORITES', 'CATEGORIES'];
if (!in_array($menuState, $legalArguments)) {
2020-11-05 09:20:16 +00:00
return new JSONResponse(['status' => 'error'], Http::STATUS_BAD_REQUEST);
}
return $this->setSetting(
2020-10-27 12:43:30 +00:00
'menuState',
$menuState
);
}
/**
2020-10-27 12:43:30 +00:00
* get menu state
*
* @return JSONResponse
*
* @NoAdminRequired
*/
2020-10-27 12:43:30 +00:00
public function getMenuState(): JSONResponse {
return $this->getSetting('menuState', 'menuState', 'TOP');
}
2020-10-28 20:21:59 +00:00
/**
* set player volume
*
* @param string $playerVolume
* @return JSONResponse
*
* @NoAdminRequired
*/
public function setVolumeState($volumeState = "0.5"): JSONResponse {
return $this->setSetting(
'volumeState',
$volumeState
);
}
/**
* get player volume
*
* @return JSONResponse
*
* @NoAdminRequired
*/
public function getVolumeState(): JSONResponse {
return $this->getSetting('volumeState', 'volumeState', 0.5);
}
}