Skip to content

Migrate admin_audit closure listeners to class listeners #39118

@ChristophWurst

Description

@ChristophWurst

⚠️ This issue respects the following points: ⚠️

Bug description

private function securityHooks(IAuditLogger $logger,
EventDispatcherInterface $eventDispatcher): void {
$eventDispatcher->addListener(IProvider::EVENT_SUCCESS, function (GenericEvent $event) use ($logger) {
$security = new Security($logger);
$security->twofactorSuccess($event->getSubject(), $event->getArguments());
});
$eventDispatcher->addListener(IProvider::EVENT_FAILED, function (GenericEvent $event) use ($logger) {
$security = new Security($logger);
$security->twofactorFailed($event->getSubject(), $event->getArguments());
});
}
uses a bunch of closure event listeners. They are heavier than class-based listeners only instantiated when a matching event is emitted.

This will also open the door for unit-testable event listeners.

Steps to reproduce

  1. Look at
    private function securityHooks(IAuditLogger $logger,
    EventDispatcherInterface $eventDispatcher): void {
    $eventDispatcher->addListener(IProvider::EVENT_SUCCESS, function (GenericEvent $event) use ($logger) {
    $security = new Security($logger);
    $security->twofactorSuccess($event->getSubject(), $event->getArguments());
    });
    $eventDispatcher->addListener(IProvider::EVENT_FAILED, function (GenericEvent $event) use ($logger) {
    $security = new Security($logger);
    $security->twofactorFailed($event->getSubject(), $event->getArguments());
    });
    }

Expected behavior

Clean code

Installation method

None

Nextcloud Server version

master

Operating system

None

PHP engine version

None

Web server

None

Database engine version

None

Is this bug present after an update or on a fresh install?

None

Are you using the Nextcloud Server Encryption module?

None

What user-backends are you using?

  • Default user-backend (database)
  • LDAP/ Active Directory
  • SSO - SAML
  • Other

Configuration report

No response

List of activated Apps

No response

Nextcloud Signing status

No response

Nextcloud Logs

No response

Additional info

cc @luka-nextcloud @blizzz as app maintainers

Metadata

Metadata

Assignees

No one assigned

    Type

    No type

    Projects

    No projects

    Milestone

    No milestone

    Relationships

    None yet

    Development

    No branches or pull requests

    Issue actions