diff --git a/bin/auth_ejabberd.php b/bin/auth_ejabberd.php
index bc976e61a4..595ccf204a 100755
--- a/bin/auth_ejabberd.php
+++ b/bin/auth_ejabberd.php
@@ -52,4 +52,4 @@ $container = \Friendica\Core\DiceContainer::fromBasePath(dirname(__DIR__));
$app = \Friendica\App::fromContainer($container);
-$app->processEjabberd();
+$app->processEjabberd($_SERVER);
diff --git a/bin/console.php b/bin/console.php
index ad612f4363..a20f3f7e02 100755
--- a/bin/console.php
+++ b/bin/console.php
@@ -19,4 +19,4 @@ $container = \Friendica\Core\DiceContainer::fromBasePath(dirname(__DIR__));
$app = \Friendica\App::fromContainer($container);
-$app->processConsole($_SERVER['argv'] ?? []);
+$app->processConsole($_SERVER);
diff --git a/bin/daemon.php b/bin/daemon.php
index 546f207e08..162a92948f 100755
--- a/bin/daemon.php
+++ b/bin/daemon.php
@@ -6,7 +6,7 @@
*
* SPDX-License-Identifier: AGPL-3.0-or-later
*
- * @deprecated 2025.02 use bin/console.php daemon instead
+ * @deprecated 2025.02 use `bin/console.php daemon` instead
*/
/**
@@ -24,11 +24,15 @@ chdir(dirname(__DIR__));
require dirname(__DIR__) . '/vendor/autoload.php';
+fwrite(STDOUT, '`bin/daemon.php` is deprecated since 2024.02 and will be removed in 5 months, please use `bin/console.php daemon` instead.' . \PHP_EOL);
+
+// BC: Add console command as second argument
$argv = $_SERVER['argv'] ?? [];
array_splice($argv, 1, 0, "daemon");
+$_SERVER['argv'] = $argv;
$container = \Friendica\Core\DiceContainer::fromBasePath(dirname(__DIR__));
$app = \Friendica\App::fromContainer($container);
-$app->processConsole($argv);
+$app->processConsole($_SERVER);
diff --git a/bin/jetstream.php b/bin/jetstream.php
index 156f961856..c97557dbb0 100755
--- a/bin/jetstream.php
+++ b/bin/jetstream.php
@@ -6,7 +6,7 @@
*
* SPDX-License-Identifier: AGPL-3.0-or-later
*
- * @deprecated 2025.02 use bin/console.php jetstream instead
+ * @deprecated 2025.02 use `bin/console.php jetstream` instead
*/
if (php_sapi_name() !== 'cli') {
@@ -19,11 +19,15 @@ chdir(dirname(__DIR__));
require dirname(__DIR__) . '/vendor/autoload.php';
+fwrite(STDOUT, '`bin/jetstream.php` is deprecated since 2024.02 and will be removed in 5 months, please use `bin/console.php jetstream` instead.' . \PHP_EOL);
+
+// BC: Add console command as second argument
$argv = $_SERVER['argv'] ?? [];
array_splice($argv, 1, 0, "jetstream");
+$_SERVER['argv'] = $argv;
$container = \Friendica\Core\DiceContainer::fromBasePath(dirname(__DIR__));
$app = \Friendica\App::fromContainer($container);
-$app->processConsole($argv);
+$app->processConsole($_SERVER);
diff --git a/bin/worker.php b/bin/worker.php
index a79d8836a7..f319bd766f 100755
--- a/bin/worker.php
+++ b/bin/worker.php
@@ -8,7 +8,7 @@
*
* Starts the background processing
*
- * @deprecated 2025.02 use bin/console.php worker instead
+ * @deprecated 2025.02 use `bin/console.php worker` instead
*/
if (php_sapi_name() !== 'cli') {
@@ -21,11 +21,15 @@ chdir(dirname(__DIR__));
require dirname(__DIR__) . '/vendor/autoload.php';
+fwrite(STDOUT, '`bin/worker.php` is deprecated since 2024.02 and will be removed in 5 months, please use `bin/console.php worker` instead.' . \PHP_EOL);
+
+// BC: Add console command as second argument
$argv = $_SERVER['argv'] ?? [];
array_splice($argv, 1, 0, "worker");
+$_SERVER['argv'] = $argv;
$container = \Friendica\Core\DiceContainer::fromBasePath(dirname(__DIR__));
$app = \Friendica\App::fromContainer($container);
-$app->processConsole($argv);
+$app->processConsole($_SERVER);
diff --git a/doc/Developers-Intro.md b/doc/Developers-Intro.md
index c500b27741..99e84739d0 100644
--- a/doc/Developers-Intro.md
+++ b/doc/Developers-Intro.md
@@ -156,3 +156,97 @@ If you are interested in improving those clients, please contact the developers
* iOS: *currently no client*
* SailfishOS: **Friendiy** [src](https://kirgroup.com/projects/fabrixxm/harbour-friendly) - developed by [Fabio](https://kirgroup.com/profile/fabrixxm/profile)
* Windows: **Friendica Mobile** for Windows versions [before 8.1](http://windowsphone.com/s?appid=e3257730-c9cf-4935-9620-5261e3505c67) and [Windows 10](https://www.microsoft.com/store/apps/9nblggh0fhmn) - developed by [Gerhard Seeber](http://mozartweg.dyndns.org/friendica/profile/gerhard/profile)
+
+## Backward compatibility
+
+### Backward Compatibility Promise
+
+Friendica can be extended by addons.
+These addons relies on many classes and conventions from Friendica.
+As developers our work on Friendica should not break things in the addons without giving the addon maintainers a chance to fix their addons.
+Our goal is to build trust for the addon maintainers but also allow Friendica developers to move on.
+This is called the Backward Compatibility Promise.
+
+Inspired by the [Symonfy BC promise](https://symfony.com/doc/current/contributing/code/bc.html) we promise BC for every class, interface, trait, enum, function, constant, etc., but with the exception of:
+
+- Classes, interfaces, traits, enums, functions, methods, properties and constants marked as `@internal` or `@private`
+- Extending or modifying a `final` class or method in any way
+- Calling `private` methods (via Reflection)
+- Accessing `private` properties (via Reflection)
+- Accessing `private` methods (via Reflection)
+- Accessing `private` constants (via Reflection)
+- New properties on overridden `protected` methods
+- Possible name collisions with new methods in an extended class (addon developers should prefix their custom methods in the extending classes in an appropriate way)
+- Dropping support for every PHP version that has reached end of life
+
+### Deprecation and removing features
+
+As the development goes by Friendica needs to get rid of old code and concepts.
+This will be done in 3 steps to give addon maintainers a chance to adjust their addons.
+
+**1. Label deprecation**
+
+If we as the Friendica maintainers decide to remove some functions, classes, interface, etc. we start this by adding a `@deprecated` PHPDoc note on the code.
+For instance the class `Friendica\Core\Logger` should be removed, so we add the following note with a possible replacement:
+
+```php
+/**
+ * Logger functions
+ *
+ * @deprecated 2025.02 Use constructor injection or `DI::logger()` instead
+ */
+class Logger {/* ... */}
+```
+
+This way addon developers might be notified early by their IDE or other tools that the usage of the class is deprecated.
+In Friendica we can now start to replace all occurrences and usage of this class with the alternative.
+
+The deprecation label COULD be remain over multiple releases.
+As long as the code that is labeled with `@deprecated` is used inside Friendica or the official addon repository, it SHOULD NOT be hard deprecated.
+
+**2. Hard deprecation**
+
+If the deprecated code is no longer used inside Friendica or the official addons it MUST be hard deprecated.
+The code MUST NOT be deleted.
+Starting from the next release, it MUST be stay for at least 5 months.
+Hard deprecated code COULD remain longer than 5 months, depending on when a release appears.
+Addon developer MUST NOT consider that they have more than 5 months to adjust their code.
+
+Hard deprecation code means that the code triggers an `E_USER_DEPRECATION` error if it is called.
+For instance with the deprecated class `Friendica\Core\Logger` the call of every method should trigger an error:
+
+```php
+/**
+ * Logger functions
+ *
+ * @deprecated 2025.02 Use constructor injection or `DI::logger()` instead
+ */
+class Logger {
+ public static function info(string $message, array $context = [])
+ {
+ trigger_error('Class `' . __CLASS__ . '` is deprecated since 2025.05 and will be removed after 5 months, use constructor injection or `DI::logger()` instead.', E_USER_DEPRECATED);
+
+ self::getInstance()->info($message, $context);
+ }
+
+ /* ... */
+}
+```
+
+This way the maintainer or users of addons will be notified that the addon will stop working in one of the next releases.
+The addon maintainer now has at least 5 months or at least one release to fix the deprecations.
+
+Please note that the deprecation message contains the release that will be released next.
+In the example the code was hard deprecated with release `2025.05`, so it COULD be removed earliest with the `2025.11` release.
+
+**3. Code Removing**
+
+We promise BC for deprecated code for at least 5 months, starting from the release the deprecation was announced.
+After this time the deprecated code COULD be remove within the next release.
+
+Breaking changes MUST be happen only in a new release but MUST be hard deprecated first.
+The BC promise refers only to releases, respective the `stable` branch.
+Deprecated code on other branches like `develop` or RC branches could be removed earlier.
+This is not a BC break as long as the release will be published 5 months after the hard deprecation.
+
+If a release breaks BC without deprecation or earlier than 5 months, this SHOULD considered as a bug and BC SHOULD be restored in a bugfix release.
diff --git a/src/App.php b/src/App.php
index 73f2913b1a..5623f9a413 100644
--- a/src/App.php
+++ b/src/App.php
@@ -57,6 +57,7 @@ use Psr\Log\LoggerInterface;
* and anything else that might need to be passed around
* before we spit the page out.
*
+ * @final
*/
class App
{
@@ -64,6 +65,9 @@ class App
const CODENAME = 'Interrupted Fern';
const VERSION = '2025.02-dev';
+ /**
+ * @internal
+ */
public static function fromContainer(Container $container): self
{
return new self($container);
@@ -130,6 +134,9 @@ class App
$this->container = $container;
}
+ /**
+ * @internal
+ */
public function processRequest(ServerRequestInterface $request, float $start_time): void
{
$this->container->addRule(Mode::class, [
@@ -158,16 +165,18 @@ class App
$this->session = $this->container->create(IHandleUserSessions::class);
$this->appHelper = $this->container->create(AppHelper::class);
- $this->loadSetupForFrontend(
- $request,
+ $this->load(
+ $request->getServerParams(),
$this->container->create(DbaDefinition::class),
$this->container->create(ViewDefinition::class),
+ $this->mode,
+ $this->config,
+ $this->profiler,
+ $this->appHelper,
);
$this->registerTemplateEngine();
- $this->mode->setExecutor(Mode::INDEX);
-
$this->runFrontend(
$this->container->create(IManagePersonalConfigValues::class),
$this->container->create(Page::class),
@@ -178,8 +187,13 @@ class App
);
}
- public function processConsole(array $argv): void
+ /**
+ * @internal
+ */
+ public function processConsole(array $serverParams): void
{
+ $argv = $serverParams['argv'] ?? [];
+
$this->setupContainerForAddons();
$this->setupLogChannel($this->determineLogChannel($argv));
@@ -188,12 +202,25 @@ class App
$this->registerErrorHandler();
+ $this->load(
+ $serverParams,
+ $this->container->create(DbaDefinition::class),
+ $this->container->create(ViewDefinition::class),
+ $this->container->create(Mode::class),
+ $this->container->create(IManageConfigValues::class),
+ $this->container->create(Profiler::class),
+ $this->container->create(AppHelper::class),
+ );
+
$this->registerTemplateEngine();
(\Friendica\Core\Console::create($this->container, $argv))->execute();
}
- public function processEjabberd(): void
+ /**
+ * @internal
+ */
+ public function processEjabberd(array $serverParams): void
{
$this->setupContainerForAddons();
@@ -203,6 +230,16 @@ class App
$this->registerErrorHandler();
+ $this->load(
+ $serverParams,
+ $this->container->create(DbaDefinition::class),
+ $this->container->create(ViewDefinition::class),
+ $this->container->create(Mode::class),
+ $this->container->create(IManageConfigValues::class),
+ $this->container->create(Profiler::class),
+ $this->container->create(AppHelper::class),
+ );
+
/** @var BasePath */
$basePath = $this->container->create(BasePath::class);
@@ -272,14 +309,21 @@ class App
/**
* Load the whole app instance
*/
- private function loadSetupForFrontend(ServerRequestInterface $request, DbaDefinition $dbaDefinition, ViewDefinition $viewDefinition)
- {
- if ($this->config->get('system', 'ini_max_execution_time') !== false) {
- set_time_limit((int)$this->config->get('system', 'ini_max_execution_time'));
+ private function load(
+ array $serverParams,
+ DbaDefinition $dbaDefinition,
+ ViewDefinition $viewDefinition,
+ Mode $mode,
+ IManageConfigValues $config,
+ Profiler $profiler,
+ AppHelper $appHelper
+ ): void {
+ if ($config->get('system', 'ini_max_execution_time') !== false) {
+ set_time_limit((int) $config->get('system', 'ini_max_execution_time'));
}
- if ($this->config->get('system', 'ini_pcre_backtrack_limit') !== false) {
- ini_set('pcre.backtrack_limit', (int)$this->config->get('system', 'ini_pcre_backtrack_limit'));
+ if ($config->get('system', 'ini_pcre_backtrack_limit') !== false) {
+ ini_set('pcre.backtrack_limit', (int) $config->get('system', 'ini_pcre_backtrack_limit'));
}
// Normally this constant is defined - but not if "pcntl" isn't installed
@@ -290,11 +334,11 @@ class App
// Ensure that all "strtotime" operations do run timezone independent
date_default_timezone_set('UTC');
- $this->profiler->reset();
+ $profiler->reset();
- if ($this->mode->has(Mode::DBAVAILABLE)) {
+ if ($mode->has(Mode::DBAVAILABLE)) {
Core\Hook::loadHooks();
- $loader = (new Config())->createConfigFileManager($this->appHelper->getBasePath(), $request->getServerParams());
+ $loader = (new Config())->createConfigFileManager($appHelper->getBasePath(), $serverParams);
Core\Hook::callAll('load_config', $loader);
// Hooks are now working, reload the whole definitions with hook enabled
@@ -302,7 +346,7 @@ class App
$viewDefinition->load(true);
}
- $this->loadDefaultTimezone();
+ $this->loadDefaultTimezone($config, $appHelper);
}
/**
@@ -312,16 +356,16 @@ class App
*
* @global string $default_timezone
*/
- private function loadDefaultTimezone()
+ private function loadDefaultTimezone(IManageConfigValues $config, AppHelper $appHelper)
{
- if ($this->config->get('system', 'default_timezone')) {
- $timezone = $this->config->get('system', 'default_timezone', 'UTC');
+ if ($config->get('system', 'default_timezone')) {
+ $timezone = $config->get('system', 'default_timezone', 'UTC');
} else {
global $default_timezone;
$timezone = $default_timezone ?? '' ?: 'UTC';
}
- $this->appHelper->setTimeZone($timezone);
+ $appHelper->setTimeZone($timezone);
}
/**
@@ -348,6 +392,8 @@ class App
float $start_time,
ServerRequestInterface $request
) {
+ $this->mode->setExecutor(Mode::INDEX);
+
$httpInput = new HTTPInputData($request->getServerParams());
$serverVars = $request->getServerParams();
$queryVars = $request->getQueryParams();
diff --git a/src/AppLegacy.php b/src/AppLegacy.php
index 4aa3f25e4c..8ec6b0aabc 100644
--- a/src/AppLegacy.php
+++ b/src/AppLegacy.php
@@ -32,6 +32,7 @@ use Friendica\Util\Strings;
* and anything else that might need to be passed around
* before we spit the page out.
*
+ * @internal
*/
final class AppLegacy implements AppHelper
{
diff --git a/src/Console/AbstractConsole.php b/src/Console/AbstractConsole.php
deleted file mode 100644
index 0b8c1d6eb8..0000000000
--- a/src/Console/AbstractConsole.php
+++ /dev/null
@@ -1,39 +0,0 @@
-executable, -strlen(CoreConsole::getDefaultExecutable())) !== CoreConsole::getDefaultExecutable()) {
- $this->out(sprintf("'%s' is deprecated and will removed. Please use 'bin/console.php %s' instead", $this->executable, $command));
- }
- }
-}
diff --git a/src/Console/Daemon.php b/src/Console/Daemon.php
index c8165a1d9b..a21ff26fc6 100644
--- a/src/Console/Daemon.php
+++ b/src/Console/Daemon.php
@@ -10,10 +10,10 @@ declare(strict_types=1);
namespace Friendica\Console;
use Asika\SimpleConsole\CommandArgsException;
+use Asika\SimpleConsole\Console;
use Friendica\App\Mode;
use Friendica\Core\Config\Capability\IManageConfigValues;
use Friendica\Core\KeyValueStorage\Capability\IManageKeyValuePairs;
-use Friendica\Core\Logger\Capability\LogChannel;
use Friendica\Core\System;
use Friendica\Core\Update;
use Friendica\Core\Worker;
@@ -27,10 +27,8 @@ use RuntimeException;
/**
* Console command for interacting with the daemon
*/
-final class Daemon extends AbstractConsole
+final class Daemon extends Console
{
- public const LOG_CHANNEL = LogChannel::DAEMON;
-
private Mode $mode;
private IManageConfigValues $config;
private IManageKeyValuePairs $keyValue;
@@ -93,8 +91,6 @@ HELP;
protected function doExecute()
{
- $this->checkDeprecated('daemon');
-
if ($this->mode->isInstall()) {
throw new RuntimeException("Friendica isn't properly installed yet");
}
diff --git a/src/Console/JetstreamDaemon.php b/src/Console/JetstreamDaemon.php
index d34e5780c2..8bb1e7e106 100644
--- a/src/Console/JetstreamDaemon.php
+++ b/src/Console/JetstreamDaemon.php
@@ -9,12 +9,12 @@ declare(strict_types=1);
namespace Friendica\Console;
+use Asika\SimpleConsole\Console;
use Friendica\App\Mode;
use Friendica\Core\Addon;
use Friendica\Core\Config\Capability\IManageConfigValues;
use Friendica\Core\Hook;
use Friendica\Core\KeyValueStorage\Capability\IManageKeyValuePairs;
-use Friendica\Core\Logger\Capability\LogChannel;
use Friendica\Protocol\ATProtocol\Jetstream;
use Friendica\System\Daemon as SysDaemon;
use RuntimeException;
@@ -22,10 +22,8 @@ use RuntimeException;
/**
* Console command for interacting with the daemon
*/
-final class JetstreamDaemon extends AbstractConsole
+final class JetstreamDaemon extends Console
{
- public const LOG_CHANNEL = LogChannel::DAEMON;
-
private Mode $mode;
private IManageConfigValues $config;
private IManageKeyValuePairs $keyValue;
@@ -79,8 +77,6 @@ HELP;
protected function doExecute()
{
- $this->checkDeprecated('jetstream');
-
if ($this->mode->isInstall()) {
throw new RuntimeException("Friendica isn't properly installed yet");
}
diff --git a/src/Console/Worker.php b/src/Console/Worker.php
index 1c7eeae002..97b7160d03 100644
--- a/src/Console/Worker.php
+++ b/src/Console/Worker.php
@@ -9,8 +9,8 @@ declare(strict_types=1);
namespace Friendica\Console;
+use Asika\SimpleConsole\Console;
use Friendica\App\Mode;
-use Friendica\Core\Logger\Capability\LogChannel;
use Friendica\Core\Update;
use Friendica\Core\Worker as CoreWorker;
use Friendica\Core\Worker\Repository\Process as ProcessRepository;
@@ -19,10 +19,8 @@ use Friendica\Util\BasePath;
/**
* Console command for starting worker
*/
-final class Worker extends AbstractConsole
+final class Worker extends Console
{
- public const LOG_CHANNEL = LogChannel::WORKER;
-
private Mode $mode;
private BasePath $basePath;
private ProcessRepository $processRepo;
@@ -69,8 +67,6 @@ HELP;
protected function doExecute()
{
- $this->checkDeprecated('worker');
-
$this->mode->setExecutor(Mode::WORKER);
// Check the database structure and possibly fixes it
diff --git a/src/Core/Container.php b/src/Core/Container.php
index 1017590a85..55e0826122 100644
--- a/src/Core/Container.php
+++ b/src/Core/Container.php
@@ -11,6 +11,8 @@ namespace Friendica\Core;
/**
* Dependency Injection Container
+ *
+ * @internal
*/
interface Container
{
diff --git a/src/Core/DiceContainer.php b/src/Core/DiceContainer.php
index 304c1e411d..bd1eaf8043 100644
--- a/src/Core/DiceContainer.php
+++ b/src/Core/DiceContainer.php
@@ -13,6 +13,8 @@ use Dice\Dice;
/**
* Wrapper for the Dice class to make some basic setups
+ *
+ * @internal
*/
final class DiceContainer implements Container
{
diff --git a/src/Core/Logger/Factory/LegacyLoggerFactory.php b/src/Core/Logger/Factory/LegacyLoggerFactory.php
index 5c91d11771..2c7b6c0237 100644
--- a/src/Core/Logger/Factory/LegacyLoggerFactory.php
+++ b/src/Core/Logger/Factory/LegacyLoggerFactory.php
@@ -26,6 +26,8 @@ use Psr\Log\LoggerInterface;
*
* @see \Friendica\Core\Logger\Factory\StreamLogger
* @see \Friendica\Core\Logger\Factory\SyslogLogger
+ *
+ * @internal
*/
final class LegacyLoggerFactory implements LoggerFactory
{
diff --git a/src/Core/Logger/LoggerManager.php b/src/Core/Logger/LoggerManager.php
index 697756099d..8379c91995 100644
--- a/src/Core/Logger/LoggerManager.php
+++ b/src/Core/Logger/LoggerManager.php
@@ -21,6 +21,8 @@ use Psr\Log\NullLogger;
/**
* Manager for the core logging instances
+ *
+ * @internal
*/
final class LoggerManager
{
diff --git a/src/DI.php b/src/DI.php
index 7d1114ac5c..c9c973f722 100644
--- a/src/DI.php
+++ b/src/DI.php
@@ -60,7 +60,8 @@ abstract class DI
/**
* Returns a clone of the current dice instance
- * This useful for overloading the current instance with mocked methods during tests
+ *
+ * @internal This useful for overloading the current instance with mocked methods during tests
*
* @return Dice
*/
diff --git a/src/Model/Contact.php b/src/Model/Contact.php
index e894dc64ea..a7dfa08dcf 100644
--- a/src/Model/Contact.php
+++ b/src/Model/Contact.php
@@ -362,10 +362,8 @@ class Contact
return [];
}
- $background_update = DI::config()->get('system', 'update_active_contacts') ? $contact['local-data'] : true;
-
// Update the contact in the background if needed
- if ($background_update && !self::isLocal($url) && Protocol::supportsProbe($contact['network']) && ($contact['next-update'] < DateTimeFormat::utcNow())) {
+ if (UpdateContact::isUpdatable($contact['id'])) {
try {
UpdateContact::add(['priority' => Worker::PRIORITY_LOW, 'dont_fork' => true], $contact['id']);
} catch (\InvalidArgumentException $e) {
@@ -537,6 +535,17 @@ class Contact
return DBA::exists('account-user-view', ["`pid` = ? AND `uid` != ? AND `rel` IN (?, ?)", $cid, 0, self::SHARING, self::FRIEND]);
}
+ /**
+ * Checks if the provided public contact id has got relations with someone on this system
+ *
+ * @param integer $cid Public Contact Id
+ * @return boolean Contact has followers or sharers on this system
+ */
+ public static function hasRelations(int $cid): bool
+ {
+ return DBA::exists('account-user-view', ["`pid` = ? AND `uid` != ? AND `rel` IN (?, ?, ?)", $cid, 0, self::FOLLOWER, self::SHARING, self::FRIEND]);
+ }
+
/**
* Get the basepath for a given contact link
*
@@ -1318,9 +1327,7 @@ class Contact
if (!empty($contact)) {
$contact_id = $contact['id'];
- $background_update = DI::config()->get('system', 'update_active_contacts') ? $contact['local-data'] : true;
-
- if ($background_update && !self::isLocal($url) && Protocol::supportsProbe($contact['network']) && ($contact['next-update'] < DateTimeFormat::utcNow())) {
+ if (UpdateContact::isUpdatable($contact['id'])) {
try {
UpdateContact::add(['priority' => Worker::PRIORITY_LOW, 'dont_fork' => true], $contact['id']);
} catch (\InvalidArgumentException $e) {
diff --git a/src/Model/GServer.php b/src/Model/GServer.php
index 9184997965..90f68b7725 100644
--- a/src/Model/GServer.php
+++ b/src/Model/GServer.php
@@ -805,8 +805,9 @@ class GServer
$gserver = DBA::selectFirst('gserver', ['network'], ['nurl' => Strings::normaliseLink($url)]);
if (!DBA::isResult($gserver)) {
$serverdata['created'] = DateTimeFormat::utcNow();
- $ret = self::insert($serverdata);
- $id = DBA::lastInsertId();
+
+ $ret = self::insert($serverdata);
+ $id = DBA::lastInsertId();
} else {
$ret = self::update($serverdata, ['nurl' => $serverdata['nurl']]);
$gserver = DBA::selectFirst('gserver', ['id'], ['nurl' => $serverdata['nurl']]);
@@ -983,7 +984,8 @@ class GServer
$serverdata['detection-method'] = self::DETECT_STATISTICS_JSON;
if (!empty($data['version'])) {
- $valid = true;
+ $valid = true;
+
$serverdata['version'] = $data['version'];
// Version numbers on statistics.json are presented with additional info, e.g.:
// 0.6.3.0-p1702cc1c, 0.6.99.0-p1b9ab160 or 3.4.3-2-1191.
@@ -991,12 +993,14 @@ class GServer
}
if (!empty($data['name'])) {
- $valid = true;
+ $valid = true;
+
$serverdata['site_name'] = $data['name'];
}
if (!empty($data['network'])) {
- $valid = true;
+ $valid = true;
+
$serverdata['platform'] = strtolower($data['network']);
if ($serverdata['platform'] == 'diaspora') {
@@ -1011,22 +1015,26 @@ class GServer
}
if (!empty($data['total_users'])) {
- $valid = true;
+ $valid = true;
+
$serverdata['registered-users'] = max($data['total_users'], 1);
}
if (!empty($data['active_users_monthly'])) {
- $valid = true;
+ $valid = true;
+
$serverdata['active-month-users'] = max($data['active_users_monthly'], 0);
}
if (!empty($data['active_users_halfyear'])) {
- $valid = true;
+ $valid = true;
+
$serverdata['active-halfyear-users'] = max($data['active_users_halfyear'], 0);
}
if (!empty($data['local_posts'])) {
- $valid = true;
+ $valid = true;
+
$serverdata['local-posts'] = max($data['local_posts'], 0);
}
@@ -1830,8 +1838,7 @@ class GServer
}
if (!empty($data['totalResults'])) {
- $registeredUsers = $serverdata['registered-users'] ?? 0;
- $serverdata['registered-users'] = max($data['totalResults'], $registeredUsers, 1);
+ $serverdata['registered-users'] = max($data['totalResults'], $serverdata['registered-users'] ?? 0, 1);
$serverdata['directory-type'] = self::DT_POCO;
$serverdata['poco'] = $url . '/poco';
}
@@ -2016,7 +2023,8 @@ class GServer
$serverdata['platform'] = 'mastodon';
$serverdata['version'] = $data['version'] ?? '';
$serverdata['network'] = Protocol::ACTIVITYPUB;
- $valid = true;
+
+ $valid = true;
}
if (!empty($data['title'])) {
@@ -2026,7 +2034,8 @@ class GServer
if (!empty($data['title']) && empty($serverdata['platform']) && ($serverdata['network'] == Protocol::PHANTOM)) {
$serverdata['platform'] = 'mastodon';
$serverdata['network'] = Protocol::ACTIVITYPUB;
- $valid = true;
+
+ $valid = true;
}
if (!empty($data['description'])) {
@@ -2040,19 +2049,22 @@ class GServer
if (!empty($serverdata['version']) && preg_match('/.*?\(compatible;\s(.*)\s(.*)\)/ism', $serverdata['version'], $matches)) {
$serverdata['platform'] = strtolower($matches[1]);
$serverdata['version'] = $matches[2];
- $valid = true;
+
+ $valid = true;
}
if (!empty($serverdata['version']) && strstr(strtolower($serverdata['version']), 'pleroma')) {
$serverdata['platform'] = 'pleroma';
$serverdata['version'] = trim(str_ireplace('pleroma', '', $serverdata['version']));
- $valid = true;
+
+ $valid = true;
}
if (!empty($serverdata['platform']) && strstr($serverdata['platform'], 'pleroma')) {
$serverdata['version'] = trim(str_ireplace('pleroma', '', $serverdata['platform']));
$serverdata['platform'] = 'pleroma';
- $valid = true;
+
+ $valid = true;
}
if ($valid && in_array($serverdata['detection-method'], self::DETECT_UNSPECIFIC)) {
@@ -2318,14 +2330,16 @@ class GServer
$doc = new DOMDocument();
@$doc->loadHTML($curlResult->getBodyString());
- $xpath = new DOMXPath($doc);
+ $xpath = new DOMXPath($doc);
+
$assigned = false;
// We can only detect honk via some HTML element on their page
if ($xpath->query('//div[@id="honksonpage"]')->count() == 1) {
$serverdata['platform'] = 'honk';
$serverdata['network'] = Protocol::ACTIVITYPUB;
- $assigned = true;
+
+ $assigned = true;
}
$title = trim(XML::getFirstNodeValue($xpath, '//head/title/text()'));
@@ -2358,11 +2372,13 @@ class GServer
if (in_array($attr['name'], ['application-name', 'al:android:app_name', 'al:ios:app_name',
'twitter:app:name:googleplay', 'twitter:app:name:iphone', 'twitter:app:name:ipad', 'generator'])) {
- $platform = str_ireplace(array_keys($platforms), array_values($platforms), $attr['content']);
- $platform = str_replace('/', ' ', $platform);
+ $platform = str_ireplace(array_keys($platforms), array_values($platforms), $attr['content']);
+ $platform = str_replace('/', ' ', $platform);
+
$platform_parts = explode(' ', $platform);
if ((count($platform_parts) >= 2) && in_array(strtolower($platform_parts[0]), array_values($platforms))) {
- $platform = $platform_parts[0];
+ $platform = $platform_parts[0];
+
$serverdata['version'] = $platform_parts[1];
}
if (in_array($platform, array_values($grouped_platforms['dfrn_platforms']))) {
@@ -2374,7 +2390,8 @@ class GServer
}
if (in_array($platform, array_values($platforms))) {
$serverdata['platform'] = $platform;
- $assigned = true;
+
+ $assigned = true;
}
}
}
@@ -2409,7 +2426,8 @@ class GServer
if (in_array($attr['property'], ['og:platform', 'generator'])) {
if (in_array($attr['content'], array_keys($platforms))) {
$serverdata['platform'] = $platforms[$attr['content']];
- $assigned = true;
+
+ $assigned = true;
}
if (in_array($attr['content'], array_keys($grouped_platforms['ap_platforms']))) {
@@ -2427,7 +2445,8 @@ class GServer
$serverdata['version'] = trim($serverdata['platform'] . ' ' . $serverdata['version']);
$serverdata['platform'] = 'microblog';
$serverdata['network'] = Protocol::ACTIVITYPUB;
- $assigned = true;
+
+ $assigned = true;
}
}
}
@@ -2440,7 +2459,8 @@ class GServer
$serverdata['version'] = trim($serverdata['platform'] . ' ' . $serverdata['version']);
$serverdata['platform'] = 'microblog';
$serverdata['network'] = Protocol::ACTIVITYPUB;
- $assigned = true;
+
+ $assigned = true;
}
}
}
@@ -2490,10 +2510,6 @@ class GServer
*/
public static function discover()
{
- if (!DI::config()->get('system', 'discover_servers')) {
- return;
- }
-
// Update the server list
self::discoverFederation();
diff --git a/src/Module/Admin/Site.php b/src/Module/Admin/Site.php
index c162acce9b..72ea6fa5a4 100644
--- a/src/Module/Admin/Site.php
+++ b/src/Module/Admin/Site.php
@@ -7,7 +7,6 @@
namespace Friendica\Module\Admin;
-use Friendica\App;
use Friendica\Core\Renderer;
use Friendica\Core\Search;
use Friendica\Core\System;
@@ -20,7 +19,6 @@ use Friendica\Model\User;
use Friendica\Module\BaseAdmin;
use Friendica\Module\Conversation\Community;
use Friendica\Module\Register;
-use Friendica\Navigation\SystemMessages;
use Friendica\Protocol\Relay;
use Friendica\Util\BasePath;
use Friendica\Util\EMailer\MailBuilder;
@@ -58,80 +56,81 @@ class Site extends BaseAdmin
$maximagelength = (!empty($_POST['maximagelength']) ? intval(trim($_POST['maximagelength'])) : -1);
$jpegimagequality = (!empty($_POST['jpegimagequality']) ? intval(trim($_POST['jpegimagequality'])) : 100);
- $register_policy = (!empty($_POST['register_policy']) ? intval(trim($_POST['register_policy'])) : 0);
- $max_registered_users = (!empty($_POST['max_registered_users']) ? intval(trim($_POST['max_registered_users'])) : 0);
- $daily_registrations = (!empty($_POST['max_daily_registrations']) ? intval(trim($_POST['max_daily_registrations'])) : 0);
- $abandon_days = (!empty($_POST['abandon_days']) ? intval(trim($_POST['abandon_days'])) : 0);
+ $register_policy = (!empty($_POST['register_policy']) ? intval(trim($_POST['register_policy'])) : 0);
+ $max_registered_users = (!empty($_POST['max_registered_users']) ? intval(trim($_POST['max_registered_users'])) : 0);
+ $daily_registrations = (!empty($_POST['max_daily_registrations']) ? intval(trim($_POST['max_daily_registrations'])) : 0);
+ $abandon_days = (!empty($_POST['abandon_days']) ? intval(trim($_POST['abandon_days'])) : 0);
- $register_text = (!empty($_POST['register_text']) ? strip_tags(trim($_POST['register_text'])) : '');
+ $register_text = (!empty($_POST['register_text']) ? strip_tags(trim($_POST['register_text'])) : '');
- $allowed_sites = (!empty($_POST['allowed_sites']) ? trim($_POST['allowed_sites']) : '');
- $allowed_email = (!empty($_POST['allowed_email']) ? trim($_POST['allowed_email']) : '');
- $disallowed_email = (!empty($_POST['disallowed_email']) ? trim($_POST['disallowed_email']) : '');
- $forbidden_nicknames = (!empty($_POST['forbidden_nicknames']) ? strtolower(trim($_POST['forbidden_nicknames'])) : '');
- $system_actor_name = (!empty($_POST['system_actor_name']) ? trim($_POST['system_actor_name']) : '');
- $no_oembed_rich_content = !empty($_POST['no_oembed_rich_content']);
- $allowed_oembed = (!empty($_POST['allowed_oembed']) ? trim($_POST['allowed_oembed']) : '');
- $block_public = !empty($_POST['block_public']);
- $force_publish = !empty($_POST['publish_all']);
- $global_directory = (!empty($_POST['directory']) ? trim($_POST['directory']) : '');
- $newuser_private = !empty($_POST['newuser_private']);
- $enotify_no_content = !empty($_POST['enotify_no_content']);
- $private_addons = !empty($_POST['private_addons']);
- $disable_embedded = !empty($_POST['disable_embedded']);
+ $allowed_sites = (!empty($_POST['allowed_sites']) ? trim($_POST['allowed_sites']) : '');
+ $allowed_email = (!empty($_POST['allowed_email']) ? trim($_POST['allowed_email']) : '');
+ $disallowed_email = (!empty($_POST['disallowed_email']) ? trim($_POST['disallowed_email']) : '');
+ $forbidden_nicknames = (!empty($_POST['forbidden_nicknames']) ? strtolower(trim($_POST['forbidden_nicknames'])) : '');
+ $system_actor_name = (!empty($_POST['system_actor_name']) ? trim($_POST['system_actor_name']) : '');
+ $no_oembed_rich_content = !empty($_POST['no_oembed_rich_content']);
+ $allowed_oembed = (!empty($_POST['allowed_oembed']) ? trim($_POST['allowed_oembed']) : '');
+ $block_public = !empty($_POST['block_public']);
+ $force_publish = !empty($_POST['publish_all']);
+ $global_directory = (!empty($_POST['directory']) ? trim($_POST['directory']) : '');
+ $newuser_private = !empty($_POST['newuser_private']);
+ $enotify_no_content = !empty($_POST['enotify_no_content']);
+ $private_addons = !empty($_POST['private_addons']);
+ $disable_embedded = !empty($_POST['disable_embedded']);
$allow_users_remote_self = !empty($_POST['allow_users_remote_self']);
- $allow_relay_channels = !empty($_POST['allow_relay_channels']);
- $adjust_poll_frequency = !empty($_POST['adjust_poll_frequency']);
- $min_poll_interval = (!empty($_POST['min_poll_interval']) ? intval(trim($_POST['min_poll_interval'])) : 0);
- $explicit_content = !empty($_POST['explicit_content']);
- $local_search = !empty($_POST['local_search']);
- $blocked_tags = (!empty($_POST['blocked_tags']) ? trim($_POST['blocked_tags']) : '');
- $cache_contact_avatar = !empty($_POST['cache_contact_avatar']);
+ $allow_relay_channels = !empty($_POST['allow_relay_channels']);
+ $adjust_poll_frequency = !empty($_POST['adjust_poll_frequency']);
+ $min_poll_interval = (!empty($_POST['min_poll_interval']) ? intval(trim($_POST['min_poll_interval'])) : 0);
+ $explicit_content = !empty($_POST['explicit_content']);
+ $local_search = !empty($_POST['local_search']);
+ $blocked_tags = (!empty($_POST['blocked_tags']) ? trim($_POST['blocked_tags']) : '');
+ $cache_contact_avatar = !empty($_POST['cache_contact_avatar']);
- $enable_multi_reg = !empty($_POST['enable_multi_reg']);
- $enable_openid = !empty($_POST['enable_openid']);
- $enable_regfullname = !empty($_POST['enable_regfullname']);
- $register_notification = !empty($_POST['register_notification']);
- $community_page_style = (!empty($_POST['community_page_style']) ? intval(trim($_POST['community_page_style'])) : 0);
+ $enable_multi_reg = !empty($_POST['enable_multi_reg']);
+ $enable_openid = !empty($_POST['enable_openid']);
+ $enable_regfullname = !empty($_POST['enable_regfullname']);
+ $register_notification = !empty($_POST['register_notification']);
+ $community_page_style = (!empty($_POST['community_page_style']) ? intval(trim($_POST['community_page_style'])) : 0);
$max_author_posts_community_page = (!empty($_POST['max_author_posts_community_page']) ? intval(trim($_POST['max_author_posts_community_page'])) : 0);
$max_server_posts_community_page = (!empty($_POST['max_server_posts_community_page']) ? intval(trim($_POST['max_server_posts_community_page'])) : 0);
- $verifyssl = !empty($_POST['verifyssl']);
- $proxyuser = (!empty($_POST['proxyuser']) ? trim($_POST['proxyuser']) : '');
- $proxy = (!empty($_POST['proxy']) ? trim($_POST['proxy']) : '');
- $timeout = (!empty($_POST['timeout']) ? intval(trim($_POST['timeout'])) : 60);
- $maxloadavg = (!empty($_POST['maxloadavg']) ? intval(trim($_POST['maxloadavg'])) : 20);
- $min_memory = (!empty($_POST['min_memory']) ? intval(trim($_POST['min_memory'])) : 0);
- $optimize_tables = (!empty($_POST['optimize_tables']) ? intval(trim($_POST['optimize_tables'])) : false);
- $contact_discovery = (!empty($_POST['contact_discovery']) ? intval(trim($_POST['contact_discovery'])) : Contact\Relation::DISCOVERY_NONE);
- $update_active_contacts = (!empty($_POST['update_active_contacts']) ? intval(trim($_POST['update_active_contacts'])) : false);
- $synchronize_directory = (!empty($_POST['synchronize_directory']) ? intval(trim($_POST['synchronize_directory'])) : false);
- $poco_requery_days = (!empty($_POST['poco_requery_days']) ? intval(trim($_POST['poco_requery_days'])) : 7);
- $poco_discovery = (!empty($_POST['poco_discovery']) ? intval(trim($_POST['poco_discovery'])) : false);
- $poco_local_search = !empty($_POST['poco_local_search']);
- $nodeinfo = !empty($_POST['nodeinfo']);
- $mail_enabled = !empty($_POST['mail_enabled']);
- $diaspora_enabled = !empty($_POST['diaspora_enabled']);
- $force_ssl = !empty($_POST['force_ssl']);
- $show_help = !empty($_POST['show_help']);
- $dbclean = !empty($_POST['dbclean']);
- $dbclean_expire_days = (!empty($_POST['dbclean_expire_days']) ? intval($_POST['dbclean_expire_days']) : 0);
- $dbclean_unclaimed = (!empty($_POST['dbclean_unclaimed']) ? intval($_POST['dbclean_unclaimed']) : 0);
- $dbclean_expire_conv = (!empty($_POST['dbclean_expire_conv']) ? intval($_POST['dbclean_expire_conv']) : 0);
- $suppress_tags = !empty($_POST['suppress_tags']);
- $max_comments = (!empty($_POST['max_comments']) ? intval($_POST['max_comments']) : 0);
- $max_display_comments = (!empty($_POST['max_display_comments']) ? intval($_POST['max_display_comments']) : 0);
- $itemspage_network = (!empty($_POST['itemspage_network']) ? intval($_POST['itemspage_network']) : 0);
+ $verifyssl = !empty($_POST['verifyssl']);
+ $proxyuser = (!empty($_POST['proxyuser']) ? trim($_POST['proxyuser']) : '');
+ $proxy = (!empty($_POST['proxy']) ? trim($_POST['proxy']) : '');
+ $timeout = (!empty($_POST['timeout']) ? intval(trim($_POST['timeout'])) : 60);
+ $maxloadavg = (!empty($_POST['maxloadavg']) ? intval(trim($_POST['maxloadavg'])) : 20);
+ $min_memory = (!empty($_POST['min_memory']) ? intval(trim($_POST['min_memory'])) : 0);
+ $optimize_tables = (!empty($_POST['optimize_tables']) ? intval(trim($_POST['optimize_tables'])) : false);
+ $contact_discovery = (!empty($_POST['contact_discovery']) ? intval(trim($_POST['contact_discovery'])) : Contact\Relation::DISCOVERY_NONE);
+ $update_active_contacts = (!empty($_POST['update_active_contacts']) ? intval(trim($_POST['update_active_contacts'])) : false);
+ $update_known_contacts = (!empty($_POST['update_known_contacts']) ? intval(trim($_POST['update_known_contacts'])) : false);
+ $synchronize_directory = (!empty($_POST['synchronize_directory']) ? intval(trim($_POST['synchronize_directory'])) : false);
+ $poco_requery_days = (!empty($_POST['poco_requery_days']) ? intval(trim($_POST['poco_requery_days'])) : 7);
+ $poco_discovery = (!empty($_POST['poco_discovery']) ? intval(trim($_POST['poco_discovery'])) : false);
+ $poco_local_search = !empty($_POST['poco_local_search']);
+ $nodeinfo = !empty($_POST['nodeinfo']);
+ $mail_enabled = !empty($_POST['mail_enabled']);
+ $diaspora_enabled = !empty($_POST['diaspora_enabled']);
+ $force_ssl = !empty($_POST['force_ssl']);
+ $show_help = !empty($_POST['show_help']);
+ $dbclean = !empty($_POST['dbclean']);
+ $dbclean_expire_days = (!empty($_POST['dbclean_expire_days']) ? intval($_POST['dbclean_expire_days']) : 0);
+ $dbclean_unclaimed = (!empty($_POST['dbclean_unclaimed']) ? intval($_POST['dbclean_unclaimed']) : 0);
+ $dbclean_expire_conv = (!empty($_POST['dbclean_expire_conv']) ? intval($_POST['dbclean_expire_conv']) : 0);
+ $suppress_tags = !empty($_POST['suppress_tags']);
+ $max_comments = (!empty($_POST['max_comments']) ? intval($_POST['max_comments']) : 0);
+ $max_display_comments = (!empty($_POST['max_display_comments']) ? intval($_POST['max_display_comments']) : 0);
+ $itemspage_network = (!empty($_POST['itemspage_network']) ? intval($_POST['itemspage_network']) : 0);
$itemspage_network_mobile = (!empty($_POST['itemspage_network_mobile']) ? intval($_POST['itemspage_network_mobile']) : 0);
- $temppath = (!empty($_POST['temppath']) ? trim($_POST['temppath']) : '');
- $singleuser = (!empty($_POST['singleuser']) ? trim($_POST['singleuser']) : '');
- $only_tag_search = !empty($_POST['only_tag_search']);
- $limited_search_scope = !empty($_POST['limited_search_scope']);
- $search_age_days = (!empty($_POST['search_age_days']) ? intval($_POST['search_age_days']) : 0);
- $compute_circle_counts = !empty($_POST['compute_circle_counts']);
- $process_view = !empty($_POST['process_view']);
- $archival_days = (!empty($_POST['archival_days']) ? intval($_POST['archival_days']) : 0);
- $check_new_version_url = (!empty($_POST['check_new_version_url']) ? trim($_POST['check_new_version_url']) : 'none');
+ $temppath = (!empty($_POST['temppath']) ? trim($_POST['temppath']) : '');
+ $singleuser = (!empty($_POST['singleuser']) ? trim($_POST['singleuser']) : '');
+ $only_tag_search = !empty($_POST['only_tag_search']);
+ $limited_search_scope = !empty($_POST['limited_search_scope']);
+ $search_age_days = (!empty($_POST['search_age_days']) ? intval($_POST['search_age_days']) : 0);
+ $compute_circle_counts = !empty($_POST['compute_circle_counts']);
+ $process_view = !empty($_POST['process_view']);
+ $archival_days = (!empty($_POST['archival_days']) ? intval($_POST['archival_days']) : 0);
+ $check_new_version_url = (!empty($_POST['check_new_version_url']) ? trim($_POST['check_new_version_url']) : 'none');
$worker_queues = (!empty($_POST['worker_queues']) ? intval($_POST['worker_queues']) : 10);
$worker_load_cooldown = (!empty($_POST['worker_load_cooldown']) ? intval($_POST['worker_load_cooldown']) : 0);
@@ -140,7 +139,6 @@ class Site extends BaseAdmin
$cron_interval = (!empty($_POST['cron_interval']) ? intval($_POST['cron_interval']) : 1);
$worker_defer_limit = (!empty($_POST['worker_defer_limit']) ? intval($_POST['worker_defer_limit']) : 15);
$worker_fetch_limit = (!empty($_POST['worker_fetch_limit']) ? intval($_POST['worker_fetch_limit']) : 1);
-
$relay_directly = !empty($_POST['relay_directly']);
$relay_scope = (!empty($_POST['relay_scope']) ? trim($_POST['relay_scope']) : '');
@@ -159,7 +157,7 @@ class Site extends BaseAdmin
$max_posts_per_author = (!empty($_POST['max_posts_per_author']) ? intval($_POST['max_posts_per_author']) : 0);
$sharer_interaction_days = (!empty($_POST['sharer_interaction_days']) ? intval($_POST['sharer_interaction_days']) : 0);
- $active_panel = (!empty($_POST['active_panel']) ? "#" . trim($_POST['active_panel']) : '');
+ $active_panel = (!empty($_POST['active_panel']) ? "#" . trim($_POST['active_panel']) : '');
$transactionConfig = DI::config()->beginTransaction();
@@ -173,23 +171,24 @@ class Site extends BaseAdmin
$diaspora_enabled = false;
}
- $transactionConfig->set('system', 'maxloadavg' , $maxloadavg);
- $transactionConfig->set('system', 'min_memory' , $min_memory);
- $transactionConfig->set('system', 'optimize_tables' , $optimize_tables);
- $transactionConfig->set('system', 'contact_discovery' , $contact_discovery);
- $transactionConfig->set('system', 'update_active_contacts' , $update_active_contacts);
- $transactionConfig->set('system', 'synchronize_directory' , $synchronize_directory);
- $transactionConfig->set('system', 'poco_requery_days' , $poco_requery_days);
- $transactionConfig->set('system', 'poco_discovery' , $poco_discovery);
- $transactionConfig->set('system', 'poco_local_search' , $poco_local_search);
- $transactionConfig->set('system', 'nodeinfo' , $nodeinfo);
+ $transactionConfig->set('system', 'maxloadavg', $maxloadavg);
+ $transactionConfig->set('system', 'min_memory', $min_memory);
+ $transactionConfig->set('system', 'optimize_tables', $optimize_tables);
+ $transactionConfig->set('system', 'contact_discovery', $contact_discovery);
+ $transactionConfig->set('system', 'update_active_contacts', $update_active_contacts);
+ $transactionConfig->set('system', 'update_known_contacts', $update_known_contacts);
+ $transactionConfig->set('system', 'synchronize_directory', $synchronize_directory);
+ $transactionConfig->set('system', 'poco_requery_days', $poco_requery_days);
+ $transactionConfig->set('system', 'poco_discovery', $poco_discovery);
+ $transactionConfig->set('system', 'poco_local_search', $poco_local_search);
+ $transactionConfig->set('system', 'nodeinfo', $nodeinfo);
if (DI::config()->isWritable('config', 'sitename')) {
$transactionConfig->set('config', 'sitename', $sitename);
}
- $transactionConfig->set('config', 'sender_email' , $sender_email);
- $transactionConfig->set('system', 'suppress_tags' , $suppress_tags);
- $transactionConfig->set('system', 'shortcut_icon' , $shortcut_icon);
- $transactionConfig->set('system', 'touch_icon' , $touch_icon);
+ $transactionConfig->set('config', 'sender_email', $sender_email);
+ $transactionConfig->set('system', 'suppress_tags', $suppress_tags);
+ $transactionConfig->set('system', 'shortcut_icon', $shortcut_icon);
+ $transactionConfig->set('system', 'touch_icon', $touch_icon);
if ($banner == "") {
$transactionConfig->delete('system', 'banner');
@@ -234,60 +233,60 @@ class Site extends BaseAdmin
} else {
DI::sysmsg()->addNotice(DI::l10n()->t('%s is no valid input for maximum image size', $maximagesize));
}
- $transactionConfig->set('system', 'max_image_length' , $maximagelength);
- $transactionConfig->set('system', 'jpeg_quality' , $jpegimagequality);
+ $transactionConfig->set('system', 'max_image_length', $maximagelength);
+ $transactionConfig->set('system', 'jpeg_quality', $jpegimagequality);
- $transactionConfig->set('config', 'register_policy' , $register_policy);
- $transactionConfig->set('config', 'max_registered_users' , $max_registered_users);
+ $transactionConfig->set('config', 'register_policy', $register_policy);
+ $transactionConfig->set('config', 'max_registered_users', $max_registered_users);
$transactionConfig->set('system', 'max_daily_registrations', $daily_registrations);
User::setRegisterMethodByUserCount();
- $transactionConfig->set('system', 'account_abandon_days' , $abandon_days);
- $transactionConfig->set('config', 'register_text' , $register_text);
- $transactionConfig->set('system', 'allowed_sites' , $allowed_sites);
- $transactionConfig->set('system', 'allowed_email' , $allowed_email);
- $transactionConfig->set('system', 'disallowed_email' , $disallowed_email);
- $transactionConfig->set('system', 'forbidden_nicknames' , $forbidden_nicknames);
- $transactionConfig->set('system', 'system_actor_name' , $system_actor_name);
- $transactionConfig->set('system', 'no_oembed_rich_content' , $no_oembed_rich_content);
- $transactionConfig->set('system', 'allowed_oembed' , $allowed_oembed);
- $transactionConfig->set('system', 'block_public' , $block_public);
- $transactionConfig->set('system', 'publish_all' , $force_publish);
- $transactionConfig->set('system', 'newuser_private' , $newuser_private);
- $transactionConfig->set('system', 'enotify_no_content' , $enotify_no_content);
- $transactionConfig->set('system', 'disable_embedded' , $disable_embedded);
+ $transactionConfig->set('system', 'account_abandon_days', $abandon_days);
+ $transactionConfig->set('config', 'register_text', $register_text);
+ $transactionConfig->set('system', 'allowed_sites', $allowed_sites);
+ $transactionConfig->set('system', 'allowed_email', $allowed_email);
+ $transactionConfig->set('system', 'disallowed_email', $disallowed_email);
+ $transactionConfig->set('system', 'forbidden_nicknames', $forbidden_nicknames);
+ $transactionConfig->set('system', 'system_actor_name', $system_actor_name);
+ $transactionConfig->set('system', 'no_oembed_rich_content', $no_oembed_rich_content);
+ $transactionConfig->set('system', 'allowed_oembed', $allowed_oembed);
+ $transactionConfig->set('system', 'block_public', $block_public);
+ $transactionConfig->set('system', 'publish_all', $force_publish);
+ $transactionConfig->set('system', 'newuser_private', $newuser_private);
+ $transactionConfig->set('system', 'enotify_no_content', $enotify_no_content);
+ $transactionConfig->set('system', 'disable_embedded', $disable_embedded);
$transactionConfig->set('system', 'allow_users_remote_self', $allow_users_remote_self);
- $transactionConfig->set('system', 'allow_relay_channels' , $allow_relay_channels);
- $transactionConfig->set('system', 'adjust_poll_frequency' , $adjust_poll_frequency);
- $transactionConfig->set('system', 'min_poll_interval' , $min_poll_interval);
- $transactionConfig->set('system', 'explicit_content' , $explicit_content);
- $transactionConfig->set('system', 'local_search' , $local_search);
- $transactionConfig->set('system', 'blocked_tags' , Strings::cleanTags($blocked_tags));
- $transactionConfig->set('system', 'cache_contact_avatar' , $cache_contact_avatar);
- $transactionConfig->set('system', 'check_new_version_url' , $check_new_version_url);
+ $transactionConfig->set('system', 'allow_relay_channels', $allow_relay_channels);
+ $transactionConfig->set('system', 'adjust_poll_frequency', $adjust_poll_frequency);
+ $transactionConfig->set('system', 'min_poll_interval', $min_poll_interval);
+ $transactionConfig->set('system', 'explicit_content', $explicit_content);
+ $transactionConfig->set('system', 'local_search', $local_search);
+ $transactionConfig->set('system', 'blocked_tags', Strings::cleanTags($blocked_tags));
+ $transactionConfig->set('system', 'cache_contact_avatar', $cache_contact_avatar);
+ $transactionConfig->set('system', 'check_new_version_url', $check_new_version_url);
$transactionConfig->set('system', 'block_extended_register', !$enable_multi_reg);
- $transactionConfig->set('system', 'no_openid' , !$enable_openid);
- $transactionConfig->set('system', 'no_regfullname' , !$enable_regfullname);
- $transactionConfig->set('system', 'register_notification' , $register_notification);
- $transactionConfig->set('system', 'community_page_style' , $community_page_style);
+ $transactionConfig->set('system', 'no_openid', !$enable_openid);
+ $transactionConfig->set('system', 'no_regfullname', !$enable_regfullname);
+ $transactionConfig->set('system', 'register_notification', $register_notification);
+ $transactionConfig->set('system', 'community_page_style', $community_page_style);
$transactionConfig->set('system', 'max_author_posts_community_page', $max_author_posts_community_page);
$transactionConfig->set('system', 'max_server_posts_community_page', $max_server_posts_community_page);
- $transactionConfig->set('system', 'verifyssl' , $verifyssl);
- $transactionConfig->set('system', 'proxyuser' , $proxyuser);
- $transactionConfig->set('system', 'proxy' , $proxy);
- $transactionConfig->set('system', 'curl_timeout' , $timeout);
- $transactionConfig->set('system', 'imap_disabled' , !$mail_enabled && function_exists('imap_open'));
- $transactionConfig->set('system', 'diaspora_enabled' , $diaspora_enabled);
+ $transactionConfig->set('system', 'verifyssl', $verifyssl);
+ $transactionConfig->set('system', 'proxyuser', $proxyuser);
+ $transactionConfig->set('system', 'proxy', $proxy);
+ $transactionConfig->set('system', 'curl_timeout', $timeout);
+ $transactionConfig->set('system', 'imap_disabled', !$mail_enabled && function_exists('imap_open'));
+ $transactionConfig->set('system', 'diaspora_enabled', $diaspora_enabled);
- $transactionConfig->set('config', 'private_addons' , $private_addons);
+ $transactionConfig->set('config', 'private_addons', $private_addons);
- $transactionConfig->set('system', 'force_ssl' , $force_ssl);
- $transactionConfig->set('system', 'hide_help' , !$show_help);
+ $transactionConfig->set('system', 'force_ssl', $force_ssl);
+ $transactionConfig->set('system', 'hide_help', !$show_help);
- $transactionConfig->set('system', 'dbclean' , $dbclean);
- $transactionConfig->set('system', 'dbclean-expire-days' , $dbclean_expire_days);
+ $transactionConfig->set('system', 'dbclean', $dbclean);
+ $transactionConfig->set('system', 'dbclean-expire-days', $dbclean_expire_days);
$transactionConfig->set('system', 'dbclean_expire_conversation', $dbclean_expire_conv);
if ($dbclean_unclaimed == 0) {
@@ -314,28 +313,28 @@ class Site extends BaseAdmin
$transactionConfig->set('system', 'process_view', $process_view);
$transactionConfig->set('system', 'archival_days', $archival_days);
- $transactionConfig->set('system', 'worker_queues' , $worker_queues);
+ $transactionConfig->set('system', 'worker_queues', $worker_queues);
$transactionConfig->set('system', 'worker_load_cooldown', $worker_load_cooldown);
- $transactionConfig->set('system', 'worker_fastlane' , $worker_fastlane);
- $transactionConfig->set('system', 'decoupled_receiver' , $decoupled_receiver);
- $transactionConfig->set('system', 'cron_interval' , max($cron_interval, 1));
- $transactionConfig->set('system', 'worker_defer_limit' , $worker_defer_limit);
- $transactionConfig->set('system', 'worker_fetch_limit' , max($worker_fetch_limit, 1));
-
- $transactionConfig->set('system', 'relay_directly' , $relay_directly);
- $transactionConfig->set('system', 'relay_scope' , $relay_scope);
- $transactionConfig->set('system', 'relay_server_tags' , Strings::cleanTags($relay_server_tags));
- $transactionConfig->set('system', 'relay_deny_tags' , Strings::cleanTags($relay_deny_tags));
- $transactionConfig->set('system', 'relay_max_tags' , $relay_max_tags);
- $transactionConfig->set('system', 'relay_user_tags' , $relay_user_tags);
- $transactionConfig->set('system', 'relay_deny_undetected_language', $relay_deny_undetected_language);
- $transactionConfig->set('system', 'relay_language_quality' , $relay_language_quality);
- $transactionConfig->set('system', 'relay_languages' , max($relay_languages, 1));
+ $transactionConfig->set('system', 'worker_fastlane', $worker_fastlane);
+ $transactionConfig->set('system', 'decoupled_receiver', $decoupled_receiver);
+ $transactionConfig->set('system', 'cron_interval', max($cron_interval, 1));
+ $transactionConfig->set('system', 'worker_defer_limit', $worker_defer_limit);
+ $transactionConfig->set('system', 'worker_fetch_limit', max($worker_fetch_limit, 1));
- $transactionConfig->set('channel', 'engagement_hours' , $engagement_hours);
- $transactionConfig->set('channel', 'engagement_post_limit' , $engagement_post_limit);
- $transactionConfig->set('channel', 'interaction_score_days' , $interaction_score_days);
- $transactionConfig->set('channel', 'max_posts_per_author' , $max_posts_per_author);
+ $transactionConfig->set('system', 'relay_directly', $relay_directly);
+ $transactionConfig->set('system', 'relay_scope', $relay_scope);
+ $transactionConfig->set('system', 'relay_server_tags', Strings::cleanTags($relay_server_tags));
+ $transactionConfig->set('system', 'relay_deny_tags', Strings::cleanTags($relay_deny_tags));
+ $transactionConfig->set('system', 'relay_max_tags', $relay_max_tags);
+ $transactionConfig->set('system', 'relay_user_tags', $relay_user_tags);
+ $transactionConfig->set('system', 'relay_deny_undetected_language', $relay_deny_undetected_language);
+ $transactionConfig->set('system', 'relay_language_quality', $relay_language_quality);
+ $transactionConfig->set('system', 'relay_languages', max($relay_languages, 1));
+
+ $transactionConfig->set('channel', 'engagement_hours', $engagement_hours);
+ $transactionConfig->set('channel', 'engagement_post_limit', $engagement_post_limit);
+ $transactionConfig->set('channel', 'interaction_score_days', $interaction_score_days);
+ $transactionConfig->set('channel', 'max_posts_per_author', $max_posts_per_author);
$transactionConfig->set('channel', 'sharer_interaction_days', $sharer_interaction_days);
$transactionConfig->commit();
@@ -357,10 +356,10 @@ class Site extends BaseAdmin
}
/* Installed themes */
- $theme_choices = [];
- $theme_choices_mobile = [];
+ $theme_choices = [];
+ $theme_choices_mobile = [];
$theme_choices_mobile['---'] = DI::l10n()->t('No special theme for mobile devices');
- $files = glob('view/theme/*');
+ $files = glob('view/theme/*');
if (is_array($files)) {
$allowed_theme_list = DI::config()->get('system', 'allowed_themes');
@@ -397,7 +396,7 @@ class Site extends BaseAdmin
/* get user names to make the install a personal install of X */
// @TODO Move to Model\User::getNames()
- $user_names = [];
+ $user_names = [];
$user_names['---'] = DI::l10n()->t('Multi user instance');
$usersStmt = DBA::select('user', ['username', 'nickname'], ['account_removed' => 0, 'account_expired' => 0]);
@@ -421,20 +420,20 @@ class Site extends BaseAdmin
/* Register policy */
$register_choices = [
- Register::CLOSED => DI::l10n()->t('Closed'),
+ Register::CLOSED => DI::l10n()->t('Closed'),
Register::APPROVE => DI::l10n()->t('Requires approval'),
- Register::OPEN => DI::l10n()->t('Open')
+ Register::OPEN => DI::l10n()->t('Open')
];
$check_git_version_choices = [
- 'none' => DI::l10n()->t('Don\'t check'),
- 'stable' => DI::l10n()->t('check the stable version'),
+ 'none' => DI::l10n()->t('Don\'t check'),
+ 'stable' => DI::l10n()->t('check the stable version'),
'develop' => DI::l10n()->t('check the development version')
];
$discovery_choices = [
- Contact\Relation::DISCOVERY_NONE => DI::l10n()->t('none'),
- Contact\Relation::DISCOVERY_LOCAL => DI::l10n()->t('Local contacts'),
+ Contact\Relation::DISCOVERY_NONE => DI::l10n()->t('none'),
+ Contact\Relation::DISCOVERY_LOCAL => DI::l10n()->t('Local contacts'),
Contact\Relation::DISCOVERY_INTERACTOR => DI::l10n()->t('Interactors'),
// "All" is deactivated until we are sure not to put too much stress on the fediverse with this
// ContactRelation::DISCOVERY_ALL => DI::l10n()->t('All'),
@@ -467,118 +466,119 @@ class Site extends BaseAdmin
'$relocate_cmd' => DI::l10n()->t('(Friendica directory)# bin/console relocate https://newdomain.com'),
// name, label, value, help string, extra data...
- '$sitename' => ['sitename', DI::l10n()->t('Site name'), DI::config()->get('config', 'sitename'), !DI::config()->isWritable('config', 'sitename') ? DI::l10n()->t('Read-only because it is set by an environment variable') : '', '', !DI::config()->isWritable('config', 'sitename') ? 'disabled' : ''],
- '$sender_email' => ['sender_email', DI::l10n()->t('Sender Email'), DI::config()->get('config', 'sender_email'), DI::l10n()->t('The email address your server shall use to send notification emails from.'), '', '', 'email'],
+ '$sitename' => ['sitename', DI::l10n()->t('Site name'), DI::config()->get('config', 'sitename'), !DI::config()->isWritable('config', 'sitename') ? DI::l10n()->t('Read-only because it is set by an environment variable') : '', '', !DI::config()->isWritable('config', 'sitename') ? 'disabled' : ''],
+ '$sender_email' => ['sender_email', DI::l10n()->t('Sender Email'), DI::config()->get('config', 'sender_email'), DI::l10n()->t('The email address your server shall use to send notification emails from.'), '', '', 'email'],
'$system_actor_name' => ['system_actor_name', DI::l10n()->t('Name of the system actor'), User::getActorName(), DI::l10n()->t("Name of the internal system account that is used to perform ActivityPub requests. This must be an unused username. If set, this can't be changed again.")],
- '$banner' => ['banner', DI::l10n()->t('Banner/Logo'), $banner, ''],
- '$email_banner' => ['email_banner', DI::l10n()->t('Email Banner/Logo'), $email_banner, ''],
- '$shortcut_icon' => ['shortcut_icon', DI::l10n()->t('Shortcut icon'), DI::config()->get('system', 'shortcut_icon'), DI::l10n()->t('Link to an icon that will be used for browsers.')],
- '$touch_icon' => ['touch_icon', DI::l10n()->t('Touch icon'), DI::config()->get('system', 'touch_icon'), DI::l10n()->t('Link to an icon that will be used for tablets and mobiles.')],
- '$additional_info' => ['additional_info', DI::l10n()->t('Additional Info'), $additional_info, DI::l10n()->t('For public servers: you can add additional information here that will be listed at %s/servers.', Search::getGlobalDirectory())],
- '$language' => ['language', DI::l10n()->t('System language'), DI::config()->get('system', 'language'), !DI::config()->isWritable('system', 'language') ? DI::l10n()->t("Read-only because it is set by an environment variable") : '', $lang_choices, !DI::config()->isWritable('system', 'language') ? 'disabled' : ''],
- '$theme' => ['theme', DI::l10n()->t('System theme'), DI::config()->get('system', 'theme'), DI::l10n()->t('Default system theme - may be over-ridden by user profiles - Change default theme settings', DI::baseUrl() . '/admin/themes'), $theme_choices],
- '$theme_mobile' => ['theme_mobile', DI::l10n()->t('Mobile system theme'), DI::config()->get('system', 'mobile-theme', '---'), DI::l10n()->t('Theme for mobile devices'), $theme_choices_mobile],
- '$force_ssl' => ['force_ssl', DI::l10n()->t('Force SSL'), DI::config()->get('system', 'force_ssl'), DI::l10n()->t('Force all Non-SSL requests to SSL - Attention: on some systems it could lead to endless loops.')],
- '$show_help' => ['show_help', DI::l10n()->t('Show help entry from navigation menu'), !DI::config()->get('system', 'hide_help'), DI::l10n()->t('Displays the menu entry for the Help pages from the navigation menu. It is always accessible by calling /help directly.')],
- '$singleuser' => ['singleuser', DI::l10n()->t('Single user instance'), DI::config()->get('system', 'singleuser', '---'), DI::l10n()->t('Make this instance multi-user or single-user for the named user'), $user_names],
+ '$banner' => ['banner', DI::l10n()->t('Banner/Logo'), $banner, ''],
+ '$email_banner' => ['email_banner', DI::l10n()->t('Email Banner/Logo'), $email_banner, ''],
+ '$shortcut_icon' => ['shortcut_icon', DI::l10n()->t('Shortcut icon'), DI::config()->get('system', 'shortcut_icon'), DI::l10n()->t('Link to an icon that will be used for browsers.')],
+ '$touch_icon' => ['touch_icon', DI::l10n()->t('Touch icon'), DI::config()->get('system', 'touch_icon'), DI::l10n()->t('Link to an icon that will be used for tablets and mobiles.')],
+ '$additional_info' => ['additional_info', DI::l10n()->t('Additional Info'), $additional_info, DI::l10n()->t('For public servers: you can add additional information here that will be listed at %s/servers.', Search::getGlobalDirectory())],
+ '$language' => ['language', DI::l10n()->t('System language'), DI::config()->get('system', 'language'), !DI::config()->isWritable('system', 'language') ? DI::l10n()->t("Read-only because it is set by an environment variable") : '', $lang_choices, !DI::config()->isWritable('system', 'language') ? 'disabled' : ''],
+ '$theme' => ['theme', DI::l10n()->t('System theme'), DI::config()->get('system', 'theme'), DI::l10n()->t('Default system theme - may be over-ridden by user profiles - Change default theme settings', DI::baseUrl() . '/admin/themes'), $theme_choices],
+ '$theme_mobile' => ['theme_mobile', DI::l10n()->t('Mobile system theme'), DI::config()->get('system', 'mobile-theme', '---'), DI::l10n()->t('Theme for mobile devices'), $theme_choices_mobile],
+ '$force_ssl' => ['force_ssl', DI::l10n()->t('Force SSL'), DI::config()->get('system', 'force_ssl'), DI::l10n()->t('Force all Non-SSL requests to SSL - Attention: on some systems it could lead to endless loops.')],
+ '$show_help' => ['show_help', DI::l10n()->t('Show help entry from navigation menu'), !DI::config()->get('system', 'hide_help'), DI::l10n()->t('Displays the menu entry for the Help pages from the navigation menu. It is always accessible by calling /help directly.')],
+ '$singleuser' => ['singleuser', DI::l10n()->t('Single user instance'), DI::config()->get('system', 'singleuser', '---'), DI::l10n()->t('Make this instance multi-user or single-user for the named user'), $user_names],
- '$maximagesize' => ['maximagesize', DI::l10n()->t('Maximum image size'), DI::config()->get('system', 'maximagesize'), DI::l10n()->t('Maximum size in bytes of uploaded images. Default is 0, which means no limits. You can put k, m, or g behind the desired value for KiB, MiB, GiB, respectively.
+ '$maximagesize' => ['maximagesize', DI::l10n()->t('Maximum image size'), DI::config()->get('system', 'maximagesize'), DI::l10n()->t('Maximum size in bytes of uploaded images. Default is 0, which means no limits. You can put k, m, or g behind the desired value for KiB, MiB, GiB, respectively.
The value of upload_max_filesize
in your PHP.ini
needs be set to at least the desired limit.
Currently upload_max_filesize
is set to %s (%s byte)', Strings::formatBytes(Strings::getBytesFromShorthand(ini_get('upload_max_filesize'))), Strings::getBytesFromShorthand(ini_get('upload_max_filesize'))),
- '', 'pattern="\d+(?:\s*[kmg])?"'],
+ '', 'pattern="\d+(?:\s*[kmg])?"'],
'$maximagelength' => ['maximagelength', DI::l10n()->t('Maximum image length'), DI::config()->get('system', 'max_image_length'), DI::l10n()->t('Maximum length in pixels of the longest side of uploaded images. Default is -1, which means no limits.')],
'$jpegimagequality' => ['jpegimagequality', DI::l10n()->t('JPEG image quality'), DI::config()->get('system', 'jpeg_quality'), DI::l10n()->t('Uploaded JPEGS will be saved at this quality setting [0-100]. Default is 100, which is full quality.')],
'$maxfilesize' => ['maxfilesize', DI::l10n()->t('Maximum media file size'), DI::config()->get('system', 'maxfilesize'), DI::l10n()->t('Maximum size in bytes of uploaded media files. Default is 0, which means no limits. You can put k, m, or g behind the desired value for KiB, MiB, GiB, respectively.
The value of upload_max_filesize
in your PHP.ini
needs be set to at least the desired limit.
Currently upload_max_filesize
is set to %s (%s byte)', Strings::formatBytes(Strings::getBytesFromShorthand(ini_get('upload_max_filesize'))), Strings::getBytesFromShorthand(ini_get('upload_max_filesize'))),
- '', 'pattern="\d+(?:\s*[kmg])?"'],
+ '', 'pattern="\d+(?:\s*[kmg])?"'],
- '$register_policy' => ['register_policy', DI::l10n()->t('Register policy'), DI::config()->get('config', 'register_policy'), '', $register_choices],
- '$max_registered_users' => ['max_registered_users', DI::l10n()->t('Maximum Users'), DI::config()->get('config', 'max_registered_users'), DI::l10n()->t('If defined, the register policy is automatically closed when the given number of users is reached and reopens the registry when the number drops below the limit. It only works when the policy is set to open or close, but not when the policy is set to approval.')],
- '$daily_registrations' => ['max_daily_registrations', DI::l10n()->t('Maximum Daily Registrations'), DI::config()->get('system', 'max_daily_registrations'), DI::l10n()->t('If registration is permitted above, this sets the maximum number of new user registrations to accept per day. If register is set to closed, this setting has no effect.')],
- '$register_text' => ['register_text', DI::l10n()->t('Register text'), DI::config()->get('config', 'register_text'), DI::l10n()->t('Will be displayed prominently on the registration page. You can use BBCode here.')],
- '$forbidden_nicknames' => ['forbidden_nicknames', DI::l10n()->t('Forbidden Nicknames'), DI::config()->get('system', 'forbidden_nicknames'), DI::l10n()->t('Comma separated list of nicknames that are forbidden from registration. Preset is a list of role names according RFC 2142.')],
- '$abandon_days' => ['abandon_days', DI::l10n()->t('Accounts abandoned after x days'), DI::config()->get('system', 'account_abandon_days'), DI::l10n()->t('Will not waste system resources polling external sites for abandonded accounts. Enter 0 for no time limit.')],
- '$allowed_sites' => ['allowed_sites', DI::l10n()->t('Allowed friend domains'), DI::config()->get('system', 'allowed_sites'), DI::l10n()->t('Comma separated list of domains which are allowed to establish friendships with this site. Wildcards are accepted. Empty to allow any domains')],
- '$allowed_email' => ['allowed_email', DI::l10n()->t('Allowed email domains'), DI::config()->get('system', 'allowed_email'), DI::l10n()->t('Comma separated list of domains which are allowed in email addresses for registrations to this site. Wildcards are accepted. Empty to allow any domains')],
- '$disallowed_email' => ['disallowed_email', DI::l10n()->t('Disallowed email domains'), DI::config()->get('system', 'disallowed_email'), DI::l10n()->t('Comma separated list of domains which are rejected as email addresses for registrations to this site. Wildcards are accepted.')],
- '$no_oembed_rich_content' => ['no_oembed_rich_content', DI::l10n()->t('No OEmbed rich content'), DI::config()->get('system', 'no_oembed_rich_content'), DI::l10n()->t('Don\'t show the rich content (e.g. embedded PDF), except from the domains listed below.')],
- '$allowed_oembed' => ['allowed_oembed', DI::l10n()->t('Trusted third-party domains'), DI::config()->get('system', 'allowed_oembed'), DI::l10n()->t('Comma separated list of domains from which content is allowed to be embedded in posts like with OEmbed. All sub-domains of the listed domains are allowed as well.')],
- '$block_public' => ['block_public', DI::l10n()->t('Block public'), DI::config()->get('system', 'block_public'), DI::l10n()->t('Check to block public access to all otherwise public personal pages on this site unless you are currently logged in.')],
- '$force_publish' => ['publish_all', DI::l10n()->t('Force publish'), DI::config()->get('system', 'publish_all'), DI::l10n()->t('Check to force all profiles on this site to be listed in the site directory.') . '' . DI::l10n()->t('Enabling this may violate privacy laws like the GDPR') . ''],
- '$global_directory' => ['directory', DI::l10n()->t('Global directory URL'), DI::config()->get('system', 'directory'), DI::l10n()->t('URL to the global directory. If this is not set, the global directory is completely unavailable to the application.')],
- '$newuser_private' => ['newuser_private', DI::l10n()->t('Private posts by default for new users'), DI::config()->get('system', 'newuser_private'), DI::l10n()->t('Set default post permissions for all new members to the default privacy circle rather than public.')],
- '$enotify_no_content' => ['enotify_no_content', DI::l10n()->t('Don\'t include post content in email notifications'), DI::config()->get('system', 'enotify_no_content'), DI::l10n()->t('Don\'t include the content of a post/comment/private message/etc. in the email notifications that are sent out from this site, as a privacy measure.')],
- '$private_addons' => ['private_addons', DI::l10n()->t('Disallow public access to addons listed in the apps menu.'), DI::config()->get('config', 'private_addons'), DI::l10n()->t('Checking this box will restrict addons listed in the apps menu to members only.')],
- '$disable_embedded' => ['disable_embedded', DI::l10n()->t('Don\'t embed private images in posts'), DI::config()->get('system', 'disable_embedded'), DI::l10n()->t('Don\'t replace locally-hosted private photos in posts with an embedded copy of the image. This means that contacts who receive posts containing private photos will have to authenticate and load each image, which may take a while.')],
- '$explicit_content' => ['explicit_content', DI::l10n()->t('Explicit Content'), DI::config()->get('system', 'explicit_content'), DI::l10n()->t('Set this to announce that your node is used mostly for explicit content that might not be suited for minors. This information will be published in the node information and might be used, e.g. by the global directory, to filter your node from listings of nodes to join. Additionally a note about this will be shown at the user registration page.')],
- '$local_search' => ['local_search', DI::l10n()->t('Only local search'), DI::config()->get('system', 'local_search'), DI::l10n()->t('Blocks search for users who are not logged in to prevent crawlers from blocking your system.')],
- '$blocked_tags' => ['blocked_tags', DI::l10n()->t('Blocked tags for trending tags'), DI::config()->get('system', 'blocked_tags'), DI::l10n()->t("Comma separated list of hashtags that shouldn't be displayed in the trending tags.")],
- '$cache_contact_avatar' => ['cache_contact_avatar', DI::l10n()->t('Cache contact avatars'), DI::config()->get('system', 'cache_contact_avatar'), DI::l10n()->t('Locally store the avatar pictures of the contacts. This uses a lot of storage space but it increases the performance.')],
- '$allow_users_remote_self'=> ['allow_users_remote_self', DI::l10n()->t('Allow Users to set remote_self'), DI::config()->get('system', 'allow_users_remote_self'), DI::l10n()->t('With checking this, every user is allowed to mark every contact as a remote_self in the repair contact dialog. Setting this flag on a contact causes mirroring every posting of that contact in the users stream.')],
- '$allow_relay_channels' => ['allow_relay_channels', DI::l10n()->t('Allow Users to set up relay channels'), DI::config()->get('system', 'allow_relay_channels'), DI::l10n()->t('If enabled, it is possible to create relay users that are used to reshare content based on user defined channels.')],
- '$adjust_poll_frequency' => ['adjust_poll_frequency', DI::l10n()->t('Adjust the feed poll frequency'), DI::config()->get('system', 'adjust_poll_frequency'), DI::l10n()->t('Automatically detect and set the best feed poll frequency.')],
- '$min_poll_interval' => ['min_poll_interval', DI::l10n()->t('Minimum poll interval'), DI::config()->get('system', 'min_poll_interval'), DI::l10n()->t('Minimal distance in minutes between two polls for mail and feed contacts. Reasonable values are between 1 and 59.')],
- '$enable_multi_reg' => ['enable_multi_reg', DI::l10n()->t('Enable multiple registrations'), !DI::config()->get('system', 'block_extended_register'), DI::l10n()->t('Enable users to register additional accounts for use as pages.')],
- '$enable_openid' => ['enable_openid', DI::l10n()->t('Enable OpenID'), !DI::config()->get('system', 'no_openid'), DI::l10n()->t('Enable OpenID support for registration and logins.')],
- '$enable_regfullname' => ['enable_regfullname', DI::l10n()->t('Enable full name check'), !DI::config()->get('system', 'no_regfullname'), DI::l10n()->t('Prevents users from registering with a display name with fewer than two parts separated by spaces.')],
- '$register_notification' => ['register_notification', DI::l10n()->t('Email administrators on new registration'), DI::config()->get('system', 'register_notification'), DI::l10n()->t('If enabled and the system is set to an open registration, an email for each new registration is sent to the administrators.')],
- '$community_page_style' => ['community_page_style', DI::l10n()->t('Community pages for visitors'), DI::config()->get('system', 'community_page_style'), DI::l10n()->t('Which community pages should be available for visitors. Local users always see both pages.'), $community_page_style_choices],
+ '$register_policy' => ['register_policy', DI::l10n()->t('Register policy'), DI::config()->get('config', 'register_policy'), '', $register_choices],
+ '$max_registered_users' => ['max_registered_users', DI::l10n()->t('Maximum Users'), DI::config()->get('config', 'max_registered_users'), DI::l10n()->t('If defined, the register policy is automatically closed when the given number of users is reached and reopens the registry when the number drops below the limit. It only works when the policy is set to open or close, but not when the policy is set to approval.')],
+ '$daily_registrations' => ['max_daily_registrations', DI::l10n()->t('Maximum Daily Registrations'), DI::config()->get('system', 'max_daily_registrations'), DI::l10n()->t('If registration is permitted above, this sets the maximum number of new user registrations to accept per day. If register is set to closed, this setting has no effect.')],
+ '$register_text' => ['register_text', DI::l10n()->t('Register text'), DI::config()->get('config', 'register_text'), DI::l10n()->t('Will be displayed prominently on the registration page. You can use BBCode here.')],
+ '$forbidden_nicknames' => ['forbidden_nicknames', DI::l10n()->t('Forbidden Nicknames'), DI::config()->get('system', 'forbidden_nicknames'), DI::l10n()->t('Comma separated list of nicknames that are forbidden from registration. Preset is a list of role names according RFC 2142.')],
+ '$abandon_days' => ['abandon_days', DI::l10n()->t('Accounts abandoned after x days'), DI::config()->get('system', 'account_abandon_days'), DI::l10n()->t('Will not waste system resources polling external sites for abandonded accounts. Enter 0 for no time limit.')],
+ '$allowed_sites' => ['allowed_sites', DI::l10n()->t('Allowed friend domains'), DI::config()->get('system', 'allowed_sites'), DI::l10n()->t('Comma separated list of domains which are allowed to establish friendships with this site. Wildcards are accepted. Empty to allow any domains')],
+ '$allowed_email' => ['allowed_email', DI::l10n()->t('Allowed email domains'), DI::config()->get('system', 'allowed_email'), DI::l10n()->t('Comma separated list of domains which are allowed in email addresses for registrations to this site. Wildcards are accepted. Empty to allow any domains')],
+ '$disallowed_email' => ['disallowed_email', DI::l10n()->t('Disallowed email domains'), DI::config()->get('system', 'disallowed_email'), DI::l10n()->t('Comma separated list of domains which are rejected as email addresses for registrations to this site. Wildcards are accepted.')],
+ '$no_oembed_rich_content' => ['no_oembed_rich_content', DI::l10n()->t('No OEmbed rich content'), DI::config()->get('system', 'no_oembed_rich_content'), DI::l10n()->t('Don\'t show the rich content (e.g. embedded PDF), except from the domains listed below.')],
+ '$allowed_oembed' => ['allowed_oembed', DI::l10n()->t('Trusted third-party domains'), DI::config()->get('system', 'allowed_oembed'), DI::l10n()->t('Comma separated list of domains from which content is allowed to be embedded in posts like with OEmbed. All sub-domains of the listed domains are allowed as well.')],
+ '$block_public' => ['block_public', DI::l10n()->t('Block public'), DI::config()->get('system', 'block_public'), DI::l10n()->t('Check to block public access to all otherwise public personal pages on this site unless you are currently logged in.')],
+ '$force_publish' => ['publish_all', DI::l10n()->t('Force publish'), DI::config()->get('system', 'publish_all'), DI::l10n()->t('Check to force all profiles on this site to be listed in the site directory.') . '' . DI::l10n()->t('Enabling this may violate privacy laws like the GDPR') . ''],
+ '$global_directory' => ['directory', DI::l10n()->t('Global directory URL'), DI::config()->get('system', 'directory'), DI::l10n()->t('URL to the global directory. If this is not set, the global directory is completely unavailable to the application.')],
+ '$newuser_private' => ['newuser_private', DI::l10n()->t('Private posts by default for new users'), DI::config()->get('system', 'newuser_private'), DI::l10n()->t('Set default post permissions for all new members to the default privacy circle rather than public.')],
+ '$enotify_no_content' => ['enotify_no_content', DI::l10n()->t('Don\'t include post content in email notifications'), DI::config()->get('system', 'enotify_no_content'), DI::l10n()->t('Don\'t include the content of a post/comment/private message/etc. in the email notifications that are sent out from this site, as a privacy measure.')],
+ '$private_addons' => ['private_addons', DI::l10n()->t('Disallow public access to addons listed in the apps menu.'), DI::config()->get('config', 'private_addons'), DI::l10n()->t('Checking this box will restrict addons listed in the apps menu to members only.')],
+ '$disable_embedded' => ['disable_embedded', DI::l10n()->t('Don\'t embed private images in posts'), DI::config()->get('system', 'disable_embedded'), DI::l10n()->t('Don\'t replace locally-hosted private photos in posts with an embedded copy of the image. This means that contacts who receive posts containing private photos will have to authenticate and load each image, which may take a while.')],
+ '$explicit_content' => ['explicit_content', DI::l10n()->t('Explicit Content'), DI::config()->get('system', 'explicit_content'), DI::l10n()->t('Set this to announce that your node is used mostly for explicit content that might not be suited for minors. This information will be published in the node information and might be used, e.g. by the global directory, to filter your node from listings of nodes to join. Additionally a note about this will be shown at the user registration page.')],
+ '$local_search' => ['local_search', DI::l10n()->t('Only local search'), DI::config()->get('system', 'local_search'), DI::l10n()->t('Blocks search for users who are not logged in to prevent crawlers from blocking your system.')],
+ '$blocked_tags' => ['blocked_tags', DI::l10n()->t('Blocked tags for trending tags'), DI::config()->get('system', 'blocked_tags'), DI::l10n()->t("Comma separated list of hashtags that shouldn't be displayed in the trending tags.")],
+ '$cache_contact_avatar' => ['cache_contact_avatar', DI::l10n()->t('Cache contact avatars'), DI::config()->get('system', 'cache_contact_avatar'), DI::l10n()->t('Locally store the avatar pictures of the contacts. This uses a lot of storage space but it increases the performance.')],
+ '$allow_users_remote_self' => ['allow_users_remote_self', DI::l10n()->t('Allow Users to set remote_self'), DI::config()->get('system', 'allow_users_remote_self'), DI::l10n()->t('With checking this, every user is allowed to mark every contact as a remote_self in the repair contact dialog. Setting this flag on a contact causes mirroring every posting of that contact in the users stream.')],
+ '$allow_relay_channels' => ['allow_relay_channels', DI::l10n()->t('Allow Users to set up relay channels'), DI::config()->get('system', 'allow_relay_channels'), DI::l10n()->t('If enabled, it is possible to create relay users that are used to reshare content based on user defined channels.')],
+ '$adjust_poll_frequency' => ['adjust_poll_frequency', DI::l10n()->t('Adjust the feed poll frequency'), DI::config()->get('system', 'adjust_poll_frequency'), DI::l10n()->t('Automatically detect and set the best feed poll frequency.')],
+ '$min_poll_interval' => ['min_poll_interval', DI::l10n()->t('Minimum poll interval'), DI::config()->get('system', 'min_poll_interval'), DI::l10n()->t('Minimal distance in minutes between two polls for mail and feed contacts. Reasonable values are between 1 and 59.')],
+ '$enable_multi_reg' => ['enable_multi_reg', DI::l10n()->t('Enable multiple registrations'), !DI::config()->get('system', 'block_extended_register'), DI::l10n()->t('Enable users to register additional accounts for use as pages.')],
+ '$enable_openid' => ['enable_openid', DI::l10n()->t('Enable OpenID'), !DI::config()->get('system', 'no_openid'), DI::l10n()->t('Enable OpenID support for registration and logins.')],
+ '$enable_regfullname' => ['enable_regfullname', DI::l10n()->t('Enable full name check'), !DI::config()->get('system', 'no_regfullname'), DI::l10n()->t('Prevents users from registering with a display name with fewer than two parts separated by spaces.')],
+ '$register_notification' => ['register_notification', DI::l10n()->t('Email administrators on new registration'), DI::config()->get('system', 'register_notification'), DI::l10n()->t('If enabled and the system is set to an open registration, an email for each new registration is sent to the administrators.')],
+ '$community_page_style' => ['community_page_style', DI::l10n()->t('Community pages for visitors'), DI::config()->get('system', 'community_page_style'), DI::l10n()->t('Which community pages should be available for visitors. Local users always see both pages.'), $community_page_style_choices],
'$max_author_posts_community_page' => ['max_author_posts_community_page', DI::l10n()->t('Posts per user on community page'), DI::config()->get('system', 'max_author_posts_community_page'), DI::l10n()->t('The maximum number of posts per user on the local community page. This is useful, when a single user floods the local community page.')],
'$max_server_posts_community_page' => ['max_server_posts_community_page', DI::l10n()->t('Posts per server on community page'), DI::config()->get('system', 'max_server_posts_community_page'), DI::l10n()->t('The maximum number of posts per server on the global community page. This is useful, when posts from a single server flood the global community page.')],
- '$mail_able' => function_exists('imap_open'),
- '$mail_enabled' => ['mail_enabled', DI::l10n()->t('Enable Mail support'), !DI::config()->get('system', 'imap_disabled', !function_exists('imap_open')), DI::l10n()->t('Enable built-in mail support to poll IMAP folders and to reply via mail.')],
- '$mail_not_able' => DI::l10n()->t('Mail support can\'t be enabled because the PHP IMAP module is not installed.'),
- '$diaspora_able' => $diaspora_able,
- '$diaspora_not_able' => DI::l10n()->t('Diaspora support can\'t be enabled because Friendica was installed into a sub directory.'),
- '$diaspora_enabled' => ['diaspora_enabled', DI::l10n()->t('Enable Diaspora support'), DI::config()->get('system', 'diaspora_enabled', $diaspora_able), DI::l10n()->t('Enable built-in Diaspora network compatibility for communicating with diaspora servers.')],
- '$verifyssl' => ['verifyssl', DI::l10n()->t('Verify SSL'), DI::config()->get('system', 'verifyssl'), DI::l10n()->t('If you wish, you can turn on strict certificate checking. This will mean you cannot connect (at all) to self-signed SSL sites.')],
- '$proxyuser' => ['proxyuser', DI::l10n()->t('Proxy user'), DI::config()->get('system', 'proxyuser'), DI::l10n()->t('User name for the proxy server.')],
- '$proxy' => ['proxy', DI::l10n()->t('Proxy URL'), DI::config()->get('system', 'proxy'), DI::l10n()->t('If you want to use a proxy server that Friendica should use to connect to the network, put the URL of the proxy here.')],
- '$timeout' => ['timeout', DI::l10n()->t('Network timeout'), DI::config()->get('system', 'curl_timeout'), DI::l10n()->t('Value is in seconds. Set to 0 for unlimited (not recommended).')],
- '$maxloadavg' => ['maxloadavg', DI::l10n()->t('Maximum Load Average'), DI::config()->get('system', 'maxloadavg'), DI::l10n()->t('Maximum system load before delivery and poll processes are deferred - default %d.', 20)],
- '$min_memory' => ['min_memory', DI::l10n()->t('Minimal Memory'), DI::config()->get('system', 'min_memory'), DI::l10n()->t('Minimal free memory in MB for the worker. Needs access to /proc/meminfo - default 0 (deactivated).')],
- '$optimize_tables' => ['optimize_tables', DI::l10n()->t('Periodically optimize tables'), DI::config()->get('system', 'optimize_tables'), DI::l10n()->t('Periodically optimize tables like the cache and the workerqueue')],
+ '$mail_able' => function_exists('imap_open'),
+ '$mail_enabled' => ['mail_enabled', DI::l10n()->t('Enable Mail support'), !DI::config()->get('system', 'imap_disabled', !function_exists('imap_open')), DI::l10n()->t('Enable built-in mail support to poll IMAP folders and to reply via mail.')],
+ '$mail_not_able' => DI::l10n()->t('Mail support can\'t be enabled because the PHP IMAP module is not installed.'),
+ '$diaspora_able' => $diaspora_able,
+ '$diaspora_not_able' => DI::l10n()->t('Diaspora support can\'t be enabled because Friendica was installed into a sub directory.'),
+ '$diaspora_enabled' => ['diaspora_enabled', DI::l10n()->t('Enable Diaspora support'), DI::config()->get('system', 'diaspora_enabled', $diaspora_able), DI::l10n()->t('Enable built-in Diaspora network compatibility for communicating with diaspora servers.')],
+ '$verifyssl' => ['verifyssl', DI::l10n()->t('Verify SSL'), DI::config()->get('system', 'verifyssl'), DI::l10n()->t('If you wish, you can turn on strict certificate checking. This will mean you cannot connect (at all) to self-signed SSL sites.')],
+ '$proxyuser' => ['proxyuser', DI::l10n()->t('Proxy user'), DI::config()->get('system', 'proxyuser'), DI::l10n()->t('User name for the proxy server.')],
+ '$proxy' => ['proxy', DI::l10n()->t('Proxy URL'), DI::config()->get('system', 'proxy'), DI::l10n()->t('If you want to use a proxy server that Friendica should use to connect to the network, put the URL of the proxy here.')],
+ '$timeout' => ['timeout', DI::l10n()->t('Network timeout'), DI::config()->get('system', 'curl_timeout'), DI::l10n()->t('Value is in seconds. Set to 0 for unlimited (not recommended).')],
+ '$maxloadavg' => ['maxloadavg', DI::l10n()->t('Maximum Load Average'), DI::config()->get('system', 'maxloadavg'), DI::l10n()->t('Maximum system load before delivery and poll processes are deferred - default %d.', 20)],
+ '$min_memory' => ['min_memory', DI::l10n()->t('Minimal Memory'), DI::config()->get('system', 'min_memory'), DI::l10n()->t('Minimal free memory in MB for the worker. Needs access to /proc/meminfo - default 0 (deactivated).')],
+ '$optimize_tables' => ['optimize_tables', DI::l10n()->t('Periodically optimize tables'), DI::config()->get('system', 'optimize_tables'), DI::l10n()->t('Periodically optimize tables like the cache and the workerqueue')],
- '$contact_discovery' => ['contact_discovery', DI::l10n()->t('Discover followers/followings from contacts'), DI::config()->get('system', 'contact_discovery'), DI::l10n()->t('If enabled, contacts are checked for their followers and following contacts.') . '
upload_max_filesize
is set to %s (%s byte)"
msgstr ""
-#: src/Module/Admin/Site.php:489
+#: src/Module/Admin/Site.php:491
msgid "Maximum image length"
msgstr ""
-#: src/Module/Admin/Site.php:489
+#: src/Module/Admin/Site.php:491
msgid "Maximum length in pixels of the longest side of uploaded images. Default is -1, which means no limits."
msgstr ""
-#: src/Module/Admin/Site.php:490
+#: src/Module/Admin/Site.php:492
msgid "JPEG image quality"
msgstr ""
-#: src/Module/Admin/Site.php:490
+#: src/Module/Admin/Site.php:492
msgid "Uploaded JPEGS will be saved at this quality setting [0-100]. Default is 100, which is full quality."
msgstr ""
-#: src/Module/Admin/Site.php:491
+#: src/Module/Admin/Site.php:493
msgid "Maximum media file size"
msgstr ""
-#: src/Module/Admin/Site.php:491
+#: src/Module/Admin/Site.php:493
#, php-format
msgid ""
"Maximum size in bytes of uploaded media files. Default is 0, which means no limits. You can put k, m, or g behind the desired value for KiB, MiB, GiB, respectively.\n"
@@ -4560,739 +4560,747 @@ msgid ""
"\t\t\t\t\t\t\t\t\t\t\t\t\tCurrently upload_max_filesize
is set to %s (%s byte)"
msgstr ""
-#: src/Module/Admin/Site.php:496
+#: src/Module/Admin/Site.php:498
msgid "Register policy"
msgstr ""
-#: src/Module/Admin/Site.php:497
+#: src/Module/Admin/Site.php:499
msgid "Maximum Users"
msgstr ""
-#: src/Module/Admin/Site.php:497
+#: src/Module/Admin/Site.php:499
msgid "If defined, the register policy is automatically closed when the given number of users is reached and reopens the registry when the number drops below the limit. It only works when the policy is set to open or close, but not when the policy is set to approval."
msgstr ""
-#: src/Module/Admin/Site.php:498
+#: src/Module/Admin/Site.php:500
msgid "Maximum Daily Registrations"
msgstr ""
-#: src/Module/Admin/Site.php:498
+#: src/Module/Admin/Site.php:500
msgid "If registration is permitted above, this sets the maximum number of new user registrations to accept per day. If register is set to closed, this setting has no effect."
msgstr ""
-#: src/Module/Admin/Site.php:499
+#: src/Module/Admin/Site.php:501
msgid "Register text"
msgstr ""
-#: src/Module/Admin/Site.php:499
+#: src/Module/Admin/Site.php:501
msgid "Will be displayed prominently on the registration page. You can use BBCode here."
msgstr ""
-#: src/Module/Admin/Site.php:500
+#: src/Module/Admin/Site.php:502
msgid "Forbidden Nicknames"
msgstr ""
-#: src/Module/Admin/Site.php:500
+#: src/Module/Admin/Site.php:502
msgid "Comma separated list of nicknames that are forbidden from registration. Preset is a list of role names according RFC 2142."
msgstr ""
-#: src/Module/Admin/Site.php:501
+#: src/Module/Admin/Site.php:503
msgid "Accounts abandoned after x days"
msgstr ""
-#: src/Module/Admin/Site.php:501
+#: src/Module/Admin/Site.php:503
msgid "Will not waste system resources polling external sites for abandonded accounts. Enter 0 for no time limit."
msgstr ""
-#: src/Module/Admin/Site.php:502
+#: src/Module/Admin/Site.php:504
msgid "Allowed friend domains"
msgstr ""
-#: src/Module/Admin/Site.php:502
+#: src/Module/Admin/Site.php:504
msgid "Comma separated list of domains which are allowed to establish friendships with this site. Wildcards are accepted. Empty to allow any domains"
msgstr ""
-#: src/Module/Admin/Site.php:503
+#: src/Module/Admin/Site.php:505
msgid "Allowed email domains"
msgstr ""
-#: src/Module/Admin/Site.php:503
+#: src/Module/Admin/Site.php:505
msgid "Comma separated list of domains which are allowed in email addresses for registrations to this site. Wildcards are accepted. Empty to allow any domains"
msgstr ""
-#: src/Module/Admin/Site.php:504
+#: src/Module/Admin/Site.php:506
msgid "Disallowed email domains"
msgstr ""
-#: src/Module/Admin/Site.php:504
+#: src/Module/Admin/Site.php:506
msgid "Comma separated list of domains which are rejected as email addresses for registrations to this site. Wildcards are accepted."
msgstr ""
-#: src/Module/Admin/Site.php:505
+#: src/Module/Admin/Site.php:507
msgid "No OEmbed rich content"
msgstr ""
-#: src/Module/Admin/Site.php:505
+#: src/Module/Admin/Site.php:507
msgid "Don't show the rich content (e.g. embedded PDF), except from the domains listed below."
msgstr ""
-#: src/Module/Admin/Site.php:506
+#: src/Module/Admin/Site.php:508
msgid "Trusted third-party domains"
msgstr ""
-#: src/Module/Admin/Site.php:506
+#: src/Module/Admin/Site.php:508
msgid "Comma separated list of domains from which content is allowed to be embedded in posts like with OEmbed. All sub-domains of the listed domains are allowed as well."
msgstr ""
-#: src/Module/Admin/Site.php:507
+#: src/Module/Admin/Site.php:509
msgid "Block public"
msgstr ""
-#: src/Module/Admin/Site.php:507
+#: src/Module/Admin/Site.php:509
msgid "Check to block public access to all otherwise public personal pages on this site unless you are currently logged in."
msgstr ""
-#: src/Module/Admin/Site.php:508
+#: src/Module/Admin/Site.php:510
msgid "Force publish"
msgstr ""
-#: src/Module/Admin/Site.php:508
+#: src/Module/Admin/Site.php:510
msgid "Check to force all profiles on this site to be listed in the site directory."
msgstr ""
-#: src/Module/Admin/Site.php:508
+#: src/Module/Admin/Site.php:510
msgid "Enabling this may violate privacy laws like the GDPR"
msgstr ""
-#: src/Module/Admin/Site.php:509
+#: src/Module/Admin/Site.php:511
msgid "Global directory URL"
msgstr ""
-#: src/Module/Admin/Site.php:509
+#: src/Module/Admin/Site.php:511
msgid "URL to the global directory. If this is not set, the global directory is completely unavailable to the application."
msgstr ""
-#: src/Module/Admin/Site.php:510
+#: src/Module/Admin/Site.php:512
msgid "Private posts by default for new users"
msgstr ""
-#: src/Module/Admin/Site.php:510
+#: src/Module/Admin/Site.php:512
msgid "Set default post permissions for all new members to the default privacy circle rather than public."
msgstr ""
-#: src/Module/Admin/Site.php:511
+#: src/Module/Admin/Site.php:513
msgid "Don't include post content in email notifications"
msgstr ""
-#: src/Module/Admin/Site.php:511
+#: src/Module/Admin/Site.php:513
msgid "Don't include the content of a post/comment/private message/etc. in the email notifications that are sent out from this site, as a privacy measure."
msgstr ""
-#: src/Module/Admin/Site.php:512
+#: src/Module/Admin/Site.php:514
msgid "Disallow public access to addons listed in the apps menu."
msgstr ""
-#: src/Module/Admin/Site.php:512
+#: src/Module/Admin/Site.php:514
msgid "Checking this box will restrict addons listed in the apps menu to members only."
msgstr ""
-#: src/Module/Admin/Site.php:513
+#: src/Module/Admin/Site.php:515
msgid "Don't embed private images in posts"
msgstr ""
-#: src/Module/Admin/Site.php:513
+#: src/Module/Admin/Site.php:515
msgid "Don't replace locally-hosted private photos in posts with an embedded copy of the image. This means that contacts who receive posts containing private photos will have to authenticate and load each image, which may take a while."
msgstr ""
-#: src/Module/Admin/Site.php:514
+#: src/Module/Admin/Site.php:516
msgid "Explicit Content"
msgstr ""
-#: src/Module/Admin/Site.php:514
+#: src/Module/Admin/Site.php:516
msgid "Set this to announce that your node is used mostly for explicit content that might not be suited for minors. This information will be published in the node information and might be used, e.g. by the global directory, to filter your node from listings of nodes to join. Additionally a note about this will be shown at the user registration page."
msgstr ""
-#: src/Module/Admin/Site.php:515
+#: src/Module/Admin/Site.php:517
msgid "Only local search"
msgstr ""
-#: src/Module/Admin/Site.php:515
+#: src/Module/Admin/Site.php:517
msgid "Blocks search for users who are not logged in to prevent crawlers from blocking your system."
msgstr ""
-#: src/Module/Admin/Site.php:516
+#: src/Module/Admin/Site.php:518
msgid "Blocked tags for trending tags"
msgstr ""
-#: src/Module/Admin/Site.php:516
+#: src/Module/Admin/Site.php:518
msgid "Comma separated list of hashtags that shouldn't be displayed in the trending tags."
msgstr ""
-#: src/Module/Admin/Site.php:517
+#: src/Module/Admin/Site.php:519
msgid "Cache contact avatars"
msgstr ""
-#: src/Module/Admin/Site.php:517
+#: src/Module/Admin/Site.php:519
msgid "Locally store the avatar pictures of the contacts. This uses a lot of storage space but it increases the performance."
msgstr ""
-#: src/Module/Admin/Site.php:518
+#: src/Module/Admin/Site.php:520
msgid "Allow Users to set remote_self"
msgstr ""
-#: src/Module/Admin/Site.php:518
+#: src/Module/Admin/Site.php:520
msgid "With checking this, every user is allowed to mark every contact as a remote_self in the repair contact dialog. Setting this flag on a contact causes mirroring every posting of that contact in the users stream."
msgstr ""
-#: src/Module/Admin/Site.php:519
+#: src/Module/Admin/Site.php:521
msgid "Allow Users to set up relay channels"
msgstr ""
-#: src/Module/Admin/Site.php:519
+#: src/Module/Admin/Site.php:521
msgid "If enabled, it is possible to create relay users that are used to reshare content based on user defined channels."
msgstr ""
-#: src/Module/Admin/Site.php:520
+#: src/Module/Admin/Site.php:522
msgid "Adjust the feed poll frequency"
msgstr ""
-#: src/Module/Admin/Site.php:520
+#: src/Module/Admin/Site.php:522
msgid "Automatically detect and set the best feed poll frequency."
msgstr ""
-#: src/Module/Admin/Site.php:521
+#: src/Module/Admin/Site.php:523
msgid "Minimum poll interval"
msgstr ""
-#: src/Module/Admin/Site.php:521
+#: src/Module/Admin/Site.php:523
msgid "Minimal distance in minutes between two polls for mail and feed contacts. Reasonable values are between 1 and 59."
msgstr ""
-#: src/Module/Admin/Site.php:522
+#: src/Module/Admin/Site.php:524
msgid "Enable multiple registrations"
msgstr ""
-#: src/Module/Admin/Site.php:522
+#: src/Module/Admin/Site.php:524
msgid "Enable users to register additional accounts for use as pages."
msgstr ""
-#: src/Module/Admin/Site.php:523
+#: src/Module/Admin/Site.php:525
msgid "Enable OpenID"
msgstr ""
-#: src/Module/Admin/Site.php:523
+#: src/Module/Admin/Site.php:525
msgid "Enable OpenID support for registration and logins."
msgstr ""
-#: src/Module/Admin/Site.php:524
+#: src/Module/Admin/Site.php:526
msgid "Enable full name check"
msgstr ""
-#: src/Module/Admin/Site.php:524
+#: src/Module/Admin/Site.php:526
msgid "Prevents users from registering with a display name with fewer than two parts separated by spaces."
msgstr ""
-#: src/Module/Admin/Site.php:525
+#: src/Module/Admin/Site.php:527
msgid "Email administrators on new registration"
msgstr ""
-#: src/Module/Admin/Site.php:525
+#: src/Module/Admin/Site.php:527
msgid "If enabled and the system is set to an open registration, an email for each new registration is sent to the administrators."
msgstr ""
-#: src/Module/Admin/Site.php:526
+#: src/Module/Admin/Site.php:528
msgid "Community pages for visitors"
msgstr ""
-#: src/Module/Admin/Site.php:526
+#: src/Module/Admin/Site.php:528
msgid "Which community pages should be available for visitors. Local users always see both pages."
msgstr ""
-#: src/Module/Admin/Site.php:527
+#: src/Module/Admin/Site.php:529
msgid "Posts per user on community page"
msgstr ""
-#: src/Module/Admin/Site.php:527
+#: src/Module/Admin/Site.php:529
msgid "The maximum number of posts per user on the local community page. This is useful, when a single user floods the local community page."
msgstr ""
-#: src/Module/Admin/Site.php:528
+#: src/Module/Admin/Site.php:530
msgid "Posts per server on community page"
msgstr ""
-#: src/Module/Admin/Site.php:528
+#: src/Module/Admin/Site.php:530
msgid "The maximum number of posts per server on the global community page. This is useful, when posts from a single server flood the global community page."
msgstr ""
-#: src/Module/Admin/Site.php:530
+#: src/Module/Admin/Site.php:532
msgid "Enable Mail support"
msgstr ""
-#: src/Module/Admin/Site.php:530
+#: src/Module/Admin/Site.php:532
msgid "Enable built-in mail support to poll IMAP folders and to reply via mail."
msgstr ""
-#: src/Module/Admin/Site.php:531
+#: src/Module/Admin/Site.php:533
msgid "Mail support can't be enabled because the PHP IMAP module is not installed."
msgstr ""
-#: src/Module/Admin/Site.php:533
+#: src/Module/Admin/Site.php:535
msgid "Diaspora support can't be enabled because Friendica was installed into a sub directory."
msgstr ""
-#: src/Module/Admin/Site.php:534
+#: src/Module/Admin/Site.php:536
msgid "Enable Diaspora support"
msgstr ""
-#: src/Module/Admin/Site.php:534
+#: src/Module/Admin/Site.php:536
msgid "Enable built-in Diaspora network compatibility for communicating with diaspora servers."
msgstr ""
-#: src/Module/Admin/Site.php:535
+#: src/Module/Admin/Site.php:537
msgid "Verify SSL"
msgstr ""
-#: src/Module/Admin/Site.php:535
+#: src/Module/Admin/Site.php:537
msgid "If you wish, you can turn on strict certificate checking. This will mean you cannot connect (at all) to self-signed SSL sites."
msgstr ""
-#: src/Module/Admin/Site.php:536
+#: src/Module/Admin/Site.php:538
msgid "Proxy user"
msgstr ""
-#: src/Module/Admin/Site.php:536
+#: src/Module/Admin/Site.php:538
msgid "User name for the proxy server."
msgstr ""
-#: src/Module/Admin/Site.php:537
+#: src/Module/Admin/Site.php:539
msgid "Proxy URL"
msgstr ""
-#: src/Module/Admin/Site.php:537
+#: src/Module/Admin/Site.php:539
msgid "If you want to use a proxy server that Friendica should use to connect to the network, put the URL of the proxy here."
msgstr ""
-#: src/Module/Admin/Site.php:538
+#: src/Module/Admin/Site.php:540
msgid "Network timeout"
msgstr ""
-#: src/Module/Admin/Site.php:538
+#: src/Module/Admin/Site.php:540
msgid "Value is in seconds. Set to 0 for unlimited (not recommended)."
msgstr ""
-#: src/Module/Admin/Site.php:539
+#: src/Module/Admin/Site.php:541
msgid "Maximum Load Average"
msgstr ""
-#: src/Module/Admin/Site.php:539
+#: src/Module/Admin/Site.php:541
#, php-format
msgid "Maximum system load before delivery and poll processes are deferred - default %d."
msgstr ""
-#: src/Module/Admin/Site.php:540
+#: src/Module/Admin/Site.php:542
msgid "Minimal Memory"
msgstr ""
-#: src/Module/Admin/Site.php:540
+#: src/Module/Admin/Site.php:542
msgid "Minimal free memory in MB for the worker. Needs access to /proc/meminfo - default 0 (deactivated)."
msgstr ""
-#: src/Module/Admin/Site.php:541
+#: src/Module/Admin/Site.php:543
msgid "Periodically optimize tables"
msgstr ""
-#: src/Module/Admin/Site.php:541
+#: src/Module/Admin/Site.php:543
msgid "Periodically optimize tables like the cache and the workerqueue"
msgstr ""
-#: src/Module/Admin/Site.php:543
+#: src/Module/Admin/Site.php:545
msgid "Discover followers/followings from contacts"
msgstr ""
-#: src/Module/Admin/Site.php:543
+#: src/Module/Admin/Site.php:545
msgid "If enabled, contacts are checked for their followers and following contacts."
msgstr ""
-#: src/Module/Admin/Site.php:544
+#: src/Module/Admin/Site.php:546
msgid "None - deactivated"
msgstr ""
-#: src/Module/Admin/Site.php:545
+#: src/Module/Admin/Site.php:547
msgid "Local contacts - contacts of our local contacts are discovered for their followers/followings."
msgstr ""
-#: src/Module/Admin/Site.php:546
+#: src/Module/Admin/Site.php:548
msgid "Interactors - contacts of our local contacts and contacts who interacted on locally visible postings are discovered for their followers/followings."
msgstr ""
-#: src/Module/Admin/Site.php:548
+#: src/Module/Admin/Site.php:550
msgid "Only update contacts/servers with local data"
msgstr ""
-#: src/Module/Admin/Site.php:548
+#: src/Module/Admin/Site.php:550
msgid "If enabled, the system will only look for changes in contacts and servers that engaged on this system by either being in a contact list of a user or when posts or comments exists from the contact on this system."
msgstr ""
-#: src/Module/Admin/Site.php:549
+#: src/Module/Admin/Site.php:551
+msgid "Only update contacts with relations"
+msgstr ""
+
+#: src/Module/Admin/Site.php:551
+msgid "If enabled, the system will only look for changes in contacts that are in a contact list of a user on this system."
+msgstr ""
+
+#: src/Module/Admin/Site.php:552
msgid "Synchronize the contacts with the directory server"
msgstr ""
-#: src/Module/Admin/Site.php:549
+#: src/Module/Admin/Site.php:552
msgid "if enabled, the system will check periodically for new contacts on the defined directory server."
msgstr ""
-#: src/Module/Admin/Site.php:551
+#: src/Module/Admin/Site.php:554
msgid "Discover contacts from other servers"
msgstr ""
-#: src/Module/Admin/Site.php:551
+#: src/Module/Admin/Site.php:554
msgid "Periodically query other servers for contacts and servers that they know of. The system queries Friendica, Mastodon and Hubzilla servers. Keep it deactivated on small machines to decrease the database size and load."
msgstr ""
-#: src/Module/Admin/Site.php:552
+#: src/Module/Admin/Site.php:555
msgid "Days between requery"
msgstr ""
-#: src/Module/Admin/Site.php:552
+#: src/Module/Admin/Site.php:555
msgid "Number of days after which a server is requeried for their contacts and servers it knows of. This is only used when the discovery is activated."
msgstr ""
-#: src/Module/Admin/Site.php:553
+#: src/Module/Admin/Site.php:556
msgid "Search the local directory"
msgstr ""
-#: src/Module/Admin/Site.php:553
+#: src/Module/Admin/Site.php:556
msgid "Search the local directory instead of the global directory. When searching locally, every search will be executed on the global directory in the background. This improves the search results when the search is repeated."
msgstr ""
-#: src/Module/Admin/Site.php:555
+#: src/Module/Admin/Site.php:558
msgid "Publish server information"
msgstr ""
-#: src/Module/Admin/Site.php:555
+#: src/Module/Admin/Site.php:558
msgid "If enabled, general server and usage data will be published. The data contains the name and version of the server, number of users with public profiles, number of posts and the activated protocols and connectors. See the-federation.info for details."
msgstr ""
-#: src/Module/Admin/Site.php:557
+#: src/Module/Admin/Site.php:560
msgid "Check upstream version"
msgstr ""
-#: src/Module/Admin/Site.php:557
+#: src/Module/Admin/Site.php:560
msgid "Enables checking for new Friendica versions at github. If there is a new version, you will be informed in the admin panel overview."
msgstr ""
-#: src/Module/Admin/Site.php:558
+#: src/Module/Admin/Site.php:561
msgid "Suppress Tags"
msgstr ""
-#: src/Module/Admin/Site.php:558
+#: src/Module/Admin/Site.php:561
msgid "Suppress showing a list of hashtags at the end of the posting."
msgstr ""
-#: src/Module/Admin/Site.php:559
+#: src/Module/Admin/Site.php:562
msgid "Clean database"
msgstr ""
-#: src/Module/Admin/Site.php:559
+#: src/Module/Admin/Site.php:562
msgid "Remove old remote items, orphaned database records and old content from some other helper tables."
msgstr ""
-#: src/Module/Admin/Site.php:560
+#: src/Module/Admin/Site.php:563
msgid "Lifespan of remote items"
msgstr ""
-#: src/Module/Admin/Site.php:560
+#: src/Module/Admin/Site.php:563
msgid "When the database cleanup is enabled, this defines the days after which remote items will be deleted. Own items, and marked or filed items are always kept. 0 disables this behaviour."
msgstr ""
-#: src/Module/Admin/Site.php:561
+#: src/Module/Admin/Site.php:564
msgid "Lifespan of unclaimed items"
msgstr ""
-#: src/Module/Admin/Site.php:561
+#: src/Module/Admin/Site.php:564
msgid "When the database cleanup is enabled, this defines the days after which unclaimed remote items (mostly content from the relay) will be deleted. Default value is 90 days. Defaults to the general lifespan value of remote items if set to 0."
msgstr ""
-#: src/Module/Admin/Site.php:562
+#: src/Module/Admin/Site.php:565
msgid "Lifespan of raw conversation data"
msgstr ""
-#: src/Module/Admin/Site.php:562
+#: src/Module/Admin/Site.php:565
msgid "The conversation data is used for ActivityPub, as well as for debug purposes. It should be safe to remove it after 14 days, default is 90 days."
msgstr ""
-#: src/Module/Admin/Site.php:563
+#: src/Module/Admin/Site.php:566
msgid "Maximum numbers of comments per post"
msgstr ""
-#: src/Module/Admin/Site.php:563
+#: src/Module/Admin/Site.php:566
msgid "How much comments should be shown for each post? Default value is 100."
msgstr ""
-#: src/Module/Admin/Site.php:564
+#: src/Module/Admin/Site.php:567
msgid "Maximum numbers of comments per post on the display page"
msgstr ""
-#: src/Module/Admin/Site.php:564
+#: src/Module/Admin/Site.php:567
msgid "How many comments should be shown on the single view for each post? Default value is 1000."
msgstr ""
-#: src/Module/Admin/Site.php:565
+#: src/Module/Admin/Site.php:568
msgid "Items per page"
msgstr ""
-#: src/Module/Admin/Site.php:565
+#: src/Module/Admin/Site.php:568
msgid "Number of items per page in stream pages (network, community, profile/contact statuses, search)."
msgstr ""
-#: src/Module/Admin/Site.php:566
+#: src/Module/Admin/Site.php:569
msgid "Items per page for mobile devices"
msgstr ""
-#: src/Module/Admin/Site.php:566
+#: src/Module/Admin/Site.php:569
msgid "Number of items per page in stream pages (network, community, profile/contact statuses, search) for mobile devices."
msgstr ""
-#: src/Module/Admin/Site.php:567
+#: src/Module/Admin/Site.php:570
msgid "Temp path"
msgstr ""
-#: src/Module/Admin/Site.php:567
+#: src/Module/Admin/Site.php:570
msgid "If you have a restricted system where the webserver can't access the system temp path, enter another path here."
msgstr ""
-#: src/Module/Admin/Site.php:568
+#: src/Module/Admin/Site.php:571
msgid "Only search in tags"
msgstr ""
-#: src/Module/Admin/Site.php:568
+#: src/Module/Admin/Site.php:571
msgid "On large systems the text search can slow down the system extremely."
msgstr ""
-#: src/Module/Admin/Site.php:569
+#: src/Module/Admin/Site.php:572
msgid "Limited search scope"
msgstr ""
-#: src/Module/Admin/Site.php:569
+#: src/Module/Admin/Site.php:572
msgid "If enabled, searches will only be performed in the data used for the channels and not in all posts."
msgstr ""
-#: src/Module/Admin/Site.php:570
+#: src/Module/Admin/Site.php:573
msgid "Maximum age of items in the search table"
msgstr ""
-#: src/Module/Admin/Site.php:570
+#: src/Module/Admin/Site.php:573
msgid "Maximum age of items in the search table in days. Lower values will increase the performance and reduce disk usage. 0 means no age restriction."
msgstr ""
-#: src/Module/Admin/Site.php:571
+#: src/Module/Admin/Site.php:574
msgid "Generate counts per contact circle when calculating network count"
msgstr ""
-#: src/Module/Admin/Site.php:571
+#: src/Module/Admin/Site.php:574
msgid "On systems with users that heavily use contact circles the query can be very expensive."
msgstr ""
-#: src/Module/Admin/Site.php:572
+#: src/Module/Admin/Site.php:575
msgid "Process \"view\" activities"
msgstr ""
-#: src/Module/Admin/Site.php:572
+#: src/Module/Admin/Site.php:575
msgid "\"view\" activities are mostly geberated by Peertube systems. Per default they are not processed for performance reasons. Only activate this option on performant system."
msgstr ""
-#: src/Module/Admin/Site.php:573
+#: src/Module/Admin/Site.php:576
msgid "Days, after which a contact is archived"
msgstr ""
-#: src/Module/Admin/Site.php:573
+#: src/Module/Admin/Site.php:576
msgid "Number of days that we try to deliver content or to update the contact data before we archive a contact."
msgstr ""
-#: src/Module/Admin/Site.php:575
+#: src/Module/Admin/Site.php:578
msgid "Maximum number of parallel workers"
msgstr ""
-#: src/Module/Admin/Site.php:575
+#: src/Module/Admin/Site.php:578
#, php-format
msgid "On shared hosters set this to %d. On larger systems, values of %d are great. Default value is %d."
msgstr ""
-#: src/Module/Admin/Site.php:576
+#: src/Module/Admin/Site.php:579
msgid "Maximum load for workers"
msgstr ""
-#: src/Module/Admin/Site.php:576
+#: src/Module/Admin/Site.php:579
msgid "Maximum load that causes a cooldown before each worker function call."
msgstr ""
-#: src/Module/Admin/Site.php:577
+#: src/Module/Admin/Site.php:580
msgid "Enable fastlane"
msgstr ""
-#: src/Module/Admin/Site.php:577
+#: src/Module/Admin/Site.php:580
msgid "When enabed, the fastlane mechanism starts an additional worker if processes with higher priority are blocked by processes of lower priority."
msgstr ""
-#: src/Module/Admin/Site.php:578
+#: src/Module/Admin/Site.php:581
msgid "Decoupled receiver"
msgstr ""
-#: src/Module/Admin/Site.php:578
+#: src/Module/Admin/Site.php:581
msgid "Decouple incoming ActivityPub posts by processing them in the background via a worker process. Only enable this on fast systems."
msgstr ""
-#: src/Module/Admin/Site.php:579
+#: src/Module/Admin/Site.php:582
msgid "Cron interval"
msgstr ""
-#: src/Module/Admin/Site.php:579
+#: src/Module/Admin/Site.php:582
msgid "Minimal period in minutes between two calls of the \"Cron\" worker job."
msgstr ""
-#: src/Module/Admin/Site.php:580
+#: src/Module/Admin/Site.php:583
msgid "Worker defer limit"
msgstr ""
-#: src/Module/Admin/Site.php:580
+#: src/Module/Admin/Site.php:583
msgid "Per default the systems tries delivering for 15 times before dropping it."
msgstr ""
-#: src/Module/Admin/Site.php:581
+#: src/Module/Admin/Site.php:584
msgid "Worker fetch limit"
msgstr ""
-#: src/Module/Admin/Site.php:581
+#: src/Module/Admin/Site.php:584
msgid "Number of worker tasks that are fetched in a single query. Higher values should increase the performance, too high values will mostly likely decrease it. Only change it, when you know how to measure the performance of your system."
msgstr ""
-#: src/Module/Admin/Site.php:583
+#: src/Module/Admin/Site.php:586
msgid "Direct relay transfer"
msgstr ""
-#: src/Module/Admin/Site.php:583
+#: src/Module/Admin/Site.php:586
msgid "Enables the direct transfer to other servers without using the relay servers"
msgstr ""
-#: src/Module/Admin/Site.php:584
+#: src/Module/Admin/Site.php:587
msgid "Relay scope"
msgstr ""
-#: src/Module/Admin/Site.php:584
+#: src/Module/Admin/Site.php:587
msgid "Can be \"all\" or \"tags\". \"all\" means that every public post should be received. \"tags\" means that only posts with selected tags should be received."
msgstr ""
-#: src/Module/Admin/Site.php:584 src/Module/Contact/Profile.php:315
+#: src/Module/Admin/Site.php:587 src/Module/Contact/Profile.php:315
#: src/Module/Settings/Display.php:259
#: src/Module/Settings/TwoFactor/Index.php:132
msgid "Disabled"
msgstr ""
-#: src/Module/Admin/Site.php:584
+#: src/Module/Admin/Site.php:587
msgid "all"
msgstr ""
-#: src/Module/Admin/Site.php:584
+#: src/Module/Admin/Site.php:587
msgid "tags"
msgstr ""
-#: src/Module/Admin/Site.php:585
+#: src/Module/Admin/Site.php:588
msgid "Server tags"
msgstr ""
-#: src/Module/Admin/Site.php:585
+#: src/Module/Admin/Site.php:588
msgid "Comma separated list of tags for the \"tags\" subscription."
msgstr ""
-#: src/Module/Admin/Site.php:586
+#: src/Module/Admin/Site.php:589
msgid "Deny Server tags"
msgstr ""
-#: src/Module/Admin/Site.php:586
+#: src/Module/Admin/Site.php:589
msgid "Comma separated list of tags that are rejected."
msgstr ""
-#: src/Module/Admin/Site.php:587
+#: src/Module/Admin/Site.php:590
msgid "Maximum amount of tags"
msgstr ""
-#: src/Module/Admin/Site.php:587
+#: src/Module/Admin/Site.php:590
msgid "Maximum amount of tags in a post before it is rejected as spam. The post has to contain at least one link. Posts from subscribed accounts will not be rejected."
msgstr ""
-#: src/Module/Admin/Site.php:588
+#: src/Module/Admin/Site.php:591
msgid "Allow user tags"
msgstr ""
-#: src/Module/Admin/Site.php:588
+#: src/Module/Admin/Site.php:591
msgid "If enabled, the tags from the saved searches will used for the \"tags\" subscription in addition to the \"relay_server_tags\"."
msgstr ""
-#: src/Module/Admin/Site.php:589
+#: src/Module/Admin/Site.php:592
msgid "Deny undetected languages"
msgstr ""
-#: src/Module/Admin/Site.php:589
+#: src/Module/Admin/Site.php:592
msgid "If enabled, posts with undetected languages will be rejected."
msgstr ""
-#: src/Module/Admin/Site.php:590
+#: src/Module/Admin/Site.php:593
msgid "Language Quality"
msgstr ""
-#: src/Module/Admin/Site.php:590
+#: src/Module/Admin/Site.php:593
msgid "The minimum language quality that is required to accept the post."
msgstr ""
-#: src/Module/Admin/Site.php:591
+#: src/Module/Admin/Site.php:594
msgid "Number of languages for the language detection"
msgstr ""
-#: src/Module/Admin/Site.php:591
+#: src/Module/Admin/Site.php:594
msgid "The system detects a list of languages per post. Only if the desired languages are in the list, the message will be accepted. The higher the number, the more posts will be falsely detected."
msgstr ""
-#: src/Module/Admin/Site.php:593
+#: src/Module/Admin/Site.php:596
msgid "Maximum age of channel"
msgstr ""
-#: src/Module/Admin/Site.php:593
+#: src/Module/Admin/Site.php:596
msgid "This defines the maximum age in hours of items that should be displayed in channels. This affects the channel performance."
msgstr ""
-#: src/Module/Admin/Site.php:594
+#: src/Module/Admin/Site.php:597
msgid "Maximum number of channel posts"
msgstr ""
-#: src/Module/Admin/Site.php:594
+#: src/Module/Admin/Site.php:597
msgid "For performance reasons, the channels use a dedicated table to store content. The higher the value the slower the channels."
msgstr ""
-#: src/Module/Admin/Site.php:595
+#: src/Module/Admin/Site.php:598
msgid "Interaction score days"
msgstr ""
-#: src/Module/Admin/Site.php:595
+#: src/Module/Admin/Site.php:598
msgid "Number of days that are used to calculate the interaction score."
msgstr ""
-#: src/Module/Admin/Site.php:596
+#: src/Module/Admin/Site.php:599
msgid "Maximum number of posts per author"
msgstr ""
-#: src/Module/Admin/Site.php:596
+#: src/Module/Admin/Site.php:599
msgid "Maximum number of posts per page by author if the contact frequency is set to \"Display only few posts\". If there are more posts, then the post with the most interactions will be displayed."
msgstr ""
-#: src/Module/Admin/Site.php:597
+#: src/Module/Admin/Site.php:600
msgid "Sharer interaction days"
msgstr ""
-#: src/Module/Admin/Site.php:597
+#: src/Module/Admin/Site.php:600
msgid "Number of days of the last interaction that are used to define which sharers are used for the \"sharers of sharers\" channel."
msgstr ""
-#: src/Module/Admin/Site.php:600
+#: src/Module/Admin/Site.php:603
msgid "Start Relocation"
msgstr ""
@@ -5837,12 +5845,12 @@ msgstr ""
#: src/Module/Calendar/Event/Form.php:195
#: src/Module/Calendar/Event/Form.php:223 src/Module/Debug/Probe.php:45
-#: src/Module/Install.php:187 src/Module/Install.php:213
-#: src/Module/Install.php:218 src/Module/Install.php:232
-#: src/Module/Install.php:241 src/Module/Install.php:246
-#: src/Module/Install.php:252 src/Module/Install.php:257
-#: src/Module/Install.php:271 src/Module/Install.php:284
-#: src/Module/Install.php:311
+#: src/Module/Install.php:186 src/Module/Install.php:212
+#: src/Module/Install.php:217 src/Module/Install.php:231
+#: src/Module/Install.php:240 src/Module/Install.php:245
+#: src/Module/Install.php:251 src/Module/Install.php:256
+#: src/Module/Install.php:270 src/Module/Install.php:283
+#: src/Module/Install.php:312
#: src/Module/Moderation/Blocklist/Server/Add.php:125
#: src/Module/Moderation/Blocklist/Server/Add.php:127
#: src/Module/Moderation/Blocklist/Server/Import.php:116
@@ -7097,132 +7105,132 @@ msgstr ""
msgid "Welcome to %s"
msgstr ""
-#: src/Module/Install.php:175
+#: src/Module/Install.php:174
msgid "Friendica Communications Server - Setup"
msgstr ""
-#: src/Module/Install.php:186
+#: src/Module/Install.php:185
msgid "System check"
msgstr ""
-#: src/Module/Install.php:188 src/Module/Install.php:233
-#: src/Module/Install.php:312
+#: src/Module/Install.php:187 src/Module/Install.php:232
+#: src/Module/Install.php:313
msgid "Requirement not satisfied"
msgstr ""
-#: src/Module/Install.php:189
+#: src/Module/Install.php:188
msgid "Optional requirement not satisfied"
msgstr ""
-#: src/Module/Install.php:190
+#: src/Module/Install.php:189
msgid "OK"
msgstr ""
-#: src/Module/Install.php:194
+#: src/Module/Install.php:193
msgid "Next"
msgstr ""
-#: src/Module/Install.php:195
+#: src/Module/Install.php:194
msgid "Check again"
msgstr ""
-#: src/Module/Install.php:208
+#: src/Module/Install.php:207
msgid "Base settings"
msgstr ""
-#: src/Module/Install.php:210
+#: src/Module/Install.php:209
msgid "Base path to installation"
msgstr ""
-#: src/Module/Install.php:212
+#: src/Module/Install.php:211
msgid "If the system cannot detect the correct path to your installation, enter the correct path here. This setting should only be set if you are using a restricted system and symbolic links to your webroot."
msgstr ""
-#: src/Module/Install.php:215
+#: src/Module/Install.php:214
msgid "The Friendica system URL"
msgstr ""
-#: src/Module/Install.php:217
+#: src/Module/Install.php:216
msgid "Overwrite this field in case the system URL determination isn't right, otherwise leave it as is."
msgstr ""
-#: src/Module/Install.php:228
+#: src/Module/Install.php:227
msgid "Database connection"
msgstr ""
-#: src/Module/Install.php:229
+#: src/Module/Install.php:228
msgid "In order to install Friendica we need to know how to connect to your database."
msgstr ""
-#: src/Module/Install.php:230
+#: src/Module/Install.php:229
msgid "Please contact your hosting provider or site administrator if you have questions about these settings."
msgstr ""
-#: src/Module/Install.php:231
+#: src/Module/Install.php:230
msgid "The database you specify below should already exist. If it does not, please create it before continuing."
msgstr ""
-#: src/Module/Install.php:238
+#: src/Module/Install.php:237
msgid "Database Server Name"
msgstr ""
-#: src/Module/Install.php:243
+#: src/Module/Install.php:242
msgid "Database Login Name"
msgstr ""
-#: src/Module/Install.php:249
+#: src/Module/Install.php:248
msgid "Database Login Password"
msgstr ""
-#: src/Module/Install.php:251
+#: src/Module/Install.php:250
msgid "For security reasons the password must not be empty"
msgstr ""
-#: src/Module/Install.php:254
+#: src/Module/Install.php:253
msgid "Database Name"
msgstr ""
-#: src/Module/Install.php:258 src/Module/Install.php:286
+#: src/Module/Install.php:257 src/Module/Install.php:286
msgid "Please select a default timezone for your website"
msgstr ""
-#: src/Module/Install.php:273
+#: src/Module/Install.php:272
msgid "Site settings"
msgstr ""
-#: src/Module/Install.php:281
+#: src/Module/Install.php:280
msgid "Site administrator email address"
msgstr ""
-#: src/Module/Install.php:283
+#: src/Module/Install.php:282
msgid "Your account email address must match this in order to use the web admin panel."
msgstr ""
-#: src/Module/Install.php:290
+#: src/Module/Install.php:291
msgid "System Language:"
msgstr ""
-#: src/Module/Install.php:292
+#: src/Module/Install.php:293
msgid "Set the default language for your Friendica installation interface and to send emails."
msgstr ""
-#: src/Module/Install.php:304
+#: src/Module/Install.php:305
msgid "Your Friendica site database has been installed."
msgstr ""
-#: src/Module/Install.php:314
+#: src/Module/Install.php:315
msgid "Installation finished"
msgstr ""
-#: src/Module/Install.php:334
+#: src/Module/Install.php:335
msgid "