Exemplo n.º 1
0
        public PlaceResponse UpdatePlace(PutRequest <Place> request)
        {
            var validator = new Response();
            var response  = new PlaceResponse();

            try
            {
                validator = new UpdatePlaceValidator(_placeRepository).Validate(request).ToResponse();
            }
            catch (Exception ex)
            {
                _logger.Error(ExceptionMessages.UpdatePlaceException, ex);
                response.Result = false;
                response.Errors.Add(new ResponseError {
                    Name = "UpdatePlaceException", Error = ExceptionMessages.UpdatePlaceException
                });
                return(response);
            }

            if (!validator.Result)
            {
                return new PlaceResponse {
                           Errors = validator.Errors, Result = false
                }
            }
            ;

            try
            {
                response = _placeRepository.UpdatePlace(request);
            }
            catch (Exception ex)
            {
                _logger.Error(ExceptionMessages.UpdatePlaceException, ex);
                response.Result = false;
                response.Errors.Add(new ResponseError {
                    Name = "UpdateEventException", Error = ExceptionMessages.UpdatePlaceException
                });
                return(response);
            }

            if (response.Result)
            {
                _logger.Information($"The Place with Id: {response.Place.Id} has been successfully updated.");
            }

            return(response);
        }