PHP
laravel
laravel5
laravel5.6

Laravelでバックエンドとフロントエンドを分離するためのscaffoldをつくってみた

前置き

続・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の設定

composer.json
    "autoload": {
        "psr-4": {
            "App\\": "app/",
            "Front\\": "front/",
            "Admin\\": "admin/"
        }
    },

編集後にcomposer dump-autoloadする。

MultiAuthの設定

config/auth.php
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先修正

app/Http/Middleware/RedirectIfAuthenticated.php
    public function handle($request, Closure $next, $guard = null)
    {
        if (Auth::guard($guard)->check()) {
            return redirect($guard.'/home');
        }

        return $next($request);
    }

認証失敗時のリダイレクト先の修正

app/Exceptions/Handler.php
    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の設定

app/Providers/RouteServiceProvider.php
    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