diff options
Diffstat (limited to 'lib/Controller/PersonalController.php')
-rw-r--r-- | lib/Controller/PersonalController.php | 123 |
1 files changed, 123 insertions, 0 deletions
diff --git a/lib/Controller/PersonalController.php b/lib/Controller/PersonalController.php new file mode 100644 index 0000000..84a456a --- /dev/null +++ b/lib/Controller/PersonalController.php @@ -0,0 +1,123 @@ +<?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) { + $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); + } + +} |