| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152 |
- <?php
- namespace App\Http\Controllers;
- use Illuminate\Http\Request;
- use App\Models\UserInfo;
- use Firebase\JWT\JWT;
- use App\Http\Api\AuthApi;
- use Illuminate\Support\Facades\Storage;
- use Illuminate\Support\Facades\App;
- use App\Http\Api\UserApi;
- class AuthController extends Controller
- {
- /**
- * Display a listing of the resource.
- *
- * @return \Illuminate\Http\Response
- */
- public function index()
- {
- //
- }
- /**
- * Store a newly created resource in storage.
- *
- * @param \Illuminate\Http\Request $request
- * @return \Illuminate\Http\Response
- */
- public function store(Request $request)
- {
- //
- }
- /**
- * Display the specified resource.
- *
- * @param int $id
- * @return \Illuminate\Http\Response
- */
- public function show($id)
- {
- //
- }
- /**
- * Update the specified resource in storage.
- *
- * @param \Illuminate\Http\Request $request
- * @param int $id
- * @return \Illuminate\Http\Response
- */
- public function update(Request $request, $id)
- {
- //
- }
- /**
- * Remove the specified resource from storage.
- *
- * @param int $id
- * @return \Illuminate\Http\Response
- */
- public function destroy($id)
- {
- //
- }
- public function signIn(Request $request)
- {
- $query = UserInfo::where(function ($query) use ($request) {
- $query->where('username', $request->get('username'))
- ->where('password', md5($request->get('password')));
- })
- ->orWhere(function ($query) use ($request) {
- $query->where('email', $request->get('username'))
- ->where('password', md5($request->get('password')));
- });
- //Log::info($query->toSql());
- $user = $query->first();
- if ($user) {
- $ExpTime = time() + 60 * 60 * 24 * 365;
- $key = config('app.key');
- $payload = [
- 'nbf' => time(),
- 'exp' => $ExpTime,
- 'uid' => $user->userid,
- 'id' => $user->id,
- ];
- $jwt = JWT::encode($payload, $key, 'HS512');
- return $this->ok($jwt);
- } else {
- return $this->error('invalid token');
- }
- }
- public static function getUserToken($userUid)
- {
- $user = UserApi::getByUuid($userUid);
- if ($user) {
- $ExpTime = time() + 60 * 60 * 24 * 365;
- $key = config('app.key');
- $payload = [
- 'nbf' => time(),
- 'exp' => $ExpTime,
- 'uid' => $user['id'],
- 'id' => $user['sn'],
- ];
- $jwt = JWT::encode($payload, $key, 'HS512');
- }
- }
- public function getUserInfoByToken(Request $request)
- {
- $curr = AuthApi::current($request);
- if (!$curr) {
- return $this->error('invalid token', 401, 401);
- }
- $userInfo = UserInfo::where('userid', $curr['user_uid'])
- ->first();
- $user = [
- "id" => $curr['user_uid'],
- "nickName" => $userInfo->nickname,
- "realName" => $userInfo->username,
- "avatar" => "",
- "token" => \substr($request->header('Authorization'), 7),
- ];
- //role为空 返回[]
- $user['roles'] = [];
- if (!empty($userInfo->role)) {
- $roles = json_decode($userInfo->role);
- if (is_array($roles)) {
- $user['roles'] = $roles;
- }
- }
- if ($curr['user_uid'] === config('mint.admin.root_uuid')) {
- $user['roles'] = ['root'];
- }
- if ($userInfo->avatar) {
- $img = str_replace('.jpg', '_s.jpg', $userInfo->avatar);
- if (App::environment('local')) {
- $user['avatar'] = Storage::url($img);
- } else {
- $user['avatar'] = Storage::temporaryUrl($img, now()->addDays(6));
- }
- }
- return $this->ok($user);
- }
- }
|