IntegralJob.php 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228
  1. <?php
  2. namespace app\jobs\integral;
  3. use app\services\user\level\UserLevelServices;
  4. use app\services\user\UserAwardIntegralServices;
  5. use app\services\user\UserBillServices;
  6. use app\services\user\UserBrokerageServices;
  7. use app\services\user\UserServices;
  8. use crmeb\basic\BaseJobs;
  9. use crmeb\traits\QueueTrait;
  10. use think\facade\Log;
  11. /**
  12. * 订单消息队列
  13. * Class OrderJob
  14. * @package app\jobs
  15. */
  16. class IntegralJob extends BaseJobs
  17. {
  18. use QueueTrait;
  19. public function dealOrderIntegral($order)
  20. {
  21. /** @var UserAwardIntegralServices $awardIntegralService */
  22. $awardIntegralService = app()->make(UserAwardIntegralServices::class);
  23. /** @var UserServices $userService */
  24. $userService = app()->make(UserServices::class);
  25. /** @var UserLevelServices $levelServices */
  26. $levelServices = app()->make(UserLevelServices::class);
  27. $user = $userService->getUserInfo($order['uid']);
  28. $integral_price = $awardIntegralService->getPrice($order['id']);
  29. $total_price = $order['total_price'];
  30. $award_price = bcsub($total_price, $order['cost'], 2);
  31. return $awardIntegralService->transaction(function () use ($award_price, $levelServices, $awardIntegralService, $userService, $user, $integral_price, $total_price, $order) {
  32. try {
  33. //添加静态积分
  34. $static_integral_ratio = sys_config('static_integral_ratio', 0);
  35. $give_static_integral = bcdiv(bcmul($award_price, $static_integral_ratio), 100, 2);
  36. // if ($give_static_integral > 0) {
  37. $rate = sys_config('static_integral_rate', 3);
  38. $extract_sum = bcmul($award_price, $rate, 2);
  39. $mark = '购买商品,获得静态积分';
  40. $awardIntegralService->incIntegral($order['uid'], $integral_price, $give_static_integral, $total_price, 0, $extract_sum, $order['id'], $mark);
  41. // }
  42. //添加奖池
  43. $lake_ratio = sys_config('lake_ratio', 0);
  44. $add_lake = bcdiv(bcmul($award_price, $lake_ratio), 100, 2);
  45. if ($add_lake > 0) {
  46. $mark = '用户' . $order['uid'] . '购买商品,添加资金池';
  47. $awardIntegralService->addLake($add_lake, $order['id'], $mark);
  48. }
  49. //TODO 加动态积分
  50. //推荐奖
  51. $rate = sys_config('action_integral_rate', 3);
  52. $spread = $userService->getUserInfo($user['spread_uid']);
  53. if ($spread) {
  54. if ($awardIntegralService->getPaySum($spread['uid']) >= 1000 || $awardIntegralService->getHourExtractPaySum($spread['uid'], 24) >= 1000) {
  55. $award_ratio = sys_config('recommend_integral', 0);
  56. $give_action_integral = bcdiv(bcmul($award_price, $award_ratio), 100, 2);
  57. if ($give_action_integral > 0) {
  58. $extract_sum = bcmul($give_action_integral, $rate, 2);
  59. $mark = '推荐用户' . $user['nickname'] . "({$user['uid']})" . '购买商品,获得推荐积分';
  60. $awardIntegralService->incIntegral($spread['uid'], $integral_price, $give_action_integral, $total_price, 1, $extract_sum, $order['id'], $mark);
  61. }
  62. }
  63. }
  64. $levelServices->detection((int)$user['uid']);
  65. $pass = [$user['uid']];
  66. $send = 0;
  67. while ($spread && !in_array($spread['uid'], $pass)) {
  68. //先发奖,再结算等级
  69. $level = $levelServices->getUserLevel($spread['uid']);
  70. $ratio = $level['levelInfo']['group_award'] ?? 0;
  71. $give_action_integral = bcdiv(bcmul($award_price, $ratio), 100, 2);
  72. if ($give_action_integral > $send) {
  73. $real_send = bcsub($give_action_integral, $send, 2);
  74. if ($real_send < 0) $real_send = 0;
  75. $extract_sum = bcmul($real_send, $rate, 2);
  76. $mark = '团队用户' . $user['nickname'] . "({$user['uid']})" . '购买商品,获得团队级差积分';
  77. $awardIntegralService->incIntegral($spread['uid'], $integral_price, $real_send, $total_price, 1, $extract_sum, $order['id'], $mark);
  78. if ($real_send > 0) $send = $give_action_integral;
  79. }
  80. $levelServices->detection((int)$spread['uid']);
  81. $pass[] = $spread['uid'];
  82. $spread = $userService->getUserInfo($spread['spread_uid']);
  83. }
  84. $this->autoExtract($awardIntegralService->getPrice());
  85. return true;
  86. } catch (\Throwable $e) {
  87. Log::error('处理积分奖池失败,失败原因:' . $e->getMessage());
  88. return false;
  89. }
  90. });
  91. }
  92. public function extract($id)
  93. {
  94. /** @var UserAwardIntegralServices $awardIntegralService */
  95. $awardIntegralService = app()->make(UserAwardIntegralServices::class);
  96. /** @var UserBrokerageServices $brokerageService */
  97. $brokerageService = app()->make(UserBrokerageServices::class);
  98. /** @var UserBillServices $billService */
  99. $billService = app()->make(UserBillServices::class);
  100. /** @var UserServices $userService */
  101. $userService = app()->make(UserServices::class);
  102. $info = $awardIntegralService->getIntegral($id);
  103. return $awardIntegralService->transaction(function () use ($info, $awardIntegralService, $brokerageService, $billService, $userService) {
  104. if ($info['status'] != 0) {
  105. $awardIntegralService->update($info['id'], ['handle' => 0]);
  106. return true;
  107. }
  108. $price = $awardIntegralService->getPrice();
  109. $sum = bcmul($price, $info['num'], 2);
  110. if ($sum > $info['extract_sum']) {
  111. $sum = $info['extract_sum'];
  112. }
  113. $res = true;
  114. $real_out = bcdiv(bcmul($sum, sys_config('extract_ratio', 0)), 100, 2);
  115. if ($real_out > 0) {
  116. $user = $userService->getUserInfo($info['uid']);
  117. $mark = '用户积分出局,出局时价格' . $price;
  118. $res = $res && $awardIntegralService->addLake(-$real_out, $info['id'], $mark);
  119. $to_brokerage = bcdiv(bcmul($real_out, sys_config('extract_brokerage_ratio', 0)), 100, 2);
  120. $balance = bcadd($user['brokerage_price'], $to_brokerage, 2);
  121. $res = $res && $brokerageService->income('extract_integral', $info['uid'], [
  122. 'type' => $info['type'] ? '动态积分' : '静态积分',
  123. 'price' => round($price, 2),
  124. 'integral_num' => $info['num'],
  125. 'number' => floatval($to_brokerage),
  126. 'frozen_time' => 0
  127. ], $balance, $info['id']);
  128. // 添加用户佣金
  129. $res = $res && $userService->bcInc($info['uid'], 'brokerage_price', $to_brokerage, 'uid');
  130. $to_energy = bcsub($real_out, $to_brokerage, 2);
  131. $balance = bcadd($user['energy'], $to_energy, 2);
  132. $res = $res && $billService->income('extract_integral', $info['uid'], [
  133. 'type' => $info['type'] ? '动态积分' : '静态积分',
  134. 'price' => round($price, 2),
  135. 'integral_num' => $info['num'],
  136. 'number' => floatval($to_energy),
  137. ], $balance, $info['id']);
  138. // 添加用户佣金
  139. $res = $res && $userService->bcInc($info['uid'], 'energy', $to_energy, 'uid');
  140. $res = $res && $awardIntegralService->update($info['id'], ['handle' => 0, 'extract_sum_real' => $sum, 'status' => 1, 'extract_time' => time()]);
  141. }
  142. return $res && $this->autoExtract($awardIntegralService->getPrice());
  143. });
  144. }
  145. public function autoExtract($price)
  146. {
  147. /** @var UserAwardIntegralServices $awardIntegralService */
  148. $awardIntegralService = app()->make(UserAwardIntegralServices::class);
  149. /** @var UserBrokerageServices $brokerageService */
  150. $brokerageService = app()->make(UserBrokerageServices::class);
  151. /** @var UserBillServices $billService */
  152. $billService = app()->make(UserBillServices::class);
  153. /** @var UserServices $userService */
  154. $userService = app()->make(UserServices::class);
  155. $infos = $awardIntegralService->getIntegralsOverExtract($price);
  156. $res = true;
  157. foreach ($infos as $info) {
  158. if ($info['status'] != 0) {
  159. $awardIntegralService->update($info['id'], ['handle' => 0]);
  160. continue;
  161. }
  162. $sum = bcmul($price, $info['num'], 2);
  163. if ($sum > $info['extract_sum']) {
  164. $sum = $info['extract_sum'];
  165. }
  166. $real_out = bcdiv(bcmul($sum, sys_config('extract_ratio', 0)), 100, 2);
  167. if ($real_out > 0) {
  168. $user = $userService->getUserInfo($info['uid']);
  169. $mark = '用户积分出局,出局时价格' . $price;
  170. $res = $res && $awardIntegralService->addLake(-$real_out, $info['id'], $mark);
  171. $to_brokerage = bcdiv(bcmul($real_out, sys_config('extract_brokerage_ratio', 0)), 100, 2);
  172. $balance = bcadd($user['brokerage_price'], $to_brokerage, 2);
  173. $res = $res && $brokerageService->income('extract_integral', $info['uid'], [
  174. 'type' => $info['type'] ? '动态积分' : '静态积分',
  175. 'price' => round($price, 2),
  176. 'integral_num' => $info['num'],
  177. 'number' => floatval($to_brokerage),
  178. 'frozen_time' => 0
  179. ], $balance, $info['id']);
  180. // 添加用户佣金
  181. $res = $res && $userService->bcInc($info['uid'], 'brokerage_price', $to_brokerage, 'uid');
  182. $to_energy = bcsub($real_out, $to_brokerage, 2);
  183. $balance = bcadd($user['energy'], $to_energy, 2);
  184. $res = $res && $billService->income('extract_integral', $info['uid'], [
  185. 'type' => $info['type'] ? '动态积分' : '静态积分',
  186. 'price' => round($price, 2),
  187. 'integral_num' => $info['num'],
  188. 'number' => floatval($to_energy),
  189. ], $balance, $info['id']);
  190. // 添加用户佣金
  191. $res = $res && $userService->bcInc($info['uid'], 'energy', $to_energy, 'uid');
  192. $res = $res && $awardIntegralService->update($info['id'], ['handle' => 0, 'extract_sum_real' => $sum, 'status' => 1, 'extract_time' => time()]);
  193. }
  194. }
  195. if (count($infos) > 0) return $res && $this->autoExtract($awardIntegralService->getPrice());
  196. return $res;
  197. }
  198. /**
  199. * 减积分
  200. * @param int $uid 用户
  201. * @param float $static 静态积分
  202. * @param float $action 动态积分
  203. * @param float $cash 资金池
  204. * @param int $link_id 关联ID
  205. * @param string $mark 备注
  206. */
  207. public function decIntegral(int $uid, float $static, float $action, float $cash, int $link_id = 0, string $mark = '')
  208. {
  209. }
  210. }