mirror of
https://gitee.com/koogua/course-tencent-cloud.git
synced 2025-06-24 12:05:39 +08:00
Merge branch 'ctc/v1.4.8'
This commit is contained in:
commit
b889569d77
@ -1,3 +1,12 @@
|
||||
### [v1.4.8](https://gitee.com/koogua/course-tencent-cloud/releases/v1.4.8)(2021-11-28)
|
||||
|
||||
- 修正后台下载课程附件问题
|
||||
- 修正后台登录检查跳转地址
|
||||
- 修正公众号关注二维码样式问题
|
||||
- 优化发货失败自动退款逻辑
|
||||
- 创建交易时增加订单支付检查
|
||||
- H5增加底部tab图标
|
||||
|
||||
### [v1.4.7](https://gitee.com/koogua/course-tencent-cloud/releases/v1.4.7)(2021-10-28)
|
||||
|
||||
- 更新README.md
|
||||
|
@ -272,6 +272,20 @@ class DeliverTask extends Task
|
||||
$refund->review_note = '自动操作';
|
||||
|
||||
$refund->create();
|
||||
|
||||
$task = new TaskModel();
|
||||
|
||||
$itemInfo = [
|
||||
'refund' => ['id' => $refund->id],
|
||||
];
|
||||
|
||||
$task->item_id = $refund->id;
|
||||
$task->item_info = $itemInfo;
|
||||
$task->item_type = TaskModel::TYPE_REFUND;
|
||||
$task->priority = TaskModel::PRIORITY_HIGH;
|
||||
$task->status = TaskModel::STATUS_PENDING;
|
||||
|
||||
$task->create();
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -77,7 +77,7 @@ class HelpController extends Controller
|
||||
*/
|
||||
public function editAction($id)
|
||||
{
|
||||
$helpService = new HelpService;
|
||||
$helpService = new HelpService();
|
||||
|
||||
$categories = $helpService->getCategories();
|
||||
|
||||
|
@ -32,6 +32,8 @@ class Refund extends Service
|
||||
|
||||
$params = $pageQuery->getParams();
|
||||
|
||||
$params['deleted'] = $params['deleted'] ?? 0;
|
||||
|
||||
/**
|
||||
* 兼容订单编号或订单序号查询
|
||||
*/
|
||||
@ -114,11 +116,7 @@ class Refund extends Service
|
||||
$task = new TaskModel();
|
||||
|
||||
$itemInfo = [
|
||||
'refund' => [
|
||||
'id' => $refund->id,
|
||||
'order_id' => $refund->order_id,
|
||||
'trade_id' => $refund->trade_id,
|
||||
],
|
||||
'refund' => ['id' => $refund->id],
|
||||
];
|
||||
|
||||
$task->item_id = $refund->id;
|
||||
|
@ -26,12 +26,6 @@ class Session extends Service
|
||||
|
||||
public function login()
|
||||
{
|
||||
$user = $this->getCurrentUser();
|
||||
|
||||
if ($user->id > 0) {
|
||||
return $this->response->redirect(['for' => 'home.index']);
|
||||
}
|
||||
|
||||
$post = $this->request->getPost();
|
||||
|
||||
$validator = new AccountValidator();
|
||||
|
@ -10,7 +10,6 @@
|
||||
{% for item in resources %}
|
||||
{% set update_url = url({'for':'admin.resource.update','id':item.id}) %}
|
||||
{% set delete_url = url({'for':'admin.resource.delete','id':item.id}) %}
|
||||
{% set download_url = url({'for':'home.download','md5':item.upload.md5}) %}
|
||||
<tr>
|
||||
<td><input class="layui-input res-name" type="text" value="{{ item.upload.name }}" data-url="{{ update_url }}"></td>
|
||||
<td>{{ item.upload.mime }}</td>
|
||||
@ -18,7 +17,7 @@
|
||||
<td>{{ date('Y-m-d H:i:s',item.create_time) }}</td>
|
||||
<td>
|
||||
<a class="layui-btn layui-btn-sm layui-bg-red res-btn-delete" href="javascript:" data-url="{{ delete_url }}">删除</a>
|
||||
<a class="layui-btn layui-btn-sm" href="{{ download_url }}" target="_blank">下载</a>
|
||||
<a class="layui-btn layui-btn-sm" href="{{ item.upload.url }}" target="_blank">下载</a>
|
||||
</td>
|
||||
</tr>
|
||||
{% endfor %}
|
||||
|
@ -15,6 +15,7 @@ use App\Services\Logic\TradeTrait;
|
||||
use App\Services\Pay\Alipay;
|
||||
use App\Services\Pay\Wxpay;
|
||||
use App\Validators\Client as ClientValidator;
|
||||
use App\Validators\Order as OrderValidator;
|
||||
use App\Validators\Trade as TradeValidator;
|
||||
|
||||
class Trade extends Service
|
||||
@ -35,6 +36,10 @@ class Trade extends Service
|
||||
|
||||
$order = $this->checkOrderBySn($post['order_sn']);
|
||||
|
||||
$validator = new OrderValidator();
|
||||
|
||||
$validator->checkIfAllowPay($order);
|
||||
|
||||
$user = $this->getLoginUser();
|
||||
|
||||
$validator = new TradeValidator();
|
||||
@ -77,6 +82,10 @@ class Trade extends Service
|
||||
|
||||
$order = $this->checkOrderBySn($post['order_sn']);
|
||||
|
||||
$validator = new OrderValidator();
|
||||
|
||||
$validator->checkIfAllowPay($order);
|
||||
|
||||
$user = $this->getLoginUser();
|
||||
|
||||
$channel = TradeModel::CHANNEL_WXPAY;
|
||||
@ -122,6 +131,10 @@ class Trade extends Service
|
||||
|
||||
$order = $this->checkOrderBySn($post['order_sn']);
|
||||
|
||||
$validator = new OrderValidator();
|
||||
|
||||
$validator->checkIfAllowPay($order);
|
||||
|
||||
$user = $this->getLoginUser();
|
||||
|
||||
$channel = TradeModel::CHANNEL_WXPAY;
|
||||
|
@ -16,7 +16,7 @@ class AppInfo
|
||||
|
||||
protected $link = 'https://koogua.com';
|
||||
|
||||
protected $version = '1.4.7';
|
||||
protected $version = '1.4.8';
|
||||
|
||||
public function __get($name)
|
||||
{
|
||||
|
@ -52,11 +52,7 @@ class Trade extends Listener
|
||||
$task = new TaskModel();
|
||||
|
||||
$itemInfo = [
|
||||
'order' => [
|
||||
'id' => $order->id,
|
||||
'item_id' => $order->item_id,
|
||||
'item_type' => $order->item_type,
|
||||
]
|
||||
'order' => ['id' => $order->id]
|
||||
];
|
||||
|
||||
$task->item_id = $order->id;
|
||||
@ -74,6 +70,8 @@ class Trade extends Listener
|
||||
$this->db->rollback();
|
||||
|
||||
$this->logger->error('After Pay Event Error ' . kg_json_encode([
|
||||
'file' => $e->getFile(),
|
||||
'line' => $e->getLine(),
|
||||
'code' => $e->getCode(),
|
||||
'message' => $e->getMessage(),
|
||||
]));
|
||||
|
@ -10,6 +10,7 @@ namespace App\Services\Logic\Trade;
|
||||
use App\Models\Trade as TradeModel;
|
||||
use App\Services\Logic\OrderTrait;
|
||||
use App\Services\Logic\Service as LogicService;
|
||||
use App\Validators\Order as OrderValidator;
|
||||
use App\Validators\Trade as TradeValidator;
|
||||
|
||||
class TradeCreate extends LogicService
|
||||
@ -23,6 +24,10 @@ class TradeCreate extends LogicService
|
||||
|
||||
$order = $this->checkOrderBySn($post['order_sn']);
|
||||
|
||||
$validator = new OrderValidator();
|
||||
|
||||
$validator->checkIfAllowPay($order);
|
||||
|
||||
$user = $this->getLoginUser();
|
||||
|
||||
$validator = new TradeValidator();
|
||||
|
@ -136,6 +136,13 @@ class Order extends Validator
|
||||
return $status;
|
||||
}
|
||||
|
||||
public function checkIfAllowPay(OrderModel $order)
|
||||
{
|
||||
if ($order->status != OrderModel::STATUS_PENDING) {
|
||||
throw new BadRequestException('order.pay_not_allowed');
|
||||
}
|
||||
}
|
||||
|
||||
public function checkIfAllowCancel(OrderModel $order)
|
||||
{
|
||||
if ($order->status != OrderModel::STATUS_PENDING) {
|
||||
|
@ -2086,7 +2086,7 @@
|
||||
}
|
||||
|
||||
.my-subscribe .qrcode {
|
||||
broder: 3px dashed #666;
|
||||
border: 3px dashed #666;
|
||||
margin: 30px auto;
|
||||
width: 160px;
|
||||
height: 160px;
|
||||
|
Loading…
x
Reference in New Issue
Block a user