You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

ActivityPublisher.php 2.0KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768
  1. <?php
  2. declare(strict_types=1);
  3. /**
  4. * @author Christoph Wurst <christoph@winzerhof-wurst.at>
  5. *
  6. * @license GNU AGPL version 3 or any later version
  7. *
  8. * This program is free software: you can redistribute it and/or modify
  9. * it under the terms of the GNU Affero General Public License as
  10. * published by the Free Software Foundation, either version 3 of the
  11. * License, or (at your option) any later version.
  12. *
  13. * This program is distributed in the hope that it will be useful,
  14. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  15. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  16. * GNU Affero General Public License for more details.
  17. *
  18. * You should have received a copy of the GNU Affero General Public License
  19. * along with this program. If not, see <http://www.gnu.org/licenses/>.
  20. *
  21. */
  22. namespace OCA\TwoFactorBackupCodes\Listener;
  23. use BadMethodCallException;
  24. use OCA\TwoFactorBackupCodes\Event\CodesGenerated;
  25. use OCP\Activity\IManager;
  26. use OCP\EventDispatcher\Event;
  27. use OCP\EventDispatcher\IEventListener;
  28. use OCP\ILogger;
  29. class ActivityPublisher implements IEventListener {
  30. /** @var IManager */
  31. private $activityManager;
  32. /** @var ILogger */
  33. private $logger;
  34. public function __construct(IManager $activityManager,
  35. ILogger $logger) {
  36. $this->activityManager = $activityManager;
  37. $this->logger = $logger;
  38. }
  39. /**
  40. * Push an event to the user's activity stream
  41. */
  42. public function handle(Event $event): void {
  43. if ($event instanceof CodesGenerated) {
  44. $activity = $this->activityManager->generateEvent();
  45. $activity->setApp('twofactor_backupcodes')
  46. ->setType('security')
  47. ->setAuthor($event->getUser()->getUID())
  48. ->setAffectedUser($event->getUser()->getUID())
  49. ->setSubject('codes_generated');
  50. try {
  51. $this->activityManager->publish($activity);
  52. } catch (BadMethodCallException $e) {
  53. $this->logger->warning('could not publish backup code creation activity', ['app' => 'twofactor_backupcodes']);
  54. $this->logger->logException($e, ['app' => 'twofactor_backupcodes']);
  55. }
  56. }
  57. }
  58. }