public PostPatientUtilizationResponse InsertPatientUtilization(PostPatientUtilizationRequest request)
        {
            try
            {
                var result = new PostPatientUtilizationResponse();

                //[Route("/{Context}/{Version}/{ContractNumber}/Patient/{PatientId}/Notes/", "GET")]
                IRestClient client = new JsonServiceClient();
                var         url    = Helper.BuildURL(string.Format("{0}/{1}/{2}/{3}/Patient/{4}/Notes/Utilizations/",
                                                                   DdPatientNoteUrl,
                                                                   "NG",
                                                                   request.Version,
                                                                   request.ContractNumber,
                                                                   request.PatientId), request.UserId);

                var ddRequest = new PostPatientUtilizationDataRequest
                {
                    Context            = request.ContractNumber,
                    ContractNumber     = request.ContractNumber,
                    PatientId          = request.PatientId,
                    PatientUtilization = Mapper.Map <PatientUtilizationData>(request.Utilization),
                    UserId             = request.UserId,
                    Version            = request.Version
                };

                PostPatientUtilizationDataResponse ddResponse = client.Post <PostPatientUtilizationDataResponse>(url,
                                                                                                                 ddRequest);

                if (ddResponse == null || ddResponse.Utilization == null)
                {
                    return(result);
                }
                result.Utilization = Mapper.Map <PatientUtilization>(ddResponse.Utilization);
                result.Result      = true;

                return(result);
            }
            catch (WebServiceException ex)
            {
                throw ex;
            }
        }
        public PostPatientUtilizationResponse Post(PostPatientUtilizationRequest request)
        {
            PostPatientUtilizationResponse response = null;
            ValidateTokenResponse result = null;

            try
            {
                request.Token = base.Request.Headers["Token"] as string;
                result = Security.IsUserValidated(request.Version, request.Token, request.ContractNumber);
                if (result.UserId.Trim() != string.Empty)
                {
                    if (string.IsNullOrEmpty(request.Utilization.PatientId))
                        throw new Exception("Missing patientid");

                    if (string.IsNullOrEmpty(request.Utilization.VisitTypeId))
                        throw new Exception("Missing visittypeid");

                    request.UserId = result.UserId;
                    response = UtilManager.InsertPatientUtilization(request);
                }
                else
                    throw new UnauthorizedAccessException();
            }
            catch (Exception ex)
            {
                CommonFormatter.FormatExceptionResponse(response, base.Response, ex);
                if ((ex is WebServiceException) == false)
                    UtilManager.LogException(ex);
            }
            finally
            {
                List<string> patientIds = new List<string>();

                if (response.Result)
                {
                    patientIds.Add(request.PatientId);
                    AuditHelper.LogAuditData(request, result.SQLUserId, patientIds, HttpContext.Current.Request, request.GetType().Name);
                }
            }
            return response;
        }