clagiordano / weblibs-configmanager
weblibs-configmanager is a tool library for easily read and access to php config array file and direct read/write configuration file / object
Installs: 2 750 207
Dependents: 7
Suggesters: 0
Security: 0
Stars: 16
Watchers: 2
Forks: 3
Open Issues: 1
Requires
- php: >=5.4
- ext-json: *
- symfony/yaml: ^2.8
Requires (Dev)
README
weblibs-configmanager
weblibs-configmanager is a tool library for easily read and access to php config array file and direct read/write configuration file / object.
Why use weblibs-configmanager ?
The purpose of this project is to propose a simple and lightweight library to manage php hierarchical configuration files.
Supported formats
This package supports config files in the following format:
All the supported format are parsed and internally handled in the same way granting the same functionalities.
Installation
The recommended way to install weblibs-configmanager is through Composer.
composer require clagiordano/weblibs-configmanager
Usage examples (Array format)
Write a sample config file like this
<?php return array ( 'app' => 'app_name', 'db' => array ( 'host' => 'localhost', 'user' => 'sample_user', 'pass' => 'sample_pass', 'port' => 3306, ), 'other' => array ( 'multi' => array ( 'deep' => array ( 'nested' => 'config_value', ), ), ), );
Instance ConfigManager object
use clagiordano\weblibs\configmanager\ConfigManager; /** * Instance object to read argument file */ $config = new ConfigManager("configfile.php");
Check if a value exists into config file
/** * Check if a value exists into config file */ $value = $config->existValue('app');
Read a simple element from config file
/** * Read a simple element from config file */ $value = $config->getValue('app');
Access to a nested element from config
/** * Access to a nested element from config */ $nestedValue = $config->getValue('other.multi.deep.nested');
Change config value at runtime
/** * Change config value at runtime */ $this->config->setValue('other.multi.deep.nested', "SUPERNESTED");
Save config file with original name (OVERWRITE)
/** * Save config file with original name (OVERWRITE) */ $this->config->saveConfigFile();
Or save config file with a different name
/** * Save config file with original name (OVERWRITE) */ $this->config->saveConfigFile('/new/file/name/or/path/test.php');
Optionally you can also reload config file from disk after save
/** * Optionally you can also reload config file from disk after save */ $this->config->saveConfigFile('/new/file/name/or/path/test.php', true);
Load another configuration file without reinstance ConfigManager
/** * Load another configuration file without reinstance ConfigManager */ $this->config->loadConfig('another_config_file.php');
Legal
Copyright (C) Claudio Giordano claudio.giordano@autistici.org