traineratwot / composer-config
description
Installs: 251
Dependents: 3
Suggesters: 0
Security: 0
Stars: 0
Watchers: 2
Forks: 0
Open Issues: 0
Type:composer-plugin
Requires
- php: ^7.4||^8.0
- composer-plugin-api: ^2.0
- traineratwot/config: ^1.0
Requires (Dev)
- composer/composer: ^2.3
- jetbrains/phpstorm-attributes: dev-master
- phpunit/phpunit: ^9.5
- roave/security-advisories: dev-latest
README
en
This is a plugin for managing the settings of your libraries and projects
How does it work?
- install plugins or a plugin-dependent package
- if this is a project
- in the
composer.json
file, you need to set the path to the php file with your future settings inextra.composer-config.configPath
- in the settings file, you must register all the global settings of your application in this way
Config::set('name', 'value','namespace');
- in the
- if library
- in the
composer.json
file, you can add the settings keys and their description to theextra.composer-config
- in the
composer.json
file, you can set the desired package name toextra.composer-config.namespace
by default package name - in your project, use
Config::get('name','namespace');
- in the
ru
Это плагин для управления настройками ваших библиотек и проектов
Как это работает?
- установить плагины или пакет зависящий от плагина
- если это проект
- в файле
composer.json
надо установить вextra.composer-config.configPath
путь до php файла с вашими будущими настройками - в файле с настрйками вы должны прописать все глобальный насройки вашего приложения таким образом
Config::set('name', 'value','namespace');
- в файле
- если библиотека
- в файле
composer.json
можно добавить вextra.composer-config
ключи настроек и их описание - в файле
composer.json
можно установить вextra.composer-config.namespace
желаемыйnamespace
по умолчанию имя пакета - в вашем проекте используйте
Config::get('name','namespace');
- в файле
//composer.json { "type" :"project" //important, "extra":{ "composer-config":{ "configPath":"src/config.php" } } }
//composer.json { "type" :"library" //important, "extra":{ "composer-config":{ "namespace":"lb1", "required" :{ "test1":"test1 description" }, "optional" :{ "test2":"test2 description" } } } }
Добавить все необходимое в ваш composer.json
Add everything you need to your composer.json
composer InitConfig
config.php
<?php # config.php use Config; Config::set('test1', 'value1'); Config::set('test1', 'value2','lb1'); Config::set('test2', 'value3'); Config::set('test3', 'value4','lb1'); echo Config::get('test1').PHP_EOL;//value1 echo Config::get('test1','lb1').PHP_EOL;//value2 echo Config::get('test2').PHP_EOL;//value3 echo Config::get('test2','lb1').PHP_EOL;//value3 echo Config::get('test3').PHP_EOL;//value4 echo Config::get('test3','lb1').PHP_EOL;//value4
Commands
getAllConfigs
en
Returns all settings that can or should be defined in the project
ru
Возвращякт все настройки которые можно или нужну определить в проэкте
composer getAllConfigsresponce
------------ ----------- ------------------ ---------- --------- config key namespace description type is set? ------------ ----------- ------------------ ---------- --------- string string string string yes/no ------------ ----------- ------------------ ---------- ---------
configUpdate
en
creates a special file that will help your IDE determine which constants have been set
ru
создает специальный файл который поможет вашей IDE определить какие константы были установлены
composer configUpdateresponce
ok
Recommendations/Cоветы
en
I advise you to create a File Watchers
on the configuration file that would execute the composer configUpdate
command
ru
Советую создать File Watchers
на файл конфигурации который бы выполнял команду composer configUpdate