3 * Zend Framework (http://framework.zend.com/)
5 * @link http://github.com/zendframework/zf2 for the canonical source repository
6 * @copyright Copyright (c) 2005-2015 Zend Technologies USA Inc. (http://www.zend.com)
7 * @license http://framework.zend.com/license/new-bsd New BSD License
10 namespace Zend\Mvc\Service
;
12 use Interop\Container\ContainerInterface
;
13 use Zend\Mvc\Exception
;
14 use Zend\ServiceManager\Di\DiServiceInitializer
;
15 use Zend\ServiceManager\FactoryInterface
;
16 use Zend\ServiceManager\ServiceLocatorInterface
;
17 use Zend\ServiceManager\ServiceManager
;
20 * @deprecated Since 2.7.9. The factory is now defined in zend-servicemanager-di,
21 * and removed in 3.0.0. Use Zend\ServiceManager\Di\DiServiceInitializerFactory
22 * from zend-servicemanager-di if you are using zend-servicemanager v3, and/or when
23 * ready to migrate to zend-mvc 3.0.
25 class DiServiceInitializerFactory
implements FactoryInterface
28 * Class responsible for instantiating a DiServiceInitializer
30 * @param ContainerInterface $container
32 * @param null|array $options
33 * @return DiServiceInitializer
35 public function __invoke(ContainerInterface
$container, $requestedName, array $options = null)
37 if (! class_exists(DiServiceInitializer
::class)) {
38 throw new Exception\
RuntimeException(sprintf(
39 "%s is not compatible with zend-servicemanager v3, which you are currently using. \n"
40 . "Please run 'composer require zendframework/zend-servicemanager-di', and then update\n"
41 . "your configuration to use Zend\ServiceManager\Di\DiServiceInitializerFactory instead.",
46 return new DiServiceInitializer($container->get('Di'), $container);
50 * Create and return DiServiceInitializer instance
52 * For use with zend-servicemanager v2; proxies to __invoke().
54 * @param ServiceLocatorInterface $container
55 * @return DiServiceInitializer
57 public function createService(ServiceLocatorInterface
$container)
59 return $this($container, DiServiceInitializer
::class);