User.php 46 KB

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