前置き
続・Laravelでバックエンドとフロントエンドを分離したいで1アプリ内でフロントエンドとバックエンドを分離するときにそれっぽくディレクトリを分ける方法について書いてみました。
これをscaffoldで簡単にできたらいいな、と思ったので作ってみました。
詳しいディレクトリ構成などについては前述の記事を参考にしてください。
まだ実際のプロジェクトでは使ったことがないので利用の際には自己責任でお願いします。
インストール方法
composer require new-japan-orders/scaffold
使い方
init
scaffold:initコマンドを利用すると、
前述のディレクトリ構成を作成した上で、
MultiAuthに必要なControllerやModelを用意できます。
このコマンドは、scaffold:appとscaffold:authを実行するのと同じ意味です。
php artisan scaffold:init front user
↑
<これらは同じ意味>
↓
php artisan scaffold:app front
php artisan scaffold:auth front user
使い方
frontとadminの2つ作る例。
frontのauth用モデルがuser、adminのauth用モデルがadminの想定です。
コマンド実行例
php artisan scaffold:init front user
php artisan scaffold:init admin admin
php artisan migrate
php artisan db:seed --class UserSeeder
php artisan db:seed --class AdminSeeder
composer autoloadの設定
"autoload": {
"psr-4": {
"App\\": "app/",
"Front\\": "front/",
"Admin\\": "admin/"
}
},
編集後にcomposer dump-autoloadする。
MultiAuthの設定
return [
'defaults' => [
'guard' => 'front',
'passwords' => 'users',
],
'guards' => [
'web' => [
'driver' => 'session',
'provider' => 'users',
],
'front' => [
'driver' => 'session',
'provider' => 'users',
],
'admin' => [
'driver' => 'session',
'provider' => 'admins',
],
'api' => [
'driver' => 'token',
'provider' => 'users',
],
],
'providers' => [
'users' => [
'driver' => 'eloquent',
'model' => App\User::class,
],
'admins' => [
'driver' => 'eloquent',
'model' => App\Admin::class,
],
],
'passwords' => [
'users' => [
'provider' => 'users',
'table' => 'password_resets',
'expire' => 60,
],
'admins' => [
'provider' => 'admins',
'table' => 'password_resets',
'expire' => 60,
],
],
];
認証済みの際のRedirect先修正
public function handle($request, Closure $next, $guard = null)
{
if (Auth::guard($guard)->check()) {
return redirect($guard.'/home');
}
return $next($request);
}
認証失敗時のリダイレクト先の修正
protected function unauthenticated($request, AuthenticationException $exception)
{
if ($request->expectsJson()) {
return response()->json(['error' => 'Unauthenticated.'], 401);
}
if (in_array('admin', $exception->guards())) {
return redirect()->guest(route('admin.login'));
}
return redirect()->guest(route('front.login'));
}
routeの設定
protected function mapWebRoutes()
{
Route::middleware('web')
->namespace('Front\Http\Controllers')
->group(base_path('routes/front.php'));
Route::middleware('web')
->namespace('Admin\Http\Controllers')
->group(base_path('routes/admin.php'));
}
mvc
scaffold:mvcコマンドを利用すると、
前述のディレクトリ構成を作成した上で、
Model, Controller, Viewの3つを作成します。
このコマンドは、
- scaffold:controller
- scaffold:model
- scaffold:view
を実行するのと同じ意味です。
php artisan scaffold:mvc front user car
↑
<これらは同じ意味>
↓
php artisan scaffold:controller front car
php artisan scaffold:model car
php artisan scaffold:view front user car