Listen to the right even for auto share accept

Signed-off-by: Roeland Jago Douma <roeland@famdouma.nl>
This commit is contained in:
Roeland Jago Douma 2020-01-15 12:38:40 +01:00
parent 3d03d82026
commit 960d89ae31
No known key found for this signature in database
GPG Key ID: F941078878347C0C
1 changed files with 30 additions and 9 deletions

View File

@ -29,8 +29,10 @@ namespace OCA\Files_Sharing\Listener;
use OCP\EventDispatcher\Event; use OCP\EventDispatcher\Event;
use OCP\EventDispatcher\IEventListener; use OCP\EventDispatcher\IEventListener;
use OCP\IConfig; use OCP\IConfig;
use OCP\Share\Events\SharedEvent; use OCP\IGroupManager;
use OCP\Share\Events\ShareCreatedEvent;
use OCP\Share\IManager; use OCP\Share\IManager;
use OCP\Share\IShare;
class UserShareAcceptanceListener implements IEventListener { class UserShareAcceptanceListener implements IEventListener {
@ -38,23 +40,42 @@ class UserShareAcceptanceListener implements IEventListener {
private $config; private $config;
/** @var IManager */ /** @var IManager */
private $shareManager; private $shareManager;
/** @var string */ /** @var IGroupManager */
private $userId; private $groupManager;
public function __construct(IConfig $config, IManager $shareManager, string $userId) { public function __construct(IConfig $config, IManager $shareManager, IGroupManager $groupManager) {
$this->config = $config; $this->config = $config;
$this->shareManager = $shareManager; $this->shareManager = $shareManager;
$this->userId = $userId; $this->groupManager = $groupManager;
} }
public function handle(Event $event): void { public function handle(Event $event): void {
if (!($event instanceof SharedEvent)) { if (!($event instanceof ShareCreatedEvent)) {
return; return;
} }
if ($this->config->getUserValue($this->userId, 'files_sharing','default_accept','no') === 'yes') {
$share = $event->getShare(); $share = $event->getShare();
$this->shareManager->acceptShare($share, $this->userId);
if ($share->getShareType() === IShare::TYPE_USER) {
$this->handleAutoAccept($share, $share->getSharedWith());
} else if ($share->getShareType() === IShare::TYPE_GROUP) {
$group = $this->groupManager->get($share->getSharedWith());
if ($group === null) {
return;
}
$users = $group->getUsers();
foreach ($users as $user) {
$this->handleAutoAccept($share, $user->getUID());
}
}
}
private function handleAutoAccept(IShare $share, string $userId) {
if ($this->config->getUserValue($userId, 'files_sharing','default_accept','no') === 'yes') {
$this->shareManager->acceptShare($share, $userId);
} }
} }