triad-ltd / expauth
A Laravel authentication driver that supports Expression Engine's membership system. New users will default to Laravel's bcrypt encryption (extremely secure), but existing users who have registered using Expression Engine can also be authenticated. Also handles their reset password procedure.
Requires
- php: >=8.3.0
- laravel/framework: ^11.0
Requires (Dev)
- phpunit/phpunit: ^11.3.1
README
#Laravel Expression Engine User Authentication
Allows you to switch your Expression Engine website to Laravel, by handling the authentication of Expression Engine members. This package allows you to easily build a front end in Laravel for Expression Engine websites, without worrying about how existing members logins and registrations will work.
For Laravel 11 support, please use the 1.3.0 version.
What it does
Expression Engine uses a number of different hashing algorithms, such as SHA512, SHA256, SHA1 and even MD5 (shudder), whilst Laravel 5 uses the much more secure bcrypt.
This package will allow your existing Expression Engine members to log in with their existing login credentials, and new users can benefit from having their data hashed with the latest bcrypt algorithm.
Furthermore, once an Expression Engine user has logged in, it's very easy to switch them over to bcrypt encryption as the needsRehash()
method will always return true for Expression Engine members.
Installation
In your composer.json file, add:
"require": {
"triad-ltd/expauth": "^1.3.0"
},
"repositories": [
{
"type": "git",
"url": "git@github.com:triad-ltd/expauth.git"
}
]
In config/auth.php, change
'driver' => 'eloquent',
to
'driver' => 'ExpressionEngineAuth',
In your User model, make sure that you set the table and primary key fields as per the Expression Engine schema:
protected $table = 'exp_members';
protected $primaryKey = 'member_id';
LV 10 Structure only
Then, in config/app.php add
'TriadLtd\ExpAuth\ExpressionEngineUserServiceProvider',
'TriadLtd\ExpAuth\ExpressionEngineHasherServiceProvider',
and (optionally) comment out
//'Illuminate\Hashing\HashServiceProvider',
and that's it!
Usage
Authentication works in exactly the same way as Laravel's regular auth methods.
Licence and credit
This package is open-sourced software licensed under the MIT license. Many thanks to the original package (pixelfusion/ExpAuth) upon which this was based, by PixelFusion.