X-Git-Url: https://gerrit.o-ran-sc.org/r/gitweb?a=blobdiff_plain;f=enrichment-coordinator-service%2Fsrc%2Fmain%2Fjava%2Forg%2Foransc%2Fenrichment%2Frepository%2FEiProducers.java;h=f0fc49ff531eafc2348912665ee8282fad09884c;hb=2dbde318f013212c81c4a1f477d7638ec3367aa5;hp=483850d97ed6a30d567eb18df280822bbbd3dfe6;hpb=ebf3211ddd6e634ca9c0a2fec56abd1f12c7625d;p=nonrtric.git diff --git a/enrichment-coordinator-service/src/main/java/org/oransc/enrichment/repository/EiProducers.java b/enrichment-coordinator-service/src/main/java/org/oransc/enrichment/repository/EiProducers.java index 483850d9..f0fc49ff 100644 --- a/enrichment-coordinator-service/src/main/java/org/oransc/enrichment/repository/EiProducers.java +++ b/enrichment-coordinator-service/src/main/java/org/oransc/enrichment/repository/EiProducers.java @@ -20,22 +20,84 @@ package org.oransc.enrichment.repository; +import java.lang.invoke.MethodHandles; +import java.util.ArrayList; import java.util.Collection; import java.util.HashMap; import java.util.Map; import java.util.Vector; +import org.immutables.value.Value.Immutable; +import org.oransc.enrichment.controllers.consumer.ConsumerCallbacks; +import org.oransc.enrichment.controllers.producer.ProducerCallbacks; import org.oransc.enrichment.exceptions.ServiceException; +import org.slf4j.Logger; +import org.slf4j.LoggerFactory; +import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.stereotype.Component; /** - * Dynamic representation of all Rics in the system. + * Dynamic representation of all EiProducers. */ +@SuppressWarnings("squid:S2629") // Invoke method(s) only conditionally +@Component public class EiProducers { - private Map allEiProducers = new HashMap<>(); + private final Logger logger = LoggerFactory.getLogger(MethodHandles.lookup().lookupClass()); + private final Map allEiProducers = new HashMap<>(); + private final MultiMap producersByType = new MultiMap<>(); - public synchronized void put(EiProducer producer) { - allEiProducers.put(producer.id(), producer); + @Autowired + private ProducerCallbacks producerCallbacks; + @Autowired + private ConsumerCallbacks consumerCallbacks; + + @Autowired + private EiJobs eiJobs; + + @Immutable + public interface EiProducerRegistrationInfo { + String id(); + + Collection supportedTypes(); + + String jobCallbackUrl(); + + String producerSupervisionCallbackUrl(); + } + + public EiProducer registerProducer(EiProducerRegistrationInfo producerInfo) { + final String producerId = producerInfo.id(); + EiProducer previousDefinition = this.get(producerId); + if (previousDefinition != null) { + for (EiType type : previousDefinition.getEiTypes()) { + producersByType.remove(type.getId(), producerId); + } + allEiProducers.remove(producerId); + } + + EiProducer producer = createProducer(producerInfo); + allEiProducers.put(producer.getId(), producer); + for (EiType type : producer.getEiTypes()) { + producersByType.put(type.getId(), producer.getId(), producer); + } + + Collection previousTypes = + previousDefinition != null ? previousDefinition.getEiTypes() : new ArrayList<>(); + + producerCallbacks.startEiJobs(producer, this.eiJobs) // + .collectList() // + .flatMapMany(list -> consumerCallbacks.notifyJobStatus(producer.getEiTypes())) // + .collectList() // + .flatMapMany(list -> consumerCallbacks.notifyJobStatus(previousTypes)) // + .subscribe(); + + return producer; + } + + private EiProducer createProducer(EiProducerRegistrationInfo producerInfo) { + return new EiProducer(producerInfo.id(), producerInfo.supportedTypes(), producerInfo.jobCallbackUrl(), + producerInfo.producerSupervisionCallbackUrl()); } public synchronized Collection getAllProducers() { @@ -54,19 +116,49 @@ public class EiProducers { return allEiProducers.get(id); } - public synchronized void remove(String id) { - this.allEiProducers.remove(id); - } - - public synchronized void remove(EiProducer producer) { - this.allEiProducers.remove(producer.id()); - } - public synchronized int size() { return allEiProducers.size(); } public synchronized void clear() { this.allEiProducers.clear(); + this.producersByType.clear(); + } + + public void deregisterProducer(EiProducer producer) { + allEiProducers.remove(producer.getId()); + for (EiType type : producer.getEiTypes()) { + if (producersByType.remove(type.getId(), producer.getId()) == null) { + this.logger.error("Bug, no producer found"); + } + } + this.consumerCallbacks.notifyJobStatus(producer.getEiTypes()) // + .subscribe(); + } + + public synchronized Collection getProducersForType(EiType type) { + return this.producersByType.get(type.getId()); + } + + public synchronized Collection getProducersForType(String typeId) { + return this.producersByType.get(typeId); + } + + public synchronized Collection getProducerIdsForType(String typeId) { + Collection producerIds = new ArrayList<>(); + for (EiProducer p : this.getProducersForType(typeId)) { + producerIds.add(p.getId()); + } + return producerIds; } + + public synchronized boolean isJobEnabled(EiJob job) { + for (EiProducer producer : this.producersByType.get(job.getTypeId())) { + if (producer.isJobEnabled(job)) { + return true; + } + } + return false; + } + }