summaryrefslogtreecommitdiffstats
path: root/apps/workflowengine/lib/Manager.php
diff options
context:
space:
mode:
authorArthur Schiwon <blizzz@arthur-schiwon.de>2019-08-16 17:17:38 +0200
committerArthur Schiwon <blizzz@arthur-schiwon.de>2019-09-09 22:56:01 +0200
commitbd5c455da4d79458906549082b49b0b83deebee8 (patch)
tree65933c5334ba8e210033dafce9e1c6bd05354911 /apps/workflowengine/lib/Manager.php
parent804d4fe69feb1853846ad7a4b92f01cc637daf71 (diff)
downloadnextcloud-server-bd5c455da4d79458906549082b49b0b83deebee8.tar.gz
nextcloud-server-bd5c455da4d79458906549082b49b0b83deebee8.zip
the workflow manager becomes scope aware, Part 1
Signed-off-by: Arthur Schiwon <blizzz@arthur-schiwon.de>
Diffstat (limited to 'apps/workflowengine/lib/Manager.php')
-rw-r--r--apps/workflowengine/lib/Manager.php33
1 files changed, 29 insertions, 4 deletions
diff --git a/apps/workflowengine/lib/Manager.php b/apps/workflowengine/lib/Manager.php
index 3a382f20dcd..3bfedfbfbf4 100644
--- a/apps/workflowengine/lib/Manager.php
+++ b/apps/workflowengine/lib/Manager.php
@@ -31,6 +31,7 @@ use OCP\IDBConnection;
use OCP\IL10N;
use OCP\ILogger;
use OCP\IServerContainer;
+use OCP\IUserSession;
use OCP\WorkflowEngine\ICheck;
use OCP\WorkflowEngine\IEntity;
use OCP\WorkflowEngine\IEntityAware;
@@ -73,6 +74,8 @@ class Manager implements IManager, IEntityAware {
/** @var ILogger */
protected $logger;
+ /** @var IUserSession */
+ protected $session;
/**
* @param IDBConnection $connection
@@ -84,13 +87,15 @@ class Manager implements IManager, IEntityAware {
IServerContainer $container,
IL10N $l,
EventDispatcherInterface $eventDispatcher,
- ILogger $logger
+ ILogger $logger,
+ IUserSession $session
) {
$this->connection = $connection;
$this->container = $container;
$this->l = $l;
$this->eventDispatcher = $eventDispatcher;
$this->logger = $logger;
+ $this->session = $session;
}
/**
@@ -155,14 +160,33 @@ class Manager implements IManager, IEntityAware {
throw new \UnexpectedValueException($this->l->t('Check %s is invalid or does not exist', $check['class']));
}
}
+ public function getAllOperations(int $scope = IManager::SCOPE_ADMIN, string $scopeId = null): array {
+ if(!in_array($scope, [IManager::SCOPE_ADMIN, IManager::SCOPE_USER])) {
+ throw new \InvalidArgumentException('Provided value for scope is not supported');
+ }
+ if($scope === IManager::SCOPE_USER && $scopeId === null) {
+ $user = $this->session->getUser();
+ if($user === null) {
+ throw new \InvalidArgumentException('No user ID was provided');
+ }
+ $scopeId = $user->getUID();
+ }
- public function getAllOperations(): array {
$this->operations = [];
$query = $this->connection->getQueryBuilder();
- $query->select('*')
- ->from('flow_operations');
+ $query->select('o.*')
+ ->from('flow_operations', 'o')
+ ->leftJoin('o', 'flow_operations_scope', 's', $query->expr()->eq('o.id', 's.operation_id'))
+ ->where($query->expr()->eq('s.type', $query->createParameter('scope')));
+
+ if($scope === IManager::SCOPE_USER) {
+ $query->andWhere($query->expr()->eq('s.value', $query->createParameter('scopeId')));
+ }
+
+ $query->setParameters(['scope' => $scope, 'scopeId' => $scopeId]);
+
$result = $query->execute();
while ($row = $result->fetch()) {
@@ -175,6 +199,7 @@ class Manager implements IManager, IEntityAware {
return $this->operations;
}
+
/**
* @param string $class
* @return array[]