X-Git-Url: https://gerrit.o-ran-sc.org/r/gitweb?a=blobdiff_plain;f=policy-agent%2Fsrc%2Fmain%2Fjava%2Forg%2Foransc%2Fpolicyagent%2Fclients%2FA1ClientFactory.java;h=8f9169dd419b605499a6d5f1bbaeb9d3e2e7fe97;hb=deb5bb7b792ba3ac90e4c622cd804c83e4647b92;hp=636a69f6e07fca32c5776e652cd8ed66855eb0fd;hpb=889b38fd05bc9143647827742e3a8e0f10783bc8;p=nonrtric.git diff --git a/policy-agent/src/main/java/org/oransc/policyagent/clients/A1ClientFactory.java b/policy-agent/src/main/java/org/oransc/policyagent/clients/A1ClientFactory.java index 636a69f6..8f9169dd 100644 --- a/policy-agent/src/main/java/org/oransc/policyagent/clients/A1ClientFactory.java +++ b/policy-agent/src/main/java/org/oransc/policyagent/clients/A1ClientFactory.java @@ -22,6 +22,7 @@ package org.oransc.policyagent.clients; import org.oransc.policyagent.clients.A1Client.A1ProtocolType; import org.oransc.policyagent.configuration.ApplicationConfig; +import org.oransc.policyagent.exceptions.ServiceException; import org.oransc.policyagent.repository.Ric; import org.slf4j.Logger; import org.slf4j.LoggerFactory; @@ -61,27 +62,40 @@ public class A1ClientFactory { */ public Mono createA1Client(Ric ric) { return getProtocolVersion(ric) // - .flatMap(version -> createA1Client(ric, version)); + .flatMap(version -> createA1ClientMono(ric, version)); } - private Mono createA1Client(Ric ric, A1ProtocolType version) { + A1Client createClient(Ric ric, A1ProtocolType version) { if (version == A1ProtocolType.STD_V1) { - return Mono.just(createStdA1ClientImpl(ric)); + return new StdA1ClientVersion1(ric.getConfig()); + } else if (version == A1ProtocolType.STD_V1_1) { + return new StdA1ClientVersion2(ric.getConfig()); } else if (version == A1ProtocolType.OSC_V1) { - return Mono.just(createOscA1Client(ric)); + return new OscA1Client(ric.getConfig()); } else if (version == A1ProtocolType.SDNC_OSC) { - return Mono.just(createSdncOscA1Client(ric)); - } else { // A1ProtocolType.SDNC_ONAP - return Mono.just(createSdncOnapA1Client(ric)); + return new SdncOscA1Client(ric.getConfig(), appConfig.getA1ControllerBaseUrl(), + appConfig.getA1ControllerUsername(), appConfig.getA1ControllerPassword()); + } else if (version == A1ProtocolType.SDNC_ONAP) { + return new SdncOnapA1Client(ric.getConfig(), appConfig.getA1ControllerBaseUrl(), + appConfig.getA1ControllerUsername(), appConfig.getA1ControllerPassword()); + } else { + logger.error("Unhandled protocol: {}", version); + return null; } } + private Mono createA1ClientMono(Ric ric, A1ProtocolType version) { + A1Client c = createClient(ric, version); + return c != null ? Mono.just(c) : Mono.error(new ServiceException("Unhandled protocol: " + version)); + } + private Mono getProtocolVersion(Ric ric) { if (ric.getProtocolVersion() == A1ProtocolType.UNKNOWN) { - return fetchVersion(createSdncOnapA1Client(ric)) // - .onErrorResume(notUsed -> fetchVersion(createSdncOscA1Client(ric))) // - .onErrorResume(notUsed -> fetchVersion(createOscA1Client(ric))) // - .onErrorResume(notUsed -> fetchVersion(createStdA1ClientImpl(ric))) // + return fetchVersion(createClient(ric, A1ProtocolType.STD_V1)) // + .onErrorResume(notUsed -> fetchVersion(createClient(ric, A1ProtocolType.STD_V1_1))) // + .onErrorResume(notUsed -> fetchVersion(createClient(ric, A1ProtocolType.OSC_V1))) // + .onErrorResume(notUsed -> fetchVersion(createClient(ric, A1ProtocolType.SDNC_OSC))) // + .onErrorResume(notUsed -> fetchVersion(createClient(ric, A1ProtocolType.SDNC_ONAP))) // .doOnNext(ric::setProtocolVersion) .doOnNext(version -> logger.debug("Recover ric: {}, protocol version:{}", ric.name(), version)) // .doOnError(notUsed -> logger.warn("Could not get protocol version from RIC: {}", ric.name())); // @@ -90,24 +104,6 @@ public class A1ClientFactory { } } - protected A1Client createOscA1Client(Ric ric) { - return new OscA1Client(ric.getConfig()); - } - - protected A1Client createStdA1ClientImpl(Ric ric) { - return new StdA1Client(ric.getConfig()); - } - - protected A1Client createSdncOscA1Client(Ric ric) { - return new SdncOscA1Client(ric.getConfig(), appConfig.getA1ControllerBaseUrl(), - appConfig.getA1ControllerUsername(), appConfig.getA1ControllerPassword()); - } - - protected A1Client createSdncOnapA1Client(Ric ric) { - return new SdncOnapA1Client(ric.getConfig(), appConfig.getA1ControllerBaseUrl(), - appConfig.getA1ControllerUsername(), appConfig.getA1ControllerPassword()); - } - private Mono fetchVersion(A1Client a1Client) { return Mono.just(a1Client) // .flatMap(client -> a1Client.getProtocolVersion());