I have two controller classes one for custom signin and one for my items.
Custome controller class that authenticates all the users
class SigninController extends Controller
{
public function getSigninRequest(Request $request)
{
$this->validate($request,[
'email'=>'required|email',
'password'=>'required'
]);
if(Auth::attempt(['email'=>$request->input('email'),
'password'=>$request->input('password')],
$request->has('remember')))
{
return redirect()->route('admin.index');
}
return redirect()->back()->with('fail','Authentication failed!');
}
}
User Model class for normal users and admin
class User extends Authenticatable
{
use Notifiable;
/**
* The attributes that are mass assignable.
*
* @var array
*/
const ADMIN_TYPE = 'admin';
const DEFAULT_TYPE ='default';
protected $fillable = [
'name', 'email', 'password',
];
/**
* The attributes that should be hidden for arrays.
*
* @var array
*/
protected $hidden = [
'password', 'remember_token',
];
public function books()
{
return $this->hasMany('App\Book');
}
public function isAdmin()
{
return $this->type=== self::ADMIN_TYPE;
}
}
user database migration in which I added type row
public function up()
{
Schema::create('users', function (Blueprint $table) {
$table->increments('id');
$table->string('name');
$table->string('email')->unique();
$table->timestamp('email_verified_at')->nullable();
$table->string('password');
$table->string('type')->default('default');
$table->rememberToken();
$table->timestamps();
});
}
Route web.php. I want to pass all data with one login route
Auth::routes();
Route::post('login',[
'uses'=>'SigninController@getSigninRequest',
'as'=>'auth.signin'
]);
I want to create admin user who can add/delete and edit items even those items are created by normal users who can only add/edit and delete their own items only. So, after login, all users must be redirected to the same page.