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 {
@Override
public ResponseEntity<String> getAllPolicyTypes() {
+ final String TITLE = "title";
try {
final String url = "/policy_schemas";
ResponseEntity<String> rsp = webClient.getForEntity(url).block();
}
PolicyTypes result = new PolicyTypes();
-
JsonArray schemas = JsonParser.parseString(rsp.getBody()).getAsJsonArray();
for (JsonElement schema : schemas) {
JsonObject schemaObj = schema.getAsJsonObject();
- if (schemaObj.get("title") != null) {
- String title = schemaObj.get("title").getAsString();
- String schemaAsStr = schemaObj.toString();
- PolicyType pt = new PolicyType(title, schemaAsStr);
- result.add(pt);
- } else {
- logger.warn("Ignoring schema: {}", schemaObj);
+ String title = "";
+ if (schemaObj.get(TITLE) != null) {
+ title = schemaObj.get(TITLE).getAsString();
}
+ PolicyType pt = new PolicyType(title, schemaObj.toString());
+ result.add(pt);
}
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);
}
}