123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301 |
- using System;
- using System.Collections.Generic;
- using System.Data;
- using System.Linq;
- using System.Threading;
- using MySystem.PxcModels;
- using Library;
- namespace MySystem
- {
-
-
-
- public class TimeOutPosChargeService
- {
- public readonly static TimeOutPosChargeService Instance = new TimeOutPosChargeService();
- private TimeOutPosChargeService()
- { }
- public void Start()
- {
- Thread th = new Thread(doSomething);
- th.IsBackground = true;
- th.Start();
- }
- public void doSomething()
- {
- while (true)
- {
- if (DateTime.Now.Hour < 9)
- {
- try
- {
- string check = function.ReadInstance("/TimeOutPosCharge/check" + DateTime.Now.ToString("yyyy-MM-dd") + ".txt");
- if (string.IsNullOrEmpty(check))
- {
- function.WritePage("/TimeOutPosCharge/", "check" + DateTime.Now.ToString("yyyy-MM-dd") + ".txt", DateTime.Now.ToString("HH:mm:ss"));
- WebCMSEntities db = new WebCMSEntities();
- var date = DateTime.Now.AddDays(-60).ToString("yyyy-MM-dd 00:00:00");
- var time = DateTime.Parse(date);
- DataTable dt = CustomerSqlConn.dtable("SELECT BuyUserId FROM PosMachinesTwo WHERE `Status`>-1 AND BuyUserId>0 AND BindingState=0 AND ActivationState=0 AND ScanQrTrade=0 AND RecycEndDate <'" + date + "' GROUP BY BuyUserId", MysqlConn.SqlConnStr);
- var query = db.PosMachinesTwo.Where(m => m.Status > -1 && m.BuyUserId > 0 && m.BindingState == 0 && m.ActivationState == 0 && m.ScanQrTrade == 0 && m.RecycEndDate < time).ToList();
- var brandInfo = db.KqProducts.ToList();
- foreach (DataRow item in dt.Rows)
- {
- int BuyUserId = int.Parse(item["BuyUserId"].ToString());
- var userAccount = db.UserAccount.FirstOrDefault(m => m.Id == BuyUserId);
- if (userAccount == null)
- {
- userAccount = db.UserAccount.Add(new UserAccount()
- {
- Id = BuyUserId,
- UserId = BuyUserId,
- }).Entity;
- db.SaveChanges();
- }
- var posInfo = query.Where(m => m.BuyUserId == BuyUserId);
- var amount = 0;
- foreach (var pos in posInfo)
- {
- var poss = db.PosMachinesTwo.FirstOrDefault(m => m.Id == pos.Id) ?? new PosMachinesTwo();
- poss.ScanQrTrade = 999;
- var Brand = brandInfo.FirstOrDefault(m => m.Id == pos.BrandId);
- if (Brand.Name.Contains("电签"))
- {
- amount = 200;
- }
- if (Brand.Name.Contains("大POS"))
- {
- amount = 300;
- }
- userAccount.ToChargeAmount += amount;
- var toChargeBackRecord = db.ToChargeBackRecord.Add(new ToChargeBackRecord
- {
- CreateDate = DateTime.Now,
- UserId = BuyUserId,
- ChargeAmount = amount,
- ChargeType = 124,
- Remark = pos.PosSn,
- }).Entity;
- }
- }
- db.SaveChanges();
- DoChargeAmount(db);
- }
- }
- catch (Exception ex)
- {
- function.WriteLog(DateTime.Now.ToString() + ":" + ex.ToString(), "过期机具执行扣费异常");
- }
- }
- Thread.Sleep(1000);
- }
- }
- public void StartDoChargeAmount()
- {
- Thread th = new Thread(StartDoChargeAmountReady);
- th.IsBackground = true;
- th.Start();
- }
- public void StartDoChargeAmountReady()
- {
- while (true)
- {
- WebCMSEntities db = new WebCMSEntities();
- DoChargeAmount(db);
- db.Dispose();
- Thread.Sleep(60000);
- }
- }
- public void ListenChargeAmount()
- {
- Thread th = new Thread(ListenChargeAmountReady);
- th.IsBackground = true;
- th.Start();
- }
- public void ListenChargeAmountReady()
- {
- while (true)
- {
- string content = RedisDbconn.Instance.RPop<string>("DoChargeAmountQueue");
- if (!string.IsNullOrEmpty(content))
- {
- WebCMSEntities db = new WebCMSEntities();
- DoChargeAmount(db, int.Parse(function.CheckInt(content)));
- db.Dispose();
- }
- }
- }
- public void DoChargeAmount(WebCMSEntities db, int UserId = 0)
- {
- MySystem.OpModels.WebCMSEntities opdb = new MySystem.OpModels.WebCMSEntities();
- IQueryable<ToChargeBackRecord> list = db.ToChargeBackRecord.Where(m => m.Status == 0);
- if (UserId > 0)
- {
- list = list.Where(m => m.UserId == UserId);
- }
- var info = list.ToList();
- foreach (var items in info)
- {
- function.WriteLog(DateTime.Now.ToString(), "扣款监听日志");
- function.WriteLog(items.UserId.ToString(), "扣款监听日志");
- var userAccount = db.UserAccount.FirstOrDefault(m => m.Id == items.UserId) ?? new UserAccount();
- var record = info.FirstOrDefault(m => m.Id == items.Id);
- var check = false;
- function.WriteLog("BalanceAmount:" + userAccount.BalanceAmount + ";ChargeAmount:" + record.ChargeAmount + ";", "扣款监听日志");
- function.WriteLog("in", "扣款监听日志");
- var ChangeType = 0;
- var Remark = "";
- if (record.ChargeType == 124)
- {
- ChangeType = 124;
- Remark = "扣机具货款";
- }
- if (record.ChargeType == 1)
- {
- ChangeType = 202;
-
- Remark = items.Remark;
- }
- if (record.ChargeType == 2)
- {
- ChangeType = 201;
-
- Remark = items.Remark;
- }
- if (record.Kind < 2)
- {
- if (record.Kind == 0)
- {
- if (userAccount.BalanceAmount >= record.ChargeAmount)
- {
- var userAccountRecord = db.UserAccountRecord.Add(new UserAccountRecord
- {
- CreateDate = DateTime.Now,
- UserId = items.UserId,
- BeforeBalanceAmount = userAccount.BalanceAmount,
- AfterBalanceAmount = userAccount.BalanceAmount - record.ChargeAmount,
- ChangeAmount = record.ChargeAmount,
- ChangeType = ChangeType,
- Remark = Remark,
- }).Entity;
- function.WriteLog("ToChargeAmount:" + userAccount.ToChargeAmount + ";ChargeAmount:" + record.ChargeAmount + ";", "扣款监听日志");
- if (userAccount.ToChargeAmount >= record.ChargeAmount)
- {
- function.WriteLog("ok", "扣款监听日志");
- userAccount.ToChargeAmount -= record.ChargeAmount;
- }
- userAccount.BalanceAmount -= record.ChargeAmount;
- check = true;
- }
- }
- if (record.Kind == 1)
- {
- if (userAccount.LeaderBalanceAmount >= record.ChargeAmount)
- {
-
-
-
-
-
-
-
-
-
-
- var leaderReserveRecord = db.LeaderReserveRecord.Add(new LeaderReserveRecord()
- {
- CreateDate = DateTime.Now,
- Sort = 12,
- UserId = items.UserId,
- Remark = "盟主预扣款",
- SeoDescription = items.SeoDescription,
- ChangeType = 2,
- BeforeAmt = userAccount.LeaderBalanceAmount,
- AfterAmt = userAccount.LeaderBalanceAmount - record.ChargeAmount,
- ChangeAmt = record.ChargeAmount,
- TradeDate = DateTime.Now.ToString("yyyyMMdd"),
- TradeMonth = DateTime.Now.ToString("yyyyMM"),
- }).Entity;
- function.WriteLog("LeaderToChargeAmount:" + userAccount.LeaderToChargeAmount + ";ChargeAmount:" + record.ChargeAmount + ";", "扣款监听日志");
- if (userAccount.LeaderToChargeAmount >= record.ChargeAmount)
- {
- function.WriteLog("ok", "扣款监听日志");
- userAccount.LeaderToChargeAmount -= record.ChargeAmount;
- }
- userAccount.LeaderBalanceAmount -= record.ChargeAmount;
- check = true;
- }
- }
- }
- else
- {
- var opUserAccount = opdb.UserAccount.FirstOrDefault(m => m.Id == items.UserId) ?? new MySystem.OpModels.UserAccount();
- if (record.Kind == 2)
- {
- if (opUserAccount.ValidForGetAmount >= record.ChargeAmount)
- {
- var amoutRecord = opdb.AmountRecord.Add(new MySystem.OpModels.AmountRecord
- {
- CreateDate = DateTime.Now,
- UserId = items.UserId,
- SeoDescription = "运营中心预扣款",
- UseAmount = record.ChargeAmount,
- OperateType = 2,
- BeforeAmount = opUserAccount.ValidAmount + opUserAccount.TotalAmt + opUserAccount.ValidForGetAmount,
- AfterAmount = opUserAccount.ValidAmount + opUserAccount.TotalAmt + opUserAccount.ValidForGetAmount - record.ChargeAmount,
- }).Entity;
- function.WriteLog("OperateToChargeAmount:" + userAccount.OperateToChargeAmount + ";ChargeAmount:" + record.ChargeAmount + ";", "扣款监听日志");
- if (userAccount.OperateToChargeAmount >= record.ChargeAmount)
- {
- function.WriteLog("ok", "扣款监听日志");
- userAccount.OperateToChargeAmount -= record.ChargeAmount;
- }
- opUserAccount.ValidForGetAmount -= record.ChargeAmount;
- amoutRecord.AfterValidForGetAmount = opUserAccount.ValidForGetAmount;
- amoutRecord.AfterTotalAmt = opUserAccount.TotalAmt;
- amoutRecord.AfterValidAmount = opUserAccount.ValidAmount;
- check = true;
- }
- }
- }
- if (check)
- {
- record.Status = 1;
- record.UpdateDate = DateTime.Now;
- if (record.ChargeType == 2)
- {
- var toChargeBackRecordSub = db.ToChargeBackRecordSub.FirstOrDefault(m => m.Id == record.Sort) ?? new ToChargeBackRecordSub();
- var toChargeByStage = db.ToChargeByStage.FirstOrDefault(m => m.Id == toChargeBackRecordSub.ParentId && m.TimeNumber > m.QueryCount) ?? new ToChargeByStage();
- toChargeBackRecordSub.Status = 1;
- toChargeByStage.QueryCount += 1;
- toChargeByStage.ChargeAmount += toChargeBackRecordSub.ChargeAmount;
- if (toChargeByStage.TimeNumber == toChargeByStage.QueryCount)
- {
- toChargeByStage.Status = 1;
- }
- }
- }
- function.WriteLog("\n\n", "扣款监听日志");
- }
- db.SaveChanges();
- opdb.SaveChanges();
- }
- }
- }
|