From f6a1ae0561c05323a57ae309b6adfeec330df381 Mon Sep 17 00:00:00 2001 From: wr148d Date: Fri, 19 Feb 2021 11:45:22 -0500 Subject: Update to have the error codes and 404's working Issue-ID: AAI-3250 Change-Id: I44180eb6b3de49458096b912320ffcab601dd955 Signed-off-by: wr148d --- .../onap/aai/sparky/ExceptionConfiguration.java | 73 ++++++++++++++++++++++ .../main/java/org/onap/aai/sparky/ProxyHelper.java | 5 +- .../sparky/exception/GenericServiceException.java | 32 ++++++++++ .../aai/sparky/exception/ProxyErrorDetails.java | 63 +++++++++++++++++++ 4 files changed, 171 insertions(+), 2 deletions(-) create mode 100644 sparkybe-onap-application/src/main/java/org/onap/aai/sparky/ExceptionConfiguration.java create mode 100644 sparkybe-onap-application/src/main/java/org/onap/aai/sparky/exception/GenericServiceException.java create mode 100644 sparkybe-onap-application/src/main/java/org/onap/aai/sparky/exception/ProxyErrorDetails.java (limited to 'sparkybe-onap-application/src') diff --git a/sparkybe-onap-application/src/main/java/org/onap/aai/sparky/ExceptionConfiguration.java b/sparkybe-onap-application/src/main/java/org/onap/aai/sparky/ExceptionConfiguration.java new file mode 100644 index 0000000..7e3ed56 --- /dev/null +++ b/sparkybe-onap-application/src/main/java/org/onap/aai/sparky/ExceptionConfiguration.java @@ -0,0 +1,73 @@ +/** + * ============LICENSE_START======================================================= + * SPARKY (AAI UI service) + * ================================================================================ + * Copyright � 2017-2018 AT&T Intellectual Property. All rights reserved. + * Copyright � 2017-2018 Amdocs + * ================================================================================ + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + * ============LICENSE_END========================================================= + */ +package org.onap.aai.sparky; + +import java.text.SimpleDateFormat; +import java.util.Date; +import java.util.regex.Matcher; +import java.util.regex.Pattern; + +import org.onap.aai.sparky.exception.GenericServiceException; +import org.onap.aai.sparky.exception.ProxyErrorDetails; +import org.onap.aai.sparky.exception.ProxyServiceException; +import org.springframework.http.HttpStatus; +import org.springframework.http.ResponseEntity; +import org.springframework.web.bind.annotation.ControllerAdvice; +import org.springframework.web.bind.annotation.ExceptionHandler; +import org.springframework.web.bind.annotation.RestController; +import org.springframework.web.context.request.WebRequest; +import org.springframework.web.servlet.mvc.method.annotation.ResponseEntityExceptionHandler; + + +@ControllerAdvice +@RestController +public class ExceptionConfiguration extends ResponseEntityExceptionHandler { + + @ExceptionHandler(ProxyServiceException.class) + public final ResponseEntity handleProxyException(ProxyServiceException ex, WebRequest request) { + Date curDate = new Date(); + SimpleDateFormat format = new SimpleDateFormat ("E yyyy.MM.dd 'at' hh:mm:ss a zzz"); + String DateToStr = format.format(curDate); + ProxyErrorDetails errorDetails = new ProxyErrorDetails( + DateToStr, ex.getMessage(),request.getDescription(false),"REQUEST PROCESSING ERROR","500"); + return new ResponseEntity<>(errorDetails, HttpStatus.INTERNAL_SERVER_ERROR); + } + + @ExceptionHandler(GenericServiceException.class) + public final ResponseEntity handleGenericException(GenericServiceException ex, WebRequest request) { + Date curDate = new Date(); + SimpleDateFormat format = new SimpleDateFormat ("E yyyy.MM.dd 'at' hh:mm:ss a zzz"); + String DateToStr = format.format(curDate); + String[] msg = ex.getMessage().split("resultCode:"); + int statusCode = Integer.valueOf(msg[1]); + HttpStatus hs = HttpStatus.valueOf(statusCode); + Matcher m = Pattern.compile("\\[\"(.*?)\"\\,").matcher(msg[0]); + + String message=""; + while(m.find()) { + message=m.group(0); + } + message=message.replaceAll("\\[\\\"", "").replaceAll("\"\\,",""); + ProxyErrorDetails errorDetails = new ProxyErrorDetails( + DateToStr,message,request.getDescription(false),hs.name().toString().toUpperCase(),msg[1]); + return new ResponseEntity<>(errorDetails, hs); + } +} \ No newline at end of file diff --git a/sparkybe-onap-application/src/main/java/org/onap/aai/sparky/ProxyHelper.java b/sparkybe-onap-application/src/main/java/org/onap/aai/sparky/ProxyHelper.java index ed9557f..b7a51f4 100644 --- a/sparkybe-onap-application/src/main/java/org/onap/aai/sparky/ProxyHelper.java +++ b/sparkybe-onap-application/src/main/java/org/onap/aai/sparky/ProxyHelper.java @@ -25,6 +25,7 @@ import org.onap.aai.cl.eelf.LoggerFactory; import org.onap.aai.restclient.client.OperationResult; import org.onap.aai.sparky.security.portal.PortalRestAPICentralServiceImpl; import org.onap.aai.sparky.util.ProxyClient; +import org.onap.aai.sparky.exception.GenericServiceException; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.context.annotation.Profile; import org.springframework.core.env.Environment; @@ -186,9 +187,9 @@ public class ProxyHelper { } } response.setHeader("Access-Control-Expose-Headers", headerTags); - /*if(or.getResultCode() != 200) { + if(or.getResultCode() != 200) { throw new GenericServiceException(String.valueOf(or.getFailureCause()+"resultCode:"+or.getResultCode())); - }*/ + } } } \ No newline at end of file diff --git a/sparkybe-onap-application/src/main/java/org/onap/aai/sparky/exception/GenericServiceException.java b/sparkybe-onap-application/src/main/java/org/onap/aai/sparky/exception/GenericServiceException.java new file mode 100644 index 0000000..46a2e4f --- /dev/null +++ b/sparkybe-onap-application/src/main/java/org/onap/aai/sparky/exception/GenericServiceException.java @@ -0,0 +1,32 @@ +/** + * ============LICENSE_START======================================================= + * org.onap.aai + * ================================================================================ + * Copyright © 2017-2021 AT&T Intellectual Property. All rights reserved. + * ================================================================================ + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + * ============LICENSE_END========================================================= + */ + +package org.onap.aai.sparky.exception; + +public class GenericServiceException extends RuntimeException { + + + private static final long serialVersionUID = 1L; + + public GenericServiceException(String exception) { + super(exception); + } + +} diff --git a/sparkybe-onap-application/src/main/java/org/onap/aai/sparky/exception/ProxyErrorDetails.java b/sparkybe-onap-application/src/main/java/org/onap/aai/sparky/exception/ProxyErrorDetails.java new file mode 100644 index 0000000..5d98a0d --- /dev/null +++ b/sparkybe-onap-application/src/main/java/org/onap/aai/sparky/exception/ProxyErrorDetails.java @@ -0,0 +1,63 @@ +/** + * ============LICENSE_START======================================================= + * org.onap.aai + * ================================================================================ + * Copyright © 2017-2021 AT&T Intellectual Property. All rights reserved. + * ================================================================================ + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + * ============LICENSE_END========================================================= + */ + +package org.onap.aai.sparky.exception; + +import java.util.Date; + +public class ProxyErrorDetails { + private String message; + private String details; + private String statusType; + private String status; + private String Date; + + + public ProxyErrorDetails(String Date, String message, String details,String statusType,String status) { + super(); + this.Date = Date; + this.message = message; + this.details = details; + this.statusType = statusType; + this.status = status; + } + + + public String getDate() { + return Date; + } + public String getMessage() { + return message; + } + + public String getDetails() { + return details; + } + + public String getStatusType() { + return statusType; + } + + public String getStatus() { + return status; + } + +} + -- cgit 1.2.3-korg