ref #10480: the term cache is filled with avail terms during connection
[taxeditor.git] / eu.etaxonomy.taxeditor.store / src / main / java / eu / etaxonomy / taxeditor / preference / CdmPreferenceCache.java
old mode 100755 (executable)
new mode 100644 (file)
index 77abbc0..6bc4bb5
@@ -9,12 +9,14 @@
 package eu.etaxonomy.taxeditor.preference;
 
 import java.util.ArrayList;
+import java.util.Collection;
 import java.util.HashMap;
 import java.util.List;
 import java.util.Map;
 import java.util.UUID;
 
-import org.apache.log4j.Logger;
+import org.apache.logging.log4j.LogManager;
+import org.apache.logging.log4j.Logger;
 
 import eu.etaxonomy.cdm.api.application.ICdmRepository;
 import eu.etaxonomy.cdm.api.service.ITermService;
@@ -23,24 +25,20 @@ import eu.etaxonomy.cdm.model.metadata.CdmPreference.PrefKey;
 import eu.etaxonomy.cdm.model.metadata.PreferencePredicate;
 import eu.etaxonomy.cdm.model.metadata.PreferenceResolver;
 import eu.etaxonomy.cdm.model.metadata.PreferenceSubject;
-import eu.etaxonomy.cdm.model.term.DefinedTermBase;
 import eu.etaxonomy.cdm.model.term.TermType;
+import eu.etaxonomy.cdm.persistence.dto.TermDto;
 import eu.etaxonomy.taxeditor.store.CdmStore;
-import eu.etaxonomy.taxeditor.store.TermStore;
 
 /**
  * @author k.luther
  * @since 27.04.2018
- *
  */
 public class CdmPreferenceCache {
-    Map<String,List<CdmPreference>> preferenceCache = new HashMap();
+    Map<String,List<CdmPreference>> preferenceCache = new HashMap<>();
 
     private static CdmPreferenceCache instance;
 
-    private final static Logger logger = Logger.getLogger(CdmPreferenceCache.class);
-
-
+    private final static Logger logger = LogManager.getLogger();
 
     public static CdmPreferenceCache instance(){
         if(instance == null){
@@ -51,7 +49,6 @@ public class CdmPreferenceCache {
 
     public CdmPreference get(String predicate){
         if (preferenceCache.get(predicate) != null){
-            List<CdmPreference> preferences = preferenceCache.get(predicate);
             if (preferenceCache.get(predicate).size() > 1){
                 CdmPreference pref = PreferenceResolver.resolve(preferenceCache.get(predicate), CdmPreference.NewKey(PreferenceSubject.NewTaxEditorInstance(), PreferencePredicate.getByKey(predicate)));
                 return pref;
@@ -94,12 +91,24 @@ public class CdmPreferenceCache {
             cachedPreferences.remove(prefToRemove);
             cachedPreferences.add(pref);
         }else{
-            List<CdmPreference> prefs = new ArrayList();
+            List<CdmPreference> prefs = new ArrayList<>();
             prefs.add(pref);
             preferenceCache.put(pref.getPredicate(), prefs);
         }
+    }
 
-
+    public boolean remove(CdmPreference pref){
+        if (preferenceCache.containsKey(pref.getPredicate())){
+            List<CdmPreference> cachedPreferences = preferenceCache.get(pref.getPredicate());
+            CdmPreference prefToRemove = null;
+            for (CdmPreference cachedPref:cachedPreferences){
+                if (pref.getKey().equals(cachedPref.getKey())){
+                    prefToRemove = cachedPref;
+                }
+            }
+            cachedPreferences.remove(prefToRemove);
+        }
+        return true;
     }
 
     public void getAllTaxEditorDBPreferences(){
@@ -112,61 +121,67 @@ public class CdmPreferenceCache {
             put(pref);
         }
 
-        PrefKey key = CdmPreference.NewKey(PreferenceSubject.NewTaxEditorInstance(), PreferencePredicate.AvailableDistributionStatus);
+        loadAndSet(PreferencePredicate.AvailableDistributionStatus, TermType.PresenceAbsenceTerm);
+        loadAndSet(PreferencePredicate.AvailableRanks, TermType.Rank);
+        loadAndSet(PreferencePredicate.AvailableNomenclaturalStatus, TermType.NomenclaturalStatusType);
+        loadAndSet(PreferencePredicate.AvailableNameRelationshipType, TermType.NameRelationshipType);
+        loadAndSet(PreferencePredicate.AvailableLanguages, TermType.Language);
+    }
 
+    private void loadAndSet(PreferencePredicate preferencePredicate, TermType termType) {
+        PrefKey key = CdmPreference.NewKey(PreferenceSubject.NewTaxEditorInstance(), preferencePredicate);
+        boolean checkLocal = false;
         if (get(key) != null){
-            if (!PreferencesUtil.getBooleanValue(PreferencesUtil.prefOverrideKey(PreferencePredicate.AvailableDistributionStatus.getKey())) || !get(key).isAllowOverride()){
+            if (!PreferencesUtil.getOverrideForPreference(preferencePredicate.getKey()) || !get(key).isAllowOverride()){
                 //get terms for the uuids... and add them to the termManager as preferred terms
-                ITermService termService = CdmStore.getService(ITermService.class);
-                List<UUID> uuidList = new ArrayList();
-                if (get(key).getValue() != null){
-                    String[] uuidArray =findBestMatching(key).getValue().split(";");
-                    for (String uuidString:uuidArray){
-                        try {
-                            uuidList.add(UUID.fromString(uuidString));
-                        } catch (Exception e) {
-                            logger.warn("Preference loading failed", e);
-                        }
-                    }
+                Collection<TermDto> dtos = createDtoList(key);
+                if (dtos != null){
+                    CdmStore.getTermManager().setPreferredTermsByType(dtos, termType);
                 }
+            }else {
+                checkLocal = true;
+            }
 
-                List<DefinedTermBase> definedTermBases = termService.load(uuidList, null);
-                CdmStore.getTermManager().setPreferredTerms(definedTermBases, TermStore.getTerms(TermType.PresenceAbsenceTerm, null));
+        }else {
+            checkLocal = true;
+        }
+        if (checkLocal) {
+            List<UUID> uuidList = PreferencesUtil.createUUIDListFromStringPref(preferencePredicate.getKey(), checkLocal);
+            ITermService termService = CdmStore.getService(ITermService.class);
+            Collection<TermDto> dtos = termService.findByUUIDsAsDto(uuidList);
+            if (dtos != null) {
+                CdmStore.getTermManager().setPreferredTermsByType(dtos, termType);
             }
         }
-         key = CdmPreference.NewKey(PreferenceSubject.NewTaxEditorInstance(), PreferencePredicate.AvailableRanks);
+    }
 
-        if (get(key) != null){
-            if (!PreferencesUtil.getBooleanValue(PreferencesUtil.prefOverrideKey(PreferencePredicate.AvailableRanks.getKey())) || !get(key).isAllowOverride()){
-                //get terms for the uuids... and add them to the termManager as preferred terms
-                ITermService termService = CdmStore.getService(ITermService.class);
-                List<UUID> uuidList = new ArrayList();
-                if (get(key).getValue() != null){
-                    String[] uuidArray =findBestMatching(key).getValue().split(";");
-                    for (String uuidString:uuidArray){
-                        try {
-                            uuidList.add(UUID.fromString(uuidString));
-                        } catch (Exception e) {
-                            logger.warn("Preference loading failed", e);
-                        }
-                    }
-                }
+    public Collection<TermDto> createDtoList(PrefKey key) {
+        ITermService termService = CdmStore.getService(ITermService.class);
+        List<UUID> uuidList = createUuidList(key);
+        Collection<TermDto> dtos = termService.findByUUIDsAsDto(uuidList);
+        return dtos;
+    }
 
-                List<DefinedTermBase> definedTermBases = termService.load(uuidList, null);
-                CdmStore.getTermManager().setPreferredTerms(definedTermBases, TermStore.getTerms(TermType.Rank, null));
+    public List<UUID> createUuidList(PrefKey key) {
+        List<UUID> uuidList = new ArrayList<>();
+        if (get(key).getValue() != null){
+            String[] uuidArray =findBestMatching(key).getValue().split(";");
+            for (String uuidString:uuidArray){
+                try {
+                    uuidList.add(UUID.fromString(uuidString));
+                } catch (Exception e) {
+                    logger.warn("Preference loading failed", e);
+                }
             }
         }
+        return uuidList;
     }
 
-
-
     public CdmPreference findBestMatching(PrefKey key) {
-        List<CdmPreference> allPrefs = new ArrayList();
+        List<CdmPreference> allPrefs = new ArrayList<>();
         for (String predicate: preferenceCache.keySet()){
             allPrefs.addAll(preferenceCache.get(predicate));
         }
-       return PreferenceResolver.resolve(allPrefs, key);
-
+        return PreferenceResolver.resolve(allPrefs, key);
     }
-
 }