diff options
author | Joas Schilling <coding@schilljs.com> | 2023-06-30 12:50:28 +0200 |
---|---|---|
committer | Joas Schilling <coding@schilljs.com> | 2023-07-04 12:36:30 +0200 |
commit | eb090538972533c40c4a2589f44b9f9454edbb1d (patch) | |
tree | 6bcef8fb2933c18f90adeffec28bef8425256f3a /apps/admin_audit | |
parent | 2c71a77f4bd35bf68674be8b0fcff6f9f3c42200 (diff) | |
download | nextcloud-server-eb090538972533c40c4a2589f44b9f9454edbb1d.tar.gz nextcloud-server-eb090538972533c40c4a2589f44b9f9454edbb1d.zip |
feat(admin_audit): Migrate to non-deprecated IEventDispatcher
Signed-off-by: Joas Schilling <coding@schilljs.com>
Diffstat (limited to 'apps/admin_audit')
-rw-r--r-- | apps/admin_audit/lib/Actions/Security.php | 29 | ||||
-rw-r--r-- | apps/admin_audit/lib/AppInfo/Application.php | 42 | ||||
-rw-r--r-- | apps/admin_audit/tests/Actions/SecurityTest.php | 15 |
3 files changed, 50 insertions, 36 deletions
diff --git a/apps/admin_audit/lib/Actions/Security.php b/apps/admin_audit/lib/Actions/Security.php index e4831ac6fc1..17cf0c3c2b9 100644 --- a/apps/admin_audit/lib/Actions/Security.php +++ b/apps/admin_audit/lib/Actions/Security.php @@ -26,6 +26,7 @@ declare(strict_types=1); */ namespace OCA\AdminAudit\Actions; +use OCP\Authentication\TwoFactorAuth\IProvider; use OCP\IUser; /** @@ -35,14 +36,14 @@ use OCP\IUser; */ class Security extends Action { /** - * Log twofactor auth enabled - * - * @param IUser $user - * @param array $params + * Logs failed twofactor challenge */ - public function twofactorFailed(IUser $user, array $params): void { - $params['uid'] = $user->getUID(); - $params['displayName'] = $user->getDisplayName(); + public function twofactorFailed(IUser $user, IProvider $provider): void { + $params = [ + 'displayName' => $user->getDisplayName(), + 'uid' => $user->getUID(), + 'provider' => $provider->getDisplayName(), + ]; $this->log( 'Failed two factor attempt by user %s (%s) with provider %s', @@ -56,14 +57,14 @@ class Security extends Action { } /** - * Logs unsharing of data - * - * @param IUser $user - * @param array $params + * Logs successful twofactor challenge */ - public function twofactorSuccess(IUser $user, array $params): void { - $params['uid'] = $user->getUID(); - $params['displayName'] = $user->getDisplayName(); + public function twofactorSuccess(IUser $user, IProvider $provider): void { + $params = [ + 'displayName' => $user->getDisplayName(), + 'uid' => $user->getUID(), + 'provider' => $provider->getDisplayName(), + ]; $this->log( 'Successful two factor attempt by user %s (%s) with provider %s', diff --git a/apps/admin_audit/lib/AppInfo/Application.php b/apps/admin_audit/lib/AppInfo/Application.php index 1160d151710..7a4d2d6e3d1 100644 --- a/apps/admin_audit/lib/AppInfo/Application.php +++ b/apps/admin_audit/lib/AppInfo/Application.php @@ -57,7 +57,10 @@ use OCP\AppFramework\Bootstrap\IBootContext; use OCP\AppFramework\Bootstrap\IBootstrap; use OCP\AppFramework\Bootstrap\IRegistrationContext; use OCP\Authentication\TwoFactorAuth\IProvider; +use OCP\Authentication\TwoFactorAuth\TwoFactorProviderChallengeFailed; +use OCP\Authentication\TwoFactorAuth\TwoFactorProviderChallengePassed; use OCP\Console\ConsoleEvent; +use OCP\EventDispatcher\IEventDispatcher; use OCP\IConfig; use OCP\IGroupManager; use OCP\IPreview; @@ -65,6 +68,7 @@ use OCP\IServerContainer; use OCP\IUserSession; use OCP\Log\Audit\CriticalActionPerformedEvent; use OCP\Log\ILogFactory; +use OCP\Preview\BeforePreviewFetchedEvent; use OCP\Share; use OCP\Util; use Psr\Container\ContainerInterface; @@ -109,8 +113,9 @@ class Application extends App implements IBootstrap { $this->groupHooks($logger, $serverContainer->get(IGroupManager::class)); $this->authHooks($logger); - /** @var EventDispatcherInterface $eventDispatcher */ - $eventDispatcher = $serverContainer->get(EventDispatcherInterface::class); + + /** @var IEventDispatcher $eventDispatcher */ + $eventDispatcher = $serverContainer->get(IEventDispatcher::class); $this->consoleHooks($logger, $eventDispatcher); $this->appHooks($logger, $eventDispatcher); @@ -169,7 +174,7 @@ class Application extends App implements IBootstrap { } private function appHooks(IAuditLogger $logger, - EventDispatcherInterface $eventDispatcher): void { + IEventDispatcher $eventDispatcher): void { $eventDispatcher->addListener(ManagerEvent::EVENT_APP_ENABLE, function (ManagerEvent $event) use ($logger) { $appActions = new AppManagement($logger); $appActions->enableApp($event->getAppID()); @@ -185,27 +190,26 @@ class Application extends App implements IBootstrap { } private function consoleHooks(IAuditLogger $logger, - EventDispatcherInterface $eventDispatcher): void { - $eventDispatcher->addListener(ConsoleEvent::EVENT_RUN, function (ConsoleEvent $event) use ($logger) { + IEventDispatcher $eventDispatcher): void { + $eventDispatcher->addListener(ConsoleEvent::class, function (ConsoleEvent $event) use ($logger) { $appActions = new Console($logger); $appActions->runCommand($event->getArguments()); }); } private function fileHooks(IAuditLogger $logger, - EventDispatcherInterface $eventDispatcher): void { + IEventDispatcher $eventDispatcher): void { $fileActions = new Files($logger); $eventDispatcher->addListener( - IPreview::EVENT, - function (GenericEvent $event) use ($fileActions) { - /** @var File $file */ - $file = $event->getSubject(); + BeforePreviewFetchedEvent::class, + function (BeforePreviewFetchedEvent $event) use ($fileActions) { + $file = $event->getNode(); $fileActions->preview([ 'path' => mb_substr($file->getInternalPath(), 5), - 'width' => $event->getArguments()['width'], - 'height' => $event->getArguments()['height'], - 'crop' => $event->getArguments()['crop'], - 'mode' => $event->getArguments()['mode'] + 'width' => $event->getWidth(), + 'height' => $event->getHeight(), + 'crop' => $event->isCrop(), + 'mode' => $event->getMode() ]); } ); @@ -267,14 +271,14 @@ class Application extends App implements IBootstrap { } private function securityHooks(IAuditLogger $logger, - EventDispatcherInterface $eventDispatcher): void { - $eventDispatcher->addListener(IProvider::EVENT_SUCCESS, function (GenericEvent $event) use ($logger) { + IEventDispatcher $eventDispatcher): void { + $eventDispatcher->addListener(TwoFactorProviderChallengePassed::class, function (TwoFactorProviderChallengePassed $event) use ($logger) { $security = new Security($logger); - $security->twofactorSuccess($event->getSubject(), $event->getArguments()); + $security->twofactorSuccess($event->getUser(), $event->getProvider()); }); - $eventDispatcher->addListener(IProvider::EVENT_FAILED, function (GenericEvent $event) use ($logger) { + $eventDispatcher->addListener(TwoFactorProviderChallengeFailed::class, function (TwoFactorProviderChallengeFailed $event) use ($logger) { $security = new Security($logger); - $security->twofactorFailed($event->getSubject(), $event->getArguments()); + $security->twofactorFailed($event->getUser(), $event->getProvider()); }); } } diff --git a/apps/admin_audit/tests/Actions/SecurityTest.php b/apps/admin_audit/tests/Actions/SecurityTest.php index d45cbb75a64..bba819ad04d 100644 --- a/apps/admin_audit/tests/Actions/SecurityTest.php +++ b/apps/admin_audit/tests/Actions/SecurityTest.php @@ -27,8 +27,9 @@ declare(strict_types=1); namespace OCA\AdminAudit\Tests\Actions; use OCA\AdminAudit\Actions\Security; -use OCP\IUser; use OCA\AdminAudit\AuditLogger; +use OCP\Authentication\TwoFactorAuth\IProvider; +use OCP\IUser; use Test\TestCase; class SecurityTest extends TestCase { @@ -60,7 +61,11 @@ class SecurityTest extends TestCase { ['app' => 'admin_audit'] ); - $this->security->twofactorFailed($this->user, ['provider' => 'myprovider']); + $provider = $this->createMock(IProvider::class); + $provider->method('getDisplayName') + ->willReturn('myprovider'); + + $this->security->twofactorFailed($this->user, $provider); } public function testTwofactorSuccess() { @@ -71,6 +76,10 @@ class SecurityTest extends TestCase { ['app' => 'admin_audit'] ); - $this->security->twofactorSuccess($this->user, ['provider' => 'myprovider']); + $provider = $this->createMock(IProvider::class); + $provider->method('getDisplayName') + ->willReturn('myprovider'); + + $this->security->twofactorSuccess($this->user, $provider); } } |