2019-05-02 00:01:43 -04:00
< ? php
2024-08-24 15:27:00 +02:00
// Copyright (C) 2010-2024, the Friendica project
// SPDX-FileCopyrightText: 2010-2024 the Friendica project
//
// SPDX-License-Identifier: AGPL-3.0-or-later
2019-05-02 00:01:43 -04:00
namespace Friendica\Module ;
use Friendica\BaseModule ;
use Friendica\Core\Addon ;
use Friendica\Core\Renderer ;
2019-12-15 22:34:11 +01:00
use Friendica\DI ;
2020-09-08 10:44:27 -04:00
use Friendica\Network\HTTPException ;
2019-05-31 00:16:07 -04:00
2019-05-02 00:01:43 -04:00
/**
* This abstract module is meant to be extended by all modules that are reserved to administrator users .
*
* It performs a blanket permission check in all the module methods as long as the relevant `parent::method()` is
* called in the inheriting module .
*
* Additionally , it puts together the administration page aside with all the administration links .
*
* @ package Friendica\Module
*/
2020-01-22 23:14:14 -05:00
abstract class BaseAdmin extends BaseModule
2019-05-02 00:01:43 -04:00
{
2020-09-08 10:44:27 -04:00
/**
2022-06-22 05:03:30 +02:00
* Checks admin access and throws exceptions if not logged - in administrator
*
2020-09-08 10:44:27 -04:00
* @ param bool $interactive
2022-06-22 05:03:30 +02:00
* @ return void
2020-09-08 10:44:27 -04:00
* @ throws HTTPException\ForbiddenException
* @ throws HTTPException\InternalServerErrorException
*/
public static function checkAdminAccess ( bool $interactive = false )
2019-05-02 00:01:43 -04:00
{
2022-10-20 22:59:12 +02:00
if ( ! DI :: userSession () -> getLocalUserId ()) {
2020-09-08 10:44:27 -04:00
if ( $interactive ) {
2022-10-17 18:55:22 +00:00
DI :: sysmsg () -> addNotice ( DI :: l10n () -> t ( 'Please login to continue.' ));
2022-10-19 09:00:43 -04:00
DI :: session () -> set ( 'return_path' , DI :: args () -> getQueryString ());
2020-09-08 10:44:27 -04:00
DI :: baseUrl () -> redirect ( 'login' );
} else {
throw new HTTPException\UnauthorizedException ( DI :: l10n () -> t ( 'Please login to continue.' ));
}
2019-05-02 00:01:43 -04:00
}
2024-05-14 08:37:10 +00:00
if ( ! DI :: userSession () -> isSiteAdmin ()) {
2020-09-08 10:44:27 -04:00
throw new HTTPException\ForbiddenException ( DI :: l10n () -> t ( 'You don\'t have access to administration pages.' ));
2019-05-02 00:01:43 -04:00
}
2022-10-21 19:33:28 +02:00
if ( DI :: userSession () -> getSubManagedUserId ()) {
2020-09-15 15:38:31 +02:00
throw new HTTPException\ForbiddenException ( DI :: l10n () -> t ( 'Submanaged account can\'t access the administration pages. Please log back in as the main account.' ));
2019-05-02 00:01:43 -04:00
}
}
2021-11-20 15:38:03 +01:00
protected function content ( array $request = []) : string
2019-05-02 00:01:43 -04:00
{
2020-09-08 10:44:27 -04:00
self :: checkAdminAccess ( true );
2019-05-02 00:01:43 -04:00
// Header stuff
2019-12-30 20:02:09 +01:00
DI :: page ()[ 'htmlhead' ] .= Renderer :: replaceMacros ( Renderer :: getMarkupTemplate ( 'admin/settings_head.tpl' ), []);
2019-05-02 00:01:43 -04:00
/*
* Side bar links
*/
// array(url, name, extra css classes)
// not part of $aside to make the template more adjustable
$aside_sub = [
2020-01-18 20:52:34 +01:00
'information' => [ DI :: l10n () -> t ( 'Information' ), [
'overview' => [ 'admin' , DI :: l10n () -> t ( 'Overview' ) , 'overview' ],
'federation' => [ 'admin/federation' , DI :: l10n () -> t ( 'Federation Statistics' ) , 'federation' ]
2019-05-02 00:01:43 -04:00
]],
2020-01-18 20:52:34 +01:00
'configuration' => [ DI :: l10n () -> t ( 'Configuration' ), [
'site' => [ 'admin/site' , DI :: l10n () -> t ( 'Site' ) , 'site' ],
2021-07-18 22:09:11 +02:00
'storage' => [ 'admin/storage' , DI :: l10n () -> t ( 'Storage' ) , 'storage' ],
2020-01-18 20:52:34 +01:00
'addons' => [ 'admin/addons' , DI :: l10n () -> t ( 'Addons' ) , 'addons' ],
'themes' => [ 'admin/themes' , DI :: l10n () -> t ( 'Themes' ) , 'themes' ],
'features' => [ 'admin/features' , DI :: l10n () -> t ( 'Additional features' ) , 'features' ],
'tos' => [ 'admin/tos' , DI :: l10n () -> t ( 'Terms of Service' ) , 'tos' ],
2019-05-02 00:01:43 -04:00
]],
2020-01-18 20:52:34 +01:00
'database' => [ DI :: l10n () -> t ( 'Database' ), [
'dbsync' => [ 'admin/dbsync' , DI :: l10n () -> t ( 'DB updates' ) , 'dbsync' ],
'deferred' => [ 'admin/queue/deferred' , DI :: l10n () -> t ( 'Inspect Deferred Workers' ), 'deferred' ],
'workerqueue' => [ 'admin/queue' , DI :: l10n () -> t ( 'Inspect worker Queue' ) , 'workerqueue' ],
2019-05-02 00:01:43 -04:00
]],
2020-01-18 20:52:34 +01:00
'logs' => [ DI :: l10n () -> t ( 'Logs' ), [
'logsconfig' => [ 'admin/logs/' , DI :: l10n () -> t ( 'Logs' ) , 'logs' ],
'logsview' => [ 'admin/logs/view' , DI :: l10n () -> t ( 'View Logs' ) , 'viewlogs' ],
2019-05-02 00:01:43 -04:00
]],
2020-01-18 20:52:34 +01:00
'diagnostics' => [ DI :: l10n () -> t ( 'Diagnostics' ), [
2024-02-22 00:53:52 -05:00
'phpinfo' => [ 'admin/phpinfo?t=' . self :: getFormSecurityToken ( 'phpinfo' ), DI :: l10n () -> t ( 'PHP Info' ) , 'phpinfo' ],
2020-01-18 20:52:34 +01:00
'probe' => [ 'probe' , DI :: l10n () -> t ( 'probe address' ) , 'probe' ],
'webfinger' => [ 'webfinger' , DI :: l10n () -> t ( 'check webfinger' ) , 'webfinger' ],
'babel' => [ 'babel' , DI :: l10n () -> t ( 'Babel' ) , 'babel' ],
2020-07-20 00:39:17 -04:00
'debug/ap' => [ 'debug/ap' , DI :: l10n () -> t ( 'ActivityPub Conversion' ) , 'debug/ap' ],
2019-05-02 00:01:43 -04:00
]],
];
$t = Renderer :: getMarkupTemplate ( 'admin/aside.tpl' );
2019-12-30 20:02:09 +01:00
DI :: page ()[ 'aside' ] .= Renderer :: replaceMacros ( $t , [
2019-05-02 00:01:43 -04:00
'$admin' => [ 'addons_admin' => Addon :: getAdminList ()],
'$subpages' => $aside_sub ,
2020-01-18 20:52:34 +01:00
'$admtxt' => DI :: l10n () -> t ( 'Admin' ),
'$plugadmtxt' => DI :: l10n () -> t ( 'Addon Features' ),
'$h_pending' => DI :: l10n () -> t ( 'User registrations waiting for confirmation' ),
2019-05-02 00:01:43 -04:00
'$admurl' => 'admin/'
]);
return '' ;
}
}