X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=src%2FBaseObject.php;h=20481884517e565123d8b17f7038a6033250525a;hb=fd706cf9a7a0c4700838a1f00b12d8fd37323b7c;hp=9a2d064750b7d74ca13bc17fd2473323cf3298f8;hpb=e0911efc87d0f6151bdcbf3a665854dc52c9cd2d;p=friendica.git diff --git a/src/BaseObject.php b/src/BaseObject.php index 9a2d064750..2048188451 100644 --- a/src/BaseObject.php +++ b/src/BaseObject.php @@ -6,19 +6,32 @@ namespace Friendica; require_once __DIR__ . '/../boot.php'; +use Dice\Dice; use Friendica\Network\HTTPException\InternalServerErrorException; /** * Basic object * * Contains what is useful to any object + * + * Act's like a global registry for classes */ class BaseObject { /** - * @var App + * @var Dice The Dependency Injection library */ - private static $app = null; + private static $dice; + + /** + * Set's the dependency injection library for a global usage + * + * @param Dice $dice The dependency injection library + */ + public static function setDependencyInjection(Dice $dice) + { + self::$dice = $dice; + } /** * Get the app @@ -26,26 +39,31 @@ class BaseObject * Same as get_app from boot.php * * @return App - * @throws \Exception */ public static function getApp() { - if (empty(self::$app)) { - throw new InternalServerErrorException('App isn\'t initialized.'); - } - - return self::$app; + return self::getClass(App::class); } /** - * Set the app + * Returns the initialized class based on it's name + * + * @param string $name The name of the class * - * @param App $app App + * @return object The initialized name * - * @return void + * @throws InternalServerErrorException */ - public static function setApp(App $app) + public static function getClass(string $name) { - self::$app = $app; + if (empty(self::$dice)) { + throw new InternalServerErrorException('DICE isn\'t initialized.'); + } + + if (class_exists($name) || interface_exists($name)) { + return self::$dice->create($name); + } else { + throw new InternalServerErrorException('Class \'' . $name . '\' isn\'t valid.'); + } } }