Order.php 8.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241
  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\Admin;
  7. use App\Models\Order as OrderModel;
  8. use Exception;
  9. use Illuminate\Support\Facades\DB;
  10. use App\Constants\HttpStatus;
  11. class Order extends Controller
  12. {
  13. /**
  14. * 订单手动退款
  15. */
  16. public function adminRefund()
  17. {
  18. DB::beginTransaction();
  19. try {
  20. $params = request()->validate([
  21. 'order_id' => ['required', 'array', 'min:1'],
  22. 'safe_word' => ['required', 'string'],
  23. ]);
  24. $id = request()->user->id;
  25. $admin = Admin::where('id', $id)->first();
  26. if (!password_verify($params['safe_word'], $admin->payment_password)) throw new Exception('资金密码错误');
  27. $orderList = OrderModel::whereIn('id', $params['order_id'])->get();
  28. foreach ($orderList as $order) {
  29. if ($order->return_status != 0 || $order->pay_status != 1) {
  30. continue;
  31. }
  32. $order->status = 3;
  33. $order->return_status = 2;
  34. $order->return_operation_time = time();
  35. $order->save();
  36. $user = User::where('user_id', $order->user_id)->first();
  37. if (!$user) continue;
  38. if ($user->type == 1) {
  39. FundsRecord::addData([
  40. 'transaction_type' => '退款',
  41. 'amount' => $order->amount,
  42. 'before_balance' => $user->money,
  43. 'after_balance' => bcsub($user->money, $order->amount, 2),
  44. 'member_id' => $user->user_id,
  45. ]);
  46. $user->money = bcsub($user->money, $order->amount, 2);
  47. $user->save();
  48. }
  49. }
  50. DB::commit();
  51. } catch (Exception $e) {
  52. DB::rollBack();
  53. return $this->error(HttpStatus::CUSTOM_ERROR, $e->getMessage());
  54. }
  55. return $this->success();
  56. }
  57. /**
  58. * @api {post} /order/refund 同意退款
  59. * @apiGroup 订单管理
  60. */
  61. public function refund()
  62. {
  63. $errors = [];
  64. try {
  65. DB::beginTransaction();
  66. $params = request()->validate([
  67. 'order_id' => ['required', 'array', 'min:1'],
  68. 'safe_word' => ['required', 'string'],
  69. ]);
  70. $order_id = $params['order_id'];
  71. $safeWord = $params['safe_word'];
  72. $id = request()->user()->id;
  73. $admin = Admin::where('id', $id)->first();
  74. if (!password_verify($safeWord, $admin->payment_password)) throw new Exception('资金密码错误');
  75. $order = OrderModel::where('id', $order_id)->first();
  76. if (!$order) throw new Exception('订单不存在');
  77. if ($order->return_status != 1 || $order->pay_status != 1) {
  78. $errors = ['id' => $order_id];
  79. throw new Exception("该订单状态无法操作");
  80. }
  81. $order->status = 3;
  82. $order->return_status = 2;
  83. $order->return_operation_time = time();
  84. $order->save();
  85. $user = User::where('user_id', $order->user_id)->first();
  86. $balanceAfter = bcadd($user->money, $order->amount, 2);
  87. FundsRecord::addData([
  88. 'transaction_type' => '退款',
  89. 'amount' => $order->amount,
  90. 'before_balance' => $user->money,
  91. 'after_balance' => bcsub($user->money, $order->amount, 2),
  92. 'member_id' => $user->user_id,
  93. ]);
  94. $user->money = $balanceAfter;
  95. $user->save();
  96. DB::commit();
  97. } catch (Exception $e) {
  98. DB::rollBack();
  99. return $this->error(HttpStatus::CUSTOM_ERROR,$e->getMessage(), $errors);
  100. }
  101. return $this->success();
  102. }
  103. /**
  104. * 驳回退款申请
  105. * @apiGroup 订单管理
  106. */
  107. public function rejection()
  108. {
  109. $errors = [];
  110. DB::beginTransaction();
  111. try {
  112. $params = request()->validate([
  113. 'order_id' => ['required', 'array', 'min:1'],
  114. 'failure_msg' => ['nullable', 'string', 'max:200'],
  115. ]);
  116. if (empty($params['failure_msg'])) $params['failure_msg'] = '';
  117. $order = OrderModel::where('id', $params['order_id'])->first();
  118. if (!$order) throw new Exception('订单不存在');
  119. if ($order->status != 1 || $order->return_status != 1) {
  120. $errors = ['id' => $params['order_id']];
  121. throw new Exception("该订单状态无法操作");
  122. }
  123. $order->return_operation_time = time();
  124. $order->failure_msg = $params['failure_msg'];
  125. $order->save();
  126. DB::commit();
  127. } catch (Exception $e) {
  128. DB::rollBack();
  129. return $this->error(HttpStatus::CUSTOM_ERROR,$e->getMessage(), $errors);
  130. }
  131. return $this->success();
  132. }
  133. /**
  134. * 订单列表
  135. */
  136. public function list()
  137. {
  138. try {
  139. $params = request()->validate([
  140. 'page' => ['nullable', 'integer', 'min:1'],
  141. 'limit' => ['nullable', 'integer', 'min:1'],
  142. 'id' => ['nullable', 'string'],
  143. 'user_id' => ['nullable', 'string'],
  144. 'order_id' => ['nullable', 'string'],
  145. 'pay_status' => ['nullable', 'integer', 'in:0,1'],
  146. 'is_win' => ['nullable', 'integer', 'in:0,1'],
  147. 'is_roll' => ['nullable', 'integer', 'in:0,1'],
  148. 'settlement_status' => ['nullable', 'integer', 'in:0,1,2,3'],
  149. 'return_status' => ['nullable', 'integer', 'in:0,1,2,3'],
  150. 'status' => ['nullable', 'integer', 'in:0,1,2,-1'],
  151. 'start_time' => ['nullable', 'date', 'date_format:Y-m-d', 'required_with:end_time'],
  152. 'end_time' => ['nullable', 'date', 'date_format:Y-m-d', 'required_with:start_time'],
  153. ]);
  154. $page = request()->input('page', 1);
  155. $limit = request()->input('limit', 15);
  156. $query = new OrderModel();
  157. if (!empty($params['start_time'])) {
  158. $startTime = strtotime($params['start_time'] . " 00:00:00");
  159. $query = $query->where('create_time', '>=', $startTime);
  160. }
  161. if (!empty($params['end_time'])) {
  162. $endTime = strtotime($params['end_time'] . " 23:59:59");
  163. $query = $query->where('create_time', '<=', $endTime);
  164. }
  165. if (!empty($params['id'])) {
  166. $query = $query->where('id', $params['id']);
  167. }
  168. if (!empty($params['order_id'])) {
  169. $query = $query->where('order_id', $params['order_id']);
  170. }
  171. if (!empty($params['user_id'])) {
  172. $query = $query->where('user_id', $params['user_id']);
  173. }
  174. if (isset($params['status'])) {
  175. $query = $query->where('status', $params['status']);
  176. }
  177. if (isset($params['return_status'])) {
  178. $query = $query->where('return_status', $params['return_status']);
  179. }
  180. if (isset($params['pay_status'])) {
  181. $query = $query->where('pay_status', $params['pay_status']);
  182. }
  183. if (isset($params['is_win'])) {
  184. $query = $query->where('is_win', $params['is_win']);
  185. }
  186. if (isset($params['settlement_status'])) {
  187. $query = $query->where('settlement_status', $params['settlement_status']);
  188. }
  189. if (isset($params['is_roll'])) {
  190. $query = $query->where('is_roll', $params['is_roll']);
  191. }
  192. $count = $query->count();
  193. $list = $query
  194. ->forPage($page, $limit)
  195. ->orderByDesc('create_time')
  196. ->get();
  197. } catch (Exception $e) {
  198. return $this->error(HttpStatus::CUSTOM_ERROR,$e->getMessage());
  199. }
  200. return $this->success(['total' => $count, 'data' => $list]);
  201. }
  202. //订单详情
  203. function info()
  204. {
  205. try {
  206. request()->validate([
  207. 'order_id' => ['required', 'string'],
  208. ]);
  209. $order_id = request()->input('order_id');
  210. $order = OrderModel::where('order_id', $order_id)->first();
  211. if (!$order) throw new Exception('订单不存在');
  212. $order = $order->toArray();
  213. $order['detail'] = json_decode($order['detail'],true);
  214. $order['game_result'] = $order['game_result'] ? json_decode($order['game_result'],true) : null;
  215. ksort($order);
  216. } catch (Exception $e) {
  217. return $this->error(HttpStatus::CUSTOM_ERROR,$e->getMessage());
  218. }
  219. return $this->success($order);
  220. }
  221. }