123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106 |
- <?php
- namespace App\Http\Controllers\Api\mini;
- use App\Models\User;
- use App\Models\UserReset;
- use Illuminate\Http\Request;
- use Illuminate\Support\Facades\Auth;
- use Illuminate\Support\Facades\Log;
- class AuthController extends BaseController
- {
- public function login(Request $request)
- {
- $credentials = $request->only('phone', 'password');
- if(Auth::guard('mini')->attempt($credentials)) {
- $user = Auth::guard('mini')->user();
- $user->updateToken();
- $user->avatar = $user->avatar ? $user->avatar : 'https://t18.9026.com/mini/default-user.png';
- $user->topRole = $user->getTopRole();
- return $this->success(['data' => $user]);
- }
- return $this->error(['msg' => '账号或密码错误']);
- }
- public function loginByWechat(Request $request)
- {
- $app = app('wechat.mini_program');
- $session_key = $request->input('session_key');
- if(!$session_key && $request->input('code')) {
- $res = $app->auth->session($request->input('code'));
- if(isset($res['session_key'])) $session_key = $res['session_key'];
- }
- if($session_key) {
- $data = $app->encryptor->decryptData($session_key, $request->input('iv'), $request->input('encryptedData'));
- if(isset($data['openId'])) {
- if($request->input('bind')) {
- $token = $request->header('X-Token');
- $user = User::where('token', $token)->first();
- if(!$user) return $this->error(['msg' => '找不到用户']);
- } else {
- $user = User::firstOrCreate([
- 'open_id' => $data['openId']
- ], [
- 'name' => $data['nickName'],
- 'nickname' => $data['nickName'],
- 'avatar' => $data['avatarUrl']
- ]);
- if(empty($user)) return $this->error(['msg' => '用户不存在,请先绑定账户']);
- }
- $union_id = isset($data['unionId']) ? $data['unionId'] : $user->union_id;
- $user->update([
- 'nickname' => $data['nickName'],
- 'avatar' => $data['avatarUrl'],
- 'union_id' => $union_id
- ]);
- $user->updateToken();
- $user = $user->getUserInfo($session_key);
- return $this->success(['data' => $user]);
- }
- }
- return $this->error(['msg' => '登陆失败']);
- }
- public function parsePhone(Request $request)
- {
- $app = app('wechat.mini_program');
- $session_key = $request->input('session_key');
- if(!$session_key && $request->input('code')) {
- $res = $app->auth->session($request->input('code'));
- if(isset($res['session_key'])) $session_key = $res['session_key'];
- }
- if($session_key) {
- $data = $app->encryptor->decryptData($session_key, $request->input('iv'), $request->input('encryptedData'));
- if(isset($data['phoneNumber'])) {
- $user = Auth::guard('mini')->user();
- $user->update(['phone' => $data['phoneNumber']]);
- $user = $user->getUserInfo($session_key);
- return $this->success(['data' => $user]);
- }
- return $this->error(['msg' => '获取失败']);
- }
- return $this->error(['msg' => '获取失败']);
- }
- public function reset(Request $request)
- {
- $user = User::where('phone', $request->input('phone'))->first();
- if(!$user) return $this->error(['msg' => '账号不存在']);
- UserReset::create([
- 'user_id' => $user->id,
- 'phone' => $request->input('phone'),
- 'name' => $request->input('name')
- ]);
- return $this->success();
- }
- public function getUserInfo()
- {
- $user = Auth::guard('mini')->user();
- $user->avatar = $user->avatar ? $user->avatar : 'https://t18.9026.com/mini/default-user.png';
- $user = $user->getUserInfo();
- return $this->success(['data' => $user]);
- }
- }
|