symflo / sy-dependency-injection-plugin
symfony 1.x plugin for Symfony Dependency Injection component SF2.
Installs: 32
Dependents: 1
Suggesters: 0
Security: 0
Stars: 2
Watchers: 2
Forks: 0
Open Issues: 0
Type:symfony1-plugin
Requires
- composer/installers: *
- symfony/config: 2.4.*@dev
- symfony/dependency-injection: 2.4.*@dev
This package is not auto-updated.
Last update: 2024-11-19 02:59:40 UTC
README
use Symfony DependencyInjection Component SF2 on SF1.
Requirements
- PHP 5.3.3+
Installation
Add autoload Composer on your symfony project.
In the config/ProjectConfiguration.class.php
add:
<?php require_once __DIR__.'/../vendor/autoload.php'; ?>
Add Symfony DependencyInjection Component in your composer.json
"require": { ... "symflo/sy-dependency-injection-plugin": "dev-master" ... },
Activate the plugin in the config/ProjectConfiguration.class.php
.
<?php class ProjectConfiguration extends sfProjectConfiguration { public function setup() { $this->enablePlugins(array( /* ... */ 'syDependencyInjectionPlugin', )); } } ?>
Configuration
Two possibilities:
Locator files
Simple and fast way (not recommanded for big project)
In app.yml
:
all: syDependencyInjectionPlugin: enabledDebug: false #true by default - if false, it allows to avoid regenerate container in sf_debug environment locators: defaultFileLocators: dir: %SF_ROOT_DIR%/config/services files: - services.php - services.xml - services.yml ... otherFileLocators: dir: %SF_PLUGIN_DIR%/YourPlugin/config/otherservices files: - services.php ...
Extensions
all: syDependencyInjectionPlugin: extensions: - MyDefaultExtension - MyOtherExtension compilerPass: custom: class: CustomCompilerPass #passConfig: not required #TYPE_BEFORE_OPTIMIZATION, TYPE_OPTIMIZE, TYPE_BEFORE_REMOVING, TYPE_REMOVE, TYPE_AFTER_REMOVING
Example extension and compilerPass:
Extension in lib\dependencyInjection
.
<?php use Symfony\Component\DependencyInjection\ContainerBuilder; use Symfony\Component\DependencyInjection\Loader\XmlFileLoader; use Symfony\Component\DependencyInjection\Extension\ExtensionInterface; use Symfony\Component\Config\FileLocator; class DefaultExtension implements ExtensionInterface { public function load(array $configs, ContainerBuilder $container) { $loader = new XmlFileLoader( $container, new FileLocator(__DIR__.'/../../config/services') ); $loader->load('services.xml'); } public function getXsdValidationBasePath() { return false; } public function getNamespace() { return false; } public function getAlias() { return 'default'; } } ?>
CompilerPass in lib\dependencyInjection\compilerPass
:
<?php use Symfony\Component\DependencyInjection\Compiler\CompilerPassInterface; use Symfony\Component\DependencyInjection\ContainerBuilder; class CustomCompilerPass implements CompilerPassInterface { public function process(ContainerBuilder $container) { } } ?>
More informations: Documentation on Component Symfony DependencyInjection
Naturaly you can use 2 ways in same time.
Then in your Action
<?php //... public function executeYourAction(sfWebRequest $request) { $container = $this->getContainer(); $service = $this->getService('your.service'); } //... ?>
Or for example in a Task
<?php //... protected function execute($arguments = array(), $options = array()) { $context = sfContext::createInstance($this->configuration); $container = $context->get('dependency_injection_container'); $service = $container->get('your.service'); } //... ?>