Skip to content
This repository has been archived by the owner on Nov 29, 2019. It is now read-only.

wuifdesign/laravel-multiauth

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

33 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Laravel MultiAuth

GitHub release Packagist License

Twitter

Laravel: 5.0, 5.1

This Package extends the default Auth library to allow logging in with accounts from different database tables or even different databases. For example if you want to save your backend and a frontend users in a different table to keep them separated.

Works with the default Laravel 5 AuthController and PasswordController!

Installation

The easiest way is to run the following command:

composer require wuifdesign/laravel-multiauth

Otherwise you can include the package in your composer.json file,

"require": {
    "wuifdesign/laravel-multiauth": "0.3.*"
}

and update or install via composer:

composer update

Now you have to open up your app/config/app.php and add

'providers' => [
    ...
    WuifDesign\MultiAuth\ServiceProvider::class
]

Configuration is pretty easy too, take app/config/auth.php with its default values

return array(

    'driver' => 'eloquent',
    'model' => 'User',
    'table' => 'users',

    'password' => array(
        'email' => 'emails.password',
        'table' => 'password_reminders',
        'expire' => 60,
    ),

);

and replace the first three options (driver, model, table) and replace them with the following

return array(

    'default' => 'user',
    'multi' => array(
        'admin' => array(
            'driver' => 'eloquent',
            'model'  => Admins::class,
        ),
        'user' => array(
            'driver' => 'eloquent',
            'model'  => Users::class,
            'password' => [
                'email' => 'users.emails.password',
            ]
        )
    ),

    'password' => array(
        'email' => 'emails.password',
        'table' => 'password_reminders',
        'expire' => 60,
    ),
);

Usage

Everything is done by using routes. Just add a key "auth" to the route array with the value you used as a key in your app/config/auth.php

Route::get('/', array(
    'uses' => function () {
        return 'Hello World';
    },
    'middleware' => [ 'auth' ],
    'auth' => 'admin',
));

Now if you call Auth::check() or any other function, it will use the driver and model set in the config for the key "admin".

If you don't add a "auth" to the route, the "default" type defined in the app/config/auth.php will be used.

If you want to check a specific auth while in a route using a different auth, you can use Auth::type($auth_key) to get the wanted auth manager.

Auth::type('admin')->check();

To get the current auth_key used by the route, or the default value, if you haven't set it in the route use.

Auth::currentType();

If you want to login as a different user, just use Auth::impersonate($id, $auth_key = null, $remember = false). If you don't parse a auth_key, the key set via route, or the default one will be used.

Auth::impersonate(3, 'admin');

About

MultiAuth for Laravel 5.0, 5.1

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages