// ใช้สำหรับตรวจสอบเลขที่ใบรับเงินชั่วคราว กับเลขที่ใบคำขอเอาประกันหรือเลขที่กรมธรรม์ว่าเคยถูกใช้ไปแล้วครบจำนวนครั้งที่กำหนดหรือยัง ถ้าพบว่าเคยใช้ไปแล้วจะไม่สามารถนำไปใช้งานได้อีก
    // 20150527: ปรับใช้ class รองรับการตรวจสอบว่าใช้เลขที่ใบรับเงินชั่วคราวนี้ได้อีกกี่ครั้ง
    private CheckTemporaryReceiptNumberAndNumberToPayInSqlIsUsedExceedLimit_Result CheckTemporaryReceiptNumberAndNumberToPayInSqlIsUsedExceedLimit(string temporaryReceiptNumber, string numberToPay)
    {
        CheckTemporaryReceiptNumberAndNumberToPayInSqlIsUsedExceedLimit_Result obj = new CheckTemporaryReceiptNumberAndNumberToPayInSqlIsUsedExceedLimit_Result();

        int limit = 2;

        using (var dbContext = new DAL.MTL_mPOSEntities())
        {
            var tr = from t in dbContext.TemporaryReceiptUsingLog
                     where t.TemporaryReceiptNumber == temporaryReceiptNumber.Trim()
                     select t;

            bool temporaryReceiptNumberHasEqualOrGreaterThanLimit = false;
            bool numberToPayIsEqualToPayToNumber = false;

            if (tr.Count() >= limit)
            {
                temporaryReceiptNumberHasEqualOrGreaterThanLimit = true;
            }

            foreach (var item in tr)
            {
                numberToPayIsEqualToPayToNumber = item.PayForNumber.Trim() == numberToPay.Trim() ? true : false;

                if (numberToPayIsEqualToPayToNumber == false)
                {
                    break;
                }
            }

            // ตรวจสอบว่าถูกต้อง หรือเกินจำนวนครั้งที่กำหนดหรือยัง
            if (tr.Count() == null || tr.Count() == 0)
            {
                //return false; // กรณีเลขที่ใบรับเงินชั่วคราวนี้ยังไม่เคยถูกใช้เลย จะ return ให้เป็นว่ายังไม่เกินจำนวนที่กำหนด
                obj.Result = false; // กรณีเลขที่ใบรับเงินชั่วคราวนี้ยังไม่เคยถูกใช้เลย จะ return ให้เป็นว่ายังไม่เกินจำนวนที่กำหนด
                return obj;
            }
            else if (temporaryReceiptNumberHasEqualOrGreaterThanLimit == true) // กรณีเลขที่ใบรับเงินชั่วคราวมีมากกว่าหรือเท่ากับจำนวนที่กำหนดไว้แล้ว จะ return ให้เป็นว่าเกินจำนวนที่กำหนดแล้ว
            {
                //return true;
                obj.Result = true;
                return obj;
            }
            else if (numberToPayIsEqualToPayToNumber == false) // กรณีเลขที่ใบคำขอเอาประกันหรือเลขที่กรมธรรม์ที่เคยใช้คู่กับเลขที่ใบรับเงินชั่วคราวนี้ไปแล้ว ไม่ตรงกับเลขที่ใบคำขอเอาประกันหรือเลขที่กรมธรรม์ที่ส่งร้องขอเข้ามาใหม่ จะ return ให้เป็นว่าเกินจำนวนที่กำหนดแล้ว
            {
                //return true;
                obj.Result = true;
                return obj;
            }
            else
            {
                var trn = from t in dbContext.TemporaryReceiptUsingLog
                          where t.TemporaryReceiptNumber == temporaryReceiptNumber.Trim() && t.PayForNumber == numberToPay.Trim()
                          select t;

                DateTime trnLogDateTime = System.DateTime.Now;

                // วนลูปเอา LogDateTime ของรายการสุดท้าย (เลขที่ใบรับเงินชั่วคราวที่ถูกใช้ครั้งล่าสุด) มาเก็บไว้ที่ตัวแปร trnLogDateTime
                foreach (var item in trn)
                {
                    trnLogDateTime = (DateTime)item.LogDateTime;
                }

                if (trn.Count() >= limit)
                {
                    //return true; // กรณีเลขที่ใบรับเงินชั่วคราว กับเลขที่ใบคำขอเอาประกันหรือเลขที่กรมธรรม์ (เลขใดเลขหนึ่ง) ถูกใช้ครบจำนวนครั้งที่กำหนด จะ return ให้เป็นว่าเกินจำนวนที่กำหนดแล้ว
                    obj.Result = true; // กรณีเลขที่ใบรับเงินชั่วคราว กับเลขที่ใบคำขอเอาประกันหรือเลขที่กรมธรรม์ (เลขใดเลขหนึ่ง) ถูกใช้ครบจำนวนครั้งที่กำหนด จะ return ให้เป็นว่าเกินจำนวนที่กำหนดแล้ว
                    return obj;
                }
                else if (trnLogDateTime.Date != System.DateTime.Now.Date)
                {
                    //return true; // กรณีเลขที่ใบรับเงินชั่วคราว กับเลขที่ใบคำขอเอาประกันหรือเลขที่กรมธรรม์ (เลขใดเลขหนึ่ง) ถูกใช้ยังไม่ครบจำนวนครั้งที่กำหนด และครั้งที่ถูกใช้ล่าสุดไม่ใช่วันเดียวกับวันปัจจุบัน จะ return ให้เป็นว่าเกินจำนวนที่กำหนดแล้ว
                    obj.Result = true; // กรณีเลขที่ใบรับเงินชั่วคราว กับเลขที่ใบคำขอเอาประกันหรือเลขที่กรมธรรม์ (เลขใดเลขหนึ่ง) ถูกใช้ยังไม่ครบจำนวนครั้งที่กำหนด และครั้งที่ถูกใช้ล่าสุดไม่ใช่วันเดียวกับวันปัจจุบัน จะ return ให้เป็นว่าเกินจำนวนที่กำหนดแล้ว
                    return obj;
                }
                else
                {
                    //return false; // กรณีเลขที่ใบรับเงินชั่วคราว กับเลขที่ใบคำขอเอาประกันหรือเลขที่กรมธรรม์ (เลขใดเลขหนึ่ง) ถูกใช้ยังไม่ครบจำนวนครั้งที่กำหนด จะ return ให้เป็นว่ายังไม่เกินจำนวนที่กำหนด
                    obj.Result = false; // กรณีเลขที่ใบรับเงินชั่วคราว กับเลขที่ใบคำขอเอาประกันหรือเลขที่กรมธรรม์ (เลขใดเลขหนึ่ง) ถูกใช้ยังไม่ครบจำนวนครั้งที่กำหนด จะ return ให้เป็นว่ายังไม่เกินจำนวนที่กำหนด
                    obj.Message = "1";
                    return obj;
                }
            }
        }
    }
    // ใช้สำหรับตรวจสอบเลขที่ใบรับเงินชั่วคราวว่าเคยถูกใช้ไปแล้วหรือยัง ถ้าพบว่าเคยใช้ไปแล้วจะไม่สามารถนำไปใช้งานได้อีก
    private bool CheckTemporaryReceiptNumberInSqlIsUsed(string temporaryReceiptNumber)
    {
        using (var dbContext = new DAL.MTL_mPOSEntities())
        {
            var tr = from t in dbContext.TemporaryReceiptUsingLog
                     where t.TemporaryReceiptNumber == temporaryReceiptNumber.Trim()
                     select t;

            if (tr.Count() >= 1)
            {
                return true;
            }
            else
            {
                return false;
            }
        }
    }
    public string AddTemporaryReceiptNumberToUsingLog(string partnerUsername, string partnerPassword, string temporaryReceiptNumber, string temporaryReceiptDate, string payFor, string payForNumber, string payAmount, string agentNumber)
    {
        string result = "";
        RefRunningTBBLL runningobj = new RefRunningTBBLL();
        this.refnum = runningobj.AddRefRunningTBAndReturn();
        WSLogBLL logobj = new WSLogBLL();
        string methodName = "AddTemporaryReceiptNumberToUsingLog";

        try
        {
            if (partnerUsername == "" || partnerPassword == "" || temporaryReceiptNumber == "" || temporaryReceiptDate == "" || payFor == "" || payForNumber == "" || payAmount == "" || agentNumber == "")
            {
                this.partnerName = partnerUsername;
                // LogRequest: Insert Log Request
                logobj.AddWSLog(this.partnerName, this.ipaddress, "Request", this.webserviceName, methodName, partnerUsername + "|" + temporaryReceiptNumber + "|" + temporaryReceiptDate + "|" + payFor + "|" + payForNumber + "|" + payAmount + "|" + agentNumber, this.refnum);

                result = "notcomplete_กรุณาระบุข้อมูลให้ครบถ้วน";
            }
            else if (temporaryReceiptNumber.Length != 12 || !MTL.Utils.ThisWeb.CheckIsNumeric(temporaryReceiptNumber))
            {
                this.partnerName = partnerUsername;
                // LogRequest: Insert Log Request
                logobj.AddWSLog(this.partnerName, this.ipaddress, "Request", this.webserviceName, methodName, partnerUsername + "|" + temporaryReceiptNumber + "|" + temporaryReceiptDate + "|" + payFor + "|" + payForNumber + "|" + payAmount + "|" + agentNumber, this.refnum);

                result = "notconmplete_กรุณาระบุเลขที่ใบรับเงินชั่วคราวให้ถูกต้อง";
            }
            else if (payForNumber.Length < 10 || payForNumber.Length > 11 || !MTL.Utils.ThisWeb.CheckIsNumeric(payForNumber))
            {
                this.partnerName = partnerUsername;
                // LogRequest: Insert Log Request
                logobj.AddWSLog(this.partnerName, this.ipaddress, "Request", this.webserviceName, methodName, partnerUsername + "|" + temporaryReceiptNumber + "|" + temporaryReceiptDate + "|" + payFor + "|" + payForNumber + "|" + payAmount + "|" + agentNumber, this.refnum);

                result = "notcomplete_กรุณาระบุเลขที่กรมธรรม์ หรือเลขที่ใบคำขอเอาประกันภัยให้ถูกต้อง";
            }
            else if (agentNumber.Length != 6 || !MTL.Utils.ThisWeb.CheckIsNumeric(agentNumber))
            {
                this.partnerName = partnerUsername;
                // LogRequest: Insert Log Request
                logobj.AddWSLog(this.partnerName, this.ipaddress, "Request", this.webserviceName, methodName, partnerUsername + "|" + temporaryReceiptNumber + "|" + temporaryReceiptDate + "|" + payFor + "|" + payForNumber + "|" + payAmount + "|" + agentNumber, this.refnum);

                result = "notcomplete_กรุณาระบุเลขที่ตัวแทนให้ถูกต้อง";
            }
            else
            {
                // พิสูจน์ตัวตนของพันธมิตรก่อนที่จะให้ใช้งานจริง
                NETWS_ForPartnerAuthenticationChecking.CheckPartnerAuthentication_Result pacobj = CheckPartnerAuthenticationReturnDetail(partnerUsername, partnerPassword, this.ipaddress);
                if (pacobj.Result.Trim().ToLower() == "passed")
                {
                    this.partnerName = pacobj.PartnerName;
                    // LogRequest: Insert Log Request
                    logobj.AddWSLog(this.partnerName, this.ipaddress, "Request", this.webserviceName, methodName, partnerUsername + "|" + temporaryReceiptNumber + "|" + temporaryReceiptDate + "|" + payFor + "|" + payForNumber + "|" + payAmount + "|" + agentNumber, this.refnum);

                    // ตรวจสอบเลขที่ใบรับเงินชั่วคราว
                    MTL.Utils.ThisWeb thisweb = new MTL.Utils.ThisWeb();
                    if (thisweb.CheckIsValidTemporaryBillNumber(temporaryReceiptNumber))
                    {
                        // ตรวจสอบเลขที่ใบรับเงินชั่วคราวว่าได้ถูกบันทึกว่าตัวแทนส่งงานเข้ามายังบริษัทฯ (เก็บอยู่ใน AS400) แล้วหรือยัง หรือสามารถนำมาใช้ได้หรือไม่ ผ่าน OSB EAppService
                        CheckTemporaryReceiptNumberInAs400IsCanUse_Result checkResult = new CheckTemporaryReceiptNumberInAs400IsCanUse_Result();
                        // 20150129: Comment ไว้เพื่อทดสอบไม่ต้องใช้ค่าจาก Web Services ว่าน
                        checkResult = this.CheckTemporaryReceiptNumberInAs400IsCanUse(temporaryReceiptNumber);
                        // 20150129: สำหรับทดสอบโดยไม่ต้องใช้ค่าจาก Web Services ว่าน
                        //checkResult.Result = "testja";

                        if (checkResult.Result == "false")
                        {
                            result = "notcomplete_" + checkResult.ErrorMessage.Trim();
                        }
                        else
                        {
                            // 20150129: ตรวจสอบเลขที่ใบรับเงินชั่วคราว กับเลขที่ใบคำขอเอาประกันหรือเลขที่กรมธรรม์ว่าเคยถูกใช้ไปแล้วครบจำนวนครั้งที่กำหนดหรือยัง ถ้าพบว่าเคยใช้ไปแล้วจะไม่สามารถนำไปใช้งานได้อีก
                            // 20150527: ปรับใช้ class รองรับการตรวจสอบว่าใช้เลขที่ใบรับเงินชั่วคราวนี้ได้อีกกี่ครั้ง
                            CheckTemporaryReceiptNumberAndNumberToPayInSqlIsUsedExceedLimit_Result checkTempAndNumberInSqlObj = new CheckTemporaryReceiptNumberAndNumberToPayInSqlIsUsedExceedLimit_Result();
                            checkTempAndNumberInSqlObj = this.CheckTemporaryReceiptNumberAndNumberToPayInSqlIsUsedExceedLimit(temporaryReceiptNumber, payForNumber);
                            if (checkTempAndNumberInSqlObj.Result == true)
                            {
                                result = "notcomplete_เลขที่ใบรับเงินชั่วคราวนี้ถูกนำไปใช้แล้ว";
                            }
                            else
                            {
                                using (var dbContext = new DAL.MTL_mPOSEntities())
                                {
                                    DAL.TemporaryReceiptUsingLog tempReceipt = new DAL.TemporaryReceiptUsingLog();
                                    tempReceipt.TemporaryReceiptNumber = temporaryReceiptNumber.Trim();

                                    CovertToDateResult dateObj = new CovertToDateResult();
                                    dateObj = ConvertToDate(temporaryReceiptDate);
                                    DateTime tempReceiptDate = new DateTime(dateObj.Year, dateObj.Month, dateObj.Day);
                                    tempReceipt.TemporaryReceiptDate = tempReceiptDate;

                                    tempReceipt.PayFor = payFor.Trim();
                                    tempReceipt.PayForNumber = payForNumber.Trim();
                                    tempReceipt.PayAmount = payAmount.Trim();
                                    tempReceipt.AgentNumber = agentNumber.Trim();
                                    tempReceipt.LogDateTime = DateTime.Now;

                                    dbContext.AddToTemporaryReceiptUsingLog(tempReceipt);
                                    dbContext.SaveChanges();

                                    result = "completed";
                                }
                            }
                        }
                    }
                    else
                    {
                        result = "notcomplete_เลขที่ใบรับเงินชั่วคราวไม่ถูกต้อง";
                    }
                }
                else
                {
                    this.partnerName = pacobj.PartnerName;
                    // LogRequest: Insert Log Request
                    logobj.AddWSLog(this.partnerName, this.ipaddress, "Request", this.webserviceName, methodName, partnerUsername + "|" + temporaryReceiptNumber + "|" + temporaryReceiptDate + "|" + payFor + "|" + payForNumber + "|" + payAmount + "|" + agentNumber, this.refnum);

                    result = pacobj.Result.Trim().Replace("notpass_", "notcomplete_");
                }
            }

            // LogResponse: Insert Log Response
            logobj.AddWSLog(this.partnerName, this.ipaddress, "Response", this.webserviceName, methodName, result + "|" + temporaryReceiptNumber + "|" + temporaryReceiptDate + "|" + payFor + "|" + payForNumber + "|" + payAmount + "|" + agentNumber, this.refnum);

            return result;
        }
        catch (Exception ex)
        {
            result = "notcomplete_" + ex.Message.ToString();

            // LogResponse: Insert Log Response
            logobj.AddWSLog(this.partnerName, this.ipaddress, "Response", webserviceName, methodName, result + "|", this.refnum);

            return result;
        }
    }