master
parent
92b2e7dc90
commit
ae6553d7b1
@ -0,0 +1,138 @@
|
||||
<?php
|
||||
|
||||
namespace App\Http\Controllers\Worker;
|
||||
|
||||
use App\Models\Paramedic;
|
||||
use App\Worker;
|
||||
use App\Http\Controllers\Controller;
|
||||
use Illuminate\Support\Facades\DB;
|
||||
|
||||
class AuthController extends Controller
|
||||
{
|
||||
|
||||
public $guardName = "worker";
|
||||
public $authModel;
|
||||
|
||||
public function __construct()
|
||||
{
|
||||
$this->authModel = new Worker();
|
||||
}
|
||||
|
||||
/**
|
||||
* Create a new AuthController instance.
|
||||
*
|
||||
* @return void
|
||||
*/
|
||||
|
||||
public function guard()
|
||||
{
|
||||
return auth()->guard($this->guardName);
|
||||
}
|
||||
|
||||
public function guardName()
|
||||
{
|
||||
return $this->guardName;
|
||||
}
|
||||
|
||||
/**
|
||||
* @OA\Post(
|
||||
* path="/worker/login-by-username",
|
||||
* tags={"护工端用户相关"},
|
||||
* summary="V2-通过用户名密码登录",
|
||||
* description="",
|
||||
* @OA\Parameter(name="username", in="query", @OA\Schema(type="string"), required=true, description="用户名(身份证号)"),
|
||||
* @OA\Parameter(name="password", in="query", @OA\Schema(type="string"), required=true, description="密码"),
|
||||
* @OA\Response(
|
||||
* response="200",
|
||||
* description="护工通过用户名(身份证号)密码登录"
|
||||
* )
|
||||
* )
|
||||
*/
|
||||
public function loginByUsername()
|
||||
{
|
||||
$credentials = [
|
||||
"id_card_number" => request()->username,
|
||||
"password" => request()->password
|
||||
];
|
||||
if (!$token = $this->guard()->attempt($credentials)) {
|
||||
return response()->json([
|
||||
'errorcode' => '401',
|
||||
'errormsg' => '登录失败'
|
||||
], 401);
|
||||
}
|
||||
|
||||
return $this->respondWithToken($token);
|
||||
}
|
||||
|
||||
/**
|
||||
* @OA\Post(
|
||||
* path="/worker/me",
|
||||
* tags={"护工端用户相关"},
|
||||
* summary="V2-获取登录者信息",
|
||||
* @OA\Parameter(name="token", in="query", @OA\Schema(type="string"), required=true, description="token"),
|
||||
* description="",
|
||||
* @OA\Response(
|
||||
* response="200",
|
||||
* description="获取登录者信息"
|
||||
* )
|
||||
* )
|
||||
*/
|
||||
public function me()
|
||||
{
|
||||
$id = $this->guard()->id();
|
||||
$paramedic = (new Paramedic())->find($id);
|
||||
return response()->json($paramedic->toArray());
|
||||
}
|
||||
|
||||
/**
|
||||
* @OA\Post(
|
||||
* path="/worker/logout",
|
||||
* tags={"护工端用户相关"},
|
||||
* summary="V2 退出登录",
|
||||
* @OA\Parameter(name="token", in="query", @OA\Schema(type="string"), required=true, description="token"),
|
||||
* description="",
|
||||
* @OA\Response(
|
||||
* response="200",
|
||||
* description="退出登录"
|
||||
* )
|
||||
* )
|
||||
*/
|
||||
public function logout()
|
||||
{
|
||||
DB::beginTransaction();
|
||||
try {
|
||||
$this->guard()->logout();
|
||||
DB::commit();
|
||||
return response()->json([
|
||||
'errormsg' => "退出登录成功!"
|
||||
]);
|
||||
} catch (\Exception $exception) {
|
||||
DB::rollBack();
|
||||
return response()->json([
|
||||
'errorcode' => '402',
|
||||
'errormsg' => $exception->getMessage()
|
||||
]);
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Get the token array structure.
|
||||
*
|
||||
* @param string $token
|
||||
*
|
||||
* @return \Illuminate\Http\JsonResponse
|
||||
*/
|
||||
protected function respondWithToken($token)
|
||||
{
|
||||
$user = $this->guard()->user();
|
||||
$user = $user->toArray();
|
||||
|
||||
return response()->json([
|
||||
'access_token' => $token,
|
||||
'token_type' => 'bearer',
|
||||
'expires_in' => $this->guard()->factory()->getTTL() * 60,
|
||||
'user_info' => $user
|
||||
]);
|
||||
}
|
||||
}
|
||||
@ -0,0 +1,27 @@
|
||||
<?php
|
||||
|
||||
namespace App\Http\Controllers\Worker;
|
||||
|
||||
use App\Http\Controllers\Controller;
|
||||
|
||||
class CommonController extends Controller
|
||||
{
|
||||
public $guardName = "worker";
|
||||
public $worker;
|
||||
|
||||
public function __construct()
|
||||
{
|
||||
$worker = $this->guard()->user();
|
||||
$this->worker = $worker;
|
||||
}
|
||||
|
||||
public function guard()
|
||||
{
|
||||
return auth()->guard($this->guardName);
|
||||
}
|
||||
|
||||
public function guardName()
|
||||
{
|
||||
return $this->guardName;
|
||||
}
|
||||
}
|
||||
@ -0,0 +1,88 @@
|
||||
<?php
|
||||
|
||||
namespace App;
|
||||
|
||||
use Illuminate\Foundation\Auth\User as Authenticatable;
|
||||
use Illuminate\Notifications\Notifiable;
|
||||
use Tymon\JWTAuth\Contracts\JWTSubject;
|
||||
|
||||
/**
|
||||
* App\Manager
|
||||
*
|
||||
*/
|
||||
class Worker extends Authenticatable implements JWTSubject
|
||||
{
|
||||
use Notifiable;
|
||||
|
||||
protected $table = "paramedic";
|
||||
|
||||
const GUARD_NAME = "worker";
|
||||
|
||||
public function getAvatarUrlAttribute()
|
||||
{
|
||||
$protocol = request()->secure() ? "https" : "http";
|
||||
if (!$this->avatar) {
|
||||
switch ($this->sex) {
|
||||
case "男":
|
||||
$this->avatar = "/images/male.png";
|
||||
break;
|
||||
case "女":
|
||||
$this->avatar = "/images/female.png";
|
||||
break;
|
||||
}
|
||||
}
|
||||
return $this->avatar ? $protocol . "://" . request()->getHost() . $this->avatar : $this->avatar;
|
||||
}
|
||||
|
||||
public function guardName()
|
||||
{
|
||||
return self::GUARD_NAME;
|
||||
}
|
||||
|
||||
// Rest omitted for brevity
|
||||
|
||||
/**
|
||||
* Get the identifier that will be stored in the subject claim of the JWT.
|
||||
*
|
||||
* @return mixed
|
||||
*/
|
||||
public function getJWTIdentifier()
|
||||
{
|
||||
return $this->getKey();
|
||||
}
|
||||
|
||||
/**
|
||||
* Return a key value array, containing any custom claims to be added to the JWT.
|
||||
*
|
||||
* @return array
|
||||
*/
|
||||
public function getJWTCustomClaims()
|
||||
{
|
||||
return [];
|
||||
}
|
||||
|
||||
/**
|
||||
* The attributes that are mass assignable.
|
||||
*
|
||||
* @var array
|
||||
*/
|
||||
protected $fillable = [];
|
||||
|
||||
/**
|
||||
* The attributes that should be hidden for arrays.
|
||||
*
|
||||
* @var array
|
||||
*/
|
||||
protected $hidden = [
|
||||
'password', 'remember_token',
|
||||
];
|
||||
|
||||
/**
|
||||
* The attributes that should be cast to native types.
|
||||
*
|
||||
* @var array
|
||||
*/
|
||||
protected $casts = [
|
||||
'verified_at' => 'datetime',
|
||||
];
|
||||
}
|
||||
@ -0,0 +1,31 @@
|
||||
<?php
|
||||
|
||||
use Illuminate\Database\Migrations\Migration;
|
||||
use Illuminate\Database\Schema\Blueprint;
|
||||
use Illuminate\Support\Facades\Schema;
|
||||
|
||||
class UpdateParamedicAddAuthFields extends Migration
|
||||
{
|
||||
/**
|
||||
* Run the migrations.
|
||||
*
|
||||
* @return void
|
||||
*/
|
||||
public function up()
|
||||
{
|
||||
Schema::table("paramedic", function (Blueprint $table) {
|
||||
$table->string("remember_token")->nullable();
|
||||
$table->string("password")->nullable();
|
||||
});
|
||||
}
|
||||
|
||||
/**
|
||||
* Reverse the migrations.
|
||||
*
|
||||
* @return void
|
||||
*/
|
||||
public function down()
|
||||
{
|
||||
//
|
||||
}
|
||||
}
|
||||
Loading…
Reference in new issue