LhcOrder.php 8.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235
  1. <?php
  2. namespace App\Http\Controllers\admin;
  3. use App\Http\Controllers\Controller;
  4. use App\Models\LhcOrder as LhcOrderModel;
  5. use App\Models\FundsRecord;
  6. use App\Models\Wallet;
  7. use App\Models\LhcLottery;
  8. use App\Models\PcIssue;
  9. use App\Models\Issue;
  10. use App\Models\JisuLottery;
  11. use Exception;
  12. use App\Constants\HttpStatus;
  13. use Illuminate\Support\Facades\DB;
  14. class LhcOrder extends Controller
  15. {
  16. /**
  17. * 订单列表
  18. */
  19. public function list()
  20. {
  21. try {
  22. $params = request()->validate([
  23. 'page' => ['nullable', 'integer', 'min:1'],
  24. 'limit' => ['nullable', 'integer', 'min:1'],
  25. 'issue' => ['nullable', 'string'],
  26. 'ordernum' => ['nullable', 'string'],
  27. 'member_id' => ['nullable', 'integer'],
  28. 'first_name' => ['nullable'],
  29. 'game' => ['nullable', 'string'],
  30. 'gameplay' => ['nullable', 'string'],
  31. 'number' => ['nullable'],
  32. 'lottery_status' => ['nullable', 'integer'],
  33. 'is_faker' => ['nullable', 'integer'],
  34. 'id' => ['nullable', 'integer'],
  35. 'type' => ['nullable', 'integer'],
  36. ]);
  37. $page = request()->input('page', 1);
  38. $limit = request()->input('limit', 15);
  39. $query = new LhcOrderModel();
  40. $query = LhcOrderModel::join('users', 'users.member_id', '=', 'lhc_order.member_id');
  41. if (!empty($params['id'])) {
  42. $query = $query->where('lhc_order.id', $params['id']);
  43. }
  44. if (!empty($params['issue'])) {
  45. $query = $query->where('lhc_order.issue', $params['issue']);
  46. }
  47. if (!empty($params['ordernum'])) {
  48. $query = $query->where('lhc_order.ordernum', $params['ordernum']);
  49. }
  50. if (!empty($params['member_id'])) {
  51. $query = $query->where('lhc_order.member_id', $params['member_id']);
  52. }
  53. if (isset($params['lottery_status']) && $params['lottery_status'] !== null) {
  54. $query = $query->where('lhc_order.lottery_status', $params['lottery_status']);
  55. }
  56. if (isset($params['is_faker']) && $params['is_faker'] !== null) {
  57. $query = $query->where('lhc_order.is_faker', $params['is_faker']);
  58. }
  59. if (!empty($params['game'])) {
  60. $query = $query->where('lhc_order.game', $params['game']);
  61. }
  62. if (!empty($params['gameplay'])) {
  63. $query = $query->where('lhc_order.gameplay', $params['gameplay']);
  64. }
  65. if (!empty($params['number'])) {
  66. $query = $query->where('lhc_order.number', $params['number']);
  67. }
  68. if (!empty($params['type'])) {
  69. $query = $query->where('lhc_order.type', $params['type']);
  70. }
  71. if (!empty($params['first_name'])) {
  72. $query = $query->where('users.first_name', 'like', "%{$params['first_name']}%");
  73. }
  74. $count = $query->count();
  75. $list = $query->select('lhc_order.*','users.first_name','users.member_id')
  76. ->forPage($page, $limit)
  77. ->orderByDesc('lhc_order.created_at')
  78. ->get();
  79. foreach($list as &$info) {
  80. //六合彩彩票
  81. if ($info['type'] >= 1 and $info['type'] <= 4) {
  82. $lottery = LhcLottery::where('type', $info['type'])->where('issue', $info['issue'])->first();
  83. if ($lottery) {
  84. $info['lottery'] = [
  85. 'open_code' => $lottery->open_code,
  86. 'open_code_other' => ''
  87. ];
  88. }
  89. }
  90. //28
  91. if ($info['type'] == 5 || $info['type'] == 6) {
  92. if ($info['type'] == 6) {
  93. $issue = PcIssue::where('issue_no', $info['issue'])->first();
  94. } elseif ($info['type'] == 5) {
  95. $issue = Issue::where('issue_no', $info['issue'])->first();
  96. }
  97. $info['lottery'] = [
  98. 'open_code' => $issue->winning_numbers,
  99. 'open_code_other' => $issue->combo
  100. ];
  101. }
  102. //极速彩票
  103. if ($info['type'] >= 7 and $info['type'] <= 13) {
  104. $lottery = JisuLottery::where('type', $info['type'] - 6)->where('issue', $info['issue'])->first();
  105. if ($lottery) {
  106. $info['lottery'] = [
  107. 'open_code' => $lottery->open_code,
  108. 'open_code_other' => $lottery->open_code_other
  109. ];
  110. }
  111. }
  112. }
  113. } catch (Exception $e) {
  114. return $this->error(HttpStatus::CUSTOM_ERROR,$e->getMessage());
  115. }
  116. return $this->success(['total' => $count, 'data' => $list]);
  117. }
  118. //订单详情
  119. function info()
  120. {
  121. try {
  122. request()->validate([
  123. 'id' => ['required', 'integer'],
  124. ]);
  125. $id = request()->input('id');
  126. $info = LhcOrderModel::where('id', $id)->first();
  127. if (!$info) throw new Exception('订单不存在');
  128. $info = $info->toArray();
  129. //六合彩彩票
  130. if ($info['type'] >= 1 and $info['type'] <= 4) {
  131. $lottery = LhcLottery::where('type', $info['type'])->where('issue', $info['issue'])->first();
  132. if ($lottery) {
  133. $info['lottery'] = [
  134. 'open_code' => $lottery->open_code,
  135. 'open_code_other' => ''
  136. ];
  137. }
  138. }
  139. //28
  140. if ($info['type'] == 5 || $info['type'] == 6) {
  141. if ($info['type'] == 6) {
  142. $issue = PcIssue::where('issue_no', $info['issue'])->first();
  143. } elseif ($info['type'] == 5) {
  144. $issue = Issue::where('issue_no', $info['issue'])->first();
  145. }
  146. $info['lottery'] = [
  147. 'open_code' => $issue->winning_numbers,
  148. 'open_code_other' => $issue->combo
  149. ];
  150. }
  151. //极速彩票
  152. if ($info['type'] >= 7 and $info['type'] <= 13) {
  153. $lottery = JisuLottery::where('type', $info['type'] - 6)->where('issue', $info['issue'])->first();
  154. if ($lottery) {
  155. $info['lottery'] = [
  156. 'open_code' => $lottery->open_code,
  157. 'open_code_other' => $lottery->open_code_other
  158. ];
  159. }
  160. }
  161. } catch (Exception $e) {
  162. return $this->error(HttpStatus::CUSTOM_ERROR,$e->getMessage());
  163. }
  164. return $this->success($info);
  165. }
  166. /**
  167. * @api {post} /lhcorder/refund 同意退款
  168. * @apiGroup 订单管理
  169. */
  170. public function refund()
  171. {
  172. $errors = [];
  173. try {
  174. DB::beginTransaction();
  175. $params = request()->validate([
  176. 'id' => ['required', 'array', 'min:1'],
  177. ]);
  178. $orderList = LhcOrderModel::whereIn('id', $params['id'])->get();
  179. foreach ($orderList as $order) {
  180. if ($order->lottery_status != 0) {
  181. continue;
  182. }
  183. $order->lottery_status = 4;
  184. $order->updated_at = time();
  185. $order->save();
  186. // 获取用户余额
  187. $walletInfo = Wallet::where(['member_id' => $order->member_id])->first();
  188. if (!$walletInfo) continue;
  189. $before = $walletInfo->available_balance;
  190. $after = bcsub($walletInfo->available_balance, $order->amount, 2);
  191. $walletInfo->available_balance = $after;
  192. $walletInfo->save();
  193. $remark = LhcOrderModel::getRemark($order->type);
  194. FundsRecord::addData([
  195. 'change_type' => $remark.'退款',
  196. 'amount' => $order->amount,
  197. 'before_balance' => $before,
  198. 'after_balance' => $after,
  199. 'member_id' => $order->member_id,
  200. 'related_id' => $order->id,
  201. 'remark' => $remark.'订单退款',
  202. ]);
  203. }
  204. DB::commit();
  205. } catch (Exception $e) {
  206. DB::rollBack();
  207. return $this->error(HttpStatus::CUSTOM_ERROR,$e->getMessage(), $errors);
  208. }
  209. return $this->success();
  210. }
  211. }