parse() // ->putenv() // ->toEnv() // ->toServer(); // } /* * Initializes default Config store and loads the main configuration file (app.php) * * CakePHP contains 2 configuration files after project creation: * - `config/app.php` for the default application configuration. * - `config/app_local.php` for environment specific configuration. */ try { Configure::config('default', new PhpConfig()); Configure::load('app', 'default', false); } catch (\Exception $e) { exit($e->getMessage() . "\n"); } /* * Load an environment local configuration file to provide overrides to your configuration. * Notice: For security reasons app_local.php **should not** be included in your git repo. */ if (file_exists(CONFIG . 'app_local.php')) { Configure::load('app_local', 'default'); } /* * When debug = true the metadata cache should only last for a short time. */ if (Configure::read('debug')) { Configure::write('Cache._cake_model_.duration', '+2 minutes'); Configure::write('Cache._cake_translations_.duration', '+2 minutes'); } /* * Set the default server timezone. Using UTC makes time calculations / conversions easier. * Check https://php.net/manual/en/timezones.php for list of valid timezone strings. */ date_default_timezone_set(Configure::read('App.defaultTimezone')); /* * Configure the mbstring extension to use the correct encoding. */ mb_internal_encoding(Configure::read('App.encoding')); /* * Set the default locale. This controls how dates, number and currency is * formatted and sets the default language to use for translations. */ ini_set('intl.default_locale', Configure::read('App.defaultLocale')); /* * Register application error and exception handlers. */ (new ErrorTrap(Configure::read('Error')))->register(); (new ExceptionTrap(Configure::read('Error')))->register(); /* * CLI/Command specific configuration. */ if (PHP_SAPI === 'cli') { // Set the fullBaseUrl to allow URLs to be generated in commands. // This is useful when sending email from commands. // Configure::write('App.fullBaseUrl', php_uname('n')); // Set logs to different files so they don't have permission conflicts. if (Configure::check('Log.debug')) { Configure::write('Log.debug.file', 'cli-debug'); } if (Configure::check('Log.error')) { Configure::write('Log.error.file', 'cli-error'); } } /* * Set the full base URL. * This URL is used as the base of all absolute links. * Can be very useful for CLI/Commandline applications. */ $fullBaseUrl = Configure::read('App.fullBaseUrl'); if (!$fullBaseUrl) { /* * When using proxies or load balancers, SSL/TLS connections might * get terminated before reaching the server. If you trust the proxy, * you can enable `$trustProxy` to rely on the `X-Forwarded-Proto` * header to determine whether to generate URLs using `https`. * * See also https://book.cakephp.org/5/en/controllers/request-response.html#trusting-proxy-headers */ $trustProxy = false; $s = null; if (env('HTTPS') || ($trustProxy && env('HTTP_X_FORWARDED_PROTO') === 'https')) { $s = 's'; } $httpHost = env('HTTP_HOST'); if ($httpHost) { $fullBaseUrl = 'http' . $s . '://' . $httpHost; } unset($httpHost, $s); } if ($fullBaseUrl) { Router::fullBaseUrl($fullBaseUrl); } unset($fullBaseUrl); /* * Apply the loaded configuration settings to their respective systems. * This will also remove the loaded config data from memory. */ Cache::setConfig(Configure::consume('Cache')); ConnectionManager::setConfig(Configure::consume('Datasources')); TransportFactory::setConfig(Configure::consume('EmailTransport')); Mailer::setConfig(Configure::consume('Email')); Log::setConfig(Configure::consume('Log')); Security::setSalt(Configure::consume('Security.salt')); /* * Setup detectors for mobile and tablet. * If you don't use these checks you can safely remove this code * and the mobiledetect package from composer.json. */ ServerRequest::addDetector('mobile', function ($request) { $detector = new \Detection\MobileDetect(); return $detector->isMobile(); }); ServerRequest::addDetector('tablet', function ($request) { $detector = new \Detection\MobileDetect(); return $detector->isTablet(); }); /* * You can enable default locale format parsing by adding calls * to `useLocaleParser()`. This enables the automatic conversion of * locale specific date formats when processing request data. For details see * @link https://book.cakephp.org/5/en/core-libraries/internationalization-and-localization.html#parsing-localized-datetime-data */ // \Cake\Database\TypeFactory::build('time')->useLocaleParser(); // \Cake\Database\TypeFactory::build('date')->useLocaleParser(); // \Cake\Database\TypeFactory::build('datetime')->useLocaleParser(); // \Cake\Database\TypeFactory::build('timestamp')->useLocaleParser(); // \Cake\Database\TypeFactory::build('datetimefractional')->useLocaleParser(); // \Cake\Database\TypeFactory::build('timestampfractional')->useLocaleParser(); // \Cake\Database\TypeFactory::build('datetimetimezone')->useLocaleParser(); // \Cake\Database\TypeFactory::build('timestamptimezone')->useLocaleParser(); /* * Custom Inflector rules, can be set to correctly pluralize or singularize * table, model, controller names or whatever other string is passed to the * inflection functions. */ // \Cake\Utility\Inflector::rules('plural', ['/^(inflect)or$/i' => '\1ables']); // \Cake\Utility\Inflector::rules('irregular', ['red' => 'redlings']); // \Cake\Utility\Inflector::rules('uninflected', ['dontinflectme']); // set a custom date and time format // see https://book.cakephp.org/5/en/core-libraries/time.html#setting-the-default-locale-and-format-string // and https://unicode-org.github.io/icu/userguide/format_parse/datetime/#datetime-format-syntax // \Cake\I18n\Date::setToStringFormat('dd.MM.yyyy'); // \Cake\I18n\Time::setToStringFormat('dd.MM.yyyy HH:mm');