Merge branch 'release/5.19.0'
[taxeditor.git] / eu.etaxonomy.taxeditor.store / src / main / java / eu / etaxonomy / taxeditor / preference / CdmPreferenceCache.java
index d1344379bac82b2749de3377edb4021e7d994e16..8ad35eb7bd1be1bf2b0b7b790caf4fb6309bf149 100755 (executable)
@@ -9,6 +9,7 @@
 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;
@@ -18,22 +19,22 @@ import org.apache.log4j.Logger;
 
 import eu.etaxonomy.cdm.api.application.ICdmRepository;
 import eu.etaxonomy.cdm.api.service.ITermService;
-import eu.etaxonomy.cdm.model.common.DefinedTermBase;
-import eu.etaxonomy.cdm.model.common.TermType;
 import eu.etaxonomy.cdm.model.metadata.CdmPreference;
 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, CdmPreference> preferenceCache = new HashMap();
+    Map<String,List<CdmPreference>> preferenceCache = new HashMap<>();
 
     private static CdmPreferenceCache instance;
 
@@ -46,135 +47,167 @@ public class CdmPreferenceCache {
         return instance;
     }
 
-    public CdmPreference get(String key){
-        return preferenceCache.get(key);
-    }
-
-    public void put(CdmPreference pref){
-        preferenceCache.put(pref.getPredicate(), pref);
+    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;
+            }
+            return preferenceCache.get(predicate).get(0);
+        }
+        return null;
     }
 
-    public void getAllTaxEditorDBPreferences(){
-        ICdmRepository controller;
-        controller = CdmStore.getCurrentApplicationConfiguration();
-        //ABCD
-        PrefKey key = CdmPreference.NewKey(PreferenceSubject.NewTaxEditorInstance(), PreferencePredicate.AbcdImportConfig);
-        loadAndPutPreference(controller, key);
-
-        //ShowIOMenu
-        key = CdmPreference.NewKey(PreferenceSubject.NewTaxEditorInstance(), PreferencePredicate.ShowImportExportMenu);
-        loadAndPutPreference(controller, key);
+    public List<CdmPreference> getAllForPredicate(String predicate){
+        if (preferenceCache.get(predicate) != null){
+            return preferenceCache.get(predicate);
 
-//        key = CdmPreference.NewKey(PreferenceSubject.NewTaxEditorInstance(), PreferencePredicate.ShowMediaView);
-//        loadAndPutPreference(controller, key);
-
-        key = CdmPreference.NewKey(PreferenceSubject.NewTaxEditorInstance(), PreferencePredicate.ShowChecklistPerspective);
-        loadAndPutPreference(controller, key);
-
-
-        //Specimen Details
-        key = CdmPreference.NewKey(PreferenceSubject.NewTaxEditorInstance(), PreferencePredicate.ShowSpecimen);
-        loadAndPutPreference(controller, key);
-
-        key = CdmPreference.NewKey(PreferenceSubject.NewTaxEditorInstance(), PreferencePredicate.ShowTaxonAssociations);
-        loadAndPutPreference(controller, key);
+        }
+        return null;
+    }
 
+    //looking for the equal prefkey
+    public CdmPreference get(PrefKey key){
+        if (preferenceCache.containsKey(key.getPredicate())){
+            for (CdmPreference pref: preferenceCache.get(key.getPredicate())){
+                if (pref.getSubjectString().equals(key.getSubject())){
+                    return pref;
+                }
+            }
 
-        key = CdmPreference.NewKey(PreferenceSubject.NewTaxEditorInstance(), PreferencePredicate.ShowCollectingAreasInGeneralSection);
-        loadAndPutPreference(controller, key);
+        }
+        return null;
+    }
 
+    public void put(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);
+            cachedPreferences.add(pref);
+        }else{
+            List<CdmPreference> prefs = new ArrayList<>();
+            prefs.add(pref);
+            preferenceCache.put(pref.getPredicate(), prefs);
+        }
+    }
 
-        key = CdmPreference.NewKey(PreferenceSubject.NewTaxEditorInstance(), PreferencePredicate.ShowLifeForm);
-        loadAndPutPreference(controller, key);
+    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;
+    }
 
-        key = CdmPreference.NewKey(PreferenceSubject.NewTaxEditorInstance(), PreferencePredicate.DeterminationOnlyForFieldUnits);
-        loadAndPutPreference(controller, key);
+    public void getAllTaxEditorDBPreferences(){
+        ICdmRepository controller;
+        controller = CdmStore.getCurrentApplicationConfiguration();
+        List<CdmPreference> allPreferences = controller.getPreferenceService().list();
+        preferenceCache.clear();
 
+        for (CdmPreference pref: allPreferences){
+            put(pref);
+        }
 
-        //Name Details
-        key = CdmPreference.NewKey(PreferenceSubject.NewTaxEditorInstance(), PreferencePredicate.NameDetailsView);
-        loadAndPutPreference(controller, key);
+        PrefKey key = CdmPreference.NewKey(PreferenceSubject.NewTaxEditorInstance(), PreferencePredicate.AvailableDistributionStatus);
 
+        if (get(key) != null){
+            if (!PreferencesUtil.getOverrideForPreference(PreferencePredicate.AvailableDistributionStatus.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);
+                        }
+                    }
+                }
 
-        key = CdmPreference.NewKey(PreferenceSubject.NewTaxEditorInstance(), PreferencePredicate.AvailableDistributionStatus);
-        loadAndPutPreference(controller, key);
+                Collection<TermDto> dtos = termService.findByUUIDsAsDto(uuidList);
+//                List<TermDto> dtos = new ArrayList<>();
+//                for (DefinedTermBase<?> term: definedTermBases){
+//                    dtos.add(TermDto.fromTerm(term));
+//                }
+                CdmStore.getTermManager().setPreferredTermsByType(dtos, TermType.PresenceAbsenceTerm);
+            }
+        }
+         key = CdmPreference.NewKey(PreferenceSubject.NewTaxEditorInstance(), PreferencePredicate.AvailableRanks);
 
-        if (preferenceCache.get(key) != null){
-            if (!PreferencesUtil.getBooleanValue(PreferencesUtil.prefOverrideKey(PreferencePredicate.AvailableDistributionStatus.getKey())) || !preferenceCache.get(key).isAllowOverride()){
+        if (get(key) != null){
+            if (!PreferencesUtil.getOverrideForPreference(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);
-                String[] uuidArray = preferenceCache.get(key).getValue().split(";");
-                List<UUID> uuidList = new ArrayList();
-                for (String uuidString:uuidArray){
-                    try {
-                        uuidList.add(UUID.fromString(uuidString));
-                    } catch (Exception e) {
-                        logger.warn("Preference loading failed", e);
+                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);
+                        }
                     }
                 }
 
                 List<DefinedTermBase> definedTermBases = termService.load(uuidList, null);
-                CdmStore.getTermManager().setPreferredTerms(definedTermBases, TermStore.getTerms(TermType.PresenceAbsenceTerm, null));
+                List<TermDto> dtos = new ArrayList<>();
+                for (DefinedTermBase<?> term: definedTermBases){
+                    dtos.add(TermDto.fromTerm(term));
+                }
+                CdmStore.getTermManager().setPreferredTermsByType(dtos, TermType.Rank);
             }
         }
 
-        key = CdmPreference.NewKey(PreferenceSubject.NewTaxEditorInstance(), PreferencePredicate.AvailableDistributionAreaVocabularies);
-        loadAndPutPreference(controller, key);
-
-
-        key = CdmPreference.NewKey(PreferenceSubject.NewTaxEditorInstance(), PreferencePredicate.DistributionEditorActivated);
-        loadAndPutPreference(controller, key);
-
-        key = CdmPreference.NewKey(PreferenceSubject.NewTaxEditorInstance(), PreferencePredicate.DisplayOfAreasInDistributionEditor);
-        loadAndPutPreference(controller, key);
-
-        key = CdmPreference.NewKey(PreferenceSubject.NewTaxEditorInstance(), PreferencePredicate.DisplayOfStatus);
-        loadAndPutPreference(controller, key);
-
-        key = CdmPreference.NewKey(PreferenceSubject.NewTaxEditorInstance(), PreferencePredicate.ShowRankInDistributionEditor);
-        loadAndPutPreference(controller, key);
-
-        key = CdmPreference.NewKey(PreferenceSubject.NewTaxEditorInstance(), PreferencePredicate.AreasSortedInDistributionEditor);
-        loadAndPutPreference(controller, key);
-
-        key = CdmPreference.NewKey(PreferenceSubject.NewTaxEditorInstance(), PreferencePredicate.OwnDescriptionForDistributionEditor);
-        loadAndPutPreference(controller, key);
-
-        //common names
-
-        key = CdmPreference.NewKey(PreferenceSubject.NewTaxEditorInstance(), PreferencePredicate.CommonNameAreaVocabularies);
-        loadAndPutPreference(controller, key);
-
-        key = CdmPreference.NewKey(PreferenceSubject.NewTaxEditorInstance(), PreferencePredicate.CommonNameReferencesWithMarker);
-        loadAndPutPreference(controller, key);
-
-        //sources
-        key = CdmPreference.NewKey(PreferenceSubject.NewTaxEditorInstance(), PreferencePredicate.ShowIdInSource);
-        loadAndPutPreference(controller, key);
-
-        key = CdmPreference.NewKey(PreferenceSubject.NewTaxEditorInstance(), PreferencePredicate.ShowNamespaceInSource);
-        loadAndPutPreference(controller, key);
-
-        //multiple classifications / taxon navigator
-
-        key = CdmPreference.NewKey(PreferenceSubject.NewTaxEditorInstance(), PreferencePredicate.DisableMultiClassification);
-        loadAndPutPreference(controller, key);
-
-
-        key = CdmPreference.NewKey(PreferenceSubject.NewTaxEditorInstance(), PreferencePredicate.ShowTaxonNodeWizard);
-        loadAndPutPreference(controller, key);
+        key = CdmPreference.NewKey(PreferenceSubject.NewTaxEditorInstance(), PreferencePredicate.AvailableNomenclaturalStatus);
 
+        if (get(key) != null){
+            if (!PreferencesUtil.getOverrideForPreference(PreferencePredicate.AvailableNomenclaturalStatus.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);
+                        }
+                    }
+                }
 
+                List<DefinedTermBase> definedTermBases = termService.load(uuidList, null);
+                List<TermDto> dtos = new ArrayList<>();
+                for (DefinedTermBase<?> term: definedTermBases){
+                    dtos.add(TermDto.fromTerm(term));
+                }
+                CdmStore.getTermManager().setPreferredTermsByType(dtos, TermType.NomenclaturalStatusType);
+            }
+        }
     }
 
-    private void loadAndPutPreference(ICdmRepository controller, PrefKey key) {
-        if (controller == null){
-            return ;
-        }
-        CdmPreference preference = controller.getPreferenceService().find(key);
-        if (preference != null){
-            put(preference);
+    public CdmPreference findBestMatching(PrefKey key) {
+        List<CdmPreference> allPrefs = new ArrayList<>();
+        for (String predicate: preferenceCache.keySet()){
+            allPrefs.addAll(preferenceCache.get(predicate));
         }
+        return PreferenceResolver.resolve(allPrefs, key);
     }
-
 }