QappUserService.php 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317
  1. <?php
  2. namespace App\Modules\User\Services;
  3. use App\Cache\Lock\LockCache;
  4. use App\Consts\ErrorConst;
  5. use App\Consts\QuickConst;
  6. use App\Jobs\Push\NewUserPushMsgDelay;
  7. use App\Jobs\QappTikTok\QappTikTokUserRequest;
  8. use App\Jobs\QappTikTok\QappTikTokUser;
  9. use App\Libs\Utils;
  10. use App\Modules\Report\Services\ReportService;
  11. use App\Modules\SendOrder\Services\SendOrderService;
  12. use App\Modules\User\Models\QappPackage;
  13. use App\Modules\User\Models\QappUser;
  14. use App\Modules\User\Models\User;
  15. use App\Modules\UserTask\Services\BaseTask;
  16. use App\Modules\UserTask\Services\UserTaskService;
  17. use Exception;
  18. use Illuminate\Support\Facades\DB;
  19. use Tymon\JWTAuth\Facades\JWTAuth;
  20. /**
  21. *
  22. */
  23. class QappUserService
  24. {
  25. /**
  26. * 登录
  27. */
  28. public function login(array $data)
  29. {
  30. $codeVersion = getProp($data, 'codeVersion');
  31. $lockToken = '';
  32. $isNewRegister = false;
  33. $device_no = $data['device_no'];
  34. $channel_id = $this->findChannelId($data['package']);
  35. $qapp_user = $this->getQAppUserByDeviceNo($device_no, $channel_id);
  36. if (!$qapp_user) {
  37. // 判断版本号,大于等于1.0.0才做处理
  38. if (version_compare($codeVersion, '1.0.0', '>=')) {
  39. // 加锁3秒,否则报错
  40. $lockToken = md5($device_no . ':' . $channel_id);
  41. $lock = LockCache::getLock($lockToken, 3);
  42. if (!$lock) {
  43. Utils::throwError(ErrorConst::QAPP_LOGIN_FREQUENTLY);
  44. }
  45. }
  46. myLog('login')->info('register', compact('codeVersion', 'device_no', 'channel_id', 'lockToken'));
  47. if($data['package'] == 'com.app.kyy.xnyd'){
  48. //return [];
  49. }
  50. // 初始化新用户
  51. $isNewRegister = true;
  52. $qapp_user = $this->createQuickAppUser($data);
  53. }
  54. if ($qapp_user) {
  55. try {
  56. if(!isset($qapp_user->user) || empty($qapp_user->user)){
  57. myLog('login')->info('undefined:qapp_user:user:error:device_no'.$device_no.' channel_id'.$channel_id.' time:'.date('Y-m-d H:i:s'));
  58. usleep(500000);
  59. $qapp_user = $this->getQAppUserByDeviceNo($device_no, $channel_id);
  60. }
  61. $user = $qapp_user->user;
  62. $uid = $user->id;
  63. $time = strtotime("+1 month");
  64. $token = JWTAuth::fromUser($user);
  65. if ($data['send_order_id']) {
  66. $result = SendOrderService::recordUserSendOrder($uid, $data['send_order_id']);
  67. if($result){
  68. UserService::setUserSendOrder((int)$uid, (int)$data['send_order_id']);
  69. }
  70. }
  71. // 新注册统计
  72. if ($isNewRegister && $qapp_user) {
  73. // 注册统计
  74. QappAddDeskTopService::incrAddDeskTop($uid, QuickConst::FIELD_REGISTER);
  75. }
  76. myLog('login')->info('uid:'.$uid.'-token:'.$token);
  77. return compact('token', 'time', 'uid');
  78. } catch (\Exception $e) {
  79. myLog('login')->info('getQAppUserByDeviceNo:error:'.$e->getMessage());
  80. }
  81. } else {
  82. return [];
  83. }
  84. }
  85. public function getGolableUser()
  86. {
  87. $qapp_user = app()->make('qapp_user');
  88. return $qapp_user;
  89. }
  90. /**
  91. * 注销用户
  92. * @param $uid
  93. * @return bool
  94. */
  95. public function getLogOff($uid)
  96. {
  97. $user = QappUser::getUserByUid($uid);
  98. if($user && $user->status == 1){
  99. $res = QappUser::where('uid',$uid)->update(['status' => 0, 'updated_at' => date('Y-m-d H:i:s')]);
  100. if(!$res){
  101. return false;
  102. }
  103. }
  104. return true;
  105. }
  106. /**
  107. * 绑定手机号
  108. * 多个账号可以绑定一个手机号
  109. */
  110. public function bindPhone(int $uid, string $phone, string $version = "1.0")
  111. {
  112. $qapp_user = QappUser::where('uid', $uid)->first();
  113. if ($qapp_user->phone && $qapp_user->phone != $phone) {
  114. return false;
  115. } else {
  116. try {
  117. DB::beginTransaction();
  118. if (!$qapp_user->phone) {
  119. $reward = 100;
  120. if ($version == "1.0") {
  121. User::where('id', $uid)->update(
  122. [
  123. 'balance' => DB::raw('balance+' . $reward),
  124. 'reward_balance' => DB::raw('reward_balance+' . $reward)
  125. ]
  126. );
  127. } else {
  128. UserTaskService::addUserTaskQueue($uid, BaseTask::bind_phone, UserTaskService::add_trigger);
  129. }
  130. }
  131. $qapp_user->phone = $phone;
  132. $qapp_user->save();
  133. DB::commit();
  134. } catch (Exception $e) {
  135. myLog('bindPhone')->error($e->getMessage());
  136. }
  137. return true;
  138. }
  139. }
  140. public function setGolableUser(int $uid, string $package)
  141. {
  142. // \Log::info('setGolableUser:'.$uid);
  143. $user_info = $this->getQAppUserByUid($uid, $package);
  144. $qapp_user = app()->make('qapp_user');
  145. $qapp_user->id = $user_info->id;
  146. $qapp_user->uid = $user_info->uid;
  147. $qapp_user->send_order_id = $user_info->send_order_id;
  148. $qapp_user->device_no = $user_info->device_no;
  149. $qapp_user->device_info = $user_info->device_info;
  150. $qapp_user->phone = $user_info->phone;
  151. $qapp_user->user = $user_info->user;
  152. $qapp_user->app_pay_merchat_id = $user_info->app_pay_merchat_id;
  153. $qapp_user->h5_pay_merchat_id = $user_info->h5_pay_merchat_id;
  154. $qapp_user->ali_pay_merchat_id = $user_info->ali_pay_merchat_id;
  155. $qapp_user->status = $user_info->status;
  156. // \Log::info('setGolableUser_uid:'.$uid.' data:'.json_encode($this->getGolableUser()));
  157. }
  158. /**
  159. * 根据设备号获取快应用用户信息
  160. */
  161. public function getQAppUserByDeviceNo(string $device_no, int $channel_id)
  162. {
  163. $qapp_user = QappUser::where('device_no', $device_no)->where('channel_id', $channel_id)->first();
  164. if ($qapp_user) {
  165. $user = User::find($qapp_user->uid);
  166. $qapp_user->user = $user;
  167. if(empty($user->id)){
  168. myLog('qapp_user_register')->info($device_no.'--'.$channel_id.'--'.json_encode($qapp_user));
  169. }
  170. }else{
  171. myLog('qapp_user_register')->info('qapp_user:no:'.$device_no.'--'.$channel_id);
  172. }
  173. return $qapp_user;
  174. }
  175. /**
  176. * 根据uid获取快应用用户信息
  177. * @param int $uid
  178. * @param string $package
  179. * @return mixed
  180. */
  181. public function getQAppUserByUid(int $uid, string $package = '')
  182. {
  183. $qapp_user = QappUser::where('uid', $uid)->first();
  184. if ($qapp_user) {
  185. $user = User::find($uid);
  186. $qapp_user->user = $user;
  187. $qapp_user->send_order_id = UserService::getUserSendOrder($uid);
  188. // 针对聚裕的包无法支付的问题(注册时传入了仙女阅读的包名,导致支付时取的支付信息不一致)
  189. if ($package && $package === 'com.juyu.kuaiying.rmyq') {
  190. $package_info = QappPackage::where('package', $package)->first();
  191. } else {
  192. $package_info = QappPackage::where('channel_id', $user->distribution_channel_id)->first();
  193. }
  194. // 支付id
  195. $qapp_user->app_pay_merchat_id = $package_info->app_pay_merchat_id;
  196. $qapp_user->h5_pay_merchat_id = $package_info->h5_pay_merchat_id;
  197. $qapp_user->ali_pay_merchat_id = $package_info->ali_pay_merchat_id;
  198. }
  199. return $qapp_user;
  200. }
  201. /**
  202. * 创建快应用用户信息
  203. */
  204. public function createQuickAppUser(array $data)
  205. {
  206. try {
  207. DB::beginTransaction();
  208. $user = $this->createUser($data);
  209. $channel_id = $user->distribution_channel_id;
  210. $qapp_user = QappUser::firstOrCreate([
  211. 'device_no' => $data['device_no'],
  212. 'channel_id' => $channel_id,
  213. ], [
  214. 'imei' => $data['imei'],
  215. 'androidid' => $data['androidid'],
  216. 'mac' => $data['mac'],
  217. 'uid' => $user->id,
  218. 'device_info' => $data['device_info'],
  219. ]);
  220. $qapp_user->user = $user;
  221. if (empty($user->id) || empty($qapp_user->id)) {
  222. myLog('qapp_user_register')->info(json_encode($data));
  223. DB::rollback();
  224. return false;
  225. }
  226. DB::commit();
  227. $this->syncHandle($user, $data);
  228. return $qapp_user;
  229. } catch (Exception $e) {
  230. DB::rollback();
  231. myLog('create_user')->error($e->getMessage());
  232. }
  233. }
  234. /**
  235. * 新用户异步处理数据
  236. */
  237. private function syncHandle(User $user, array $data)
  238. {
  239. // 队列处理回传业务
  240. try {
  241. $tikTokRegisterRequest = new QappTikTokUserRequest();
  242. $tikTokRegisterRequest->ip = $user->register_ip;
  243. $tikTokRegisterRequest->device_no = $data['device_no'];
  244. $tikTokRegisterRequest->mac = $data['mac'];
  245. $tikTokRegisterRequest->channel_id = $user->distribution_channel_id;
  246. $tikTokRegisterRequest->uid = $user->id;
  247. $tikTokRegisterRequest->register_time = $user->created_at->format('Y-m-d H:i:s');
  248. $tikTokRegisterRequest->send_order_id = $data['send_order_id'];
  249. myLog('qapp_register')->info('', compact('tikTokRegisterRequest'));
  250. $start = time();
  251. // 回传业务
  252. $job = new QappTikTokUser($tikTokRegisterRequest);
  253. dispatch($job->onConnection('redis_queue')->onQueue('{qapp_tiktok_user_register_queue}'));
  254. $time = time() - $start;
  255. if ($time >= 1 ){
  256. myLog('mq-put-timeout')->info("注册qapp_tiktok_user_register_queue-mq-投递超过1耗时".$time."s;路径:app/Modules/User/Services/QappUserService.php 270行");
  257. }
  258. $start = time();
  259. UserTaskService::addUserTaskQueue($user->id, BaseTask::register, UserTaskService::add_trigger);
  260. $job = new NewUserPushMsgDelay($user->id);
  261. dispatch($job->onConnection('redis_queue')->onQueue('{new_user_push_msg}'));
  262. $time = time() - $start;
  263. if ($time >= 1 ){
  264. myLog('mq-put-timeout')->info("注册new_user_push_msg-mq-投递超过1耗时".$time."s;路径:app/Modules/User/Services/QappUserService.php 279行");
  265. }
  266. // 同步数据
  267. $user->channel_id = $user->distribution_channel_id;
  268. // ReportService::reportRegister($user); // 取消上报
  269. }catch (Exception $exception){
  270. // \Log::info('login_fail_user_syncHandle_error_data:',$data);
  271. // \Log::info('login_fail_user_syncHandle_error_msg:'.$exception->getMessage());
  272. }
  273. }
  274. private function findChannelId(string $package)
  275. {
  276. $channel_id = env('QUICKAPP_SITE');
  277. if ($package) {
  278. $package_info = QappPackage::where('package', $package)->first();
  279. $channel_id = $package_info ? $package_info->channel_id : $channel_id;
  280. }
  281. return $channel_id;
  282. }
  283. /**
  284. * 创建用户
  285. */
  286. private function createUser(array $data): User
  287. {
  288. $openid = $data['device_no'];
  289. $unionid = $data['device_no'];
  290. $register_ip = _getIp();
  291. $distribution_channel_id = $this->findChannelId($data['package']);
  292. $send_order_id = $data['send_order_id'];
  293. $unique_key = compact('unionid', 'distribution_channel_id');
  294. $data = compact('openid', 'register_ip', 'send_order_id');
  295. return User::firstOrCreate($unique_key, $data);
  296. }
  297. }