
* #84 - fix remembering user * #84 - ecs fix * #84 - fix * #84 - fix test * #84 - wip * #84 - add comment to observer * #84 - cr fix * Apply suggestions from code review Co-authored-by: Krzysztof Rewak <krzysztof.rewak@blumilk.pl> * #84 - cr fix Co-authored-by: Krzysztof Rewak <krzysztof.rewak@blumilk.pl>
38 lines
953 B
PHP
38 lines
953 B
PHP
<?php
|
|
|
|
declare(strict_types=1);
|
|
|
|
namespace Toby\Eloquent\Observers;
|
|
|
|
use Illuminate\Contracts\Hashing\Hasher;
|
|
use Illuminate\Support\Str;
|
|
use Toby\Eloquent\Models\User;
|
|
use Toby\Eloquent\Models\YearPeriod;
|
|
|
|
class UserObserver
|
|
{
|
|
public function __construct(
|
|
protected Hasher $hash,
|
|
) {}
|
|
|
|
public function creating(User $user): void
|
|
{
|
|
/**
|
|
* A random password for user is generated because AuthenticateSession middleware needs a user's password
|
|
* for some checks. Users use Google to login, so they don't need to know the password (GitHub issue #84)
|
|
*/
|
|
$user->password = $this->hash->make(Str::random(40));
|
|
}
|
|
|
|
public function created(User $user): void
|
|
{
|
|
$yearPeriods = YearPeriod::all();
|
|
|
|
foreach ($yearPeriods as $yearPeriod) {
|
|
$user->vacationLimits()->create([
|
|
"year_period_id" => $yearPeriod->id,
|
|
]);
|
|
}
|
|
}
|
|
}
|