//This method is shared between create and save private ActionResult UpdateAbuseType() { // Get the updated model var model = GetUpdatedModel(); // Test to see if there are any errors var errors = ModelState .Where(x => x.Value.Errors.Count > 0) .Select(x => new { x.Key, x.Value.Errors[0].ErrorMessage }) .ToArray(); //Set flags false SetFlagsFalse(model); // Test to see if the model has validated correctly if (ModelState.IsValid) { // Create service instance IUcbService sc = UcbService; //Attempt update try { // Map model to data contract AbuseTypeDC AbuseTypeItem = Mapper.Map <AbuseTypeDC>(model.AbuseTypeItem); AbuseTypeVMDC returnedObject = null; if (null == model.AbuseTypeItem.Code || model.AbuseTypeItem.Code == Guid.Empty) { // Call service to create new AbuseType item returnedObject = sc.CreateAbuseType(CurrentUser, CurrentUser, appID, "", AbuseTypeItem); } else { // Call service to update AbuseType item returnedObject = sc.UpdateAbuseType(CurrentUser, CurrentUser, appID, "", AbuseTypeItem); } // Close service communication ((ICommunicationObject)sc).Close(); // Retrieve item returned by service var createdAbuseType = returnedObject.AbuseTypeItem; // Map data contract to model model.AbuseTypeItem = Mapper.Map <AbuseTypeModel>(createdAbuseType); //After creation some of the fields are display only so we need the resolved look up nmames ResolveFieldCodesToFieldNamesUsingLists(model); // Set access context to Edit mode model.AccessContext = AbuseTypeAccessContext.Edit; // Save version of item returned by service into session sessionManager.AbuseTypeServiceVersion = model.AbuseTypeItem; sessionManager.CurrentAbuseType = model.AbuseTypeItem; // Remove the state from the model as these are being populated by the controller and the HTML helpers are being populated with // the POSTED values and not the changed ones. ModelState.Clear(); model.Message = Resources.MESSAGE_UPDATE_SUCCEEDED; } catch (Exception e) { // Handle the exception string message = ExceptionManager.HandleException(e, (ICommunicationObject)sc); model.Message = message; return(View(model)); } } return(View(model)); }
/// <summary> /// Retrieve a AbuseType with associated lookups /// </summary> /// <param name="currentUser"></param> /// <param name="user"></param> /// <param name="appID"></param> /// <param name="overrideID"></param> /// <param name="code"></param> /// <param name="dataRepository"></param> /// <param name="uow"></param> /// <returns></returns> public AbuseTypeVMDC GetAbuseType(string currentUser, string user, string appID, string overrideID, string code, IUnitOfWork uow, IRepository <AbuseType> dataRepository , IExceptionManager exceptionManager, IMappingService mappingService) { try { #region Parameter validation // Validate parameters if (string.IsNullOrEmpty(currentUser)) { throw new ArgumentOutOfRangeException("currentUser"); } if (string.IsNullOrEmpty(user)) { throw new ArgumentOutOfRangeException("user"); } if (string.IsNullOrEmpty(appID)) { throw new ArgumentOutOfRangeException("appID"); } if (null == dataRepository) { throw new ArgumentOutOfRangeException("dataRepository"); } if (null == uow) { throw new ArgumentOutOfRangeException("uow"); } if (null == exceptionManager) { throw new ArgumentOutOfRangeException("exceptionManager"); } if (null == mappingService) { throw new ArgumentOutOfRangeException("mappingService"); } #endregion using (uow) { AbuseTypeDC destination = null; // If code is null then just return supporting lists if (!string.IsNullOrEmpty(code)) { // Convert code to Guid Guid codeGuid = Guid.Parse(code); // Retrieve specific AbuseType AbuseType dataEntity = dataRepository.Single(x => x.Code == codeGuid); // Convert to data contract for passing through service interface destination = mappingService.Map <AbuseType, AbuseTypeDC>(dataEntity); } // Create aggregate contract AbuseTypeVMDC returnObject = new AbuseTypeVMDC(); returnObject.AbuseTypeItem = destination; return(returnObject); } } catch (Exception e) { //Prevent exception from propogating across the service interface exceptionManager.ShieldException(e); return(null); } }
/// <summary> /// Create a AbuseType /// </summary> /// <param name="currentUser"></param> /// <param name="user"></param> /// <param name="appID"></param> /// <param name="overrideID"></param> /// <param name="dc"></param> /// <param name="dataRepository"></param> /// <param name="uow"></param> public AbuseTypeVMDC CreateAbuseType(string currentUser, string user, string appID, string overrideID, AbuseTypeDC dc, IRepository <AbuseType> dataRepository, IUnitOfWork uow, IExceptionManager exceptionManager, IMappingService mappingService) { try { #region Parameter validation // Validate parameters if (string.IsNullOrEmpty(currentUser)) { throw new ArgumentOutOfRangeException("currentUser"); } if (string.IsNullOrEmpty(user)) { throw new ArgumentOutOfRangeException("user"); } if (string.IsNullOrEmpty(appID)) { throw new ArgumentOutOfRangeException("appID"); } if (null == dc) { throw new ArgumentOutOfRangeException("dc"); } if (null == dataRepository) { throw new ArgumentOutOfRangeException("dataRepository"); } if (null == uow) { throw new ArgumentOutOfRangeException("uow"); } if (null == exceptionManager) { throw new ArgumentOutOfRangeException("exceptionManager"); } if (null == mappingService) { throw new ArgumentOutOfRangeException("mappingService"); } #endregion using (uow) { // Create a new ID for the AbuseType item dc.Code = Guid.NewGuid(); // Map data contract to model AbuseType destination = mappingService.Map <AbuseTypeDC, AbuseType>(dc); // Add the new item dataRepository.Add(destination); // Commit unit of work uow.Commit(); // Map model back to data contract to return new row id. dc = mappingService.Map <AbuseType, AbuseTypeDC>(destination); } // Create aggregate data contract AbuseTypeVMDC returnObject = new AbuseTypeVMDC(); // Add new item to aggregate returnObject.AbuseTypeItem = dc; return(returnObject); } catch (Exception e) { //Prevent exception from propogating across the service interface exceptionManager.ShieldException(e); return(null); } }
/// <summary> /// Create a AbuseType /// </summary> /// <param name="currentUser"></param> /// <param name="user"></param> /// <param name="appID"></param> /// <param name="overrideID"></param> /// <param name="dc"></param> public AbuseTypeVMDC CreateAbuseType(string currentUser, string user, string appID, string overrideID, AbuseTypeDC dc) { // Create unit of work IUnitOfWork uow = new UnitOfWork(currentUser); // Create repository Repository <AbuseType> dataRepository = new Repository <AbuseType>(uow.ObjectContext, currentUser, user, appID, overrideID); //Create ExceptionManager IExceptionManager exceptionManager = new ExceptionManager(); //Create MappingService IMappingService mappingService = new MappingService(); // Call overload with injected objects return(CreateAbuseType(currentUser, user, appID, overrideID, dc, dataRepository, uow, exceptionManager, mappingService)); }