Pub.php 18 KB

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