mirror of
https://github.com/nextcloud/server.git
synced 2026-02-20 00:12:30 -05:00
fix(files): Properly handle denied ownership transfers
When the receiver denies the transfer the notification handler was missing, so no notification was created for the transfer owner. But also the internal notification was created two times: 1. When rejecting the transfer 2. By the reject function when dismissing the notification This is fixed by only relying on the dismiss function. Signed-off-by: Ferdinand Thiessen <opensource@fthiessen.de>
This commit is contained in:
parent
54bf26ae50
commit
1550af87cd
2 changed files with 34 additions and 29 deletions
|
|
@ -189,20 +189,10 @@ class TransferOwnershipController extends OCSController {
|
|||
->setObject('transfer', (string)$id);
|
||||
$this->notificationManager->markProcessed($notification);
|
||||
|
||||
$notification = $this->notificationManager->createNotification();
|
||||
$notification->setUser($transferOwnership->getSourceUser())
|
||||
->setApp($this->appName)
|
||||
->setDateTime($this->timeFactory->getDateTime())
|
||||
->setSubject('transferownershipRequestDenied', [
|
||||
'sourceUser' => $transferOwnership->getSourceUser(),
|
||||
'targetUser' => $transferOwnership->getTargetUser(),
|
||||
'nodeName' => $transferOwnership->getNodeName()
|
||||
])
|
||||
->setObject('transfer', (string)$transferOwnership->getId());
|
||||
$this->notificationManager->notify($notification);
|
||||
|
||||
$this->mapper->delete($transferOwnership);
|
||||
|
||||
// A "request denied" notification will be created by Notifier::dismissNotification
|
||||
|
||||
return new DataResponse([], Http::STATUS_OK);
|
||||
}
|
||||
}
|
||||
|
|
|
|||
|
|
@ -69,23 +69,15 @@ class Notifier implements INotifier, IDismissableNotifier {
|
|||
throw new \InvalidArgumentException('Unhandled app');
|
||||
}
|
||||
|
||||
if ($notification->getSubject() === 'transferownershipRequest') {
|
||||
return $this->handleTransferownershipRequest($notification, $languageCode);
|
||||
}
|
||||
if ($notification->getSubject() === 'transferOwnershipFailedSource') {
|
||||
return $this->handleTransferOwnershipFailedSource($notification, $languageCode);
|
||||
}
|
||||
if ($notification->getSubject() === 'transferOwnershipFailedTarget') {
|
||||
return $this->handleTransferOwnershipFailedTarget($notification, $languageCode);
|
||||
}
|
||||
if ($notification->getSubject() === 'transferOwnershipDoneSource') {
|
||||
return $this->handleTransferOwnershipDoneSource($notification, $languageCode);
|
||||
}
|
||||
if ($notification->getSubject() === 'transferOwnershipDoneTarget') {
|
||||
return $this->handleTransferOwnershipDoneTarget($notification, $languageCode);
|
||||
}
|
||||
|
||||
throw new \InvalidArgumentException('Unhandled subject');
|
||||
return match($notification->getSubject()) {
|
||||
'transferownershipRequest' => $this->handleTransferownershipRequest($notification, $languageCode),
|
||||
'transferownershipRequestDenied' => $this->handleTransferOwnershipRequestDenied($notification, $languageCode),
|
||||
'transferOwnershipFailedSource' => $this->handleTransferOwnershipFailedSource($notification, $languageCode),
|
||||
'transferOwnershipFailedTarget' => $this->handleTransferOwnershipFailedTarget($notification, $languageCode),
|
||||
'transferOwnershipDoneSource' => $this->handleTransferOwnershipDoneSource($notification, $languageCode),
|
||||
'transferOwnershipDoneTarget' => $this->handleTransferOwnershipDoneTarget($notification, $languageCode),
|
||||
default => throw new \InvalidArgumentException('Unhandled subject')
|
||||
};
|
||||
}
|
||||
|
||||
public function handleTransferownershipRequest(INotification $notification, string $languageCode): INotification {
|
||||
|
|
@ -144,6 +136,29 @@ class Notifier implements INotifier, IDismissableNotifier {
|
|||
return $notification;
|
||||
}
|
||||
|
||||
public function handleTransferOwnershipRequestDenied(INotification $notification, string $languageCode): INotification {
|
||||
$l = $this->l10nFactory->get('files', $languageCode);
|
||||
$param = $notification->getSubjectParameters();
|
||||
|
||||
$targetUser = $this->getUser($param['targetUser']);
|
||||
$notification->setRichSubject($l->t('Ownership transfer denied'))
|
||||
->setRichMessage(
|
||||
$l->t('Your ownership transfer of {path} was denied by {user}.'),
|
||||
[
|
||||
'path' => [
|
||||
'type' => 'highlight',
|
||||
'id' => $param['targetUser'] . '::' . $param['nodeName'],
|
||||
'name' => $param['nodeName'],
|
||||
],
|
||||
'user' => [
|
||||
'type' => 'user',
|
||||
'id' => $targetUser->getUID(),
|
||||
'name' => $targetUser->getDisplayName(),
|
||||
],
|
||||
]);
|
||||
return $notification;
|
||||
}
|
||||
|
||||
public function handleTransferOwnershipFailedSource(INotification $notification, string $languageCode): INotification {
|
||||
$l = $this->l10nFactory->get('files', $languageCode);
|
||||
$param = $notification->getSubjectParameters();
|
||||
|
|
|
|||
Loading…
Reference in a new issue