Pub.php 20 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611
  1. <?php
  2. // +----------------------------------------------------------------------
  3. // | [ WE CAN DO IT MORE SIMPLE ]
  4. // +----------------------------------------------------------------------
  5. // | Copyright (c) 2018-2020 rights reserved.
  6. // +----------------------------------------------------------------------
  7. // | Author: TABLE ME
  8. // +----------------------------------------------------------------------
  9. // | Date: 2020-08-25 17:23
  10. // +----------------------------------------------------------------------
  11. declare (strict_types=1);
  12. namespace app\api\controller;
  13. use app\model\api\ArticleModel;
  14. use app\model\api\ContractComment;
  15. use app\model\api\LikeBookmark;
  16. use app\model\api\UserClock;
  17. use think\db\exception\DataNotFoundException;
  18. use think\db\exception\DbException;
  19. use think\db\exception\ModelNotFoundException;
  20. use think\facade\Log;
  21. use think\facade\View;
  22. use app\BaseController;
  23. use app\Request;
  24. use library\services\UtilService;
  25. use library\utils\UtilsTool;
  26. use think\facade\Db;
  27. use think\Image;
  28. use think\Db as D;
  29. use app\model\api\AppBug;
  30. use app\model\api\User as UserModel;
  31. use app\model\api\AccessIp;
  32. use app\model\api\ShowTemplate;
  33. use app\model\api\UserShowTemplate;
  34. use app\model\api\ServiceType;
  35. use app\model\api\ServiceLabel;
  36. use app\model\api\ServiceTimeType;
  37. use app\model\api\UserWorkType;
  38. use app\model\api\InfoAudit;
  39. use app\model\api\TypeAudit;
  40. use app\model\api\Sys as SysModel;
  41. use app\model\api\Education;
  42. use app\model\api\Advert as AdvertModel;
  43. use library\utils\WxpayV2 as wxpayApi;
  44. class Pub extends BaseController
  45. {
  46. private $user = null;
  47. public function checkUser($token = null)
  48. {
  49. if (empty($token)) {
  50. return false;
  51. }
  52. $memData = (new UserModel)
  53. ->where('token', $token)
  54. ->where('status', 1)
  55. ->find();
  56. if (empty($memData)) {
  57. return false;
  58. }
  59. $this->user = $memData->toArray();
  60. return true;
  61. }
  62. /**
  63. * 获取支付类型数据
  64. */
  65. public function getPayTypeData()
  66. {
  67. $data = [
  68. ["code" => "wxpay", "title" => "微信支付", "img" => env('appinfo.app_api_domain', '') . "/resource/icon/" . "wxicon.png"],
  69. ["code" => "score", "title" => "积分支付", "img" => env('appinfo.app_api_domain', '') . "/resource/icon/" . "score.png"],
  70. ];
  71. return app('json')->success($data);
  72. }
  73. /**
  74. * 获取分享信息
  75. * @return type
  76. */
  77. public function getShareInfo()
  78. {
  79. $data = (new SysModel)->getDataInfo("share");
  80. return app('json')->success($data);
  81. }
  82. /**
  83. * 获取积分信息
  84. * @return type
  85. */
  86. public function getScoreInfo()
  87. {
  88. $data = (new SysModel)->getDataInfo("score");
  89. return app('json')->success($data);
  90. }
  91. /**
  92. * 获取模板详情
  93. * @param Request $request
  94. * @return type
  95. */
  96. public function getShowTemplateItem($id)
  97. {
  98. $data = (new ShowTemplate)
  99. ->field("id,title,price,old_price,status,imgs,is_hot,is_recommend,code,look_count,real_sales,unreal_sales")
  100. ->where("id", $id)
  101. ->find();
  102. if (empty($data)) {
  103. return app('json')->fail("模板不存在");
  104. }
  105. if ($data["is_init"] == 0 && $data["status"] != 1) {
  106. return app('json')->fail("模板已下架");
  107. }
  108. $data = $data->toArray();
  109. $data["is_use"] = 0;
  110. $data["imgs"] = getImageAr($data["imgs"]);
  111. $data["img"] = empty($data["imgs"]) ? "" : $data["imgs"][0];
  112. $data["sales_count"] = $data["real_sales"] + $data["unreal_sales"];
  113. unset($data["real_sales"]);
  114. unset($data["unreal_sales"]);
  115. //验证是否购买过并添加浏览记录
  116. $this->checkUser(request()->header("token", ""));
  117. if (!empty($this->user)) {
  118. $data["is_use"] = (new UserShowTemplate)->where("uid", $this->user["uid"])->where("show_template_id", $data["id"])->count() > 0 ? 1 : 0;
  119. (new ShowTemplate)->where('id', $data["id"])->inc('look_count', 1)->update();
  120. }
  121. return app('json')->success($data);
  122. }
  123. /**
  124. * 获取皮肤模板列表
  125. * @param Request $request
  126. */
  127. public function getShowTemplateList(Request $request)
  128. {
  129. $post = UtilService::getMore([
  130. ['is_hot', '0'],
  131. ['is_recommend', '0'],
  132. ['page', 1],
  133. ['pageSize', 50],
  134. ], $request);
  135. $where["pageSize"] = $post["pageSize"] > 50 ? 50 : (int)$post["pageSize"];
  136. $where["page"] = $post["page"] <= 0 ? 1 : (int)$post["page"];
  137. $where["status"] = 1;
  138. if ((int)$post["is_hot"] == 1) {
  139. $where["is_hot"] = 1;
  140. }
  141. if ((int)$post["is_recommend"] == 1) {
  142. $where["is_recommend"] = 1;
  143. }
  144. $data = (new ShowTemplate)->getDataList($where, "id,title,price,old_price,status,imgs,is_hot,is_recommend,code,look_count,real_sales,unreal_sales");
  145. return app('json')->success($data);
  146. }
  147. /**
  148. * 获取轮播图
  149. * @param Request $request
  150. */
  151. public function getBannerList(Request $request)
  152. {
  153. $post = UtilService::getMore([
  154. ['type', ''],
  155. ['page', 1],
  156. ['pageSize', 50],
  157. ['page_id', 70],
  158. ], $request);
  159. $post["pageSize"] = $post["pageSize"] > 50 ? 50 : (int)$post["pageSize"];
  160. $post["page"] = $post["page"] <= 0 ? 1 : (int)$post["page"];
  161. $where = [];
  162. $where[] = ["is_show", "=", 1];
  163. $where[] = ["page_id", "=", $post['page_id']];
  164. $totalCount = (new AdvertModel)->where($where)->count();
  165. $data = null;
  166. if ($totalCount > 0) {
  167. $data = (new AdvertModel)
  168. ->field("*")
  169. ->where($where)
  170. ->order("sort", "desc")
  171. ->page($post["page"], $post["pageSize"])
  172. ->select();
  173. }
  174. $data = empty($data) ? [] : $data;
  175. return app('json')->success(["list" => $data, "pageSize" => $post["pageSize"], "page" => $post["page"], "totalCount" => $totalCount]);
  176. }
  177. /**
  178. * 获取服务类型列表
  179. * @param Request $request
  180. * @return type
  181. */
  182. public function getServiceTypeList(Request $request)
  183. {
  184. $post = UtilService::getMore([
  185. ['page', 1],
  186. ['pageSize', 50],
  187. ], $request);
  188. $post["pageSize"] = $post["pageSize"] > 50 ? 50 : (int)$post["pageSize"];
  189. $post["page"] = $post["page"] <= 0 ? 1 : (int)$post["page"];
  190. $post["status"] = 1;
  191. $data = (new ServiceType)->getList($post, "id,title,content,img");
  192. return app('json')->success($data);
  193. }
  194. /**
  195. * 获取标签列表
  196. * @param Request $request
  197. * @return type
  198. */
  199. public function getServiceLabelList(Request $request)
  200. {
  201. $post = UtilService::getMore([
  202. ['page', 1],
  203. ['pageSize', 50],
  204. ], $request);
  205. $post["pageSize"] = $post["pageSize"] > 50 ? 50 : (int)$post["pageSize"];
  206. $post["page"] = $post["page"] <= 0 ? 1 : (int)$post["page"];
  207. $post["status"] = 1;
  208. $data = (new ServiceLabel)->getList($post, "id,title,type");
  209. return app('json')->success($data);
  210. }
  211. /**
  212. * 获取用户工作服务类型
  213. * @param Request $request
  214. */
  215. public function getUserWorkTypeList(Request $request)
  216. {
  217. $post = UtilService::getMore([
  218. ['page', 1],
  219. ['pageSize', 50],
  220. ], $request);
  221. $post["pageSize"] = $post["pageSize"] > 50 ? 50 : (int)$post["pageSize"];
  222. $post["page"] = $post["page"] <= 0 ? 1 : (int)$post["page"];
  223. $post["status"] = 1;
  224. $data = (new UserWorkType)->getList($post, "id,title,content,img");
  225. return app('json')->success($data);
  226. }
  227. /**
  228. * 获取从业人员列表
  229. * @param Request $request
  230. * @return type
  231. */
  232. public function getWorkerList(Request $request)
  233. {
  234. $post = UtilService::getMore([
  235. // ['page', 1],
  236. // ['pageSize', 50],
  237. // ['work_type_id', ""],
  238. // ['service_area', []],
  239. ['page', 1],
  240. ['pageSize', 50],
  241. ['work_type_id', ""],
  242. ['servicePrice', 0],
  243. ['areaId', ''],
  244. ['is_china', ''],
  245. ['service_area', []],
  246. ['timetype', '']
  247. ], $request);
  248. $post["pageSize"] = $post["pageSize"] > 50 ? 50 : (int)$post["pageSize"];
  249. $post["page"] = $post["page"] <= 0 ? 1 : (int)$post["page"];
  250. $post["status"] = 1;
  251. // @file_put_contents('quanju.txt', json_encode($post). "-搜索条件\r\n", 8);
  252. @file_put_contents('quanju.txt', json_encode($post). "-城市选择\r\n", 8);
  253. $data = (new UserModel)->getApiWorkerList($post);
  254. foreach ($data['list'] as &$item) {
  255. $infoAuditDb = new InfoAudit();
  256. $infoData = $infoAuditDb->getItem(["status" => 1, "uid" => $item["uid"]]);
  257. $item['is_type_audit'] = $item['is_type_audit'] == 1 ? 1 : 0;
  258. $item['ancestral_place'] = !empty($infoData['ancestral_place']) ? $infoData['ancestral_place'] : '';
  259. }
  260. return app('json')->success($data);
  261. }
  262. /**
  263. * 获取从业人员列表
  264. * @param Request $request
  265. * @return type
  266. */
  267. public function getGoodWorkerList(Request $request)
  268. {
  269. $post = UtilService::getMore([
  270. ['page', 1],
  271. ['pageSize', 50],
  272. ['work_type_id', ""],
  273. ['servicePrice', 0],
  274. ['areaId', ''],
  275. ['is_china', ''],
  276. ['service_area', []],
  277. ['timetype', '']
  278. ], $request);
  279. $post["pageSize"] = $post["pageSize"] > 50 ? 50 : (int)$post["pageSize"];
  280. $post["page"] = $post["page"] <= 0 ? 1 : (int)$post["page"];
  281. $post["status"] = 1;
  282. @file_put_contents('quanju.txt', json_encode($post['service_area']). "-城市选择\r\n", 8);
  283. $data = (new UserModel)->getGoodApiWorkerList($post);
  284. foreach ($data['list'] as &$item) {
  285. $infoAuditDb = new InfoAudit();
  286. $infoData = $infoAuditDb->getItem(["status" => 1, "uid" => $item["uid"]]);
  287. $item['is_type_audit'] = $item['is_type_audit'] == 1 ? 1 : 0;
  288. $item['ancestral_place'] = !empty($infoData['ancestral_place']) ? $infoData['ancestral_place'] : '';
  289. }
  290. return app('json')->success($data);
  291. }
  292. /**
  293. * 获取从业人员列表
  294. * @param Request $request
  295. * @return type
  296. */
  297. public function getNewWorkerList(Request $request)
  298. {
  299. $post = UtilService::getMore([
  300. ['page', 1],
  301. ['pageSize', 50],
  302. ['work_type_id', ""],
  303. ['servicePrice', 0],
  304. ['areaId', ''],
  305. ['is_china', ''],
  306. ['service_area', []],
  307. ['timetype', '']
  308. ], $request);
  309. $post["pageSize"] = $post["pageSize"] > 50 ? 50 : (int)$post["pageSize"];
  310. $post["page"] = $post["page"] <= 0 ? 1 : (int)$post["page"];
  311. $post["status"] = 1;
  312. $data = (new UserModel)->getNewApiWorkerList($post);
  313. foreach ($data['list'] as &$item) {
  314. $infoAuditDb = new InfoAudit();
  315. $infoData = $infoAuditDb->getItem(["status" => 1, "uid" => $item["uid"]]);
  316. $item['is_type_audit'] = $item['is_type_audit'] == 1 ? 1 : 0;
  317. $item['ancestral_place'] = !empty($infoData['ancestral_place']) ? $infoData['ancestral_place'] : '';
  318. }
  319. return app('json')->success($data);
  320. }
  321. /**
  322. * 获取服务时长类型
  323. * @param Request $request
  324. * @return type
  325. */
  326. public function getServiceTimeTypeList(Request $request)
  327. {
  328. $post = UtilService::getMore([
  329. ['page', 1],
  330. ['pageSize', 50],
  331. ], $request);
  332. $post["pageSize"] = $post["pageSize"] > 50 ? 50 : (int)$post["pageSize"];
  333. $post["page"] = $post["page"] <= 0 ? 1 : (int)$post["page"];
  334. $post["status"] = 1;
  335. $data = (new ServiceTimeType)->getList($post, "title,code");
  336. return app('json')->success($data);
  337. }
  338. /**
  339. * 获取系统信息
  340. * @param Request $request
  341. */
  342. public function getSysData(Request $request)
  343. {
  344. $data = (new Sys)->where("id", 1)->find()->toArray();
  345. $data = [];
  346. return app("json")->success($data);
  347. }
  348. /**
  349. * 首页轮播
  350. * @param Request $request
  351. */
  352. public function getHomeBanner(Request $request)
  353. {
  354. $data = (new AdvertModel)
  355. ->field("id,img,title,url")
  356. ->where("page_id", 70)
  357. ->where("is_show", 1)
  358. ->order("sort", "desc")
  359. ->select()
  360. ->toArray();
  361. $data = empty($data) ? [] : $data;
  362. return app("json")->success($data);
  363. }
  364. /**
  365. * 评论列表
  366. * @param Request $request
  367. */
  368. public function getCommentList(Request $request)
  369. {
  370. $post = UtilService::getMore([
  371. ['uid', 0],
  372. ['to_uid', 0],
  373. ['page', 1],
  374. ['pageSize', 50],
  375. ], $request);
  376. $post["pageSize"] = $post["pageSize"] > 50 ? 50 : (int)$post["pageSize"];
  377. $post["page"] = $post["page"] <= 0 ? 1 : (int)$post["page"];
  378. $data = (new ContractComment())->getCommentList($post);
  379. $data = empty($data) ? [] : $data;
  380. return app("json")->success($data);
  381. }
  382. /**
  383. * 打卡记录列表
  384. * @param Request $request
  385. */
  386. public function getClockList(Request $request)
  387. {
  388. $post = UtilService::getMore([
  389. ['uid', 0],
  390. ['to_uid', 0],
  391. ['contract_id', 0],
  392. ['page', 1],
  393. ['pageSize', 50],
  394. ], $request);
  395. $post["pageSize"] = $post["pageSize"] > 50 ? 50 : (int)$post["pageSize"];
  396. $post["page"] = $post["page"] <= 0 ? 1 : (int)$post["page"];
  397. $data = (new UserClock())->getClockList($post);
  398. $data = empty($data) ? [] : $data;
  399. return app("json")->success($data);
  400. }
  401. /**
  402. * 获取其他用户名片信息
  403. * @param Request $request
  404. */
  405. public function getCommonUserCardInfo(Request $request)
  406. {
  407. [$uid] = UtilService::getMore([
  408. ['uid', '', 'empty', "用户信息为空"],
  409. ], $request, true);
  410. $userData = (new UserModel)->where("uid", $uid)->find();
  411. if (empty($userData)) {
  412. return app('json')->fail("用户不存在");
  413. }
  414. $userData->toArray();
  415. if ($userData["status"] == -1){
  416. return app('json')->fail("该名片已被禁用");
  417. }
  418. $data = (new InfoAudit)->getItem(["uid" => $uid, "status" => 1]);
  419. if (empty($data)) {
  420. return app('json')->fail("当前用户还未通过审核");
  421. }
  422. $typeData = (new TypeAudit)->where("uid", $uid)->order("id", "desc")->find();
  423. $data["is_type_audit"] = (empty($typeData) || $typeData["status"] != 1) ? 0 : 1;
  424. //名片浏览次数
  425. (new UserModel)->where('uid', $uid)->inc('card_look_count', 1)->update();
  426. $accessiInfo = [
  427. 'uid' => $uid,
  428. 'add_time' => time(),
  429. 'url_ip' => $request->ip(),
  430. ];
  431. $res = AccessIp::create($accessiInfo);
  432. // $add_time = time();//访问时间
  433. // $url_ip = $request->url();//访问IP
  434. $data["card_look_count"] = $userData["card_look_count"] + 1;
  435. $data['like_count'] = $userData['like_count'];
  436. $data['bookmark_count'] = $userData['bookmark_count'];
  437. if (isset($request->user['uid'])) {
  438. $likeCount = (new LikeBookmark())->where('uid', $request->user['uid'])->where('aid', $uid)->where('type', 1)->where('is_del', 0)->count();
  439. if ($likeCount > 0) {
  440. $data['is_like'] = 1;
  441. } else {
  442. $data['is_like'] = 0;
  443. }
  444. $bookmarkCount = (new LikeBookmark())->where('uid', $request->user['uid'])->where('aid', $uid)->where('type', 2)->where('is_del', 0)->count();
  445. if ($bookmarkCount > 0) {
  446. $data['is_bookmark'] = 1;
  447. } else {
  448. $data['is_bookmark'] = 0;
  449. }
  450. } else {
  451. $data['is_like'] = 0;
  452. $data['is_bookmark'] = 0;
  453. }
  454. $data['check_num'] = (new UserClock())->where('uid',$uid)->count();
  455. $data['comment_num'] = (new ContractComment())->where('to_uid',$uid)->count();
  456. return app('json')->success($data);
  457. }
  458. /**
  459. * 名片浏览量排行榜
  460. * @param Request $request
  461. */
  462. public function getCardLookCountRank(Request $request)
  463. {
  464. $time = $request->param();
  465. $users = AccessIp::where('add_time', '>=', $time['time'])
  466. ->where('add_time', '<=', $time['times'])
  467. ->field('uid, count(*) as ip_count')
  468. ->group('uid')
  469. ->order('ip_count', 'desc')
  470. ->select();
  471. $rankList = [];
  472. foreach ($users as $key => $value) {
  473. $userInfo = (new UserModel)->where('uid', $value['uid'])->find();
  474. $auth = (new InfoAudit)->where('uid', $value['uid'])->find();
  475. $template = $this->getShowTemplateItem($value['uid']);
  476. $user_work_type_title = (new UserWorkType)->where('id', $auth['user_work_type_id'])->find();
  477. $rankList[] = [
  478. 'rank' => $key + 1,
  479. 'uid' => $value['uid'],
  480. 'name' => $userInfo['name'],
  481. 'avatar' => $userInfo['avatar'],
  482. 'card_look_count' => $value['ip_count'],
  483. 'template' => $template,
  484. 'is_type_audit' => $auth && $auth['status'] == 1 ? 1 : 0,
  485. 'ancestral_place' => $auth ? $auth['ancestral_place'] : '',
  486. 'auth_info' => $auth ? $auth->toArray() : [],
  487. 'user_work_type_id' => $user_work_type_title['title'],
  488. ];
  489. }
  490. $rankList = array_values(array_filter($rankList, function ($item) {
  491. return !empty($item['ancestral_place']);
  492. }));
  493. return app('json')->success($rankList);
  494. }
  495. //获取文章详情
  496. public function getArtDetail(\think\Request $request)
  497. {
  498. $id = $request->param('id');
  499. $article = ArticleModel::where('id', $id)->find();
  500. if (!$article) {
  501. return app('json')->fail('文章不存在');
  502. }
  503. return app('json')->success(['list' => [$article], 'count' => 1]);
  504. }
  505. /**
  506. * bug提交
  507. * @param Request $request
  508. */
  509. public function appBugSub(Request $request)
  510. {
  511. [$error] = UtilService::getMore([
  512. ['error', '', 'empty', "错误信息为空"],
  513. ], $request, true);
  514. $deviceId = $request->header("deviceId", "");
  515. $deviceType = $request->header("deviceType", "");
  516. $fromPlat = $request->header("fromPlat", "");
  517. $version = $request->header("version", "");
  518. (new AppBug)->insert([
  519. "device_id" => $deviceId,
  520. "device_type" => $deviceType,
  521. "from_plat" => $fromPlat,
  522. "version" => $version,
  523. "error" => $error,
  524. "time" => time()
  525. ]);
  526. return app("json")->success("提交成功");
  527. }
  528. /**
  529. * 测试
  530. */
  531. public function appTest(Request $request)
  532. {
  533. $labelData = (new ServiceLabel)->where("status", 1)->where("id", "in", ["", 1, 2, 6, 7, 8, 0])->column('id');
  534. var_dump($labelData);
  535. exit;
  536. $money = $request->post("money", 0);
  537. $money = bcadd("0", $money . "", 2);
  538. echo $money;
  539. exit;
  540. $xml = "<xml><appid><![CDATA[wx57a473fc2f83f7e5]]></appid>
  541. <attach><![CDATA[微信小程序支付]]></attach>
  542. <bank_type><![CDATA[OTHERS]]></bank_type>
  543. <cash_fee><![CDATA[1]]></cash_fee>
  544. <fee_type><![CDATA[CNY]]></fee_type>
  545. <is_subscribe><![CDATA[N]]></is_subscribe>
  546. <mch_id><![CDATA[1640972417]]></mch_id>
  547. <nonce_str><![CDATA[TTEMpfip075pcFNNhS5P60tDtis91veA]]></nonce_str>
  548. <openid><![CDATA[oOqrp4tndyR_iDwrGC5P7Y4moP2Y]]></openid>
  549. <out_trade_no><![CDATA[A202304201681959554328879382]]></out_trade_no>
  550. <result_code><![CDATA[SUCCESS]]></result_code>
  551. <return_code><![CDATA[SUCCESS]]></return_code>
  552. <sign><![CDATA[146B5ADFF5ADC399A92C60D62C54638A]]></sign>
  553. <time_end><![CDATA[20230420105928]]></time_end>
  554. <total_fee>1</total_fee>
  555. <trade_type><![CDATA[JSAPI]]></trade_type>
  556. <transaction_id><![CDATA[4200001803202304202712861307]]></transaction_id>
  557. </xml>";
  558. $wxpay = new wxpayApi();
  559. // $r = $wxpay->notifyCheckSign($xml);
  560. $r = $wxpay->searchOrderQuery("A202304201681959554328879382");
  561. var_dump($r);
  562. }
  563. }