Пример #1
0
        public ActionResult Create(QueryDetailView queryDetailView)
        {
            #region Access Check
            bool hasPermission = GetEmployee().IsGuaranteed("Query_Insert");
            if (!hasPermission)
            {
                ModelState.AddModelError("", "AccessDenied");
                return(View(queryDetailView));
            }
            #endregion

            queryDetailView.EmployeeView = GetEmployee();

            if (ModelState.IsValid)
            {
                try
                {
                    AddQueryRequestOld request = new AddQueryRequestOld();
                    request.CreateEmployeeID = GetEmployee().ID;
                    request.PrmDefinition    = queryDetailView.QueryView.PrmDefinition;
                    request.QueryText        = queryDetailView.QueryView.QueryText;
                    request.PrmValues        = queryDetailView.QueryView.PrmValues;
                    request.Title            = queryDetailView.QueryView.Title;
                    request.xType            = "customercontainer";

                    GeneralResponse response = this._queryService.AddQuery(request);

                    if (response.success)
                    {
                        return(RedirectToAction("Index"));
                    }
                    else
                    {
                        foreach (string error in response.ErrorMessages)
                        {
                            ModelState.AddModelError("", error);
                        }
                        return(View(queryDetailView));
                    }
                }
                catch (Exception ex)
                {
                    ModelState.AddModelError("", ex.Message);
                    return(View(queryDetailView));
                }
            }

            return(View(queryDetailView));
        }
Пример #2
0
        public GeneralResponse AddQuery(AddQueryRequestOld request)
        {
            GeneralResponse response = new GeneralResponse();

            try
            {
                Query query = new Query();
                query.ID             = Guid.NewGuid();
                query.CreateDate     = PersianDateTime.Now;
                query.CreateEmployee = _employeeRepository.FindBy(request.CreateEmployeeID);
                query.xType          = request.xType;
                query.PrmDefinition  = request.PrmDefinition;
                query.PrmValues      = request.PrmValues;
                query.QueryText      = request.QueryText;
                query.Title          = request.Title;
                query.RowVersion     = 1;

                #region Validation
                if (query.GetBrokenRules().Count() > 0)
                {
                    foreach (BusinessRule businessRule in query.GetBrokenRules())
                    {
                        response.ErrorMessages.Add(businessRule.Rule);
                    }

                    return(response);
                }
                #endregion

                _queryRepository.Add(query);
                _uow.Commit();

                ////response.success = true;
            }
            catch (Exception ex)
            {
                response.ErrorMessages.Add(ex.Message);
            }

            return(response);
        }