-
Notifications
You must be signed in to change notification settings - Fork 6
/
ContainerInterface.php
63 lines (58 loc) · 2.35 KB
/
ContainerInterface.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
<?php
declare(strict_types=1);
/**
* CakePHP(tm) : Rapid Development Framework (https://cakephp.org)
* Copyright (c) Cake Software Foundation, Inc. (https://cakefoundation.org)
*
* Licensed under The MIT License
* For full copyright and license information, please see the LICENSE.txt
* Redistributions of files must retain the above copyright notice.
*
* @copyright Copyright (c) Cake Software Foundation, Inc. (https://cakefoundation.org)
* @link https://cakephp.org CakePHP(tm) Project
* @since 4.2.0
* @license https://opensource.org/licenses/mit-license.php MIT License
*/
namespace Cake\Core;
use League\Container\Definition\DefinitionInterface;
use Psr\Container\ContainerInterface as PsrInterface;
/**
* Interface for the Dependency Injection Container in CakePHP applications
*
* This interface extends the PSR-11 container interface and adds
* methods to add services and service providers to the container.
*
* The methods defined in this interface use the conventions provided
* by league/container as that is the library that CakePHP uses.
*
* @experimental This interface is not final and can have additional
* methods and parameters added in future minor releases.
*/
interface ContainerInterface extends PsrInterface
{
/**
* Add an item to the container.
*
* @param string $id The class name or name of the service being registered.
* @param mixed $concrete Either the classname an interface or name resolves to.
* Can also be a constructed object, Closure, or null. When null, the `$id` parameter will
* be used as the concrete class name.
* @param bool $shared Set to true to make a service shared.
* @return \League\Container\Definition\DefinitionInterface
*/
public function add(string $id, $concrete = null, bool $shared = false): DefinitionInterface;
/**
* Add a service provider to the container
*
* @param \League\Container\ServiceProvider\ServiceProviderInterface $provider The service provider to add.
* @return $this
*/
public function addServiceProvider($provider);
/**
* Modify an existing definition
*
* @param string $id The class name or name of the service being modified.
* @return \League\Container\Definition\DefinitionInterface
*/
public function extend(string $id): DefinitionInterface;
}