. */ $skip_permissions = true; include_once __DIR__.'/core.php'; use Models\User; use Modules\Emails\Mail; use Modules\Emails\Template; use Notifications\EmailNotification; $token = get('reset_token'); switch (post('op')) { case 'reset': $username = post('username'); $email = post('email'); $database->insert('zz_logs', [ 'username' => $username, 'ip' => get_client_ip(), 'stato' => Auth::getStatus()['failed']['code'], ]); try { $utente = User::where('username', $username)->where('email', $email)->first(); if (!empty($utente)) { $utente->reset_token = secure_random_string(); $utente->save(); $template = Template::pool('Reset password'); $mail = Mail::build($utente, $template, $utente->id); $mail->addReceiver($utente->email); $mail->save(); $email = EmailNotification::build($mail); $email->send(); } flash()->info(tr("Se le informazioni inserite corrispondono ai dati di un utente, riceverai a breve un'email all'indirizzo collegato").'.'); } catch (Exception $e) { flash()->error(tr("Errore durante la gestione della richiesta: si prega di contattare l'amministratore").'.'); } redirect(base_link().'/index.php'); exit(); break; case 'update': $password = post('password'); $utente = User::where('reset_token', $token)->first(); if (!empty($utente)) { $utente->password = $password; $utente->reset_token = null; $utente->save(); } flash()->info(tr('Password cambiata!')); redirect(base_link().'/index.php'); exit(); break; } $pageTitle = tr('Reimpostazione password'); include_once App::filepath('include|custom|', 'top.php'); // Controllo se è una beta e in caso mostro un warning if (Auth::isBrute()) { echo '
'.tr('Sono stati effettuati troppi tentativi di accesso consecutivi!').'
'.tr('Tempo rimanente (in secondi)').': '.(Auth::getBruteTimeout() + 1).'