diff options
Diffstat (limited to 'application/container')
-rw-r--r-- | application/container/ContainerBuilder.php | 20 | ||||
-rw-r--r-- | application/container/ShaarliContainer.php | 3 |
2 files changed, 21 insertions, 2 deletions
diff --git a/application/container/ContainerBuilder.php b/application/container/ContainerBuilder.php index 99c12334..c5c4a2c3 100644 --- a/application/container/ContainerBuilder.php +++ b/application/container/ContainerBuilder.php | |||
@@ -11,6 +11,7 @@ use Shaarli\Formatter\FormatterFactory; | |||
11 | use Shaarli\History; | 11 | use Shaarli\History; |
12 | use Shaarli\Plugin\PluginManager; | 12 | use Shaarli\Plugin\PluginManager; |
13 | use Shaarli\Render\PageBuilder; | 13 | use Shaarli\Render\PageBuilder; |
14 | use Shaarli\Render\PageCacheManager; | ||
14 | use Shaarli\Security\LoginManager; | 15 | use Shaarli\Security\LoginManager; |
15 | use Shaarli\Security\SessionManager; | 16 | use Shaarli\Security\SessionManager; |
16 | 17 | ||
@@ -34,19 +35,30 @@ class ContainerBuilder | |||
34 | /** @var LoginManager */ | 35 | /** @var LoginManager */ |
35 | protected $login; | 36 | protected $login; |
36 | 37 | ||
37 | public function __construct(ConfigManager $conf, SessionManager $session, LoginManager $login) | 38 | /** @var string */ |
38 | { | 39 | protected $webPath; |
40 | |||
41 | public function __construct( | ||
42 | ConfigManager $conf, | ||
43 | SessionManager $session, | ||
44 | LoginManager $login, | ||
45 | string $webPath | ||
46 | ) { | ||
39 | $this->conf = $conf; | 47 | $this->conf = $conf; |
40 | $this->session = $session; | 48 | $this->session = $session; |
41 | $this->login = $login; | 49 | $this->login = $login; |
50 | $this->webPath = $webPath; | ||
42 | } | 51 | } |
43 | 52 | ||
44 | public function build(): ShaarliContainer | 53 | public function build(): ShaarliContainer |
45 | { | 54 | { |
46 | $container = new ShaarliContainer(); | 55 | $container = new ShaarliContainer(); |
56 | |||
47 | $container['conf'] = $this->conf; | 57 | $container['conf'] = $this->conf; |
48 | $container['sessionManager'] = $this->session; | 58 | $container['sessionManager'] = $this->session; |
49 | $container['loginManager'] = $this->login; | 59 | $container['loginManager'] = $this->login; |
60 | $container['webPath'] = $this->webPath; | ||
61 | |||
50 | $container['plugins'] = function (ShaarliContainer $container): PluginManager { | 62 | $container['plugins'] = function (ShaarliContainer $container): PluginManager { |
51 | return new PluginManager($container->conf); | 63 | return new PluginManager($container->conf); |
52 | }; | 64 | }; |
@@ -81,6 +93,10 @@ class ContainerBuilder | |||
81 | return new FormatterFactory($container->conf, $container->loginManager->isLoggedIn()); | 93 | return new FormatterFactory($container->conf, $container->loginManager->isLoggedIn()); |
82 | }; | 94 | }; |
83 | 95 | ||
96 | $container['pageCacheManager'] = function (ShaarliContainer $container): PageCacheManager { | ||
97 | return new PageCacheManager($container->conf->get('resource.page_cache')); | ||
98 | }; | ||
99 | |||
84 | return $container; | 100 | return $container; |
85 | } | 101 | } |
86 | } | 102 | } |
diff --git a/application/container/ShaarliContainer.php b/application/container/ShaarliContainer.php index fdf2f77f..af62e574 100644 --- a/application/container/ShaarliContainer.php +++ b/application/container/ShaarliContainer.php | |||
@@ -10,6 +10,7 @@ use Shaarli\Formatter\FormatterFactory; | |||
10 | use Shaarli\History; | 10 | use Shaarli\History; |
11 | use Shaarli\Plugin\PluginManager; | 11 | use Shaarli\Plugin\PluginManager; |
12 | use Shaarli\Render\PageBuilder; | 12 | use Shaarli\Render\PageBuilder; |
13 | use Shaarli\Render\PageCacheManager; | ||
13 | use Shaarli\Security\LoginManager; | 14 | use Shaarli\Security\LoginManager; |
14 | use Shaarli\Security\SessionManager; | 15 | use Shaarli\Security\SessionManager; |
15 | use Slim\Container; | 16 | use Slim\Container; |
@@ -20,11 +21,13 @@ use Slim\Container; | |||
20 | * @property ConfigManager $conf | 21 | * @property ConfigManager $conf |
21 | * @property SessionManager $sessionManager | 22 | * @property SessionManager $sessionManager |
22 | * @property LoginManager $loginManager | 23 | * @property LoginManager $loginManager |
24 | * @property string $webPath | ||
23 | * @property History $history | 25 | * @property History $history |
24 | * @property BookmarkServiceInterface $bookmarkService | 26 | * @property BookmarkServiceInterface $bookmarkService |
25 | * @property PageBuilder $pageBuilder | 27 | * @property PageBuilder $pageBuilder |
26 | * @property PluginManager $pluginManager | 28 | * @property PluginManager $pluginManager |
27 | * @property FormatterFactory $formatterFactory | 29 | * @property FormatterFactory $formatterFactory |
30 | * @property PageCacheManager $pageCacheManager | ||
28 | */ | 31 | */ |
29 | class ShaarliContainer extends Container | 32 | class ShaarliContainer extends Container |
30 | { | 33 | { |