X-Git-Url: https://gerrit.o-ran-sc.org/r/gitweb?a=blobdiff_plain;f=policy-agent%2Fsrc%2Fmain%2Fjava%2Forg%2Foransc%2Fpolicyagent%2Frepository%2FPolicies.java;h=4e2ebfa03bae9650787e2b19b900c6b6f5bfe619;hb=7de2f355ed1956001d15cb7e57fdd37fdf88cdc5;hp=54f876ac44a8d261d36292a80792af4b4d492d86;hpb=9013ed7ad46ce6927fbf69890487e8df61b7d7ee;p=nonrtric.git diff --git a/policy-agent/src/main/java/org/oransc/policyagent/repository/Policies.java b/policy-agent/src/main/java/org/oransc/policyagent/repository/Policies.java index 54f876ac..4e2ebfa0 100644 --- a/policy-agent/src/main/java/org/oransc/policyagent/repository/Policies.java +++ b/policy-agent/src/main/java/org/oransc/policyagent/repository/Policies.java @@ -25,6 +25,7 @@ import java.util.Collections; import java.util.HashMap; import java.util.Map; import java.util.Set; +import java.util.Vector; import org.oransc.policyagent.exceptions.ServiceException; @@ -60,7 +61,7 @@ public class Policies { if (map == null) { return Collections.emptyList(); } - return Collections.unmodifiableCollection(map.values()); + return new Vector<>(map.values()); } public synchronized boolean containsPolicy(String id) { @@ -80,7 +81,7 @@ public class Policies { } public synchronized Collection getAll() { - return Collections.unmodifiableCollection(policiesId.values()); + return new Vector<>(policiesId.values()); } public synchronized Collection getForService(String service) { @@ -110,6 +111,13 @@ public class Policies { multiMapRemove(policiesType, policy.type().name(), policy); } + public synchronized void removePoliciesForRic(String ricName) { + Collection policiesForRic = getForRic(ricName); + for (Policy policy : policiesForRic) { + remove(policy); + } + } + public synchronized int size() { return policiesId.size(); }