changed flush mode to COMMIT. Solves lots of issues regarding hibernate conversations.
[cdmlib.git] / cdmlib-services / src / main / java / eu / etaxonomy / cdm / api / service / NameServiceImpl.java
index d781f8c0fbeaaea1886ffcc45f6d1b69a39b7266..0bf6581b18a12b7e5e655c5a1d5e7a2acf34a314 100644 (file)
@@ -1,3 +1,4 @@
+// $Id$\r
 /**\r
 * Copyright (C) 2007 EDIT\r
 * European Distributed Institute of Taxonomy \r
@@ -13,6 +14,7 @@ import java.util.ArrayList;
 import java.util.Collection;\r
 import java.util.List;\r
 import java.util.Map;\r
+import java.util.Set;\r
 import java.util.UUID;\r
 \r
 import org.apache.log4j.Logger;\r
@@ -21,14 +23,18 @@ import org.springframework.beans.factory.annotation.Qualifier;
 import org.springframework.stereotype.Service;\r
 import org.springframework.transaction.annotation.Transactional;\r
 \r
+import eu.etaxonomy.cdm.api.service.config.IIdentifiableEntityServiceConfigurator;\r
+import eu.etaxonomy.cdm.api.service.config.INameServiceConfigurator;\r
 import eu.etaxonomy.cdm.api.service.pager.Pager;\r
 import eu.etaxonomy.cdm.api.service.pager.impl.DefaultPagerImpl;\r
 import eu.etaxonomy.cdm.model.common.Annotation;\r
 import eu.etaxonomy.cdm.model.common.CdmBase;\r
 import eu.etaxonomy.cdm.model.common.OrderedTermVocabulary;\r
 import eu.etaxonomy.cdm.model.common.ReferencedEntityBase;\r
+import eu.etaxonomy.cdm.model.common.RelationshipBase;\r
 import eu.etaxonomy.cdm.model.common.RelationshipTermBase;\r
 import eu.etaxonomy.cdm.model.common.TermVocabulary;\r
+import eu.etaxonomy.cdm.model.common.UuidAndTitleCache;\r
 import eu.etaxonomy.cdm.model.name.BotanicalName;\r
 import eu.etaxonomy.cdm.model.name.HomotypicalGroup;\r
 import eu.etaxonomy.cdm.model.name.HybridRelationship;\r
@@ -37,10 +43,13 @@ import eu.etaxonomy.cdm.model.name.NameRelationship;
 import eu.etaxonomy.cdm.model.name.NameRelationshipType;\r
 import eu.etaxonomy.cdm.model.name.NomenclaturalStatus;\r
 import eu.etaxonomy.cdm.model.name.NomenclaturalStatusType;\r
+import eu.etaxonomy.cdm.model.name.NonViralName;\r
 import eu.etaxonomy.cdm.model.name.Rank;\r
 import eu.etaxonomy.cdm.model.name.TaxonNameBase;\r
 import eu.etaxonomy.cdm.model.name.TypeDesignationBase;\r
-import eu.etaxonomy.cdm.model.name.TypeDesignationStatus;\r
+import eu.etaxonomy.cdm.model.name.SpecimenTypeDesignationStatus;\r
+import eu.etaxonomy.cdm.model.name.TypeDesignationStatusBase;\r
+import eu.etaxonomy.cdm.model.taxon.TaxonBase;\r
 import eu.etaxonomy.cdm.persistence.dao.common.IOrderedTermVocabularyDao;\r
 import eu.etaxonomy.cdm.persistence.dao.common.IReferencedEntityDao;\r
 import eu.etaxonomy.cdm.persistence.dao.common.ITermVocabularyDao;\r
@@ -48,6 +57,8 @@ import eu.etaxonomy.cdm.persistence.dao.name.IHomotypicalGroupDao;
 import eu.etaxonomy.cdm.persistence.dao.name.INomenclaturalStatusDao;\r
 import eu.etaxonomy.cdm.persistence.dao.name.ITaxonNameDao;\r
 import eu.etaxonomy.cdm.persistence.dao.name.ITypeDesignationDao;\r
+import eu.etaxonomy.cdm.persistence.query.MatchMode;\r
+import eu.etaxonomy.cdm.persistence.query.OrderHint;\r
 \r
 \r
 @Service\r
@@ -73,7 +84,7 @@ public class NameServiceImpl extends IdentifiableServiceBase<TaxonNameBase,ITaxo
         * Constructor\r
         */\r
        public NameServiceImpl(){\r
-               logger.debug("Load NameService Bean");\r
+               if (logger.isDebugEnabled()) { logger.debug("Load NameService Bean"); }\r
        }\r
 \r
 //********************* METHODS ****************************************************************//     \r
@@ -82,6 +93,11 @@ public class NameServiceImpl extends IdentifiableServiceBase<TaxonNameBase,ITaxo
                return super.findCdmObjectsByTitle(name);\r
        }\r
        \r
+       public List<NonViralName> getNamesByNameCache(String nameCache){\r
+               List result = dao.findByName(nameCache, MatchMode.EXACT, null, null, null, null);\r
+               return result;\r
+       }\r
+       \r
        public List getNamesByName(String name, CdmBase sessionObject){\r
                return super.findCdmObjectsByTitle(name, sessionObject);\r
        }\r
@@ -93,6 +109,10 @@ public class NameServiceImpl extends IdentifiableServiceBase<TaxonNameBase,ITaxo
        public List findNamesByTitle(String title, CdmBase sessionObject){\r
                return super.findCdmObjectsByTitle(title, sessionObject);\r
        }\r
+       \r
+       public List<TaxonNameBase> findByTitle(IIdentifiableEntityServiceConfigurator config) {\r
+               return super.findByTitle(config);\r
+       }\r
        \r
        public TaxonNameBase<?,?> getTaxonNameByUuid(UUID uuid) {\r
                return super.getCdmObjectByUuid(uuid);\r
@@ -139,12 +159,27 @@ public class NameServiceImpl extends IdentifiableServiceBase<TaxonNameBase,ITaxo
        public List<TypeDesignationBase> getAllTypeDesignations(int limit, int start){\r
                return typeDesignationDao.getAllTypeDesignations(limit, start);\r
        }\r
-       \r
+        /**\r
+        * FIXME Candidate for harmonization\r
+        * homotypicalGroupService.list\r
+        */\r
        public List<HomotypicalGroup> getAllHomotypicalGroups(int limit, int start){\r
                return homotypicalGroupDao.list(limit, start);\r
        }\r
        \r
-       /* (non-Javadoc)\r
+       /**\r
+        * FIXME Candidate for harmonization\r
+        * remove\r
+        */\r
+       @Deprecated\r
+       public List<RelationshipBase> getAllRelationships(int limit, int start){\r
+               return dao.getAllRelationships(limit, start);\r
+       }\r
+       \r
+       /**\r
+        * FIXME Candidate for harmonization\r
+        * is this the same as termService.getVocabulary(VocabularyEnum.Rank) \r
+        * (non-Javadoc)\r
         * @see eu.etaxonomy.cdm.api.service.INameService#getRankVocabulary()\r
         */\r
        public OrderedTermVocabulary<Rank> getRankVocabulary() {\r
@@ -155,7 +190,10 @@ public class NameServiceImpl extends IdentifiableServiceBase<TaxonNameBase,ITaxo
                return rankVocabulary;\r
        }\r
 \r
-       /* (non-Javadoc)\r
+       /**\r
+        * FIXME Candidate for harmonization\r
+        * is this the same as termService.getVocabulary(VocabularyEnum.NameRelationshipType) \r
+        *  (non-Javadoc)\r
         * @see eu.etaxonomy.cdm.api.service.INameService#getNameRelationshipTypeVocabulary()\r
         */\r
        public TermVocabulary<NameRelationshipType> getNameRelationshipTypeVocabulary() {\r
@@ -166,7 +204,10 @@ public class NameServiceImpl extends IdentifiableServiceBase<TaxonNameBase,ITaxo
                return nameRelTypeVocabulary;\r
        }\r
 \r
-       /* (non-Javadoc)\r
+       /**\r
+        * FIXME Candidate for harmonization\r
+        * is this the same as termService.getVocabulary(VocabularyEnum.StatusType) \r
+        * (non-Javadoc)\r
         * @see eu.etaxonomy.cdm.api.service.INameService#getStatusTypeVocabulary()\r
         */\r
        public TermVocabulary<NomenclaturalStatusType> getStatusTypeVocabulary() {\r
@@ -177,17 +218,35 @@ public class NameServiceImpl extends IdentifiableServiceBase<TaxonNameBase,ITaxo
                return nomStatusTypeVocabulary;\r
        }\r
 \r
-       /* (non-Javadoc)\r
+       /**\r
+        * FIXME Candidate for harmonization\r
+        * is this the same as termService.getVocabulary(VocabularyEnum.SpecimenTypeDesignationStatus) \r
+        *  (non-Javadoc)\r
         * @see eu.etaxonomy.cdm.api.service.INameService#getTypeDesignationStatusVocabulary()\r
         */\r
-       public TermVocabulary<TypeDesignationStatus> getTypeDesignationStatusVocabulary() {\r
+       public TermVocabulary<SpecimenTypeDesignationStatus> getSpecimenTypeDesignationStatusVocabulary() {\r
                String uuidString = "ab177bd7-d3c8-4e58-a388-226fff6ba3c2";\r
                UUID uuid = UUID.fromString(uuidString);\r
-               TermVocabulary<TypeDesignationStatus> typeDesigStatusVocabulary = \r
+               TermVocabulary<SpecimenTypeDesignationStatus> typeDesigStatusVocabulary = \r
                        (TermVocabulary)vocabularyDao.findByUuid(uuid);\r
-               return null;\r
+               return typeDesigStatusVocabulary;\r
        }\r
        \r
+       /**\r
+        * FIXME Candidate for harmonization\r
+        * is this the same as termService.getVocabulary(VocabularyEnum.SpecimenTypeDesignationStatus)\r
+        * and also seems to duplicate the above method, differing only in the DAO used and the return type \r
+        * (non-Javadoc)\r
+        * @see eu.etaxonomy.cdm.api.service.INameService#getTypeDesignationStatusVocabulary()\r
+        */\r
+       public OrderedTermVocabulary<SpecimenTypeDesignationStatus> getSpecimenTypeDesignationVocabulary() {\r
+               String uuidString = "ab177bd7-d3c8-4e58-a388-226fff6ba3c2";\r
+               UUID uuid = UUID.fromString(uuidString);\r
+               OrderedTermVocabulary<SpecimenTypeDesignationStatus> typeDesignationVocabulary = \r
+                       (OrderedTermVocabulary)orderedVocabularyDao.findByUuid(uuid);\r
+               return typeDesignationVocabulary;\r
+       }\r
+\r
        public void generateTitleCache() {\r
                logger.warn("Not yet implemented");\r
                // TODO Auto-generated method stub\r
@@ -198,48 +257,121 @@ public class NameServiceImpl extends IdentifiableServiceBase<TaxonNameBase,ITaxo
                this.dao = dao;\r
        }\r
 \r
-       public Pager<HybridRelationship> getHybridNames(BotanicalName name,     HybridRelationshipType type, Integer pageSize, Integer pageNumber) {\r
+       public Pager<HybridRelationship> getHybridNames(BotanicalName name,     HybridRelationshipType type, Integer pageSize, Integer pageNumber, List<OrderHint> orderHints, List<String> propertyPaths) {\r
         Integer numberOfResults = dao.countHybridNames(name, type);\r
                \r
                List<HybridRelationship> results = new ArrayList<HybridRelationship>();\r
                if(numberOfResults > 0) { // no point checking again\r
-                       results = dao.getHybridNames(name, type, pageSize, pageNumber); \r
+                       results = dao.getHybridNames(name, type, pageSize, pageNumber,orderHints,propertyPaths); \r
                }\r
                \r
                return new DefaultPagerImpl<HybridRelationship>(pageNumber, numberOfResults, pageSize, results);\r
        }\r
-\r
-       public Pager<NameRelationship> getRelatedNames(TaxonNameBase name,NameRelationshipType type, Integer pageSize, Integer pageNumber) {\r
-        Integer numberOfResults = dao.countRelatedNames(name, type);\r
+       \r
+       public List<NameRelationship> listFromNameRelationships(TaxonNameBase name, NameRelationshipType type, Integer pageSize, Integer pageNumber, List<OrderHint> orderHints, List<String> propertyPaths) {\r
+               Integer numberOfResults = dao.countNameRelationships(name, NameRelationship.Direction.relatedFrom, type);\r
                \r
                List<NameRelationship> results = new ArrayList<NameRelationship>();\r
                if(numberOfResults > 0) { // no point checking again\r
-                       results = dao.getRelatedNames(name, type, pageSize, pageNumber); \r
+                       results = dao.getNameRelationships(name, NameRelationship.Direction.relatedFrom, type, pageSize, pageNumber, orderHints, propertyPaths); \r
                }\r
+               return results;\r
+       }\r
+\r
+       public Pager<NameRelationship> pageFromNameRelationships(TaxonNameBase name, NameRelationshipType type, Integer pageSize, Integer pageNumber, List<OrderHint> orderHints, List<String> propertyPaths) {\r
+        Integer numberOfResults = dao.countNameRelationships(name, NameRelationship.Direction.relatedFrom, type);\r
                \r
+               List<NameRelationship> results = new ArrayList<NameRelationship>();\r
+               if(numberOfResults > 0) { // no point checking again\r
+                       results = dao.getNameRelationships(name, NameRelationship.Direction.relatedFrom, type, pageSize, pageNumber, orderHints, propertyPaths); \r
+               }\r
                return new DefaultPagerImpl<NameRelationship>(pageNumber, numberOfResults, pageSize, results);\r
        }\r
+       \r
+       public List<NameRelationship> listToNameRelationships(TaxonNameBase name, NameRelationshipType type,\r
+                       Integer pageSize, Integer pageNumber, List<OrderHint> orderHints, List<String> propertyPaths) {\r
 \r
-       public Pager<TypeDesignationBase> getTypeDesignations(TaxonNameBase name,TypeDesignationStatus status, Integer pageSize, Integer pageNumber) {\r
+               Integer numberOfResults = dao.countNameRelationships(name, NameRelationship.Direction.relatedTo, type);\r
+\r
+               List<NameRelationship> results = new ArrayList<NameRelationship>();\r
+               if (numberOfResults > 0) { // no point checking again\r
+                       results = dao.getNameRelationships(name, NameRelationship.Direction.relatedTo, type, pageSize, pageNumber,\r
+                               orderHints, propertyPaths);\r
+               }\r
+               return results;\r
+       }\r
+       \r
+       public Pager<NameRelationship> pageToNameRelationships(TaxonNameBase name, NameRelationshipType type, Integer pageSize, Integer pageNumber, List<OrderHint> orderHints, List<String> propertyPaths) {\r
+               Integer numberOfResults = dao.countNameRelationships(name, NameRelationship.Direction.relatedTo, type);\r
+\r
+               List<NameRelationship> results = new ArrayList<NameRelationship>();\r
+               if (numberOfResults > 0) { // no point checking again\r
+                       results = dao.getNameRelationships(name, NameRelationship.Direction.relatedTo, type, pageSize, pageNumber,\r
+                               orderHints, propertyPaths);\r
+               }\r
+\r
+               return new DefaultPagerImpl<NameRelationship>(pageNumber, numberOfResults, pageSize, results);\r
+       }\r
+\r
+       \r
+       public Pager<TypeDesignationBase> getTypeDesignations(TaxonNameBase name, SpecimenTypeDesignationStatus status, \r
+                       Integer pageSize, Integer pageNumber) { \r
+               return getTypeDesignations(name, status, pageSize, pageNumber, null);\r
+       }\r
+       \r
+       public Pager<TypeDesignationBase> getTypeDesignations(TaxonNameBase name, SpecimenTypeDesignationStatus status, \r
+                               Integer pageSize, Integer pageNumber, List<String> propertyPaths){\r
         Integer numberOfResults = dao.countTypeDesignations(name, status);\r
                \r
                List<TypeDesignationBase> results = new ArrayList<TypeDesignationBase>();\r
                if(numberOfResults > 0) { // no point checking again\r
-                       results = dao.getTypeDesignations(name, status, pageSize, pageNumber); \r
+                       results = dao.getTypeDesignations(name, status, pageSize, pageNumber, propertyPaths); \r
                }\r
                \r
                return new DefaultPagerImpl<TypeDesignationBase>(pageNumber, numberOfResults, pageSize, results);\r
        }\r
-\r
-       public Pager<TaxonNameBase> searchNames(String uninomial,String infraGenericEpithet, String specificEpithet, String infraspecificEpithet, Rank rank, Integer pageSize,  Integer pageNumber) {\r
+       \r
+    /**\r
+     * FIXME Candidate for harmonization\r
+        * rename search\r
+     */\r
+       public Pager<TaxonNameBase> searchNames(String uninomial,String infraGenericEpithet, String specificEpithet, String infraspecificEpithet, Rank rank, Integer pageSize,  Integer pageNumber, List<OrderHint> orderHints,\r
+                       List<String> propertyPaths) {\r
         Integer numberOfResults = dao.countNames(uninomial, infraGenericEpithet, specificEpithet, infraspecificEpithet, rank);\r
                \r
                List<TaxonNameBase> results = new ArrayList<TaxonNameBase>();\r
                if(numberOfResults > 0) { // no point checking again\r
-                       results = dao.searchNames(uninomial, infraGenericEpithet, specificEpithet, infraspecificEpithet, rank, pageSize, pageNumber); \r
+                       results = dao.searchNames(uninomial, infraGenericEpithet, specificEpithet, infraspecificEpithet, rank, pageSize, pageNumber, orderHints, propertyPaths); \r
+               }\r
+               \r
+               return new DefaultPagerImpl<TaxonNameBase>(pageNumber, numberOfResults, pageSize, results);\r
+       }\r
+       \r
+       public Pager<TaxonNameBase> search(Class<? extends TaxonNameBase> clazz, String queryString, Integer pageSize, Integer pageNumber, List<OrderHint> orderHints, List<String> propertyPaths) {\r
+        Integer numberOfResults = dao.count(clazz,queryString);\r
+               \r
+               List<TaxonNameBase> results = new ArrayList<TaxonNameBase>();\r
+               if(numberOfResults > 0) { // no point checking again\r
+                       results = dao.search(clazz,queryString, pageSize, pageNumber, orderHints, propertyPaths); \r
                }\r
                \r
                return new DefaultPagerImpl<TaxonNameBase>(pageNumber, numberOfResults, pageSize, results);\r
        }\r
 \r
+       /* (non-Javadoc)\r
+        * @see eu.etaxonomy.cdm.api.service.INameService#getUuidAndTitleCacheOfNames()\r
+        */\r
+       public List<UuidAndTitleCache> getUuidAndTitleCacheOfNames() {\r
+               return dao.getUuidAndTitleCacheOfNames();\r
+       }\r
+\r
+       /* (non-Javadoc)\r
+        * @see eu.etaxonomy.cdm.api.service.IService#list(java.lang.Class, java.lang.Integer, java.lang.Integer, java.util.List, java.util.List)\r
+        */\r
+       public <TYPE extends TaxonNameBase> Pager<TYPE> list(Class<TYPE> type,\r
+                       Integer pageSize, Integer pageNumber, List<OrderHint> orderHints,\r
+                       List<String> propertyPaths) {\r
+               // TODO Auto-generated method stub\r
+               return null;\r
+       }\r
 }\r