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
|
}
|