X-Git-Url: https://gerrit.o-ran-sc.org/r/gitweb?a=blobdiff_plain;f=policy-agent%2Fsrc%2Fmain%2Fjava%2Forg%2Foransc%2Fpolicyagent%2Fclients%2FA1ClientImpl.java;h=b3773b8e0910413c92461e916acae75ef6dfd5c8;hb=b47a7130c10bef2bf812366ca971e4eaa938b152;hp=f621566e70aeebbf9aad0bcb51ffc553b26a060e;hpb=581b06ef3c0536416575de7fb7315ba95b849c92;p=nonrtric.git diff --git a/policy-agent/src/main/java/org/oransc/policyagent/clients/A1ClientImpl.java b/policy-agent/src/main/java/org/oransc/policyagent/clients/A1ClientImpl.java index f621566e..b3773b8e 100644 --- a/policy-agent/src/main/java/org/oransc/policyagent/clients/A1ClientImpl.java +++ b/policy-agent/src/main/java/org/oransc/policyagent/clients/A1ClientImpl.java @@ -22,6 +22,7 @@ package org.oransc.policyagent.clients; import java.lang.invoke.MethodHandles; import java.util.ArrayList; +import java.util.Collection; import java.util.List; import org.json.JSONArray; @@ -29,8 +30,6 @@ import org.json.JSONException; import org.json.JSONObject; import org.slf4j.Logger; import org.slf4j.LoggerFactory; - -import reactor.core.publisher.Flux; import reactor.core.publisher.Mono; public class A1ClientImpl implements A1Client { @@ -45,19 +44,19 @@ public class A1ClientImpl implements A1Client { } @Override - public Flux getPolicyTypeIdentities(String nearRtRicUrl) { + public Mono> getPolicyTypeIdentities(String nearRtRicUrl) { logger.debug("getPolicyTypeIdentities nearRtRicUrl = {}", nearRtRicUrl); AsyncRestClient client = createClient(nearRtRicUrl); - Mono response = client.get("/policytypes/identities"); - return response.flatMapMany(this::createFlux); + return client.get("/policytypes/identities") // + .flatMap(this::parseJsonArrayOfString); } @Override - public Flux getPolicyIdentities(String nearRtRicUrl) { + public Mono> getPolicyIdentities(String nearRtRicUrl) { logger.debug("getPolicyIdentities nearRtRicUrl = {}", nearRtRicUrl); AsyncRestClient client = createClient(nearRtRicUrl); - Mono response = client.get("/policies/identities"); - return response.flatMapMany(this::createFlux); + return client.get("/policies/identities") // + .flatMap(this::parseJsonArrayOfString); } @Override @@ -84,7 +83,7 @@ public class A1ClientImpl implements A1Client { return client.delete("/policies/" + policyId); } - private Flux createFlux(String inputString) { + private Mono> parseJsonArrayOfString(String inputString) { try { List arrayList = new ArrayList<>(); JSONArray jsonArray = new JSONArray(inputString); @@ -92,9 +91,9 @@ public class A1ClientImpl implements A1Client { arrayList.add(jsonArray.getString(i)); } logger.debug("A1 client: received list = {}", arrayList); - return Flux.fromIterable(arrayList); + return Mono.just(arrayList); } catch (JSONException ex) { // invalid json - return Flux.error(ex); + return Mono.error(ex); } }