clubdrei / typo3-env-config
Dependency-free parser for converting flat environment variables into nested PHP arrays (TYPO3-focused, framework-agnostic)
Installs: 3
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Forks: 0
pkg:composer/clubdrei/typo3-env-config
Requires
- php: >=5.4
README
Dependency-free parser for converting flat environment variables into nested PHP arrays.
Main use case: TYPO3-style keys like TYPO3_CONF_VARS__....
Also works in any PHP project (framework agnostic).
Requirements
- PHP
>=5.4
Installation
composer require clubdrei/typo3-env-config
What it does
Input:
TYPO3_CONF_VARS__DB__Connections__Default__host=127.0.0.1
TYPO3_CONF_VARS__DB__Connections__Default__dbname=mydb
Output:
[
'TYPO3_CONF_VARS' => [
'DB' => [
'Connections' => [
'Default' => [
'host' => '127.0.0.1',
'dbname' => 'mydb',
],
],
],
],
];
Usage
1) Parse directly from runtime environment
Use parseFromEnvironment() when values already exist in $_SERVER, $_ENV, and/or getenv().
<?php
use Clubdrei\Typo3EnvConfig\Parser;
$parsed = Parser::parseFromEnvironment('TYPO3_CONF_VARS');
if (isset($parsed['TYPO3_CONF_VARS'])) {
$config = array_replace_recursive($config, $parsed['TYPO3_CONF_VARS']);
}
Lookup precedence in parseFromEnvironment():
$_SERVER$_ENVgetenv()(PHP>=7.1only, where parameterlessgetenv()is available)
First value found for a key wins.
This matches the common $_SERVER / $_ENV / getenv() behavior used in Laravel and vlucas/phpdotenv setups.
2) Parse a custom key/value array
Use parseFromArray() when you already have env variables in your own array.
<?php
use Clubdrei\Typo3EnvConfig\Parser;
$env = [
'APP_CONFIG__database__host' => '127.0.0.1',
'APP_CONFIG__database__name' => 'mydb',
'APP_CONFIG__features__0' => 'search',
'APP_CONFIG____emptySegment' => 'yes',
'UNRELATED__value' => 'ignored',
];
$parsed = Parser::parseFromArray($env, 'APP_CONFIG');
Result:
[
'APP_CONFIG' => [
'database' => [
'host' => '127.0.0.1',
'name' => 'mydb',
],
'features' => [
'0' => 'search',
],
'' => [
'emptySegment' => 'yes',
],
],
];
Notes:
- Keys outside the selected prefix are ignored.
- Numeric and empty segments are kept as-is.
- Values can be processed with special placeholders.
3) Value processors
The parser supports these value processors:
%int:VALUE%castsVALUEtoint%bool:VALUE%castsVALUEtobool(Symfony-style semantics)%typo3.environment.getProjectPath%resolvesTYPO3\CMS\Core\Core\Environment::getProjectPath()%typo3.environment.getVarPath%resolvesTYPO3\CMS\Core\Core\Environment::getVarPath()
Example:
<?php
use Clubdrei\Typo3EnvConfig\Parser;
$env = [
'TYPO3_CONF_VARS__SYS__maxRetries' => '%int:3%',
'TYPO3_CONF_VARS__SYS__displayErrors' => '%bool:false%',
'TYPO3_CONF_VARS__SYS__projectPath' => '%typo3.environment.getProjectPath%',
];
$parsed = Parser::parseFromArray($env, 'TYPO3_CONF_VARS');
API
Parser::parseFromEnvironment($prefix = 'TYPO3_CONF_VARS', $separator = '__')Parser::parseFromArray(array $environmentVariables, $prefix = 'TYPO3_CONF_VARS', $separator = '__')
License
MIT