| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586 | <?phpnamespace App\Task;use App\Service\Premium\PremiumWalletServices;use App\Service\Premium\PremiumWalletTradeUsdtServices;use App\Model\Premium\PremiumWalletTradeList;use App\Library\Log;// use Swoole\Coroutine\WaitGroup;use Hyperf\Utils\Coroutine\Concurrent;class GetPremiumWalletUsdtTrade{    public function execute()    {        try {            $premiumWallet_services = new PremiumWalletServices();            $list = $premiumWallet_services->getList();      //获取收款列表                        if(!empty($list)){                try {                    // $this->log('getpremiumwalletusdttrade','-----------开始执行:拉取钱包交易列表数据,钱包总数:'.count($list).'个--------------');                    //协程通知                    // $wg = new WaitGroup();                    //协程数量                    $concurrent = new Concurrent(5);                                        foreach ($list as $k => $v) {                        // $wg->add();                        // go(function () use ($wg,$v) {                        //     $premiumWalletTradeUsdt_services = new PremiumWalletTradeUsdtServices();                        //     $res = $this->handle($wg,$v,$premiumWalletTradeUsdt_services);                                                    //     $wg->done();                        // });                                                $concurrent->create(function () use ($v) {                            // sleep(1); //不容易被api限制                            $premiumWalletTradeUsdt_services = new PremiumWalletTradeUsdtServices();                            $res = $this->handle($v,$premiumWalletTradeUsdt_services);                        });                    }                    // $wg->wait();                    // $this->log('getpremiumwalletusdttrade','-----------结束执行:拉取钱包交易列表数据--------------');                }catch (\Exception $e){                    $this->log('getpremiumwalletusdttrade','拉取失败'.$e->getMessage().'----------');                }            }else{                // $this->log('getpremiumwalletusdttrade','-----------没有钱包需要拉取交易数据--------');            }        }catch (\Exception $e){            // $this->log('getpremiumwalletusdttrade','----------任务执行报错,请联系管理员。报错原因:----------'.$e->getMessage());        }    }    public function handle($v,$premiumWalletTradeUsdt_services){        try {            $start_time = PremiumWalletTradeList::where('transferto_address',$v['receive_wallet'])->where('coin_name','usdt')->orderBy('timestamp','desc')->value('timestamp');            if(empty($start_time)){                $start_time = 0;            }            $get_tx_time = strtotime($v['get_tx_time'])*1000-10;            if($get_tx_time > $start_time){                $start_time = $get_tx_time;            }            // 获取收款数据            $res = $premiumWalletTradeUsdt_services->getList($v,$start_time);            return ['code' => 200,'msg'=>'钱包地址:'.$v['receive_wallet'].',成功总数'.$res['success_count'].',失败总数'.$res['error_count']];        }catch (\Exception $e){            return ['code' => 400,'msg'=>$v['receive_wallet'].',拉取地址失败,'.$e->getMessage().'----------'];        }    }    /**     * 记入日志     * @param $log_title [日志路径]     * @param $message [内容,不支持数组]     * @param $remarks [备注]    */    protected function log($log_title,$message,$remarks='info'){        Log::get($remarks,$log_title)->info($message);    }}
 |