【发布时间】:2017-10-12 15:41:07
【问题描述】:
所以我需要检查 User 模型中的现有关系,并制作 if 语句以向具有 Company 关系的用户授予路由访问权限。
用户.php
public function company(){
return $this->belongsTo('App\Company', 'user_id');
}
公司.php
public function user(){
return $this->hasMany('App\User') ;
}
ListingController.php
public function create(User $user){
if(count($user->company) > 0){
return view('listings.create');
} else{
return redirect()->back();
}
}
导航视图
@inject('user', 'App\User')
@if(count($user->company) > 0)
<li><a href="{{route('listings.create', [$area])}}">Add Listing</a></li>
@endif
在 web.php 中列出路由
Route::group(['prefix' => '/listing', 'namespace' => 'Listing'], function (){
// Route::get('/me', 'ListingController@userListingsView')->name('listings.index');
Route::get('/favourites', 'ListingFavoriteController@index')->name('listings.favourites.index');
Route::post('/{listing}/favourites', 'ListingFavoriteController@store')->name('listings.favourites.store');
Route::delete('/{listing}/favourites', 'ListingFavoriteController@destroy')->name('listings.favourites.destroy');
Route::post('{listing}/contact', 'ListingContactController@store')->name('listings.contact.store');
Route::get('{listing}/share', 'ListingShareController@index')->name('listings.share.index');
Route::post('{listing}/share', 'ListingShareController@store')->name('listings.share.store');
Route::group(['middleware' => 'auth'], function (){
Route::get('/create', 'ListingController@create')->name('listings.create');
Route::post('/', 'ListingController@store')->name('listings.store');
Route::get('{listing}/edit', 'ListingController@edit')->name('listings.edit');
Route::patch('{listing}', 'ListingController@update')->name('listings.update');
});
});
URL :: project.dev/{area}/listing/create
现在我不确定我与用户之间的公司关系是否正确,当我使用具有公司关系的用户登录时,它仍然会将我重定向回来,而不是创建列表路线。
【问题讨论】:
-
在导航视图中,$area 到底是什么?
标签: php mysql laravel eloquent relationship