Reintegration of the red list branch into trunk
[cdmlib.git] / cdmlib-model / src / main / java / eu / etaxonomy / cdm / model / location / ReferenceSystem.java
index 11244bed665c04b9319a35e4d141d726be2cd632..7103be9878dcf53463d47673eb073a0ccf420d98 100644 (file)
 package eu.etaxonomy.cdm.model.location;
 
 
-import eu.etaxonomy.cdm.model.common.DefinedTermBase;
-import eu.etaxonomy.cdm.model.common.TermVocabulary;
-
-import org.apache.log4j.Logger;
+import java.util.HashMap;
+import java.util.Map;
+import java.util.UUID;
 
-import javax.persistence.*;
+import javax.persistence.Entity;
 import javax.xml.bind.annotation.XmlAccessType;
 import javax.xml.bind.annotation.XmlAccessorType;
 import javax.xml.bind.annotation.XmlRootElement;
 import javax.xml.bind.annotation.XmlType;
 
+import org.apache.log4j.Logger;
+import org.hibernate.envers.Audited;
+import org.hibernate.search.annotations.Indexed;
+
+import eu.etaxonomy.cdm.model.common.DefaultTermInitializer;
+import eu.etaxonomy.cdm.model.common.DefinedTermBase;
+import eu.etaxonomy.cdm.model.common.TermVocabulary;
+
 /**
  * Reference systems for coordinates also according to OGC (Open Geographical
  * Consortium) The list should be extensible at runtime through configuration.
@@ -33,11 +40,21 @@ import javax.xml.bind.annotation.XmlType;
 @XmlType(name = "ReferenceSystem")
 @XmlRootElement(name = "ReferenceSystem")
 @Entity
-//@Audited
+@Indexed(index = "eu.etaxonomy.cdm.model.common.DefinedTermBase")
+@Audited
 public class ReferenceSystem extends DefinedTermBase<ReferenceSystem> {
-       private static final long serialVersionUID = 2704455299046749175L;
+       private static final long serialVersionUID = -9060720949197749047L;
+
+       @SuppressWarnings("unused")
        private static final Logger logger = Logger.getLogger(ReferenceSystem.class);
 
+       protected static Map<UUID, ReferenceSystem> termMap = null;             
+
+       private static final UUID uuidWGS84 = UUID.fromString("63f4dd55-00fa-49e7-96fd-2b7059a1c1ee");
+       private static final UUID uuidGoogleEarth = UUID.fromString("1bb67042-2814-4b09-9e76-c8c1e68aa281");
+       private static final UUID uuidGazetteer = UUID.fromString("e35f1d1c-9347-4190-bd47-a3b00632fcf3");
+       
+       
        /**
         * Factory method
         * @return
@@ -57,28 +74,54 @@ public class ReferenceSystem extends DefinedTermBase<ReferenceSystem> {
        /**
         * Constructor
         */
-       private ReferenceSystem() {
-               super();
+       public ReferenceSystem() {
        }
-
+       
        /**
         * Constructor
         */
-       public ReferenceSystem(String term, String label, String labelAbbrev) {
+       private ReferenceSystem(String term, String label, String labelAbbrev) {
                super(term, label, labelAbbrev);
        }
 
+// ************************************* MTEHODS ***************************************************/  
+       
+       /* (non-Javadoc)
+        * @see eu.etaxonomy.cdm.model.common.DefinedTermBase#resetTerms()
+        */
+       @Override
+       public void resetTerms(){
+               termMap = null;
+       }
+
+       
 
+       protected static ReferenceSystem getTermByUuid(UUID uuid){
+               if (termMap == null){
+                       DefaultTermInitializer vocabularyStore = new DefaultTermInitializer();
+                       vocabularyStore.initialize();
+               }
+               return (ReferenceSystem)termMap.get(uuid);
+       }
+       
        public static final ReferenceSystem WGS84(){
-               logger.warn("not yet implemented");
-               return null;
+               return getTermByUuid(uuidWGS84);
+       }
+       
+       public static final ReferenceSystem GOOGLE_EARTH(){
+               return getTermByUuid(uuidGoogleEarth);
        }
 
+       public static final ReferenceSystem GAZETTEER(){
+               return getTermByUuid(uuidGazetteer);
+       }
+       
        @Override
-       protected void setDefaultTerms(
-                       TermVocabulary<ReferenceSystem> termVocabulary) {
-               // TODO Auto-generated method stub
-               
+       protected void setDefaultTerms(TermVocabulary<ReferenceSystem> termVocabulary){
+               termMap = new HashMap<UUID, ReferenceSystem>();
+               for (ReferenceSystem term : termVocabulary.getTerms()){
+                       termMap.put(term.getUuid(), term); 
+               }
        }
 
 }
\ No newline at end of file