Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
S
syncEnrollments
Project
Project
Details
Activity
Releases
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Yeray Santana Hualde
syncEnrollments
Commits
60f61f31
Commit
60f61f31
authored
May 01, 2012
by
Taylor Otwell
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
refactored authentication system.
parent
c49e1964
Changes
4
Show whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
221 additions
and
167 deletions
+221
-167
auth.php
laravel/auth.php
+47
-162
driver.php
laravel/auth/drivers/driver.php
+36
-5
eloquent.php
laravel/auth/drivers/eloquent.php
+74
-0
fluent.php
laravel/auth/drivers/fluent.php
+64
-0
No files found.
laravel/auth.php
View file @
60f61f31
...
...
@@ -3,214 +3,99 @@
class
Auth
{
/**
* The current
user of the application
.
* The current
ly active authentication drivers
.
*
* @var
object
* @var
array
*/
public
static
$
user
;
public
static
$
drivers
=
array
()
;
/**
* The
key used when storing the user ID in the session
.
* The
third-party driver registrar
.
*
* @var
string
* @var
array
*/
const
user_key
=
'laravel_user_id'
;
public
static
$registrar
=
array
()
;
/**
*
Determine if the user of the application is not logged in
.
*
Get an authentication driver instance
.
*
* This method is the inverse of the "check" method.
*
* @return bool
*/
public
static
function
guest
()
{
return
!
static
::
check
();
}
/**
* Determine if the user of the application is logged in.
*
* @return bool
*/
public
static
function
check
()
{
return
!
is_null
(
static
::
user
());
}
/**
* Get the current user of the application.
*
* <code>
* // Get the current user of the application
* $user = Auth::user();
*
* // Access a property on the current user of the application
* $email = Auth::user()->email;
* </code>
*
* @return object|null
* @param string $driver
* @return Driver
*/
public
static
function
user
(
)
public
static
function
driver
(
$driver
=
null
)
{
if
(
!
is_null
(
static
::
$user
))
return
static
::
$user
;
$id
=
Session
::
get
(
Auth
::
user_key
);
if
(
is_null
(
$driver
))
$driver
=
Config
::
get
(
'auth.driver'
);
// To retrieve the user, we'll first attempt to use the "user" Closure
// defined in the auth configuration file, passing in the ID. The user
// Closure gives the developer a ton of freedom surrounding how the
// user is actually retrieved.
$config
=
Config
::
get
(
'auth'
);
static
::
$user
=
call_user_func
(
$config
[
'user'
],
$id
);
// If the user wasn't found in the database but a "remember me" cookie
// exists, we'll attempt to recall the user based on the cookie value.
// Since all cookies contain a fingerprint hash verifying that they
// haven't changed, we can trust it.
$recaller
=
Cookie
::
get
(
$config
[
'cookie'
]);
if
(
is_null
(
static
::
$user
)
and
!
is_null
(
$recaller
))
if
(
!
isset
(
static
::
$drivers
[
$driver
]))
{
static
::
$
user
=
static
::
recall
(
$recall
er
);
static
::
$
drivers
[
$driver
]
=
static
::
factory
(
$driv
er
);
}
return
static
::
$
user
;
return
static
::
$
drivers
[
$driver
]
;
}
/**
*
Attempt to login a user based on a long-lived "remember me" cooki
e.
*
Create a new authentication driver instanc
e.
*
* @param string $
recall
er
* @return
mixed
* @param string $
driv
er
* @return
Driver
*/
protected
static
function
recall
(
$recall
er
)
protected
static
function
factory
(
$driv
er
)
{
$recaller
=
explode
(
'|'
,
Crypter
::
decrypt
(
$recaller
));
// We'll pass the ID that was stored in the cookie into the same user
// Closure that is used by the "user" method. If the method returns
// a user, we will log them into the application.
$user
=
call_user_func
(
Config
::
get
(
'auth.user'
),
$recaller
[
0
]);
if
(
!
is_null
(
$user
))
if
(
isset
(
static
::
$registrar
[
$driver
]))
{
static
::
login
(
$user
);
return
$user
;
}
return
static
::
$registrar
[
$driver
]();
}
/**
* Attempt to log a user into the application.
*
* <code>
* // Attempt to log a user into the application
* $success = Auth::attempt('username', 'password');
*
* // Attempt to login a user and set the "remember me" cookie
* Auth::attempt('username', 'password', true);
* </code>
*
* @param string $username
* @param string $password
* @param bool $remember
* @return bool
*/
public
static
function
attempt
(
$username
,
$password
=
null
,
$remember
=
false
)
switch
(
$driver
)
{
$config
=
Config
::
get
(
'auth'
);
// When attempting to login the user, we will call the "attempt" closure
// from the configuration file. This gives the developer the freedom to
// authenticate based on the needs of their application, even allowing
// the user of third-party providers.
$user
=
call_user_func
(
$config
[
'attempt'
],
$username
,
$password
);
case
'fluent'
:
return
new
Auth\Drivers\Fluent
(
Config
::
get
(
'auth.table'
));
if
(
is_null
(
$user
))
return
false
;
case
'eloquent'
:
return
new
Auth\Drivers\Eloquent
(
Config
::
get
(
'auth.model'
));
static
::
login
(
$user
,
$remember
);
return
true
;
default
:
throw
new
\Exception
(
"Auth driver
{
$driver
}
is not supported."
);
}
}
/**
* Log a user into the application.
*
* <code>
* // Login the user with an ID of 15
* Auth::login(15);
* Run the logout method on all active drivers.
*
* // Login a user by passing a user object
* Auth::login($user);
*
* // Login a user and set a "remember me" cookie
* Auth::login($user, true);
* </code>
*
* @param object|int $user
* @param bool $remember
* @return void
*/
public
static
function
log
in
(
$user
,
$remember
=
false
)
public
static
function
log
out
(
)
{
$id
=
(
is_object
(
$user
))
?
$user
->
id
:
(
int
)
$user
;
if
(
$remember
)
static
::
remember
(
$id
);
Session
::
put
(
Auth
::
user_key
,
$id
);
array_walk
(
static
::
$drivers
,
function
(
$d
)
{
$d
->
logout
();
});
}
/**
*
Set a cookie so that the user is "remembered"
.
*
Register a third-party authentication driver
.
*
* @param string $id
* @param string $driver
* @param Closure $resolver
* @return void
*/
p
rotected
static
function
remember
(
$id
)
p
ublic
static
function
extend
(
$driver
,
Closure
$resolver
)
{
$recaller
=
Crypter
::
encrypt
(
$id
.
'|'
.
Str
::
random
(
40
));
// This method assumes the "remember me" cookie should have the same
// configuration as the session cookie. Since this cookie, like the
// session cookie, should be kept very secure, it's probably safe.
// to assume the cookie settings are the same.
$config
=
Config
::
get
(
'session'
);
extract
(
$config
,
EXTR_SKIP
);
$cookie
=
Config
::
get
(
'auth.cookie'
);
Cookie
::
forever
(
$cookie
,
$recaller
,
$path
,
$domain
,
$secure
);
static
::
$registrar
[
$driver
]
=
$resolver
;
}
/**
*
Log the current user out of the application
.
*
Magic Method for calling the methods on the default cache driver
.
*
* @return void
* <code>
* // Call the "user" method on the default auth driver
* $user = Auth::user();
*
* // Call the "check" method on the default auth driver
* Auth::check();
* </code>
*/
public
static
function
logout
(
)
public
static
function
__callStatic
(
$method
,
$parameters
)
{
// We will call the "logout" closure first, which gives the developer
// the chance to do any clean-up or before the user is logged out of
// the application. No action is taken by default.
call_user_func
(
Config
::
get
(
'auth.logout'
),
static
::
user
());
static
::
$user
=
null
;
$config
=
Config
::
get
(
'session'
);
extract
(
$config
,
EXTR_SKIP
);
// When forgetting the cookie, we need to also pass in the path and
// domain that would have been used when the cookie was originally
// set by the framework, otherwise it will not be deleted.
$cookie
=
Config
::
get
(
'auth.cookie'
);
Cookie
::
forget
(
$cookie
,
$path
,
$domain
,
$secure
);
Session
::
forget
(
Auth
::
user_key
);
return
call_user_func_array
(
array
(
static
::
driver
(),
$method
),
$parameters
);
}
}
\ No newline at end of file
laravel/auth/drivers/driver.php
View file @
60f61f31
<?php
namespace
Laravel\Auth\
Login\
Drivers
;
<?php
namespace
Laravel\Auth\Drivers
;
use
Laravel\Str
;
use
Laravel\Cookie
;
...
...
@@ -41,6 +41,18 @@ abstract class Driver {
}
}
/**
* Determine if the user of the application is not logged in.
*
* This method is the inverse of the "check" method.
*
* @return bool
*/
public
function
guest
()
{
return
!
$this
->
check
();
}
/**
* Determine if the user is logged in.
*
...
...
@@ -58,15 +70,28 @@ abstract class Driver {
*
* @return mixed|null
*/
abstract
public
function
user
();
public
function
user
()
{
if
(
!
is_null
(
$this
->
user
))
return
$this
->
user
;
return
$this
->
user
=
$this
->
retrieve
(
$this
->
token
);
}
/**
* Get the a given application user by ID.
*
* @param int $id
* @return mixed
*/
abstract
public
function
retrieve
(
$id
);
/**
* Attempt to log a user into the application.
*
* @param
dynamic
$arguments
* @param
array
$arguments
* @return void
*/
abstract
public
function
attempt
();
abstract
public
function
attempt
(
$arguments
=
array
()
);
/**
* Login the user assigned to the given token.
...
...
@@ -74,10 +99,16 @@ abstract class Driver {
* The token is typically a numeric ID for the user.
*
* @param string $token
* @param bool $remember
* @return bool
*/
public
function
login
(
$token
)
public
function
login
(
$token
,
$remember
=
false
)
{
$this
->
store
(
$token
);
if
(
$remember
)
$this
->
remember
(
$token
);
return
true
;
}
/**
...
...
laravel/auth/drivers/eloquent.php
0 → 100644
View file @
60f61f31
<?php
namespace
Laravel\Auth\Drivers
;
use
User
,
Laravel\Hash
;
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.
*
* If the user is a guest, null should be returned.
*
* @param int $id
* @return mixed|null
*/
public
function
retrieve
(
$id
)
{
if
(
filter_var
(
$id
,
FILTER_VALIDATE_INT
)
!==
false
)
{
return
$this
->
model
()
->
find
(
$id
);
}
}
/**
* Attempt to log a user into the application.
*
* @param array $arguments
* @return void
*/
public
function
attempt
(
$arguments
=
array
())
{
$user
=
$this
->
model
()
->
where
(
'email'
,
'='
,
$arguments
[
'email'
])
->
first
();
// This driver uses a basic username and password authentication scheme
// so if the credentials match what is in the database we will just
// log the user into the application and remember them if asked.
$password
=
$arguments
[
'password'
];
if
(
!
is_null
(
$user
)
and
Hash
::
check
(
$password
,
$user
->
password
))
{
return
$this
->
login
(
$user
->
id
,
array_get
(
$arguments
,
'remember'
));
}
return
false
;
}
/**
* Get a fresh model instance.
*
* @return Eloquent
*/
protected
function
model
()
{
return
new
$this
->
model
;
}
}
\ No newline at end of file
laravel/auth/drivers/fluent.php
0 → 100644
View file @
60f61f31
<?php
namespace
Laravel\Auth\Drivers
;
use
Laravel\Hash
,
Laravel\Database
;
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.
*
* If the user is a guest, null should be returned.
*
* @param int $id
* @return mixed|null
*/
public
function
retrieve
(
$id
)
{
if
(
filter_var
(
$id
,
FILTER_VALIDATE_INT
)
!==
false
)
{
Database
::
table
(
$this
->
table
)
->
find
(
$id
);
}
}
/**
* Attempt to log a user into the application.
*
* @param array $arguments
* @return void
*/
public
function
attempt
(
$arguments
=
array
())
{
$user
=
Database
::
table
(
$this
->
table
)
->
where_email
(
$arguments
[
'email'
])
->
first
();
// This driver uses a basic username and password authentication scheme
// so if the credentials mmatch what is in the database we will just
// log the user into the application and remember them if asked.
$password
=
$arguments
[
'password'
];
if
(
!
is_null
(
$user
)
and
Hash
::
check
(
$password
,
$user
->
password
))
{
return
$this
->
login
(
$user
->
id
,
array_get
(
$arguments
,
'remember'
));
}
return
false
;
}
}
\ No newline at end of file
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment