User.php 46 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412
  1. <?php
  2. namespace app\api\controller\v1;
  3. use app\api\services\UserServices;
  4. use app\common\model\ActiveLogModel;
  5. use app\common\model\BoxRecordModel;
  6. use app\common\model\CouponnumLogModel;
  7. use app\common\model\MedalLogModel;
  8. use app\common\model\MoneyLogModel;
  9. use app\common\model\PaymentModel;
  10. use app\common\model\RedStorePoolModel;
  11. use app\common\model\ScoreAwayLogModel;
  12. use app\common\model\ScoreLock1LogModel;
  13. use app\common\model\ScorelockLogModel;
  14. use app\common\model\ScoreLog;
  15. use app\common\model\ScoreLogModel;
  16. use app\common\model\SuggestModel;
  17. use app\common\model\TzLogModel;
  18. use app\common\model\UserDataModel;
  19. use app\common\model\UserModel;
  20. use app\common\model\UserMoneyModel;
  21. use app\common\model\UserUnmoneyModel;
  22. use app\common\model\WithDrawLogModel;
  23. use app\common\model\XzLogModel;
  24. use app\common\service\ShopGoodsService;
  25. use app\model\UserWithdrawalModel;
  26. use app\Request;
  27. use app\api\validate\UserValidate;
  28. use jobs\UserJobs;
  29. use think\cache\driver\Redis;
  30. use think\Exception;
  31. use think\exception\ValidateException;
  32. use think\facade\Db;
  33. use utils\Queue;
  34. use function Sodium\library_version_minor;
  35. class User
  36. {
  37. protected $service = null;
  38. public function __construct( UserServices $services)
  39. {
  40. $this->service = $services;
  41. }
  42. // 用户注册
  43. public function register(Request $request)
  44. {
  45. // 这是测试 上线要干掉
  46. // echo '网站正在更新';
  47. // die();
  48. $params = $request->post();
  49. try {
  50. validate(UserValidate::class)->scene('register')->check($params);
  51. if (!vertifyPass(AESjiemi($params['password']))){
  52. throw new Exception('密码必须包含字母和数字,长度大于8位');
  53. }
  54. if (!vertifyUserName($params['user_name'])){
  55. throw new Exception('用户名必须包含字母和数字,长度大于6位小于15位');
  56. }
  57. $params['password'] = AESjiemi($params['password']);
  58. return api_succ_return($this->service->userRegister($params));
  59. }catch (ValidateException $e){
  60. return api_error_return($e->getMessage());
  61. }catch (Exception $e){
  62. return api_error_return($e->getMessage());
  63. }
  64. }
  65. // 注册获取上级信息
  66. public function registerUpUser(Request $request, UserModel $model){
  67. Db::startTrans();
  68. try {
  69. // $scanCode = AESjiemi($request->post('scan_code'));
  70. $scanCode = $request->post('scan_code');
  71. if (empty($scanCode) || !$scanCode){
  72. return api_error_return('参数错误');
  73. }
  74. $params = getUrlParams($scanCode);
  75. $is_px = false;
  76. $upuser = $model->where('code', $params['code'])->field('nickname,mobile,px_code,code,avatar')->withAttr('avatar', function($val, $data){
  77. return __HTTPIMG($val);
  78. })->find();
  79. if (!$upuser){
  80. $upuser = $model->where('px_code', $params['code'])->field('nickname,px_code,code,avatar,mobile')->withAttr('avatar', function($val, $data){
  81. return __HTTPIMG($val);
  82. })->find();
  83. $is_px = true;
  84. }
  85. if (!$upuser){
  86. return api_error_return('查询失败,暂无用户');
  87. }
  88. $upuser['mobile'] = substr($upuser['mobile'], 0, 3).'****'.substr($upuser['mobile'], 7);
  89. $upuser['share_way'] = $is_px?2:1;
  90. Db::commit();
  91. }catch (\Exception $e){
  92. Db::rollback();
  93. return api_error_return($e->getMessage());
  94. }
  95. // if ($upuser){
  96. // return api_succ_return(['msg'=>'成功', 'data'=>['user'=>$upuser]]);
  97. // }else{
  98. // return api_error_return('查询失败,暂无用户');
  99. // }
  100. return api_succ_return(['msg'=>'成功', 'data'=>['user'=>$upuser]]);
  101. }
  102. // 退出登录
  103. public function logout(Request $request){
  104. Db::startTrans();
  105. try {
  106. // Db::name('user')->where('id', $request->uid)->save(['jg_regid'=>'']);
  107. Db::commit();
  108. }catch (\Exception $e){
  109. Db::rollback();
  110. }
  111. return api_succ_return('成功');
  112. }
  113. // 登录
  114. public function login(Request $request){
  115. $curandroid = env('app.CUR_ANDROID_VERSION', '');
  116. $curios = env('app.CUR_IOS_VERSION', '');;
  117. $curAndroidVersion = str_replace('.', '', $curandroid);
  118. $curAndroidVersion = dispRepair($curAndroidVersion, 4, '0', '0');
  119. $curIosVersion = str_replace('.', '', $curios);
  120. $curIosVersion = dispRepair($curIosVersion, 4, '0', '0');
  121. $app_sources = $request->param('app_sources');
  122. $app_version = $request->param('app_version');
  123. $app_version = str_replace('.', '', $app_version);
  124. $app_version = dispRepair($app_version, 4, '0', '0');
  125. // if ($app_sources == 'ios'){
  126. // if ($curIosVersion > $app_version){
  127. // return api_error_return('app版本号过低,请更新');
  128. // }
  129. // }
  130. // if ($app_sources == 'ios'){
  131. // if ($curIosVersion > $app_version){
  132. // return api_error_return('苹果app版本更新会尽快通知,敬请期待!');
  133. // }
  134. // }
  135. // if ($app_sources == 'android'){
  136. // if ($curAndroidVersion > $app_version){
  137. // return api_error_return('app版本号过低,请更新');
  138. // }
  139. // }
  140. $param = $request->param();
  141. //var_dump($param);
  142. Db::startTrans();
  143. try {
  144. validate(UserValidate::class)->scene('login')->check($param);
  145. $data = $this->service->userLogin($param);
  146. Db::commit();
  147. return api_succ_return($data);
  148. }catch (ValidateException $e){
  149. Db::rollback();
  150. return api_error_return($e->getMessage());
  151. }catch (Exception $e){
  152. Db::rollback();
  153. return api_error_return(['msg'=>$e->getMessage(), 'code'=>$e->getCode()]);
  154. }
  155. }
  156. // 编辑用户信息
  157. public function editUserInfo(Request $request){
  158. $param = $request->param();
  159. try {
  160. // validate(UserValidate::class)->scene('editUserInfo')->check($param);
  161. //
  162. return api_succ_return($this->service->setUserInfo($request->uid, $param));
  163. }catch (Exception $e){
  164. return api_error_return(['msg'=>$e->getMessage(), 'code'=>$e->getCode()]);
  165. }
  166. }
  167. // 编辑用户信息
  168. public function setSellerPayWay(Request $request){
  169. $param = $request->param();
  170. try {
  171. // validate(UserValidate::class)->scene('editUserInfo')->check($param);
  172. return api_succ_return($this->service->setSellerPayWay($request->uid, $param));
  173. }catch (Exception $e){
  174. return api_error_return(['msg'=>$e->getMessage(), 'code'=>$e->getCode()]);
  175. }
  176. }
  177. // 用户信息
  178. public function userInfo(Request $request, UserModel $model)
  179. {
  180. Db::startTrans();
  181. try {
  182. $post = $request->param();
  183. $user = $model->getUserDetailByUid($request->uid);
  184. $time = time();
  185. // $user['avatar'] .= '?' . $time;
  186. // $user['avatar'] = __HTTPIMG($user['avatar']);
  187. // $user['avatar'] = $user['avatar']=='static/img/user/default_avatar.jpg'?__HTTPLOCALIMG($user['avatar']) :__HTTPIMG($user['avatar']);
  188. // unset($user['id']);
  189. // 卷轴任务不隐藏(新用户隐藏 老用户不隐藏 ,userinfo 后台返回一个字段来控制)
  190. unset($user['password']);
  191. unset($user['status']);
  192. unset($user['login_count']);
  193. unset($user['login_ip']);
  194. unset($user['login_time']);
  195. // unset($user['getinfo_count']);
  196. // Db::name('user')->where('id', $request->uid)->inc('getinfo_count', 1)->update();
  197. Db::commit();
  198. return api_succ_return(['msg'=>'个人信息获取成功', 'data'=>$user]);
  199. }catch (\Exception $e){
  200. Db::rollback();
  201. return api_error_return($e->getMessage());
  202. }
  203. }
  204. // 修改登录密码
  205. public function editLoginPass(Request $request, UserModel $model)
  206. {
  207. try {
  208. return $model->editLoginPass($request);
  209. }catch (\Exception $e){
  210. return api_error_return($e->getMessage());
  211. }
  212. }
  213. // 修改安全密码
  214. public function editSecurityPass(Request $request, UserModel $model)
  215. {
  216. try {
  217. return $model->editSecurityPass($request);
  218. }catch (\Exception $e){
  219. return api_error_return($e->getMessage());
  220. }
  221. }
  222. // 余额记录
  223. public function moneyLog (Request $request, MoneyLogModel $model)
  224. {
  225. try {
  226. return api_succ_return(['msg'=>'成功', 'data'=>$model->getLog($request)]);
  227. } catch (\Exception $e) {
  228. return api_error_return('失败');
  229. }
  230. }
  231. // 积分记录
  232. public function scoreLog (Request $request, ScoreLogModel $model)
  233. {
  234. try {
  235. return api_succ_return(['msg'=>'成功', 'data'=>$model->getLog($request)]);
  236. } catch (\Exception $e) {
  237. return api_error_return('失败');
  238. }
  239. }
  240. // jh记录
  241. public function jhLog (Request $request, TzLogModel $model)
  242. {
  243. try {
  244. return api_succ_return(['msg'=>'成功', 'data'=>$model->getLog($request)]);
  245. } catch (\Exception $e) {
  246. return api_error_return('失败');
  247. }
  248. }
  249. // 福利积分记录
  250. public function scoreAwayLog (Request $request, ScoreAwayLogModel $model)
  251. {
  252. try {
  253. return api_succ_return(['msg'=>'成功', 'data'=>$model->getLog($request)]);
  254. } catch (\Exception $e) {
  255. return api_error_return('失败');
  256. }
  257. }
  258. public function scoreLockLog (Request $request, ScoreLock1LogModel $model)
  259. {
  260. try {
  261. return api_succ_return(['msg'=>'成功', 'data'=>$model->getLog($request)]);
  262. } catch (\Exception $e) {
  263. return api_error_return('失败');
  264. }
  265. }
  266. // 抢购值记录
  267. public function couponNumLog (Request $request, CouponnumLogModel $model)
  268. {
  269. try {
  270. return api_succ_return(['msg'=>'成功', 'data'=>$model->getLog($request)]);
  271. } catch (\Exception $e) {
  272. return api_error_return('失败');
  273. }
  274. }
  275. // 星钻记录
  276. public function xzLog (Request $request, XzLogModel $model)
  277. {
  278. try {
  279. return api_succ_return(['msg'=>'成功', 'data'=>$model->getLog($request)]);
  280. } catch (\Exception $e) {
  281. return api_error_return('失败');
  282. }
  283. }
  284. // 勋章记录
  285. public function medalLog (Request $request, MedalLogModel $model)
  286. {
  287. try {
  288. return api_succ_return(['msg'=>'成功', 'data'=>$model->getLog($request)]);
  289. } catch (\Exception $e) {
  290. return api_error_return('失败');
  291. }
  292. }
  293. // 团队数据
  294. public function teamData(Request $request, UserModel $model){
  295. try {
  296. // return $model->getFansData($request->uid);
  297. return api_succ_return(['msg'=>'成功', 'data'=>$model->getFansData($request->uid)]);
  298. } catch (\Exception $e) {
  299. return api_error_return($e->getMessage());
  300. }
  301. }
  302. // 团队列表
  303. public function teamList(Request $request, UserModel $model){
  304. try {
  305. return api_succ_return(['msg'=>'成功', 'data'=>$model->getFansList($request->uid, $request->post('limit'), $request->post('type'), $request->post('keyword'))]);
  306. } catch (\Exception $e) {
  307. return api_error_return($e->getMessage());
  308. }
  309. }
  310. // 团队信息
  311. public function teamInfo(Request $request){
  312. $uid = $request->uid;
  313. $display_ids = env('app.NOT_OPEN_GOODS_ID');
  314. $has_display = false;
  315. if (strpos($display_ids, strval($uid)) !== false){
  316. $has_display = true;
  317. }
  318. $data = [
  319. 'zt_valid'=>Db::name('user')->where('pid', $uid)->where('has_fd', 1)->count('id'),
  320. 'zt_total'=>Db::name('user')->where('pid', $uid)->count('id'),
  321. 'zt_teamtotal'=>Db::name('user')->whereFindInSet('path', $uid)->count('id'),
  322. 'zt_teamvalid'=>Db::name('user')->whereFindInSet('path', $uid)->where('has_fd', 1)->count('id'),
  323. 'display_str' => $has_display?('团队总充值:'.$request->user_info['total_team_income'].',团队总提现:'.$request->user_info['total_team_withdraw']):''
  324. ];
  325. return api_succ_return(['msg'=>'成功', 'data'=>$data]);
  326. }
  327. // 直推列表
  328. public function directListData(Request $request, UserModel $model){
  329. try {
  330. return api_succ_return(['msg'=>'成功', 'data'=>$model->getDirectDataList($request->uid, $request->post('is_auth'), $request->post('limit'), $request->post('keyworld'))]);
  331. }catch (Exception $e){
  332. return api_error_return($e->getMessage());
  333. }
  334. }
  335. // 活跃点明细
  336. public function activeLog(Request $request, ActiveLogModel $model){
  337. try {
  338. return api_succ_return(['msg'=>'成功', 'data'=>$model->getLog($request)]);
  339. }catch (Exception $e){
  340. return api_error_return($e->getMessage());
  341. }
  342. }
  343. // 反馈建议
  344. public function suggestSubmit(Request $request, SuggestModel $model){
  345. $post = $request->post();
  346. Db::startTrans();
  347. try {
  348. $model->insert([
  349. 'type'=>2,
  350. 'uid'=>$request->uid,
  351. 'created_time'=>sr_getcurtime(time()),
  352. 'content'=>$post['content']
  353. ]);
  354. Db::commit();
  355. }catch (\Exception $e){
  356. Db::rollback();
  357. return api_error_return('失败'.$e->getMessage());
  358. }
  359. return api_succ_return('成功');
  360. }
  361. // 用户升星
  362. public function upgradeLevel (Request $request, UserServices $services)
  363. {
  364. try {
  365. return $services->upgradeStar($request);
  366. } catch (Exception $e) {
  367. return api_succ_return(['code'=>$e->getCode(), 'msg'=>$e->getMessage()]);
  368. }
  369. }
  370. // 用户星钻升星
  371. public function upgradeXzLevel (Request $request, UserServices $services)
  372. {
  373. return api_error_return('success');
  374. if (!getServiceTop()){
  375. return api_error_return('success');
  376. }
  377. try {
  378. return $services->upgradeXzStar($request);
  379. } catch (Exception $e) {
  380. return api_succ_return(['code'=>$e->getCode(), 'msg'=>$e->getMessage()]);
  381. }
  382. }
  383. // 勋章兑换
  384. public function medalExchange (Request $request, UserModel $model)
  385. {
  386. $post = $request->post();
  387. Db::startTrans();
  388. try {
  389. $model->medalExchange($request->uid, $post['number']);
  390. Db::commit();
  391. }catch (\Exception $e){
  392. Db::rollback();
  393. // if ($e->getCode() == 399){
  394. // return api_error_return(['msg'=>'请设置安全密码', 'code'=>399]);
  395. // }
  396. return api_error_return($e->getMessage());
  397. }
  398. return api_succ_return('兑换成功');
  399. }
  400. // redPoolList
  401. public function redStorePoolList(Request $request, RedStorePoolModel $model)
  402. {
  403. try {
  404. // return $model->getUserStoreRedPoolList($request->uid, $request->post('limit'), $request, $request->post('page'));
  405. return api_succ_return(['msg'=>'获取成功', 'data'=>$model->getUserStoreRedPoolList($request->uid, $request->post('limit'), $request, $request->post('page'))]);
  406. } catch (\Exception $e) {
  407. return api_error_return('获取失败'.$e->getMessage());
  408. }
  409. }
  410. // 获取红包
  411. public function getStoreRed(Request $request, RedStorePoolModel $model)
  412. {
  413. if (!$request->data['id']){
  414. return api_error_return('参数错误');
  415. }
  416. Db::startTrans();
  417. try {
  418. $model->getStoreRed($request);
  419. Db::commit();
  420. } catch (Exception $e){
  421. Db::rollback();
  422. return api_error_return($e->getMessage());
  423. }
  424. return api_succ_return('领取成功');
  425. }
  426. // 提货券列表
  427. public function getLockScoreLog(Request $request, ScorelockLogModel $model){
  428. try {
  429. return api_succ_return(['msg'=>'成功', 'data'=>$model->getLog($request)]);
  430. } catch (\Exception $e) {
  431. return api_error_return('失败');
  432. }
  433. }
  434. // 积分兑换成余额
  435. public function scoreExchangeMoney(Request $request, UserModel $model){
  436. return api_error_return('兑换失败,此功能将在后续关闭');
  437. // 校验订单是否正确
  438. if (getSysOrderStatusBackError()){
  439. return api_error_return('订单校验失败,请联系客服');
  440. }
  441. Db::startTrans();
  442. try {
  443. $model->scoreExchangeMoney($request->uid, $request->post('score'));
  444. Db::commit();
  445. }catch (\Exception $e){
  446. Db::rollback();
  447. // if ($e->getCode() == 399){
  448. // return api_error_return(['msg'=>'请设置安全密码', 'code'=>399]);
  449. // }
  450. return api_error_return($e->getMessage());
  451. }
  452. return api_succ_return('兑换成功');
  453. }
  454. // 余额兑换成积分
  455. public function moneyExchangeScore(Request $request, UserModel $model){
  456. Db::startTrans();
  457. try {
  458. $model->moneyExchangescore($request->uid, $request->post('money'));
  459. Db::commit();
  460. }catch (\Exception $e){
  461. Db::rollback();
  462. return api_error_return($e->getMessage());
  463. }
  464. return api_succ_return('兑换成功');
  465. }
  466. // 分红任务包分红记录
  467. public function getRwMoneyLog(Request $request, UserMoneyModel $model){
  468. $type_conf = config('type.money');
  469. $list = $model->where('uid', $request->uid)
  470. ->where('type', 5)
  471. ->field('money,id,type,create_at,state')
  472. ->withAttr('type', function ($value, $data) use ($type_conf) {
  473. return isset($type_conf[$value]) ? $type_conf[$value] : '未知类型';
  474. })
  475. ->withAttr('create_at', function ($value, $data){
  476. return date("Y-m-d",strtotime($value));
  477. })
  478. ->order('create_at', 'desc')
  479. ->paginate($request->data['limit'])
  480. ->toArray();
  481. return api_succ_return(['msg'=>'成功', 'data'=>$list['data']]);
  482. }
  483. //视频开始播放
  484. public function openAdBegin(Request $request){
  485. // if (!getServiceTop()){
  486. // return api_error_return('优惠券抢购中,请稍后在试');
  487. // }
  488. // getUserDeny($request);
  489. Db::name('user')->where('id', $request->uid)->save(['today_task_down'=>2]);
  490. if (!Db::name('ad_finishlog')->where('uid', $request->uid)->where('type', 1)->whereDay('create_time', 'today')->find()){
  491. // 每日完成任务日志
  492. Db::name('ad_finishlog')->insert([
  493. 'uid'=>$request->uid,
  494. 'create_time'=>sr_getcurtime(time()),
  495. 'type'=>1
  496. ]);
  497. }
  498. return api_succ_return('成功');
  499. $type = $request->post('type');
  500. if (!in_array($type, [1])){
  501. return api_error_return('参数错误');
  502. }
  503. $sources = $request->post('app_sources');
  504. if ($sources == 'ios' || $sources == 'android'){
  505. // 苹果直接完成任务奖励
  506. // Db::name('user')->where('id', $request->uid)->save(['today_task_down'=>2]);
  507. if (!Db::name('ad_finishlog')->where('uid', $request->uid)->where('type', 1)->whereDay('create_time', 'today')->find()){
  508. // 每日完成任务日志
  509. Db::name('ad_finishlog')->insert([
  510. 'uid'=>$request->uid,
  511. 'create_time'=>sr_getcurtime(time()),
  512. 'type'=>1
  513. ]);
  514. }
  515. return api_succ_return('苹果手机用户直接领取奖励');
  516. }
  517. Db::startTrans();
  518. try {
  519. // 查询上一次成功间隔时间
  520. // $last_id = Db::name('ad_log')->where('uid', $request->uid)->where('status', 2)->whereDay('create_time', 'today')->max('id');
  521. // if (!empty($last_id)){
  522. // $info = Db::name('ad_log')->where('id', $last_id)->find();
  523. // if (time() - strtotime($info['end_time']) < 10){
  524. // throw new Exception('具体上次观看视频时间太短,请稍后在试^_^', 304);
  525. // }
  526. // }
  527. $rid = Db::name('ad_log')->insertGetId([
  528. 'uid'=>$request->uid,
  529. 'create_time'=>sr_getcurtime(time()),
  530. 'type'=> 1
  531. ]);
  532. Db::commit();
  533. }catch (\Exception $e){
  534. Db::rollback();
  535. if ($e->getCode() == 304){
  536. Db::name('adfauiler_log')->insert([
  537. 'uid'=>$request->uid,
  538. 'create_time'=>sr_getcurtime(time()),
  539. 'other'=>$type.'---'.'距离上次观看视频时间太短,请稍后在试^_^'
  540. ]);
  541. }
  542. return api_error_return($e->getMessage());
  543. }
  544. return api_succ_return(['msg'=>'成功', 'data'=>['order_id'=>$rid]]);
  545. }
  546. //视频结束播放
  547. public function openAdEnd(Request $request){
  548. // if (!getServiceTop()){
  549. // return api_error_return('优惠券抢购中,请稍后在试');
  550. // }
  551. return api_succ_return('成功');
  552. $order_id = $request->post('order_id');
  553. $info = Db::name('ad_log')->where('id', $order_id)->find();
  554. if (!$info){
  555. return api_error_return('参数错误');
  556. }
  557. if (time() - strtotime($info['create_time']) < 15){
  558. Db::name('adfauiler_log')->insert([
  559. 'uid'=>$request->uid,
  560. 'create_time'=>sr_getcurtime(time()),
  561. 'other'=>$request->ip()
  562. ]);
  563. return api_error_return('观看广告时间过短,请稍后在试');
  564. }
  565. Db::startTrans();
  566. try {
  567. Db::name('ad_log')->where('id', $order_id)->save(['status'=>2,'end_time'=>sr_getcurtime(time())]);
  568. Db::commit();
  569. }catch (\Exception $e){
  570. Db::rollback();
  571. return api_error_return($e->getMessage());
  572. }
  573. $count = Db::name('ad_log')->whereDay('create_time', 'today')->where('type', 1)->where('status', 2)->where('uid', $request->uid)->count();
  574. if ($count >= env('AD.ONE_DAY_TASK_NUM')){
  575. // Db::name('user')->where('id', $request->uid)->save(['today_task_down'=>2]);
  576. if (!Db::name('ad_finishlog')->where('uid', $request->uid)->where('type', 1)->whereDay('create_time', 'today')->find()){
  577. // 每日完成任务日志
  578. Db::name('ad_finishlog')->insert([
  579. 'uid'=>$request->uid,
  580. 'create_time'=>sr_getcurtime(time()),
  581. 'type'=>1
  582. ]);
  583. }
  584. }
  585. return api_succ_return(['msg'=>'成功']);
  586. }
  587. // 今日播放视频数据
  588. public function openAdTodayData(Request $request){
  589. $type = $request->post('type');
  590. $sources = $request->post('app_sources');
  591. if (!in_array($type, [1,2])){
  592. return api_error_return('参数错误');
  593. }
  594. return api_succ_return(['msg'=>'成功', 'data'=>['total'=>env('AD.ONE_DAY_TASK_NUM'),'today_count'=>env('AD.ONE_DAY_TASK_NUM')]]);
  595. Db::startTrans();
  596. try {
  597. $count = Db::name('ad_log')->whereDay('create_time', 'today')->where('type', $type)->where('status', 2)->where('uid', $request->uid)->count();
  598. if ($count>env('AD.ONE_DAY_TASK_NUM')){
  599. $count = env('AD.ONE_DAY_TASK_NUM');
  600. }
  601. if ($sources == 'ios'){
  602. $count = env('AD.ONE_DAY_TASK_NUM');
  603. }
  604. Db::commit();
  605. }catch (\Exception $e){
  606. Db::rollback();
  607. return api_error_return($e->getMessage());
  608. }
  609. return api_succ_return(['msg'=>'成功', 'data'=>['total'=>env('AD.ONE_DAY_TASK_NUM'),'today_count'=>$count]]);
  610. }
  611. //提现记录
  612. public function withdrawLog (Request $request, WithDrawLogModel $model)
  613. {
  614. try {
  615. return api_succ_return(['msg'=>'成功', 'data'=>$model->getLog($request)]);
  616. } catch (\Exception $e) {
  617. return api_error_return($e->getMessage());
  618. }
  619. }
  620. // 绑定提现账号
  621. public function bangWithdrawInfo(Request $request, UserServices $service)
  622. {
  623. Db::startTrans();
  624. try {
  625. $service->bangWithdrawInfo($request->uid, $request->post('type'), $request->post('number'), $request->post('name'));
  626. Db::commit();
  627. }catch (Exception $e){
  628. Db::rollback();
  629. return api_error_return($e->getMessage());
  630. }
  631. return api_succ_return('绑定成功');
  632. }
  633. // 解绑提现账号
  634. public function unBangWithdrawInfo(Request $request, UserServices $service)
  635. {
  636. Db::startTrans();
  637. try {
  638. $service->unbangWithdrawInfo($request->uid, $request->post('type'));
  639. Db::commit();
  640. }catch (Exception $e){
  641. Db::rollback();
  642. return api_error_return($e->getMessage());
  643. }
  644. return api_succ_return('解绑成功');
  645. }
  646. // 用户转赠提交
  647. public function exchargeSubmit(Request $request, UserServices $service){
  648. return api_error_return("星钻转赠以下线");
  649. $post = $request->post();
  650. if ($request->user['mobile'] == $post['mobile']){
  651. return api_error_return('不能给自己转赠');
  652. }
  653. Db::startTrans();
  654. try {
  655. $info = $service->exchargeSubmit($request->uid, $post['xz_num'], $post['mobile']);
  656. Db::commit();
  657. }catch (Exception $e){
  658. Db::rollback();
  659. return api_error_return($e->getMessage());
  660. }
  661. return api_succ_return(['msg'=>'请求成功', 'data'=>$info]);
  662. }
  663. // 用户转赠确认
  664. public function exchargeDone(Request $request, UserServices $service){
  665. $post = $request->post();
  666. Db::startTrans();
  667. try {
  668. getActionSecury($request->uid, $request->post('security_pass', ''));
  669. $info = $service->exchargeDone($request->uid, $post['xz_num'], $post['mobile']);
  670. Db::commit();
  671. }catch (Exception $e){
  672. Db::rollback();
  673. return api_error_return($e->getMessage());
  674. }
  675. return api_succ_return(['msg'=>'请求成功', 'data'=>$info]);
  676. }
  677. // 用户转赠提交
  678. public function exchargeMedalSubmit(Request $request, UserServices $service){
  679. $post = $request->post();
  680. if ($request->user['mobile'] == $post['mobile']){
  681. return api_error_return('不能给自己转赠');
  682. }
  683. Db::startTrans();
  684. try {
  685. $info = $service->exchargeMedalSubmit($request->uid, $post['medal_num'], $post['mobile']);
  686. Db::commit();
  687. }catch (Exception $e){
  688. Db::rollback();
  689. return api_error_return($e->getMessage());
  690. }
  691. return api_succ_return(['msg'=>'请求成功', 'data'=>$info]);
  692. }
  693. // 用户转赠确认
  694. public function exchargeMedalDone(Request $request, UserServices $service){
  695. $post = $request->post();
  696. Db::startTrans();
  697. try {
  698. getActionSecury($request->uid, $request->post('security_pass', ''));
  699. $info = $service->exchargeMedalDone($request->uid, $post['medal_num'], $post['mobile']);
  700. Db::commit();
  701. }catch (Exception $e){
  702. Db::rollback();
  703. // if ($e->getCode() == 399){
  704. // return api_error_return(['msg'=>'请设置安全密码', 'code'=>399]);
  705. // }
  706. return api_error_return($e->getMessage());
  707. }
  708. return api_succ_return(['msg'=>'请求成功', 'data'=>$info]);
  709. }
  710. // 用户播放视频报错
  711. public function watchAdError(Request $request, UserServices $service){
  712. $code = $request->post('error', '');
  713. $message = $request->post('error1', '');
  714. Db::startTrans();
  715. try {
  716. $error_codes = explode(',', env('APP.AD_ERROR_CODE'));
  717. $error_msgs = explode(',', env('APP.AD_ERROR_MESSAGE'));
  718. if (!(in_array($code, $error_codes) && in_array($message, $error_msgs))){
  719. if (!Db::name('ad_error_records')->where('uid', $request->uid)->where('error_code', $code)->where('status', 1)->find()){
  720. Db::name('ad_error_records')->insert([
  721. 'uid'=>$request->uid,
  722. 'error_code'=>$code,
  723. 'error_msg'=>$message,
  724. 'create_time'=>sr_getcurtime(time())
  725. ]);
  726. }
  727. }else{
  728. throw new Exception('请求失败');
  729. }
  730. Db::commit();
  731. }catch (\Exception $e){
  732. Db::rollback();
  733. return api_error_return($e->getMessage());
  734. }
  735. return api_succ_return(['msg'=>'加载广告失败,请直接领取任务包奖励', 'code'=>200]);
  736. }
  737. // 首页必读公告获取
  738. public function getHomeMsg(Request $request){
  739. $list = Db::name('system_article')->where('type', 9)->order('create_time desc')->select();
  740. $user = Db::name('user')->where('id', $request->uid)->find();
  741. foreach ($list as $key=>$val){
  742. if (!Db::name('article_get')->where('uid', $request->uid)->where('article_id', $val['id'])->find()){
  743. if ($user['reg_time'] < $val['create_time']){
  744. return api_succ_return(['msg'=>'成功','data'=> [$val]]);
  745. }
  746. }
  747. }
  748. return api_succ_return('成功');
  749. }
  750. // 用户消息已读
  751. public function getMsgDown(Request $request){
  752. $article_id = $request->post('article_id');
  753. if (Db::name('system_article')->where('id', $article_id)->where('type', 9)->find()){
  754. Db::name('article_get')->insert([
  755. 'uid'=>$request->uid,
  756. 'article_id'=>$article_id,
  757. 'create_time'=>sr_getcurtime(time())
  758. ]);
  759. }
  760. return api_succ_return('成功');
  761. }
  762. // 用户通知信息列表
  763. public function messageList(Request $request){
  764. $page = $request->post('page', 1);
  765. $limit = $request->post('limit', 10);
  766. return api_succ_return(['msg'=>'成功', 'data'=>Db::name('user_message')->where('uid', $request->uid)->page($page, $limit)->field('title,type,banner_desc,create_time,uid')->select()->toArray()]);
  767. }
  768. // 用户余额转赠提交
  769. public function moneyExchargeSubmit(Request $request, UserServices $service){
  770. $post = $request->post();
  771. if ($request->user['mobile'] == $post['mobile']){
  772. return api_error_return('不能给自己转赠');
  773. }
  774. Db::startTrans();
  775. try {
  776. $info = $service->exchargeMoneySubmit($request->uid, $post['money'], $post['mobile']);
  777. Db::commit();
  778. }catch (Exception $e){
  779. Db::rollback();
  780. return api_error_return($e->getMessage());
  781. }
  782. return api_succ_return(['msg'=>'请求成功', 'data'=>$info]);
  783. }
  784. // 余额赠送
  785. public function moneyExcharge(Request $request, UserServices $service){
  786. $post = $request->post();
  787. Db::startTrans();
  788. try {
  789. getActionSecury($request->uid, $request->post('security_pass', ''));
  790. $info = $service->exchargeMoneyDone($request->uid, $post['money'], $post['mobile'], $request->user['mobile']);
  791. Db::commit();
  792. }catch (Exception $e){
  793. Db::rollback();
  794. return api_error_return($e->getMessage());
  795. }
  796. return api_succ_return(['msg'=>'请求成功', 'data'=>$info]);
  797. }
  798. // 用户余额转赠提交
  799. public function jhExchargeSubmit(Request $request, UserServices $service){
  800. $post = $request->post();
  801. if ($request->user['mobile'] == $post['mobile']){
  802. return api_error_return('不能给自己转赠');
  803. }
  804. Db::startTrans();
  805. try {
  806. $info = $service->exchargeJhSubmit($request->uid, $post['money'], $post['mobile']);
  807. Db::commit();
  808. }catch (Exception $e){
  809. Db::rollback();
  810. return api_error_return($e->getMessage());
  811. }
  812. return api_succ_return(['msg'=>'请求成功', 'data'=>$info]);
  813. }
  814. // JH转赠
  815. public function jhExcharge(Request $request, UserServices $service){
  816. $post = $request->post();
  817. Db::startTrans();
  818. try {
  819. getActionSecury($request->uid, $request->post('security_pass', ''));
  820. $info = $service->exchargeJHDone($request->uid, $post['money'], $post['mobile']);
  821. Db::commit();
  822. }catch (Exception $e){
  823. Db::rollback();
  824. return api_error_return($e->getMessage());
  825. }
  826. return api_succ_return('赠送成功');
  827. }
  828. // jh购买
  829. public function jhBuy(Request $request, UserServices $service){
  830. $post = $request->post();
  831. // return api_error_return('暂未开放');
  832. // return api_error_return("由于系统更新 暂不支持兑换 开放时间另行通知");
  833. Db::startTrans();
  834. try {
  835. getActionSecury($request->uid, $request->post('security_pass', ''));
  836. $info = $service->JHBuy($request->uid, $post['count']);
  837. Db::commit();
  838. }catch (Exception $e){
  839. Db::rollback();
  840. return api_error_return($e->getMessage());
  841. }
  842. return api_succ_return(['msg'=>'购买成功,本期剩余'.$info]);
  843. }
  844. /**
  845. * 取消收藏商品
  846. * @param Request $request
  847. * @return \think\Response
  848. */
  849. public function cancelAttension(Request $request){
  850. $goodsId = $request->post('goods_id');
  851. if(ShopGoodsService::make()->cancelAttension($request->uid, $goodsId)){
  852. return api_succ_return('成功');
  853. }else{
  854. return api_error_return('失败');
  855. }
  856. }
  857. // 商品收藏列表
  858. public function goodsAttList(Request $request){
  859. $post = $request->post();
  860. $list = Db::name('goods_attension')
  861. ->alias('a')
  862. ->where('a.uid', '=', $request->uid)
  863. ->leftJoin('shop_goods g', 'g.goods_id = a.goods_id')
  864. ->field('a.id,a.goods_id, g.goods_img, g.goods_name,g.goods_sn, g.attension_count,g.price, g.rebate_score')
  865. ->page($post['page'], $post['limit'])
  866. ->select()->toArray();
  867. return api_succ_return(['msg'=>'成功', 'data'=>$list]);
  868. }
  869. // 用户注销
  870. public function denyOff(Request $request){
  871. // Db::startTrans();
  872. // try {
  873. //
  874. // if ($request->user['status'] != 1){
  875. // sr_throw('用户状态错误');
  876. // }
  877. //
  878. // Db::name('user')->where('id', $request->uid)->save(['status'=>3, 'mobile'=>'12345678', 'desc'=>'之前手机号:'.$request->user['mobile'], 'user_name'=>'已注销'.$request->user['user_name']]);
  879. //
  880. // Db::commit();
  881. // }catch (\Exception $e){
  882. // Db::rollback();
  883. // return api_error_return($e->getMessage());
  884. // }
  885. return api_succ_return('注销成功');
  886. }
  887. public function rechargeOrderList(Request $request){
  888. $post = $request->post();
  889. $list = Db::name('recharge_order')->where('user_id', $request->uid)->page($post['page'], $post['limit'])->order('order_id desc')->select()->toArray();
  890. return api_succ_return(['msg'=>'成功', 'data'=>$list]);
  891. }
  892. public function rechargeUsdtVerify(Request $request){
  893. $post = $request->post();
  894. Db::startTrans();
  895. try {
  896. $orderinfo = Db::name('recharge_order')->where('recharge_sn', $post['recharge_id'])->find();
  897. if (!$orderinfo){
  898. sr_throw('参数错误');
  899. }
  900. if ($orderinfo['user_id'] != $request->uid){
  901. sr_throw('不是你的订单');
  902. }
  903. if ($orderinfo['pay_type'] != 19){
  904. sr_throw("充值类型错误");
  905. }
  906. if ($orderinfo['status'] != 1){
  907. sr_throw('状态错误');
  908. }
  909. Db::name('recharge_order')->where('order_id', $orderinfo['order_id'])->save([
  910. 'charge_img'=>env('app.API_WEB_URL').'/'.$post['img'],
  911. 'status'=>3
  912. ]);
  913. Db::commit();
  914. }catch (\Exception $e){
  915. Db::rollback();
  916. return api_error_return($e->getMessage());
  917. }
  918. return api_succ_return('提交成功');
  919. }
  920. public function getSellerPayWay(Request $request){
  921. return api_succ_return(['msg'=>'成功', 'data'=>getUserPayWay($request->uid)]);
  922. }
  923. // 用户签到
  924. public function daySign(Request $request){
  925. Db::startTrans();
  926. try {
  927. // Db::name('user')->where('id', $request->uid)->save(['today_task_down'=>2]);
  928. if (!Db::name('ad_finishlog')->where('uid', $request->uid)->where('type', 1)->whereDay('create_time', 'today')->find()){
  929. // 每日完成任务日志
  930. Db::name('ad_finishlog')->insert([
  931. 'uid'=>$request->uid,
  932. 'create_time'=>sr_getcurtime(time()),
  933. 'type'=>1
  934. ]);
  935. }
  936. Db::commit();
  937. }catch (\Exception $e){
  938. Db::rollback();
  939. return api_error_return($e->getMessage());
  940. }
  941. return api_succ_return('签到成功');
  942. }
  943. // 省代理购买
  944. public function provinceAgentBuy(Request $request){
  945. return ;
  946. Db::startTrans();
  947. try {
  948. getActionSecury($request->uid, $request->post('security_pass', ''));
  949. $price = 175000;
  950. $user = Db::name('user')->where('id', $request->uid)->find();
  951. if ($user['money'] < $price){
  952. sr_throw('余额不足');
  953. }
  954. if ($user['agent_type'] != 0){
  955. sr_throw('购买失败,已是代理');
  956. }
  957. edit_user_money(15, $request->uid, $price);
  958. // edit_user_tz(13, $request->uid, 20000);
  959. Db::name('user')->where('id', $request->uid)->save(['agent_type'=>1]);
  960. Db::commit();
  961. }catch (\Exception $e){
  962. Db::rollback();
  963. return api_error_return($e->getMessage());
  964. }
  965. return api_succ_return('购买成功');
  966. }
  967. // 市代理购买
  968. public function cityAgentBuy(Request $request){
  969. return ;
  970. Db::startTrans();
  971. try {
  972. getActionSecury($request->uid, $request->post('security_pass', ''));
  973. $price = 56000;
  974. $user = Db::name('user')->where('id', $request->uid)->find();
  975. if ($user['money'] < $price){
  976. sr_throw('余额不足');
  977. }
  978. if ($user['agent_type'] != 0){
  979. sr_throw('购买失败,已是代理');
  980. }
  981. edit_user_money(16, $request->uid, $price);
  982. // edit_user_tz(14, $request->uid, 8000);
  983. Db::name('user')->where('id', $request->uid)->save(['agent_type'=>2]);
  984. Db::commit();
  985. }catch (\Exception $e){
  986. Db::rollback();
  987. return api_error_return($e->getMessage());
  988. }
  989. return api_succ_return('购买成功');
  990. }
  991. // 回收卡信息
  992. public function recycleCardInfo(Request $request){
  993. $data = [];
  994. $user_info = Db::name('user')->where('id', $request->uid)->field('today_money,todayaward_money,store_type')->find();
  995. $data['every_day_recycle_count'] = $user_info['store_type'] == 1?120:20;
  996. $zt_numcount = Db::name('user')->where('pid', $request->uid)->where('has_fd', 1)->count();
  997. $data['zt_count'] = $zt_numcount * env('boxsetting.ONE_DIRECT_RECYCLE_COUNT');
  998. $has_get = Db::name('recyclecard_log')->where('type', 1)->where('uid', $request->uid)->whereDay('create_at', 'today')->find();
  999. $has_ztget = Db::name('recyclecard_log')->where('type', 2)->where('uid', $request->uid)->whereDay('create_at', 'today')->find();
  1000. $data['has_today_get'] = $has_get?1:0;
  1001. $data['has_today_ztget'] = $has_ztget?1:0;
  1002. // $data['has_today_get'] = 0;
  1003. // $data['has_today_ztget'] = 0;
  1004. $data['todayaward_money'] = $user_info['todayaward_money'];
  1005. $data['today_money']=$user_info['today_money'];
  1006. $data['services_store_price']=env('boxsetting.SERVICES_STORE_OPEN_PRICE');
  1007. return api_succ_return(['msg'=>'成功', 'data'=>$data]);
  1008. }
  1009. // 领取回收卡
  1010. public function getRecycleCard(Request $request){
  1011. $type = $request->post('type');
  1012. $model = new UserModel();
  1013. Db::startTrans();
  1014. try {
  1015. $model->getRecycleCard($request->uid, $type, $request->user);
  1016. Db::commit();
  1017. }catch (\Exception $e){
  1018. Db::rollback();
  1019. return api_error_return($e->getMessage());
  1020. }
  1021. return api_succ_return('领取成功');
  1022. }
  1023. // 领取每日奖金
  1024. public function getUserTeamMoney(Request $request){
  1025. $model = new UserModel();
  1026. return api_error_return('奖金已在每天21后自动领取');
  1027. Db::startTrans();
  1028. try {
  1029. // getActionBefore(6);
  1030. $model->getUserTeamMoney($request->uid);
  1031. Db::commit();
  1032. }catch (\Exception $e){
  1033. Db::rollback();
  1034. return api_error_return($e->getMessage());
  1035. }
  1036. return api_succ_return('领取成功');
  1037. }
  1038. // 今日奖金记录
  1039. public function todayTeamMoneyLog(Request $request){
  1040. $model = new MoneyLogModel();
  1041. try {
  1042. return api_succ_return(['msg'=>'成功', 'data'=>$model->getTeamMoneyLog($request)]);
  1043. } catch (\Exception $e) {
  1044. return api_error_return('失败');
  1045. }
  1046. }
  1047. // 利润结算记录
  1048. public function incomeMoneyLog(Request $request){
  1049. $model = new MoneyLogModel();
  1050. try {
  1051. // $request->data['type'] = 8;
  1052. return api_succ_return(['msg'=>'成功', 'data'=>$model->getLog($request, 8)]);
  1053. } catch (\Exception $e) {
  1054. return api_error_return('失败'.$e->getMessage());
  1055. }
  1056. }
  1057. // 利润结算
  1058. public function getUserIncomeTeam(Request $request){
  1059. $model = new UserModel();
  1060. Db::startTrans();
  1061. try {
  1062. $model->getUserIncomeTeam($request->uid);
  1063. Db::commit();
  1064. }catch (\Exception $e){
  1065. Db::rollback();
  1066. return api_error_return('结算失败'.$e->getMessage());
  1067. // return api_error_return($e->getMessage());
  1068. }
  1069. return api_succ_return('结算成功');
  1070. }
  1071. // 消费记录
  1072. public function consumeLog(Request $request){
  1073. $model = new PaymentModel();
  1074. try {
  1075. return api_succ_return(['msg'=>'成功', 'data'=>$model->getLog($request, 8)]);
  1076. } catch (\Exception $e) {
  1077. return api_error_return('失败'.$e->getMessage());
  1078. }
  1079. }
  1080. // 商务合作申请
  1081. public function bussinessApply(Request $request){
  1082. $model = new UserModel();
  1083. Db::startTrans();
  1084. try {
  1085. $model->bussinessApply($request->uid, $request->post());
  1086. Db::commit();
  1087. }catch (\Exception $e){
  1088. Db::rollback();
  1089. return api_error_return($e->getMessage());
  1090. }
  1091. return api_succ_return('申请成功');
  1092. }
  1093. // 用户利润信息
  1094. public function userProfitInfo(Request $request){
  1095. $user_info = Db::name('user')->where('id', $request->uid)->find();
  1096. return api_succ_return(['msg'=>'成功', 'data'=>[
  1097. 'total'=>$user_info['total_profit_money'],
  1098. 'cur_profit'=>$user_info['profit_money'],
  1099. 'desc'=>'按照100的倍数结算到余额'
  1100. ]]);
  1101. }
  1102. // 邀请好友 绑定上级好友
  1103. public function bangUpFriend(Request $request){
  1104. $model = new UserModel();
  1105. Db::startTrans();
  1106. try {
  1107. $model->bangUpFriend($request->uid, $request->post());
  1108. Db::commit();
  1109. }catch (\Exception $e){
  1110. Db::rollback();
  1111. return api_error_return($e->getMessage());
  1112. }
  1113. return api_succ_return('绑定成功');
  1114. }
  1115. // 获得直推上级信息
  1116. public function getUpUserInfo(Request $request){
  1117. $user_info = $request->user_info;
  1118. if ($user_info['pid'] > 0){
  1119. $pid_info = Db::name('user')->where('id', $user_info['pid'])->field('nickname,mobile,id')->find();
  1120. $pid_info['mobile'] = substr($pid_info['mobile'], 0, 3).'****'.substr($pid_info['mobile'], 7);
  1121. return api_succ_return(['msg'=>'成功', 'data'=>$pid_info]);
  1122. }else{
  1123. return api_succ_return(['msg'=>'成功', 'data'=>[]]);
  1124. }
  1125. }
  1126. // 获取用户订单状态 处理
  1127. public function orderUnreadInfo(Request $request){
  1128. $data = [];
  1129. Db::startTrans();
  1130. try {
  1131. $count1 = Db::name('shop_order')->where('user_id', $request->uid)->where('status', 0)->count();
  1132. $count2 = Db::name('shop_order')->where('user_id', $request->uid)->where('status', 1)->count();
  1133. $count3 = Db::name('shop_order')->where('user_id', $request->uid)->where('status', 2)->count();
  1134. $data = [$count1, $count2, $count3, 0];
  1135. Db::commit();
  1136. }catch (\Exception $e){
  1137. Db::rollback();
  1138. return api_error_return('接口请求失败');
  1139. }
  1140. return api_succ_return(['msg'=>'成功', 'data'=>$data]);
  1141. }
  1142. }