__('Status 1'), '2' => __('Status 2'), '3' => __('Status 3'), '-1' => __('Status -1')]; } public function getStatusTextAttr($value, $data) { $value = $value ? $value : (isset($data['status']) ? $data['status'] : ''); $list = $this->getStatusList(); return isset($list[$value]) ? $list[$value] : ''; } public function getSettletimeTextAttr($value, $data) { $value = $value ? $value : (isset($data['settletime']) ? $data['settletime'] : ''); return is_numeric($value) ? date("Y-m-d H:i:s", $value) : $value; } public function getCanceltimeTextAttr($value, $data) { $value = $value ? $value : (isset($data['canceltime']) ? $data['canceltime'] : ''); return is_numeric($value) ? date("Y-m-d H:i:s", $value) : $value; } public function getUnfreezetimeTextAttr($value, $data) { $value = $value ? $value : (isset($data['unfreezetime']) ? $data['unfreezetime'] : ''); return is_numeric($value) ? date("Y-m-d H:i:s", $value) : $value; } protected function setSettletimeAttr($value) { return $value === '' ? null : ($value && !is_numeric($value) ? strtotime($value) : $value); } protected function setCanceltimeAttr($value) { return $value === '' ? null : ($value && !is_numeric($value) ? strtotime($value) : $value); } protected function setUnfreezetimeAttr($value) { return $value === '' ? null : ($value && !is_numeric($value) ? strtotime($value) : $value); } public function order() { return $this->belongsTo(Order::class, 'activity_order_id', 'id', [], 'LEFT')->setEagerlyType(0); } public function log() { return $this->belongsTo(UserwithdrawalLog::class, 'withdrawal_log_id', 'id', [], 'LEFT')->setEagerlyType(0); } public function touser() { return $this->belongsTo('app\common\model\User', 'to_user_id', 'id', [], 'LEFT')->setEagerlyType(0); } public function payuser() { return $this->belongsTo('app\common\model\User', 'pay_user_id', 'id', [], 'LEFT')->setEagerlyType(0); } /** 生成结算记录 * @param $order_id * @param $trans * @return true * @throws \Exception */ public function generatorLog($order_id,$trans=false){ $order = Order::where("id" ,$order_id)->find(); if(!$order) return false; //免费的忽略 if($order->payprice <= 0) return false; $detail = $order->detail; if(!$detail) return false; $data = [ "activity_order_id" => $order_id, "withdrawal_log_id" =>0, "to_user_id" => $detail->user_id, "pay_user_id" => $order->user_id, "status" =>'1', "unfreezetime" => $detail->settlement_time, "order_price" => $order->payprice, "sub_refundprice" =>$order->sub_refundprice, "fee_scale" => $order->fee_scale, "fee_price" => $order->fee_price, "settle_price" => bcsub($order->sub_refundprice,$order->fee_price,2) ]; //判断逻辑 if($trans){ self::beginTrans(); } $res = true; try{ $res =self::where([ "activity_order_id" => $order_id, "status" =>'1', "to_user_id" => $detail->user_id, ])->find(); //保存 if(!$res)$res = self::create($data); //记录状态检测 $this->settleCheck($res["id"]); if($trans){ self::commitTrans(); } }catch (\Exception $e){ if($trans){ self::rollbackTrans(); } throw new \Exception($e->getMessage().$e->getFile().$e->getLine()); } return $res; } /** 结算冻结状态更新 * @param $log_id * @param $trans * @return true * @throws \Exception */ public function settleCheck($log,$trans=false){ if(is_string($log)||is_numeric($log))$log = self::where("id" ,$log)->where("status",'1')->find(); if(!$log) return false; //判断逻辑 if($trans){ self::beginTrans(); } $res = true; try{ $time = time(); if($log->unfreezetime < $time){ //更新状态 $res = self::where("id" ,$log["id"])->update(["status" =>'2']); } if($trans){ self::commitTrans(); } }catch (\Exception $e){ if($trans){ self::rollbackTrans(); } throw new \Exception($e->getMessage().$e->getFile().$e->getLine()); } return $res; } /** * 超时检测 */ public static function timeoutCheck($activity_order_id=null,$to_user_id=null,$trans = false){ $count = 0; $model = self::where("status",'1'); if($activity_order_id)$model = $model->where("activity_order_id",$activity_order_id); if($to_user_id)$model = $model->where("to_user_id",$to_user_id); //得到所有过期的队列 $list = $model->select(); if ($trans) { self::beginTrans(); } try { foreach ($list as $log) { //更新结算状态 (new self)->settleCheck($log,$trans=false); $count++; } if ($trans) { self::commitTrans(); } } catch (\Exception $e) { if ($trans) { self::rollbackTrans(); } throw new \Exception($e->getMessage()); } return $count; } /** * 批量关闭 */ public static function allClose($activity_order_id=null,$to_user_id=null,$trans = false){ $count = 0; $model = self::where("status",'2'); if($activity_order_id)$model = $model->where("activity_order_id",$activity_order_id); if($to_user_id)$model = $model->where("to_user_id",$to_user_id); //得到所有过期的队列 $list = $model->select(); if ($trans) { self::beginTrans(); } try { foreach ($list as $log) { $log["status"] = "-1"; $log["canceltime"] = time(); $log->save(); $count++; } if ($trans) { self::commitTrans(); } } catch (\Exception $e) { if ($trans) { self::rollbackTrans(); } throw new \Exception($e->getMessage()); } return $count; } }