firefly-iii/app/controllers/UserController.php

182 lines
4.3 KiB
PHP
Raw Normal View History

<?php
2014-07-15 15:16:29 -05:00
/**
* Class UserController
*/
class UserController extends BaseController
{
/**
* Constructor.
*/
public function __construct()
{
}
/**
* Show the login view.
*
* @return \Illuminate\View\View
*/
public function login()
{
return View::make('user.login');
}
2014-11-12 15:36:02 -06:00
/**
* Logout user.
*
* @return \Illuminate\Http\RedirectResponse
*/
public function logout()
{
Auth::logout();
Session::flush();
return Redirect::route('index');
}
/**
* Login.
*
* @return \Illuminate\Http\RedirectResponse|\Illuminate\View\View
*/
public function postLogin()
{
$rememberMe = Input::get('remember_me') == '1';
2014-11-12 15:36:02 -06:00
$data = ['email' => Input::get('email'), 'password' => Input::get('password')];
$result = Auth::attempt($data, $rememberMe);
if ($result) {
return Redirect::route('index');
}
2014-07-28 14:33:32 -05:00
Session::flash('error', 'No good!');
return View::make('user.login');
}
/**
* If allowed, register the user.
*
* Then:
*
* - Send password OR
* - Send reset code.
*
* @return $this|\Illuminate\View\View
*/
public function postRegister()
{
if (Config::get('auth.allow_register') !== true) {
return View::make('error')->with('message', 'Not possible');
}
2014-12-15 13:24:19 -06:00
/** @var \FireflyIII\Database\User\User $repository */
$repository = App::make('FireflyIII\Database\User\User');
/** @var \FireflyIII\Shared\Mail\RegistrationInterface $email */
$email = App::make('FireflyIII\Shared\Mail\RegistrationInterface');
$user = $repository->register(Input::all());
//$user = $this->user->register(Input::all());
if ($user) {
if (Config::get('auth.verify_mail') === true) {
$email->sendVerificationMail($user);
2014-07-28 14:33:32 -05:00
return View::make('user.verification-pending');
}
$email->sendPasswordMail($user);
2014-07-28 14:33:32 -05:00
return View::make('user.registered');
}
2014-07-28 14:33:32 -05:00
2014-12-06 14:48:23 -06:00
return View::make('user.register');
}
/**
* If need to verify, send new reset code.
* Otherwise, send new password.
*
* @return \Illuminate\View\View
*/
public function postRemindme()
{
2014-12-15 13:24:19 -06:00
/** @var \FireflyIII\Database\User\User $repository */
$repository = App::make('FireflyIII\Database\User\User');
/** @var \FireflyIII\Shared\Mail\RegistrationInterface $email */
$email = App::make('FireflyIII\Shared\Mail\RegistrationInterface');
$user = $repository->findByEmail(Input::get('email'));
if (!$user) {
Session::flash('error', 'No good!');
2014-07-28 14:33:32 -05:00
return View::make('user.remindme');
}
if (Config::get('auth.verify_reset') === true) {
$email->sendResetVerification($user);
2014-07-28 14:33:32 -05:00
return View::make('user.verification-pending');
}
$email->sendPasswordMail($user);
2014-07-28 14:33:32 -05:00
return View::make('user.registered');
}
2014-11-12 15:36:02 -06:00
/**
* If allowed, show the register form.
*
* @return $this|\Illuminate\View\View
*/
public function register()
{
if (Config::get('auth.allow_register') !== true) {
return View::make('error')->with('message', 'Not possible');
}
return View::make('user.register');
}
/**
* Show form to help user get a new password.
*
* @return \Illuminate\View\View
*/
public function remindme()
{
return View::make('user.remindme');
}
/**
* Send a user a password based on his reset code.
*
* @param $reset
*
* @return $this|\Illuminate\View\View
*/
public function reset($reset)
{
2014-12-15 13:24:19 -06:00
/** @var \FireflyIII\Database\User\User $repository */
$repository = App::make('FireflyIII\Database\User\User');
/** @var \FireflyIII\Shared\Mail\RegistrationInterface $email */
$email = App::make('FireflyIII\Shared\Mail\RegistrationInterface');
$user = $repository->findByReset($reset);
if ($user) {
$email->sendPasswordMail($user);
2014-07-28 14:33:32 -05:00
return View::make('user.registered');
}
2014-07-28 14:33:32 -05:00
return View::make('error')->with('message', 'Yo no hablo reset code!');
}
}