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

Maintainers

👁 clagiordano

Package info

github.com/clagiordano/weblibs-configmanager

pkg:composer/clagiordano/weblibs-configmanager

Statistics

Installs: 3 692 085

Dependents: 7

Suggesters: 0

Stars: 16

Open Issues: 1

v1.5.0 2021-07-12 15:27 UTC

Requires

Suggests

None

Provides

None

Conflicts

None

Replaces

None

LGPL-3.0-or-later 8802c7396d61a923c9a73e37ead062b24bb1b273

  • Claudio Giordano <claudio.giordano.woop@autistici.org>

configurationmanagertoolclagiordanoweblibs

This package is auto-updated.

Last update: 2026-06-22 18:04:52 UTC


README

👁 PHP Composer
👁 Coverage Status
👁 SymfonyInsight

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:

Format Component Since version Description
Array ConfigManager v0.1.0 Deprecated, legacy name for the php array reader, only for compatibility support
Array ArrayConfigManager v1.2.0 A file that returns a php array, the original supported format
Yaml YamlConfigManager v1.3.0 A file containing a valid YAML file
JSON JsonConfigManager v1.4.0 A file containing a valid JSON file

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