PublicController.php 19 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441
  1. <?php
  2. namespace app\api\controller;
  3. use app\admin\model\system\SystemAttachment;
  4. use app\models\mining\MiningMachine;
  5. use app\models\mining\UserMining;
  6. use app\models\mining\UserMiningMachine;
  7. use app\models\store\StoreCategory;
  8. use app\models\store\StoreCouponIssue;
  9. use app\models\store\StoreProduct;
  10. use app\models\store\StoreService;
  11. use app\models\system\Express;
  12. use app\models\system\SystemCity;
  13. use app\models\system\SystemStore;
  14. use app\models\system\SystemStoreStaff;
  15. use app\models\system\SystemUserTask;
  16. use app\models\trade\CashTradeOrder;
  17. use app\models\trade\ZtpayCallback;
  18. use app\models\user\UserBill;
  19. use app\models\user\UserMoney;
  20. use app\models\user\UserMoneyOrder;
  21. use app\models\user\WechatUser;
  22. use app\Request;
  23. use crmeb\basic\BaseModel;
  24. use crmeb\services\CacheService;
  25. use crmeb\services\UtilService;
  26. use crmeb\services\workerman\ChannelService;
  27. use crmeb\services\ZtPayService;
  28. use think\db\exception\DataNotFoundException;
  29. use think\db\exception\DbException;
  30. use think\db\exception\ModelNotFoundException;
  31. use think\Exception;
  32. use think\facade\Cache;
  33. use crmeb\services\upload\Upload;
  34. use think\facade\Db;
  35. /**
  36. * 公共类
  37. * Class PublicController
  38. * @package app\api\controller
  39. */
  40. class PublicController
  41. {
  42. public function version(Request $request)
  43. {
  44. $version_code = sys_config('version_code');
  45. $apk = sys_config('apk');
  46. return app('json')->success('ok', compact('version_code', 'apk'));
  47. }
  48. public function test(Request $request)
  49. {
  50. SystemUserTask::SmallGroupHashRate(1, 1);
  51. // UserMiningMachine::dayMining();
  52. // $money_types = MiningMachine::group('get_money_type')->field('COUNT(id),get_money_type')->select();
  53. // $day_gets = [];
  54. // foreach ($money_types as $v) {
  55. // $day_gets[$v['get_money_type']] = get_hpool_price($v['get_money_type']);
  56. // }
  57. ////// var_dump($day_gets);
  58. ////
  59. // $uid = $request->post('uid', '');
  60. // $umid = $request->post('umid', '');
  61. // $num = $request->post('num', 0);
  62. // $price = $day_gets['XCH'];
  63. // $time = time();
  64. // $day_get = bcmul($price, $num, 8);
  65. // $service_ratio = 0.8;
  66. // $day_service_get = bcmul($service_ratio, $day_get, 8);
  67. // $day_real_get = $day_service_get;
  68. // if ($day_real_get > 0) {
  69. // UserMining::create([
  70. // 'umid' => $umid,
  71. // 'get_money' => $day_real_get,
  72. // 'get_money_type' => 'XCH',
  73. // 'add_time' => $time,
  74. // 'add_date' => date('Y-m-d', $time),
  75. // ]) && UserMoney::incomeMoney($uid, 'XCH', bcadd($day_real_get, 0, 8), 'mining', '挖矿', '第一阶段每日释放' . $day_get . 'XCH' . ',扣除技术服务费后实际到账' . $day_real_get . 'XCH')
  76. // && UserMiningMachine::sendGroupAward($uid, 'XCH', bcadd($day_real_get, 0, 8))
  77. // && UserMiningMachine::sendSystemAward($uid, 'XCH', bcadd($day_real_get, 0, 8));
  78. // }
  79. }
  80. public function TRC20CashAdmin(Request $request)
  81. {
  82. $trans_adds = UserMoney::field('money_type,address_TRC20')->select();
  83. foreach ($trans_adds as $v) {
  84. if ($v['address_TRC20']) {
  85. $res = ZtPayService::instance()->get_balance(($v['money_type'] == "TRX") ? "TRX" : ($v['money_type'] . '_TRC20'), $v['address_TRC20']);
  86. // $res = json_decode($res, true);
  87. if (isset($res['data']['USDT']) && $res['data']['USDT'] > 0) {
  88. //执行转账
  89. $address = 'TEn1gLWumRj1FfjQ927vSoQrUCqKhuiWV2';//归集总地址
  90. if (isset($res['data']['TRX']) && $res['data']['TRX'] < 5) {
  91. $amount_address = 'TWkaVx6NW1q7LZxRW8BbhvqShP76EJPckZ';//手续费地址
  92. $res2 = ZtPayService::instance()->transfer('TRX', $amount_address, $v['address_TRC20'], 5);
  93. var_dump('---------------------' . $v['address_TRC20'] . '----A---------------------');
  94. var_dump($res2);
  95. } else {
  96. $res3 = ZtPayService::instance()->transfer(($v['money_type'] == "TRX") ? "TRX" : ($v['money_type'] . '_TRC20'), $v['address_TRC20'], $address, $res['data'][$v['money_type']]);
  97. var_dump('---------------------' . $v['address_TRC20'] . '----B---------------------');
  98. var_dump(($v['money_type'] == "TRX") ? "TRX" : ($v['money_type'] . '_TRC20'));
  99. var_dump($address);
  100. var_dump($res['data'][$v['money_type']]);
  101. }
  102. }
  103. }
  104. }
  105. }
  106. /**
  107. * @param Request $request
  108. * @return mixed
  109. * @throws DataNotFoundException
  110. * @throws ModelNotFoundException
  111. * @throws \think\exception\DbException
  112. */
  113. public function index(Request $request)
  114. {
  115. $banner = sys_data('routine_home_banner') ?: [];//TODO 首页banner图
  116. $menus = sys_data('routine_home_menus') ?: [];//TODO 首页按钮
  117. $roll = sys_data('routine_home_roll_news') ?: [];//TODO 首页滚动新闻
  118. $activity = sys_data('routine_home_activity', 3) ?: [];//TODO 首页活动区域图片
  119. $site_name = sys_config('site_name');
  120. $routine_index_page = sys_data('routine_index_page');
  121. $info['fastInfo'] = $routine_index_page[0]['fast_info'] ?? '';//sys_config('fast_info');//TODO 快速选择简介
  122. $info['bastInfo'] = $routine_index_page[0]['bast_info'] ?? '';//sys_config('bast_info');//TODO 精品推荐简介
  123. $info['firstInfo'] = $routine_index_page[0]['first_info'] ?? '';//sys_config('first_info');//TODO 首发新品简介
  124. $info['salesInfo'] = $routine_index_page[0]['sales_info'] ?? '';//sys_config('sales_info');//TODO 促销单品简介
  125. $logoUrl = sys_config('routine_index_logo');//TODO 促销单品简介
  126. if (strstr($logoUrl, 'http') === false && $logoUrl) $logoUrl = sys_config('site_url') . $logoUrl;
  127. $logoUrl = str_replace('\\', '/', $logoUrl);
  128. $fastNumber = sys_config('fast_number', 0);//TODO 快速选择分类个数
  129. $bastNumber = sys_config('bast_number', 0);//TODO 精品推荐个数
  130. $firstNumber = sys_config('first_number', 0);//TODO 首发新品个数
  131. $promotionNumber = sys_config('promotion_number', 0);//TODO 首发新品个数
  132. $info['fastList'] = StoreCategory::byIndexList((int)$fastNumber, false);//TODO 快速选择分类个数
  133. $info['bastList'] = StoreProduct::getBestProduct('id,image,store_name,cate_id,price,ot_price,IFNULL(sales,0) + IFNULL(ficti,0) as sales,unit_name', (int)$bastNumber, $request->uid(), false);//TODO 精品推荐个数
  134. $info['firstList'] = StoreProduct::getNewProduct('id,image,store_name,cate_id,price,unit_name,IFNULL(sales,0) + IFNULL(ficti,0) as sales', (int)$firstNumber, $request->uid(), false);//TODO 首发新品个数
  135. $info['bastBanner'] = sys_data('routine_home_bast_banner') ?? [];//TODO 首页精品推荐图片
  136. $benefit = StoreProduct::getBenefitProduct('id,image,store_name,cate_id,price,ot_price,stock,unit_name', $promotionNumber);//TODO 首页促销单品
  137. $lovely = sys_data('routine_home_new_banner') ?: [];//TODO 首发新品顶部图
  138. $likeInfo = StoreProduct::getHotProduct('id,image,store_name,cate_id,price,ot_price,unit_name', 3);//TODO 热门榜单 猜你喜欢
  139. $couponList = StoreCouponIssue::getIssueCouponList($request->uid(), 3);
  140. if ($request->uid()) {
  141. $subscribe = WechatUser::where('uid', $request->uid())->value('subscribe') ? true : false;
  142. } else {
  143. $subscribe = true;
  144. }
  145. $newGoodsBananr = sys_config('new_goods_bananr');
  146. $tengxun_map_key = sys_config('tengxun_map_key');
  147. return app('json')->successful(compact('banner', 'menus', 'roll', 'info', 'activity', 'lovely', 'benefit', 'likeInfo', 'logoUrl', 'couponList', 'site_name', 'subscribe', 'newGoodsBananr', 'tengxun_map_key'));
  148. }
  149. /**
  150. * @param Request $request
  151. * @return mixed
  152. * @throws DataNotFoundException
  153. * @throws DbException
  154. * @throws ModelNotFoundException
  155. */
  156. public function cityArea(Request $request)
  157. {
  158. $province = SystemCity::where('level', 0)->where('parent_id', 0)->field('name,city_id')->select()->each(function ($item) {
  159. $item['city'] = SystemCity::where('level', 1)
  160. ->where('parent_id', $item['city_id'])
  161. ->field('name,city_id')
  162. ->select()->each(function ($sub_item) {
  163. $sub_item['area'] = SystemCity::where('level', 2)
  164. ->where('parent_id', $sub_item['city_id'])
  165. ->column('name');
  166. unset($sub_item['city_id']);
  167. })->toArray();
  168. unset($item['city_id']);
  169. });
  170. return app('json')->success('ok', $province->toArray());
  171. }
  172. /**
  173. * 获取分享配置
  174. * @return mixed
  175. */
  176. public function share()
  177. {
  178. $data['img'] = sys_config('wechat_share_img');
  179. if (strstr($data['img'], 'http') === false) $data['img'] = sys_config('site_url') . $data['img'];
  180. $data['img'] = str_replace('\\', '/', $data['img']);
  181. $data['title'] = sys_config('wechat_share_title');
  182. $data['synopsis'] = sys_config('wechat_share_synopsis');
  183. return app('json')->successful(compact('data'));
  184. }
  185. /**
  186. * 获取个人中心菜单
  187. * @param Request $request
  188. * @return mixed
  189. * @throws DataNotFoundException
  190. * @throws ModelNotFoundException
  191. * @throws \think\exception\DbException
  192. */
  193. public function menu_user(Request $request)
  194. {
  195. $menusInfo = sys_data('routine_my_menus') ?? [];
  196. $user = $request->user();
  197. $vipOpen = sys_config('vip_open');
  198. $vipOpen = is_string($vipOpen) ? (int)$vipOpen : $vipOpen;
  199. foreach ($menusInfo as $key => &$value) {
  200. $value['pic'] = set_file_url($value['pic']);
  201. if ($value['id'] == 137 && !(intval(sys_config('store_brokerage_statu')) == 2 || $user->is_promoter == 1))
  202. unset($menusInfo[$key]);
  203. if ($value['id'] == 174 && !StoreService::orderServiceStatus($user->uid))
  204. unset($menusInfo[$key]);
  205. if (((!StoreService::orderServiceStatus($user->uid)) && (!SystemStoreStaff::verifyStatus($user->uid))) && $value['wap_url'] === '/order/order_cancellation')
  206. unset($menusInfo[$key]);
  207. if (((!StoreService::orderServiceStatus($user->uid)) && (!SystemStoreStaff::verifyStatus($user->uid))) && $value['wap_url'] === '/admin/order_cancellation/index')
  208. unset($menusInfo[$key]);
  209. if ((!StoreService::orderServiceStatus($user->uid)) && $value['wap_url'] === '/admin/order/index')
  210. unset($menusInfo[$key]);
  211. if ($value['wap_url'] == '/user/vip' && !$vipOpen)
  212. unset($menusInfo[$key]);
  213. if ($value['wap_url'] == '/customer/index' && !StoreService::orderServiceStatus($user->uid))
  214. unset($menusInfo[$key]);
  215. }
  216. return app('json')->successful(['routine_my_menus' => $menusInfo]);
  217. }
  218. /**
  219. * 热门搜索关键字获取
  220. * @return mixed
  221. * @throws DataNotFoundException
  222. * @throws ModelNotFoundException
  223. * @throws \think\exception\DbException
  224. */
  225. public function search()
  226. {
  227. $routineHotSearch = sys_data('routine_hot_search') ?? [];
  228. $searchKeyword = [];
  229. if (count($routineHotSearch)) {
  230. foreach ($routineHotSearch as $key => &$item) {
  231. array_push($searchKeyword, $item['title']);
  232. }
  233. }
  234. return app('json')->successful($searchKeyword);
  235. }
  236. /**
  237. * 图片上传
  238. * @param Request $request
  239. * @return mixed
  240. * @throws \Psr\SimpleCache\InvalidArgumentException
  241. */
  242. public function upload_image(Request $request)
  243. {
  244. $data = UtilService::postMore([
  245. ['filename', 'file'],
  246. ], $request);
  247. if (!$data['filename']) return app('json')->fail('参数有误');
  248. if (Cache::has('start_uploads_' . $request->uid()) && Cache::get('start_uploads_' . $request->uid()) >= 100) return app('json')->fail('非法操作');
  249. $upload_type = sys_config('upload_type', 1);
  250. $upload = new Upload((int)$upload_type, [
  251. 'accessKey' => sys_config('accessKey'),
  252. 'secretKey' => sys_config('secretKey'),
  253. 'uploadUrl' => sys_config('uploadUrl'),
  254. 'storageName' => sys_config('storage_name'),
  255. 'storageRegion' => sys_config('storage_region'),
  256. ]);
  257. $info = $upload->to('store/comment')->validate()->move($data['filename']);
  258. if ($info === false) {
  259. return app('json')->fail($upload->getError());
  260. }
  261. $res = $upload->getUploadInfo();
  262. SystemAttachment::attachmentAdd($res['name'], $res['size'], $res['type'], $res['dir'], $res['thumb_path'], 1, $upload_type, $res['time'], 2);
  263. if (Cache::has('start_uploads_' . $request->uid()))
  264. $start_uploads = (int)Cache::get('start_uploads_' . $request->uid());
  265. else
  266. $start_uploads = 0;
  267. $start_uploads++;
  268. Cache::set('start_uploads_' . $request->uid(), $start_uploads, 86400);
  269. $res['dir'] = path_to_url($res['dir']);
  270. if (strpos($res['dir'], 'http') === false) $res['dir'] = $request->domain() . $res['dir'];
  271. return app('json')->successful('图片上传成功!', ['name' => $res['name'], 'url' => $res['dir']]);
  272. }
  273. /**
  274. * 物流公司
  275. * @return mixed
  276. */
  277. public function logistics()
  278. {
  279. $expressList = Express::lst();
  280. if (!$expressList) return app('json')->successful([]);
  281. return app('json')->successful($expressList->hidden(['code', 'id', 'sort', 'is_show'])->toArray());
  282. }
  283. /**
  284. * 短信购买异步通知
  285. *
  286. * @param Request $request
  287. * @return mixed
  288. */
  289. public function sms_pay_notify(Request $request)
  290. {
  291. list($order_id, $price, $status, $num, $pay_time, $attach) = UtilService::postMore([
  292. ['order_id', ''],
  293. ['price', 0.00],
  294. ['status', 400],
  295. ['num', 0],
  296. ['pay_time', time()],
  297. ['attach', 0],
  298. ], $request, true);
  299. if ($status == 200) {
  300. ChannelService::instance()->send('PAY_SMS_SUCCESS', ['price' => $price, 'number' => $num], [$attach]);
  301. return app('json')->successful();
  302. }
  303. return app('json')->fail();
  304. }
  305. /**
  306. * 记录用户分享
  307. * @param Request $request
  308. * @return mixed
  309. */
  310. public function user_share(Request $request)
  311. {
  312. return app('json')->successful(UserBill::setUserShare($request->uid()));
  313. }
  314. /**
  315. * 获取图片base64
  316. * @param Request $request
  317. * @return mixed
  318. */
  319. public function get_image_base64(Request $request)
  320. {
  321. list($imageUrl, $codeUrl) = UtilService::postMore([
  322. ['image', ''],
  323. ['code', ''],
  324. ], $request, true);
  325. try {
  326. $codeTmp = $code = $codeUrl ? image_to_base64($codeUrl) : false;
  327. if (!$codeTmp) {
  328. $putCodeUrl = put_image($codeUrl);
  329. $code = $putCodeUrl ? image_to_base64($_SERVER['HTTP_HOST'] . '/' . $putCodeUrl) : false;
  330. $code ?? unlink($_SERVER["DOCUMENT_ROOT"] . '/' . $putCodeUrl);
  331. }
  332. $imageTmp = $image = $imageUrl ? image_to_base64($imageUrl) : false;
  333. if (!$imageTmp) {
  334. $putImageUrl = put_image($imageUrl);
  335. $image = $putImageUrl ? image_to_base64($_SERVER['HTTP_HOST'] . '/' . $putImageUrl) : false;
  336. $image ?? unlink($_SERVER["DOCUMENT_ROOT"] . '/' . $putImageUrl);
  337. }
  338. return app('json')->successful(compact('code', 'image'));
  339. } catch (\Exception $e) {
  340. return app('json')->fail($e->getMessage());
  341. }
  342. }
  343. /**
  344. * 门店列表
  345. * @return mixed
  346. */
  347. public function store_list(Request $request)
  348. {
  349. list($latitude, $longitude, $page, $limit) = UtilService::getMore([
  350. ['latitude', ''],
  351. ['longitude', ''],
  352. ['page', 1],
  353. ['limit', 10]
  354. ], $request, true);
  355. $list = SystemStore::lst($latitude, $longitude, $page, $limit);
  356. if (!$list) $list = [];
  357. $data['list'] = $list;
  358. $data['tengxun_map_key'] = sys_config('tengxun_map_key');
  359. return app('json')->successful($data);
  360. }
  361. /**
  362. * 查找城市数据
  363. * @param Request $request
  364. * @return mixed
  365. */
  366. public function city_list(Request $request)
  367. {
  368. $list = CacheService::get('CITY_LIST', function () {
  369. $list = SystemCity::with('children')->field(['city_id', 'name', 'id', 'parent_id'])->where('parent_id', 0)->order('id asc')->select()->toArray();
  370. $data = [];
  371. foreach ($list as &$item) {
  372. $value = ['v' => $item['city_id'], 'n' => $item['name']];
  373. if ($item['children']) {
  374. foreach ($item['children'] as $key => &$child) {
  375. $value['c'][$key] = ['v' => $child['city_id'], 'n' => $child['name']];
  376. unset($child['id'], $child['area_code'], $child['merger_name'], $child['is_show'], $child['level'], $child['lng'], $child['lat'], $child['lat']);
  377. if (SystemCity::where('parent_id', $child['city_id'])->count()) {
  378. $child['children'] = SystemCity::where('parent_id', $child['city_id'])->field(['city_id', 'name', 'id', 'parent_id'])->select()->toArray();
  379. foreach ($child['children'] as $kk => $vv) {
  380. $value['c'][$key]['c'][$kk] = ['v' => $vv['city_id'], 'n' => $vv['name']];
  381. }
  382. }
  383. }
  384. }
  385. $data[] = $value;
  386. }
  387. return $data;
  388. }, 0);
  389. return app('json')->successful($list);
  390. }
  391. /**
  392. * 查找城市数据
  393. * @param Request $request
  394. * @return mixed
  395. */
  396. public function data_center(Request $request)
  397. {
  398. $bt_all = sys_config('bt_sum', 0);
  399. $bt_circulate = UserMoney::where('money_type', 'BT')->sum('money');
  400. $bt_destroy = UserMoneyOrder::where('money_type', 'BT')->where('to_uid', 0)->sum('money');
  401. $bt_create_all = UserMoneyOrder::where('money_type', 'BT')->where('uid', 0)->sum('money');
  402. $bt_create_today = UserMoneyOrder::whereTime('add_time', 'today')->where('money_type', 'BT')->where('uid', 0)->sum('money');
  403. $bt = compact('bt_all', 'bt_circulate', 'bt_create_all', 'bt_create_today', 'bt_destroy');
  404. return app('json')->successful('ok', compact('bt'));
  405. }
  406. public function checkMoney($money_type, Request $request)
  407. {
  408. $num = $request->get('num', 0);
  409. $price = 0;
  410. $list = sys_data('money_type');
  411. foreach ($list as $v) {
  412. if ($v['code'] == $money_type) {
  413. $price = $v['price'] ? $v['price'] : CashTradeOrder::averagePrice($v['code']);
  414. }
  415. }
  416. return bcmul($num, $price, 2);
  417. }
  418. }