GongdengOrderService.php 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304
  1. <?php
  2. // +----------------------------------------------------------------------
  3. // | Laravel框架 [ Laravel ]
  4. // +----------------------------------------------------------------------
  5. // | 版权所有 2017~2021 Laravel研发中心
  6. // +----------------------------------------------------------------------
  7. // | 官方网站: http://www.laravel.cn
  8. // +----------------------------------------------------------------------
  9. // | Author: wesmiler <12345678@qq.com>
  10. // +----------------------------------------------------------------------
  11. namespace App\Services;
  12. use App\Models\GongdengFoxiangModel;
  13. use App\Models\GongdengOrderModel;
  14. use App\Models\LampMealsModel;
  15. use App\Models\MemberModel;
  16. /**
  17. * 供灯管理-服务类
  18. * @author wesmiler
  19. * @since 2020/11/11
  20. * Class GongdengOrderService
  21. * @package App\Services
  22. */
  23. class GongdengOrderService extends BaseService
  24. {
  25. /**
  26. * 构造函数
  27. * @author wesmiler
  28. * @since 2020/11/11
  29. * GongdengOrderService constructor.
  30. */
  31. public function __construct()
  32. {
  33. $this->model = new GongdengOrderModel();
  34. }
  35. public function getList()
  36. {
  37. $params = request()->all();
  38. $page = isset($params['pageSize']) ? intval($params['pageSize']) : PAGE;
  39. $pageSize = isset($params['pageSize']) ? intval($params['pageSize']) : PERPAGE;
  40. $dataList = $this->model::from('gongdeng_orders as a')
  41. ->leftJoin('gongdeng_foxiang as gf', 'gf.id', '=', 'a.source_id')
  42. ->leftJoin('member as m', 'a.user_id', '=', 'm.id')
  43. ->where(function ($query) use ($params) {
  44. $query->where('a.mark', 1);
  45. $status = isset($params['status']) ? $params['status'] : 0;
  46. if ($status > 0) {
  47. $query->where('a.status', $status);
  48. } else {
  49. $query->where('a.status', '>', 0);
  50. }
  51. })
  52. ->where(function ($query) use ($params) {
  53. $keyword = isset($params['keyword']) ? trim($params['keyword']) : '';
  54. if (!empty($keyword)) {
  55. $query->where('a.order_sn', 'like', "%{$keyword}%")
  56. ->orWhere('m.nickname', 'like', "%{$keyword}%");
  57. }
  58. })
  59. ->select(['a.id', 'a.source_id', 'a.user_id','a.pay_money','a.total','a.num','a.device_num','a.is_hide','a.order_sn','a.buy_type','a.trade_no', 'a.sf_name', 'a.qf_content', 'a.is_hide', 'gf.name as fx_name', 'gf.thumb as fx_thumb', 'm.nickname', 'm.avatar', 'a.status','a.lamp_status', 'a.create_time', 'a.pay_at','a.expire_time', 'a.update_time'])
  60. ->orderBy('a.pay_at', 'desc')
  61. ->orderBy('a.create_time', 'desc')
  62. ->paginate($pageSize);
  63. $dataList = $dataList ? $dataList->toArray() : [];
  64. if ($dataList) {
  65. foreach ($dataList['data'] as &$item) {
  66. $item['avatar'] = $item['avatar'] ? get_image_url($item['avatar']) : '';
  67. $item['fx_thumb'] = $item['fx_thumb'] ? get_image_url($item['fx_thumb']) : '';
  68. $item['create_time'] = $item['create_time'] ? datetime($item['create_time'], 'Y-m-d H:i:s') : '';
  69. $item['expire_at'] = $item['expire_time'] ? datetime($item['expire_time'], 'Y-m-d H:i:s') : '';
  70. }
  71. unset($item);
  72. }
  73. return [
  74. 'code' => 0,
  75. 'success' => true,
  76. 'msg' => '操作成功',
  77. 'count' => isset($dataList['total']) ? $dataList['total'] : 0,
  78. 'data' => isset($dataList['data']) ? $dataList['data'] : 0,
  79. ];
  80. }
  81. /**
  82. * 功德列表
  83. */
  84. public function getGdList()
  85. {
  86. $params = request()->all();
  87. $page = isset($params['pageSize']) ? intval($params['pageSize']) : PAGE;
  88. $pageSize = isset($params['pageSize']) ? intval($params['pageSize']) : PERPAGE;
  89. $dataList = $this->model::from('gongdeng_orders as a')
  90. ->leftJoin('gongdeng_foxiang as gf', 'gf.id', '=', 'a.source_id')
  91. ->leftJoin('member as m', 'a.user_id', '=', 'm.id')
  92. ->where(['a.mark' => 1, 'a.status' => 2])
  93. ->select(['a.id', 'a.source_id', 'a.user_id', 'a.sf_name', 'a.qf_content', 'a.is_hide', 'gf.name as fx_name', 'm.nickname', 'm.avatar', 'a.status', 'a.create_time', 'a.pay_at', 'a.update_time'])
  94. ->orderBy('a.pay_at', 'desc')
  95. ->orderBy('a.create_time', 'desc')
  96. ->paginate($pageSize);
  97. $dataList = $dataList ? $dataList->toArray() : [];
  98. if ($dataList) {
  99. foreach ($dataList['data'] as &$item) {
  100. $item['avatar'] = $item['avatar'] ? get_image_url($item['avatar']) : '';
  101. $item['create_time'] = $item['create_time'] ? datetime($item['create_time'], 'Y-m-d H:i:s') : '';
  102. $time = $item['pay_at'] ? $item['pay_at'] : $item['create_time'];
  103. $item['time_text'] = $time ? format_time(strtotime($time)) : '刚刚';
  104. if ($item['is_hide']) {
  105. $item['nickname'] = formatName($item['nickname']);
  106. }
  107. }
  108. unset($item);
  109. }
  110. return [
  111. 'code' => 0,
  112. 'success' => true,
  113. 'msg' => '操作成功',
  114. 'count' => isset($dataList['total']) ? $dataList['total'] : 0,
  115. 'data' => isset($dataList['data']) ? $dataList['data'] : 0,
  116. ];
  117. }
  118. /**
  119. * 我的供灯列表
  120. */
  121. public function getMyGdList($userId)
  122. {
  123. $params = request()->all();
  124. $page = isset($params['pageSize']) ? intval($params['pageSize']) : PAGE;
  125. $pageSize = isset($params['pageSize']) ? intval($params['pageSize']) : PERPAGE;
  126. $dataList = $this->model::from('gongdeng_orders as a')
  127. ->leftJoin('gongdeng_foxiang as gf', 'gf.id', '=', 'a.source_id')
  128. ->leftJoin('member as m', 'a.user_id', '=', 'm.id')
  129. ->where(['a.mark' => 1,'a.user_id'=> $userId])
  130. ->whereIn('a.status',[1,2,3])
  131. ->select(['a.id', 'a.source_id','a.order_sn', 'a.user_id', 'a.sf_name','gf.thumb as fx_thumb','a.buy_type','a.pay_money', 'a.qf_content','a.lamp_status','a.device_num', 'a.is_hide','a.expire_time', 'gf.name as fx_name', 'm.nickname', 'm.avatar', 'a.status', 'a.create_time', 'a.pay_at', 'a.update_time'])
  132. ->orderBy('a.pay_at', 'desc')
  133. ->orderBy('a.create_time', 'desc')
  134. ->paginate($pageSize);
  135. $dataList = $dataList ? $dataList->toArray() : [];
  136. if ($dataList) {
  137. foreach ($dataList['data'] as &$item) {
  138. $item['avatar'] = $item['avatar'] ? get_image_url($item['avatar']) : '';
  139. $item['fx_thumb'] = $item['fx_thumb'] ? get_image_url($item['fx_thumb']) : '';
  140. $item['create_time'] = $item['create_time'] ? datetime($item['create_time'], 'Y-m-d H:i:s') : '';
  141. $item['expire_at'] = $item['expire_time'] ? datetime($item['expire_time'], 'Y-m-d H:i:s') : '';
  142. $time = $item['pay_at'] ? $item['pay_at'] : $item['create_time'];
  143. $item['time_text'] = $time ? format_time(strtotime($time)) : '刚刚';
  144. // $item['nickname'] = iconv('utf8','utf8mb4', $item['nickname']);
  145. if ($item['is_hide']) {
  146. $item['nickname'] = formatName($item['nickname']);
  147. }
  148. }
  149. unset($item);
  150. }
  151. return [
  152. 'code' => 0,
  153. 'success' => true,
  154. 'msg' => '操作成功',
  155. 'count' => isset($dataList['total']) ? $dataList['total'] : 0,
  156. 'data' => isset($dataList['data']) ? $dataList['data'] : 0,
  157. ];
  158. }
  159. /**
  160. * 获取订单信息
  161. * @param $orderSn
  162. * @return array
  163. */
  164. public function orderInfo($orderSn){
  165. $info = $this->model::where(['order_sn'=> $orderSn, 'mark'=> 1])
  166. ->whereIn('status',[1,2,3])
  167. ->select(['id','order_sn as out_trade_no','source_id','user_id','pay_money','total','status'])
  168. ->first();
  169. $info = $info? $info->toArray() : [];
  170. if($info){
  171. $info['type'] = 1;
  172. $info['pay_money'] = $info['pay_money']? $info['pay_money'] : $info['total'];
  173. }
  174. return $info;
  175. }
  176. /**
  177. * 供灯下单
  178. */
  179. public function buy($userId)
  180. {
  181. $params = request()->all();
  182. // 验证佛像信息
  183. $fid = isset($params['fid']) ? $params['fid'] : 0;
  184. $foInfo = GongdengFoxiangModel::where(['id' => $fid, 'status' => 1, 'mark' => 1])
  185. ->select(['id', 'name'])
  186. ->first();
  187. if (!$foInfo || $fid <= 0) {
  188. return message('供灯佛像信息不存在', false);
  189. }
  190. $payType = isset($params['payType']) ? $params['payType'] : 0;
  191. if (!in_array($payType, [1])) {
  192. return message('支付方式暂不支持', false);
  193. }
  194. // 套餐信息
  195. $mid = isset($params['mid']) ? $params['mid'] : 0;
  196. $mealInfo = LampMealsModel::where(['id' => $mid, 'status' => 1, 'mark' => 1])
  197. ->select(['id', 'name', 'price', 'num'])
  198. ->first();
  199. if (!$mealInfo) {
  200. return message('供灯套餐不存在或已下架', false);
  201. }
  202. // 验证用户是否已授权
  203. $memberInfo = MemberModel::where(['id' => $userId, 'mark' => 1, 'status' => 1])
  204. ->select('id', 'openid', 'nickname')
  205. ->first();
  206. $openid = isset($memberInfo['openid']) ? trim($memberInfo['openid']) : '';
  207. if (!$memberInfo) {
  208. return message('账号已被冻结,请联系客服', false);
  209. }
  210. if (empty($openid)) {
  211. return message('账号获取授权参数失败,请退出重试', false);
  212. }
  213. // 验证是否供灯过
  214. $buyType = 1;
  215. $gdCheckData = GongdengOrderModel::where(['source_id' => $fid, 'user_id' => $userId,'lamp_status'=> 2, 'status' => 2, 'mark' => 1])
  216. ->where('expire_time', '>=', time())
  217. ->select(['id', 'source_id', 'user_id','device_num', 'expire_time', 'params'])
  218. ->first();
  219. // 续费
  220. if ($gdCheckData && $gdCheckData->id) {
  221. $buyType = 2;
  222. }
  223. // 创建订单
  224. $expireTime = ($mealInfo->num * 24 * 3600) + time();
  225. $data = [
  226. 'source_id' => $fid,
  227. 'user_id' => $userId,
  228. 'pay_type' => $payType,
  229. 'buy_type' => $buyType,
  230. 'order_sn' => get_order_num('G'),
  231. 'num' => 1,
  232. 'price' => $mealInfo->price,
  233. 'total' => $mealInfo->price,
  234. 'sf_name' => isset($params['sf_name']) ? trim($params['sf_name']) : '',
  235. 'qf_content' => isset($params['qf_content']) ? trim($params['qf_content']) : '',
  236. 'is_hide' => isset($params['is_hide']) ? intval($params['is_hide']) : 0,
  237. 'expire_time' => $expireTime,
  238. 'create_time' => time(),
  239. 'status' => 1,
  240. ];
  241. if($gdCheckData){
  242. $data['device_num'] = $gdCheckData->device_num;
  243. $data['params'] = $gdCheckData->params;
  244. }
  245. // 订单
  246. if (!$oid = GongdengOrderModel::insertGetId($data)) {
  247. return message('供灯订单创建失败', false);
  248. }
  249. // 支付参数
  250. switch ($payType) {
  251. case 1: // 微信支付
  252. $order = [
  253. 'openid' => $openid,
  254. 'orderNo' => $data['order_sn'],
  255. 'amount' => $data['total'],
  256. 'body' => '供灯订单支付',
  257. ];
  258. $jsapiParams = WechatService::jsapiUnifiedorder($order);
  259. $code = isset($jsapiParams['code']) ? $jsapiParams['code'] : '';
  260. if ($code == 'error' || empty($jsapiParams)) {
  261. $message = isset($jsapiParams['message']) && $jsapiParams['message'] ? $jsapiParams['message'] : '订单支付处理失败';
  262. return message($message, false);
  263. }
  264. return message('订单创建成功', true, ['id' => $oid, 'params' => $jsapiParams]);
  265. break;
  266. default:
  267. break;
  268. }
  269. return message('支付处理失败', false);
  270. }
  271. }