From 964f827ee527c25afe13eb4c73d465cbcfe118aa Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Dani=C3=ABl=20Klabbers?= Date: Fri, 29 Jan 2021 14:13:16 +0100 Subject: [PATCH] Fixes model visibility (#2580) Model Visibility extender does not take into consideration missing dependencies. For instance flarum/tags adds a policy on the Flag model from flarum/flags. But because flarum/flags might as well not be installed we need to check for the existence of that model. Otherwise the exception is thrown or flarum fails to boot. --- src/Extend/ModelVisibility.php | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) diff --git a/src/Extend/ModelVisibility.php b/src/Extend/ModelVisibility.php index 92e81e6d1..3313b0ea8 100644 --- a/src/Extend/ModelVisibility.php +++ b/src/Extend/ModelVisibility.php @@ -44,7 +44,7 @@ class ModelVisibility implements ExtenderInterface { $this->modelClass = $modelClass; - if (! method_exists($modelClass, 'registerVisibilityScoper')) { + if (class_exists($this->modelClass) && ! is_callable([$modelClass, 'registerVisibilityScoper'])) { throw new Exception("Model $modelClass cannot be visibility scoped as it does not use Flarum\Database\ScopeVisibilityTrait."); } } @@ -89,6 +89,10 @@ class ModelVisibility implements ExtenderInterface public function extend(Container $container, Extension $extension = null) { + if (! class_exists($this->modelClass)) { + return; + } + foreach ($this->scopers as $ability => $scopers) { foreach ($scopers as $scoper) { $this->modelClass::registerVisibilityScoper(ContainerUtil::wrapCallback($scoper, $container), $ability);