定制 nilsframework/nils-config 二次开发

按需修改功能、优化性能、对接业务系统,提供一站式技术支持

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

nilsframework/nils-config

最新稳定版本:1.0.0

Composer 安装命令:

composer require nilsframework/nils-config

包简介

Package de gestion de configuration JSON pour NilsFramework

README 文档

README

Package de gestion de configuration JSON pour NilsFramework.
Charge et expose un fichier config.json via une API statique simple.

📋 Table des matières

Installation

composer require nilsframework/nils-config

Configuration

Créez un fichier Configuration/config.json à la racine de votre projet :

{
    "app_name": "Song-Taaba",
    "app_debug": true,
    "app_url": "http://localhost:8000",

    "mysql": {
        "driver": "mysql",
        "host": "127.0.0.1",
        "username": "root",
        "password": "secret",
        "database": "song_taaba"
    },
    "mariadb": {
        "driver": "mariadb",
        "host": "",
        "username": "",
        "password": "",
        "database": ""
    },
    "sqlite": {
        "driver": "sqlite",
        "database": ""
    },
    "postgresql": {
        "driver": "postgresql",
        "host": "",
        "username": "",
        "password": "",
        "database": ""
    }
}

⚠️ Ne commitez jamais config.json — ajoutez-le à votre .gitignore.
Utilisez config.example.json comme modèle versionné.

Méthodes

charger()

Charge le fichier de configuration JSON.
Appelée automatiquement par toutes les autres méthodes — rarement nécessaire de l'appeler manuellement.

use Configuration\Config;

// Chargement explicite avec chemin personnalisé
Config::charger('Configuration/config.json');

// Chargement automatique implicite
Config::get('app_name'); // charger() est appelé automatiquement

Si la configuration est déjà chargée, un second appel est ignoré.

get()

Retourne la valeur d'une clé de premier niveau.

// Sans valeur par défaut — lève une exception si la clé est absente
$appName = Config::get('app_name');
// "Song-Taaba"

// Avec valeur par défaut
$debug = Config::get('app_debug', false);
// true

$url = Config::get('app_url', 'http://localhost:8000');
// "http://localhost:8000"

// Lève RuntimeException si la clé est absente et pas de défaut
$jwt = Config::get('jwt_secret'); // ← RuntimeException

getSection()

Retourne une section entière du fichier de configuration sous forme de tableau.

$mysql = Config::getSection('mysql');
// [
//   'driver'   => 'mysql',
//   'host'     => '127.0.0.1',
//   'username' => 'root',
//   'password' => 'secret',
//   'database' => 'song_taaba',
// ]

$mailer = Config::getSection('mailer');
// [
//   'host' => 'smtp.example.com',
//   'port' => 587,
//   ...
// ]

getDatabaseConfig()

Retourne la configuration du driver de base de données actif.
Le driver actif est détecté automatiquement — c'est le premier bloc avec les champs obligatoires non vides.

$config = Config::getDatabaseConfig();
// [
//   'driver'   => 'mysql',
//   'host'     => '127.0.0.1',
//   'username' => 'root',
//   'password' => 'secret',
//   'database' => 'song_taaba',
// ]

Règles de détection :

DriverChamps requis
mysql / mariadb / postgresqlhost + database non vides
sqlitedatabase non vide

L'ordre de priorité est : mysqlmariadbsqlitepostgresql.

has()

Vérifie si une clé existe dans la configuration sans lever d'exception.

if (Config::has('mailer')) {
    $mailer = Config::getSection('mailer');
}

if (!Config::has('jwt_secret')) {
    throw new \RuntimeException("JWT non configuré.");
}

all()

Retourne toutes les données de configuration sous forme de tableau.

$config = Config::all();
// [
//   'app_name'  => 'Song-Taaba',
//   'app_debug' => true,
//   'mysql'     => [...],
//   ...
// ]

// Afficher toutes les clés disponibles
echo implode(', ', array_keys(Config::all()));
// app_name, app_debug, app_url, mysql, sqlite, ...

cheminFichier()

Retourne le chemin absolu du fichier de configuration chargé.

$chemin = Config::cheminFichier();
// "/var/www/html/Configuration/config.json"

// Utile pour le débogage
echo "Config chargée depuis : " . Config::cheminFichier();

reinitialiser()

Réinitialise la configuration chargée.
Utile pour les tests unitaires ou pour recharger un fichier différent.

// Charger la config de test
Config::reinitialiser();
Config::charger('Configuration/config.test.json');

$db = Config::getDatabaseConfig();
// Retourne la config de test (SQLite par exemple)

// Restaurer après le test
Config::reinitialiser();

Exceptions

Toutes les erreurs lèvent une \RuntimeException :

SituationMessage
Fichier introuvableFichier de configuration introuvable : /chemin/config.json
JSON invalideJSON invalide dans le fichier de configuration : ...
Clé absente (sans défaut)Clé de configuration introuvable : ma_cle
Section absenteSection de configuration introuvable : ma_section
Aucun driver DB valideAucune base de données valide trouvée dans la configuration.
use Configuration\Config;

try {
    $secret = Config::get('jwt_secret');
} catch (\RuntimeException $e) {
    echo $e->getMessage();
    // "Clé de configuration introuvable : jwt_secret"
}

Licence

MIT — © NilsFramework

统计信息

  • 总下载量: 11
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 0
  • 点击次数: 7
  • 依赖项目数: 1
  • 推荐数: 0

GitHub 信息

  • Stars: 0
  • Watchers: 0
  • Forks: 0
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2026-04-19