Last active
September 30, 2017 16:36
-
-
Save mostafa6765/be7b5d7017205fe6f2873b1430a8347a to your computer and use it in GitHub Desktop.
Laravel Addiotional and username_or_email login
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
<?php | |
// this is LoginController | |
namespace App\Http\Controllers\Auth; | |
use App\Http\Controllers\Controller; | |
use Illuminate\Http\Request; | |
use Illuminate\Foundation\Auth\AuthenticatesUsers; | |
use Auth; | |
class LoginController extends Controller | |
{ | |
/* | |
|-------------------------------------------------------------------------- | |
| Login Controller | |
|-------------------------------------------------------------------------- | |
| | |
| This controller handles authenticating users for the application and | |
| redirecting them to your home screen. The controller uses a trait | |
| to conveniently provide its functionality to your applications. | |
| | |
*/ | |
use AuthenticatesUsers; | |
/** | |
* Where to redirect users after login. | |
* | |
* @var string | |
*/ | |
protected $redirectTo = '/home'; | |
/** | |
* Create a new controller instance. | |
* | |
* @return void | |
*/ | |
public function __construct() | |
{ | |
$this->middleware('guest')->except('logout'); | |
} | |
protected function validateLogin(Request $request) | |
{ | |
$this->validate($request, [ | |
$this->username() => 'required' , 'password' => 'required','token' => 'required', | |
]); | |
} | |
protected function credentials(Request $request) | |
{ | |
$field = filter_var($request->input($this->username()), FILTER_VALIDATE_EMAIL) ? 'email' : 'username'; | |
$request->merge([$field => $request->input($this->username())]); | |
return $request->only($field, 'password','token'); | |
} | |
public function username() | |
{ | |
return 'login'; | |
} | |
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
@extends('layouts.app') | |
@section('content') | |
<div class="container"> | |
<div class="row"> | |
<div class="col-md-8 col-md-offset-2"> | |
<div class="panel panel-default"> | |
<div class="panel-heading">Login</div> | |
<div class="panel-body"> | |
<form class="form-horizontal" method="POST" action="{{ route('login') }}"> | |
{{ csrf_field() }} | |
<div class="form-group"> | |
<label for="email" class="col-md-4 control-label">E-Mail/Username</label> | |
<div class="col-md-6"> | |
<input id="email" type="text" class="form-control" name="login" value="{{ old('email') }}" required autofocus> | |
@if ($errors->has('login')) | |
<span class="help-block"> | |
<strong>{{ $errors->first('login') }}</strong> | |
</span> | |
@endif | |
</div> | |
</div> | |
<div class="form-group{{ $errors->has('token') ? ' has-error' : '' }}"> | |
<label for="token" class="col-md-4 control-label">token</label> | |
<div class="col-md-6"> | |
<input id="token" type="text" class="form-control" name="token" value="{{ old('token') }}" required autofocus> | |
@if ($errors->has('token')) | |
<span class="help-block"> | |
<strong>{{ $errors->first('token') }}</strong> | |
</span> | |
@endif | |
</div> | |
</div> | |
<div class="form-group{{ $errors->has('password') ? ' has-error' : '' }}"> | |
<label for="password" class="col-md-4 control-label">Password</label> | |
<div class="col-md-6"> | |
<input id="password" type="password" class="form-control" name="password" required> | |
@if ($errors->has('password')) | |
<span class="help-block"> | |
<strong>{{ $errors->first('password') }}</strong> | |
</span> | |
@endif | |
</div> | |
</div> | |
<div class="form-group"> | |
<div class="col-md-6 col-md-offset-4"> | |
<div class="checkbox"> | |
<label> | |
<input type="checkbox" name="remember" {{ old('remember') ? 'checked' : '' }}> Remember Me | |
</label> | |
</div> | |
</div> | |
</div> | |
<div class="form-group"> | |
<div class="col-md-8 col-md-offset-4"> | |
<button type="submit" class="btn btn-primary"> | |
Login | |
</button> | |
<a class="btn btn-link" href="{{ route('password.request') }}"> | |
Forgot Your Password? | |
</a> | |
</div> | |
</div> | |
</form> | |
</div> | |
</div> | |
</div> | |
</div> | |
</div> | |
@endsection |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
@extends('layouts.app') | |
@section('content') | |
<div class="container"> | |
<div class="row"> | |
<div class="col-md-8 col-md-offset-2"> | |
<div class="panel panel-default"> | |
<div class="panel-heading">Register</div> | |
<div class="panel-body"> | |
<form class="form-horizontal" method="POST" action="{{ route('register') }}"> | |
{{ csrf_field() }} | |
<div class="form-group{{ $errors->has('name') ? ' has-error' : '' }}"> | |
<label for="name" class="col-md-4 control-label">Name</label> | |
<div class="col-md-6"> | |
<input id="name" type="text" class="form-control" name="name" value="{{ old('name') }}" required autofocus> | |
@if ($errors->has('name')) | |
<span class="help-block"> | |
<strong>{{ $errors->first('name') }}</strong> | |
</span> | |
@endif | |
</div> | |
</div> | |
<div class="form-group{{ $errors->has('username') ? ' has-error' : '' }}"> | |
<label for="username" class="col-md-4 control-label">Username</label> | |
<div class="col-md-6"> | |
<input id="username" type="text" class="form-control" name="username" value="{{ old('name') }}" required autofocus> | |
@if ($errors->has('username')) | |
<span class="help-block"> | |
<strong>{{ $errors->first('username') }}</strong> | |
</span> | |
@endif | |
</div> | |
</div> | |
<div class="form-group{{ $errors->has('token') ? ' has-error' : '' }}"> | |
<label for="token" class="col-md-4 control-label">token</label> | |
<div class="col-md-6"> | |
<input id="token" type="text" class="form-control" name="token" value="{{ old('token') }}" required autofocus> | |
@if ($errors->has('token')) | |
<span class="help-block"> | |
<strong>{{ $errors->first('token') }}</strong> | |
</span> | |
@endif | |
</div> | |
</div> | |
<div class="form-group{{ $errors->has('email') ? ' has-error' : '' }}"> | |
<label for="email" class="col-md-4 control-label">E-Mail Address</label> | |
<div class="col-md-6"> | |
<input id="email" type="email" class="form-control" name="email" value="{{ old('email') }}" required> | |
@if ($errors->has('email')) | |
<span class="help-block"> | |
<strong>{{ $errors->first('email') }}</strong> | |
</span> | |
@endif | |
</div> | |
</div> | |
<div class="form-group{{ $errors->has('password') ? ' has-error' : '' }}"> | |
<label for="password" class="col-md-4 control-label">Password</label> | |
<div class="col-md-6"> | |
<input id="password" type="password" class="form-control" name="password" required> | |
@if ($errors->has('password')) | |
<span class="help-block"> | |
<strong>{{ $errors->first('password') }}</strong> | |
</span> | |
@endif | |
</div> | |
</div> | |
<div class="form-group"> | |
<label for="password-confirm" class="col-md-4 control-label">Confirm Password</label> | |
<div class="col-md-6"> | |
<input id="password-confirm" type="password" class="form-control" name="password_confirmation" required> | |
</div> | |
</div> | |
<div class="form-group"> | |
<div class="col-md-6 col-md-offset-4"> | |
<button type="submit" class="btn btn-primary"> | |
Register | |
</button> | |
</div> | |
</div> | |
</form> | |
</div> | |
</div> | |
</div> | |
</div> | |
</div> | |
@endsection |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
<?php | |
namespace App\Http\Controllers\Auth; | |
use App\User; | |
use App\Http\Controllers\Controller; | |
use Illuminate\Support\Facades\Validator; | |
use Illuminate\Foundation\Auth\RegistersUsers; | |
class RegisterController extends Controller | |
{ | |
/* | |
|-------------------------------------------------------------------------- | |
| Register Controller | |
|-------------------------------------------------------------------------- | |
| | |
| This controller handles the registration of new users as well as their | |
| validation and creation. By default this controller uses a trait to | |
| provide this functionality without requiring any additional code. | |
| | |
*/ | |
use RegistersUsers; | |
/** | |
* Where to redirect users after registration. | |
* | |
* @var string | |
*/ | |
protected $redirectTo = '/home'; | |
/** | |
* Create a new controller instance. | |
* | |
* @return void | |
*/ | |
public function __construct() | |
{ | |
$this->middleware('guest'); | |
} | |
/** | |
* Get a validator for an incoming registration request. | |
* | |
* @param array $data | |
* @return \Illuminate\Contracts\Validation\Validator | |
*/ | |
protected function validator(array $data) | |
{ | |
return Validator::make($data, [ | |
'name' => 'required|string|max:255', | |
'token'=> 'required', | |
'username'=> 'required|unique:users', | |
'email' => 'required|string|email|max:255|unique:users', | |
'password' => 'required|string|min:6|confirmed', | |
]); | |
} | |
/** | |
* Create a new user instance after a valid registration. | |
* | |
* @param array $data | |
* @return \App\User | |
*/ | |
protected function create(array $data) | |
{ | |
return User::create([ | |
'name' => $data['name'], | |
'token'=> $data['token'], | |
'username'=> $data['username'], | |
'email' => $data['email'], | |
'password' => bcrypt($data['password']), | |
]); | |
} | |
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
<?php | |
namespace App; | |
use Illuminate\Notifications\Notifiable; | |
use Illuminate\Foundation\Auth\User as Authenticatable; | |
class User extends Authenticatable | |
{ | |
use Notifiable; | |
// use AuthenticableTrait; | |
/** | |
* The attributes that are mass assignable. | |
* | |
* @var array | |
*/ | |
protected $fillable = [ | |
'name', 'email', 'password','token','username', | |
]; | |
/** | |
* The attributes that should be hidden for arrays. | |
* | |
* @var array | |
*/ | |
protected $hidden = [ | |
'password', 'remember_token', | |
]; | |
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
<?php | |
use Illuminate\Support\Facades\Schema; | |
use Illuminate\Database\Schema\Blueprint; | |
use Illuminate\Database\Migrations\Migration; | |
class CreateUsersTable extends Migration | |
{ | |
/** | |
* Run the migrations. | |
* | |
* @return void | |
*/ | |
public function up() | |
{ | |
Schema::create('users', function (Blueprint $table) { | |
$table->increments('id'); | |
$table->string('name'); | |
$table->string('email')->unique(); | |
$table->string('token')->unique(); | |
$table->string('username')->unique(); | |
$table->string('password'); | |
$table->rememberToken(); | |
$table->timestamps(); | |
}); | |
} | |
/** | |
* Reverse the migrations. | |
* | |
* @return void | |
*/ | |
public function down() | |
{ | |
Schema::dropIfExists('users'); | |
} | |
} |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment