| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133 | <?phpnamespace App\Console\Commands;use App\Modules\User\Services\UserSignService;use Illuminate\Console\Command;use DB;use Redis;use App\Jobs\SendTexts;use App\Modules\User\Services\ReadRecordService;use App\Modules\User\Services\UserService;use App\Modules\Book\Services\BookConfigService;use Hashids;use App\Modules\Activity\Models\Activity;use App\Modules\Activity\Services\ActivityService;class SignReward extends Command{    /**     * The name and signature of the console command.     *     * @var string     */    protected $signature = 'sign:reward {--record}';    /**     * The console command description.     *     * @var string     */    protected $description = '签到奖励';    /**     * Create a new command instance.     *     * @return void     */    public function __construct()    {        parent::__construct();    }    /**     * Execute the console command.     *     * @return mixed     */    public function handle()    {        $option = $this->option('record');        if($option){            $this->signRecord();        }else{            $this->signPushMsg();        }    }    public function saveSignInfoAndReward($option)    {        if ($option) {            $sign_key = 'sign-' . date('Y-m-d', time() - 86400);        } else {            $sign_key = 'sign-' . date('Y-m-d');        }        //print_r($sign_key);        //return 1;        $res = Redis::hgetall($sign_key);        $sign_data = [];        $uid_arr = [];        if (!$res) return -1;        foreach ($res as $key => $v) {            if (Redis::SISMEMBER($sign_key, $key)) {                continue;            }            $uid_arr[] = $key;            $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')];            Redis::sadd($sign_key, $key);        }        DB::table('user_sign')->insert($sign_data);        DB::table('users')->whereIn('id', $uid_arr)->increment('balance', 50);        DB::table('users')->whereIn('id', $uid_arr)->increment('reward_balance', 50);        return 0;    }    public function signRecord(){        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) {            foreach ($res as $v) {                $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";                $user_sign_info = DB::select($sql);                DB::table('order_day_stats')->where('id',$v->id)->update([                    'sign_num'=>(int)$user_sign_info[0]->count                ]);            }        });    }    public function signPushMsg()    {        $sign_key = 'leyuee:wap:usersigni';        //Redis::sadd($sign_key, 9);        $records = Redis::hgetall($sign_key);        if ($records ) {            //$uids = Redis::SMEMBERS($sign_key);            Redis::del($sign_key);            $uids = [];            foreach ($records as $u=>$p){                $uids[] = $u;            }            if (empty($uids)) return false;            $subscribe_user = DB::table('force_subscribe_users')->whereIn('uid', $uids)->where('is_subscribed', 1)->select('uid', 'appid', 'openid', 'distribution_channel_id')->get();            if ($subscribe_user) {                $delay = 0;                foreach ($subscribe_user as $keys => $value) {                    $content = UserSignService::userSignReturnContent3($value->openid);                    $data['openid'] = $value->openid;                    $data['appid'] = $value->appid;                    $data['content'] = $content;                    $data['type'] = 'one_task';                    $data['send_time'] = date("Y-m-d H:i:s");                    $data['task_id'] = md5(123);                    $send_data = array(                        'send_time' => date("Y-m-d H:i:s"),                        'data' => $data                    );                    //print_r($send_data);                    dispatch((new SendTexts($send_data))->onConnection('rabbitmq')->delay($delay)->onQueue('send_texts_list'));                }            }            return false;        }        return false;    }}
 |