CheckCommission.php 3.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114
  1. <?php
  2. namespace App\Console\Commands;
  3. use Illuminate\Console\Command;
  4. use App\Models\Order;
  5. use App\Models\User;
  6. use Illuminate\Support\Facades\DB;
  7. class CheckCommission extends Command
  8. {
  9. /**
  10. * The name and signature of the console command.
  11. *
  12. * @var string
  13. */
  14. protected $signature = 'check:commission';
  15. /**
  16. * The console command description.
  17. *
  18. * @var string
  19. */
  20. protected $description = '返佣服务';
  21. /**
  22. * Create a new command instance.
  23. *
  24. * @return void
  25. */
  26. public function __construct()
  27. {
  28. parent::__construct();
  29. }
  30. /**
  31. * Execute the console command.
  32. *
  33. * @return mixed
  34. */
  35. public function handle()
  36. {
  37. $this->autoCheck();
  38. $this->autoPayCommission();
  39. }
  40. public function autoCheck()
  41. {
  42. if ((int)config('v2board.commission_auto_check_enable', 1)) {
  43. Order::where('commission_status', 0)
  44. ->where('invite_user_id', '!=', NULL)
  45. ->whereNotIn('status', [0, 2])
  46. ->where('updated_at', '<=', strtotime('-3 day', time()))
  47. ->update([
  48. 'commission_status' => 1
  49. ]);
  50. }
  51. }
  52. public function autoPayCommission()
  53. {
  54. $orders = Order::where('commission_status', 1)
  55. ->where('invite_user_id', '!=', NULL)
  56. ->get();
  57. foreach ($orders as $order) {
  58. DB::beginTransaction();
  59. if (!$this->payHandle($order->invite_user_id, $order)) {
  60. DB::rollBack();
  61. continue;
  62. }
  63. $order->commission_status = 2;
  64. if (!$order->save()) {
  65. DB::rollBack();
  66. continue;
  67. }
  68. DB::commit();
  69. }
  70. }
  71. public function payHandle($inviteUserId, Order $order)
  72. {
  73. if ((int)config('v2board.commission_distribution_enable', 0)) {
  74. $level = 3;
  75. $commissionShareLevels = [
  76. 0 => (int)config('v2board.commission_distribution_l1'),
  77. 1 => (int)config('v2board.commission_distribution_l2'),
  78. 2 => (int)config('v2board.commission_distribution_l3')
  79. ];
  80. } else {
  81. $level = 3;
  82. $commissionShareLevels = [
  83. 0 => 100
  84. ];
  85. }
  86. for ($l = 0; $l < $level; $l++) {
  87. $inviter = User::find($inviteUserId);
  88. if (!$inviter) continue;
  89. if (!$commissionShareLevels[$l]) continue;
  90. $commissionBalance = $order->commission_balance * $commissionShareLevels[$l];
  91. if ((int)config('v2board.withdraw_close_enable', 0)) {
  92. $inviter->balance = $inviter->balance + $commissionBalance;
  93. } else {
  94. $inviter->commission_balance = $inviter->commission_balance + $commissionBalance;
  95. }
  96. if (!$inviter->save()) {
  97. DB::rollBack();
  98. return false;
  99. }
  100. $inviteUserId = $inviter->invite_user_id;
  101. }
  102. return true;
  103. }
  104. }