* @copyright 2001 - 2011 Ampache.org * @license http://opensource.org/licenses/gpl-2.0 GPLv2 * @version PHP 5.2 * @link http://www.ampache.org/ * @since File available since Release 1.0 */ define('NO_SESSION','1'); require_once 'lib/init.php'; $action = (isset($_POST['action'])) ? $_POST['action'] : ""; switch ($action) { case 'send': /* Check for posted email */ $result = false; if (isset($_POST['email']) && $_POST['email']) { /* Get the email address and the current ip*/ $email = scrub_in($_POST['email']); $current_ip =(isset($_SERVER['HTTP_X_FORWARDED_FOR'])) ? $_SERVER['HTTP_X_FORWARDED_FOR'] :$_SERVER['REMOTE_ADDR']; $result = send_newpassword($email, $current_ip); } if ($result) { Error::add('general', _('Password has been sent')); } else { Error::add('general', _('Password has not been sent')); } require Config::get('prefix') . '/templates/show_login_form.inc.php'; break; default: require Config::get('prefix') . '/templates/show_lostpassword_form.inc.php'; } function send_newpassword($email,$current_ip){ /* get the Client and set the new password */ $client = User::get_from_email($email); if ($client->email == $email) { $newpassword = generate_password(6); $client->update_password($newpassword); $mailer = new AmpacheMail(); $mailer->set_default_sender(); $mailer->subject = _("Lost Password"); $mailer->recipient_name = $client->fullname; $mailer->recipient = $client->email; $message = sprintf(_("A user from %s has requested a password reset for '%s'."), $current_ip, $client->username); $message .= "\n"; $message .= sprintf(_("The password has been set to: %s"), $newpassword); $mailer->message = $message; return $mailer->send(); } return false; } ?>