PayLogService.php 8.0 KB
Newer Older
D
v1.2.0  
devil_gong 已提交
1 2 3 4
<?php
// +----------------------------------------------------------------------
// | ShopXO 国内领先企业级B2C免费开源电商系统
// +----------------------------------------------------------------------
D
devil_gong 已提交
5
// | Copyright (c) 2011~2019 http://shopxo.net All rights reserved.
D
v1.2.0  
devil_gong 已提交
6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23
// +----------------------------------------------------------------------
// | Licensed ( http://www.apache.org/licenses/LICENSE-2.0 )
// +----------------------------------------------------------------------
// | Author: Devil
// +----------------------------------------------------------------------
namespace app\service;

use think\Db;

/**
 * 支付日志服务层
 * @author   Devil
 * @blog     http://gong.gg/
 * @version  0.0.1
 * @datetime 2016-12-01T21:51:08+0800
 */
class PayLogService
{
D
devil_gong 已提交
24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47
    /**
     * 支付日志添加
     * @author   Devil
     * @blog     http://gong.gg/
     * @version  1.0.0
     * @datetime 2019-05-07T00:57:36+0800
     * @param   [array]             $params         [输入参数]
     * @param   [int]               $user_id        [用户id]
     * @param   [int]               $order_id       [业务订单id]
     * @param   [float]             $total_price    [业务订单实际金额]
     * @param   [string]            $trade_no       [支付平台交易号]
     * @param   [string]            $buyer_user     [支付平台用户帐号]
     * @param   [float]             $pay_price      [支付金额]
     * @param   [string]            $subject        [业务订单名称]
     * @param   [string]            $payment        [支付方式标记]
     * @param   [string]            $payment_name   [支付方式名称]
     * @param   [int]               $business_type  [业务类型(0默认, 1订单, 2充值, ...)]
     * @return  [boolean]                           [成功true, 失败false]
     */
    public static function PayLogInsert($params = [])
    {
        $data = [
            'user_id'           => isset($params['user_id']) ? intval($params['user_id']) : 0,
            'order_id'          => isset($params['order_id']) ? intval($params['order_id']) : 0,
D
devil_gong 已提交
48
            'total_price'       => isset($params['total_price']) ? PriceNumberFormat($params['total_price']) : 0.00,
D
devil_gong 已提交
49
            'trade_no'          => isset($params['trade_no']) ? $params['trade_no'] : '',
D
devil_gong 已提交
50
            'buyer_user'        => isset($params['buyer_user']) ? $params['buyer_user'] : '',
D
devil_gong 已提交
51
            'pay_price'         => isset($params['pay_price']) ? PriceNumberFormat($params['pay_price']) : 0.00,
D
devil_gong 已提交
52 53 54
            'subject'           => isset($params['subject']) ? $params['subject'] : '',
            'payment'           => isset($params['payment']) ? $params['payment'] : '',
            'payment_name'      => isset($params['payment_name']) ? $params['payment_name'] : '',
D
devil_gong 已提交
55 56 57 58 59 60
            'business_type'     => isset($params['business_type']) ? intval($params['business_type']) : 0,
            'add_time'          => time(),
        ];
        return Db::name('PayLog')->insertGetId($data) > 0;
    }

D
v1.2.0  
devil_gong 已提交
61 62 63 64 65 66 67 68
    /**
     * 获取支付日志类型
     * @author   Devil
     * @blog     http://gong.gg/
     * @version  1.0.0
     * @datetime 2018-12-23T02:22:03+0800
     * @param   [array]          $params [输入参数]
     */
69
    public static function PayLogTypeList($params = [])
D
v1.2.0  
devil_gong 已提交
70
    {
71
        $data = Db::name('PayLog')->field('any_value(payment) AS id, any_value(payment_name) AS name')->group('payment')->select();
D
v1.2.0  
devil_gong 已提交
72 73
        return DataReturn('处理成功', 0, $data);
    }
G
1.3.0  
gongfuxiang 已提交
74
    
D
v1.2.0  
devil_gong 已提交
75 76 77 78 79 80 81 82 83
    /**
     * 后台管理员列表
     * @author   Devil
     * @blog    http://gong.gg/
     * @version 1.0.0
     * @date    2018-09-29
     * @desc    description
     * @param   [array]          $params [输入参数]
     */
84
    public static function AdminPayLogList($params = [])
D
v1.2.0  
devil_gong 已提交
85 86 87 88
    {
        $where = empty($params['where']) ? [] : $params['where'];
        $m = isset($params['m']) ? intval($params['m']) : 0;
        $n = isset($params['n']) ? intval($params['n']) : 10;
89
        $field = 'p.*,u.username,u.nickname,u.mobile,u.email,u.gender';
D
v1.2.0  
devil_gong 已提交
90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114
        $order_by = empty($params['order_by']) ? 'p.id desc' : $params['order_by'];

        // 获取数据列表
        $data = Db::name('PayLog')->alias('p')->join(['__USER__'=>'u'], 'u.id=p.user_id')->where($where)->field($field)->limit($m, $n)->order($order_by)->select();
        if(!empty($data))
        {
            $common_business_type_list = lang('common_business_type_list');
            $common_gender_list = lang('common_gender_list');
            foreach($data as &$v)
            {
                // 业务类型
                $v['business_type_name'] = $common_business_type_list[$v['business_type']]['name'];

                // 性别
                $v['gender_text'] = $common_gender_list[$v['gender']]['name'];

                // 时间
                $v['add_time_time'] = date('Y-m-d H:i:s', $v['add_time']);
                $v['add_time_date'] = date('Y-m-d', $v['add_time']);
            }
        }
        return DataReturn('处理成功', 0, $data);
    }

    /**
D
devil_gong 已提交
115
     * 总数
D
v1.2.0  
devil_gong 已提交
116 117 118 119 120 121 122
     * @author   Devil
     * @blog    http://gong.gg/
     * @version 1.0.0
     * @date    2018-09-29
     * @desc    description
     * @param   [array]          $where [条件]
     */
123
    public static function AdminPayLogTotal($where = [])
D
v1.2.0  
devil_gong 已提交
124 125 126 127 128
    {
        return (int) Db::name('PayLog')->alias('p')->join(['__USER__'=>'u'], 'u.id=p.user_id')->where($where)->count();
    }

    /**
D
devil_gong 已提交
129
     * 列表条件
D
v1.2.0  
devil_gong 已提交
130 131 132 133 134 135 136
     * @author   Devil
     * @blog    http://gong.gg/
     * @version 1.0.0
     * @date    2018-09-29
     * @desc    description
     * @param   [array]          $params [输入参数]
     */
137
    public static function AdminPayLogListWhere($params = [])
D
v1.2.0  
devil_gong 已提交
138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163
    {
        $where = [];
        
        // 关键字
        if(!empty($params['keywords']))
        {
            $where[] = ['p.trade_no|u.username|u.nickname|u.mobile', 'like', '%'.$params['keywords'].'%'];
        }

        // 是否更多条件
        if(isset($params['is_more']) && $params['is_more'] == 1)
        {
            // 等值
            if(isset($params['business_type']) && $params['business_type'] > -1)
            {
                $where[] = ['p.business_type', '=', intval($params['business_type'])];
            }
            if(!empty($params['pay_type']))
            {
                $where[] = ['p.payment', '=', $params['pay_type']];
            }
            if(isset($params['gender']) && $params['gender'] > -1)
            {
                $where[] = ['u.gender', '=', intval($params['gender'])];
            }

G
gongfuxiang 已提交
164 165 166 167 168 169 170 171 172
            if(!empty($params['price_start']))
            {
                $where[] = ['p.pay_price', '>', PriceNumberFormat($params['price_start'])];
            }
            if(!empty($params['price_end']))
            {
                $where[] = ['p.pay_price', '<', PriceNumberFormat($params['price_end'])];
            }

D
v1.2.0  
devil_gong 已提交
173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194
            if(!empty($params['time_start']))
            {
                $where[] = ['p.add_time', '>', strtotime($params['time_start'])];
            }
            if(!empty($params['time_end']))
            {
                $where[] = ['p.add_time', '<', strtotime($params['time_end'])];
            }
        }

        return $where;
    }

    /**
     * 删除
     * @author   Devil
     * @blog    http://gong.gg/
     * @version 1.0.0
     * @date    2018-12-18
     * @desc    description
     * @param   [array]          $params [输入参数]
     */
195
    public static function PayLogDelete($params = [])
D
v1.2.0  
devil_gong 已提交
196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220
    {
        // 请求参数
        $p = [
            [
                'checked_type'      => 'empty',
                'key_name'          => 'id',
                'error_msg'         => '操作id有误',
            ],
        ];
        $ret = ParamsChecked($params, $p);
        if($ret !== true)
        {
            return DataReturn($ret, -1);
        }

        // 删除操作
        if(Db::name('PayLog')->where(['id'=>$params['id']])->delete())
        {
            return DataReturn('删除成功');
        }

        return DataReturn('删除失败或资源不存在', -100);
    }
}
?>