fi1a/package-config

Управление конфигурацией пакетов

Installs: 153

Dependents: 1

Suggesters: 0

Security: 0

Stars: 0

Watchers: 1

Forks: 0

Open Issues: 0

Type:composer-plugin

dev-master 2023-02-18 08:59 UTC

This package is auto-updated.

Last update: 2024-05-18 11:36:07 UTC


README

Latest Version Software License PHP Version Coverage Status Total Downloads Support mail

Предоставляет возможность использовать конфигурационные файлы в вашем пакете. Объединяет все конфигурационные файлы из установленных пакетов в один и предоставляет доступ по группам. Данный пакет реализует систему плагинов Composer, которая обеспечивает сборку конфигураций непосредственно при установке нового пакета.

Установка

Установить этот пакет можно как зависимость, используя Composer.

composer require fi1a/package-config

Использование

Данный пакет представляет собой плагин Composer. После установки или удаления пакета вызываются обработчики событий, которые запускают сборку конфигураций:

  • проверяется наличие ключа package-config в секции extra файла composer.json установленных пакетов;
  • формируется карта конфигурационных файлов всех пакетов и сохраняется в файл vendor/fi1a/package-config/runtime/.map.json.

Ключ package-config в секции extra файла composer.json может иметь слудующую структуру:

{
  "extra": {
    "package-config": {
      "params": "params.php",
      "web": "web.php",
      "modules": [
        {
          "sort": 1000,
          "file": "modules2.php"
        },
        {
          "sort": 900,
          "file": "modules1.php"
        }
      ]
    }
  }
}

Ключи params, web и modules являются названием группы конфигураций. По данному параметру группируются значения в объединенной конфигурации (например конфигурация из файла params.php будет записана в группу params и будет доступна по данному значению).

Значения params.php, web.php, modules1.php и modules2.php являются названиями файлов конфигурации в директории configs.

Значение ключа sort представляет собой сортировку по которой будут отсортированы в порядке возрастания файлы конфигураций перед объединением. Соответсвенно данный параметр влияет из какого конфигурационного файла значение будет перезаписано. По умолчанию для пакета сортировка равна 500, а для корневого пакета равна 1000.

Файлы конфигураций пакетов должны располагаться в папке configs вашего пакета.

Для доступа к значениям конфигурационных файлов можно воспользоваться хелпером config(string $group):

config('params')->get('foo:bar:baz', 'defaultValue');

Хелпер возвращает объект Fi1a\Config\ConfigValuesInterface из пакета fi1a/config Данный класс позволяет получать доступ к ключам массива по пути (foo:bar:baz).

Команды

Плагин добавляет команды package-config-publish и package-config-rebuild в Composer.

Команда package-config-publish публикует конфигурационные файлы пакета в директорию configsкорневого пакета:

composer package-config-publish <package-name> [files]

Опубликовать все файлы конфигураций пакета:

composer package-config-publish foo/bar

Опубликовать указанные файлы конфигураций пакета:

composer package-config-publish foo/bar params.php web.php

Команда package-config-rebuild запускает сборку конфигураций. Она будет полезна при добавлении нового файла конфигурации или изменение сортировки, когда требуется пересоздать файл карты конфигурационных файлов.

composer package-config-rebuild