Laravel5で2種類のログイン認証を実装したい
Laravel5.0でログインを必要とするページを作っています。
管理ユーザー(Admin)と一般ユーザー(User)が存在し、構造や用途も大きく異なるため別のテーブルに分けました。
Userのログインには標準のeloquentドライバーを用いた認証機能を少し改造(ログインIDで認証)して利用しています。
今回、新しく管理ユーザー専用の認証ドライバーのようなものを作り、特定のページではAdminとしてログインするようにしたいと考えています。
認証はmiddlewareで行っており、Userの認証は各ページコントローラーのコンストラクタで次のようにして認証の必要なページを指定しています。
public function __construct()
{
$this->middleware('auth');
}
Adminの認証も同様に次の形を取ろうと考えています。
public function __construct()
{
$this->middleware('admin-auth');
}
ひとまず「App\Http\Middleware\Authenticate.php」をコピーした「AdminAuthenticate.php」を作りKernel.phpに登録するところまで行いました。
おそらくconfig/app.phpに「App\Providers\AdminAuthServiceProvider」のようなものを追記してその中でAuthを拡張していくのかと推測していますが具体的な方法がわかりません。
eloquentとは別の認証ドライバを新しく作って切り替えられるようにするのでしょうか?
良い方法がございましたら教えて下さい。