forked from DesignPatternsPHP/DesignPatternsPHP
-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathDependencyInjection.php
63 lines (56 loc) · 1.52 KB
/
DependencyInjection.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
namespace DesignPatterns;
/**
* Dependency Injection
*
* Purpose:
* to implement a loosely coupled architecture in order to get better testable, maintainable and extendable code
*
* Examples:
* - the Doctrine2 ORM uses dependency injection e.g. for Configuration that is injected into a Connection object. for
* testing purposes, one can easily create a mock object of the configuration and inject that into the connection
* object
* - Symfony and Zend Framework 2 already have containers for DI that create objects via a configuration array and
* inject them where needed (i.e. in Controllers)
*
*/
class Configuration
{
protected $_host;
/**
* @param string $host
* @return Configuration
*/
public function setHost($host)
{
$this->_host = $host;
return $this; // for a fluent interface
}
/**
* @return string
*/
public function getHost()
{
return $this->_host;
}
}
class Connection
{
protected $_configuration;
/**
* here, Configuration gets injected and Connection will get all that it needs from Configuration
* without DI, the configuration would be created directly in Connection, which is not very good
* for testing and extending Connection
*
* @param Configuration $config
*/
public function __construct(Configuration $config)
{
$this->_configuration = $config;
}
public function connect()
{
$host = $this->_configuration->getHost();
// ...
}
}