using Library;
using MySystem.PxcModels;
using System;
using System.Linq;

namespace MySystem
{
    public class UserStoreChangeHelper
    {
        public readonly static UserStoreChangeHelper Instance = new UserStoreChangeHelper();
        private UserStoreChangeHelper()
        { }

        public string Start()
        {
            bool op = true;
            WebCMSEntities db = new WebCMSEntities();
            string result = "";
            int total = 0;
            while (op)
            {
                UserStoreChange PopData = new UserStoreChange();
                try
                {
                    //获取apserver待同步的数据,执行入库
                    PopData = RedisDbconn.Instance.RPop<UserStoreChange>("Pop:UserStoreChange");
                    if (PopData != null)
                    {
                        // UserStoreChange checkExist = db.UserStoreChange.FirstOrDefault(m => m.Id == PopData.Id);
                        // if (checkExist != null)
                        // {
                        //     checkExist = PopData;
                        // }
                        // else
                        // {
                            db.UserStoreChange.Add(PopData);
                        // }
                        if (total >= 20)
                        {
                            total = 0;
                            db.SaveChanges();
                        }
                        if (string.IsNullOrEmpty(result)) result = "success";
                    }
                    else
                    {
                        db.SaveChanges();
                        op = false;
                    }
                }
                catch (Exception ex)
                {
                    ErrorMsg msg = new ErrorMsg();
                    msg.Obj = PopData;
                    msg.Time = DateTime.Now;
                    msg.ErrorContent = ex.ToString();
                    function.WriteLog(Newtonsoft.Json.JsonConvert.SerializeObject(msg), "Pop:UserStoreChange:Error");
                    result = "有异常,请查看Pop:UserStoreChange:Error队列";
                }
            }
            db.Dispose();
            return result;
        }
    }
}