0.0.1 2018-05-10 08:05 UTC

This package is not auto-updated.

Last update: 2024-06-23 03:31:42 UTC


README

scaffold

概要

目的

フロントとバックエンドは分離したい。 けどアプリを2つ作るほどの規模じゃない。 なのでディレクトリで分離する。 中小規模でのCMS開発がターゲット。

ディレクトリ構成

例えば以下のようにコマンドを実行した場合。

php artisan scaffold:init front user

ディレクトリ構成は以下のようになります。

base_path
├ app
│   ├ Models
│   │   └ User.php  
│   └ Policies
├ front
│   ├ Http
│   │   └ Controllers
│   │       ├ Controller.php
│   │       ├ HomeController.php
│   │       └ Auth
│   │           ├ LoginController.php
│   │           ├ ForgetController.php
│   │           ├ RegisterController.php
│   │           └ ResetController.php
│   ├ Policies
│   └ Notifications
│       └ ResetPassword.php
├ resources
│   └ views
│       └ front
│           ├ home.blade.php
│           ├ layouts
│           │   └ app.blade.php
│           └ auth  
│               ├ login.blade.php
│               ├ register.blade.php
│               └ passwords
│                   ├ reset.blade.php
│                   └ email.blade.php
└ routes
    └ front.php

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つ作る例。

コマンド実行例

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,
        ],


        // 'users' => [
        //     'driver' => 'database',
        //     'table' => 'users',
        // ],
    ],
    'passwords' => [
        'front' => [
            'provider' => 'users',
            'table' => 'user_password_resets',
            'expire' => 60,
        ],
        'admin' => [
            'provider' => 'admins',
            'table' => 'admin_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