diff options
author | Joas Schilling <coding@schilljs.com> | 2023-02-15 15:36:32 +0100 |
---|---|---|
committer | Joas Schilling <coding@schilljs.com> | 2023-02-23 06:18:38 +0100 |
commit | cd4aad1ab6a99f9aaed1306e3b051a946944a648 (patch) | |
tree | c4daa2a1ac62fbefbe36d436c827a25d67f0753f /apps/workflowengine/lib/Manager.php | |
parent | 2be84b5867be2027bb5085819c626dc746d50faa (diff) | |
download | nextcloud-server-cd4aad1ab6a99f9aaed1306e3b051a946944a648.tar.gz nextcloud-server-cd4aad1ab6a99f9aaed1306e3b051a946944a648.zip |
Also check the scope when reading operations from the database
Signed-off-by: Joas Schilling <coding@schilljs.com>
Diffstat (limited to 'apps/workflowengine/lib/Manager.php')
-rw-r--r-- | apps/workflowengine/lib/Manager.php | 23 |
1 files changed, 23 insertions, 0 deletions
diff --git a/apps/workflowengine/lib/Manager.php b/apps/workflowengine/lib/Manager.php index 8aeb588d016..a06b56dc208 100644 --- a/apps/workflowengine/lib/Manager.php +++ b/apps/workflowengine/lib/Manager.php @@ -189,6 +189,13 @@ class Manager implements IManager { return $scopesByOperation[$operationClass]; } + try { + /** @var IOperation $operation */ + $operation = $this->container->query($operationClass); + } catch (QueryException $e) { + return []; + } + $query = $this->connection->getQueryBuilder(); $query->selectDistinct('s.type') @@ -203,6 +210,11 @@ class Manager implements IManager { $scopesByOperation[$operationClass] = []; while ($row = $result->fetch()) { $scope = new ScopeContext($row['type'], $row['value']); + + if (!$operation->isAvailableForScope((int) $row['type'])) { + continue; + } + $scopesByOperation[$operationClass][$scope->getHash()] = $scope; } @@ -232,6 +244,17 @@ class Manager implements IManager { $this->operations[$scopeContext->getHash()] = []; while ($row = $result->fetch()) { + try { + /** @var IOperation $operation */ + $operation = $this->container->query($row['class']); + } catch (QueryException $e) { + continue; + } + + if (!$operation->isAvailableForScope((int) $row['scope_type'])) { + continue; + } + if (!isset($this->operations[$scopeContext->getHash()][$row['class']])) { $this->operations[$scopeContext->getHash()][$row['class']] = []; } |