package org.oransc.policyagent.repository;
-import java.util.ArrayList;
import java.util.Collection;
import java.util.HashMap;
-import java.util.List;
import java.util.Map;
import java.util.Vector;
*/
public class Ric {
- private final RicConfig ricConfig;
- private final List<String> managedElementIds;
-
+ @Setter
+ private RicConfig ricConfig;
private RicState state = RicState.UNDEFINED;
private Map<String, PolicyType> supportedPolicyTypes = new HashMap<>();
@Getter
private final Lock lock = new Lock();
/**
- * Creates the Ric. Initial state is {@link RicState.NOT_INITIATED}.
+ * Creates the Ric. Initial state is {@link RicState.UNDEFINED}.
*
* @param ricConfig The {@link RicConfig} for this Ric.
*/
public Ric(RicConfig ricConfig) {
this.ricConfig = ricConfig;
- this.managedElementIds = new ArrayList<>(ricConfig.managedElementIds()); // TODO, this is config why is it
- // copied here?
}
public String name() {
* @return a vector containing the nodes managed by this Ric.
*/
public synchronized Collection<String> getManagedElementIds() {
- return managedElementIds;
+ return ricConfig.managedElementIds();
}
/**
* @return true if the given node is managed by this Ric.
*/
public synchronized boolean isManaging(String managedElementId) {
- return managedElementIds.contains(managedElementId);
- }
-
- /**
- * Adds the given node as managed by this Ric.
- *
- * @param managedElementId the node to add.
- */
- public synchronized void addManagedElement(String managedElementId) {
- if (!managedElementIds.contains(managedElementId)) {
- managedElementIds.add(managedElementId);
- }
- }
-
- /**
- * Removes the given node as managed by this Ric.
- *
- * @param managedElementId the node to remove.
- */
- public synchronized void removeManagedElement(String managedElementId) {
- managedElementIds.remove(managedElementId);
+ return ricConfig.managedElementIds().contains(managedElementId);
}
/**
@Override
public synchronized String toString() {
return Ric.class.getSimpleName() + ": " + "name: " + name() + ", state: " + state + ", baseUrl: "
- + ricConfig.baseUrl() + ", managedNodes: " + managedElementIds;
+ + ricConfig.baseUrl() + ", managedNodes: " + ricConfig.managedElementIds();
}
/**