2014-06-29 15:12:33 -05:00
|
|
|
<?php
|
|
|
|
|
|
|
|
use Firefly\Helper\Email\EmailHelperInterface as EHI;
|
|
|
|
use Firefly\Storage\User\UserRepositoryInterface as URI;
|
|
|
|
|
|
|
|
class UserController extends BaseController
|
|
|
|
{
|
|
|
|
|
|
|
|
public function __construct(URI $user, EHI $email)
|
|
|
|
{
|
|
|
|
$this->user = $user;
|
|
|
|
$this->email = $email;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
public function login()
|
|
|
|
{
|
|
|
|
return View::make('user.login');
|
|
|
|
}
|
|
|
|
|
|
|
|
public function postLogin()
|
|
|
|
{
|
2014-07-02 16:12:31 -05:00
|
|
|
$rememberMe = Input::get('remember_me') == '1';
|
|
|
|
$data = [
|
|
|
|
'email' => Input::get('email'),
|
|
|
|
'password' => Input::get('password')
|
|
|
|
];
|
|
|
|
if (Auth::attempt($data, $rememberMe)) {
|
2014-07-02 16:31:59 -05:00
|
|
|
Session::flash('success', 'Logged in!');
|
2014-07-02 16:12:31 -05:00
|
|
|
return Redirect::route('index');
|
2014-06-29 15:12:33 -05:00
|
|
|
}
|
|
|
|
Session::flash('error', 'No good!');
|
|
|
|
return View::make('user.login');
|
|
|
|
}
|
|
|
|
|
|
|
|
public function register()
|
|
|
|
{
|
|
|
|
if (Config::get('auth.allow_register') !== true) {
|
2014-07-02 16:31:59 -05:00
|
|
|
App::abort(404);
|
2014-06-29 15:12:33 -05:00
|
|
|
}
|
|
|
|
return View::make('user.register');
|
|
|
|
}
|
|
|
|
|
|
|
|
public function postRegister()
|
|
|
|
{
|
|
|
|
if (Config::get('auth.allow_register') !== true) {
|
2014-07-02 16:31:59 -05:00
|
|
|
App::abort(404);
|
2014-06-29 15:12:33 -05:00
|
|
|
}
|
2014-07-02 16:12:31 -05:00
|
|
|
$user = $this->user->register(Input::all());
|
2014-06-29 15:12:33 -05:00
|
|
|
if ($user) {
|
|
|
|
if (Config::get('auth.verify_mail') === true) {
|
|
|
|
$this->email->sendVerificationMail($user);
|
|
|
|
return View::make('user.verification-pending');
|
|
|
|
}
|
|
|
|
$this->email->sendPasswordMail($user);
|
|
|
|
return View::make('user.registered');
|
|
|
|
}
|
|
|
|
return View::make('user.register');
|
|
|
|
}
|
|
|
|
|
2014-06-30 00:26:38 -05:00
|
|
|
public function logout()
|
|
|
|
{
|
|
|
|
Auth::logout();
|
|
|
|
return Redirect::route('index');
|
|
|
|
}
|
|
|
|
|
|
|
|
public function remindme()
|
|
|
|
{
|
|
|
|
return View::make('user.remindme');
|
|
|
|
}
|
|
|
|
|
|
|
|
public function postRemindme()
|
|
|
|
{
|
|
|
|
$user = $this->user->findByEmail(Input::get('email'));
|
|
|
|
if ($user) {
|
|
|
|
if (Config::get('auth.verify_reset') === true) {
|
|
|
|
$this->email->sendResetVerification($user);
|
2014-07-03 01:50:21 -05:00
|
|
|
return View::make('user.verification-pending');
|
2014-06-30 00:26:38 -05:00
|
|
|
}
|
|
|
|
if (Config::get('auth.verify_reset') === false) {
|
|
|
|
$this->email->sendPasswordMail($user);
|
2014-07-03 01:50:21 -05:00
|
|
|
return View::make('user.registered');
|
2014-06-30 00:26:38 -05:00
|
|
|
}
|
|
|
|
}
|
|
|
|
Session::flash('error', 'No good!');
|
|
|
|
return View::make('user.remindme');
|
|
|
|
|
|
|
|
}
|
|
|
|
|
2014-06-29 15:12:33 -05:00
|
|
|
public function verify($verification)
|
|
|
|
{
|
|
|
|
$user = $this->user->findByVerification($verification);
|
|
|
|
if ($user) {
|
|
|
|
$this->email->sendPasswordMail($user);
|
|
|
|
return View::make('user.registered');
|
|
|
|
}
|
|
|
|
return View::make('error')->with('message', 'Yo no hablo verification code!');
|
|
|
|
}
|
2014-07-02 16:12:31 -05:00
|
|
|
|
2014-06-30 00:26:38 -05:00
|
|
|
public function reset($reset)
|
|
|
|
{
|
|
|
|
$user = $this->user->findByReset($reset);
|
|
|
|
if ($user) {
|
|
|
|
$this->email->sendPasswordMail($user);
|
|
|
|
return View::make('user.registered');
|
|
|
|
}
|
|
|
|
return View::make('error')->with('message', 'Yo no hablo reset code!');
|
|
|
|
}
|
2014-06-29 15:12:33 -05:00
|
|
|
|
2014-07-02 16:12:31 -05:00
|
|
|
}
|