Project

General

Profile

Download (33.7 KB) Statistics
| Branch: | Revision:
1
/**
2
* Copyright (C) 2009 EDIT
3
* European Distributed Institute of Taxonomy
4
* http://www.e-taxonomy.eu
5
*
6
* The contents of this file are subject to the Mozilla Public License Version 1.1
7
* See LICENSE.TXT at the top of this package for the full license terms.
8
*/ 
9

    
10
package eu.etaxonomy.cdm.io.redlist.bfnXml;
11

    
12
import java.util.UUID;
13

    
14
import org.apache.commons.lang.StringUtils;
15
import org.apache.log4j.Logger;
16

    
17
import eu.etaxonomy.cdm.common.ResultWrapper;
18
import eu.etaxonomy.cdm.model.common.RelationshipTermBase;
19
import eu.etaxonomy.cdm.model.name.NomenclaturalCode;
20
import eu.etaxonomy.cdm.model.name.NomenclaturalStatusType;
21
import eu.etaxonomy.cdm.model.name.Rank;
22
import eu.etaxonomy.cdm.model.name.SpecimenTypeDesignationStatus;
23
/*import eu.etaxonomy.cdm.model.reference.Article;
24
import eu.etaxonomy.cdm.model.reference.Book;
25
import eu.etaxonomy.cdm.model.reference.BookSection;
26
import eu.etaxonomy.cdm.model.reference.Journal;
27
import eu.etaxonomy.cdm.model.reference.PersonalCommunication;
28
import eu.etaxonomy.cdm.model.reference.PrintSeries;*/
29
import eu.etaxonomy.cdm.model.reference.Reference;
30
import eu.etaxonomy.cdm.model.reference.ReferenceFactory;
31
//import eu.etaxonomy.cdm.model.reference.WebPage;
32
import eu.etaxonomy.cdm.model.taxon.SynonymRelationshipType;
33
import eu.etaxonomy.cdm.model.taxon.TaxonRelationshipType;
34
import eu.etaxonomy.cdm.strategy.exceptions.UnknownCdmTypeException;
35

    
36
public final class BfnXmlTransformer {
37
	@SuppressWarnings("unused")
38
	private static final Logger logger = Logger.getLogger(BfnXmlTransformer.class);
39

    
40
	//redList state Vocabularies
41
	public static final UUID vocStateRLKat =  UUID.fromString("66bbb391-af8a-423b-9506-a235b61af922");
42
	public static final UUID vocStateRlKatDiff =  UUID.fromString("abe3702e-ddd4-420c-a985-08a0f8138215");
43
	public static final UUID vocStateRlAkt =  UUID.fromString("a0bb10de-35c1-47f5-b700-02ceb0a6b50c");
44
	public static final UUID vocStateRLLang =  UUID.fromString("c48d99db-50b6-469f-879d-8bb781842382");
45
	public static final UUID vocStateRLKurz =  UUID.fromString("46549c3b-d9d0-4d34-9135-4789d5ed6fff");
46
	public static final UUID vocStateRLRisk =  UUID.fromString("ec38db54-07dd-4e48-8976-bfa4813ffa44");
47
	public static final UUID vocStateRLResp =  UUID.fromString("c4763d33-75ea-4387-991f-b767650b4899");
48
	public static final UUID vocStateRLKatOld =  UUID.fromString("e9be0626-e14e-4556-a8af-9d49e6279669");
49
	public static final UUID vocStateRLNeo =  UUID.fromString("6c55ae1d-046d-4b67-89aa-b24c4888df6a");
50
	public static final UUID vocStateRLKatId =  UUID.fromString("c54481b3-bf07-43ce-b1cb-09759e4d2a70");
51
	public static final UUID vocStateRLSpecialCases =  UUID.fromString("ce2f4f8f-4222-429f-938b-77b794ecf704");
52
	public static final UUID vocGermanFederalStates =  UUID.fromString("a80dc3d4-0def-4c9b-97a1-12e8eb7ec87f");
53

    
54
	//redlist feature
55
	public static final UUID featureRLKat =  UUID.fromString("744f8833-619a-4d83-b330-1997c3b2c2f9");
56
	public static final UUID featureRlKatDiff =  UUID.fromString("bf93361d-0c8c-4961-9f60-20bcb1d3dbaf");
57
	public static final UUID featureRlAkt =  UUID.fromString("39b6962b-05ba-4cd6-a1a9-337d5d156e2f");
58
	public static final UUID featureRLLang =  UUID.fromString("f6027318-b17d-49e6-b8eb-7464304044c8");
59
	public static final UUID featureRLKurz =  UUID.fromString("9ecc65b5-7760-4ce7-add0-950bdcc2c792");
60
	public static final UUID featureRLRisk =  UUID.fromString("2c8f8ffa-c604-4385-b428-4485f5650735");
61
	public static final UUID featureRLResp =  UUID.fromString("02d8010f-7d1b-46a3-8c01-b5e6760bfd14");
62
	public static final UUID featureRLKatOld =  UUID.fromString("bbdff68d-4fa0-438d-afb5-cff89791c93f");
63
	public static final UUID featureRLNeo =  UUID.fromString("153c7173-6d3d-4bee-b8f2-cf8e63e0bc25");
64
	public static final UUID featureRLKatId =  UUID.fromString("dc9f5dd2-302c-4a32-bd70-278bbd9abd16");
65
	public static final UUID featureRLTaxComment =  UUID.fromString("b7c05d78-16a4-4b6e-a03b-fa6bb2ed74ae");
66
	public static final UUID featureRLHazardComment =  UUID.fromString("5beb1ebf-8643-4d5f-9849-8087c35455bb");
67
	public static final UUID featureRLSpecialCases =  UUID.fromString("fb92068d-667a-448e-8019-ca4551891b3b");
68
	public static final UUID featureRLLastOccurrence =  UUID.fromString("218a32be-fb87-41c9-8d64-b21b43b47caa");
69
	public static final UUID featureRLAdditionalComment =  UUID.fromString("c610c98e-f242-4f3b-9edd-7b84a9435867");
70
	
71

    
72
	//rl kat state list
73
	public static final UUID stateTermRlKat0 = UUID.fromString("05ff7c0f-2fb2-4c10-9527-a2e0c68d68af");
74
	public static final UUID stateTermRlKat1 = UUID.fromString("76a6defc-41d0-43bf-a15a-997caeefbbce");
75
	public static final UUID stateTermRlKat2 = UUID.fromString("ee6b79b6-8306-42d1-a80a-2963ded7c952");
76
	public static final UUID stateTermRlKat3 = UUID.fromString("309bf199-c0a3-4f01-829a-b10aafda4547");
77
	public static final UUID stateTermRlKatG = UUID.fromString("fdf9c84e-1b76-4aa8-b676-a614591ad320");
78
	public static final UUID stateTermRlKatR = UUID.fromString("a694e7bd-87a4-4d3c-8333-aed5092bcb0e");
79
	public static final UUID stateTermRlKatV = UUID.fromString("b1a6695d-65f9-4c53-9765-fd7b54e1674c");
80
	public static final UUID stateTermRlKatStar = UUID.fromString("1cda0ef4-cace-42e9-8061-4ada41d03974");
81
	public static final UUID stateTermRlKatStar2 = UUID.fromString("539cffb0-29b9-48fd-af6e-abf9c466199c");
82
	public static final UUID stateTermRlKatD = UUID.fromString("4d61cadd-b27e-41da-9c91-f29e96adaf89");
83
	public static final UUID stateTermRlKatDiamond = UUID.fromString("aedc4006-4097-41cd-bab9-f8607ff84519");
84
	public static final UUID stateTermRlKatKN = UUID.fromString("49dc7656-4cef-4b0e-81dd-8422a3d0d06b");
85
	
86
	//rl kat diff state list
87
	public static final UUID stateTermRLKatDiffPlus = UUID.fromString("6bc7ddc2-6f25-4076-a392-2626cb7a4b35");
88
	public static final UUID stateTermRLKatDiffMinus = UUID.fromString("8f6a8c16-195c-4084-a201-8d702f9636e7");
89
	public static final UUID stateTermRLKatDiffEqual = UUID.fromString("5215fd8a-7e70-43a6-abde-4e14966a0e0e");
90
	
91
	//rl kat neo state list
92
	public static final UUID stateTermRLKatNeo = UUID.fromString("d9ae3dc2-99c9-40aa-b724-9810ed52ca15");
93
	
94
	//rl kat akt state list
95
	public static final UUID stateTermRLKatAktEx = UUID.fromString("a36d4251-0ca1-4818-bbf7-4089a9362a7e");
96
	public static final UUID stateTermRLKatAktEs = UUID.fromString("9d2426a2-d845-47df-9607-01addc4e3253");
97
	public static final UUID stateTermRLKatAktSs = UUID.fromString("bde09fdd-459a-4f8e-a83c-ee562e220f52");
98
	public static final UUID stateTermRLKatAktS = UUID.fromString("3f44fbd3-6d02-4cef-a2c7-c29684b4eb20");
99
	public static final UUID stateTermRLKatAktMh = UUID.fromString("88e3cfff-623a-43b0-a708-e4d7125a504c");
100
	public static final UUID stateTermRLKatAktH = UUID.fromString("ec96d3f0-0f32-4121-9636-41c44079c9ea");
101
	public static final UUID stateTermRLKatAktSh = UUID.fromString("1126e1ad-5c06-43b2-bfd5-8327257a41eb");
102
	public static final UUID stateTermRLKatAktQuest = UUID.fromString("2ee9820e-c98d-4d5a-8621-5d7b73be66c2");
103
	public static final UUID stateTermRLKatAktNb = UUID.fromString("5da81f91-0089-4360-b07c-b3b833f8fc8e");
104
	public static final UUID stateTermRLKatAktKn = UUID.fromString("f10865f9-aa13-4cf0-9e6c-cc657103bd13");
105
	
106
	//rl kat lang state list
107
	public static final UUID stateTermRLKatLangLT3 = UUID.fromString("6d23b5f9-ac18-4ecb-9be8-2c6e5e7db736");
108
	public static final UUID stateTermRLKatLangLT2 = UUID.fromString("1bd75728-79ed-427d-b96e-858ddca6103d");
109
	public static final UUID stateTermRLKatLangLT1 = UUID.fromString("b7c592a4-72cd-4914-87f0-05a6b324af43");
110
	public static final UUID stateTermRLKatLangLT = UUID.fromString("5f202b93-6f20-4bae-ba3c-e2792b5451b4");
111
	public static final UUID stateTermRLKatLangEqual = UUID.fromString("d66be068-4a0c-4f95-aa6e-9e5804ceb1f1");
112
	public static final UUID stateTermRLKatLangGT = UUID.fromString("528185c6-3c12-41bd-a1e5-6ee3d729776c");
113
	public static final UUID stateTermRLKatLangQuest = UUID.fromString("53076429-d4ac-427f-a9dc-2c8a15901999");
114
	
115
	//rl kat kurz state list
116
	public static final UUID stateTermRLKatKurzDown3 = UUID.fromString("dd97697c-004a-4860-a553-67695d32a992");
117
	public static final UUID stateTermRLKatKurzDown2 = UUID.fromString("311a531b-8263-4c72-af79-662ffbc26fbe");
118
	public static final UUID stateTermRLKatKurzDown1 = UUID.fromString("d2a2a51f-5c8f-4cef-809a-58162beae5c2");
119
	public static final UUID stateTermRLKatKurzEqual = UUID.fromString("0a8cf4c0-8b7c-49d5-9195-0999a0f202ad");
120
	public static final UUID stateTermRLKatKurzUp = UUID.fromString("13e7c95c-3ca3-435d-b7b6-4889e594bf2a");
121
	public static final UUID stateTermRLKatKurzQuest = UUID.fromString("4eb11517-a874-484d-8390-dbb8c6bda47c");
122
	
123
	//rl kat risk state list
124
	public static final UUID stateTermRLKatRiskMinus = UUID.fromString("4e96c671-e1f7-4273-83e7-6650207b57e0");
125
	public static final UUID stateTermRLKatRiskEqual = UUID.fromString("d3f00d31-26a4-40c0-99d4-55ea3672ff5d");
126
	
127
	//rl kat resp state list
128
	public static final UUID stateTermRLKatRespBang2 = UUID.fromString("d1e6b6cd-bb19-40a3-9d02-33099295e7f7");
129
	public static final UUID stateTermRLKatRespBang1 = UUID.fromString("01856904-aced-4889-b955-d16872bcd0e8");
130
	public static final UUID stateTermRLKatRespBang = UUID.fromString("c432e39e-ec09-41b7-be9b-28e0d76a4cf9");
131
	public static final UUID stateTermRLKatRespQuest = UUID.fromString("4116fbda-a392-417c-be1c-08f5e72f762b");
132
	public static final UUID stateTermRLKatRespNb = UUID.fromString("800328ce-f618-4de1-9237-243f16fbe9f9");
133
	
134
	//rl Kat old state list
135
	public static final UUID stateTermRLKatOld0 = UUID.fromString("1977b29c-8b63-407a-a11b-ada8726ac653");
136
	public static final UUID stateTermRLKatOld1 = UUID.fromString("4f3d3255-7e06-4a4e-83d1-5841beee85d4");
137
	public static final UUID stateTermRLKatOld2 = UUID.fromString("65163104-76db-4c20-a00f-5c7531f42b3b");
138
	public static final UUID stateTermRLKatOld3 = UUID.fromString("3c0fbb9e-b3fa-4bab-ada2-6efb9b6b9155");
139
	public static final UUID stateTermRLKatOldG = UUID.fromString("a3d2daf2-a570-40d7-b08d-d105a30bb5e2");
140
	public static final UUID stateTermRLKatOldR = UUID.fromString("d6e511cb-40aa-48ab-8a0d-2365c984d698");
141
	public static final UUID stateTermRLKatOldV = UUID.fromString("92a6f1ec-6d61-4879-826a-255c34492507");
142
	public static final UUID stateTermRLKatOldStar = UUID.fromString("196310bc-3b8b-43c9-b317-e2b02bff5c8a");
143
	public static final UUID stateTermRLKatOldStar2 = UUID.fromString("7fbc42ed-43b6-4198-a9dc-bb97bacb3b9b");
144
	public static final UUID stateTermRLKatOldD = UUID.fromString("075a456c-2291-436c-9b9c-b06d95bf6fc6");
145
	public static final UUID stateTermRLKatOldNb = UUID.fromString("72faec78-6db9-4471-9a65-c6d2337bd324");
146
	public static final UUID stateTermRLKatOldKn = UUID.fromString("92276f3e-3c09-4761-ba5b-b49697c6d5ce");
147
	public static final UUID stateTermEmpty = UUID.fromString("1d357340-5329-4f43-a454-7f99625a1d71");
148
	public static final UUID stateTermRLSpecialS = UUID.fromString("71fda1f6-a7eb-44a0-aeb8-e7f676096916");
149
	public static final UUID stateTermRLSpecialE = UUID.fromString("ef335a01-f4f1-4a02-95a2-2254aa457774");
150
	public static final UUID stateTermRLSpecialD = UUID.fromString("6b267cc5-49b6-4ebd-87ec-aa574e9cbcc5");
151
	
152
	
153
	public static TaxonRelationshipType concept2TaxonRelation(String conceptStatus) throws UnknownCdmTypeException{
154
		if(conceptStatus == null) {
155
			return null;
156
		}else if(conceptStatus.equalsIgnoreCase("!=")){
157
			return TaxonRelationshipType.CONGRUENT_TO();
158
		}else if(conceptStatus.equalsIgnoreCase("!=,>")){
159
			return TaxonRelationshipType.CONGRUENT_OR_INCLUDES();
160
		}else if(conceptStatus.equalsIgnoreCase("!=,<")){
161
			return TaxonRelationshipType.CONGRUENT_OR_INCLUDED_OR_INCLUDES();
162
		}else if(conceptStatus.equalsIgnoreCase(">")){	
163
			return TaxonRelationshipType.INCLUDES();
164
		}else if(conceptStatus.equalsIgnoreCase(">,><")){
165
			return TaxonRelationshipType.INCLUDES_OR_OVERLAPS();
166
//		}else if(conceptStatus.equalsIgnoreCase("<")){//TODO: should be just Included In
167
//			return TaxonRelationshipType.INCLUDED_OR_INCLUDES();
168
		}else if(conceptStatus.equalsIgnoreCase(">,><")){//TODO: should be Included In Or Overlaps
169
			return TaxonRelationshipType.INCLUDED_OR_INCLUDES_OR_OVERLAPS();
170
		}else if(conceptStatus.equalsIgnoreCase("><")){
171
			return TaxonRelationshipType.OVERLAPS();
172
		}else if(conceptStatus.equalsIgnoreCase("~")){//TODO Included in not here
173
			return TaxonRelationshipType.CONGRUENT_OR_INCLUDES_OR_OVERLAPS();
174
		}else if(conceptStatus.equalsIgnoreCase("?")){
175
			return TaxonRelationshipType.ALL_RELATIONSHIPS();
176
		}else if(conceptStatus.equalsIgnoreCase("/=")){
177
			return TaxonRelationshipType.EXCLUDES();
178
		}else if(conceptStatus.equalsIgnoreCase("\\")){
179
			return TaxonRelationshipType.EXCLUDES();
180
		}
181
		else{
182
			throw new UnknownCdmTypeException("Unknown concept relation status " + conceptStatus);
183
		}
184
	}
185
	
186
	
187
	/** Creates an cdm-Rank by the tcs rank
188
	 */
189
	public static Rank rankCode2Rank (String strRank) throws UnknownCdmTypeException{
190
		if (strRank == null){return null;
191
		//genus group
192
		}else if (strRank.equals("infragen")){return Rank.INFRAGENUS();
193
		}else if (strRank.equals("subgen")){return Rank.SUBGENUS();
194
		}else if (strRank.equals("gen")){return Rank.GENUS();
195
		//genus subdivision
196
		//TODO 
197
		}else if (strRank.equals("aggr")){return Rank.SPECIESAGGREGATE();
198
		}else if (strRank.equals("agg.")){return Rank.SPECIESAGGREGATE();
199
		}else if (strRank.equals("taxinfragen")){return Rank.INFRAGENERICTAXON();
200
		}else if (strRank.equals("subser")){return Rank.SUBSERIES();
201
		}else if (strRank.equals("ser")){return Rank.SERIES();
202
		}else if (strRank.equals("subsect")){return Rank.SUBSECTION_BOTANY();
203
		}else if (strRank.equals("sect")){return Rank.SECTION_BOTANY();
204
		//species group
205
		}else if (strRank.equals("subsp_aggr")){return Rank.SUBSPECIFICAGGREGATE();
206
		}else if (strRank.equals("ssp")){return Rank.SUBSPECIES();
207
		}else if (strRank.equals("subsp.")){return Rank.SUBSPECIES();
208
		}else if (strRank.equals("subsp")){return Rank.SUBSPECIES();
209
		}else if (strRank.equals("sp")){return Rank.SPECIES();
210
		}else if (strRank.equals("spezies")){return Rank.SPECIES();
211
		//below subspecies
212
		}else if (strRank.equals("cand")){return Rank.CANDIDATE();
213
		}else if (strRank.equals("taxinfrasp")){return Rank.INFRASPECIFICTAXON();
214
		}else if (strRank.equals("fsp")){return Rank.SPECIALFORM();
215
		}else if (strRank.equals("subsubfm")){return Rank.SUBSUBFORM();
216
		}else if (strRank.equals("subfm")){return Rank.SUBFORM();
217
		}else if (strRank.equals("fm")){return Rank.FORM();
218
		}else if (strRank.equals("f.")){return Rank.FORM();
219
		}else if (strRank.equals("subsubvar")){return Rank.SUBSUBVARIETY();
220
		}else if (strRank.equals("subvar")){return Rank.SUBVARIETY();
221
		}else if (strRank.equals("var")){return Rank.VARIETY();
222
		}else if (strRank.equals("var.")){return Rank.VARIETY();
223
		//TODO -> see documentation, Bacteria status
224
//		}else if (strRank.equals("pv")){return Rank;
225
//		}else if (strRank.equals("bv")){return Rank.;
226
		}else if (strRank.equals("infrasp")){return Rank.INFRASPECIES();
227
		//above superfamily
228
		}else if (strRank.equals("infraord")){return Rank.INFRAORDER();
229
		}else if (strRank.equals("ord")){return Rank.ORDER();
230
		}else if (strRank.equals("superord")){return Rank.SUPERORDER();
231
		}else if (strRank.equals("infracl")){return Rank.INFRACLASS();
232
		}else if (strRank.equals("subcl")){return Rank.SUBCLASS();
233
		}else if (strRank.equals("cl")){return Rank.CLASS();
234
		}else if (strRank.equals("supercl")){return Rank.SUPERCLASS();
235
		}else if (strRank.equals("infraphyl_div")){return Rank.INFRAPHYLUM();
236
		}else if (strRank.equals("subphyl_div")){return Rank.SUBPHYLUM();
237
		}else if (strRank.equals("phyl_div")){return Rank.PHYLUM();
238
		}else if (strRank.equals("superphyl_div")){return Rank.SUPERPHYLUM();
239
		}else if (strRank.equals("infrareg")){return Rank.INFRAKINGDOM();
240
		}else if (strRank.equals("subreg")){return Rank.SUBKINGDOM();
241
		}else if (strRank.equals("reg")){return Rank.KINGDOM();
242
		}else if (strRank.equals("superreg")){return Rank.SUPERKINGDOM();
243
		}else if (strRank.equals("dom")){return Rank.DOMAIN();
244
		}else if (strRank.equals("taxsupragen")){return Rank.SUPRAGENERICTAXON();
245
		}else if (strRank.equals("Auswertungsgruppe")){return Rank.EMPIRE();
246
		//family group
247
		}else if (strRank.equals("infrafam")){return Rank.FAMILY();
248
		}else if (strRank.equals("subfam")){return Rank.FAMILY();
249
		}else if (strRank.equals("fam")){return Rank.FAMILY();
250
		}else if (strRank.equals("superfam")){return Rank.FAMILY();
251
		//family subdivision
252
		}else if (strRank.equals("intratrib")){return Rank.FAMILY();
253
		}else if (strRank.equals("subtrib")){return Rank.FAMILY();
254
		}else if (strRank.equals("trib")){return Rank.FAMILY();
255
		}else if (strRank.equals("supertrib")){return Rank.FAMILY();
256
		}	
257
		else {
258
			throw new UnknownCdmTypeException("Unknown Rank " + strRank);
259
		}
260
	}
261

    
262
	public static String redListString2RedListCode (String redListCode) throws UnknownCdmTypeException{
263
		if (redListCode == null){ return null;
264
		}else if (redListCode.equals("#dtpl_RLKat_NULL#")){return "0";
265
		}else if (redListCode.equals("#dtpl_RLKat_EINS#")){return "1";
266
		}else if (redListCode.equals("#dtpl_RLKat_ZWEI#")){return "2"; 
267
		}else if (redListCode.equals("#dtpl_RLKat_DREI#")){return "3"; 
268
		}else if (redListCode.equals("#dtpl_RLKat_VIER#")){return "4"; 
269
		}else if (redListCode.equals("#dtpl_RLKat_G#")){return "G"; 
270
		}else if (redListCode.equals("#dtpl_RLKat_R#")){return "R"; 
271
		}else if (redListCode.equals("#dtpl_RLKat_V#")){return "V"; 
272
		}else if (redListCode.equals("#dtpl_RLKat_STERN#")){return "*";
273
		}else if (redListCode.equals("#dtpl_RLKat_STERN##dtpl_RLKat_STERN#")){return "**";
274
		}else if (redListCode.equals("#dtpl_RLKat_D#")){return "D";
275
		}else if (redListCode.equals("#dtpl_RLKat_RAUTE#")){
276
			char c = 0x2666;
277
			return String.valueOf(c);
278
		}else if (redListCode.equals("kN")){return "kN";
279
		}else if (redListCode.equals("+")){return "+";
280
		}else if (redListCode.equals("-")){return "-";
281
		}else if (redListCode.equals("=")){return "=";
282
		}else if (redListCode.equals("N")){return "N";
283
		}else if (redListCode.equals("S")){return "S";
284
		}else if (redListCode.equals("E")){return "E";
285
		}else if (redListCode.equals("D")){return "D";
286
		}else if (redListCode.equals("#dtpl_KurzfBest_RUNTER##dtpl_KurzfBest_RUNTER##dtpl_KurzfBest_RUNTER#")){
287
			char c = 0x2193;
288
			return String.valueOf(c)+String.valueOf(c)+String.valueOf(c);
289
		}else if (redListCode.equals("#dtpl_KurzfBest_RUNTER##dtpl_KurzfBest_RUNTER#")){
290
			char c = 0x2193;
291
			return String.valueOf(c)+String.valueOf(c);
292
		}else if (redListCode.equals("(#dtpl_KurzfBest_RUNTER#)")){
293
			char c = 0x2193;
294
			return "("+String.valueOf(c)+")";
295
		}else if (redListCode.equals("#dtpl_KurzfBest_HOCH#")){
296
			char c = 0x2191;
297
			return String.valueOf(c);
298
		}else if (redListCode.equals("#dtpl_Risiko_MINUS#")){return "-";
299
		}else if (redListCode.equals("#dtpl_VERANTW_NB#")){return "nb";
300
		}else if (redListCode.equals("#dtpl_TaxBez_GLEICH#")){return "=";
301
		}else if (redListCode.equals("#dtpl_TaxBez_KLEINER#")){return "<";
302
		}else if (redListCode.equals("#dtpl_TaxBez_GROESSER#")){return ">";
303
		}else if (redListCode.equals("#dtpl_TaxBez_UNGLEICH#")){
304
			char c = 0x2260;
305
			return String.valueOf(c);
306
		}else if (redListCode.equals("#dtpl_AlteRLKat_STERN#")){return "*";
307
		}else if (redListCode.equals("#dtpl_AlteRLKat_ZWEISTERN#")){return "**";
308
		}else if (redListCode.equals("#dtpl_AlteRLKat_NB#")){return "nb";
309
		}else if (redListCode.equals("#dtpl_AlteRLKat_KN#")){return "kN";
310
		}else if (redListCode.equals("#dtpl_TaxBez_UNGLEICH#")){return "-";
311
		}else if (StringUtils.isBlank(redListCode)){return "keine Angabe";
312
		}	
313
		else {
314
			throw new UnknownCdmTypeException("Unknown Redlist Code " + redListCode);
315
		}
316
	}
317
	
318
	public static NomenclaturalCode nomCodeString2NomCode (String nomCode) throws UnknownCdmTypeException{
319
		if (nomCode != null){
320
			nomCode = nomCode.trim();
321
		}
322
		if (nomCode == null){ return null;
323
		}else if (nomCode.equals("Botanical")){return NomenclaturalCode.ICNAFP;
324
		}else if (nomCode.equals("Zoological")){return NomenclaturalCode.ICZN;
325
		}else if (nomCode.equals("Viral")){return NomenclaturalCode.ICVCN;
326
		}else if (nomCode.equals("Bacteriological")){return NomenclaturalCode.ICNB;
327
		}else if (nomCode.equals("CultivatedPlant")){return NomenclaturalCode.ICNCP;
328
		//TODO code Indeterminate
329
//		}else if (nomCode.equals("Indeterminate")){return NomenclaturalCode.XXX();
330
		}	
331
		else {
332
			throw new UnknownCdmTypeException("Unknown Nomenclatural Code " + nomCode);
333
		}
334
	}
335
	public static UUID getRedlistVocabularyUUID(String redListVocabulary) throws UnknownCdmTypeException {
336

    
337
		if(redListVocabulary.equalsIgnoreCase("RL Kat.")) return vocStateRLKat;
338
		if(redListVocabulary.equalsIgnoreCase("Kat. +/-")) return vocStateRlKatDiff;
339
		if(redListVocabulary.equalsIgnoreCase("aktuelle Bestandsstituation")) return vocStateRlAkt;
340
		if(redListVocabulary.equalsIgnoreCase("langfristiger Bestandstrend")) return vocStateRLLang;
341
		if(redListVocabulary.equalsIgnoreCase("kurzfristiger Bestandstrend")) return vocStateRLKurz;
342
		if(redListVocabulary.equalsIgnoreCase("Risikofaktoren")) return vocStateRLRisk;
343
		if(redListVocabulary.equalsIgnoreCase("Verantwortlichkeit")) return vocStateRLResp;
344
		if(redListVocabulary.equalsIgnoreCase("alte RL- Kat.")) return vocStateRLKatOld;
345
		if(redListVocabulary.equalsIgnoreCase("Neobiota")) return vocStateRLNeo;
346
		if(redListVocabulary.equalsIgnoreCase("Eindeutiger Code")) return vocStateRLKatId;
347
		if(redListVocabulary.equalsIgnoreCase("Sonderfälle")) return vocStateRLSpecialCases;
348
		if(redListVocabulary.equalsIgnoreCase("German Federal States")) return vocGermanFederalStates;
349
		else{
350
			throw new UnknownCdmTypeException("Unknown Vocabulary feature, could not match: " + redListVocabulary);
351
		}
352

    
353
	}
354

    
355

    
356
	public static UUID getRedlistFeatureUUID(String redListFeature) throws UnknownCdmTypeException {
357

    
358
		if(redListFeature.equalsIgnoreCase("RL Kat.")) return featureRLKat;
359
		if(redListFeature.equalsIgnoreCase("Kat. +/-")) return featureRlKatDiff;
360
		if(redListFeature.equalsIgnoreCase("aktuelle Bestandsstituation")) return featureRlAkt;
361
		if(redListFeature.equalsIgnoreCase("langfristiger Bestandstrend")) return featureRLLang;
362
		if(redListFeature.equalsIgnoreCase("kurzfristiger Bestandstrend")) return featureRLKurz;
363
		if(redListFeature.equalsIgnoreCase("Risikofaktoren")) return featureRLRisk;
364
		if(redListFeature.equalsIgnoreCase("Verantwortlichkeit")) return featureRLResp;
365
		if(redListFeature.equalsIgnoreCase("alte RL- Kat.")) return featureRLKatOld;
366
		if(redListFeature.equalsIgnoreCase("Neobiota")) return featureRLNeo;
367
		if(redListFeature.equalsIgnoreCase("Eindeutiger Code")) return featureRLKatId;
368
		if(redListFeature.equalsIgnoreCase("Kommentar zur Taxonomie")) return featureRLTaxComment;
369
		if(redListFeature.equalsIgnoreCase("Kommentar zur Gefährdung")) return featureRLHazardComment;
370
		if(redListFeature.equalsIgnoreCase("Sonderfälle")) return featureRLSpecialCases;
371
		if(redListFeature.equalsIgnoreCase("Letzter Nachweis")) return featureRLLastOccurrence;
372
		if(redListFeature.equalsIgnoreCase("Weitere Kommentare")) return featureRLAdditionalComment;
373
		
374
		else{
375
			throw new UnknownCdmTypeException("Unknown feature, could not match: " + redListFeature);
376
		}
377

    
378
	}
379

    
380
	public static UUID getRedlistStateTermUUID(String redListStateTerm, String redListFeature) throws UnknownCdmTypeException {
381
		//RL Kat
382
		char a = 0x2666;
383
		if(redListStateTerm.equalsIgnoreCase("0") && redListFeature.equalsIgnoreCase("RL Kat.")) return stateTermRlKat0;
384
		if(redListStateTerm.equalsIgnoreCase("1") && redListFeature.equalsIgnoreCase("RL Kat.")) return stateTermRlKat1;
385
		if(redListStateTerm.equalsIgnoreCase("2") && redListFeature.equalsIgnoreCase("RL Kat.")) return stateTermRlKat2;
386
		if(redListStateTerm.equalsIgnoreCase("3") && redListFeature.equalsIgnoreCase("RL Kat.")) return stateTermRlKat3;
387
		if(redListStateTerm.equalsIgnoreCase("G") && redListFeature.equalsIgnoreCase("RL Kat.")) return stateTermRlKatG;
388
		if(redListStateTerm.equalsIgnoreCase("R") && redListFeature.equalsIgnoreCase("RL Kat.")) return stateTermRlKatR;
389
		if(redListStateTerm.equalsIgnoreCase("V") && redListFeature.equalsIgnoreCase("RL Kat.")) return stateTermRlKatV;
390
		if(redListStateTerm.equalsIgnoreCase("*") && redListFeature.equalsIgnoreCase("RL Kat.")) return stateTermRlKatStar;
391
		if(redListStateTerm.equalsIgnoreCase("**") && redListFeature.equalsIgnoreCase("RL Kat.")) return stateTermRlKatStar2;
392
		if(redListStateTerm.equalsIgnoreCase("D") && redListFeature.equalsIgnoreCase("RL Kat.")) return stateTermRlKatD;
393
		if(redListStateTerm.equalsIgnoreCase(String.valueOf(a)) && redListFeature.equalsIgnoreCase("RL Kat.")) return stateTermRlKatDiamond;
394
		if(redListStateTerm.equalsIgnoreCase("kN") && redListFeature.equalsIgnoreCase("RL Kat.")) return stateTermRlKatKN;
395
		
396
		//RL Diff
397
		if(redListStateTerm.equalsIgnoreCase("+") && redListFeature.equalsIgnoreCase("Kat. +/-")) return stateTermRLKatDiffPlus;
398
		if(redListStateTerm.equalsIgnoreCase("-") && redListFeature.equalsIgnoreCase("Kat. +/-")) return stateTermRLKatDiffMinus;
399
		if(redListStateTerm.equalsIgnoreCase("=") && redListFeature.equalsIgnoreCase("Kat. +/-")) return stateTermRLKatDiffEqual;
400
		
401
		//Rl Akt
402
		if(redListStateTerm.equalsIgnoreCase("ex") && redListFeature.equalsIgnoreCase("aktuelle Bestandsstituation")) return stateTermRLKatAktEx;
403
		if(redListStateTerm.equalsIgnoreCase("es") && redListFeature.equalsIgnoreCase("aktuelle Bestandsstituation")) return stateTermRLKatAktEs;
404
		if(redListStateTerm.equalsIgnoreCase("ss") && redListFeature.equalsIgnoreCase("aktuelle Bestandsstituation")) return stateTermRLKatAktSs;
405
		if(redListStateTerm.equalsIgnoreCase("s") && redListFeature.equalsIgnoreCase("aktuelle Bestandsstituation")) return stateTermRLKatAktS;
406
		if(redListStateTerm.equalsIgnoreCase("mh") && redListFeature.equalsIgnoreCase("aktuelle Bestandsstituation")) return stateTermRLKatAktMh;
407
		if(redListStateTerm.equalsIgnoreCase("h") && redListFeature.equalsIgnoreCase("aktuelle Bestandsstituation")) return stateTermRLKatAktH;
408
		if(redListStateTerm.equalsIgnoreCase("sh") && redListFeature.equalsIgnoreCase("aktuelle Bestandsstituation")) return stateTermRLKatAktSh;
409
		if(redListStateTerm.equalsIgnoreCase("?") && redListFeature.equalsIgnoreCase("aktuelle Bestandsstituation")) return stateTermRLKatAktQuest;
410
		if(redListStateTerm.equalsIgnoreCase("nb") && redListFeature.equalsIgnoreCase("aktuelle Bestandsstituation")) return stateTermRLKatAktNb;
411
		if(redListStateTerm.equalsIgnoreCase("kN") && redListFeature.equalsIgnoreCase("aktuelle Bestandsstituation")) return stateTermRLKatAktKn;
412
		
413
		//RL Lang
414
		if(redListStateTerm.equalsIgnoreCase("<<<") && redListFeature.equalsIgnoreCase("langfristiger Bestandstrend")) return stateTermRLKatLangLT3;
415
		if(redListStateTerm.equalsIgnoreCase("<<") && redListFeature.equalsIgnoreCase("langfristiger Bestandstrend")) return stateTermRLKatLangLT2;
416
		if(redListStateTerm.equalsIgnoreCase("<") && redListFeature.equalsIgnoreCase("langfristiger Bestandstrend")) return stateTermRLKatLangLT1;
417
		if(redListStateTerm.equalsIgnoreCase("(<)") && redListFeature.equalsIgnoreCase("langfristiger Bestandstrend")) return stateTermRLKatLangLT;
418
		if(redListStateTerm.equalsIgnoreCase("=") && redListFeature.equalsIgnoreCase("langfristiger Bestandstrend")) return stateTermRLKatLangEqual;
419
		if(redListStateTerm.equalsIgnoreCase(">") && redListFeature.equalsIgnoreCase("langfristiger Bestandstrend")) return stateTermRLKatLangGT;
420
		if(redListStateTerm.equalsIgnoreCase("?") && redListFeature.equalsIgnoreCase("langfristiger Bestandstrend")) return stateTermRLKatLangQuest;
421
		
422
		//RL Kurz
423
		char c = 0x2193;
424
		char b = 0x2191;
425
		if(redListStateTerm.equalsIgnoreCase(String.valueOf(c)+String.valueOf(c)+String.valueOf(c)) && redListFeature.equalsIgnoreCase("kurzfristiger Bestandstrend")) return stateTermRLKatKurzDown3;
426
		if(redListStateTerm.equalsIgnoreCase(String.valueOf(c)+String.valueOf(c)) && redListFeature.equalsIgnoreCase("kurzfristiger Bestandstrend")) return stateTermRLKatKurzDown2;
427
		if(redListStateTerm.equalsIgnoreCase("("+String.valueOf(c)+")") && redListFeature.equalsIgnoreCase("kurzfristiger Bestandstrend")) return stateTermRLKatKurzDown1;
428
		if(redListStateTerm.equalsIgnoreCase("=") && redListFeature.equalsIgnoreCase("kurzfristiger Bestandstrend")) return stateTermRLKatKurzEqual;
429
		if(redListStateTerm.equalsIgnoreCase(String.valueOf(b)) && redListFeature.equalsIgnoreCase("kurzfristiger Bestandstrend")) return stateTermRLKatKurzUp;
430
		if(redListStateTerm.equalsIgnoreCase("?") && redListFeature.equalsIgnoreCase("kurzfristiger Bestandstrend")) return stateTermRLKatKurzQuest;
431
		
432
		//RL Risk
433
		if(redListStateTerm.equalsIgnoreCase("-") && redListFeature.equalsIgnoreCase("Risikofaktoren")) return stateTermRLKatRiskMinus;
434
		if(redListStateTerm.equalsIgnoreCase("=") && redListFeature.equalsIgnoreCase("Risikofaktoren")) return stateTermRLKatRiskEqual;
435
		
436
		//RL Resp
437
		if(redListStateTerm.equalsIgnoreCase("!!") && redListFeature.equalsIgnoreCase("Verantwortlichkeit")) return stateTermRLKatRespBang2;
438
		if(redListStateTerm.equalsIgnoreCase("!") && redListFeature.equalsIgnoreCase("Verantwortlichkeit")) return stateTermRLKatRespBang1;
439
		if(redListStateTerm.equalsIgnoreCase("(!)") && redListFeature.equalsIgnoreCase("Verantwortlichkeit")) return stateTermRLKatRespBang;
440
		if(redListStateTerm.equalsIgnoreCase("?") && redListFeature.equalsIgnoreCase("Verantwortlichkeit")) return stateTermRLKatRespQuest;
441
		if(redListStateTerm.equalsIgnoreCase("nb") && redListFeature.equalsIgnoreCase("Verantwortlichkeit")) return stateTermRLKatRespNb;
442
		
443
		//RL Kat Old
444
		if(redListStateTerm.equalsIgnoreCase("0") && redListFeature.equalsIgnoreCase("alte RL- Kat.")) return stateTermRLKatOld0;
445
		if(redListStateTerm.equalsIgnoreCase("1") && redListFeature.equalsIgnoreCase("alte RL- Kat.")) return stateTermRLKatOld1;
446
		if(redListStateTerm.equalsIgnoreCase("2") && redListFeature.equalsIgnoreCase("alte RL- Kat.")) return stateTermRLKatOld2;
447
		if(redListStateTerm.equalsIgnoreCase("3") && redListFeature.equalsIgnoreCase("alte RL- Kat.")) return stateTermRLKatOld3;
448
		if(redListStateTerm.equalsIgnoreCase("G") && redListFeature.equalsIgnoreCase("alte RL- Kat.")) return stateTermRLKatOldG;
449
		if(redListStateTerm.equalsIgnoreCase("R") && redListFeature.equalsIgnoreCase("alte RL- Kat.")) return stateTermRLKatOldR;
450
		if(redListStateTerm.equalsIgnoreCase("V") && redListFeature.equalsIgnoreCase("alte RL- Kat.")) return stateTermRLKatOldV;
451
		if(redListStateTerm.equalsIgnoreCase("*") && redListFeature.equalsIgnoreCase("alte RL- Kat.")) return stateTermRLKatOldStar;
452
		if(redListStateTerm.equalsIgnoreCase("**") && redListFeature.equalsIgnoreCase("alte RL- Kat.")) return stateTermRLKatOldStar2;
453
		if(redListStateTerm.equalsIgnoreCase("D") && redListFeature.equalsIgnoreCase("alte RL- Kat.")) return stateTermRLKatOldD;
454
		if(redListStateTerm.equalsIgnoreCase("nb") && redListFeature.equalsIgnoreCase("alte RL- Kat.")) return stateTermRLKatOldNb;
455
		if(redListStateTerm.equalsIgnoreCase("kN") && redListFeature.equalsIgnoreCase("alte RL- Kat.")) return stateTermRLKatOldKn;
456
		
457
		//RL Neo
458
		if(redListStateTerm.equalsIgnoreCase("N") && redListFeature.equalsIgnoreCase("Neobiota")) return stateTermRLKatNeo;
459

    
460
		//RL Special
461
		if(redListStateTerm.equalsIgnoreCase("S") && redListFeature.equalsIgnoreCase("Sonderfälle")) return stateTermRLSpecialS;
462
		if(redListStateTerm.equalsIgnoreCase("E") && redListFeature.equalsIgnoreCase("Sonderfälle")) return stateTermRLSpecialE;
463
		if(redListStateTerm.equalsIgnoreCase("D") && redListFeature.equalsIgnoreCase("Sonderfälle")) return stateTermRLSpecialD;
464
		
465
		
466
		
467
		//RL Empty
468
		if(StringUtils.isBlank(redListStateTerm) || redListStateTerm.equalsIgnoreCase("keine Angabe")) return stateTermEmpty; 
469
		
470
		else
471
			throw new UnknownCdmTypeException("Unknown State, could not match: " + redListStateTerm +"\n In Category: " + redListFeature);
472
	
473
	}
474

    
475

    
476
	public static UUID getGermanStateUUID(String strGermanState) throws UnknownCdmTypeException {
477

    
478
		if(strGermanState.equalsIgnoreCase("Deutschland")) return UUID.fromString("a7f3855e-d4fa-4313-8fcf-da792ef848e7");
479
		if(strGermanState.equalsIgnoreCase("Baden-Württemberg"))return UUID.fromString("00e64948-9ce9-4ebf-961b-133c56517b1c");
480
		if(strGermanState.equalsIgnoreCase("Bayern"))return UUID.fromString("ba075265-368f-4ff0-8942-88546239c70a");
481
		if(strGermanState.equalsIgnoreCase("Berlin"))return UUID.fromString("d9339e12-7efa-45df-a008-3c934b9386bc");
482
		if(strGermanState.equalsIgnoreCase("Brandenburg"))return UUID.fromString("dda9d8b8-8090-4667-953e-d8b1f7243926");
483
		if(strGermanState.equalsIgnoreCase("Hamburg"))return UUID.fromString("f087a7d7-974f-4627-a414-df27c04f99dd");
484
		if(strGermanState.equalsIgnoreCase("Hessen"))return UUID.fromString("59de29e6-bf32-4677-89c7-a6834fcb5085");
485
		if(strGermanState.equalsIgnoreCase("Mecklenburg-Vorpommern"))return UUID.fromString("06dccbd5-8d5a-4e4f-b56e-d1d74ab25c19");
486
		if(strGermanState.equalsIgnoreCase("Niedersachsen"))return UUID.fromString("97f77fe8-07ab-4e14-8f8b-40e8caf7e653");
487
		if(strGermanState.equalsIgnoreCase("Nordrhein-Westfalen"))return UUID.fromString("46bf702e-1438-470c-9c77-04202c34ebf2");
488
		if(strGermanState.equalsIgnoreCase("Rheinland-Pfalz"))return UUID.fromString("dd3ddb29-b1ec-4937-99a9-4a94d383becf");
489
		if(strGermanState.equalsIgnoreCase("Saarland"))return UUID.fromString("26d3e85f-ce90-43ae-8ac0-42a60302b7b7");
490
		if(strGermanState.equalsIgnoreCase("Sachsen"))return UUID.fromString("ca3ef152-ee3a-45f2-8343-983cf0fdddbd");
491
		if(strGermanState.equalsIgnoreCase("Sachsen-Anhalt"))return UUID.fromString("bb95b9a4-87ee-49bd-a542-4c30289e8d1f");
492
		if(strGermanState.equalsIgnoreCase("Schleswig-Holstein"))return UUID.fromString("863323a7-22fb-4070-ad94-ce317098a28a");
493
		if(strGermanState.equalsIgnoreCase("Thüringen"))return UUID.fromString("72e18526-6bf7-4300-8329-53cab5da2b51");
494

    
495
		else
496
			throw new UnknownCdmTypeException("Unknown State, could not match: " + strGermanState);
497
	}
498
	
499
}
(8-8/8)