2 * ========================LICENSE_START=================================
5 * Copyright (C) 2019 Nordix Foundation
7 * Licensed under the Apache License, Version 2.0 (the "License");
8 * you may not use this file except in compliance with the License.
9 * You may obtain a copy of the License at
11 * http://www.apache.org/licenses/LICENSE-2.0
13 * Unless required by applicable law or agreed to in writing, software
14 * distributed under the License is distributed on an "AS IS" BASIS,
15 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
16 * See the License for the specific language governing permissions and
17 * limitations under the License.
18 * ========================LICENSE_END===================================
21 package org.oransc.policyagent.repository;
23 import java.util.Vector;
25 import org.oransc.policyagent.configuration.RicConfig;
28 * Represents the dynamic information about a NearRealtime-RIC.
31 private final RicConfig ricConfig;
32 private RicState state = RicState.NOT_INITIATED;
35 * Creates the Ric. Initial state is {@link RicState.NOT_INITIATED}.
37 * @param ricConfig The {@link RicConfig} for this Ric.
39 public Ric(RicConfig ricConfig) {
40 this.ricConfig = ricConfig;
43 public String name() {
44 return ricConfig.name();
47 public RicState state() {
51 public void setState(RicState newState) {
56 * Gets the nodes managed by this Ric.
58 * @return a vector containing the nodes managed by this Ric.
60 public Vector<String> getManagedNodes() {
61 return ricConfig.managedElementIds();
65 * Determines if the given node is managed by this Ric.
67 * @param nodeName the node name to check.
68 * @return true if the given node is managed by this Ric.
70 public boolean isManaging(String nodeName) {
71 return ricConfig.managedElementIds().contains(nodeName);
75 * Adds the given node as managed by this Ric.
77 * @param nodeName the node to add.
79 public void addManagedNode(String nodeName) {
80 if (!ricConfig.managedElementIds().contains(nodeName)) {
81 ricConfig.managedElementIds().add(nodeName);
86 * Removes the given node as managed by this Ric.
88 * @param nodeName the node to remove.
90 public void removeManagedNode(String nodeName) {
91 ricConfig.managedElementIds().remove(nodeName);
95 * Represents the states possible for a Ric.
97 public static enum RicState {
99 * The Ric has not been initiated yet.
103 * The Ric is working fine.
107 * Something is wrong with the Ric.
111 * The node is unreachable at the moment.