b3f70a8d30 feat(queue): 新增临时锁卡任务
- 添加 LinSuoKa 类实现临时锁卡功能
- 优化卡密订单关联逻辑,处理状态为 4 的订单- 新增 redis 记录订单详情,用于限单和退款处理
- 修改 Qiling 类中的签名生成逻辑
- 更新 Test 控制器中的 test_ts 方法,增加对不同订单表的处理
2025-06-03 18:55:03 +08:00

154 lines
4.0 KiB
PHP

<?php
namespace app\channel\service\system;
#模板
class Mgdy extends Core
{
protected $host = ''; // 主机,不设置,后台
protected $mid = ''; // 商户id
protected $token = ''; // 密钥
protected $api = '';
//话费直充
# 通用卡密购买,命名规范 渠道加卡的首字母_cardbuy 骏卡xxka jkxxk_cardbuy
# cardbuy为通用写法
public function dy($param)
{
$check = array
(
'account' => 'dyAccount',
'cash'=>'amount'
);
$this->api='api/order/v1/submit';
return $this->submit($param, $check);
}
public function common($param)
{
$check = array
(
'account' => 'dyAccount',
'cash'=>'amount'
);
$this->api='api/order/v1/submit';
return $this->submit($param, $check);
}
# 通知处理 主要返回状态 2是成功 3是失败
public function notify($data)
{
$result = array();
$result['cash'] = 1;
$result['status'] = 4;
#以上基本不要变
if ($data['status'] == 'SUCCESS') {
$result['status'] = 2;
} else if($data['status'] == 'FAILED') {
$result['status'] = 3;
}else {
$result['status'] = 4;
}
#以下处理逻辑可以自由
$result['yes'] = 'ok'; //响应给上游的数据
$result['data'] = $data;
return $result;
}
# 数据响应格式处理
public function response($data)
{
$log['type'] = 'response';
$log['data'] = $data;
$log['config'] = $this->data;
$this->log($log);
#以上不要做任何变动
$array = $this->json_decode($data); //响应数据为json
#如果响应为XML格式
//
if (!$array) {
$msg = 'error';
} elseif (isset($array['code']) && $array['code']=='200') { //修改判断逻辑为确定提交成功即可
# 正确
$msg = 'ok';
} else {
# 错误
$msg = $array['msg'] ?? 'error'; //前面message根据响应内容改成对应的错误提示
}
return array
(
'msg' => $msg,
'data' => $data,
'array' => $array,
);
}
# 提交数据
private function submit($param, $check)
{
#提交处理
$param = $this->param($param, $check);
if (is_string($param) || (is_array($param) && $param['status'] == 1)) {
return $param;
}
$request = $param['detail']; //上面替换剩下的
#结束初步
$request['appId']=$this->mid; //
$request['outTradeNo']=$param['order']; //我方系统订单号
$request['type']=$this->getGid($param['cash']); //此方法为根据面值获取产品id,如无需可注释
$request['asyncUrl']=$this->getNotify($param['order'], 1); //回调方法默认不用改
$request['nonceStr']=rand(100000,999999);
// unset($request['cash']);
$request['sign'] = $this->_sign($request);
$url = $this->host . $this->api; //组装地址
#该系统提交写法:
$response = $this->curl('post', $url, $request);
$response = $this->response($response);
$channel_order_id = '';
#如果出现响应有上游订单号,可以如下
if (isset($response["array"]['data']['orderNo'])) {
$channel_order_id = $response["array"]['data']['orderNo'];
}
$this->create($param['order'], $channel_order_id, $param['merchant_order'], $param['cash'], $url, $request, $response, 1, $param['account']);
return $response['msg'];
}
private function _sign($request)
{
// unset($request['cash']);
ksort($request);
$str='';
foreach($request as $k=>$v){
$str.=$k.'='.$v.'&';
}
$str=$str.'key='.$this->token;
// var_dump($str);die;
return strtoupper(md5($str));
}
}