summaryrefslogtreecommitdiffstats
path: root/apps
diff options
context:
space:
mode:
authorArthur Schiwon <blizzz@arthur-schiwon.de>2019-11-13 12:28:23 +0100
committerArthur Schiwon <blizzz@arthur-schiwon.de>2019-11-28 17:03:33 +0100
commit4baab51f4ccdf44399f656e5a5acf89d1f6b779b (patch)
treef8857c41f8fbed921a6a0b409a54bf7e056e4a12 /apps
parentbe85d00a386dfc8c60f413e7000009237855ce7e (diff)
downloadnextcloud-server-4baab51f4ccdf44399f656e5a5acf89d1f6b779b.tar.gz
nextcloud-server-4baab51f4ccdf44399f656e5a5acf89d1f6b779b.zip
extend with group deletion handling
Signed-off-by: Arthur Schiwon <blizzz@arthur-schiwon.de>
Diffstat (limited to 'apps')
-rw-r--r--apps/files_external/lib/AppInfo/Application.php11
-rw-r--r--apps/files_external/lib/Service/DBConfigService.php20
2 files changed, 25 insertions, 6 deletions
diff --git a/apps/files_external/lib/AppInfo/Application.php b/apps/files_external/lib/AppInfo/Application.php
index aa14772bae0..47c88a67d20 100644
--- a/apps/files_external/lib/AppInfo/Application.php
+++ b/apps/files_external/lib/AppInfo/Application.php
@@ -64,6 +64,7 @@ use OCA\Files_External\Service\BackendService;
use OCP\AppFramework\App;
use OCP\AppFramework\IAppContainer;
use OCP\Files\Config\IUserMountCache;
+use OCP\IGroup;
use OCP\IUser;
use Symfony\Component\EventDispatcher\GenericEvent;
@@ -111,6 +112,16 @@ class Application extends App implements IBackendProvider, IAuthMechanismProvide
$config->modifyMountsOnUserDelete($user->getUID());
}
);
+ $dispatcher->addListener(
+ IGroup::class . '::postDelete',
+ function (GenericEvent $event) {
+ /** @var IGroup $group */
+ $group = $event->getSubject();
+ /** @var DBConfigService $config */
+ $config = $this->getContainer()->query(DBConfigService::class);
+ $config->modifyMountsOnGroupDelete($group->getGID());
+ }
+ );
}
/**
diff --git a/apps/files_external/lib/Service/DBConfigService.php b/apps/files_external/lib/Service/DBConfigService.php
index 0d8d048fc1d..9394924d396 100644
--- a/apps/files_external/lib/Service/DBConfigService.php
+++ b/apps/files_external/lib/Service/DBConfigService.php
@@ -114,15 +114,23 @@ class DBConfigService {
return $this->getMountsFromQuery($query);
}
- public function modifyMountsOnUserDelete(string $uid) {
+ public function modifyMountsOnUserDelete(string $uid): void {
+ $this->modifyMountsOnDelete($uid, self::APPLICABLE_TYPE_USER);
+ }
+
+ public function modifyMountsOnGroupDelete(string $gid): void {
+ $this->modifyMountsOnDelete($gid, self::APPLICABLE_TYPE_GROUP);
+ }
+
+ protected function modifyMountsOnDelete(string $applicableId, int $applicableType): void {
$builder = $this->connection->getQueryBuilder();
$query = $builder->select(['a.mount_id', $builder->func()->count('a.mount_id', 'count')])
->from('external_applicable', 'a')
->rightJoin('a', 'external_applicable', 'b', $builder->expr()->eq('a.mount_id', 'b.mount_id'))
- ->where($builder->expr()->andX( // mounts for user
- $builder->expr()->eq('a.type', $builder->createNamedParameter(self::APPLICABLE_TYPE_USER, IQueryBuilder::PARAM_INT)),
- $builder->expr()->eq('a.value', $builder->createNamedParameter($uid))
- )
+ ->where($builder->expr()->andX(
+ $builder->expr()->eq('a.type', $builder->createNamedParameter($applicableType, IQueryBuilder::PARAM_INT)),
+ $builder->expr()->eq('a.value', $builder->createNamedParameter($applicableId))
+ )
)
->groupBy(['a.mount_id']);
$stmt = $query->execute();
@@ -131,7 +139,7 @@ class DBConfigService {
foreach ($result as $row) {
if((int)$row['count'] > 1) {
- $this->removeApplicable($row['mount_id'], self::APPLICABLE_TYPE_USER, $uid);
+ $this->removeApplicable($row['mount_id'], $applicableType, $applicableId);
} else {
$this->removeMount($row['mount_id']);
}