summaryrefslogtreecommitdiffstats
path: root/apps/workflowengine
diff options
context:
space:
mode:
authorRoeland Jago Douma <rullzer@users.noreply.github.com>2020-04-04 10:34:49 +0200
committerGitHub <noreply@github.com>2020-04-04 10:34:49 +0200
commit4261cfb1326ae469efbbec4e5bcd771a44ed66fb (patch)
tree8e99db57c2cc5e11b87021896cd34906e8590e0f /apps/workflowengine
parentb54b5a503e86f7ad46e0ee4912c1078ca385f886 (diff)
parentaeff8a84f156ff9ea38264224f7b2b8ea943bd64 (diff)
downloadnextcloud-server-4261cfb1326ae469efbbec4e5bcd771a44ed66fb.tar.gz
nextcloud-server-4261cfb1326ae469efbbec4e5bcd771a44ed66fb.zip
Merge pull request #20158 from nextcloud/backport/19930/stable18
[stable18] Add app config to disable user flows
Diffstat (limited to 'apps/workflowengine')
-rw-r--r--apps/workflowengine/lib/Controller/UserWorkflowsController.php2
-rw-r--r--apps/workflowengine/lib/Manager.php13
-rw-r--r--apps/workflowengine/lib/Service/RuleMatcher.php2
-rw-r--r--apps/workflowengine/lib/Settings/ASettings.php2
-rw-r--r--apps/workflowengine/lib/Settings/Personal.php4
-rw-r--r--apps/workflowengine/tests/ManagerTest.php7
6 files changed, 25 insertions, 5 deletions
diff --git a/apps/workflowengine/lib/Controller/UserWorkflowsController.php b/apps/workflowengine/lib/Controller/UserWorkflowsController.php
index 3e907d22696..9bb7fc4778a 100644
--- a/apps/workflowengine/lib/Controller/UserWorkflowsController.php
+++ b/apps/workflowengine/lib/Controller/UserWorkflowsController.php
@@ -106,7 +106,7 @@ class UserWorkflowsController extends AWorkflowController {
protected function getScopeContext(): ScopeContext {
if($this->scopeContext === null) {
$user = $this->session->getUser();
- if(!$user) {
+ if(!$user || !$this->manager->isUserScopeEnabled()) {
throw new OCSForbiddenException('User not logged in');
}
$this->scopeContext = new ScopeContext(IManager::SCOPE_USER, $user->getUID());
diff --git a/apps/workflowengine/lib/Manager.php b/apps/workflowengine/lib/Manager.php
index 2818238081e..1fc30001518 100644
--- a/apps/workflowengine/lib/Manager.php
+++ b/apps/workflowengine/lib/Manager.php
@@ -23,6 +23,7 @@ namespace OCA\WorkflowEngine;
use Doctrine\DBAL\DBALException;
use OC\Cache\CappedMemoryCache;
+use OCA\WorkflowEngine\AppInfo\Application;
use OCA\WorkflowEngine\Check\FileMimeType;
use OCA\WorkflowEngine\Check\FileName;
use OCA\WorkflowEngine\Check\FileSize;
@@ -40,6 +41,7 @@ use OCP\AppFramework\QueryException;
use OCP\DB\QueryBuilder\IQueryBuilder;
use OCP\EventDispatcher\IEventDispatcher;
use OCP\Files\Storage\IStorage;
+use OCP\IConfig;
use OCP\IDBConnection;
use OCP\IL10N;
use OCP\ILogger;
@@ -108,6 +110,9 @@ class Manager implements IManager {
/** @var IEventDispatcher */
private $dispatcher;
+ /** @var IConfig */
+ private $config;
+
public function __construct(
IDBConnection $connection,
IServerContainer $container,
@@ -115,7 +120,8 @@ class Manager implements IManager {
LegacyDispatcher $eventDispatcher,
ILogger $logger,
IUserSession $session,
- IEventDispatcher $dispatcher
+ IEventDispatcher $dispatcher,
+ IConfig $config
) {
$this->connection = $connection;
$this->container = $container;
@@ -125,6 +131,7 @@ class Manager implements IManager {
$this->operationsByScope = new CappedMemoryCache(64);
$this->session = $session;
$this->dispatcher = $dispatcher;
+ $this->config = $config;
}
public function getRuleMatcher(): IRuleMatcher {
@@ -704,4 +711,8 @@ class Manager implements IManager {
return [];
}
}
+
+ public function isUserScopeEnabled(): bool {
+ return $this->config->getAppValue(Application::APP_ID, 'user_scope_disabled', 'no') === 'no';
+ }
}
diff --git a/apps/workflowengine/lib/Service/RuleMatcher.php b/apps/workflowengine/lib/Service/RuleMatcher.php
index 99a5db8a9d0..fefb77d4fb1 100644
--- a/apps/workflowengine/lib/Service/RuleMatcher.php
+++ b/apps/workflowengine/lib/Service/RuleMatcher.php
@@ -117,7 +117,7 @@ class RuleMatcher implements IRuleMatcher {
public function getMatchingOperations(string $class, bool $returnFirstMatchingOperationOnly = true): array {
$scopes[] = new ScopeContext(IManager::SCOPE_ADMIN);
$user = $this->session->getUser();
- if($user !== null) {
+ if($user !== null && $this->manager->isUserScopeEnabled()) {
$scopes[] = new ScopeContext(IManager::SCOPE_USER, $user->getUID());
}
diff --git a/apps/workflowengine/lib/Settings/ASettings.php b/apps/workflowengine/lib/Settings/ASettings.php
index ac2ebdb8cac..b10d84fd1f5 100644
--- a/apps/workflowengine/lib/Settings/ASettings.php
+++ b/apps/workflowengine/lib/Settings/ASettings.php
@@ -49,7 +49,7 @@ abstract class ASettings implements ISettings {
private $eventDispatcher;
/** @var Manager */
- private $manager;
+ protected $manager;
/** @var IInitialStateService */
private $initialStateService;
diff --git a/apps/workflowengine/lib/Settings/Personal.php b/apps/workflowengine/lib/Settings/Personal.php
index 9c23a250355..30f52073a1c 100644
--- a/apps/workflowengine/lib/Settings/Personal.php
+++ b/apps/workflowengine/lib/Settings/Personal.php
@@ -31,4 +31,8 @@ class Personal extends ASettings {
function getScope(): int {
return IManager::SCOPE_USER;
}
+
+ public function getSection() {
+ return $this->manager->isUserScopeEnabled() ? 'workflow' : null;
+ }
}
diff --git a/apps/workflowengine/tests/ManagerTest.php b/apps/workflowengine/tests/ManagerTest.php
index 22d323a9436..28001a05a92 100644
--- a/apps/workflowengine/tests/ManagerTest.php
+++ b/apps/workflowengine/tests/ManagerTest.php
@@ -28,6 +28,7 @@ use OCA\WorkflowEngine\Helper\ScopeContext;
use OCA\WorkflowEngine\Manager;
use OCP\EventDispatcher\IEventDispatcher;
use OCP\Files\IRootFolder;
+use OCP\IConfig;
use OCP\IDBConnection;
use OCP\IL10N;
use OCP\ILogger;
@@ -67,6 +68,8 @@ class ManagerTest extends TestCase {
protected $l;
/** @var MockObject|IEventDispatcher */
protected $dispatcher;
+ /** @var MockObject|IConfig */
+ protected $config;
protected function setUp(): void {
parent::setUp();
@@ -84,6 +87,7 @@ class ManagerTest extends TestCase {
$this->logger = $this->createMock(ILogger::class);
$this->session = $this->createMock(IUserSession::class);
$this->dispatcher = $this->createMock(IEventDispatcher::class);
+ $this->config = $this->createMock(IConfig::class);
$this->manager = new Manager(
\OC::$server->getDatabaseConnection(),
@@ -92,7 +96,8 @@ class ManagerTest extends TestCase {
$this->legacyDispatcher,
$this->logger,
$this->session,
- $this->dispatcher
+ $this->dispatcher,
+ $this->config
);
$this->clearTables();
}