Commit f050f773 authored by Taylor Otwell's avatar Taylor Otwell

Refactoring some auth code.

parent de7046cc
...@@ -18,6 +18,19 @@ return array( ...@@ -18,6 +18,19 @@ return array(
'driver' => 'eloquent', 'driver' => 'eloquent',
/*
|--------------------------------------------------------------------------
| Authentication Username
|--------------------------------------------------------------------------
|
| Here you may specify the database column that should be considered the
| "username" for your users. Typically, this will either be "usenrame"
| or "email". Of course, you're free to change the value to anything.
|
*/
'username' => 'email',
/* /*
|-------------------------------------------------------------------------- |--------------------------------------------------------------------------
| Authentication Model | Authentication Model
......
<?php namespace Laravel\Auth\Drivers; use User, Laravel\Hash; <?php namespace Laravel\Auth\Drivers; use Laravel\Hash, Laravel\Config;
class Eloquent extends Driver { class Eloquent extends Driver {
/**
* The name of the "User" model used by the application.
*
* @var string
*/
public $model;
/**
* Create a new Eloquent authentication driver.
*
* @param string $model
* @return void
*/
public function __construct($model)
{
$this->model = $model;
parent::__construct();
}
/** /**
* Get the current user of the application. * Get the current user of the application.
* *
...@@ -46,7 +26,9 @@ class Eloquent extends Driver { ...@@ -46,7 +26,9 @@ class Eloquent extends Driver {
*/ */
public function attempt($arguments = array()) public function attempt($arguments = array())
{ {
$user = $this->model()->where('email', '=', $arguments['email'])->first(); $username = Config::get('auth.username');
$user = $this->model()->where($username, '=', $arguments['username'])->first();
// This driver uses a basic username and password authentication scheme // This driver uses a basic username and password authentication scheme
// so if the credentials match what is in the database we will just // so if the credentials match what is in the database we will just
...@@ -68,7 +50,9 @@ class Eloquent extends Driver { ...@@ -68,7 +50,9 @@ class Eloquent extends Driver {
*/ */
protected function model() protected function model()
{ {
return new $this->model; $model = Config::get('auth.model');
return new $model;
} }
} }
\ No newline at end of file
<?php namespace Laravel\Auth\Drivers; use Laravel\Hash, Laravel\Database; <?php namespace Laravel\Auth\Drivers; use Laravel\Hash, Laravel\Database as DB;
class Fluent extends Driver { class Fluent extends Driver {
/**
* The "users" table used by the application.
*
* @var string
*/
public $table;
/**
* Create a new fluent authentication driver.
*
* @param string $table
* @return void
*/
public function __construct($table)
{
$this->table = $table;
parent::__construct();
}
/** /**
* Get the current user of the application. * Get the current user of the application.
* *
...@@ -34,7 +14,7 @@ class Fluent extends Driver { ...@@ -34,7 +14,7 @@ class Fluent extends Driver {
{ {
if (filter_var($id, FILTER_VALIDATE_INT) !== false) if (filter_var($id, FILTER_VALIDATE_INT) !== false)
{ {
Database::table($this->table)->find($id); DB::table(Config::get('auth.table'))->find($id);
} }
} }
...@@ -46,7 +26,7 @@ class Fluent extends Driver { ...@@ -46,7 +26,7 @@ class Fluent extends Driver {
*/ */
public function attempt($arguments = array()) public function attempt($arguments = array())
{ {
$user = Database::table($this->table)->where_email($arguments['email'])->first(); $user = $this->get_user($arguments['username']);
// This driver uses a basic username and password authentication scheme // This driver uses a basic username and password authentication scheme
// so if the credentials mmatch what is in the database we will just // so if the credentials mmatch what is in the database we will just
...@@ -61,4 +41,19 @@ class Fluent extends Driver { ...@@ -61,4 +41,19 @@ class Fluent extends Driver {
return false; return false;
} }
/**
* Get the user from the database table by username.
*
* @param mixed $value
* @return mixed
*/
protected function get_user($value)
{
$table = Config::get('auth.table');
$username = Config::get('auth.username');
return DB::table($table)->where($username, '=', $value)->first();
}
} }
\ No newline at end of file
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment