Order.php 6.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162
  1. <?php
  2. namespace App\Http\Controllers\admin;
  3. use App\Http\Controllers\Controller;
  4. use App\Models\FundsRecord;
  5. use App\Models\User;
  6. use App\Models\Order as OrderModel;
  7. use Exception;
  8. use Illuminate\Support\Facades\DB;
  9. use App\Constants\HttpStatus;
  10. use App\Models\Wallet;
  11. /**
  12. * 足球订单
  13. */
  14. class Order extends Controller
  15. {
  16. /**
  17. * 订单手动退款
  18. */
  19. public function refund()
  20. {
  21. DB::beginTransaction();
  22. try {
  23. $params = request()->validate([
  24. 'id' => ['required', 'array', 'min:1'],
  25. ]);
  26. $orderList = OrderModel::whereIn('id', $params['id'])->get();
  27. foreach ($orderList as $order) {
  28. if ($order->return_status != 0 || $order->pay_status != 1 || $order->settlement_status != 0) {
  29. continue;
  30. }
  31. $order->status = 2;
  32. $order->return_status = 2;
  33. $order->return_operation_time = time();
  34. $order->save();
  35. // 获取用户余额
  36. $walletInfo = Wallet::where(['member_id' => $order->user_id])->first();
  37. if (!$walletInfo) continue;
  38. $before = $walletInfo->available_balance;
  39. $after = bcsub($walletInfo->available_balance, $order->amount, 2);
  40. $walletInfo->available_balance = $after;
  41. $walletInfo->save();
  42. FundsRecord::addData([
  43. 'change_type' => '退款',
  44. 'amount' => $order->amount,
  45. 'before_balance' => $before,
  46. 'after_balance' => $after,
  47. 'member_id' => $order->user_id,
  48. 'related_id' => $order->id,
  49. 'remark' => '体彩订单退款',
  50. ]);
  51. }
  52. DB::commit();
  53. } catch (Exception $e) {
  54. DB::rollBack();
  55. return $this->error(HttpStatus::CUSTOM_ERROR, $e->getMessage());
  56. }
  57. return $this->success();
  58. }
  59. /**
  60. * 订单列表
  61. */
  62. public function list()
  63. {
  64. try {
  65. $params = request()->validate([
  66. 'page' => ['nullable', 'integer', 'min:1'],
  67. 'limit' => ['nullable', 'integer', 'min:1'],
  68. 'id' => ['nullable', 'string'],
  69. 'user_id' => ['nullable', 'string'],
  70. 'order_id' => ['nullable', 'string'],
  71. 'issue' => ['nullable', 'integer'],
  72. 'pay_status' => ['nullable', 'integer', 'in:0,1'],
  73. 'is_win' => ['nullable', 'integer', 'in:0,1'],
  74. 'is_roll' => ['nullable', 'integer', 'in:0,1'],
  75. 'settlement_status' => ['nullable', 'integer', 'in:0,1,2,3'],
  76. 'return_status' => ['nullable', 'integer', 'in:0,1,2,3'],
  77. 'status' => ['nullable', 'integer', 'in:0,1,2,-1'],
  78. 'start_time' => ['nullable', 'date', 'date_format:Y-m-d', 'required_with:end_time'],
  79. 'end_time' => ['nullable', 'date', 'date_format:Y-m-d', 'required_with:start_time'],
  80. ]);
  81. $page = request()->input('page', 1);
  82. $limit = request()->input('limit', 15);
  83. $query = new OrderModel();
  84. if (!empty($params['start_time'])) {
  85. $startTime = strtotime($params['start_time'] . " 00:00:00");
  86. $query = $query->where('create_time', '>=', $startTime);
  87. }
  88. if (!empty($params['end_time'])) {
  89. $endTime = strtotime($params['end_time'] . " 23:59:59");
  90. $query = $query->where('create_time', '<=', $endTime);
  91. }
  92. if (!empty($params['id'])) {
  93. $query = $query->where('id', $params['id']);
  94. }
  95. if (!empty($params['order_id'])) {
  96. $query = $query->where('order_id', $params['order_id']);
  97. }
  98. if (!empty($params['user_id'])) {
  99. $query = $query->where('user_id', $params['user_id']);
  100. }
  101. if (isset($params['status'])) {
  102. $query = $query->where('status', $params['status']);
  103. }
  104. if (isset($params['return_status'])) {
  105. $query = $query->where('return_status', $params['return_status']);
  106. }
  107. if (isset($params['pay_status'])) {
  108. $query = $query->where('pay_status', $params['pay_status']);
  109. }
  110. if (isset($params['is_win'])) {
  111. $query = $query->where('is_win', $params['is_win']);
  112. }
  113. if (isset($params['settlement_status'])) {
  114. $query = $query->where('settlement_status', $params['settlement_status']);
  115. }
  116. if (isset($params['is_roll'])) {
  117. $query = $query->where('is_roll', $params['is_roll']);
  118. }
  119. $count = $query->count();
  120. $list = $query
  121. ->forPage($page, $limit)
  122. ->orderByDesc('create_time')
  123. ->get();
  124. } catch (Exception $e) {
  125. return $this->error(HttpStatus::CUSTOM_ERROR,$e->getMessage());
  126. }
  127. return $this->success(['total' => $count, 'data' => $list]);
  128. }
  129. //订单详情
  130. function info()
  131. {
  132. try {
  133. request()->validate([
  134. 'order_id' => ['required', 'string'],
  135. ]);
  136. $order_id = request()->input('order_id');
  137. $order = OrderModel::where('order_id', $order_id)->first();
  138. if (!$order) throw new Exception('订单不存在');
  139. $order = $order->toArray();
  140. $order['detail'] = json_decode($order['detail'],true);
  141. $order['game_result'] = $order['game_result'] ? json_decode($order['game_result'],true) : null;
  142. $order['first_name'] = User::where('user_id', $order['user_id'])->value('first_name');
  143. ksort($order);
  144. } catch (Exception $e) {
  145. return $this->error(HttpStatus::CUSTOM_ERROR,$e->getMessage());
  146. }
  147. return $this->success($order);
  148. }
  149. }