FirstLogin.php 5.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189
  1. <?php
  2. namespace App\Http\Livewire;
  3. use Illuminate\Support\Facades\Auth;
  4. use Illuminate\Support\Facades\Hash;
  5. use Illuminate\Support\Facades\DB;
  6. use Illuminate\Support\Facades\Log;
  7. use Livewire\Component;
  8. use App\Http\Middleware\TenantMiddleware;
  9. use Illuminate\Support\Facades\Mail;
  10. class FirstLogin extends Component
  11. {
  12. // Component properties
  13. public $name;
  14. public $cognome;
  15. public $email;
  16. public $telefono;
  17. public $cellulare;
  18. public $password;
  19. public $password_confirmation;
  20. public $isLoading = false; // Make sure this is defined
  21. protected $rules = [
  22. 'password' => 'required|min:6|confirmed',
  23. 'password_confirmation' => 'required|min:6',
  24. ];
  25. protected $messages = [
  26. 'password.required' => 'La password è obbligatoria',
  27. 'password.min' => 'La password deve essere di almeno 6 caratteri',
  28. 'password.confirmed' => 'Le password non coincidono',
  29. 'password_confirmation.required' => 'Conferma la password',
  30. ];
  31. public function boot()
  32. {
  33. app(TenantMiddleware::class)->setupTenantConnection();
  34. }
  35. public function mount()
  36. {
  37. $currentUser = Auth::user();
  38. if ($currentUser->first_login_completed) {
  39. return redirect('/dashboard');
  40. }
  41. $user = \App\Models\User::findOrFail($currentUser->id);
  42. $this->name = $user->name ?? '';
  43. $this->cognome = $user->cognome ?? '';
  44. $this->email = $user->email ?? '';
  45. $this->telefono = $user->telefono ?? '';
  46. $this->cellulare = $user->cellulare ?? '';
  47. }
  48. public function completeProfile()
  49. {
  50. $this->isLoading = true;
  51. $this->validate();
  52. $currentUser = Auth::user();
  53. try {
  54. DB::beginTransaction();
  55. $user = \App\Models\User::findOrFail($currentUser->id);
  56. $oldEmail = $user->email;
  57. $user->password = Hash::make($this->password);
  58. $user->first_login_completed = true;
  59. $user->email_verified_at = now();
  60. $user->save();
  61. $this->updateMasterDatabase($currentUser, $oldEmail);
  62. DB::commit();
  63. $this->sendAccountActivationEmail($user);
  64. session()->flash('success', 'Profilo completato con successo! Benvenuto in Leezard.cloud.');
  65. $this->isLoading = false;
  66. return redirect('/dashboard');
  67. } catch (\Exception $e) {
  68. DB::rollback();
  69. Log::error('First login profile completion failed', [
  70. 'user_id' => $currentUser->id,
  71. 'error' => $e->getMessage(),
  72. 'trace' => $e->getTraceAsString()
  73. ]);
  74. $this->isLoading = false;
  75. session()->flash('error', 'Errore durante il completamento del profilo: ' . $e->getMessage());
  76. }
  77. }
  78. private function updateMasterDatabase($currentUser, $oldEmail)
  79. {
  80. try {
  81. $masterConfig = [
  82. 'driver' => 'mysql',
  83. 'host' => env('DB_HOST', '127.0.0.1'),
  84. 'port' => env('DB_PORT', '3306'),
  85. 'database' => env('DB_DATABASE'),
  86. 'username' => env('DB_USERNAME'),
  87. 'password' => env('DB_PASSWORD'),
  88. 'charset' => 'utf8mb4',
  89. 'collation' => 'utf8mb4_unicode_ci',
  90. 'prefix' => '',
  91. 'strict' => true,
  92. 'engine' => null,
  93. ];
  94. config(['database.connections.master_temp' => $masterConfig]);
  95. $updateData = [
  96. 'password' => Hash::make($this->password),
  97. 'first_login_completed' => true,
  98. 'email_verified_at' => now(),
  99. 'updated_at' => now()
  100. ];
  101. $updated = DB::connection('master_temp')
  102. ->table('users')
  103. ->where('email', $oldEmail)
  104. ->update($updateData);
  105. if ($updated) {
  106. Log::info('Successfully updated user in master database during first login', [
  107. 'old_email' => $oldEmail,
  108. 'new_email' => $this->email
  109. ]);
  110. }
  111. DB::purge('master_temp');
  112. } catch (\Exception $e) {
  113. Log::error('Failed to update master database during first login', [
  114. 'error' => $e->getMessage(),
  115. 'user_id' => $currentUser->id,
  116. 'old_email' => $oldEmail,
  117. 'new_email' => $this->email
  118. ]);
  119. throw $e;
  120. }
  121. }
  122. private function sendAccountActivationEmail($user)
  123. {
  124. try {
  125. $emailData = [
  126. 'name' => $user->name,
  127. 'email' => $user->email,
  128. 'login_url' => url('/'),
  129. 'activation_time' => now()->format('d/m/Y H:i'),
  130. 'platform_name' => 'Leezard.cloud'
  131. ];
  132. Mail::send('emails.account-activated', $emailData, function ($message) use ($user) {
  133. $message->to($user->email, $user->name)
  134. ->subject('Il tuo account è attivo – Benvenuto in Leezard.cloud')
  135. ->from(config('mail.from.address'), config('mail.from.name'));
  136. });
  137. Log::info('Account activation email sent after first login completion', [
  138. 'user_id' => $user->id,
  139. 'email' => $user->email
  140. ]);
  141. } catch (\Exception $e) {
  142. Log::error('Failed to send account activation email', [
  143. 'user_id' => $user->id,
  144. 'email' => $user->email,
  145. 'error' => $e->getMessage()
  146. ]);
  147. }
  148. }
  149. public function render()
  150. {
  151. return view('livewire.first-login');
  152. }
  153. }