liaoxujun@qq.com
2024-03-04 c8f9d5977cc950592f0ccfea01237eccde506350
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
/***********************************************************************
 *            Project: CoreCms
 *        ProjectName: 百分兵法管理系统                               
 *                Web: hhtp://chuanyin.com                     
 *             Author:                                        
 *              Email:                               
 *         CreateTime: 2021/7/10 22:41:46
 *        Description: 暂无
 ***********************************************************************/
 
 
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using CoreCms.Net.Configuration;
using CoreCms.Net.IServices;
using CoreCms.Net.Loging;
using CoreCms.Net.Model.Entities;
using InitQ.Abstractions;
using InitQ.Attributes;
using Newtonsoft.Json;
 
namespace CoreCms.Net.RedisMQ
{
    /// <summary>
    /// 订单退款处理
    /// </summary>
    public class RefundSubscribe : IRedisSubscribe
    {
 
        private readonly ICoreCmsOrderServices _orderServices;
        private readonly ICoreCmsBillRefundServices _billRefundServices;
        private readonly ISysTaskLogServices _taskLogServices;
 
 
        public RefundSubscribe(ICoreCmsOrderServices orderServices, ICoreCmsBillRefundServices billRefundServices, ISysTaskLogServices taskLogServices)
        {
            _orderServices = orderServices;
            _billRefundServices = billRefundServices;
            _taskLogServices = taskLogServices;
        }
 
        /// <summary>
        /// 订单退款处理
        /// </summary>
        /// <param name="msg"></param>
        /// <returns></returns>
        [Subscribe(RedisMessageQueueKey.RefundSubscribeQueue)]
        private async Task RefundSubscribeQueue(string msg)
        {
            try
            {
                var refundInfo = JsonConvert.DeserializeObject<CoreCmsBillRefund>(msg);
 
                //去退款
                var toRefundResult = await _billRefundServices.ToRefund(refundInfo.refundId, (int)GlobalEnumVars.BillRefundStatus.STATUS_REFUND);
 
                //插入退款日志
                var log = new SysTaskLog
                {
                    createTime = DateTime.Now,
                    isSuccess = toRefundResult.status,
                    name = "定时任务取消拼团订单退款日志",
                    parameters = JsonConvert.SerializeObject(toRefundResult)
                };
                await _taskLogServices.InsertAsync(log);
 
                //更新订单状态为已退款已完成
                await _orderServices.UpdateAsync(p => new CoreCmsOrder()
                {
                    payStatus = (int)GlobalEnumVars.OrderPayStatus.Refunded,
                    status = (int)GlobalEnumVars.OrderStatus.Complete
                }, p => p.orderId == refundInfo.sourceId);
 
                NLogUtil.WriteAll(NLog.LogLevel.Info, LogType.RedisMessageQueue, "订单退款处理-成功", msg);
            }
            catch (Exception ex)
            {
                NLogUtil.WriteAll(NLog.LogLevel.Error, LogType.RedisMessageQueue, "订单退款处理-异常", msg, ex);
                throw;
            }
            await Task.CompletedTask;
        }
 
 
    }
}