public ActionResult Edit(Guid id, SecurityPermissionGroupModel model, string button) { using (DBEntities context = Settings.CreateDataContext()) { ValidateGroup(context, model); if (!ModelState.IsValid) { return View(model); } SecurityPermissionGroup target = null; if (model.Id != Guid.Empty) { target = SecurityPermissionHelper.GetGroup(model.Id, context); if (target == null) { ModelState.AddModelError("", Resources.Resource.RowNotFound); return View(model); } } else { target = new SecurityPermissionGroup(); target.Id = Guid.NewGuid(); context.AddToSecurityPermissionGroup(target); } SecurityPermissionGroupModel.CreateMap(); Mapper.Map(model, target); try { context.SaveChanges(); } catch (Exception ex) { var sb = new StringBuilder(Resources.Resource.SaveError + ": " + ex.Message); if (ex.InnerException != null) sb.AppendLine(ex.InnerException.Message); ModelState.AddModelError("", sb.ToString()); return View(model); } if (button == "SaveAndExit") return RedirectToAction("Index"); else return RedirectToAction("Edit", new { target.Id }); } }
private void ValidateGroup(DBEntities context, SecurityPermissionGroupModel model) { //string res = SecurityPermissionGroupValidator.CheckTableName(context, model.Id, model.TableName); //if (res.Length > 0) // ModelState.AddModelError("TableName", res); }