<?php
/**
- * @copyright Copyright (C) 2010-2021, the Friendica project
+ * @copyright Copyright (C) 2010-2022, the Friendica project
*
* @license GNU AGPL version 3 or any later version
*
use Friendica\Module\Special\HTTPException as ModuleHTTPException;
use Friendica\Network\HTTPException;
use Friendica\Util\DateTimeFormat;
+use Friendica\Util\HTTPInputData;
use Friendica\Util\HTTPSignature;
use Friendica\Util\Profiler;
use Friendica\Util\Strings;
-use GuzzleHttp\Psr7\Response;
use Psr\Log\LoggerInterface;
/**
$this->nickname = $nickname;
}
- public function isLoggedIn()
+ public function isLoggedIn(): bool
{
return local_user() && $this->user_id && ($this->user_id == local_user());
}
*
* @return bool true if user is an admin
*/
- public function isSiteAdmin()
+ public function isSiteAdmin(): bool
{
$admin_email = $this->config->get('config', 'admin_email');
/**
* Fetch the user id
- * @return int
+ * @return int User id
*/
- public function getLoggedInUserId()
+ public function getLoggedInUserId(): int
{
return $this->user_id;
}
/**
* Fetch the user nick name
- * @return string
+ * @return string User's nickname
*/
- public function getLoggedInUserNickname()
+ public function getLoggedInUserNickname(): string
{
return $this->nickname;
}
*
* @return int
*/
- public function getProfileOwner():int
+ public function getProfileOwner(): int
{
return $this->profile_owner;
}
*
* @return int
*/
- public function getContactId():int
+ public function getContactId(): int
{
return $this->contact_id;
}
*
* @return int
*/
- public function getTimeZone():string
+ public function getTimeZone(): string
{
return $this->timezone;
}
/**
* Fetch workerqueue information
*
- * @return array
+ * @return array Worker queue
*/
- public function getQueue()
+ public function getQueue(): array
{
return $this->queue ?? [];
}
/**
* Fetch a specific workerqueue field
*
- * @param string $index
- * @return mixed
+ * @param string $index Work queue record to fetch
+ * @return mixed Work queue item or NULL if not found
*/
public function getQueueValue(string $index)
{
/**
* The basepath of this app
*
- * @return string
+ * @return string Base path from configuration
*/
- public function getBasePath()
+ public function getBasePath(): string
{
// Don't use the basepath of the config table for basepath (it should always be the config-file one)
return $this->config->getCache()->get('system', 'basepath');
/**
* Returns the current theme name. May be overriden by the mobile theme name.
*
- * @return string
+ * @return string Current theme name or empty string in installation phase
* @throws Exception
*/
- public function getCurrentTheme()
+ public function getCurrentTheme(): string
{
if ($this->mode->isInstall()) {
return '';
/**
* Returns the current mobile theme name.
*
- * @return string
+ * @return string Mobile theme name or empty string if installer
* @throws Exception
*/
- public function getCurrentMobileTheme()
+ public function getCurrentMobileTheme(): string
{
if ($this->mode->isInstall()) {
return '';
return $this->currentMobileTheme;
}
- public function setCurrentTheme($theme)
+ /**
+ * Setter for current theme name
+ *
+ * @param string $theme Name of current theme
+ */
+ public function setCurrentTheme(string $theme)
{
$this->currentTheme = $theme;
}
- public function setCurrentMobileTheme($theme)
+ /**
+ * Setter for current mobile theme name
+ *
+ * @param string $theme Name of current mobile theme
+ */
+ public function setCurrentMobileTheme(string $theme)
{
$this->currentMobileTheme = $theme;
}
// Allow folks to override user themes and always use their own on their own site.
// This works only if the user is on the same server
$user = $this->database->selectFirst('user', ['theme'], ['uid' => $this->profile_owner]);
- if ($this->database->isResult($user) && !$this->pConfig->get(local_user(), 'system', 'always_my_theme')) {
+ if ($this->database->isResult($user) && !local_user()) {
$page_theme = $user['theme'];
}
}
if (!empty($this->profile_owner) && ($this->profile_owner != local_user())) {
// Allow folks to override user themes and always use their own on their own site.
// This works only if the user is on the same server
- if (!$this->pConfig->get(local_user(), 'system', 'always_my_theme')) {
+ if (!local_user()) {
$page_mobile_theme = $this->pConfig->get($this->profile_owner, 'system', 'mobile-theme');
}
}
/**
* Provide a sane default if nothing is chosen or the specified theme does not exist.
*
- * @return string
+ * @return string Current theme's stylsheet path
* @throws Exception
*/
- public function getCurrentThemeStylesheetPath()
+ public function getCurrentThemeStylesheetPath(): string
{
return Core\Theme::getStylesheetPath($this->getCurrentTheme());
}
*
* @param App\Router $router
* @param IManagePersonalConfigValues $pconfig
- * @param Authentication $auth The Authentication backend of the node
- * @param App\Page $page The Friendica page printing container
+ * @param Authentication $auth The Authentication backend of the node
+ * @param App\Page $page The Friendica page printing container
+ * @param HTTPInputData $httpInput A library for processing PHP input streams
+ * @param float $start_time The start time of the overall script execution
*
* @throws HTTPException\InternalServerErrorException
* @throws \ImagickException
*/
- public function runFrontend(App\Router $router, IManagePersonalConfigValues $pconfig, Authentication $auth, App\Page $page, float $start_time)
+ public function runFrontend(App\Router $router, IManagePersonalConfigValues $pconfig, Authentication $auth, App\Page $page, HTTPInputData $httpInput, float $start_time)
{
$this->profiler->set($start_time, 'start');
$this->profiler->set(microtime(true), 'classinit');
$moduleName = $this->args->getModuleName();
+ $page->setLogging($this->args->getCommand(), $this->args->getMethod());
try {
// Missing DB connection: ERROR
if ($this->mode->has(App\Mode::LOCALCONFIGPRESENT) && !$this->mode->has(App\Mode::DBAVAILABLE)) {
- throw new HTTPException\InternalServerErrorException('Apologies but the website is unavailable at the moment.');
+ throw new HTTPException\InternalServerErrorException($this->l10n->t('Apologies but the website is unavailable at the moment.'));
}
if (!$this->mode->isInstall()) {
}
// ZRL
- if (!empty($_GET['zrl']) && $this->mode->isNormal() && !$this->mode->isBackend()) {
- if (!local_user()) {
- // Only continue when the given profile link seems valid
- // Valid profile links contain a path with "/profile/" and no query parameters
- if ((parse_url($_GET['zrl'], PHP_URL_QUERY) == "") &&
- strstr(parse_url($_GET['zrl'], PHP_URL_PATH), "/profile/")) {
- if (Core\Session::get('visitor_home') != $_GET["zrl"]) {
- Core\Session::set('my_url', $_GET['zrl']);
- Core\Session::set('authenticated', 0);
-
- $remote_contact = Contact::getByURL($_GET['zrl'], false, ['subscribe']);
- if (!empty($remote_contact['subscribe'])) {
- $_SESSION['remote_comment'] = $remote_contact['subscribe'];
- }
+ if (!empty($_GET['zrl']) && $this->mode->isNormal() && !$this->mode->isBackend() && !local_user()) {
+ // Only continue when the given profile link seems valid
+ // Valid profile links contain a path with "/profile/" and no query parameters
+ if ((parse_url($_GET['zrl'], PHP_URL_QUERY) == '') &&
+ strstr(parse_url($_GET['zrl'], PHP_URL_PATH), '/profile/')) {
+ if (Core\Session::get('visitor_home') != $_GET['zrl']) {
+ Core\Session::set('my_url', $_GET['zrl']);
+ Core\Session::set('authenticated', 0);
+
+ $remote_contact = Contact::getByURL($_GET['zrl'], false, ['subscribe']);
+ if (!empty($remote_contact['subscribe'])) {
+ $_SESSION['remote_comment'] = $remote_contact['subscribe'];
}
-
- Model\Profile::zrlInit($this);
- } else {
- // Someone came with an invalid parameter, maybe as a DDoS attempt
- // We simply stop processing here
- $this->logger->debug('Invalid ZRL parameter.', ['zrl' => $_GET['zrl']]);
- throw new HTTPException\ForbiddenException();
}
+
+ Model\Profile::zrlInit($this);
+ } else {
+ // Someone came with an invalid parameter, maybe as a DDoS attempt
+ // We simply stop processing here
+ $this->logger->debug('Invalid ZRL parameter.', ['zrl' => $_GET['zrl']]);
+ throw new HTTPException\ForbiddenException();
}
}
header('X-Account-Management-Status: none');
}
- $_SESSION['sysmsg'] = Core\Session::get('sysmsg', []);
- $_SESSION['sysmsg_info'] = Core\Session::get('sysmsg_info', []);
- $_SESSION['last_updated'] = Core\Session::get('last_updated', []);
-
/*
* check_config() is responsible for running update scripts. These automatically
* update the DB schema whenever we push a new one out. It also checks to see if
// Initialize module that can set the current theme in the init() method, either directly or via App->setProfileOwner
$page['page_title'] = $moduleName;
- if (!$this->mode->isInstall() && !$this->mode->has(App\Mode::MAINTENANCEDISABLED)) {
+ // The "view" module is required to show the theme CSS
+ if (!$this->mode->isInstall() && !$this->mode->has(App\Mode::MAINTENANCEDISABLED) && $moduleName !== 'view') {
$module = $router->getModule(Maintenance::class);
} else {
// determine the module class and save it to the module instance
$module = $router->getModule();
}
+ // Processes data from GET requests
+ $httpinput = $httpInput->process();
+ $input = array_merge($httpinput['variables'], $httpinput['files'], $request ?? $_REQUEST);
+
// Let the module run it's internal process (init, get, post, ...)
- $response = $module->run($_POST, $_REQUEST);
+ $timestamp = microtime(true);
+ $response = $module->run($input);
+ $this->profiler->set(microtime(true) - $timestamp, 'content');
if ($response->getHeaderLine(ICanCreateResponses::X_HEADER) === ICanCreateResponses::TYPE_HTML) {
$page->run($this, $this->baseURL, $this->args, $this->mode, $response, $this->l10n, $this->profiler, $this->config, $pconfig);
} else {
} catch (HTTPException $e) {
(new ModuleHTTPException())->rawContent($e);
}
+ $page->logRuntime($this->config, 'runFrontend');
}
/**
*
* @throws HTTPException\InternalServerErrorException
*/
- public function redirect($toUrl)
+ public function redirect(string $toUrl)
{
if (!empty(parse_url($toUrl, PHP_URL_SCHEME))) {
Core\System::externalRedirect($toUrl);