hprotravel/composer-service-handler
最新稳定版本:v1.3.0
Composer 安装命令:
composer require hprotravel/composer-service-handler
包简介
Composer script handling for generating service definitions from class annotation
README 文档
README
Symfony annotation-based services.yml generator
Use Case
Minimizing conflict issues occurred by single-file based services.yml dependency injections
Installation
Install with composer
Add
`Compass\ServiceHandler\ScriptHandler::buildServices`command of "symfony-scripts" list in composer.json. It should look like following:"scripts": { ... "post-install-cmd": [ "Compass\\ServiceHandler\\ScriptHandler::buildServices", "@auto-scripts" ], "post-update-cmd": [ "Compass\\ServiceHandler\\ScriptHandler::buildServices", "@auto-scripts" ], "post-autoload-dump": [ "Compass\\ServiceHandler\\ScriptHandler::buildServices" ], }Define which bundles will have automatic generated services.yml in app folder
service.ymlparameters: locale: en service_handler: App\: resource: 'src/' exclude: 'src/{Controller,Entity,Exclude,Repository,Kernel.php}'
Define which file will be handle in composer.json file extra section as
compass-servicescomposer.json"extra": { ... "compass-services": { "file": "config/services.yaml" } }Add
services.ymlto .gitignore
Usage
services.yml will be auto-generated after each each execution
composer install or composer update command
Usage of @Service annotation at repository class
namespace App\Repository;
use Compass\ServiceHandler\Annotation\Service;
/**
* @Service(
* id="app.repository.my_repository",
* factory= {"@doctrine.orm.default_entity_manager", "getRepository"},
* arguments={"App:MyEntity"},
* calls={
* {"setSender", {"@App\Mailer\Sender"}}
* }
* )
*/
class MyRepository {
}
Usage of @Service annotation at event listener class
namespace App\EventListener;
use Compass\ServiceHandler\Annotation\Service;
use Compass\ServiceHandler\Annotation\Tag;
/**
* @Service(
* id="app.event_listener.my_listener",
* arguments={
* "@App\Repository\MyRepository",
* "@App\Mailer\Sender"
* },
* tags={
* @Tag(name="kernel.event_listener", event="success", method="onSuccess"),
* @Tag(name="kernel.event_listener", event="fail", method="onFail")
* }
* )
*/
class MyListener {
}
@Service annotation does not have any different usage than a
services.yml based definition.
统计信息
- 总下载量: 1.85k
- 月度下载量: 0
- 日度下载量: 0
- 收藏数: 0
- 点击次数: 0
- 依赖项目数: 0
- 推荐数: 0
其他信息
- 授权协议: MIT
- 更新时间: 2021-10-26