public JsonResult CreditServices_Insert(AddCreditServiceRequest request) { GeneralResponse response = new GeneralResponse(); #region Access Check bool hasPermission = GetEmployee().IsGuaranteed("CreditService_Insert"); if (!hasPermission) { response.ErrorMessages.Add("AccessDenied"); return(Json(response, JsonRequestBehavior.AllowGet)); } #endregion response = _creditServiceService.AddCreditServices(request, GetEmployee().ID); return(Json(response, JsonRequestBehavior.AllowGet)); }
public GeneralResponse AddCreditServices(AddCreditServiceRequest request, Guid EmployeeID) { GeneralResponse response = new GeneralResponse(); try { CreditService creditService = new CreditService(); #region Validate Uncredit Service Code string _errorMessag = AddValidate(request.CreditServiceCode, request.ServiceName); if (_errorMessag != "NoError") { response.ErrorMessages.Add(_errorMessag); return(response); } #endregion if (request.MaxDiscount > request.UnitPrice) { response.ErrorMessages.Add("تخفیف نمیتواند بیش از قیمت پایه باشد"); return(response); } creditService.ID = Guid.NewGuid(); creditService.CreateDate = PersianDateTime.Now; creditService.CreateEmployee = _employeeRepository.FindBy(EmployeeID); creditService.CreditServiceCode = request.CreditServiceCode; creditService.Discontinued = request.Discontinued; creditService.ExpDays = request.ExpDays; creditService.Imposition = request.Imposition; creditService.MaxDiscount = request.MaxDiscount; creditService.Network = this._networkRepository.FindBy(request.NetworkID); creditService.PurchaseUnitPrice = request.PurchaseUnitPrice; creditService.ResellerUnitPrice = request.ResellerUnitPrice; creditService.ServiceName = request.ServiceName; creditService.UnitPrice = request.UnitPrice; creditService.Note = request.Note; creditService.Discontinued = request.Discontinued; creditService.Bonus = request.Bonus; creditService.Comission = request.Comission; creditService.SortOrder = GetSortOrder(); creditService.RowVersion = 1; #region validation if (creditService.GetBrokenRules().Count() > 0) { foreach (BusinessRule businessRule in creditService.GetBrokenRules()) { response.ErrorMessages.Add(businessRule.Rule); } return(response); } #endregion _creditServiceRepository.Add(creditService); _uow.Commit(); } catch (Exception ex) { if (ex.InnerException != null && ex.InnerException.Message.Substring(0, 177) == @"The INSERT statement conflicted with the CHECK constraint ""CK_CreditService"". The conflict occurred in database ""Saman"", table ""Store.CreditService"", column 'CreditServiceCode'.") { response.ErrorMessages.Add("MustBeBegin3000Key"); } else { response.ErrorMessages.Add(ex.Message); if (ex.InnerException != null) { response.ErrorMessages.Add(ex.InnerException.Message); } } } return(response); }