%PDF- %PDF-
| Direktori : /www/varak.net/nextcloud.varak.net/apps_old/apps/privacy/lib/Controller/ |
| Current File : /www/varak.net/nextcloud.varak.net/apps_old/apps/privacy/lib/Controller/AdminController.php |
<?php
/**
* SPDX-FileCopyrightText: 2019 Nextcloud GmbH and Nextcloud contributors
* SPDX-License-Identifier: AGPL-3.0-or-later
*/
namespace OCA\Privacy\Controller;
use OCP\AppFramework\Controller;
use OCP\AppFramework\Http;
use OCP\AppFramework\Http\JSONResponse;
use OCP\IConfig;
use OCP\IDBConnection;
use OCP\IRequest;
/**
* Class AdminController
*
* @package OCA\Privacy\Controller
*/
class AdminController extends Controller {
/** @var IConfig */
private $config;
/** @var IDBConnection */
private $dbConnection;
/**
* AdminController constructor.
*
* @param string $appName
* @param IRequest $request
* @param IConfig $config
* @param IDBConnection $dbConnection
*/
public function __construct(string $appName, IRequest $request,
IConfig $config, IDBConnection $dbConnection) {
parent::__construct($appName, $request);
$this->config = $config;
$this->dbConnection = $dbConnection;
}
/**
* @param string $code
* @return JSONResponse
*/
public function setReadableLocation(string $code):JSONResponse {
$this->config->setAppValue($this->appName, 'readableLocation', $code);
return new JSONResponse([], Http::STATUS_OK);
}
/**
* @param string $name
* @return JSONResponse
*/
public function addAdditionalAdmin(string $name):JSONResponse {
$query = $this->dbConnection->getQueryBuilder();
$query->insert('privacy_admins')
->setValue('displayname', $query->createNamedParameter($name))
->execute();
$id = $query->getLastInsertId();
return new JSONResponse([
'id' => $id,
'displayname' => $name,
'internal' => false,
], Http::STATUS_CREATED);
}
/**
* @param int $id
* @return JSONResponse
*/
public function deleteAdditionalAdmin(int $id):JSONResponse {
$query = $this->dbConnection->getQueryBuilder();
$query->delete('privacy_admins')
->where($query->expr()->eq('id', $query->createNamedParameter($id)))
->execute();
return new JSONResponse([], Http::STATUS_OK);
}
/**
* @param string $enabled
* @return JSONResponse
*/
public function setFullDiskEncryption(string $enabled):JSONResponse {
$allowedValues = ['0', '1'];
if (!\in_array($enabled, $allowedValues, true)) {
return new JSONResponse([], HTTP::STATUS_NOT_ACCEPTABLE);
}
$this->config->setAppValue('privacy', 'fullDiskEncryptionEnabled', $enabled);
return new JSONResponse([], HTTP::STATUS_OK);
}
}