diff --git a/src/main/java/org/recap/ScsbConstants.java b/src/main/java/org/recap/ScsbConstants.java index da02ebc5..57ae6406 100644 --- a/src/main/java/org/recap/ScsbConstants.java +++ b/src/main/java/org/recap/ScsbConstants.java @@ -468,6 +468,6 @@ public static List getRequestTypeList() { public static final String VERSION = "ns1:version"; public static final String SCHEME = "ns1:Scheme"; public static final String XMLNS = "xmlns:ns1"; - + public static final String SQL_EXCEPTION = "Exception captured at Database level while creating request."; } diff --git a/src/main/java/org/recap/controller/RequestItemValidatorController.java b/src/main/java/org/recap/controller/RequestItemValidatorController.java index 2e006396..76cfb29e 100644 --- a/src/main/java/org/recap/controller/RequestItemValidatorController.java +++ b/src/main/java/org/recap/controller/RequestItemValidatorController.java @@ -1,6 +1,7 @@ package org.recap.controller; import lombok.extern.slf4j.Slf4j; +import org.recap.ScsbCommonConstants; import org.recap.ScsbConstants; import org.recap.ils.connector.factory.ILSProtocolConnectorFactory; import org.recap.model.request.ItemRequestInformation; @@ -9,6 +10,7 @@ import org.slf4j.Logger; import org.slf4j.LoggerFactory; import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.http.HttpHeaders; import org.springframework.http.HttpStatus; import org.springframework.http.MediaType; import org.springframework.http.ResponseEntity; @@ -17,6 +19,9 @@ import org.springframework.web.bind.annotation.PostMapping; import org.springframework.web.bind.annotation.RestController; +import java.sql.SQLException; +import java.util.Date; + /** * Created by hemalathas on 10/11/16. */ @@ -72,13 +77,28 @@ public ResponseEntity validateItemRequestInformations(@RequestBody ItemRequestIn */ @PostMapping(value = "/validateItemRequest", consumes = MediaType.APPLICATION_JSON_VALUE, produces = MediaType.APPLICATION_JSON_VALUE) public ResponseEntity validateItemRequest(@RequestBody ItemRequestInformation itemRequestInformation) { - ResponseEntity responseEntity; - log.info("Request Validation: Start"); - responseEntity = requestParamaterValidatorService.validateItemRequestParameters(itemRequestInformation); - if (responseEntity == null) { - responseEntity = itemValidatorService.itemValidation(itemRequestInformation); + ResponseEntity responseEntity = null; + try { + log.info("Request Validation: Start"); + responseEntity = requestParamaterValidatorService.validateItemRequestParameters(itemRequestInformation); + if (responseEntity == null) { + responseEntity = itemValidatorService.itemValidation(itemRequestInformation); + } + log.info(String.format("Request Validation: %s - %s",responseEntity.getStatusCode(), responseEntity.getBody())); + return responseEntity; + } catch (Exception e) { + if(e instanceof SQLException) + return new ResponseEntity<>(ScsbConstants.SQL_EXCEPTION, getHttpHeaders(), HttpStatus.BAD_REQUEST); + else + return responseEntity; } - log.info(String.format("Request Validation: %s - %s",responseEntity.getStatusCode(), responseEntity.getBody())); - return responseEntity; + + + } + + private HttpHeaders getHttpHeaders() { + HttpHeaders responseHeaders = new HttpHeaders(); + responseHeaders.add(ScsbCommonConstants.RESPONSE_DATE, new Date().toString()); + return responseHeaders; } }