public async Task <IActionResult> UpdateHearingDetails(Guid hearingId, [FromBody] UpdateHearingRequest request) { if (hearingId == Guid.Empty) { ModelState.AddModelError(nameof(hearingId), $"Please provide a valid {nameof(hearingId)}"); return(BadRequest(ModelState)); } var result = new UpdateHearingRequestValidation().Validate(request); if (!result.IsValid) { ModelState.AddFluentValidationErrors(result.Errors); return(BadRequest(ModelState)); } var getHearingByIdQuery = new GetHearingByIdQuery(hearingId); var videoHearing = await _queryHandler.Handle <GetHearingByIdQuery, VideoHearing>(getHearingByIdQuery); if (videoHearing == null) { return(NotFound()); } var venue = await GetVenue(request.HearingVenueName); if (venue == null) { ModelState.AddModelError(nameof(request.HearingVenueName), "Hearing venue does not exist"); return(BadRequest(ModelState)); } var cases = MapCase(request.Cases); // use existing video hearing values here when request properties are null request.AudioRecordingRequired ??= videoHearing.AudioRecordingRequired; request.QuestionnaireNotRequired ??= videoHearing.QuestionnaireNotRequired; request.HearingRoomName ??= videoHearing.HearingRoomName; request.OtherInformation ??= videoHearing.OtherInformation; var command = new UpdateHearingCommand(hearingId, request.ScheduledDateTime, request.ScheduledDuration, venue, request.HearingRoomName, request.OtherInformation, request.UpdatedBy, cases, request.QuestionnaireNotRequired.Value, request.AudioRecordingRequired.Value); await _commandHandler.Handle(command); var hearingMapper = new HearingToDetailsResponseMapper(); var updatedHearing = await _queryHandler.Handle <GetHearingByIdQuery, VideoHearing>(getHearingByIdQuery); var response = hearingMapper.MapHearingToDetailedResponse(updatedHearing); if (videoHearing.Status == BookingStatus.Created) { // publish this event when Hearing is set for ready for video await _eventPublisher.PublishAsync(new HearingDetailsUpdatedIntegrationEvent(updatedHearing)); } return(Ok(response)); }
public void Should_map_all_properties() { var refDataBuilder = new RefDataBuilder(); var venue = refDataBuilder.HearingVenues.First(x => x.Name == _hearingVenueName); var caseType = new CaseType(1, _caseTypeName); var hearingType = Builder <HearingType> .CreateNew().WithFactory(() => new HearingType(_hearingTypeName)).Build(); var scheduledDateTime = DateTime.Today.AddDays(1).AddHours(11).AddMinutes(45); var duration = 80; var hearingRoomName = "Roome03"; var otherInformation = "OtherInformation03"; var createdBy = "User03"; const bool questionnaireNotRequired = false; const bool audioRecordingRequired = true; var cancelReason = "Online abandonment (incomplete registration)"; var hearing = new VideoHearing(caseType, hearingType, scheduledDateTime, duration, venue, hearingRoomName, otherInformation, createdBy, questionnaireNotRequired, audioRecordingRequired, cancelReason); _videoHearing = Builder <VideoHearing> .CreateNew().WithFactory(() => hearing).Build(); var applicantCaseRole = new CaseRole(1, "Applicant"); var applicantLipHearingRole = new HearingRole(1, "Litigant in person") { UserRole = new UserRole(1, "Individual") }; _videoHearing.AddCase("0875", "Test Case Add", false); var person1 = new PersonBuilder(true).Build(); _videoHearing.AddIndividual(person1, applicantLipHearingRole, applicantCaseRole, $"{person1.FirstName} {person1.LastName}"); var party = _videoHearing.GetParticipants().FirstOrDefault(); party.SetProtected(nameof(party.CaseRole), applicantCaseRole); party.SetProtected(nameof(party.HearingRole), applicantLipHearingRole); var endpoints = new Endpoint("displayName", "333", "200", null); _videoHearing.AddEndpoint(endpoints); // Set the navigation properties as well since these would've been set if we got the hearing from DB _videoHearing.SetProtected(nameof(_videoHearing.HearingType), hearingType); _videoHearing.SetProtected(nameof(_videoHearing.CaseType), caseType); _videoHearing.SetProtected(nameof(_videoHearing.HearingVenue), venue); var response = _mapper.MapHearingToDetailedResponse(_videoHearing); response.Should().BeEquivalentTo(response, options => options .Excluding(v => v.Id) ); }
public async Task <IActionResult> GetHearingDetailsById(Guid hearingId) { if (hearingId == Guid.Empty) { ModelState.AddModelError(nameof(hearingId), $"Please provide a valid {nameof(hearingId)}"); return(BadRequest(ModelState)); } var query = new GetHearingByIdQuery(hearingId); var videoHearing = await _queryHandler.Handle <GetHearingByIdQuery, VideoHearing>(query); if (videoHearing == null) { return(NotFound()); } var hearingMapper = new HearingToDetailsResponseMapper(); var response = hearingMapper.MapHearingToDetailedResponse(videoHearing); return(Ok(response)); }
public async Task <IActionResult> BookNewHearing(BookNewHearingRequest request) { try { if (request == null) { const string modelErrorMessage = "BookNewHearingRequest is null"; const string logModelErrorMessage = "BookNewHearing Error: BookNewHearingRequest is null"; return(ModelStateErrorLogger(nameof(BookNewHearingRequest), modelErrorMessage, logModelErrorMessage, null, SeverityLevel.Information)); } var result = await new BookNewHearingRequestValidation().ValidateAsync(request); if (!result.IsValid) { const string logBookNewHearingValidationError = "BookNewHearing Validation Errors"; const string emptyPayLoadErrorMessage = "Empty Payload"; const string keyPayload = "payload"; ModelState.AddFluentValidationErrors(result.Errors); var dictionary = result.Errors.ToDictionary(x => x.PropertyName + "-" + Guid.NewGuid(), x => x.ErrorMessage); var payload = JsonConvert.SerializeObject(request); dictionary.Add(keyPayload, !string.IsNullOrWhiteSpace(payload) ? payload : emptyPayLoadErrorMessage); _logger.TrackTrace(logBookNewHearingValidationError, SeverityLevel.Error, dictionary); return(BadRequest(ModelState)); } var query = new GetCaseTypeQuery(request.CaseTypeName); var caseType = await _queryHandler.Handle <GetCaseTypeQuery, CaseType>(query); if (caseType == null) { const string logCaseDoesNotExist = "BookNewHearing Error: Case type does not exist"; return(ModelStateErrorLogger(nameof(request.CaseTypeName), "Case type does not exist", logCaseDoesNotExist, request.CaseTypeName, SeverityLevel.Error)); } var hearingType = caseType.HearingTypes.SingleOrDefault(x => x.Name == request.HearingTypeName); if (hearingType == null) { const string logHearingTypeDoesNotExist = "BookNewHearing Error: Hearing type does not exist"; return(ModelStateErrorLogger(nameof(request.HearingTypeName), "Hearing type does not exist", logHearingTypeDoesNotExist, request.HearingTypeName, SeverityLevel.Error)); } var venue = await GetVenue(request.HearingVenueName); if (venue == null) { const string logHearingVenueDoesNotExist = "BookNewHearing Error: Hearing venue does not exist"; return(ModelStateErrorLogger(nameof(request.HearingVenueName), "Hearing venue does not exist", logHearingVenueDoesNotExist, request.HearingVenueName, SeverityLevel.Error)); } var cases = request.Cases.Select(x => new Case(x.Number, x.Name)).ToList(); const string logHasCases = "BookNewHearing got cases"; const string keyCases = "Cases"; _logger.TrackTrace(logHasCases, SeverityLevel.Information, new Dictionary <string, string> { { keyCases, string.Join(", ", cases.Select(x => new { x.Name, x.Number })) } }); var createVideoHearingCommand = BookNewHearingRequestToCreateVideoHearingCommandMapper.Map( request, caseType, hearingType, venue, cases, _randomGenerator, _kinlyConfiguration.SipAddressStem); const string logCallingDb = "BookNewHearing Calling DB..."; const string dbCommand = "createVideoHearingCommand"; const string logSaveSuccess = "BookNewHearing DB Save Success"; const string logNewHearingId = "NewHearingId"; _logger.TrackTrace(logCallingDb, SeverityLevel.Information, new Dictionary <string, string> { { dbCommand, JsonConvert.SerializeObject(createVideoHearingCommand) } }); await _commandHandler.Handle(createVideoHearingCommand); _logger.TrackTrace(logSaveSuccess, SeverityLevel.Information, new Dictionary <string, string> { { logNewHearingId, createVideoHearingCommand.NewHearingId.ToString() } }); var videoHearingId = createVideoHearingCommand.NewHearingId; var getHearingByIdQuery = new GetHearingByIdQuery(videoHearingId); var queriedVideoHearing = await _queryHandler.Handle <GetHearingByIdQuery, VideoHearing>(getHearingByIdQuery); const string logRetrieveNewHearing = "BookNewHearing Retrieved new hearing from DB"; const string keyHearingId = "HearingId"; const string keyCaseType = "CaseType"; const string keyParticipantCount = "Participants.Count"; _logger.TrackTrace(logRetrieveNewHearing, SeverityLevel.Information, new Dictionary <string, string> { { keyHearingId, queriedVideoHearing.Id.ToString() }, { keyCaseType, queriedVideoHearing.CaseType?.Name }, { keyParticipantCount, queriedVideoHearing.Participants.Count.ToString() }, }); var hearingMapper = new HearingToDetailsResponseMapper(); var response = hearingMapper.MapHearingToDetailedResponse(queriedVideoHearing); const string logProcessFinished = "BookNewHearing Finished, returning response"; _logger.TrackTrace(logProcessFinished, SeverityLevel.Information, new Dictionary <string, string> { { "response", JsonConvert.SerializeObject(response) } }); return(CreatedAtAction(nameof(GetHearingDetailsById), new { hearingId = response.Id }, response)); } catch (Exception ex) { const string keyPayload = "payload"; const string keyScheduledDateTime = "ScheduledDateTime"; const string keyScheduledDuration = "ScheduledDuration"; const string keyCaseTypeName = "CaseTypeName"; const string keyHearingTypeName = "HearingTypeName"; if (request != null) { var payload = JsonConvert.SerializeObject(request); _logger.TrackError(ex, new Dictionary <string, string> { { keyPayload, !string.IsNullOrWhiteSpace(payload) ? payload : "Empty Payload" }, { keyScheduledDateTime, request.ScheduledDateTime.ToString("s") }, { keyScheduledDuration, request.ScheduledDuration.ToString() }, { keyCaseTypeName, request.CaseTypeName }, { keyHearingTypeName, request.HearingTypeName } }); } throw; } }