private JobRoleLookupListsCacheObject GetJobRoleAndLookups() { UcbServiceClient sc = new UcbServiceClient(); JobRoleVMDC returnObject = sc.GetJobRole(HttpContext.Current.User.Identity.Name, HttpContext.Current.User.Identity.Name, "FrameworkAdmin", "", null); JobRoleLookupListsCacheObject CachedLists = new JobRoleLookupListsCacheObject(); return(CachedLists); }
public ActionResult Edit() { // Retrieve ID from session string code = sessionManager.JobRoleCode; JobRoleVM model = new JobRoleVM(); // Not from staff or error if (String.IsNullOrEmpty(code)) { //If session has lists then use them RepopulateListsFromCacheSession(model); //Assume we are in create mode as no code passed model.JobRoleItem = new JobRoleModel() { IsActive = true }; } //if we have been passed a code then assume we are in edit situation and we need to retrieve from the database. else { // Create service instance IUcbService sc = UcbService; try { // Call service to get JobRole item and any associated lookups JobRoleVMDC returnedObject = sc.GetJobRole(CurrentUser, CurrentUser, appID, "", code); // Close service communication ((ICommunicationObject)sc).Close(); //Get view model from service model = ConvertJobRoleDC(returnedObject); ResolveFieldCodesToFieldNamesUsingLists(model); //Store the service version sessionManager.JobRoleServiceVersion = model.JobRoleItem; } catch (Exception e) { // Handle the exception string message = ExceptionManager.HandleException(e, (ICommunicationObject)sc); model.Message = message; return(View(model)); } } //Adds current retrieved JobRole to session sessionManager.CurrentJobRole = model.JobRoleItem; SetAccessContext(model); return(View(model)); }
private JobRoleVM ConvertJobRoleDC(JobRoleVMDC returnedObject) { JobRoleVM model = new JobRoleVM(); // Map JobRole Item model.JobRoleItem = Mapper.Map <JobRoleDC, JobRoleModel>(returnedObject.JobRoleItem); // Map lookup data lists return(model); }
//This method is shared between create and save private ActionResult UpdateJobRole() { // 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 JobRoleDC JobRoleItem = Mapper.Map <JobRoleDC>(model.JobRoleItem); JobRoleVMDC returnedObject = null; if (null == model.JobRoleItem.Code || model.JobRoleItem.Code == Guid.Empty) { // Call service to create new JobRole item returnedObject = sc.CreateJobRole(CurrentUser, CurrentUser, appID, "", JobRoleItem); } else { // Call service to update JobRole item returnedObject = sc.UpdateJobRole(CurrentUser, CurrentUser, appID, "", JobRoleItem); } // Close service communication ((ICommunicationObject)sc).Close(); // Retrieve item returned by service var createdJobRole = returnedObject.JobRoleItem; // Map data contract to model model.JobRoleItem = Mapper.Map <JobRoleModel>(createdJobRole); //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 = JobRoleAccessContext.Edit; // Save version of item returned by service into session sessionManager.JobRoleServiceVersion = model.JobRoleItem; sessionManager.CurrentJobRole = model.JobRoleItem; // 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> /// Create a JobRole /// </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 JobRoleVMDC CreateJobRole(string currentUser, string user, string appID, string overrideID, JobRoleDC dc, IRepository <JobRole> 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 JobRole item dc.Code = Guid.NewGuid(); // Map data contract to model JobRole destination = mappingService.Map <JobRoleDC, JobRole>(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 <JobRole, JobRoleDC>(destination); } // Create aggregate data contract JobRoleVMDC returnObject = new JobRoleVMDC(); // Add new item to aggregate returnObject.JobRoleItem = dc; return(returnObject); } catch (Exception e) { //Prevent exception from propogating across the service interface exceptionManager.ShieldException(e); return(null); } }
/// <summary> /// Retrieve a JobRole 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 JobRoleVMDC GetJobRole(string currentUser, string user, string appID, string overrideID, string code, IUnitOfWork uow, IRepository <JobRole> 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) { JobRoleDC 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 JobRole JobRole dataEntity = dataRepository.Single(x => x.Code == codeGuid); // Convert to data contract for passing through service interface destination = mappingService.Map <JobRole, JobRoleDC>(dataEntity); } // Create aggregate contract JobRoleVMDC returnObject = new JobRoleVMDC(); returnObject.JobRoleItem = destination; return(returnObject); } } catch (Exception e) { //Prevent exception from propogating across the service interface exceptionManager.ShieldException(e); return(null); } }