<?php
|
namespace app\api\logic\order;
|
|
use think\Db;
|
use app\common\logic\Basic as BasicLogic;
|
use app\common\model\order\JtkOrder as ModelJtkOrder;
|
use app\api\logic\commission\Jtk as LogicJtkCommission;
|
|
class JtkOrder extends BasicLogic
|
{
|
protected $model;
|
|
protected static $userRate = 0; //用户反佣比例
|
|
|
public function __construct(){
|
$this->model = new ModelJtkOrder();
|
}
|
|
|
|
/**
|
* 订单入库和更新
|
*
|
* @return void
|
*/
|
public function fanliOrder($order)
|
{
|
$order_sn = isset($order['order_sn']) ? $order['order_sn'] : '';
|
if(empty($order_sn))return ['status'=>false,'info'=>'订单号不能为空'];
|
Db::startTrans();
|
$find_order = $this->model->where(['order_sn'=>$order['order_sn']])->find();
|
$save_order = [
|
'act_name' => isset($order['act_name']) ? $order['act_name'] : '',
|
'act_id' => isset($order['act_id']) ? $order['act_id'] : '',
|
'sid' => isset($order['sid']) ? $order['sid'] : '',
|
'pub_id' => isset($order['pub_id']) ? $order['pub_id'] : '',
|
'jtk_share_rate' => isset($order['jtk_share_rate']) ? $order['jtk_share_rate']*100 : '',
|
'jtk_share_fee' => isset($order['jtk_share_fee']) ? $order['jtk_share_fee'] : '',
|
'order_sn' => $order_sn,
|
'order_title' => isset($order['order_title']) ? $order['order_title'] : '',
|
'create_time' => isset($order['create_time']) ? $order['create_time'] : '',
|
'pay_time' => isset($order['pay_time']) ? $order['pay_time'] : '',
|
'modified_time' => isset($order['modified_time']) ? $order['modified_time'] : '',
|
'order_price' => isset($order['order_price']) ? $order['order_price'] : '',
|
'pay_price' => isset($order['pay_price']) ? $order['pay_price'] : '',
|
'status' => isset($order['status']) ? $order['status'] : '',
|
'status_desc' => isset($order['status_desc']) ? $order['status_desc'] : '',
|
'sub_share_rate' => isset($order['sub_share_rate']) ? $order['sub_share_rate'] : '',
|
'sub_share_fee' => isset($order['sub_share_fee']) ? $order['sub_share_fee'] : '',
|
];
|
if(empty($find_order)){
|
$save_order['tk_z_status'] = 1;
|
$save_order['is_distribution'] = (empty($save_order['sid']) || $save_order['sid'] == 0) ? 2 : 0; //如果没有渠道关系ID则该订单无须反佣
|
$save_order['update_time'] = time();
|
$res = $this->model->insert($save_order);
|
if(!$res){
|
Db::rollback();
|
return ['status'=>false,'info'=>'订单添加失败,订单order_sn:'.$order['order_sn']];
|
}
|
}else{
|
if($find_order['status'] != $save_order['status']){ //订单发生改变,更新订单
|
$save_order['update_time'] = time();
|
$save_order['tk_z_status'] = 2;
|
$res_update = $this->model->where(['id'=> $find_order['id']])->update($save_order);
|
if(!$res_update){
|
Db::rollback();
|
return ['status'=>false,'info'=>'订单更新失败,订单order_sn:'.$order['order_sn']];
|
}
|
}
|
}
|
Db::commit();
|
return ['status'=>true,'info'=>'订单逻辑处理完成'];
|
}
|
|
|
/**
|
* 拆分订单
|
*
|
* @return void
|
*/
|
public function chaifenOrder()
|
{
|
$list = $this->model->where(['is_distribution'=>0,'sid'=>['neq',''],'sid'=>['neq',0]])->whereOr("is_distribution = 1 And tk_z_status = 2 And sid !=''")->limit(20)->order('create_time desc')->select();
|
if(!empty($list)){
|
$LogicDyCommission = new LogicJtkCommission();
|
foreach($list as $order){
|
$result = $LogicDyCommission->fanliCommission($order);
|
if(!$result){
|
mylog('订单拆分错误',$result['info'],"errorInfo");
|
}
|
}
|
}
|
return ['status'=>true,'info'=>'拆分逻辑执行完成'];
|
}
|
|
}
|