X-Git-Url: https://gerrit.o-ran-sc.org/r/gitweb?a=blobdiff_plain;f=policy-agent%2Fsrc%2Fmain%2Fjava%2Forg%2Foransc%2Fpolicyagent%2Frepository%2FRic.java;h=df612dc5476981d539854d98d0c8a7549459c8d5;hb=dfbd081159b02601a48162a647848223a9303ebf;hp=bfd8ef65e1316ca8e6e6a640fe4aa9a58cd5be77;hpb=63036ab25f7878781e74b2ca0706b28451f59f27;p=nonrtric.git diff --git a/policy-agent/src/main/java/org/oransc/policyagent/repository/Ric.java b/policy-agent/src/main/java/org/oransc/policyagent/repository/Ric.java index bfd8ef65..df612dc5 100644 --- a/policy-agent/src/main/java/org/oransc/policyagent/repository/Ric.java +++ b/policy-agent/src/main/java/org/oransc/policyagent/repository/Ric.java @@ -20,8 +20,11 @@ package org.oransc.policyagent.repository; +import java.util.Collections; +import java.util.List; +import java.util.Vector; + import org.oransc.policyagent.configuration.RicConfig; -import org.oransc.policyagent.repository.Ric.RicState; /** * Represents the dynamic information about a NearRealtime-RIC. @@ -29,6 +32,7 @@ import org.oransc.policyagent.repository.Ric.RicState; public class Ric { private final RicConfig ricConfig; private RicState state = RicState.NOT_INITIATED; + private Vector supportedPolicyTypes = new Vector<>(); /** * Creates the Ric. Initial state is {@link RicState.NOT_INITIATED}. @@ -51,6 +55,19 @@ public class Ric { state = newState; } + public RicConfig getConfig() { + return this.ricConfig; + } + + /** + * Gets the nodes managed by this Ric. + * + * @return a vector containing the nodes managed by this Ric. + */ + public Vector getManagedNodes() { + return ricConfig.managedElementIds(); + } + /** * Determines if the given node is managed by this Ric. * @@ -81,6 +98,57 @@ public class Ric { ricConfig.managedElementIds().remove(nodeName); } + /** + * Gets the policy types supported by this Ric. + * + * @return the policy types supported by this Ric in an unmodifiable list. + */ + public List getSupportedPolicyTypes() { + return Collections.unmodifiableList(supportedPolicyTypes); + } + + /** + * Adds a policy type as supported by this Ric. + * + * @param type the policy type to support. + */ + public void addSupportedPolicyType(PolicyType type) { + if (!supportedPolicyTypes.contains(type)) { + supportedPolicyTypes.add(type); + } + } + + /** + * Adds policy types as supported by this Ric. + * + * @param types the policy types to support. + */ + public void addSupportedPolicyTypes(Vector types) { + for (PolicyType type : types) { + addSupportedPolicyType(type); + } + } + + /** + * Removes a policy type as supported by this Ric. + * + * @param type the policy type to remove as supported by this Ric. + */ + public void removeSupportedPolicyType(PolicyType type) { + supportedPolicyTypes.remove(type); + } + + /** + * Checks if a type is supported by this Ric. + * + * @param type the type to check if it is supported. + * + * @return true if the given type issupported by this Ric, false otherwise. + */ + public boolean isSupportingType(PolicyType type) { + return supportedPolicyTypes.contains(type); + } + /** * Represents the states possible for a Ric. */