海南旅游SAAS
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

117 lines
3.6 KiB

4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
  1. <?php
  2. namespace App\AdminAgent\Controllers;
  3. use App\AdminAgent\Repositories\WithdrawalAlipay;
  4. use App\Common\StatementType;
  5. use App\Models\Agent;
  6. use App\Models\SystemSetting;
  7. use App\Models\Withdrawal;
  8. use App\Service\WithdrawalService;
  9. use App\Traits\DemandTraits;
  10. use App\Traits\StatementTraits;
  11. use App\Traits\WithdrawalTraits;
  12. use Dcat\Admin\Admin;
  13. use Dcat\Admin\Form;
  14. use Dcat\Admin\Grid;
  15. use Dcat\Admin\Repositories\EloquentRepository;
  16. use Dcat\Admin\Show;
  17. use Dcat\Admin\Http\Controllers\AdminController;
  18. use Illuminate\Database\Eloquent\Model;
  19. use Illuminate\Support\Facades\DB;
  20. class WithdrawalAlipayController extends AdminController
  21. {
  22. /**
  23. * Make a form builder.
  24. *
  25. * @return Form
  26. */
  27. protected function form()
  28. {
  29. return Form::make(new WithdrawalAlipay(), function (Form $form) {
  30. $auto = Withdrawal::query()
  31. ->with('pay')
  32. ->where([
  33. 'user_id' => Admin::user()->id,
  34. 'user_type' => DemandTraits::$col[0],
  35. 'status' => WithdrawalTraits::$state[3],
  36. 'pay_type' => WithdrawalTraits::$userType[0],
  37. ])
  38. ->orderByDesc('updated_at')
  39. ->first();
  40. $form->display('id');
  41. $min = SystemSetting::val('withdrawal', WithdrawalTraits::$adminType[3]) ?? 0;
  42. $form->decimal('price','提现金额')->rules('required|numeric|min:'.$min.'|not_in:0',[
  43. '*' => '提现金额为必填字段且必须大于'.$min,
  44. ])
  45. ->default($auto->price ?? 0)
  46. ->help('含手续费' . SystemSetting::val('withdrawal', WithdrawalTraits::$adminType[0]) . ' %,最小提现金额'.$min);
  47. $form->text('account')->required()->maxLength(50)->default($auto->pay->account ?? '');
  48. $form->text('name')->required()->maxLength(50)->default($auto->pay->name ?? '');
  49. $form->image('qrcode');
  50. $form->hidden('withdrawal_id');
  51. $form->saving(function (Form $form) {
  52. DB::beginTransaction();
  53. try {
  54. $user = Agent::query()->where('id', Admin::user()->id)->lockForUpdate()->first();
  55. //手续费
  56. $cutPrice = bcmul($form->price, SystemSetting::val('withdrawal', WithdrawalTraits::$adminType[0]), 6);
  57. $cutPrice = $cutPrice > 0 ? bcdiv($cutPrice, 100, 6) : 0;
  58. //总花费
  59. $total = bcadd($form->price, $cutPrice,6);
  60. if ($total > $user->balance) {
  61. return $form->response()->error('余额不足,本次提现需花费'.bcadd($total,0,2).'(含手续费),当前可用余额为' . $user->balance);
  62. }
  63. $user->balance = bcsub($user->balance, $total, 6);
  64. $user->save();
  65. $withdrawal = new Withdrawal();
  66. $withdrawal->user_id = Admin::user()->id;
  67. $withdrawal->user_type = DemandTraits::$col[0];
  68. $withdrawal->price = request('price', 0);
  69. $withdrawal->cut_price = $cutPrice;
  70. //$withdrawal->pay_id = $form->getKey();
  71. $withdrawal->pay_type = WithdrawalTraits::$userType[0];
  72. $withdrawal->save();
  73. //提现扣钱流水
  74. $service = new WithdrawalService();
  75. $service->create(
  76. bcmul($form->price, -1, 6),
  77. StatementType::WITHDRAWAL,
  78. Admin::user()->id,
  79. DemandTraits::$col[0],
  80. $withdrawal->id,
  81. StatementTraits::$type[1]
  82. );
  83. //提现手续费流水
  84. $service->create(
  85. bcmul($cutPrice, -1, 6),
  86. StatementType::WITHDRAWAL_CAT,
  87. Admin::user()->id,
  88. DemandTraits::$col[0],
  89. $withdrawal->id,
  90. StatementTraits::$type[1]
  91. );
  92. $form->withdrawal_id = $withdrawal->id;
  93. $form->deleteInput('price');
  94. DB::commit();
  95. } catch (\Exception $e) {
  96. DB::rollBack();
  97. return $form->response()->error($e->getMessage());
  98. }
  99. });
  100. $form->saved(function (Form $form) {
  101. $withdrawal = Withdrawal::find($form->withdrawal_id);
  102. $withdrawal->pay_id = $form->getKey();
  103. $withdrawal->save();
  104. });
  105. });
  106. }
  107. }