SignReward.php 4.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133
  1. <?php
  2. namespace App\Console\Commands;
  3. use App\Modules\User\Services\UserSignService;
  4. use Illuminate\Console\Command;
  5. use DB;
  6. use Redis;
  7. use App\Jobs\SendTexts;
  8. use App\Modules\User\Services\ReadRecordService;
  9. use App\Modules\User\Services\UserService;
  10. use App\Modules\Book\Services\BookConfigService;
  11. use Hashids;
  12. use App\Modules\Activity\Models\Activity;
  13. use App\Modules\Activity\Services\ActivityService;
  14. class SignReward extends Command
  15. {
  16. /**
  17. * The name and signature of the console command.
  18. *
  19. * @var string
  20. */
  21. protected $signature = 'sign:reward {--record}';
  22. /**
  23. * The console command description.
  24. *
  25. * @var string
  26. */
  27. protected $description = '签到奖励';
  28. /**
  29. * Create a new command instance.
  30. *
  31. * @return void
  32. */
  33. public function __construct()
  34. {
  35. parent::__construct();
  36. }
  37. /**
  38. * Execute the console command.
  39. *
  40. * @return mixed
  41. */
  42. public function handle()
  43. {
  44. $option = $this->option('record');
  45. if($option){
  46. $this->signRecord();
  47. }else{
  48. $this->signPushMsg();
  49. }
  50. }
  51. public function saveSignInfoAndReward($option)
  52. {
  53. if ($option) {
  54. $sign_key = 'sign-' . date('Y-m-d', time() - 86400);
  55. } else {
  56. $sign_key = 'sign-' . date('Y-m-d');
  57. }
  58. //print_r($sign_key);
  59. //return 1;
  60. $res = Redis::hgetall($sign_key);
  61. $sign_data = [];
  62. $uid_arr = [];
  63. if (!$res) return -1;
  64. foreach ($res as $key => $v) {
  65. if (Redis::SISMEMBER($sign_key, $key)) {
  66. continue;
  67. }
  68. $uid_arr[] = $key;
  69. $sign_data[] = ['uid' => $key, 'price' => 50, 'sign_time' => $v, 'created_at' => date('Y-m-d H:i:s'), 'updated_at' => date('Y-m-d H:i:s')];
  70. Redis::sadd($sign_key, $key);
  71. }
  72. DB::table('user_sign')->insert($sign_data);
  73. DB::table('users')->whereIn('id', $uid_arr)->increment('balance', 50);
  74. DB::table('users')->whereIn('id', $uid_arr)->increment('reward_balance', 50);
  75. return 0;
  76. }
  77. public function signRecord(){
  78. DB::table('order_day_stats')->select('id', 'distribution_channel_id', 'date')->where('date',date('Y-m-d',time()-86400))->orderBy('id')->chunk(1000, function ($res) {
  79. foreach ($res as $v) {
  80. $sql = "select count(*) as count from user_sign join users on user_sign.uid=users.id where date(user_sign.created_at)='%s' and user.distribution_channel_id=%s";
  81. $user_sign_info = DB::select($sql);
  82. DB::table('order_day_stats')->where('id',$v->id)->update([
  83. 'sign_num'=>(int)$user_sign_info[0]->count
  84. ]);
  85. }
  86. });
  87. }
  88. public function signPushMsg()
  89. {
  90. $sign_key = 'leyuee:wap:usersigni';
  91. //Redis::sadd($sign_key, 9);
  92. $records = Redis::hgetall($sign_key);
  93. if ($records ) {
  94. //$uids = Redis::SMEMBERS($sign_key);
  95. Redis::del($sign_key);
  96. $uids = [];
  97. foreach ($records as $u=>$p){
  98. $uids[] = $u;
  99. }
  100. if (empty($uids)) return false;
  101. $subscribe_user = DB::table('force_subscribe_users')->whereIn('uid', $uids)->where('is_subscribed', 1)->select('uid', 'appid', 'openid', 'distribution_channel_id')->get();
  102. if ($subscribe_user) {
  103. $delay = 0;
  104. foreach ($subscribe_user as $keys => $value) {
  105. $content = UserSignService::userSignReturnContent3($value->openid);
  106. $data['openid'] = $value->openid;
  107. $data['appid'] = $value->appid;
  108. $data['content'] = $content;
  109. $data['type'] = 'one_task';
  110. $data['send_time'] = date("Y-m-d H:i:s");
  111. $data['task_id'] = md5(123);
  112. $send_data = array(
  113. 'send_time' => date("Y-m-d H:i:s"),
  114. 'data' => $data
  115. );
  116. //print_r($send_data);
  117. dispatch((new SendTexts($send_data))->onConnection('rabbitmq')->delay($delay)->onQueue('send_texts_list'));
  118. }
  119. }
  120. return false;
  121. }
  122. return false;
  123. }
  124. }