Download the PHP package free-elephants/di without Composer
On this page you can find all versions of the php package free-elephants/di. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.
Download free-elephants/di
More information about free-elephants/di
Files in free-elephants/di
Package di
Short Description IoC, constructor dependency injection
License BSD-2-Clause
Informations about the package di
Simple PHP Constructor-based Dependency Injection
Configure less. Do more.
Framework-agnostic Dependency Injection tool and PSR-11 implementation provider.
Requirements
PHP 7.4|8+
Installation
Usage
Your entry php script (index.php or some background-job runner)
Your components.php
file with dependencies description should look like this:
The main idea: all your components should expect all dependencies as constructor arguments. All other work entrust to Injector. You do not have to want to instantiate any classes directly in your code. Your must inject some factories instead.
Override Components by Environments
EnvAwareConfigLoader
load config/components.php
and merge it with config/components.test.php
if it exists.
Options:
allowNullableConstructorArgs
Default value is false
.
allowInstantiateNotRegisteredTypes
Default value is false
. When you set it true
, you can register only specific interfaces instances.
All final typed dependency will be lazy-instantiated by chain!
useIdAsTypeName
Default value is true
.
enableLoggerAwareInjection
Default value is false
.
Allow to set LoggerInterface into LoggerAwareInterface instances after constructing, or use loggers map if type present.
Conception
[In Russian] Простейшее внедрение зависимостей через конструктор для PHP
В ООП можно выделить две большие группы классов по их ответственности: сущности и сервисы.
Сущности содержат данные и методы для работы с ними. Они чаще всего обладают состоянием и требуются во множестве экзепляров, создаваемых во время исполнения программы. Например:
- доменные объекты (например Entities в контексте Doctrine, Models у Propel)
- Value Objects
- объекты для передачи данных (Data Transfer Objects)
- Request / Response из PSR 7
Сервисы отвечают за всё остальное:
- обрабатывают запрос пользователя (контроллеры, команды)
- оперируют сущностями
- обеспечивают коммуникацию между компонентами системы
- инстанцируют другие сущности и сервисы (фабрики, локаторы)
- предоставляют прикладную функциональность (протоколы, хранилища, роутинг)
Сервис часто требуются в единственном экземпляре, и, редко меняет собственное состояние во время исполнения. Сервисы могут быть описаны до этапа исполнения, например в статическом файле, и быть получены в коде по требованию, или созданы единожды при запуске приложения.
Сущности не должны зависеть от сервисов. В то время, как сервисы наоборот — часто оперируют экземплярами сущностей. При этом сервисы могут использовать другие сервисы.
Наиболее явный и надёжный способ внедрения зависимостей, это инъекция в конструктор:
- нельзя создать экземпляр неготовый к использованию
- зависимости класса обозначены контрактом в одном месте
Type Hinting и рефлексия в php позволяют собрать готовый к использованию сервис на основе сигнатуры его конструктора, без лишних конфигурационных файлов и магии. Такой подход использован в free-elephants/di. Этот способ хорошо поддерживает рефакторинг, т.к. используется только нативный php-код, не требует статического описания зависимостей в yml, xml или аннотациях.