承接 piotrpolak/codeigniter-symfony2-bridge 相关项目开发

从需求分析到上线部署,全程专人跟进,保证项目质量与交付效率

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

piotrpolak/codeigniter-symfony2-bridge

Composer 安装命令:

composer require piotrpolak/codeigniter-symfony2-bridge

包简介

CodeIgniter library that facilitates integration of Symfony2 services into a CodeIgniter application in a compact yet elegant way.

README 文档

README

Build Status Maintainability Test Coverage

A library that facilitates integration of Symfony services into legacy framework applications in a compact way.

As version 1.0.0 the package is composer-compatible and the code has been decoupled from the CodeIgniter framework.

If you want to use the initial CodeIgniter library, please check the 0.1.0 release.

Some history and the most common scenario

The library was written for a long term support project that had to be integrated with a brand new Symfony2+ application. The business logic is encapsulated within services managed by Symfony2+ dependency injection component and consumed both by the Symfony2+ bundles and some legacy CodeIgniter components.

Where possible, the service methods are taking variables of primitive types as input for convenience.

The output of the methods can be both of primitive types and complex objects as the bridge and the Symfony2+ kernel itself manages the PSR class autoload. The bridge does not create any overhead related to communication and parameter serialization.

Compatibility

CodeIgniter: 2.0 - 3.1+

Symfony: 2.0+, 3.0+, 4.0+

Testing

composer install --prefer-dist && ./vendor/bin/phpunit -v

To test in an arbitrary version combination, please use (sudo might be required to connect to the Docker daemon):

PHP_VERSION=7.2 bin/test_in_docker.sh

Examples

Getting Symfony2+ service container

$bridge = new \PiotrPolak\CodeIgniterSymfonyBridge\Bridge('./symfonyRootDir');
try {
    // \Symfony\Component\DependencyInjection\Container
    $container = $bridge->getKernel()->getContainer();
} catch(\PiotrPolak\CodeIgniterSymfonyBridge\Exception\KernelInitializationException $e) {
    // Unable to initialize Symfony2+ kernel
}

More information about Symfony service container and depencency injection:

Consuming a service

$bridge = new \PiotrPolak\CodeIgniterSymfonyBridge\Bridge('./symfonyRootDir');
try {
    $result = $bridge->getKernel()->getContainer()->get('my_service')->businessLogicServiceMethod('parameter of a primitive type'));
} catch(\PiotrPolak\CodeIgniterSymfonyBridge\Exception\KernelInitializationException $e) {
    // Unable to initialize Symfony2+ kernel
}

When designing a service, parameters of primitive types are preferred - this creates minimum overhead and makes the service integration easy. The output of the service method can be of any type.

Getting Doctrine2 entity manager

$bridge = new \PiotrPolak\CodeIgniterSymfonyBridge\Bridge('./symfonyRootDir');
try {
    $em = $bridge->getKernel()->getContainer()->get('doctrine')->getManager();
} catch(\PiotrPolak\CodeIgniterSymfonyBridge\Exception\KernelInitializationException $e) {
    // Unable to initialize Symfony2+ kernel
}

Getting access to the Doctrine2 entity manager makes you able to get access to the entities and related repositories.

Loading an arbitrary class defined within a Symfony2+ bundle

$bridge = new \PiotrPolak\CodeIgniterSymfonyBridge\Bridge('./symfonyRootDir');
try {
    $container = $bridge->getKernel()->getContainer(); // Initializes Symfony2+ PSR class loader
    $imageHelper = new \Pepis\ImageManipulationBundle\Helpers\ImageHelper();
} catch(\PiotrPolak\CodeIgniterSymfonyBridge\Exception\KernelInitializationException $e) {
    // Unable to initialize Symfony2+ kernel
}

License

The software is dual-licensed under:

统计信息

  • 总下载量: 99
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 2
  • 点击次数: 0
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 2
  • Watchers: 1
  • Forks: 4
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2018-10-24

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固