Pub.php 16 KB

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