StoreGp.php 7.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150
  1. <?php
  2. namespace app\models\store;
  3. use app\models\user\User;
  4. use app\models\user\UserBill;
  5. use crmeb\basic\BaseModel;
  6. use crmeb\traits\ModelTrait;
  7. use think\Exception;
  8. class StoreGp extends BaseModel
  9. {
  10. use ModelTrait;
  11. /**
  12. * 创建公排
  13. * @param $order
  14. */
  15. public static function createGp($data)
  16. {
  17. $order = $data['data'];
  18. @file_put_contents("job.txt",json_encode($order));
  19. try {
  20. $no = intval(self::value('max(no)') ?: 0) + 1;
  21. $rs = self::getpath($no);
  22. list($p_no, $no_path,$gp_id,$send,$gpinfo) = [$rs['p_no'],$rs['no_path'],$rs['gp_id'],$rs['send'],$rs['info']];
  23. @file_put_contents("job.txt","\r\n".json_encode($rs),8);
  24. $order_id = $order['id'];
  25. $add_time = time();
  26. $price = $order['total_price'];
  27. $uid = $order['uid'];
  28. $status = 0;
  29. self::create(compact('no', 'uid', 'order_id', 'add_time', 'price', 'p_no', 'no_path','status'));
  30. if($no>1) {
  31. self::where('no', $p_no)->inc('cts', 1)->update();
  32. self::where('no', $gp_id)->inc('team_cts', 1)->update();
  33. }
  34. $user = User::where('uid',$order['uid'])->find();
  35. $spuser = User::where('uid',$user['spread_uid'])->find();
  36. User::where('uid',$order['uid'])->update(['cycle_time'=>strtotime("+31 day")]);
  37. User::where('uid',$spuser['uid'])->update(['cycle_time'=>strtotime("+31 day")]);
  38. if($send==1)
  39. {
  40. $p_user = User::find($gpinfo['uid']);
  41. $sp_brokeragePrice1 = 3000;
  42. $gp_balance = bcadd($p_user['gp_now_money'], $sp_brokeragePrice1, 2);
  43. $mark = "公排号:" . $no . "满3个加报单余额3000元,订单号:" . $order['order_id'];
  44. $res = UserBill::income('满3个报单余额', $p_user['uid'], 'now_money', 'brokerage', $sp_brokeragePrice1, $order['id'], $gp_balance, $mark, 1);
  45. User::where('uid', $p_user['uid'])->inc('gp_now_money', $sp_brokeragePrice1)->update();
  46. self::where('no', $p_no)->update(['send'=>1]);
  47. }
  48. $p_no_cts = self::where('no', $gp_id)->value('team_cts');
  49. if ($p_no_cts>0 && $p_no_cts % 3 == 0) {
  50. $info = self::where('no', $gp_id)->find();
  51. $sp_userInfo = User::find($info['uid']);
  52. if($sp_userInfo['cycle_time']>time()) {
  53. switch ($p_no_cts) {
  54. case 3:
  55. $sp_brokeragePrice = $order['out_amount'] - 3000;
  56. $balance = bcadd($sp_userInfo['brokerage_price'], $sp_brokeragePrice, 2);
  57. $mark = "公排号:" . $no . "满3个拥金3000元,订单号:" . $order['order_id'];
  58. $res = UserBill::income('满3个拥金', $sp_userInfo['uid'], 'now_money', 'brokerage', $sp_brokeragePrice, $order['id'], $balance, $mark, 1);
  59. User::where('uid', $sp_userInfo['uid'])->inc('brokerage_price', $sp_brokeragePrice)->update();
  60. break;
  61. case 6:
  62. case 9:
  63. $sp_brokeragePrice = $order['out_amount'];
  64. $balance = bcadd($sp_userInfo['brokerage_price'], $sp_brokeragePrice, 2);
  65. $mark = "公排号:" . $no . '满' . $p_no_cts . '个拥金' . $order['out_amount'] . "元,订单号:" . $order['order_id'];
  66. $res = UserBill::income('满' . $p_no_cts . '个拥金', $sp_userInfo['uid'], 'now_money', 'brokerage', $sp_brokeragePrice, $order['id'], $balance, $mark, 1);
  67. User::where('uid', $sp_userInfo['uid'])->inc('brokerage_price', $sp_brokeragePrice)->update();
  68. break;
  69. case 12:
  70. $sp_brokeragePrice = $order['out_amount'] - 1000;
  71. $balance = bcadd($sp_userInfo['brokerage_price'], $sp_brokeragePrice, 2);
  72. $mark = "公排号:" . $no . '满' . $p_no_cts . '个拥金' . $order['out_amount'] . "元,订单号:" . $order['order_id'];
  73. $res = UserBill::income('满' . $p_no_cts . '个拥金', $sp_userInfo['uid'], 'now_money', 'brokerage', $sp_brokeragePrice, $order['id'], $balance, $mark, 1);
  74. User::where('uid', $sp_userInfo['uid'])->inc('brokerage_price', $sp_brokeragePrice)->update();
  75. self::where('no', $gp_id)->update(['status' => 1]);
  76. break;
  77. }
  78. }
  79. }
  80. $no_path = explode(",",$no_path);
  81. if (sizeof($no_path) > 3) {
  82. $path = array_reverse($no_path);
  83. $n = 0;
  84. foreach ($path as $v) {
  85. $n++;
  86. if ($n <=3) continue;
  87. if($n>10) break;
  88. $sp_brokeragePrice = $order['team'];
  89. $user = user::find(self::where('no', $v)->value('uid'));
  90. $spuser = user::find($user['spread_uid']);
  91. if($user['cycle_time']>time()) {
  92. $balance = bcadd($user['brokerage_price'], $sp_brokeragePrice, 2);
  93. $mark = "公排号:" . $no . '团队奖' . floatval($sp_brokeragePrice) . "元,订单号:" . $order['order_id'];
  94. $res1 = UserBill::income('团队奖', $user['uid'], 'now_money', 'brokerage', $sp_brokeragePrice, $order['id'], $balance, $mark, 1);
  95. User::where('uid', $user['uid'])->inc('brokerage_price', $sp_brokeragePrice)->update();
  96. }
  97. if($spuser && $user['spread_uid']>0 && $spuser['cycle_time']>time())
  98. {
  99. $sp_brokeragePrice = $order['recommend'];
  100. $balance = bcadd($spuser['brokerage_price'], $sp_brokeragePrice, 2);
  101. $mark = "公排号:" . $no . '推荐奖' . $order['recommend'] . "元,订单号:" . $order['order_id'];
  102. $res = UserBill::income('推荐奖', $spuser['uid'], 'now_money', 'brokerage', $sp_brokeragePrice, $order['id'], $balance, $mark, 1);
  103. User::where('uid', $spuser['uid'])->inc('brokerage_price', $sp_brokeragePrice)->update();
  104. }
  105. }
  106. }
  107. return true;
  108. }catch (Exception $e)
  109. {
  110. echo $e->getFile().'--'.$e->getLine().'--'.$e->getMessage();
  111. return false;
  112. }
  113. }
  114. /**
  115. * 获取上级及路径
  116. * @param $no
  117. * @return array
  118. * @throws \think\db\exception\DataNotFoundException
  119. * @throws \think\db\exception\DbException
  120. * @throws \think\db\exception\ModelNotFoundException
  121. */
  122. private static function getpath($no)
  123. {
  124. $no_path = [];$p_no=0;$send = 0;$info = null;
  125. if($no==1) {
  126. $no_path[] =1;
  127. $gp_id = 1;
  128. }
  129. else
  130. {
  131. $gp_id = self::where('team_cts','<',12)->value('no');
  132. $min = self::where('cts','<',3)->order("id asc")->find();
  133. $p_no = $min['no'];
  134. $no_path = explode(",",$min['no_path']);
  135. $no_path[] = $no;
  136. if($min['cts']==2)
  137. {
  138. $send = 1;
  139. }
  140. $info = $min;
  141. }
  142. $no_path = join(",",$no_path);
  143. return compact('p_no','no_path','gp_id','send','info');
  144. }
  145. }