public async Task <IActionResult> Post(string tripName, [FromBody] StopViewModel vm) { try { // If VM is valid if (ModelState.IsValid) { var newStop = Mapper.Map <Stop>(vm); // Lookup the GEO codes var result = await _coordsService.GetCoordsAsync(newStop.Name); if (!result.Success) { _logger.LogError(result.Message); } else { newStop.Longitude = result.Longitude; newStop.Latitude = result.Latitude; // Save to the database //_repository.AddStop(tripName, newStop); _repository.AddStop(tripName, newStop, User.Identity.Name); if (await _repository.SaveChangesAsync()) { return(Created($"/api/trips/{tripName}/stops/{newStop.Name}", Mapper.Map <StopViewModel>(newStop))); } } } } catch (Exception ex) { _logger.LogError($"Error saving new stop: {ex}"); } return(BadRequest("Error saving new stop!")); }
public async Task <IActionResult> Post(string tripName, [FromBody] StopViewModel vm) { try { // if the vm is valid if (ModelState.IsValid) { var newStop = Mapper.Map <Stop>(vm); // Lookup the geocodes var result = await _coordsService.GetCoordsAsync(newStop.Name); if (!result.Success) { _logger.LogError(result.Message); } else { newStop.Latitude = result.Latitude; newStop.Longitude = result.Longitude; //save to the database _repository.AddStop(tripName, newStop); if (await _repository.SaveChangesAsync()) { return(Created($"/api/trips/{tripName}/stops/{newStop.Name}", Mapper.Map <StopViewModel>(newStop))); } } } } catch (Exception e) { _logger.LogError("Failed to save new stop {0}", e); } return(BadRequest("Failed to save new stop")); }