| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184 | <?phpnamespace App\Console\Commands;use App\Modules\SendOrder\Services\SendOrderService;use App\Modules\Subscribe\Services\YearOrderService;use App\Modules\User\Models\UserMonthSign;use App\Modules\User\Services\UserMonthService;use App\Modules\User\Services\UserService;use Illuminate\Console\Command;use App\Modules\Subscribe\Services\OrderService;use Redis;use Log;use DB;class CheckOrderStatus extends Command{    /**     * The name and signature of the console command.     *     * @var string     */    protected $signature = 'checkOrderStatus {--uid= : the uid}';    /**     * The console command description.     *     * @var string     */    protected $description = 'Command description';    /**     * Create a new command instance.     *     * @return void     */    public function __construct()    {        parent::__construct();    }    /**     * Execute the console command.     *     * @return mixed     */    public function handle()    {        //$this->checkOne(157286149);        $uid = $this->option('uid');        if($uid) {            $this->checkOne($uid);        }else{            $result = UserMonthSign::where('created_at','>=',date('Y-m-d H:i:s',time()-1800))->select('uid')->get();            if($result->isNotEmpty()){                foreach ($result as $item){                    $this->checkOne($item->uid);                }            }        }    }    public function checkOne($uid){        //int $user_id,int $plan_id,string $app_id,string $key,string $app_secret        $plan_id = env('MONTH_ORDER_PLAN_ID');        $app_id = env('MONTH_ORDER_APPID');        $key = env('MONTH_ORDER_KEY');        $app_secret = env('MONTH_ORDER_APP_SECRET');        $result = UserMonthService::checkOrderStatus($uid,$plan_id,$app_id,$key,$app_secret);        if(isset($result['code']) && !$result['code']){            echo sprintf('sign fail ,uid is :%s',$uid).PHP_EOL;            return '';        }        //print_r($result);        $trade_no = $result['trade_no'];        $out_trade_no = $result['out_trade_no'];        $money = $result['money'];        if(empty($trade_no) || empty($out_trade_no) || empty($money)){            echo sprintf('uid is : %s,order is not exist',$uid).PHP_EOL;            return '';        }        if (!UserMonthService::getOrderByOrder($trade_no, $out_trade_no)) {            UserMonthService::createLOrder($uid, $plan_id, $money, $trade_no, $out_trade_no);            $this->addOrderAndVip($uid, $out_trade_no, $trade_no, $money);        }    }    private function addOrderAndVip($uid, $out_trade_no, $trade_no, $price)    {        $order_info = OrderService::getByTradeNo($out_trade_no);        //订单已经存在        if ($order_info) {            return;        }        $user_info = UserService::getById($uid);        if (!$user_info) return;        $this->createOrder($uid, $user_info->distribution_channel_id, 0, $price, $out_trade_no, $trade_no);        YearOrderService::save_month_order([            'uid' => $uid,            'distribution_channel_id' => $user_info->distribution_channel_id,            'fee' => $price / 100,            'send_order_id' => 0        ]);    }    private function createOrder($uid, $distribution_channel_id, $product_id, $price, $trade_no, $transaction_id)    {        $count = OrderService::getUserChargeTimes($uid);        $count = $count + 1;        $send_order_id = 0;        try {            $send_order_id = (int)Redis::hget('book_read:' . $uid, 'send_order_id');        } catch (\Exception $e) {        }        $send_order_name = '';        if ($send_order_id) {            $send_order_info = SendOrderService::getById($send_order_id);            if ($send_order_info && isset($send_order_info->name) && !empty($send_order_info->name)) {                $send_order_name = $send_order_info->name;            }        }        $init_order = [            'distribution_channel_id' => $distribution_channel_id,            'uid' => $uid,            'product_id' => 6826,            'price' => $price / 100,            'pay_type' => $count,            'trade_no' => $trade_no,            'pay_merchant_source' => 'MONTH',            'pay_merchant_id' => 99,            'create_ip' => '',            'send_order_id' => $send_order_id,            'send_order_name' => $send_order_name,            'order_type' => 'RECHARGE',            'from_bid' => '0',            'from_type' => 'auto_month',            'activity_id' => 0,            'inner_send_order_id' => '',            'status' => 'PAID',            'transaction_id' => $transaction_id,            'pay_end_at' => date('Y-m-d H:i:s')        ];        OrderService::save_order($init_order);    }    protected function successPayPushMsg($uid)    {        try {            $force_sub_info = DB::table('force_subscribe_users')->where('uid', $uid)->where('is_subscribed', 1)->first();            $data = UserService::getById($uid);            if (!$force_sub_info) {                return;            }            $content_format = "包月购买成功通知:\r\n\r\n购买类型: 30元包月\r\n\r\n><a href='%s'>点击继续上次阅读</a>\r\n\r\n为了方便阅读,请<a href='%s'>置顶公众号</a>\r\n\r\n为了方便阅读,请<a href='%s'>置顶公众号</a>\r\n\r\n为了方便阅读,请<a href='%s'>置顶公众号</a>";            $delay = 0;            $url = env('PROTOCOL') . '://site' . encodeDistributionChannelId($data->distribution_channel_id) . '.' . env('CUSTOM_HOST') . '.com/continue';;            $top_url = 'https://help.zhuishuyun.com/top.html';            $content = sprintf($content_format, $url, $top_url, $top_url, $top_url);            $res['openid'] = $force_sub_info->openid;            $res['appid'] = $force_sub_info->appid;            $res['content'] = $content;            $res['type'] = 'one_task';            $res['send_time'] = date("Y-m-d H:i:s");            $res['task_id'] = md5('month_pay_success_push');            $send_data = array(                'send_time' => date("Y-m-d H:i:s"),                'data' => $res            );            dispatch((new SendTexts($send_data))->onConnection('rabbitmq')->delay($delay)->onQueue('send_texts_list'));        } catch (\Exception $e) {            Log::error('pay_success_push error');            Log::error($e);        }        return;    }}
 |