// +---------------------------------------------------------------------- namespace app\controller\api\v2\wechat; use app\Request; use app\services\wechat\RoutineServices; use crmeb\services\CacheService; /** * Class Routine * @package app\controller\api\v2\wechat */ class Routine { protected $services = NUll; /** * AuthController constructor. * @param RoutineServices $services */ public function __construct(RoutineServices $services) { $this->services = $services; } /** * 返回用户信息的缓存key,返回是否强制绑定手机号 * @param $code * @param $spread_code * @param $spread_spid * @return \think\Response */ public function authType($code, $spread_code = '', $spread_spid = '') { if (!$code) return app('json')->fail('参数有误'); $data = $this->services->authType($code, $spread_spid, $spread_code); return app('json')->success($data); } /** * 根据缓存获取token * @param $key * @return \think\Response */ public function authLogin($key) { if (!$key) return app('json')->fail('参数有误'); $data = $this->services->authLogin($key); return app('json')->success($data); } /** * @param $key * @param $phone * @param $captcha * @param $spread_code * @param $spread_spid * @param $code * @return \think\Response * @throws \Psr\SimpleCache\InvalidArgumentException */ public function phoneLogin($key = '', $phone = '', $captcha = '', $spread_code = '', $spread_spid = '', $code = '') { //验证验证码 $verifyCode = CacheService::get('code_' . $phone); if (!$verifyCode) return app('json')->fail('请先获取验证码'); $verifyError = (int)CacheService::get('code_error_' . $phone); if ($verifyError >= 10) { return app('json')->fail('请稍后在获取'); } $verifyCode = substr($verifyCode, 0, 6); if ($verifyCode != $captcha) { CacheService::set('code_error_' . $phone, $verifyError + 1, 180); return app('json')->fail('验证码错误'); } CacheService::delete('code_' . $phone); CacheService::delete('code_error_' . $phone); $data = $this->services->phoneLogin($key, $phone, $spread_spid, $spread_code, $code); return app('json')->success($data); } /** * 小程序绑定手机号 * @param $code * @param $iv * @param $encryptedData * @return \think\Response */ public function bindingPhone($code = '', $iv = '', $encryptedData = '') { if (!$code || !$iv || !$encryptedData) return app('json')->fail('参数有误'); $this->services->bindingPhone($code, $iv, $encryptedData); return app('json')->success(410016); } /** * 小程序授权登录 * @param Request $request * @return mixed * @throws \Psr\SimpleCache\InvalidArgumentException * @throws \think\db\exception\DataNotFoundException * @throws \think\db\exception\ModelNotFoundException * @throws \think\exception\DbException */ public function auth(Request $request) { [$code, $spread_spid, $spread_code, $iv, $encryptedData] = $request->postMore([ ['code', ''], ['spread_spid', 0], ['spread_code', ''], ['iv', ''], ['encryptedData', ''], ], true); $token = $this->services->newAuth($code, $spread_spid, $spread_code, $iv, $encryptedData); if ($token) { if (isset($token['key']) && $token['key']) { return app('json')->successful('授权成功,请绑定手机号', $token); } else { return app('json')->successful('登录成功!', ['token' => $token['token'], 'userInfo' => $token['userInfo'], 'expires_time' => $token['params']['exp'], 'store_user_avatar' => $token['store_user_avatar'] ?? 0]); } } else return app('json')->fail('获取用户访问token失败!'); } /** * 静默授权 * @param $code * @param $spread * @return mixed */ public function silenceAuth($code, $spread_code = '', $spread_spid = '') { $token = $this->services->silenceAuth($code, (int)$spread_code, (int)$spread_spid); if ($token && isset($token['key'])) { return app('json')->success('授权成功,请绑定手机号', $token); } else if ($token) { return app('json')->success('登录成功', ['token' => $token['token'], 'expires_time' => $token['params']['exp'], 'store_user_avatar' => $token['store_user_avatar'] ?? 0]); } else return app('json')->fail('登录失败'); } /** * 静默授权 不登录 * @param $code * @param $spread * @return mixed */ public function silenceAuthNoLogin($code, $spread_code = '', $spread_spid = '') { $token = $this->services->silenceAuth($code, (int)$spread_code, (int)$spread_spid, true); if ($token && isset($token['auth_login'])) { return app('json')->success('授权成功'); } else if ($token) { return app('json')->success('登录成功', ['token' => $token['token'], 'userInfo' => $token['userInfo'], 'expires_time' => $token['params']['exp'], 'store_user_avatar' => $token['store_user_avatar'] ?? 0]); } else return app('json')->fail('登录失败'); } /** * 静默授权 * @param $code * @param $spread * @return mixed */ public function silenceAuthBindingPhone($code = '', $spread_code = '', $spread_spid = '', $phone = '', $captcha = '') { //验证验证码 $verifyCode = CacheService::get('code_' . $phone); if (!$verifyCode) return app('json')->fail('请先获取验证码'); $verifyError = (int)CacheService::get('code_error_' . $phone); if ($verifyError >= 10) { return app('json')->fail('请稍后在获取'); } $verifyCode = substr($verifyCode, 0, 6); if ($verifyCode != $captcha) { CacheService::delete('code_' . $phone); CacheService::set('code_error_' . $phone, $verifyError + 1, 180); return app('json')->fail('验证码错误'); } $token = $this->services->silenceAuthBindingPhone($code, $spread_code, $spread_spid, $phone); if ($token) { CacheService::delete('code_' . $phone); CacheService::delete('code_error_' . $phone); return app('json')->success('登录成功', ['token' => $token['token'], 'expires_time' => $token['params']['exp'], 'store_user_avatar' => $token['store_user_avatar'] ?? 0]); } else return app('json')->fail('登录失败'); } /** * 授权获取小程序用户手机号 直接绑定 * @param $code * @param $iv * @param $encryptedData * @return mixed */ public function authBindingPhone($code = '', $iv = '', $encryptedData = '', $spread_code = '', $spread_spid = '', $key = '') { if (!$code || !$iv || !$encryptedData) return app('json')->fail('参数有误'); $token = $this->services->authBindingPhone($code, $iv, $encryptedData, $spread_code, $spread_spid, $key); if ($token) { return app('json')->success('登录成功', $token); } else return app('json')->fail('登录失败'); } /** * 更新用户信息 * @param $userInfo * @return mixed */ public function updateInfo(Request $request, $userInfo) { if (!$userInfo) { return app('json')->fail('参数有误'); } $uid = (int)$request->uid(); $re = $this->services->updateUserInfo($uid, $userInfo); if ($re) { return app('json')->success('更新成功'); } else return app('json')->fail('更新失败'); } }