mirror of
https://github.com/Mibew/mibew.git
synced 2025-03-23 02:21:23 +03:00
Encapsulate cache pool instantiation in CacheFactory
This commit is contained in:
parent
57182b0589
commit
758203b6d3
@ -39,6 +39,19 @@ mailer:
|
|||||||
# "tls".
|
# "tls".
|
||||||
encryption: false
|
encryption: false
|
||||||
|
|
||||||
|
# Cache subsystem
|
||||||
|
cache:
|
||||||
|
# This value determines where the cached data will be stored. Possible
|
||||||
|
# values are "none" and "file_system".
|
||||||
|
#
|
||||||
|
# If "none" is used the caching will be disabled. This option should be used
|
||||||
|
# only if none of the other options works.
|
||||||
|
#
|
||||||
|
# If "file_system" is used the cached data will be stored in files within
|
||||||
|
# the "cache/" directory. Notice, that the file system storage does not work
|
||||||
|
# on NFS systems bucause exclusive file locks are not supported where.
|
||||||
|
storage: file_system
|
||||||
|
|
||||||
# Locales
|
# Locales
|
||||||
## Native name will be used in this locale
|
## Native name will be used in this locale
|
||||||
home_locale: en
|
home_locale: en
|
||||||
|
@ -22,6 +22,7 @@ require_once(dirname(__FILE__) . '/libs/init.php');
|
|||||||
|
|
||||||
use Mibew\Application;
|
use Mibew\Application;
|
||||||
use Mibew\Authentication\AuthenticationManager;
|
use Mibew\Authentication\AuthenticationManager;
|
||||||
|
use Mibew\Cache\CacheFactory;
|
||||||
use Mibew\Mail\MailerFactory;
|
use Mibew\Mail\MailerFactory;
|
||||||
use Mibew\Routing\Router;
|
use Mibew\Routing\Router;
|
||||||
use Mibew\Routing\Loader\CacheLoader;
|
use Mibew\Routing\Loader\CacheLoader;
|
||||||
@ -31,14 +32,17 @@ use Symfony\Component\Config\Loader\LoaderResolver;
|
|||||||
use Symfony\Component\HttpFoundation\Request;
|
use Symfony\Component\HttpFoundation\Request;
|
||||||
use Symfony\Component\Routing\Loader\YamlFileLoader;
|
use Symfony\Component\Routing\Loader\YamlFileLoader;
|
||||||
|
|
||||||
// Use custom cache
|
$configs = load_system_configs();
|
||||||
$cache_driver = new \Stash\Driver\FileSystem();
|
|
||||||
$cache_driver->setOptions(array('path' => MIBEW_FS_ROOT . '/cache/stash'));
|
// Prepare the cache
|
||||||
$cache = new \Stash\Pool($cache_driver);
|
$cache_factory = new CacheFactory($configs['cache']);
|
||||||
|
// For now directory for cache files cannot be changed via the configs file.
|
||||||
|
// TODO: Evaluate possibility of using custom cache directory.
|
||||||
|
$cache_factory->setOption('path', MIBEW_FS_ROOT . '/cache/stash');
|
||||||
|
|
||||||
// The main route loader which loads nothig but works as a cache proxy for other
|
// The main route loader which loads nothig but works as a cache proxy for other
|
||||||
// loaders.
|
// loaders.
|
||||||
$route_loader = new CacheLoader($cache);
|
$route_loader = new CacheLoader($cache_factory->getCache());
|
||||||
// Real loaders are attached via the resolver.
|
// Real loaders are attached via the resolver.
|
||||||
$loader_resolver = new LoaderResolver(array(
|
$loader_resolver = new LoaderResolver(array(
|
||||||
$route_loader,
|
$route_loader,
|
||||||
@ -49,10 +53,9 @@ $loader_resolver = new LoaderResolver(array(
|
|||||||
$router = new Router($route_loader, 'configs/routing.yml');
|
$router = new Router($route_loader, 'configs/routing.yml');
|
||||||
|
|
||||||
$application = new Application($router, new AuthenticationManager());
|
$application = new Application($router, new AuthenticationManager());
|
||||||
$application->setCache($cache);
|
$application->setCache($cache_factory->getCache());
|
||||||
|
|
||||||
// Use custom config-dependent mailer factory
|
// Use custom config-dependent mailer factory
|
||||||
$configs = load_system_configs();
|
|
||||||
$application->setMailerFactory(new MailerFactory($configs['mailer']));
|
$application->setMailerFactory(new MailerFactory($configs['mailer']));
|
||||||
|
|
||||||
// Process request
|
// Process request
|
||||||
|
152
src/mibew/libs/classes/Mibew/Cache/CacheFactory.php
Normal file
152
src/mibew/libs/classes/Mibew/Cache/CacheFactory.php
Normal file
@ -0,0 +1,152 @@
|
|||||||
|
<?php
|
||||||
|
/*
|
||||||
|
* This file is a part of Mibew Messenger.
|
||||||
|
*
|
||||||
|
* Copyright 2005-2015 the original author or authors.
|
||||||
|
*
|
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
* you may not use this file except in compliance with the License.
|
||||||
|
* You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
namespace Mibew\Cache;
|
||||||
|
|
||||||
|
use Stash\Interfaces\PoolInterface;
|
||||||
|
use Stash\Driver\Ephemeral as EphemeralDriver;
|
||||||
|
use Stash\Driver\FileSystem as FileSystemDriver;
|
||||||
|
use Stash\Pool as CachePool;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Creates and configures appropriate instance of Cache pool.
|
||||||
|
*/
|
||||||
|
class CacheFactory
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* @var PoolInterface|null
|
||||||
|
*/
|
||||||
|
private $cache = null;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* List of factory's options.
|
||||||
|
*
|
||||||
|
* @var array
|
||||||
|
*/
|
||||||
|
private $options;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Class constructor.
|
||||||
|
*
|
||||||
|
* @param Array $options Associative array of options that should be used.
|
||||||
|
*/
|
||||||
|
public function __construct($options = array())
|
||||||
|
{
|
||||||
|
$this->setOptions($options);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets factory's option.
|
||||||
|
*
|
||||||
|
* @param string $name Name of the option to retrieve.
|
||||||
|
* @throws \InvalidArgumentException If the option is unknown.
|
||||||
|
*/
|
||||||
|
public function getOption($name)
|
||||||
|
{
|
||||||
|
if (!isset($this->options[$name])) {
|
||||||
|
throw new \InvalidArgumentException(sprintf('Unknown option "%s"', $name));
|
||||||
|
}
|
||||||
|
|
||||||
|
return $this->options[$name];
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Sets factory's option.
|
||||||
|
*
|
||||||
|
* @param string $name Name of the option to set.
|
||||||
|
* @param string $value New value.
|
||||||
|
* @throws \InvalidArgumentException If the option is unknown.
|
||||||
|
*/
|
||||||
|
public function setOption($name, $value)
|
||||||
|
{
|
||||||
|
if (!isset($this->options[$name])) {
|
||||||
|
throw new \InvalidArgumentException(sprintf('Unknown option "%s"', $name));
|
||||||
|
}
|
||||||
|
|
||||||
|
$this->options[$name] = $value;
|
||||||
|
|
||||||
|
// Cached instance of cache is not valid any more. New one should be
|
||||||
|
// created.
|
||||||
|
$this->cache = null;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Sets factory's options.
|
||||||
|
*
|
||||||
|
* @param array $options Associative array of options.
|
||||||
|
* @throws \InvalidArgumentException If specified array has unknow options.
|
||||||
|
*/
|
||||||
|
public function setOptions($options)
|
||||||
|
{
|
||||||
|
$defaults = array(
|
||||||
|
'storage' => 'file_system',
|
||||||
|
'path' => '/tmp',
|
||||||
|
);
|
||||||
|
|
||||||
|
// Make sure all passed options are known
|
||||||
|
$unknown_options = array_diff(array_keys($options), array_keys($defaults));
|
||||||
|
if (count($unknown_options) != 0) {
|
||||||
|
throw new \InvalidArgumentException(sprintf(
|
||||||
|
'These options are unknown: %s',
|
||||||
|
implode(', ', $unknown_options)
|
||||||
|
));
|
||||||
|
}
|
||||||
|
|
||||||
|
if (empty($this->options)) {
|
||||||
|
// The options are set for the first time.
|
||||||
|
$this->options = $options + $defaults;
|
||||||
|
} else {
|
||||||
|
// Update only specified options.
|
||||||
|
$this->options = $options + $this->options;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Cached instance of cache is not valid any more. New one should be
|
||||||
|
// created.
|
||||||
|
$this->cache = null;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Builds cache pool instance.
|
||||||
|
*
|
||||||
|
* @return PoolInterface An instance of cache pool.
|
||||||
|
* @throws \RuntimeException If at least one of factory's options is
|
||||||
|
* invalid.
|
||||||
|
*/
|
||||||
|
public function getCache()
|
||||||
|
{
|
||||||
|
if (is_null($this->cache)) {
|
||||||
|
$storage = $this->getOption('storage');
|
||||||
|
if ($storage === 'none') {
|
||||||
|
$driver = new EphemeralDriver();
|
||||||
|
} elseif ($storage === 'file_system') {
|
||||||
|
$driver = new FileSystemDriver();
|
||||||
|
$driver->setOptions(array('path' => $this->getOption('path')));
|
||||||
|
} else {
|
||||||
|
throw new \RuntimeException(sprintf(
|
||||||
|
'Wrong value of "storage" option: "%s"',
|
||||||
|
$storage
|
||||||
|
));
|
||||||
|
}
|
||||||
|
|
||||||
|
$this->cache = new CachePool($driver);
|
||||||
|
}
|
||||||
|
|
||||||
|
return $this->cache;
|
||||||
|
}
|
||||||
|
}
|
@ -33,9 +33,13 @@ function load_system_configs()
|
|||||||
if (is_null($configs)) {
|
if (is_null($configs)) {
|
||||||
$parser = new YamlParser();
|
$parser = new YamlParser();
|
||||||
$configs = $parser->parse(file_get_contents(MIBEW_FS_ROOT . '/configs/config.yml'));
|
$configs = $parser->parse(file_get_contents(MIBEW_FS_ROOT . '/configs/config.yml'));
|
||||||
// Mailer configs are not necessary and can be omited but the section
|
$configs += array(
|
||||||
// must exist anyway.
|
// Mailer configs are not necessary and can be omited but the
|
||||||
$configs += array('mailer' => array());
|
// section must exist anyway.
|
||||||
|
'mailer' => array(),
|
||||||
|
// Cache section must extst too.
|
||||||
|
'cache' => array(),
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
return $configs;
|
return $configs;
|
||||||
|
Loading…
Reference in New Issue
Block a user