■ 試したこと
まず、Postポリシーを作りました。
PHP
1<?php 2 3// app/Policies/PostPolicy.php 4 5namespace App\Policies; 6 7use App\User; 8use Illuminate\Auth\Access\HandlesAuthorization; 9 10class AnnouncementPolicy 11{ 12 use HandlesAuthorization; 13 14 public function view(User $user) 15 { 16 $user_types = [ 17 'administration', 18 ]; 19 dd(in_array($user->role, $user_types)); 20 return (in_array($user->role, $user_types)); 21 } 22}
次に、AuthServiceProviderで、Postモデルと関連付けます。
PHP
1<?php 2 3// app/Providers/AuthServiceProvider.php 4 5namespace App\Providers; 6 7use Illuminate\Support\Facades\Gate; 8use Illuminate\Foundation\Support\Providers\AuthServiceProvider as ServiceProvider; 9use Illuminate\Http\Request; 10 11class AuthServiceProvider extends ServiceProvider 12{ 13 /** 14 * The policy mappings for the application. 15 * 16 * @var array 17 */ 18 protected $policies = [ 19 App\Post::class => App\Policies\PostPolicy::class, 20 ]; 21 22 /** 23 * Register any authentication / authorization services. 24 * 25 * @return void 26 */ 27 public function boot() 28 { 29 $this->registerPolicies(); 30 31 // 32 } 33}
ここで、コントローラに条件を記載しました。
PHP
1<?php 2 3// app/Http/Controllers/HomeController.php 4 5namespace App\Http\Controllers; 6 7use Illuminate\Support\Facades\Auth; 8use Illuminate\Http\Request; 9 10class HomeController extends Controller 11{ 12 /** 13 * Create a new controller instance. 14 * 15 * @return void 16 */ 17 public function __construct() 18 { 19 $this->middleware('auth'); 20 } 21 22 public function index() { 23 if (Auth::user()->can('view', StoreParent::class)) 24 { 25 // 26 } 27 return view('home.index'); 28 } 29}
users テーブルには、 role カラムに administration を文字列で登録したのち、
以上のような形で実行してみたのですが、 Home コントローラを呼び出しても
Auth::user()->can の部分は false のままで、
Postポリシーに記載したdd();でストップすることもないことから、
そもそも、Postポリシーのviewメソッドが呼び出されていないような気がしています。
原因がどこか、わかりません。
何か心当たりのある方おられましたら教えていただけないでしょうか?
よろしくお願い致します。
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。