Server IP : 184.154.167.98 / Your IP : 3.141.25.125 Web Server : Apache System : Linux pink.dnsnetservice.com 4.18.0-553.22.1.lve.1.el8.x86_64 #1 SMP Tue Oct 8 15:52:54 UTC 2024 x86_64 User : puertode ( 1767) PHP Version : 8.2.26 Disable Function : NONE MySQL : OFF | cURL : ON | WGET : ON | Perl : ON | Python : ON | Sudo : ON | Pkexec : ON Directory : /home/puertode/public_html/sesiones/apps/privacy/lib/Controller/ |
Upload File : |
<?php /** * Privacy App * * @author Georg Ehrke * @copyright 2019 Georg Ehrke <oc.list@georgehrke.com> * * 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\Privacy\Controller; use OCP\AppFramework\Controller; use OCP\AppFramework\Http; use OCP\AppFramework\Http\JSONResponse; use OCP\IConfig; use OCP\IDBConnection; use OCP\IGroupManager; use OCP\IRequest; /** * Class PersonalController * * @package OCA\Privacy\Controller */ class PersonalController extends Controller { /** @var IConfig */ private $config; /** @var IGroupManager */ private $groupManager; /** @var IDBConnection */ private $dbConnection; /** * PersonalController constructor. * * @param string $appName * @param IRequest $request * @param IConfig $config * @param IGroupManager $groupManager * @param IDBConnection $dbConnection */ public function __construct(string $appName, IRequest $request, IConfig $config, IGroupManager $groupManager, IDBConnection $dbConnection) { parent::__construct($appName, $request); $this->config = $config; $this->groupManager = $groupManager; $this->dbConnection = $dbConnection; } /** * @NoAdminRequired * * @return JSONResponse */ public function getReadableLocation():JSONResponse { $location = $this->config->getAppValue($this->appName, 'readableLocation'); if ($location === null) { return new JSONResponse([], Http::STATUS_NOT_FOUND); } return new JSONResponse([ 'code' => $location, ], Http::STATUS_OK); } /** * @NoAdminRequired * * @return JSONResponse */ public function getAdmins():JSONResponse { $adminGroup = $this->groupManager->get('admin'); // Admin Group should always exist, just catch for safety's sake if (!$adminGroup) { return new JSONResponse([]); } $adminUsers = $adminGroup->getUsers(); $uids = []; foreach($adminUsers as $adminUser) { if (!$adminUser->isEnabled()) { continue; } $uids[] = [ 'id' => $adminUser->getUID(), 'displayname' => $adminUser->getDisplayName(), 'internal' => true, ]; } $query = $this->dbConnection->getQueryBuilder(); $query->select(['id', 'displayname']) ->from('privacy_admins'); $stmt = $query->execute(); foreach($stmt->fetchAll(\PDO::FETCH_ASSOC) as $row) { $uids[] = [ 'id' => (int)$row['id'], 'displayname' => (string)$row['displayname'], 'internal' => false, ]; } return new JSONResponse($uids, Http::STATUS_OK); } }