public function testGarbageCollection()
 {
     $testPasswordResetToken = UserPasswordResetTokenTest::createOldTestPasswordResetToken();
     $user = $testPasswordResetToken->getUser();
     self::$entityManager->persist($user->getRole());
     self::$entityManager->persist($user);
     self::$entityManager->flush();
     UserPasswordResetTokenService::create($testPasswordResetToken);
     $tokens = self::$entityManager->createQuery('SELECT e FROM Rexmac\\Zyndax\\Entity\\UserPasswordResetToken e')->execute();
     $this->assertEquals(1, count($tokens));
     UserPasswordResetTokenService::collectGarbage();
     $tokens = self::$entityManager->createQuery('SELECT e FROM Rexmac\\Zyndax\\Entity\\UserPasswordResetToken e')->execute();
     $this->assertEquals(0, count($tokens));
 }
Пример #2
0
    /**
     * Send password reset email to user
     *
     * @param User $user
     * @param Zend_Mail_Transport_Abstract $transport [Optional] Zend mail transport class
     * @return void
     */
    public static function sendPasswordResetEmail(User $user, Zend_Mail_Transport_Abstract $transport = null)
    {
        $serverUrlHelper = new Zend_View_Helper_ServerUrl();
        $urlHelper = HelperBroker::getStaticHelper('url');
        $siteDomain = preg_replace('/^https?:\\/\\//', '', $serverUrlHelper->serverUrl());
        $siteName = Zend_Registry::get('siteName');
        $config = Zend_Registry::get('config');
        $from = 'noreply@' . $siteDomain;
        if (!empty($config->mail) && !empty($config->mail->from)) {
            $from = $config->mail->from;
        }
        if (null === $transport) {
            if (Zend_Session::$_unitTestEnabled) {
                $transport = new MockMailTransport();
            } else {
                if (!empty($config->mail) && !empty($config->mail->smtp) && !empty($config->mail->smtp->host)) {
                    $options = $config->mail->smtp->toArray();
                    unset($options['host']);
                    $transport = new Zend_Mail_Transport_Smtp($config->mail->smtp->host, $options);
                }
            }
        }
        UserPasswordResetTokenService::collectGarbage();
        // @todo cronjob?
        $resetToken = sha1(mt_rand() . $user->getEmail() . mt_rand());
        if (APPLICATION_ENV === 'testing') {
            $resetLink = $serverUrlHelper->serverUrl() . '/resetPassword/' . $resetToken;
        } else {
            // @codeCoverageIgnoreStart
            $resetLink = $serverUrlHelper->serverUrl() . $urlHelper->url(array('token' => $resetToken), 'resetPassword');
        }
        // @codeCoverageIgnoreEnd
        // Clear any existing tokens
        UserPasswordResetTokenService::clearTokensForUser($user);
        // Generate a new token
        UserPasswordResetTokenService::create(new UserPasswordResetToken(array('user' => $user, 'token' => $resetToken, 'requestDate' => new DateTime())));
        $text = 'Hello ' . $user->getUsername() . ',
We recently received a request to reset your password.

Please use the following link within the next 24 hours to reset your password.

' . $resetLink . '

If you did not request to have your password reset, then please ignore this message.

Thank you,
The ' . $siteName . ' Team
';
        $html = '<p>Hello ' . $user->getUsername() . ',</p>
<p>We recently received a request to reset your password.</p>

<p>Please use the following link within the next 24 hours to reset your password.</p>

<p><a href="' . $resetLink . '" title="Reset your password">' . $resetLink . '</a></p>

<p>If you did not request to have your password reset, then please ignore this message.</p>

<p>Thank you,<br>
The ' . $siteName . ' Team</p>
';
        try {
            Logger::info('Attempting to send email to \'' . $user->getEmail() . '\'.');
            $mail = new Zend_Mail('utf-8');
            $mail->setFrom($from, $siteName)->setSubject('[' . $siteName . '] Lost password')->setBodyText($text)->setBodyHtml($html)->addTo($user->getEmail());
            $mail->send($transport);
        } catch (Exception $e) {
            Logger::crit($e->getMessage());
            throw $e;
        }
    }