*/
package org.oransc.portal.nonrtric.controlpanel.eiproducerapi;
-import com.google.gson.GsonBuilder;
-
import java.lang.invoke.MethodHandles;
-
-import javax.net.ssl.SSLException;
-
import org.json.JSONArray;
import org.json.JSONObject;
import org.oransc.portal.nonrtric.controlpanel.util.AsyncRestClient;
+import org.oransc.portal.nonrtric.controlpanel.util.ErrorResponseHandler;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
-import org.springframework.http.HttpStatus;
import org.springframework.http.ResponseEntity;
import org.springframework.stereotype.Component;
-import org.springframework.web.client.HttpClientErrorException;
-import org.springframework.web.client.HttpServerErrorException;
@Component("EiProducerApi")
public class EiProducerApiImpl implements EiProducerApi {
private final AsyncRestClient webClient;
- private static com.google.gson.Gson gson = new GsonBuilder() //
- .serializeNulls() //
- .create(); //
-
@Autowired
public EiProducerApiImpl(
@org.springframework.beans.factory.annotation.Value("${enrichmentcontroller.url.prefix}") final String urlPrefix) {
}
return new ResponseEntity<>(new JSONArray(rsp.getBody()).toString(), rsp.getStatusCode());
} catch (Exception e) {
- return handleException(e);
+ return ErrorResponseHandler.handleException(e);
}
}
}
return new ResponseEntity<>(new JSONObject(rsp.getBody()).toString(), rsp.getStatusCode());
} catch (Exception e) {
- return handleException(e);
- }
- }
-
- private ResponseEntity<String> handleException(Exception throwable) {
- if (throwable instanceof HttpClientErrorException) {
- HttpClientErrorException e = (HttpClientErrorException) throwable;
- return new ResponseEntity<>(e.getMessage(), e.getStatusCode());
- } else if (throwable instanceof HttpServerErrorException) {
- HttpServerErrorException e = (HttpServerErrorException) throwable;
- return new ResponseEntity<>(e.getResponseBodyAsString(), e.getStatusCode());
- } else if (throwable instanceof SSLException) {
- SSLException e = (SSLException) throwable;
- return new ResponseEntity<>("Could not create WebClient " + e.getMessage(),
- HttpStatus.INTERNAL_SERVER_ERROR);
+ return ErrorResponseHandler.handleException(e);
}
- return new ResponseEntity<>(throwable.getClass().getName() + ": " + throwable.getMessage(),
- HttpStatus.INTERNAL_SERVER_ERROR);
}
}
import com.google.gson.JsonObject;
import com.google.gson.JsonParser;
import com.google.gson.reflect.TypeToken;
-
import java.lang.invoke.MethodHandles;
import java.lang.reflect.Type;
import java.util.ArrayList;
import java.util.Collection;
import java.util.List;
-
-import javax.net.ssl.SSLException;
-
import org.immutables.gson.Gson;
import org.immutables.value.Value;
import org.oransc.portal.nonrtric.controlpanel.model.ImmutablePolicyInfo;
import org.oransc.portal.nonrtric.controlpanel.model.PolicyType;
import org.oransc.portal.nonrtric.controlpanel.model.PolicyTypes;
import org.oransc.portal.nonrtric.controlpanel.util.AsyncRestClient;
+import org.oransc.portal.nonrtric.controlpanel.util.ErrorResponseHandler;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.http.HttpStatus;
import org.springframework.http.ResponseEntity;
import org.springframework.stereotype.Component;
-import org.springframework.web.client.HttpClientErrorException;
-import org.springframework.web.client.HttpServerErrorException;
@Component("PolicyAgentApi")
public class PolicyAgentApiImpl implements PolicyAgentApi {
}
return new ResponseEntity<>(gson.toJson(result), rsp.getStatusCode());
} catch (Exception e) {
- return handleException(e);
+ return ErrorResponseHandler.handleException(e);
}
}
}
return new ResponseEntity<>(gson.toJson(result), rsp.getStatusCode());
} catch (Exception e) {
- return handleException(e);
+ return ErrorResponseHandler.handleException(e);
}
}
String str = obj.toString();
return new ResponseEntity<>(str, rsp.getStatusCode());
} catch (Exception e) {
- ResponseEntity<String> rsp = handleException(e);
+ ResponseEntity<String> rsp = ErrorResponseHandler.handleException(e);
return new ResponseEntity<>(rsp.getBody(), rsp.getStatusCode());
}
}
webClient.putForEntity(url, jsonStr).block();
return new ResponseEntity<>(HttpStatus.OK);
} catch (Exception e) {
- return handleException(e);
+ return ErrorResponseHandler.handleException(e);
}
}
webClient.deleteForEntity(url).block();
return new ResponseEntity<>(HttpStatus.OK);
} catch (Exception e) {
- return handleException(e);
+ return ErrorResponseHandler.handleException(e);
}
}
String json = gson.toJson(result);
return new ResponseEntity<>(json, HttpStatus.OK);
} catch (Exception e) {
- return handleException(e);
- }
- }
-
- private ResponseEntity<String> handleException(Exception throwable) {
- if (throwable instanceof HttpClientErrorException) {
- HttpClientErrorException e = (HttpClientErrorException) throwable;
- return new ResponseEntity<>(e.getMessage(), e.getStatusCode());
- } else if (throwable instanceof HttpServerErrorException) {
- HttpServerErrorException e = (HttpServerErrorException) throwable;
- return new ResponseEntity<>(e.getResponseBodyAsString(), e.getStatusCode());
- } else if (throwable instanceof SSLException) {
- SSLException e = (SSLException) throwable;
- return new ResponseEntity<>("Could not create WebClient " + e.getMessage(),
- HttpStatus.INTERNAL_SERVER_ERROR);
+ return ErrorResponseHandler.handleException(e);
}
- return new ResponseEntity<>(throwable.getMessage(), HttpStatus.INTERNAL_SERVER_ERROR);
}
}
--- /dev/null
+/*-
+ * ========================LICENSE_START=================================
+ * O-RAN-SC
+ * %%
+ * Copyright (C) 2020 Nordix Foundation
+ * %%
+ * 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.oransc.portal.nonrtric.controlpanel.util;
+
+import javax.net.ssl.SSLException;
+import org.springframework.http.HttpStatus;
+import org.springframework.http.ResponseEntity;
+import org.springframework.web.client.HttpClientErrorException;
+import org.springframework.web.client.HttpServerErrorException;
+
+public class ErrorResponseHandler {
+
+ private ErrorResponseHandler() {
+ throw new IllegalStateException("ErrorResponseHandler is a utility class and not meant to be instantiated");
+ }
+
+ public static ResponseEntity<String> handleException(Exception throwable) {
+ if (throwable instanceof HttpClientErrorException) {
+ HttpClientErrorException e = (HttpClientErrorException) throwable;
+ return new ResponseEntity<>(e.getMessage(), e.getStatusCode());
+ } else if (throwable instanceof HttpServerErrorException) {
+ HttpServerErrorException e = (HttpServerErrorException) throwable;
+ return new ResponseEntity<>(e.getResponseBodyAsString(), e.getStatusCode());
+ } else if (throwable instanceof SSLException) {
+ SSLException e = (SSLException) throwable;
+ return new ResponseEntity<>("Could not create WebClient " + e.getMessage(),
+ HttpStatus.INTERNAL_SERVER_ERROR);
+ }
+ return new ResponseEntity<>(throwable.getClass().getName() + ": " + throwable.getMessage(),
+ HttpStatus.INTERNAL_SERVER_ERROR);
+ }
+}
import org.springframework.web.client.HttpServerErrorException;
import reactor.core.publisher.Mono;
-public class EiProducerApiImplTest {
+class EiProducerApiImplTest {
private static final String URL_EI_TYPES = "/eitypes";
private static final String EI_TYPE_1 = "eitype1";
private static final String EI_TYPE_2 = "eitype2";