huangsijun
2025-09-22 a78c011de350b188afb03beb2f26a73f35f71986
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
<?php
 
namespace app\job\event;
 
use app\job\model\order\Order as OrderModel;
use app\job\model\order\OrderAdvance as OrderAdvanceModel;
use think\facade\Cache;
 
/**
 * 预售订单事件管理
 */
class AdvanceOrder
{
 
    // 应用id
    private $appId;
 
    /**
     * 执行函数
     */
    public function handle($app_id)
    {
        try {
            $cacheKey = "task_space_advance_order_task";
            if (!Cache::has($cacheKey)) {
                // 绑定订单模型
                $this->appId = $app_id;
                // 定金订单行为管理
                $this->front();
                // 未支付尾款订单自动关闭
                $this->order();
                // 未支付尾款订单退定金
                $this->return();
                Cache::set($cacheKey, time(), 10);
            }
        } catch (\Throwable $e) {
            log_write('ORDER_ADVANCE TASK : ' . $app_id . '__ ' . $e->getMessage(), 'task');
        }
        return true;
    }
 
    /**
     * 定金订单行为管理
     */
    private function front()
    {
        $OrderAdvanceModel = new OrderAdvanceModel();
        // 执行自动关闭
        $orderAdvanceIds = $OrderAdvanceModel->close();
        // 记录日志
        $this->dologs('frontClose', [
            'orderAdvanceIds' => json_encode($orderAdvanceIds),
        ]);
        return true;
    }
 
    /**
     * 未支付尾款订单自动关闭
     */
    private function order()
    {
        $OrderModel = new OrderModel();
        // 执行自动关闭
        $closeOrderIds = $OrderModel->close();
        // 记录日志
        $this->dologs('advanceClose', [
            'orderIds' => json_encode($closeOrderIds),
        ]);
        return true;
    }
 
    /**
     * 未支付尾款订单自动退定金
     */
    private function return()
    {
        $OrderAdvanceModel = new OrderAdvanceModel();
        // 执行自动关闭
        $closeOrderAdvanceIds = $OrderAdvanceModel->return();
        // 记录日志
        $this->dologs('advanceReturn', [
            'orderIds' => json_encode($closeOrderAdvanceIds),
        ]);
        return true;
    }
 
    /**
     * 记录日志
     */
    private function dologs($method, $params = [])
    {
        $value = 'behavior OrderAdvance --' . $method;
        foreach ($params as $key => $val)
            $value .= ' --' . $key . ' ' . $val;
        return log_write($value, 'task');
    }
 
}