// ใช้สำหรับตรวจสอบเลขที่ใบรับเงินชั่วคราว กับเลขที่ใบคำขอเอาประกันหรือเลขที่กรมธรรม์ว่าเคยถูกใช้ไปแล้วครบจำนวนครั้งที่กำหนดหรือยัง ถ้าพบว่าเคยใช้ไปแล้วจะไม่สามารถนำไปใช้งานได้อีก // 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; } }