LhcOrder.php 5.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150
  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 Exception;
  8. use App\Constants\HttpStatus;
  9. use Illuminate\Support\Facades\DB;
  10. class LhcOrder extends Controller
  11. {
  12. /**
  13. * 订单列表
  14. */
  15. public function list()
  16. {
  17. try {
  18. $params = request()->validate([
  19. 'page' => ['nullable', 'integer', 'min:1'],
  20. 'limit' => ['nullable', 'integer', 'min:1'],
  21. 'issue' => ['nullable', 'string'],
  22. 'ordernum' => ['nullable', 'string'],
  23. 'member_id' => ['nullable', 'integer'],
  24. 'game' => ['nullable', 'string'],
  25. 'gameplay' => ['nullable', 'string'],
  26. 'number' => ['nullable'],
  27. 'lottery_status' => ['nullable', 'integer'],
  28. 'is_faker' => ['nullable', 'integer'],
  29. 'id' => ['nullable', 'integer'],
  30. 'type' => ['nullable', 'integer'],
  31. ]);
  32. $page = request()->input('page', 1);
  33. $limit = request()->input('limit', 15);
  34. $query = new LhcOrderModel();
  35. if (!empty($params['id'])) {
  36. $query = $query->where('id', $params['id']);
  37. }
  38. if (!empty($params['issue'])) {
  39. $query = $query->where('issue', $params['issue']);
  40. }
  41. if (!empty($params['ordernum'])) {
  42. $query = $query->where('ordernum', $params['ordernum']);
  43. }
  44. if (!empty($params['member_id'])) {
  45. $query = $query->where('member_id', $params['member_id']);
  46. }
  47. if (isset($params['lottery_status']) && $params['lottery_status'] !== null) {
  48. $query = $query->where('lottery_status', $params['lottery_status']);
  49. }
  50. if (isset($params['is_faker']) && $params['is_faker'] !== null) {
  51. $query = $query->where('is_faker', $params['is_faker']);
  52. }
  53. if (!empty($params['game'])) {
  54. $query = $query->where('game', $params['game']);
  55. }
  56. if (!empty($params['gameplay'])) {
  57. $query = $query->where('gameplay', $params['gameplay']);
  58. }
  59. if (!empty($params['number'])) {
  60. $query = $query->where('number', $params['number']);
  61. }
  62. if (!empty($params['type'])) {
  63. $query = $query->where('type', $params['type']);
  64. }
  65. $count = $query->count();
  66. $list = $query->with(['lottery'])
  67. ->forPage($page, $limit)
  68. ->orderByDesc('created_at')
  69. ->get();
  70. } catch (Exception $e) {
  71. return $this->error(HttpStatus::CUSTOM_ERROR,$e->getMessage());
  72. }
  73. return $this->success(['total' => $count, 'data' => $list]);
  74. }
  75. //订单详情
  76. function info()
  77. {
  78. try {
  79. request()->validate([
  80. 'id' => ['required', 'integer'],
  81. ]);
  82. $id = request()->input('id');
  83. $order = LhcOrderModel::where('id', $id)->first();
  84. if (!$order) throw new Exception('订单不存在');
  85. $order = $order->toArray();
  86. } catch (Exception $e) {
  87. return $this->error(HttpStatus::CUSTOM_ERROR,$e->getMessage());
  88. }
  89. return $this->success($order);
  90. }
  91. /**
  92. * @api {post} /lhcorder/refund 同意退款
  93. * @apiGroup 订单管理
  94. */
  95. public function refund()
  96. {
  97. $errors = [];
  98. try {
  99. DB::beginTransaction();
  100. $params = request()->validate([
  101. 'id' => ['required', 'array', 'min:1'],
  102. ]);
  103. $orderList = LhcOrderModel::whereIn('id', $params['id'])->get();
  104. foreach ($orderList as $order) {
  105. if ($order->lottery_status != 0) {
  106. continue;
  107. }
  108. $order->lottery_status = 4;
  109. $order->updated_at = time();
  110. $order->save();
  111. // 获取用户余额
  112. $walletInfo = Wallet::where(['member_id' => $order->member_id])->first();
  113. if (!$walletInfo) continue;
  114. $before = $walletInfo->available_balance;
  115. $after = bcsub($walletInfo->available_balance, $order->amount, 2);
  116. $walletInfo->available_balance = $after;
  117. $walletInfo->save();
  118. $remark = $order->type == 1 ? '澳门六合彩' : '香港六合彩';
  119. FundsRecord::addData([
  120. 'change_type' => $remark.'退款',
  121. 'amount' => $order->amount,
  122. 'before_balance' => $before,
  123. 'after_balance' => $after,
  124. 'member_id' => $order->user_id,
  125. 'related_id' => $order->id,
  126. 'remark' => $remark.'订单退款',
  127. ]);
  128. }
  129. DB::commit();
  130. } catch (Exception $e) {
  131. DB::rollBack();
  132. return $this->error(HttpStatus::CUSTOM_ERROR,$e->getMessage(), $errors);
  133. }
  134. return $this->success();
  135. }
  136. }