Files
firefly-iii/app/Handlers/Events/LDAPEventHandler.php

58 lines
1.7 KiB
PHP
Raw Normal View History

2021-07-10 07:35:54 +02:00
<?php
2021-08-10 19:31:55 +02:00
2021-07-10 07:35:54 +02:00
/*
* LDAPEventHandler.php
* Copyright (c) 2021 james@firefly-iii.org
*
* This file is part of Firefly III (https://github.com/firefly-iii).
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU Affero General Public License as
* published by the Free Software Foundation, either version 3 of the
* License, or (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Affero General Public License for more details.
*
* You should have received a copy of the GNU Affero General Public License
* along with this program. If not, see <https://www.gnu.org/licenses/>.
*/
2021-08-10 19:31:55 +02:00
declare(strict_types=1);
2021-07-10 07:35:54 +02:00
namespace FireflyIII\Handlers\Events;
use FireflyIII\User;
use LdapRecord\Laravel\Events\Import\Imported;
use Log;
/**
* Class LDAPEventHandler
*/
class LDAPEventHandler
{
/**
* @param Imported $event
*/
public function importedUser(Imported $event)
{
2021-07-17 17:26:12 +02:00
Log::debug(sprintf('Now in %s', __METHOD__));
2021-07-10 07:35:54 +02:00
/** @var User $user */
$user = $event->eloquent;
$alternative = User::where('email', $user->email)->where('id', '!=', $user->id)->first();
if (null !== $alternative) {
2021-07-17 17:26:12 +02:00
Log::debug(sprintf('User #%d is created but user #%d already exists.', $user->id, $alternative->id));
2021-07-10 07:35:54 +02:00
$alternative->objectguid = $user->objectguid;
$alternative->domain = $user->domain;
$alternative->save();
$user->delete();
auth()->logout();
}
}
2021-07-10 15:54:49 +02:00
}