2019-08-16 19:38:26 +03:00
|
|
|
<?php
|
2019-10-05 18:26:10 +03:00
|
|
|
|
2019-08-16 19:38:26 +03:00
|
|
|
declare(strict_types=1);
|
|
|
|
|
|
|
|
namespace Shlinkio\Shlink;
|
|
|
|
|
|
|
|
use Monolog\Handler\StreamHandler;
|
|
|
|
use Monolog\Logger;
|
|
|
|
|
|
|
|
use function explode;
|
2019-10-06 12:38:23 +03:00
|
|
|
use function Functional\contains;
|
2019-08-16 19:38:26 +03:00
|
|
|
use function Shlinkio\Shlink\Common\env;
|
|
|
|
|
2020-06-20 12:21:37 +03:00
|
|
|
use const Shlinkio\Shlink\Core\DEFAULT_DELETE_SHORT_URL_THRESHOLD;
|
|
|
|
use const Shlinkio\Shlink\Core\DEFAULT_REDIRECT_CACHE_LIFETIME;
|
|
|
|
use const Shlinkio\Shlink\Core\DEFAULT_REDIRECT_STATUS_CODE;
|
2020-02-18 21:34:01 +03:00
|
|
|
use const Shlinkio\Shlink\Core\DEFAULT_SHORT_CODES_LENGTH;
|
|
|
|
use const Shlinkio\Shlink\Core\MIN_SHORT_CODES_LENGTH;
|
|
|
|
|
2019-08-16 19:38:26 +03:00
|
|
|
$helper = new class {
|
|
|
|
private const DB_DRIVERS_MAP = [
|
|
|
|
'mysql' => 'pdo_mysql',
|
2019-10-06 12:38:23 +03:00
|
|
|
'maria' => 'pdo_mysql',
|
2019-08-16 19:38:26 +03:00
|
|
|
'postgres' => 'pdo_pgsql',
|
2020-02-14 21:27:21 +03:00
|
|
|
'mssql' => 'pdo_sqlsrv',
|
2019-08-16 19:38:26 +03:00
|
|
|
];
|
|
|
|
private const DB_PORTS_MAP = [
|
|
|
|
'mysql' => '3306',
|
2019-10-06 12:38:23 +03:00
|
|
|
'maria' => '3306',
|
2019-08-16 19:38:26 +03:00
|
|
|
'postgres' => '5432',
|
2020-02-14 21:27:21 +03:00
|
|
|
'mssql' => '1433',
|
2019-08-16 19:38:26 +03:00
|
|
|
];
|
|
|
|
|
|
|
|
public function getDbConfig(): array
|
|
|
|
{
|
|
|
|
$driver = env('DB_DRIVER');
|
2020-11-29 21:46:34 +03:00
|
|
|
$isMysql = contains(['maria', 'mysql'], $driver);
|
2019-08-16 19:38:26 +03:00
|
|
|
if ($driver === null || $driver === 'sqlite') {
|
|
|
|
return [
|
|
|
|
'driver' => 'pdo_sqlite',
|
|
|
|
'path' => 'data/database.sqlite',
|
|
|
|
];
|
|
|
|
}
|
|
|
|
|
|
|
|
return [
|
|
|
|
'driver' => self::DB_DRIVERS_MAP[$driver],
|
|
|
|
'dbname' => env('DB_NAME', 'shlink'),
|
|
|
|
'user' => env('DB_USER'),
|
|
|
|
'password' => env('DB_PASSWORD'),
|
2020-11-29 21:46:34 +03:00
|
|
|
'host' => env('DB_HOST', $driver === 'postgres' ? env('DB_UNIX_SOCKET') : null),
|
2019-08-16 19:38:26 +03:00
|
|
|
'port' => env('DB_PORT', self::DB_PORTS_MAP[$driver]),
|
2020-11-29 21:46:34 +03:00
|
|
|
'unix_socket' => $isMysql ? env('DB_UNIX_SOCKET') : null,
|
2019-08-16 19:38:26 +03:00
|
|
|
];
|
|
|
|
}
|
|
|
|
|
2019-11-02 13:30:09 +03:00
|
|
|
public function getNotFoundRedirectsConfig(): array
|
2019-08-16 19:38:26 +03:00
|
|
|
{
|
|
|
|
return [
|
2019-12-31 17:38:37 +03:00
|
|
|
'invalid_short_url' => env('INVALID_SHORT_URL_REDIRECT_TO'),
|
2019-11-02 19:23:21 +03:00
|
|
|
'regular_404' => env('REGULAR_404_REDIRECT_TO'),
|
2019-11-02 13:30:09 +03:00
|
|
|
'base_url' => env('BASE_URL_REDIRECT_TO'),
|
2019-08-16 19:38:26 +03:00
|
|
|
];
|
|
|
|
}
|
2019-12-28 18:35:16 +03:00
|
|
|
|
|
|
|
public function getVisitsWebhooks(): array
|
|
|
|
{
|
|
|
|
$webhooks = env('VISITS_WEBHOOKS');
|
|
|
|
return $webhooks === null ? [] : explode(',', $webhooks);
|
|
|
|
}
|
2020-01-05 18:45:14 +03:00
|
|
|
|
|
|
|
public function getRedisConfig(): ?array
|
|
|
|
{
|
|
|
|
$redisServers = env('REDIS_SERVERS');
|
|
|
|
return $redisServers === null ? null : ['servers' => $redisServers];
|
|
|
|
}
|
2020-02-18 21:34:01 +03:00
|
|
|
|
|
|
|
public function getDefaultShortCodesLength(): int
|
|
|
|
{
|
|
|
|
$value = (int) env('DEFAULT_SHORT_CODES_LENGTH', DEFAULT_SHORT_CODES_LENGTH);
|
|
|
|
return $value < MIN_SHORT_CODES_LENGTH ? MIN_SHORT_CODES_LENGTH : $value;
|
|
|
|
}
|
2020-04-12 21:41:23 +03:00
|
|
|
|
|
|
|
public function getMercureConfig(): array
|
|
|
|
{
|
|
|
|
$publicUrl = env('MERCURE_PUBLIC_HUB_URL');
|
|
|
|
|
|
|
|
return [
|
|
|
|
'public_hub_url' => $publicUrl,
|
|
|
|
'internal_hub_url' => env('MERCURE_INTERNAL_HUB_URL', $publicUrl),
|
|
|
|
'jwt_secret' => env('MERCURE_JWT_SECRET'),
|
|
|
|
];
|
|
|
|
}
|
2019-08-16 19:38:26 +03:00
|
|
|
};
|
|
|
|
|
|
|
|
return [
|
|
|
|
|
|
|
|
'delete_short_urls' => [
|
|
|
|
'check_visits_threshold' => true,
|
2020-06-20 12:21:37 +03:00
|
|
|
'visits_threshold' => (int) env('DELETE_SHORT_URL_THRESHOLD', DEFAULT_DELETE_SHORT_URL_THRESHOLD),
|
2019-08-16 19:38:26 +03:00
|
|
|
],
|
|
|
|
|
|
|
|
'entity_manager' => [
|
|
|
|
'connection' => $helper->getDbConfig(),
|
|
|
|
],
|
|
|
|
|
|
|
|
'url_shortener' => [
|
|
|
|
'domain' => [
|
|
|
|
'schema' => env('SHORT_DOMAIN_SCHEMA', 'http'),
|
|
|
|
'hostname' => env('SHORT_DOMAIN_HOST', ''),
|
|
|
|
],
|
2019-12-31 18:29:32 +03:00
|
|
|
'validate_url' => (bool) env('VALIDATE_URLS', false),
|
2019-12-28 18:35:16 +03:00
|
|
|
'visits_webhooks' => $helper->getVisitsWebhooks(),
|
2020-02-18 21:34:01 +03:00
|
|
|
'default_short_codes_length' => $helper->getDefaultShortCodesLength(),
|
2020-06-20 12:21:37 +03:00
|
|
|
'redirect_status_code' => (int) env('REDIRECT_STATUS_CODE', DEFAULT_REDIRECT_STATUS_CODE),
|
|
|
|
'redirect_cache_lifetime' => (int) env('REDIRECT_CACHE_LIFETIME', DEFAULT_REDIRECT_CACHE_LIFETIME),
|
2021-02-05 20:33:36 +03:00
|
|
|
'auto_resolve_titles' => (bool) env('AUTO_RESOLVE_TITLES', false),
|
2021-05-16 10:30:04 +03:00
|
|
|
],
|
|
|
|
|
|
|
|
'tracking' => [
|
|
|
|
'anonymize_remote_addr' => (bool) env('ANONYMIZE_REMOTE_ADDR', true),
|
2021-02-10 22:09:25 +03:00
|
|
|
'track_orphan_visits' => (bool) env('TRACK_ORPHAN_VISITS', true),
|
2021-05-16 10:30:04 +03:00
|
|
|
'disable_track_param' => env('DISABLE_TRACK_PARAM'),
|
|
|
|
'disable_tracking' => (bool) env('DISABLE_TRACKING', false),
|
|
|
|
'disable_ip_tracking' => (bool) env('DISABLE_IP_TRACKING', false),
|
|
|
|
'disable_referrer_tracking' => (bool) env('DISABLE_REFERRER_TRACKING', false),
|
|
|
|
'disable_ua_tracking' => (bool) env('DISABLE_UA_TRACKING', false),
|
2019-08-16 19:38:26 +03:00
|
|
|
],
|
|
|
|
|
2019-11-02 13:30:09 +03:00
|
|
|
'not_found_redirects' => $helper->getNotFoundRedirectsConfig(),
|
|
|
|
|
2019-08-16 19:38:26 +03:00
|
|
|
'logger' => [
|
2019-11-30 19:59:04 +03:00
|
|
|
'Shlink' => [
|
|
|
|
'handlers' => [
|
|
|
|
'shlink_handler' => [
|
|
|
|
'name' => StreamHandler::class,
|
|
|
|
'params' => [
|
|
|
|
'level' => Logger::INFO,
|
|
|
|
'stream' => 'php://stdout',
|
|
|
|
],
|
2019-11-30 11:28:09 +03:00
|
|
|
],
|
2019-08-16 19:38:26 +03:00
|
|
|
],
|
|
|
|
],
|
|
|
|
],
|
|
|
|
|
|
|
|
'dependencies' => [
|
|
|
|
'aliases' => env('REDIS_SERVERS') === null ? [] : [
|
|
|
|
'lock_store' => 'redis_lock_store',
|
|
|
|
],
|
|
|
|
],
|
|
|
|
|
2020-01-05 18:45:14 +03:00
|
|
|
'cache' => [
|
|
|
|
'redis' => $helper->getRedisConfig(),
|
2019-08-16 19:38:26 +03:00
|
|
|
],
|
|
|
|
|
2019-09-13 21:36:40 +03:00
|
|
|
'router' => [
|
|
|
|
'base_path' => env('BASE_PATH', ''),
|
|
|
|
],
|
|
|
|
|
2020-01-01 23:11:53 +03:00
|
|
|
'mezzio-swoole' => [
|
2019-11-09 13:05:54 +03:00
|
|
|
'swoole-http-server' => [
|
2020-10-03 12:49:25 +03:00
|
|
|
'port' => (int) env('PORT', 8080),
|
2019-11-09 13:05:54 +03:00
|
|
|
'options' => [
|
|
|
|
'worker_num' => (int) env('WEB_WORKER_NUM', 16),
|
|
|
|
'task_worker_num' => (int) env('TASK_WORKER_NUM', 16),
|
|
|
|
],
|
|
|
|
],
|
|
|
|
],
|
|
|
|
|
2020-04-29 20:27:35 +03:00
|
|
|
'geolite2' => [
|
2021-05-30 13:30:03 +03:00
|
|
|
'license_key' => env('GEOLITE_LICENSE_KEY', 'G4Lm0C60yJsnkdPi'), // Deprecated. Remove hardcoded license on v3
|
2020-04-29 20:27:35 +03:00
|
|
|
],
|
|
|
|
|
2020-04-12 21:41:23 +03:00
|
|
|
'mercure' => $helper->getMercureConfig(),
|
|
|
|
|
2019-08-16 19:38:26 +03:00
|
|
|
];
|