Ejemplo n.º 1
0
        public string RetailTraderLogin(string pRequest)
        {
            var rp = pRequest.DeserializeJSONTo <APIRequest <RetailTraderLoginRP> >();

            //string customerCode = rp.Parameters.CustomerCode;
            //if (string.IsNullOrEmpty(customerCode))
            //{
            //    throw new APIException("客户代码不能为空") { ErrorCode = 135 };
            //}

            if (rp.Parameters.RetailTraderLogin == null)
            {
                throw new APIException("缺少参数【RetailTraderLogin】或参数值为空")
                      {
                          ErrorCode = 135
                      };
            }
            if (rp.Parameters.RetailTraderPass == null)
            {
                throw new APIException("缺少参数【RetailTraderPass】或参数值为空")
                      {
                          ErrorCode = 135
                      };
            }
            // var loggingSessionInfo = Default.GetBSLoggingSession(rp.CustomerID, "1");

            //WMenuBLL menuServer = new WMenuBLL(Default.GetAPLoggingSession(""));
            //string customerId = menuServer.GetCustomerIDByCustomerCode(customerCode);

            //if (string.IsNullOrEmpty(customerId))
            //{
            //    throw new APIException("客户代码对应的客户不存在") { ErrorCode = Error_CustomerCode_NotExist };
            //}


            var bll2 = new RetailTraderBLL(Default.GetAPLoggingSession(""));//用空的登陆信息去查

            var ds = bll2.getRetailTraderInfoByLogin2(rp.Parameters.RetailTraderLogin, "", "");
            var retailTraderInfo = new RetailTraderInfo();


            var    rd         = new SaveRetailTraderRD();
            var    rsp        = new SuccessResponse <IAPIResponseData>(rd);
            string customerId = "";

            //判断账号是否存在
            if (ds != null && ds.Tables.Count > 0 && ds.Tables[0].Rows.Count > 0)
            {
                var tempDt = ds.Tables[0];
                retailTraderInfo = DataTableToObject.ConvertToObject <RetailTraderInfo>(tempDt.Rows[0]);//直接根据所需要的字段反序列化

                customerId = retailTraderInfo.CustomerId;
            }
            else
            {
                rsp.Message    = "登陆名不存在";
                rsp.ResultCode = 136;
                return(rsp.ToJSON());
            }



            var loggingSessionInfo = Default.GetBSLoggingSession(customerId, "1");
            var bll = new RetailTraderBLL(loggingSessionInfo);



            //获取分销商的信息,包括头像等loggingSessionInfo.ClientID
            ds = bll.getRetailTraderInfoByLogin(rp.Parameters.RetailTraderLogin, "", loggingSessionInfo.ClientID);
            retailTraderInfo = new RetailTraderInfo();
            //判断账号是否存在
            if (ds != null && ds.Tables.Count > 0 && ds.Tables[0].Rows.Count > 0)
            {
                var tempDt = ds.Tables[0];
                retailTraderInfo = DataTableToObject.ConvertToObject <RetailTraderInfo>(tempDt.Rows[0]);//直接根据所需要的字段反序列化
            }
            else
            {
                rsp.Message    = "登陆名不存在";
                rsp.ResultCode = 136;
                return(rsp.ToJSON());
            }
            //判断密码是否正确
            if (retailTraderInfo.RetailTraderPass != rp.Parameters.RetailTraderPass)
            {
                rsp.Message    = "登陆密码不正确";
                rsp.ResultCode = 136;
                return(rsp.ToJSON());
            }
            //判断密码是否正确
            //if (retailTraderInfo.Status != "1")
            //{
            //    rsp.Message = "该分销商账号已经被停用";
            //    rsp.ResultCode = 136;
            //    return rsp.ToJSON();
            //}


            //正确时返回分销商数据
            rd.RetailTraderInfo = retailTraderInfo;


            return(rsp.ToJSON());
        }
Ejemplo n.º 2
0
        public string GetRetailTraderByID(string pRequest)
        {
            var rp = pRequest.DeserializeJSONTo <APIRequest <RetailTraderLoginRP> >();

            if (rp.Parameters.RetailTraderID == null)
            {
                throw new APIException("缺少参数【RetailTraderID】或参数值为空")
                      {
                          ErrorCode = 135
                      };
            }

            var loggingSessionInfo = Default.GetBSLoggingSession(rp.CustomerID, "1");
            var bll = new RetailTraderBLL(loggingSessionInfo);
            var rd  = new SaveRetailTraderRD();

            var rsp = new SuccessResponse <IAPIResponseData>(rd);
            //获取分销商的信息,包括头像等loggingSessionInfo.ClientID
            var ds = bll.getRetailTraderInfoByLogin("", rp.Parameters.RetailTraderID, loggingSessionInfo.ClientID);
            var retailTraderInfo = new RetailTraderInfo();

            //判断账号是否存在
            if (ds != null && ds.Tables.Count > 0 && ds.Tables[0].Rows.Count > 0)
            {
                var tempDt = ds.Tables[0];
                retailTraderInfo = DataTableToObject.ConvertToObject <RetailTraderInfo>(tempDt.Rows[0]);//直接根据所需要的字段反序列化
            }



            //正确时返回分销商数据
            rd.RetailTraderInfo = retailTraderInfo;//分销商

            //获取奖励规则
            SysRetailRewardRuleEntity[] ruleList = null;
            SysRetailRewardRuleBLL      _SysRetailRewardRuleBLL = new SysRetailRewardRuleBLL(loggingSessionInfo);
            //先看该分销商自己是否有奖励规则
            SysRetailRewardRuleEntity en = new SysRetailRewardRuleEntity();

            en.IsTemplate     = 0;
            en.CooperateType  = retailTraderInfo.CooperateType;
            en.RetailTraderID = rp.Parameters.RetailTraderID;
            en.CustomerId     = rp.CustomerID;
            en.IsDelete       = 0;
            //获取奖励模板
            ruleList = _SysRetailRewardRuleBLL.QueryByEntity(en, null);


            //  SysRetailRewardRuleEntity en = new SysRetailRewardRuleEntity();
            if (ruleList == null || ruleList.Count() == 0)
            {
                SysRetailRewardRuleEntity en2 = new SysRetailRewardRuleEntity();
                en2.IsTemplate    = 1;
                en2.CooperateType = retailTraderInfo.CooperateType;
                en2.IsDelete      = 0;
                en2.CustomerId    = rp.CustomerID;                           //加上这个,否则多个客户的奖励规则一起取了
                //获取奖励模板
                ruleList = _SysRetailRewardRuleBLL.QueryByEntity(en2, null); //这里不能用en了,用en会包含之前的RetailTraderID属性了
            }

            StringBuilder sb = new StringBuilder("");

            if (ruleList != null || ruleList.Count() != 0)
            {
                for (int i = 0; i < ruleList.Count(); i++)
                {
                    if (ruleList[i].RetailTraderReward > 0)
                    {
                        sb.Append(ruleList[i].RewardTypeName);
                        int temp = (int)ruleList[i].RetailTraderReward;//判断一下小数点后面是不是0,如果是0,就不要了
                        if (ruleList[i].RetailTraderReward > temp)
                        {
                            sb.Append(ruleList[i].RetailTraderReward);
                        }
                        else
                        {
                            sb.Append(temp);
                        }
                        if (ruleList[i].AmountOrPercent == 1)
                        {
                            sb.Append("元");
                        }
                        else
                        {
                            sb.Append("%");
                        }
                        if (ruleList[i].RewardTypeCode == "AttentThreeMonth")
                        {
                            sb.Append("(不包含首笔交易)");
                        }
                        sb.Append(",");
                    }
                }
                if (sb.ToString() != "")
                {
                    sb.Replace(',', '。', sb.Length - 1, 1);
                }
            }
            else
            {
                if (retailTraderInfo.CooperateType == "TwoWay")
                {
                    sb.Append(retailTraderInfo.UnitName).Append("门店帮您发放优惠券,也可向您的门店带来潜在的顾客。 ");
                }
            }



            rd.RewardNotic = sb.ToString();//奖励规则说明



            return(rsp.ToJSON());
        }