まず分かりにくいタイトルですいません。
これというのが思いつかず、これでも核を突いたタイトルになっているのかなと思っています。
Laravelを使って開発しています。
まだそこまで進んでいないプロジェクトなので100%SPAに切り替えようと思っています。
そこで1つ気になる点があります。
それが、「権限閲覧制限」です。
SPAじゃなければ遷移する度に、gateやらcontroller側の基底クラスでチェックできますが、
https://www.ritolab.com/entry/56
SPAとなるとview(bladeの方)は基本的に1つ用意すると認識しています。
ログインしているのかしていないのか
ログインしていても権限は〜〜〜以上か〜〜〜以下なのか
それによって読み込むlayoutを切り替えていましたがSPAだとこれができないのでは?と思っています。
例えば、転職サイトがあったとしましょう。
ログインしていないユーザー(ゲスト)は求人情報を見ることはできても
応募するには、ログインしないとできない。
また、WEBサーバーは同一でサブドメインやadminというディレクトリ配下が管理画面になっているケースではログインしてても一定以上の権限がないとログインできないとかあると思います。
はたまたコーポレートサイトで社員による記事投稿ができるページがあった場合、
記事ページに関してはOGPタグを含めた方が宣伝効果もあるでしょうし
記事ページ以外に関してはOGPタグは必要なく、
管理画面に関してはnoindexなど指定したいところで、
権限によってheadの部分がかなりかわってきます。
そもそも管理画面とユーザーサイトは別サーバー立てればそんな悩みなくなるというのは承知の上ですので、同サーバーにある前提でこの問題を解決したいです。
以下のようなページはログインしてなくても見れそうです。
https://example.jp/login
https://example.jp/company/list
https://example.jp/company/{companyId}/detail
以下のようなページはログインしていないと見れそうもないです。
https://example.jp/my-page
https://example.jp/company/message/list
https://example.jp/company/message/{companyId}/execute
SPAじゃなければそれこそ
Route::group(['middleware' => ['auth'], 'prefix' => 'management/'], function () { // マイページ Route::get('/', 'Auth\MyPageController@index')->name('my_page'); });
といった感じでmiddleware
適応すればいいだけの話ですが、
SPAは
全てのURLを1つのcontrollerで受け取り
レンダリングされるview(bladeの方)が持つエレメント配下で
root.jsで定義するエレメントと紐づいて
router-viewの各pathで指定するcomponent.vueをレンダリングする。
と認識していますので、まずlaravel側のgate機能などは使えないのではと思っています。
今私の頭の中にあるのは、、、
多分、非ログインユーザー用
ログインユーザー用
管理者用
3つのcontrollerを作る。
PublishController
AuthController
AdminController
・ログインしているかしていないか
・ログインしてても管理者であるか否か
この2つのmiddlewareを作ってroutingで定義。
bladeも3種類作る。
っていうのは思いついたんですが、今回何が知りたいのかの核は
middlewareが走るのはブラウザをリロードするからであって router-viewによる画面の切り替えはブラウザのリロードではないから middlewareをLaravel側のroutingで設定しても無意味なのでは?
というところです。
このあたりに詳しい方いましたらアドバイスお願いします。
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。