YearOrderService.php 3.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798
  1. <?php
  2. namespace App\Modules\Subscribe\Services;
  3. use App\Modules\Statistic\Services\DataAnalysisSelectUserService;
  4. use App\Modules\Subscribe\Models\YearOrder;
  5. use Redis;
  6. class YearOrderService
  7. {
  8. /**
  9. * 获取订购记录
  10. * @param $uid
  11. * @return mixed
  12. */
  13. public static function getRecord($uid)
  14. {
  15. $now = date('Y-m-d H:i:s');
  16. $where = [
  17. ['uid', '=', $uid],
  18. ['begin_time', '<=', $now],
  19. ['end_time', '>=', $now],
  20. ];
  21. return YearOrder::where($where)->select('id', 'uid', 'u', 'begin_time', 'end_time')->first();
  22. }
  23. static function save_year_order($data)
  24. {
  25. $insert_data = array();
  26. $insert_data['uid'] = $data['uid'];
  27. $insert_data['begin_time'] = date('Y-m-d H:i:s');
  28. $insert_data['end_time'] = date('Y-m-d H:i:s', strtotime('+365 day'));
  29. $insert_data['distribution_channel_id'] = $data['distribution_channel_id'];
  30. $insert_data['fee'] = $data['fee'];
  31. $insert_data['send_order_id'] = $data['send_order_id'];
  32. $old = YearOrder::where('uid', $data['uid'])->select('id', 'uid', 'u', 'begin_time', 'end_time', 'fee')->first();
  33. if ($old) {
  34. //如果包过年
  35. if (strtotime($old->end_time) > time()) {
  36. //旧的包年没过期
  37. $old->end_time = date('Y-m-d H:i:s', strtotime($old->end_time) + 86400 * 365);
  38. $old->fee = $old->fee + $data['fee'];
  39. $old->save();
  40. } else {
  41. //旧的包年过期了
  42. $old->end_time = date('Y-m-d H:i:s', strtotime('+365 day'));
  43. $old->fee = $old->fee + $data['fee'];
  44. $old->save();
  45. }
  46. return $old;
  47. } else {
  48. return YearOrder::save_year_order($insert_data);
  49. }
  50. }
  51. static function foreverFree($data)
  52. {
  53. $insert_data = array();
  54. $insert_data['uid'] = $data['uid'];
  55. $insert_data['begin_time'] = date('Y-m-d H:i:s');
  56. $insert_data['end_time'] = date('Y-m-d H:i:s', time() + 86400 * 365 * 80);
  57. $insert_data['distribution_channel_id'] = $data['distribution_channel_id'];
  58. $insert_data['fee'] = $data['fee'];
  59. $insert_data['send_order_id'] = $data['send_order_id'];
  60. $old = YearOrder::where('uid', $data['uid'])->select('id', 'uid', 'u', 'begin_time', 'end_time', 'fee')->first();
  61. if ($old) {
  62. $old->end_time = date('Y-m-d H:i:s', time() + 86400 * 365 * 80);
  63. $old->fee = $old->fee + $data['fee'];
  64. $old->save();
  65. return $old;
  66. } else {
  67. return YearOrder::save_year_order($insert_data);
  68. }
  69. }
  70. /**
  71. * 幸运用户终身免费
  72. * @param $uid
  73. * @param $distribution_channel_id
  74. * @param $send_order_id
  75. * @return bool
  76. */
  77. static function luckyYearOrder($uid,$distribution_channel_id,$send_order_id){
  78. if(empty($uid)){
  79. return false;
  80. }
  81. try{
  82. Redis::sadd('luckyYearOrderUser',$uid);
  83. }catch (\Exception $e){}
  84. self::foreverFree([
  85. 'uid'=>$uid,
  86. 'distribution_channel_id'=>$distribution_channel_id,
  87. 'send_order_id'=>$send_order_id
  88. ]);
  89. return true;
  90. }
  91. }