X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=src%2FBaseObject.php;h=20481884517e565123d8b17f7038a6033250525a;hb=fd706cf9a7a0c4700838a1f00b12d8fd37323b7c;hp=01957164c10bd664fbd536b2f6c0680b5af8e9c9;hpb=b85c94a60d5142adc9aa77d2de7c05b91021c450;p=friendica.git diff --git a/src/BaseObject.php b/src/BaseObject.php index 01957164c1..2048188451 100644 --- a/src/BaseObject.php +++ b/src/BaseObject.php @@ -4,44 +4,66 @@ */ namespace Friendica; -require_once 'boot.php'; +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 { - private static $app = null; + /** + * @var Dice The Dependency Injection library + */ + 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 * * Same as get_app from boot.php * - * @return object + * @return App */ public static function getApp() { - if (self::$app) { - return self::$app; - } - - self::$app = get_app(); - - return self::$app; + return self::getClass(App::class); } /** - * Set the app + * Returns the initialized class based on it's name * - * @param object $app App + * @param string $name The name of the class * - * @return void + * @return object The initialized name + * + * @throws InternalServerErrorException */ - public static function setApp($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.'); + } } }