1 | <?php |
||
22 | class WebHelper |
||
23 | { |
||
24 | /** @var WebHelperRepository a Repository instance */ |
||
25 | private $repository; |
||
26 | |||
27 | /** @var VersionParser a VersionParser instance */ |
||
28 | private $versionParser; |
||
29 | |||
30 | /** @var Comparator a Comparator instance */ |
||
31 | private $comparator; |
||
32 | |||
33 | /** @var WebServer\WebServerInterface a Web Server instance */ |
||
34 | private $server; |
||
35 | |||
36 | /** |
||
37 | * Base constructor. |
||
38 | */ |
||
39 | 5 | public function __construct() |
|
44 | |||
45 | /** |
||
46 | * Sets the Repository Instance. |
||
47 | * |
||
48 | * @param string $resDir a Path of a Directives Repository |
||
49 | */ |
||
50 | 5 | public function setRepository($resDir = '') |
|
56 | |||
57 | /** |
||
58 | * Gets the Repository Instance. |
||
59 | * |
||
60 | * @return WebHelperRepository the Repository Instance |
||
61 | */ |
||
62 | 5 | public function getRepository() |
|
66 | |||
67 | /** |
||
68 | * Sets the web server instance. |
||
69 | * |
||
70 | * @param string $server a web server name |
||
71 | * @param string $version a semver-like version |
||
72 | */ |
||
73 | 5 | public function setServer($server, $version) |
|
74 | { |
||
75 | 5 | $factory = new Factory(); |
|
76 | 5 | $this->server = $factory->createWebServer($server, $this->versionParser->normalize($version)); |
|
77 | |||
78 | 5 | return $this; |
|
79 | } |
||
80 | |||
81 | /** |
||
82 | * Gets the web server instance. |
||
83 | * |
||
84 | * @return WebServerInterface the web server instance |
||
85 | */ |
||
86 | 3 | public function getServer() |
|
90 | |||
91 | /** |
||
92 | * Finds the best template for a web server directive according to its version. |
||
93 | * |
||
94 | * @param string $directive a directive |
||
95 | * @return string the relative path to the template |
||
96 | */ |
||
97 | 3 | public function find($directive) |
|
116 | |||
117 | /** |
||
118 | * Outputs a webserver directive. |
||
119 | * |
||
120 | * @param string $twigFile a relative path of a template |
||
121 | * @param array $params parameters |
||
122 | * @return string the directive output |
||
123 | */ |
||
124 | 3 | public function render($twigFile, array $params = array()) |
|
132 | } |
||
133 |