X-Git-Url: https://gerrit.o-ran-sc.org/r/gitweb?a=blobdiff_plain;f=policy-agent%2Fsrc%2Fmain%2Fjava%2Forg%2Foransc%2Fpolicyagent%2Fclients%2FOscA1Client.java;h=9384726db41ba8ec49a70cb68f98f9cc167712bd;hb=99dbc2588e004ad1c5a6bac78265e3875a669878;hp=e7a15878ed17a7155c3b2b17c6820b8591e46c49;hpb=9013ed7ad46ce6927fbf69890487e8df61b7d7ee;p=nonrtric.git diff --git a/policy-agent/src/main/java/org/oransc/policyagent/clients/OscA1Client.java b/policy-agent/src/main/java/org/oransc/policyagent/clients/OscA1Client.java index e7a15878..9384726d 100644 --- a/policy-agent/src/main/java/org/oransc/policyagent/clients/OscA1Client.java +++ b/policy-agent/src/main/java/org/oransc/policyagent/clients/OscA1Client.java @@ -28,46 +28,78 @@ import org.oransc.policyagent.configuration.RicConfig; import org.oransc.policyagent.repository.Policy; import org.slf4j.Logger; import org.slf4j.LoggerFactory; -import org.springframework.web.util.UriComponentsBuilder; import reactor.core.publisher.Flux; import reactor.core.publisher.Mono; +@SuppressWarnings("squid:S2629") // Invoke method(s) only conditionally public class OscA1Client implements A1Client { - private static final String URL_PREFIX = "/a1-p"; - private static final String POLICY_TYPES = "/policytypes"; - private static final String CREATE_SCHEMA = "create_schema"; - private static final String TITLE = "title"; + public static class UriBuilder implements A1UriBuilder { + private final RicConfig ricConfig; + + public UriBuilder(RicConfig ricConfig) { + this.ricConfig = ricConfig; + } - private static final String HEALTHCHECK = "/healthcheck"; + @Override + public String createPutPolicyUri(String type, String policyId) { + return createPolicyUri(type, policyId); + } + + public String createGetPolicyIdsUri(String type) { + return createPolicyTypeUri(type) + "/policies"; + } - private static final UriComponentsBuilder POLICY_TYPE_SCHEMA_URI = - UriComponentsBuilder.fromPath("/policytypes/{policy-type-name}"); + @Override + public String createDeleteUri(String type, String policyId) { + return createPolicyUri(type, policyId); + } - private static final UriComponentsBuilder POLICY_URI = - UriComponentsBuilder.fromPath("/policytypes/{policy-type-name}/policies/{policy-id}"); + @Override + public String createGetPolicyStatusUri(String type, String policyId) { + return createPolicyUri(type, policyId) + "/status"; + } - private static final UriComponentsBuilder POLICY_IDS_URI = - UriComponentsBuilder.fromPath("/policytypes/{policy-type-name}/policies"); + public String createHealtcheckUri() { + return baseUri() + "/healthcheck"; + } - private static final UriComponentsBuilder POLICY_STATUS_URI = - UriComponentsBuilder.fromPath("/policytypes/{policy-type-name}/policies/{policy-id}/status"); + public String createGetSchemaUri(String type) { + return this.createPolicyTypeUri(type); + } - private static final Logger logger = LoggerFactory.getLogger(MethodHandles.lookup().lookupClass()); + public String createPolicyTypesUri() { + return baseUri() + "/policytypes"; + } + private String createPolicyUri(String type, String id) { + return createPolicyTypeUri(type) + "/policies/" + id; + } + + private String createPolicyTypeUri(String type) { + return createPolicyTypesUri() + "/" + type; + } + + private String baseUri() { + return ricConfig.baseUrl() + "/a1-p"; + } + } + + private static final String TITLE = "title"; + private static final Logger logger = LoggerFactory.getLogger(MethodHandles.lookup().lookupClass()); private final AsyncRestClient restClient; + private final UriBuilder uri; public OscA1Client(RicConfig ricConfig) { - String baseUrl = ricConfig.baseUrl() + URL_PREFIX; - this.restClient = new AsyncRestClient(baseUrl); - if (logger.isDebugEnabled()) { - logger.debug("OscA1Client for ric: {}", ricConfig.name()); - } + this(ricConfig, new AsyncRestClient("")); } - public OscA1Client(AsyncRestClient restClient) { + public OscA1Client(RicConfig ricConfig, AsyncRestClient restClient) { this.restClient = restClient; + logger.debug("OscA1Client for ric: {}", ricConfig.name()); + + uri = new UriBuilder(ricConfig); } @Override @@ -85,15 +117,15 @@ public class OscA1Client implements A1Client { @Override public Mono getPolicyTypeSchema(String policyTypeId) { - String uri = POLICY_TYPE_SCHEMA_URI.buildAndExpand(policyTypeId).toUriString(); - return restClient.get(uri) // + String schemaUri = uri.createGetSchemaUri(policyTypeId); + return restClient.get(schemaUri) // .flatMap(response -> getCreateSchema(response, policyTypeId)); } @Override public Mono putPolicy(Policy policy) { - String uri = POLICY_URI.buildAndExpand(policy.type().name(), policy.id()).toUriString(); - return restClient.put(uri, policy.json()); + String policyUri = this.uri.createPutPolicyUri(policy.type().name(), policy.id()); + return restClient.put(policyUri, policy.json()); } @Override @@ -103,7 +135,7 @@ public class OscA1Client implements A1Client { @Override public Mono getProtocolVersion() { - return restClient.get(HEALTHCHECK) // + return restClient.get(uri.createHealtcheckUri()) // .flatMap(notUsed -> Mono.just(A1ProtocolType.OSC_V1)); } @@ -115,36 +147,37 @@ public class OscA1Client implements A1Client { @Override public Mono getPolicyStatus(Policy policy) { - String uri = POLICY_STATUS_URI.buildAndExpand(policy.type().name(), policy.id()).toUriString(); - return restClient.get(uri); + String statusUri = uri.createGetPolicyStatusUri(policy.type().name(), policy.id()); + return restClient.get(statusUri); } private Flux getPolicyTypeIds() { - return restClient.get(POLICY_TYPES) // + return restClient.get(uri.createPolicyTypesUri()) // .flatMapMany(JsonHelper::parseJsonArrayOfString); } private Flux getPolicyIdentitiesByType(String typeId) { - return restClient.get(POLICY_IDS_URI.buildAndExpand(typeId).toUriString()) // + return restClient.get(uri.createGetPolicyIdsUri(typeId)) // .flatMapMany(JsonHelper::parseJsonArrayOfString); } private Mono getCreateSchema(String policyTypeResponse, String policyTypeId) { try { JSONObject obj = new JSONObject(policyTypeResponse); - JSONObject schemaObj = obj.getJSONObject(CREATE_SCHEMA); + JSONObject schemaObj = obj.getJSONObject("create_schema"); schemaObj.put(TITLE, policyTypeId); return Mono.just(schemaObj.toString()); } catch (Exception e) { - logger.error("Unexcpected response for policy type: {}", policyTypeResponse, e); + String exceptionString = e.toString(); + logger.error("Unexpected response for policy type: {}, exception: {}", policyTypeResponse, exceptionString); return Mono.error(e); } } private Mono deletePolicyById(String typeId, String policyId) { - String uri = POLICY_URI.buildAndExpand(typeId, policyId).toUriString(); - return restClient.delete(uri); + String policyUri = uri.createDeleteUri(typeId, policyId); + return restClient.delete(policyUri); } private Flux deletePoliciesForType(String typeId) {