2018-11-29 03:27:04 -05:00
|
|
|
<?php
|
|
|
|
|
|
|
|
namespace Friendica\Core;
|
|
|
|
|
|
|
|
use Friendica\Core\Config;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Manage storage backends
|
|
|
|
*
|
|
|
|
* Core code uses this class to get and set current storage backend class.
|
|
|
|
* Addons use this class to register and unregister additional backends.
|
|
|
|
*/
|
|
|
|
class StorageManager
|
|
|
|
{
|
2018-11-29 06:57:57 -05:00
|
|
|
private static $default_backends = [
|
2018-11-29 03:27:04 -05:00
|
|
|
'Filesystem' => \Friendica\Model\Storage\Filesystem::class,
|
|
|
|
'Database' => \Friendica\Model\Storage\Database::class,
|
|
|
|
];
|
|
|
|
|
2018-11-29 06:57:57 -05:00
|
|
|
private static $backends = [];
|
2018-11-29 03:27:04 -05:00
|
|
|
|
|
|
|
private static function setup()
|
|
|
|
{
|
2018-11-29 06:57:57 -05:00
|
|
|
if (count(self::$backends)==0) {
|
|
|
|
self::$backends = Config::get('storage', 'backends', self::$default_backends);
|
2018-11-29 03:27:04 -05:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Return current storage backend class
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
public static function getBackend()
|
|
|
|
{
|
|
|
|
return Config::get('storage', 'class', '');
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Return storage backend class by registered name
|
|
|
|
*
|
|
|
|
* @param string $name Backend name
|
|
|
|
* @return string Empty if no backend registered at $name exists
|
|
|
|
*/
|
|
|
|
public static function getByName($name)
|
|
|
|
{
|
|
|
|
self::setup();
|
2018-11-29 06:57:57 -05:00
|
|
|
return defaults(self::$backends, $name, '');
|
2018-11-29 03:27:04 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Set current storage backend class
|
|
|
|
*
|
|
|
|
* @param string $class Backend class name
|
|
|
|
*/
|
|
|
|
public static function setBackend($class)
|
|
|
|
{
|
|
|
|
/// @todo Check that $class implements IStorage
|
|
|
|
Config::set('storage', 'class', $class);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Get registered backends
|
|
|
|
*
|
|
|
|
* @return array
|
|
|
|
*/
|
|
|
|
public static function listBackends()
|
|
|
|
{
|
|
|
|
self::setup();
|
|
|
|
return self::$backends;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Register a storage backend class
|
|
|
|
*
|
|
|
|
* @param string $name User readable backend name
|
|
|
|
* @param string $class Backend class name
|
|
|
|
*/
|
|
|
|
public static function register($name, $class)
|
|
|
|
{
|
|
|
|
/// @todo Check that $class implements IStorage
|
|
|
|
self::setup();
|
2018-11-29 06:57:57 -05:00
|
|
|
self::$backends[$name] = $class;
|
|
|
|
Config::set('storage', 'backends', self::$backends);
|
2018-11-29 03:27:04 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Unregister a storage backend class
|
|
|
|
*
|
|
|
|
* @param string $name User readable backend name
|
|
|
|
*/
|
|
|
|
public static function unregister($class)
|
|
|
|
{
|
|
|
|
self::setup();
|
2018-11-29 06:57:57 -05:00
|
|
|
unset(self::$backends[$name]);
|
|
|
|
Config::set('storage', 'backends', self::$backends);
|
2018-11-29 03:27:04 -05:00
|
|
|
}
|
|
|
|
}
|