You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
235 lines
8.1 KiB
235 lines
8.1 KiB
1 year ago
|
<?php
|
||
|
// +----------------------------------------------------------------------
|
||
|
// | CRMEB [ CRMEB赋能开发者,助力企业发展 ]
|
||
|
// +----------------------------------------------------------------------
|
||
|
// | Copyright (c) 2016~2022 https://www.crmeb.com All rights reserved.
|
||
|
// +----------------------------------------------------------------------
|
||
|
// | Licensed CRMEB并不是自由软件,未经许可不能去掉CRMEB相关版权
|
||
|
// +----------------------------------------------------------------------
|
||
|
// | Author: CRMEB Team <admin@crmeb.com>
|
||
|
// +----------------------------------------------------------------------
|
||
|
|
||
|
namespace app\common\repositories\system\serve;
|
||
|
|
||
|
use AlibabaCloud\SDK\Dysmsapi\V20170525\Models\AddShortUrlResponseBody\data;
|
||
|
use app\common\dao\system\serve\ServeOrderDao;
|
||
|
use app\common\model\system\serve\ServeOrder;
|
||
|
use app\common\repositories\BaseRepository;
|
||
|
use app\common\repositories\store\order\StoreOrderRepository;
|
||
|
use app\common\repositories\store\product\ProductCopyRepository;
|
||
|
use app\common\repositories\system\merchant\MerchantRepository;
|
||
|
use app\common\repositories\user\UserRepository;
|
||
|
use crmeb\services\CombinePayService;
|
||
|
use crmeb\services\PayService;
|
||
|
use think\exception\ValidateException;
|
||
|
use think\facade\Cache;
|
||
|
use think\facade\Db;
|
||
|
use think\facade\Log;
|
||
|
|
||
|
class ServeOrderRepository extends BaseRepository
|
||
|
{
|
||
|
protected $dao;
|
||
|
|
||
|
public function __construct(ServeOrderDao $dao)
|
||
|
{
|
||
|
$this->dao = $dao;
|
||
|
}
|
||
|
//复制商品
|
||
|
const TYPE_COPY_PRODUCT = 1;
|
||
|
//电子面单
|
||
|
const TYPE_DUMP = 2;
|
||
|
//保证金 margin
|
||
|
const TYPE_MARGIN = 10;
|
||
|
//同城配送delivery
|
||
|
const TYPE_DELIVERY = 20;
|
||
|
|
||
|
|
||
|
/**
|
||
|
* TODO 购买一号通 支付
|
||
|
* @param $merId
|
||
|
* @param $data
|
||
|
* @return array
|
||
|
* @author Qinii
|
||
|
* @day 1/26/22
|
||
|
*/
|
||
|
public function meal($merId, $data)
|
||
|
{
|
||
|
$ret = app()->make(ServeMealRepository::class)->get($data['meal_id']);
|
||
|
if(!$ret) throw new ValidateException('数据不存在');
|
||
|
$key = 'Meal_'.$merId.'_'.$data['meal_id'].'_'.date('YmdH',time());
|
||
|
$arr = [
|
||
|
'meal_id' => $ret['meal_id'],
|
||
|
'name' => $ret['name'],
|
||
|
'num' => $ret['num'],
|
||
|
'price' => $ret['price'],
|
||
|
'type' => $ret['type'],
|
||
|
];
|
||
|
$param = [
|
||
|
'status' => 0,
|
||
|
'is_del' => 0,
|
||
|
'mer_id' => $merId,
|
||
|
'type' => $ret['type'],
|
||
|
'meal_id'=> $ret['meal_id'],
|
||
|
'pay_type' => $data['pay_type'],
|
||
|
'attach' => 'meal',
|
||
|
'order_info' => json_encode($arr,JSON_UNESCAPED_UNICODE),
|
||
|
'pay_price' => $ret['price'],
|
||
|
];
|
||
|
return compact('key', 'param');
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* TODO 商户保证金 支付
|
||
|
* @param $merId
|
||
|
* @param $data
|
||
|
* @return array
|
||
|
* @author Qinii
|
||
|
* @day 1/26/22
|
||
|
*/
|
||
|
public function margin($merId, $data)
|
||
|
{
|
||
|
$ret = app()->make(MerchantRepository::class)->get($merId);
|
||
|
if ($ret['is_margin'] !== 1) throw new ValidateException('此商户无需支付保证金');
|
||
|
$key = 'Margin_'.$merId.'_'.date('YmdH',time());
|
||
|
$arr = [
|
||
|
'type_id' => $ret['type_id'],
|
||
|
'is_margin' => $ret['is_margin'],
|
||
|
'margin' => $ret['margin'],
|
||
|
];
|
||
|
$param = [
|
||
|
'status' => 0,
|
||
|
'is_del' => 0,
|
||
|
'mer_id' => $merId,
|
||
|
'type' => 10,
|
||
|
'meal_id'=> $ret['type_id'],
|
||
|
'pay_type' => $data['pay_type'],
|
||
|
'attach' => 'meal',
|
||
|
'order_info' => json_encode($arr,JSON_UNESCAPED_UNICODE),
|
||
|
'pay_price' => $ret['margin'],
|
||
|
];
|
||
|
|
||
|
return compact('key', 'param');
|
||
|
}
|
||
|
|
||
|
public function delivery($merId, $data)
|
||
|
{
|
||
|
$key = 'Delivery_'.$merId.'_'.md5(date('YmdH',time()).$data['price']);
|
||
|
$arr = ['price' => $data['price']];
|
||
|
$param = [
|
||
|
'status' => 0,
|
||
|
'is_del' => 0,
|
||
|
'mer_id' => $merId,
|
||
|
'type' => 20,
|
||
|
'meal_id'=> 0,
|
||
|
'pay_type' => $data['pay_type'],
|
||
|
'attach' => 'meal',
|
||
|
'order_info' => json_encode($arr,JSON_UNESCAPED_UNICODE),
|
||
|
'pay_price' => $data['price'],
|
||
|
];
|
||
|
|
||
|
return compact('key', 'param');
|
||
|
}
|
||
|
|
||
|
public function QrCode(int $merId, string $type, array $data)
|
||
|
{
|
||
|
$res = $this->{$type}($merId, $data);
|
||
|
$key = $res['key'];
|
||
|
$param = $res['param'];
|
||
|
|
||
|
if(!$result = Cache::store('file')->get($key)){
|
||
|
$order_sn = app()->make(StoreOrderRepository::class)->getNewOrderId('cs');
|
||
|
$param['order_sn'] = $order_sn;
|
||
|
$param['body'] = $order_sn;
|
||
|
$payType = $data['pay_type'] == 1 ? 'weixinQr' : 'alipayQr';
|
||
|
$service = new PayService($payType,$param);
|
||
|
$code = $service->pay(null);
|
||
|
|
||
|
$endtime = time() + 1800 ;
|
||
|
$result = [
|
||
|
'config' => $code['config'],
|
||
|
'endtime'=> date('Y-m-d H:i:s',$endtime),
|
||
|
'price' => $param['pay_price']
|
||
|
];
|
||
|
Cache::store('file')->set($key,$result,30);
|
||
|
$param['key'] = $key;
|
||
|
Cache::store('file')->set($order_sn,$param,60 * 24);
|
||
|
}
|
||
|
|
||
|
return $result;
|
||
|
}
|
||
|
|
||
|
public function paySuccess($data)
|
||
|
{
|
||
|
$get = $this->dao->getWhere(['order_sn' => $data['order_sn']]);
|
||
|
if(!$get){
|
||
|
$dat = Cache::store('file')->get($data['order_sn']);
|
||
|
$key = $dat['key'];
|
||
|
unset($dat['attach'],$dat['body'],$dat['key']);
|
||
|
|
||
|
$dat['status'] = 1;
|
||
|
$dat['pay_time'] = date('y_m-d H:i:s', time());
|
||
|
Db::transaction(function () use($data, $dat,$key){
|
||
|
$res = $this->dao->create($dat);
|
||
|
$this->payAfter($dat,$res);
|
||
|
Cache::store('file')->delete($data['order_sn']);
|
||
|
Cache::store('file')->delete($key);
|
||
|
});
|
||
|
}
|
||
|
}
|
||
|
|
||
|
public function payAfter($dat, $ret = null)
|
||
|
{
|
||
|
$info = json_decode($dat['order_info']);
|
||
|
switch ($dat['type']) {
|
||
|
case self::TYPE_COPY_PRODUCT:
|
||
|
app()->make(ProductCopyRepository::class)->add([
|
||
|
'type' => 'pay_copy',
|
||
|
'num' => $info->num,
|
||
|
'info' => $dat['order_info'],
|
||
|
'message' => '购买复制商品套餐' ,
|
||
|
],$dat['mer_id']);
|
||
|
break;
|
||
|
case self::TYPE_DUMP:
|
||
|
app()->make(ProductCopyRepository::class)->add(['type' => 'pay_dump', 'num' => $info->num, 'info' => $dat['order_info'], 'message' => '购买电子面单套餐',],$dat['mer_id']);
|
||
|
break;
|
||
|
case self::TYPE_MARGIN:
|
||
|
$res = app()->make(MerchantRepository::class)->get($dat['mer_id']);
|
||
|
if (bccomp($res['margin'] , $dat['pay_price'], 2) === 0) {
|
||
|
$res->ot_margin = $res['margin'];
|
||
|
$res->is_margin = 10;
|
||
|
} else {
|
||
|
$res->is_margin = 20;
|
||
|
}
|
||
|
$res->save();
|
||
|
break;
|
||
|
case self::TYPE_DELIVERY:
|
||
|
$res = app()->make(MerchantRepository::class)->get($dat['mer_id']);
|
||
|
if ($res) {
|
||
|
$res->delivery_balance = bcadd($res->delivery_balance, $dat['pay_price'],2);
|
||
|
$res->save();
|
||
|
} else {
|
||
|
Log::info('同城配送充值异常 :'. json_encode($dat));
|
||
|
}
|
||
|
break;
|
||
|
default:
|
||
|
break;
|
||
|
}
|
||
|
return ;
|
||
|
}
|
||
|
|
||
|
|
||
|
public function getList(array $where, int $page, int $limit)
|
||
|
{
|
||
|
$where['is_del'] = 0;
|
||
|
$query = $this->dao->search($where)->with([
|
||
|
'merchant' => function($query){
|
||
|
$query->with(['merchantType']);
|
||
|
$query->field('mer_id,mer_name,is_trader,mer_avatar,type_id,mer_phone,mer_address,is_margin,margin,real_name,ot_margin');
|
||
|
}
|
||
|
])->order('ServeOrder.create_time DESC');
|
||
|
$count = $query->count();
|
||
|
$list = $query->page($page, $limit)->select();
|
||
|
return compact('count','list');
|
||
|
}
|
||
|
}
|