%PDF- %PDF-
| Direktori : /www/old2/_muzikoterapie/uloziste.eacm.cz/apps/serverinfo/lib/Controller/ |
| Current File : /www/old2/_muzikoterapie/uloziste.eacm.cz/apps/serverinfo/lib/Controller/ApiController.php |
<?php
declare(strict_types=1);
/**
* @copyright Copyright (c) 2016 Bjoern Schiessle <bjoern@schiessle.org>
*
* @license GNU AGPL version 3 or any later version
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU Affero General Public License as
* published by the Free Software Foundation, either version 3 of the
* License, or (at your option) any later version.
*
* This program 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 program. If not, see <http://www.gnu.org/licenses/>.
*
*/
namespace OCA\ServerInfo\Controller;
use OCA\ServerInfo\DatabaseStatistics;
use OCA\ServerInfo\Os;
use OCA\ServerInfo\PhpStatistics;
use OCA\ServerInfo\SessionStatistics;
use OCA\ServerInfo\ShareStatistics;
use OCA\ServerInfo\StorageStatistics;
use OCA\ServerInfo\SystemStatistics;
use OCP\AppFramework\Http;
use OCP\AppFramework\Http\DataResponse;
use OCP\AppFramework\OCSController;
use OCP\IConfig;
use OCP\IGroupManager;
use OCP\IRequest;
use OCP\IUserSession;
class ApiController extends OCSController {
private Os $os;
private IConfig $config;
private IGroupManager $groupManager;
private ?IUserSession $userSession;
private SystemStatistics $systemStatistics;
private StorageStatistics $storageStatistics;
private PhpStatistics $phpStatistics;
private DatabaseStatistics $databaseStatistics;
private ShareStatistics $shareStatistics;
private SessionStatistics $sessionStatistics;
/**
* ApiController constructor.
*/
public function __construct(string $appName,
IRequest $request,
IConfig $config,
IGroupManager $groupManager,
?IUserSession $userSession,
Os $os,
SystemStatistics $systemStatistics,
StorageStatistics $storageStatistics,
PhpStatistics $phpStatistics,
DatabaseStatistics $databaseStatistics,
ShareStatistics $shareStatistics,
SessionStatistics $sessionStatistics) {
parent::__construct($appName, $request);
$this->config = $config;
$this->groupManager = $groupManager;
$this->userSession = $userSession;
$this->os = $os;
$this->systemStatistics = $systemStatistics;
$this->storageStatistics = $storageStatistics;
$this->phpStatistics = $phpStatistics;
$this->databaseStatistics = $databaseStatistics;
$this->shareStatistics = $shareStatistics;
$this->sessionStatistics = $sessionStatistics;
}
/**
* Check if authorized to view serverinfo API.
*/
private function checkAuthorized(): bool {
// check for monitoring privilege
$token = $this->request->getHeader('NC-Token');
if (!empty($token)) {
$storedToken = $this->config->getAppValue('serverinfo', 'token', '');
if (hash_equals($storedToken, $token)) {
return true;
}
}
// fallback to admin privilege
$userSession = $this->userSession;
if ($userSession === null) {
return false;
}
$user = $userSession->getUser();
if ($user === null) {
return false;
}
return $this->groupManager->isAdmin($user->getUID());
}
/**
* @NoCSRFRequired
* @NoAdminRequired
* @PublicPage
* @BruteForceProtection(action=serverinfo)
*/
public function info(): DataResponse {
if (!$this->checkAuthorized()) {
$response = new DataResponse(['message' => 'Unauthorized']);
$response->throttle();
$response->setStatus(Http::STATUS_UNAUTHORIZED);
return $response;
}
return new DataResponse([
'nextcloud' => [
'system' => $this->systemStatistics->getSystemStatistics(),
'storage' => $this->storageStatistics->getStorageStatistics(),
'shares' => $this->shareStatistics->getShareStatistics()
],
'server' => [
'webserver' => $this->getWebserver(),
'php' => $this->phpStatistics->getPhpStatistics(),
'database' => $this->databaseStatistics->getDatabaseStatistics()
],
'activeUsers' => $this->sessionStatistics->getSessionStatistics()
]);
}
public function BasicData(): DataResponse {
$servertime = $this->os->getTime();
$uptime = $this->formatUptime($this->os->getUptime());
$thermalzones = $this->os->getThermalZones();
return new DataResponse([
'servertime' => $servertime,
'uptime' => $uptime,
'thermalzones' => $thermalzones
]);
}
public function DiskData(): DataResponse {
$result = $this->os->getDiskData();
return new DataResponse($result);
}
/**
* Get webserver information
*/
private function getWebserver(): string {
if (isset($_SERVER['SERVER_SOFTWARE'])) {
return $_SERVER['SERVER_SOFTWARE'];
}
return 'unknown';
}
/**
* Return the uptime of the system as human readable value
*/
private function formatUptime(int $uptime): string {
if ($uptime === -1) {
return 'Unknown';
}
try {
$boot = new \DateTime($uptime . ' seconds ago');
} catch (\Exception $e) {
return 'Unknown';
}
$interval = $boot->diff(new \DateTime());
if ($interval->days > 0) {
return $interval->format('%a days, %h hours, %i minutes, %s seconds');
}
return $interval->format('%h hours, %i minutes, %s seconds');
}
}