Project

General

Profile

Download (113 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
package eu.etaxonomy.cdm.io.pesi.out;
10

    
11
import java.sql.ResultSet;
12
import java.sql.SQLException;
13
import java.util.EnumSet;
14
import java.util.HashMap;
15
import java.util.HashSet;
16
import java.util.Map;
17
import java.util.Set;
18
import java.util.UUID;
19

    
20
import org.apache.commons.lang.StringUtils;
21
import org.apache.log4j.Logger;
22

    
23
import eu.etaxonomy.cdm.common.CdmUtils;
24
import eu.etaxonomy.cdm.io.berlinModel.BerlinModelTransformer;
25
import eu.etaxonomy.cdm.io.common.Source;
26
import eu.etaxonomy.cdm.io.common.mapping.UndefinedTransformerMethodException;
27
import eu.etaxonomy.cdm.io.common.mapping.out.ExportTransformerBase;
28
import eu.etaxonomy.cdm.io.pesi.erms.ErmsTransformer;
29
import eu.etaxonomy.cdm.io.pesi.out.PesiExportBase.PesiSource;
30
import eu.etaxonomy.cdm.model.common.CdmBase;
31
import eu.etaxonomy.cdm.model.common.Language;
32
import eu.etaxonomy.cdm.model.common.RelationshipBase;
33
import eu.etaxonomy.cdm.model.common.RelationshipTermBase;
34
import eu.etaxonomy.cdm.model.description.Feature;
35
import eu.etaxonomy.cdm.model.description.PresenceAbsenceTerm;
36
import eu.etaxonomy.cdm.model.location.Country;
37
import eu.etaxonomy.cdm.model.location.NamedArea;
38
import eu.etaxonomy.cdm.model.name.HybridRelationshipType;
39
import eu.etaxonomy.cdm.model.name.NameRelationshipType;
40
import eu.etaxonomy.cdm.model.name.NameTypeDesignationStatus;
41
import eu.etaxonomy.cdm.model.name.NomenclaturalCode;
42
import eu.etaxonomy.cdm.model.name.NomenclaturalStatusType;
43
import eu.etaxonomy.cdm.model.name.Rank;
44
import eu.etaxonomy.cdm.model.name.TaxonName;
45
import eu.etaxonomy.cdm.model.reference.Reference;
46
import eu.etaxonomy.cdm.model.reference.ReferenceType;
47
import eu.etaxonomy.cdm.model.taxon.Synonym;
48
import eu.etaxonomy.cdm.model.taxon.SynonymType;
49
import eu.etaxonomy.cdm.model.taxon.Taxon;
50
import eu.etaxonomy.cdm.model.taxon.TaxonBase;
51
import eu.etaxonomy.cdm.model.taxon.TaxonRelationshipType;
52
import eu.etaxonomy.cdm.strategy.exceptions.UnknownCdmTypeException;
53

    
54
/**
55
 * @author e.-m.lee
56
 * @author a.mueller (update)
57
 * @since 16.02.2010
58
 */
59
public final class PesiTransformer extends ExportTransformerBase{
60
	private static final Logger logger = Logger.getLogger(PesiTransformer.class);
61

    
62
	public static final String AUCT_STRING = "auct.";
63

    
64
	//source identifiers
65
	public static final int SOURCE_EM = 1;
66
	public static final int SOURCE_FE = 2;
67
	public static final int SOURCE_IF = 3;
68
	public static final int SOURCE_ERMS = 4;
69

    
70
	//sourceRefUUIDs
71
	public static final UUID uuidSourceRefEuroMed = UUID.fromString("51b3900c-91e0-4cc5-94f3-577a352ca9c4");
72
	public static final UUID uuidSourceRefFaunaEuropaea = UUID.fromString("6786d863-75d4-4796-b916-c1c3dff4cb70");
73
	public static final UUID uuidSourceRefErms = UUID.fromString("7744bc26-f914-42c4-b54a-dd2a030a8bb7");
74
	public static final UUID uuidSourceRefIndexFungorum = UUID.fromString("8de25d27-7d40-47f4-af3b-59d64935a843");
75
	public static final UUID uuidSourceRefAuct = UUID.fromString("5f79f96c-c100-4cd8-b78e-2b2dacf09a23");
76

    
77
    public static final UUID uuidTaxonValuelessEuroMed = UUID.fromString("f0a9322b-a57e-447b-9a75-a909f2f2a994");
78

    
79
	public static final String SOURCE_STR_EM = "E+M";
80
	public static final String SOURCE_STR_FE = "FaEu";
81
	public static final String SOURCE_STR_IF = "IF";
82
	public static final String SOURCE_STR_ERMS = "ERMS";
83

    
84
	// status keys
85
	public static int QUALITY_STATUS_CHECKED_EDITOR_ERMS_1_1 = 0;
86
	public static int QUALITY_STATUS_ADD_BY_DBMT= 2;
87
	public static int QUALITY_STATUS_CHECKED_EDITOR = 3;
88
	public static int QUALITY_STATUS_EDITED_BY_DBMT = 4;
89

    
90
	// marker type
91
	public static final UUID uuidMarkerGuidIsMissing = UUID.fromString("24e70843-05e2-44db-954b-84df0d23ea20");
92
	public static final UUID uuidMarkerTypeHasNoLastAction = UUID.fromString("99652d5a-bc92-4251-b57d-0fec4d258ab7");
93
//	public static final UUID uuidMarkerFossil = UUID.fromString("761ce108-031a-4e07-b444-f8d757070312");
94

    
95

    
96
	//extension type uuids
97
	public static final UUID uuidExtCacheCitation = UUID.fromString("29656168-32d6-4301-9067-d57c63be5c67");
98
	//public static final UUID expertUserIdUuid = UUID.fromString("e25813d3-c67c-4585-9aa0-970fafde50b4");
99
	//public static final UUID speciesExpertUserIdUuid = UUID.fromString("6d42abd8-8894-4980-ae07-e918affd4172");
100
	public static final UUID uuidExtExpertName = BerlinModelTransformer.uuidExpertName;
101
	public static final UUID uuidExtSpeciesExpertName = BerlinModelTransformer.uuidSpeciesExpertName;
102
	public static final UUID uuidExtLastActionDate = UUID.fromString("8d0a7d81-bb83-4576-84c3-8c906ef039b2");
103
	public static final UUID uuidExtLastAction = UUID.fromString("bc20d5bc-6161-4279-9499-89ea26ce5f6a");
104
	public static final UUID uuidExtTaxComment = UUID.fromString("8041a752-0479-4626-ab1b-b266b751f816");
105
	public static final UUID uuidExtFauComment = UUID.fromString("054f773a-41c8-4ad5-83e3-981320c1c126");
106
	public static final UUID uuidExtFauExtraCodes = UUID.fromString("b8c7e77d-9869-4787-bed6-b4b302dbc5f5");
107

    
108
	// References
109
	public static int REF_ARTICLE_IN_PERIODICAL = 1;
110
	public static int REF_PART_OF_OTHER = 2;
111
	public static int REF_BOOK = 3;
112
	public static int REF_DATABASE = 4;
113
	public static int REF_INFORMAL = 5;
114
	public static int REF_NOT_APPLICABLE = 6;
115
	public static int REF_WEBSITE = 7;
116
	public static int REF_PUBLISHED = 8;
117
	public static int REF_JOURNAL = 9;
118
	public static int REF_UNRESOLVED = 10;
119
	public static int REF_PUBLICATION = 11;
120
	public static String REF_STR_UNRESOLVED = "unresolved";
121

    
122

    
123
	// NameStatus
124
    public static UUID uuidNomStatusTemporaryName = UUID.fromString("aa6ada5a-ca21-4fef-b76f-9ae237e9c4ae");
125

    
126
	public static int NAME_ST_NOM_INVAL = 1;
127
	public static int NAME_ST_NOM_ILLEG = 2;
128
	public static int NAME_ST_NOM_NUD = 3;
129
	public static int NAME_ST_NOM_REJ = 4;
130
	public static int NAME_ST_NOM_REJ_PROP = 5;
131
	public static int NAME_ST_NOM_UTIQUE_REJ = 6;
132
	public static int NAME_ST_NOM_UTIQUE_REJ_PROP = 7;
133
	public static int NAME_ST_NOM_CONS = 8;
134
	public static int NAME_ST_NOM_CONS_PROP = 9;
135
	public static int NAME_ST_ORTH_CONS = 10;
136
	public static int NAME_ST_ORTH_CONS_PROP = 11;
137
	public static int NAME_ST_NOM_SUPERFL = 12;
138
	public static int NAME_ST_NOM_AMBIG = 13;
139
	public static int NAME_ST_NOM_PROVIS = 14;
140
	public static int NAME_ST_NOM_DUB = 15;
141
	public static int NAME_ST_NOM_NOV = 16;
142
	public static int NAME_ST_NOM_CONFUS = 17;
143
	public static int NAME_ST_NOM_ALTERN = 18;
144
	public static int NAME_ST_COMB_INVAL = 19;
145
	public static int NAME_ST_LEGITIMATE = 20; // PESI specific from here
146
	public static int NAME_ST_COMB_INED = 21;
147
	public static int NAME_ST_COMB_AND_STAT_INED = 22;
148
	public static int NAME_ST_NOM_AND_ORTH_CONS = 23;
149
	public static int NAME_ST_NOM_NOV_INED = 24;
150
	public static int NAME_ST_SP_NOV_INED = 25;
151
	public static int NAME_ST_ALTERNATE_REPRESENTATION = 26;
152
	public static int NAME_ST_TEMPORARY_NAME = 27;
153
	public static int NAME_ST_SPECIES_INQUIRENDA = 28;
154

    
155
	// TaxonStatus
156
	public static int T_STATUS_ACCEPTED = 1;
157
	public static int T_STATUS_SYNONYM = 2;
158
	public static int T_STATUS_PARTIAL_SYN = 3;
159
	public static int T_STATUS_PRO_PARTE_SYN = 4;
160
	public static int T_STATUS_UNRESOLVED = 5;
161
	public static int T_STATUS_ORPHANED = 6;
162
	public static int T_STATUS_UNACCEPTED = 7;
163
	public static int T_STATUS_NOT_ACCEPTED = 8;
164

    
165
	// TypeDesginationStatus //	 -> not a table anymore
166
	public static int TYPE_BY_ORIGINAL_DESIGNATION = 1;
167
	public static int TYPE_BY_SUBSEQUENT_DESIGNATION = 2;
168
	public static int TYPE_BY_MONOTYPY = 3;
169
	public static String TYPE_STR_BY_ORIGINAL_DESIGNATION = "Type by original designation";
170
	public static String TYPE_STR_BY_SUBSEQUENT_DESIGNATION = "Type by subsequent designation";
171
	public static String TYPE_STR_BY_MONOTYPY = "Type by monotypy";
172

    
173
	// RelTaxonQualifier
174
	public static int IS_BASIONYM_FOR = 1;
175
	public static int IS_LATER_HOMONYM_OF = 2;
176
	public static int IS_REPLACED_SYNONYM_FOR = 3;
177
	public static int IS_VALIDATION_OF = 4;
178
	public static int IS_LATER_VALIDATION_OF = 5;
179
	public static int IS_TYPE_OF = 6;
180
	public static int IS_CONSERVED_TYPE_OF = 7;
181
	public static int IS_REJECTED_TYPE_OF = 8;
182
	public static int IS_FIRST_PARENT_OF = 9;
183
	public static int IS_SECOND_PARENT_OF = 10;
184
	public static int IS_FEMALE_PARENT_OF = 11;
185
	public static int IS_MALE_PARENT_OF = 12;
186
	public static int IS_CONSERVED_AGAINST = 13;
187
	public static int IS_REJECTED_IN_FAVOUR_OF = 14;
188
	public static int IS_TREATED_AS_LATER_HOMONYM_OF = 15;
189
	public static int IS_ORTHOGRAPHIC_VARIANT_OF = 16;
190
	public static int IS_ALTERNATIVE_NAME_FOR = 17;
191
	public static int HAS_SAME_TYPE_AS = 18;
192
	public static int IS_LECTOTYPE_OF = 61;
193
	public static int TYPE_NOT_DESIGNATED = 62;
194
	public static int IS_TAXONOMICALLY_INCLUDED_IN = 101;
195
	public static int IS_SYNONYM_OF = 102;
196
	public static int IS_MISAPPLIED_NAME_FOR = 103;
197
	public static int IS_PRO_PARTE_SYNONYM_OF = 104;
198
	public static int IS_PARTIAL_SYNONYM_OF = 105;
199
	public static int IS_HETEROTYPIC_SYNONYM_OF = 106;
200
	public static int IS_HOMOTYPIC_SYNONYM_OF = 107;
201
	public static int IS_PRO_PARTE_AND_HOMOTYPIC_SYNONYM_OF = 201;
202
	public static int IS_PRO_PARTE_AND_HETEROTYPIC_SYNONYM_OF = 202;
203
	public static int IS_PARTIAL_AND_HOMOTYPIC_SYNONYM_OF = 203;
204
	public static int IS_PARTIAL_AND_HETEROTYPIC_SYNONYM_OF = 204;
205
	public static int IS_INFERRED_EPITHET_FOR = 301;
206
	public static int IS_INFERRED_GENUS_FOR = 302;
207
	public static int IS_POTENTIAL_COMBINATION_FOR = 303;
208

    
209
	//namespaces
210
	public static String STR_NAMESPACE_NOMINAL_TAXON = "Nominal taxon from TAX_ID:";
211
	public static String STR_NAMESPACE_INFERRED_EPITHET = "Inferred epithet from TAX_ID:";
212
	public static String STR_NAMESPACE_INFERRED_GENUS = "Inferred genus from TAX_ID:";
213
	public static String STR_NAMESPACE_POTENTIAL_COMBINATION = "Potential combination from TAX_ID:";
214

    
215
	// Kingdoms
216
	public static final int KINGDOM_NULL = 0;
217
	public static final int KINGDOM_ANIMALIA = 2;
218
	public static final int KINGDOM_PLANTAE = 3;
219
	public static final int KINGDOM_FUNGI = 4;
220
	public static final int KINGDOM_PROTOZOA = 5;
221
	public static final int KINGDOM_BACTERIA = 6;
222
	public static final int KINGDOM_CHROMISTA = 7;
223

    
224
	// Kingdoms
225
	public static Map<String, Integer> pesiKingdomMap = new HashMap<>();
226

    
227
	//Kingdom title
228
    public static String KINGDOM_PLANTAE_STRING = "Plantae";
229
    public static String KINGDOM_FUNGI_STRING = "Fungi";
230
    public static String KINGDOM_PROTOZOA_STRING = "Protozoa";
231
    public static String kINGDOM_BACTERIA_STRING = "Bacteria";
232
    public static String KINGDOM_CHROMISTA_STRING = "Chromista";
233

    
234
	//ranks all kingdoms
235
    public static int Kingdom = 10;
236
    public static int Subkingdom = 20;
237
    public static int Phylum = 30;  //Phylum and Division is same (#8541) according to ICNAFP
238
    public static int Division = 30;
239
    public static int Subphylum = 40;  //See above comment
240
    public static int Subdivision = 40;
241
    public static int Class = 60;
242
    public static int Subclass = 70;
243
    public static int Order = 100;
244
    public static int Suborder = 110;
245
    public static int Family = 140;
246
    public static int Subfamily = 150;
247
    public static int Tribe = 160;
248
    public static int Subtribe = 170;
249
    public static int Genus = 180;
250
    public static int Subgenus = 190;
251
    public static int Species =220;
252
    public static int Subspecies = 230;
253
    public static int Variety = 240;
254
    public static int Forma = 260;
255

    
256
    //ranks some kingdoms
257
    public static int Infrakingdom = 25; //2,3,5,7
258
    public static int Infraphylum = 45;  //2,7
259
    public static int Superclass = 50;   //2,5,6,7
260
    public static int Infraclass = 80;   //2,5,6,7
261
    public static int Superorder = 90;   //2,3,5,6,7
262
    public static int Infraorder = 120;  //2,5,6,7
263
    public static int Superfamily = 130; //2,5,6,7
264
    public static int Bot_Section = 200;    //3,4,7
265
    public static int Bot_Subsection = 210; //3,4,7
266
    public static int Subvariety = 250;     //2,3,4,7
267
    public static int Subform = 270;        //2,3,4
268
    public static int Forma_spec = 275;     //3,4,5,7
269

    
270
    // Animalia Ranks
271
	public static int Superphylum = 28;
272
	public static int Subterclass = 85;
273
	public static int Parvorder = 122;
274
	public static int Animalia_Section = 125;
275
	public static int Animalia_Subsection = 127;
276
	public static int Natio = 235;
277

    
278
	// Plantae Ranks
279
	public static int Series = 212;
280
	public static int Subseries	= 214;
281
	public static int Aggregate	= 216;
282
	public static int Coll_Species = 218;
283
	public static int Grex = 225;
284
	public static int Proles = 232;
285
	public static int Race = 234;
286
	public static int Convarietas = 236;
287
	public static int Taxa_infragen = 280;
288
	public static int Taxa_infraspec = 285;
289

    
290

    
291
	//NoteCategory
292
	public static int NoteCategory_description = 1;
293
	public static int NoteCategory_ecology = 4;
294
	public static int NoteCategory_phenology	= 5;
295
	public static int NoteCategory_general_distribution_euromed = 10;
296
	public static int NoteCategory_general_distribution_world = 11;
297
	public static int NoteCategory_Common_names = 12;
298
	public static int NoteCategory_Occurrence = 13;
299
	public static int NoteCategory_Maps =14;
300
	public static int NoteCategory_Link_to_maps = 20;
301
	public static int NoteCategory_Link_to_images = 21;
302
	public static int NoteCategory_Link_to_taxonomy = 22;
303
	public static int NoteCategory_Link_to_general_information = 23;
304
	public static int NoteCategory_undefined_link = 24;
305
	public static int NoteCategory_Editor_Braces = 249;
306
	public static int NoteCategory_Editor_Brackets = 250;
307
	public static int NoteCategory_Editor_Parenthesis = 251;
308
	public static int NoteCategory_Inedited = 252;
309
	public static int NoteCategory_Comments_on_editing_process = 253;
310
	public static int NoteCategory_Publication_date = 254;
311
	public static int NoteCategory_Morphology = 255;
312
	public static int NoteCategory_Acknowledgments = 257;
313
	public static int NoteCategory_Original_publication = 258;
314
	public static int NoteCategory_Type_locality	= 259;
315
	public static int NoteCategory_Environment = 260;
316
	public static int NoteCategory_Spelling = 261;
317
	public static int NoteCategory_Systematics = 262;
318
	public static int NoteCategory_Remark = 263;
319
	public static int NoteCategory_Additional_information = 266;
320
	public static int NoteCategory_Status = 267;
321
	public static int NoteCategory_Nomenclature = 268;
322
	public static int NoteCategory_Homonymy = 269;
323
	public static int NoteCategory_Taxonomy = 270;
324
	public static int NoteCategory_Taxonomic_status = 272;
325
	public static int NoteCategory_Authority	= 273;
326
	public static int NoteCategory_Identification = 274;
327
	public static int NoteCategory_Validity = 275;
328
	public static int NoteCategory_Classification = 276;
329
	public static int NoteCategory_Distribution = 278;
330
	public static int NoteCategory_Synonymy = 279;
331
	public static int NoteCategory_Habitat = 280;
332
	public static int NoteCategory_Biology = 281;
333
	public static int NoteCategory_Diagnosis	= 282;
334
	public static int NoteCategory_Host = 283;
335
	public static int NoteCategory_Note = 284;
336
	public static int NoteCategory_Rank = 285;
337
	public static int NoteCategory_Taxonomic_Remark = 286;
338
	public static int NoteCategory_Taxonomic_Remarks = 287;
339
	public static int NoteCategory_Etymology = 288;
340
    public static int NoteCategory_Type_species = 289;
341
	public static int NoteCategory_Depth_Range = 290;
342
	public static int NoteCategory_Grammatical_Gender = 291;
343
	public static int NoteCategory_Introduced_Species_Remark = 292;
344
	public static int NoteCategory_Alien_Species = 293;
345
	public static int NoteCategory_Dimensions = 294;
346
    public static int NoteCategory_New_Combination = 295;
347
    public static int NoteCategory_Original_Combination = 296;
348

    
349
	public static int NoteCategory_Conservation_Status= 301;
350
	public static int NoteCategory_Use = 302;
351
	public static int NoteCategory_Comments = 303;
352
    public static int NoteCategory_Diet = 304;
353
    public static int NoteCategory_Fossil_Range = 305;
354
    public static int NoteCategory_Original_Description = 306;
355
    public static int NoteCategory_Reproduction = 307;
356
    public static int NoteCategory_Specimen = 308;
357
    public static int NoteCategory_Type_Specimen = 309;
358
    public static int NoteCategory_Type_Material = 310;
359
    public static int NoteCategory_Editors_Comment = 311;
360
    public static int NoteCategory_Syntype = 312;
361

    
362
	// FossilStatus
363
	public static int FOSSILSTATUS_RECENT_ONLY = 1;
364
	public static int FOSSILSTATUS_FOSSIL_ONLY = 2;
365
	public static int FOSSILSTATUS_RECENT_FOSSIL = 3;
366
	public static String STR_FOSSIL_ONLY = "fossil only";  //still used for Index Fungorum
367

    
368
	// SourceUse
369
	public static int ORIGINAL_DESCRIPTION = 1;
370
	public static int BASIS_OF_RECORD = 2;
371
	public static int ADDITIONAL_SOURCE = 3;
372
	public static int SOURCE_OF_SYNONYMY = 4;
373
	public static int REDESCRIPTION = 5;
374
	public static int NEW_COMBINATION_REFERENCE = 6;
375
	public static int STATUS_SOURCE = 7;
376
	public static int NOMENCLATURAL_REFERENCE = 8;
377
	public static String STR_NOMENCLATURAL_REFERENCE = "nomenclatural reference";
378

    
379
	// Area
380
	public static int AREA_EAST_AEGEAN_ISLANDS = 1;
381
	public static int AREA_GREEK_EAST_AEGEAN_ISLANDS = 2;
382
	public static int AREA_TURKISH_EAST_AEGEAN_ISLANDS = 3;
383
	public static int AREA_ALBANIA = 4;
384
	public static int AREA_AUSTRIA_WITH_LIECHTENSTEIN = 5;
385
	public static int AREA_AUSTRIA = 6;
386
	public static int AREA_LIECHTENSTEIN = 7;
387
	public static int AREA_AZORES = 8;
388
	public static int AREA_CORVO = 9;
389
	public static int AREA_FAIAL = 10;
390
	public static int AREA_GRACIOSA = 11;
391
	public static int AREA_SAO_JORGE = 12;
392
	public static int AREA_FLORES = 13;
393
	public static int AREA_SAO_MIGUEL = 14;
394
	public static int AREA_PICO = 15;
395
	public static int AREA_SANTA_MARIA = 16;
396
	public static int AREA_TERCEIRA = 17;
397
	public static int AREA_BELGIUM_WITH_LUXEMBOURG = 18;
398
	public static int AREA_BELGIUM = 19;
399
	public static int AREA_LUXEMBOURG = 20;
400
	public static int AREA_BOSNIA_HERZEGOVINA = 21;
401
	public static int AREA_BALEARES = 22;
402
	public static int AREA_IBIZA_WITH_FORMENTERA = 23;
403
	public static int AREA_MALLORCA = 24;
404
	public static int AREA_MENORCA = 25;
405
	public static int AREA_GREAT_BRITAIN = 26;
406
	public static int AREA_BALTIC_STATES_ESTONIA_LATVIA_LITHUANIA_AND_KALININGRAD_REGION = 27;
407
	public static int AREA_BULGARIA = 28;
408
	public static int AREA_BELARUS = 29;
409
	public static int AREA_CANARY_ISLANDS = 30;
410
	public static int AREA_GRAN_CANARIA = 31;
411
	public static int AREA_FUERTEVENTURA_WITH_LOBOS = 32;
412
	public static int AREA_GOMERA = 33;
413
	public static int AREA_HIERRO = 34;
414
	public static int AREA_LANZAROTE_WITH_GRACIOSA = 35;
415
	public static int AREA_LA_PALMA = 36;
416
	public static int AREA_TENERIFE = 37;
417
	public static int AREA_MONTENEGRO = 38;
418
	public static int AREA_CORSE = 39;
419
	public static int AREA_CRETE_WITH_KARPATHOS_KASOS_AND_GAVDHOS = 40;
420
	public static int AREA_CZECH_REPUBLIC = 41;
421
	public static int AREA_CROATIA = 42;
422
	public static int AREA_CYPRUS = 43;
423
	public static int AREA_FORMER_CZECHOSLOVAKIA = 44;
424
	public static int AREA_DENMARK_WITH_BORNHOLM = 45;
425
	public static int AREA_ESTONIA = 46;
426
	public static int AREA_FAROE_ISLANDS = 47;
427
	public static int AREA_FINLAND_WITH_AHVENANMAA = 48;
428
	public static int AREA_FRANCE = 49;
429
	public static int AREA_CHANNEL_ISLANDS = 50;
430
	public static int AREA_FRENCH_MAINLAND = 51;
431
	public static int AREA_MONACO = 52;
432
	public static int AREA_GERMANY = 53;
433
	public static int AREA_GREECE_WITH_CYCLADES_AND_MORE_ISLANDS = 54;
434
	public static int AREA_IRELAND = 55;
435
	public static int AREA_REPUBLIC_OF_IRELAND = 56;
436
	public static int AREA_NORTHERN_IRELAND = 57;
437
	public static int AREA_SWITZERLAND = 58;
438
	public static int AREA_NETHERLANDS = 59;
439
	public static int AREA_SPAIN = 60;
440
	public static int AREA_ANDORRA = 61;
441
	public static int AREA_GIBRALTAR = 62;
442
	public static int AREA_KINGDOM_OF_SPAIN = 63;
443
	public static int AREA_HUNGARY = 64;
444
	public static int AREA_ICELAND = 65;
445
	public static int AREA_ITALY = 66;
446
	public static int AREA_ITALIAN_MAINLAND = 67;
447
	public static int AREA_SAN_MARINO = 68;
448
	public static int AREA_FORMER_JUGOSLAVIA = 69;
449
	public static int AREA_LATVIA = 70;
450
	public static int AREA_LITHUANIA = 71;
451
	public static int AREA_PORTUGUESE_MAINLAND = 72;
452
	public static int AREA_MADEIRA_ARCHIPELAGO = 73;
453
	public static int AREA_DESERTAS = 74;
454
	public static int AREA_MADEIRA = 75;
455
	public static int AREA_PORTO_SANTO = 76;
456
	public static int AREA_THE_FORMER_JUGOSLAV_REPUBLIC_OF_MAKEDONIJA = 77;
457
	public static int AREA_MOLDOVA = 78;
458
	public static int AREA_NORWEGIAN_MAINLAND = 79;
459
	public static int AREA_POLAND = 80;
460
	public static int AREA_THE_RUSSIAN_FEDERATION = 81;
461
	public static int AREA_NOVAYA_ZEMLYA_AND_FRANZ_JOSEPH_LAND = 82;
462
	public static int AREA_CENTRAL_EUROPEAN_RUSSIA = 83;
463
	public static int AREA_EASTERN_EUROPEAN_RUSSIA = 84;
464
	public static int AREA_KALININGRAD = 85;
465
	public static int AREA_NORTHERN_EUROPEAN_RUSSIA = 86;
466
	public static int AREA_NORTHWEST_EUROPEAN_RUSSIA = 87;
467
	public static int AREA_SOUTH_EUROPEAN_RUSSIA = 88;
468
	public static int AREA_ROMANIA = 89;
469
	public static int AREA_FORMER_USSR = 90;
470
	public static int AREA_RUSSIA_BALTIC = 91;
471
	public static int AREA_RUSSIA_CENTRAL = 92;
472
	public static int AREA_RUSSIA_SOUTHEAST = 93;
473
	public static int AREA_RUSSIA_NORTHERN = 94;
474
	public static int AREA_RUSSIA_SOUTHWEST = 95;
475
	public static int AREA_SARDEGNA = 96;
476
	public static int AREA_SVALBARD_WITH_BJORNOYA_AND_JAN_MAYEN = 97;
477
	public static int AREA_SELVAGENS_ISLANDS = 98;
478
	public static int AREA_SICILY_WITH_MALTA = 99;
479
	public static int AREA_MALTA = 100;
480
	public static int AREA_SICILY = 101;
481
	public static int AREA_SLOVAKIA = 102;
482
	public static int AREA_SLOVENIA = 103;
483
	public static int AREA_SERBIA_WITH_MONTENEGRO = 104;
484
	public static int AREA_SERBIA_INCLUDING_VOJVODINA_AND_WITH_KOSOVO = 105;
485
	public static int AREA_SWEDEN = 106;
486
	public static int AREA_EUROPEAN_TURKEY = 107;
487
	public static int AREA_UKRAINE_INCLUDING_CRIMEA = 108;
488
	public static int AREA_CRIMEA = 109;
489
	public static int AREA_UKRAINE = 110;
490
	public static int AREA_GREEK_MAINLAND = 111;
491
	public static int AREA_CRETE = 112;
492
	public static int AREA_DODECANESE_ISLANDS = 113;
493
	public static int AREA_CYCLADES_ISLANDS = 114;
494
	public static int AREA_NORTH_AEGEAN_ISLANDS = 115;
495
	public static int AREA_VATICAN_CITY = 116;
496
	public static int AREA_FRANZ_JOSEF_LAND = 117;
497
	public static int AREA_NOVAYA_ZEMLYA = 118;
498
	public static int AREA_AZERBAIJAN_INCLUDING_NAKHICHEVAN = 119;
499
	public static int AREA_AZERBAIJAN = 120;
500
	public static int AREA_NAKHICHEVAN = 121;
501
	public static int AREA_ALGERIA = 122;
502
	public static int AREA_ARMENIA = 123;
503
	public static int AREA_CAUCASUS_REGION = 124;
504
	public static int AREA_EGYPT = 125;
505
	public static int AREA_GEORGIA = 126;
506
	public static int AREA_ISRAEL_JORDAN = 127;
507
	public static int AREA_ISRAEL = 128;
508
	public static int AREA_JORDAN = 129;
509
	public static int AREA_LEBANON = 130;
510
	public static int AREA_LIBYA = 131;
511
	public static int AREA_LEBANON_SYRIA = 132;
512
	public static int AREA_MOROCCO = 133;
513
	public static int AREA_NORTH_CAUCASUS = 134;
514
	public static int AREA_SINAI = 135;
515
	public static int AREA_SYRIA = 136;
516
	public static int AREA_TUNISIA = 137;
517
	public static int AREA_ASIATIC_TURKEY = 138;
518
	public static int AREA_TURKEY = 139;
519
	public static int AREA_NORTHERN_AFRICA = 140;
520
	public static int AREA_AFRO_TROPICAL_REGION = 141;
521
	public static int AREA_AUSTRALIAN_REGION = 142;
522
	public static int AREA_EAST_PALAEARCTIC = 143;
523
	public static int AREA_NEARCTIC_REGION = 144;
524
	public static int AREA_NEOTROPICAL_REGION = 145;
525
	public static int AREA_NEAR_EAST = 146;
526
	public static int AREA_ORIENTAL_REGION = 147;
527
	public static int AREA_EUROPEAN_MARINE_WATERS = 148;
528
	public static int AREA_MEDITERRANEAN_SEA = 149;
529
	public static int AREA_WHITE_SEA = 150;
530
	public static int AREA_NORTH_SEA = 151;
531
	public static int AREA_BALTIC_SEA = 152;
532
	public static int AREA_BLACK_SEA = 153;
533
	public static int AREA_BARENTS_SEA = 154;
534
	public static int AREA_CASPIAN_SEA = 155;
535
	public static int AREA_PORTUGUESE_EXCLUSIVE_ECONOMIC_ZONE = 156;
536
	public static int AREA_BELGIAN_EXCLUSIVE_ECONOMIC_ZONE = 157;
537
	public static int AREA_FRENCH_EXCLUSIVE_ECONOMIC_ZONE = 158;
538
	public static int AREA_ENGLISH_CHANNEL = 159;
539
	public static int AREA_ADRIATIC_SEA = 160;
540
	public static int AREA_BISCAY_BAY = 161;
541
	public static int AREA_DUTCH_EXCLUSIVE_ECONOMIC_ZONE = 162;
542
	public static int AREA_UNITED_KINGDOM_EXCLUSIVE_ECONOMIC_ZONE = 163;
543
	public static int AREA_SPANISH_EXCLUSIVE_ECONOMIC_ZONE = 164;
544
	public static int AREA_EGYPTIAN_EXCLUSIVE_ECONOMIC_ZONE = 165;
545
	public static int AREA_GREEK_EXCLUSIVE_ECONOMIC_ZONE = 166;
546
	public static int AREA_TIRRENO_SEA = 167;
547
	public static int AREA_ICELANDIC_EXCLUSIVE_ECONOMIC_ZONE = 168;
548
	public static int AREA_IRISH_EXCLUSIVE_ECONOMIC_ZONE = 169;
549
	public static int AREA_IRISH_SEA = 170;
550
	public static int AREA_ITALIAN_EXCLUSIVE_ECONOMIC_ZONE = 171;
551
	public static int AREA_NORWEGIAN_SEA = 172;
552
	public static int AREA_MOROCCAN_EXCLUSIVE_ECONOMIC_ZONE = 173;
553
	public static int AREA_NORWEGIAN_EXCLUSIVE_ECONOMIC_ZONE = 174;
554
	public static int AREA_SKAGERRAK = 175;
555
	public static int AREA_TUNISIAN_EXCLUSIVE_ECONOMIC_ZONE = 176;
556
	public static int AREA_WADDEN_SEA = 177;
557
	public static int AREA_BELT_SEA = 178;
558
	public static int AREA_MARMARA_SEA = 179;
559
	public static int AREA_SEA_OF_AZOV = 180;
560
	public static int AREA_AEGEAN_SEA = 181;
561
	public static int AREA_BULGARIAN_EXCLUSIVE_ECONOMIC_ZONE = 182;
562
	public static int AREA_SOUTH_BALTIC_PROPER = 183;
563
	public static int AREA_BALTIC_PROPER = 184;
564
	public static int AREA_NORTH_BALTIC_PROPER = 185;
565
	public static int AREA_ARCHIPELAGO_SEA = 186;
566
	public static int AREA_BOTHNIAN_SEA = 187;
567
	public static int AREA_GERMAN_EXCLUSIVE_ECONOMIC_ZONE = 188;
568
	public static int AREA_SWEDISH_EXCLUSIVE_ECONOMIC_ZONE = 189;
569
	public static int AREA_UKRAINIAN_EXCLUSIVE_ECONOMIC_ZONE = 190;
570
	public static int AREA_MADEIRAN_EXCLUSIVE_ECONOMIC_ZONE = 191;
571
	public static int AREA_LEBANESE_EXCLUSIVE_ECONOMIC_ZONE = 192;
572
	public static int AREA_SPANISH_EXCLUSIVE_ECONOMIC_ZONE_MEDITERRANEAN_PART = 193;
573
	public static int AREA_ESTONIAN_EXCLUSIVE_ECONOMIC_ZONE = 194;
574
	public static int AREA_CROATIAN_EXCLUSIVE_ECONOMIC_ZONE = 195;
575
	public static int AREA_BALEAR_SEA = 196;
576
	public static int AREA_TURKISH_EXCLUSIVE_ECONOMIC_ZONE = 197;
577
	public static int AREA_DANISH_EXCLUSIVE_ECONOMIC_ZONE = 198;
578
	public static int AREA_TRANSCAUCASUS = 199;
579

    
580
	public static int AREA_GEORGIA_G = 200;
581
	public static int AREA_ABKHAZIA = 201;
582
	public static int AREA_ADZARIA = 202;
583

    
584
	public static int AREA_UNITED_KINGDOM = 203;
585
	public static int AREA_DENMARK_COUNTRY = 204;
586
	public static int AREA_TURKEY_COUNTRY = 205;
587
	public static int AREA_SPAIN_COUNTRY = 206;
588
	public static int AREA_GREECE_COUNTRY = 207;
589
	public static int AREA_PORTUGAL_COUNTRY = 208;
590
	//continues without variables
591

    
592
	// OccurrenceStatus
593
	public static int STATUS_PRESENT = 1;
594
	public static int STATUS_ABSENT = 2;
595
	public static int STATUS_NATIVE = 3;
596
	public static int STATUS_INTRODUCED = 4;
597
	public static int STATUS_NATURALISED = 5;
598
	public static int STATUS_INVASIVE = 6;
599
	public static int STATUS_MANAGED = 7;
600
	public static int STATUS_DOUBTFUL = 8;
601

    
602
	private final Map<String, Integer> tdwgKeyMap = new HashMap<>();
603
	private final Map<Integer, String> areaCacheMap = new HashMap<>();
604
	private final Map<Integer, String> languageCacheMap  = new HashMap<>();
605
	private static final Map<String,Integer> languageCodeToKeyMap = new HashMap<>();
606

    
607
	private final Map<Integer, String> featureCacheMap  = new HashMap<>();
608
	private final Map<Integer, String> nameStatusCacheMap  = new HashMap<>();
609
	private final Map<Integer, String> qualityStatusCacheMap  = new HashMap<>();
610
	private final Map<Integer, String> taxonStatusCacheMap  = new HashMap<>();
611
	private final Map<Integer, String> taxRelQualifierCacheMap  = new HashMap<>();
612
	private final Map<Integer, String> taxRelZooQualifierCacheMap  = new HashMap<>();
613
	private final Map<Integer, String> sourceUseCacheMap  = new HashMap<>();
614
	private final Map<Integer, String> fossilStatusCacheMap  = new HashMap<>();
615
	private final Map<Integer, String> typeDesigStatusCacheMap  = new HashMap<>();
616
	private final Map<Integer, String> sourceCategoryCacheMap  = new HashMap<>();
617
	private final Map<Integer, String> occurrenceStatusCacheMap  = new HashMap<>();
618
	private final Map<Integer, Map<Integer, String>> rankCacheMap  = new  HashMap<>();
619
	private final Map<Integer, Map<Integer, String>> rankAbbrevCacheMap  = new  HashMap<>();
620

    
621

    
622
	private final Source destination;
623

    
624
	public PesiTransformer(Source destination) {
625
		super();
626
		this.destination = destination;
627
		fillMaps();
628
	}
629

    
630
	private void fillMaps() {
631
		try {
632
		    //TDWG
633
			String sql = " SELECT AreaId, AreaName, AreaTdwgCode, AreaEmCode, AreaFaEuCode FROM Area";
634
			ResultSet rs = destination.getResultSet(sql);
635
			while (rs.next()){
636
				String tdwg = rs.getString("AreaTdwgCode");
637
				Integer id = rs.getInt("AreaId");
638
				String label = rs.getString("AreaName");
639

    
640
				if (StringUtils.isNotBlank(tdwg)){
641
					this.tdwgKeyMap.put(tdwg, id);
642
				}
643
				this.areaCacheMap.put(id, label);
644
			}
645

    
646
			//rankCache
647
			sql = " SELECT KingdomId, RankId, Rank, RankAbbrev, Kingdom  FROM Rank";
648
			rs = destination.getResultSet(sql);
649
			while (rs.next()){
650
				String rank = rs.getString("Rank");
651
				String abbrev = rs.getString("RankAbbrev");
652
				Integer rankId = rs.getInt("RankId");
653
				Integer kingdomId = rs.getInt("KingdomId");
654
				String kingdom = rs.getString("Kingdom");
655

    
656
				//rank str
657
				Map<Integer, String> kingdomMap = rankCacheMap.get(kingdomId);
658
				if (kingdomMap == null){
659
					kingdomMap = new HashMap<>();
660
					rankCacheMap.put(kingdomId, kingdomMap);
661
				}
662
				kingdomMap.put(rankId, rank);
663

    
664
				if (rank.equals("Kingdom")){
665
				    pesiKingdomMap.put(kingdom, kingdomId);
666
				}
667

    
668
				//rank abbrev
669
				Map<Integer, String> kingdomAbbrevMap = rankAbbrevCacheMap.get(kingdomId);
670
				if (kingdomAbbrevMap == null){
671
					kingdomAbbrevMap = new HashMap<>();
672
					rankAbbrevCacheMap.put(kingdomId, kingdomAbbrevMap);
673
				}
674
				if (StringUtils.isNotBlank(abbrev)){
675
					kingdomAbbrevMap.put(rankId, abbrev);
676
				}
677
			}
678

    
679
			//languageCache
680
			fillSingleMap(languageCacheMap,"Language");
681

    
682
			//feature / note category
683
			fillSingleMap(featureCacheMap,"NoteCategory");
684

    
685
			//nameStatusCache
686
			fillSingleMap(nameStatusCacheMap,"NameStatus", "NomStatus");
687

    
688
			//qualityStatusCache
689
			fillSingleMap(qualityStatusCacheMap,"QualityStatus");
690

    
691
			//taxonStatusCache
692
			fillSingleMap(taxonStatusCacheMap,"TaxonStatus", "Status");
693

    
694
			//sourceUse
695
			fillSingleMap(sourceUseCacheMap,"SourceUse");
696

    
697
			//fossil status
698
			fillSingleMap(fossilStatusCacheMap,"FossilStatus");
699

    
700
			//fossil status
701
			fillSingleMap(typeDesigStatusCacheMap,"FossilStatus");
702

    
703
			//fossil status
704
			fillSingleMap(occurrenceStatusCacheMap,"OccurrenceStatus");
705

    
706
			//source category
707
			fillSingleMap(sourceCategoryCacheMap,"SourceCategory", "Category", "SourceCategoryId");
708

    
709
			//RelTaxonQualifier
710
			sql = " SELECT QualifierId, Qualifier, ZoologQualifier FROM RelTaxonQualifier ";
711
			rs = destination.getResultSet(sql);
712
			while (rs.next()){
713
				Integer key = rs.getInt("QualifierId");
714
				String cache = rs.getString("Qualifier");
715
				if (StringUtils.isNotBlank(cache)){
716
					this.taxRelQualifierCacheMap.put(key, cache);
717
				}
718
				String zoologCache = rs.getString("ZoologQualifier");
719
				if (StringUtils.isNotBlank(zoologCache)){
720
					this.taxRelZooQualifierCacheMap.put(key, zoologCache);
721
				}
722
			}
723

    
724
			//language code map
725
			sql = " SELECT LanguageId, Language, ISO639_1, ISO639_2, ISO639_3 FROM Language";
726
			rs = destination.getResultSet(sql);
727
			while (rs.next()){
728
                Integer id = rs.getInt("LanguageId");
729
                Integer oldId;
730
                String iso639_1 = rs.getString("ISO639_1");
731
                if (StringUtils.isNotBlank(iso639_1)){
732
                    oldId = languageCodeToKeyMap.put(iso639_1, id);
733
                    checkOldId(id, oldId, iso639_1);
734
                }
735
                String iso639_2 = rs.getString("ISO639_2");
736
                if (StringUtils.isNotBlank(iso639_2)){
737
                    oldId = languageCodeToKeyMap.put(iso639_2, id);
738
                    checkOldId(id, oldId, iso639_1);
739
                }
740
                String iso639_3 = rs.getString("ISO639_3");
741
                if (StringUtils.isNotBlank(iso639_3)){
742
                    oldId = languageCodeToKeyMap.put(iso639_3, id);
743
                    checkOldId(id, oldId, iso639_1);
744
                }
745

    
746
            }
747
			rs = null;
748
		} catch (Exception e) {
749
			logger.error("Exception when trying to read area map", e);
750
			e.printStackTrace();
751
		}
752
	}
753

    
754
    private void checkOldId(Integer id, Integer oldId, String isoCode) {
755
        if (oldId != null && !oldId.equals(id)){
756
            logger.warn("Language code " + isoCode + " exists for >1 language IDs. This should not happen.");
757
        }
758
    }
759

    
760
    private void fillSingleMap(Map<Integer, String> map, String tableName) throws SQLException {
761
		fillSingleMap(map, tableName, tableName,  tableName + "Id");
762
	}
763

    
764
	private void fillSingleMap(Map<Integer, String> map, String tableName, String attr) throws SQLException {
765
			fillSingleMap(map, tableName, attr,  attr + "Id");
766
	}
767

    
768
	private void fillSingleMap(Map<Integer, String> map, String tableName, String attr, String idAttr) throws SQLException {
769
		String sql;
770
		ResultSet rs;
771
		sql = " SELECT %s, %s FROM %s ";
772
		sql = String.format(sql, idAttr, attr, tableName);
773
		rs = destination.getResultSet(sql);
774
		while (rs.next()){
775
			Integer key = rs.getInt(idAttr);
776
			String cache = rs.getString(attr);
777
			if (StringUtils.isNotBlank(cache)){
778
				map.put(key, cache);
779
			}
780
		}
781
	}
782

    
783
	/**
784
	 * Converts the databaseString to its abbreviation if its known.
785
	 * Otherwise the databaseString is returned.
786
	 * @param databaseString
787
	 * @return
788
	 */
789
	public static String databaseString2Abbreviation(String databaseString) {
790
		String result = databaseString;
791
		if (databaseString.equals("Fauna Europaea database")) {
792
			result = "FaEu";
793
		}
794
		return result;
795
	}
796

    
797
	/**
798
	 * Returns the OccurrenceStatusId for a given PresenceAbsenceTerm.
799
	 * @param term
800
	 * @return
801
	 * @throws UnknownCdmTypeException
802
	 */
803
	public static Integer presenceAbsenceTerm2OccurrenceStatusId(PresenceAbsenceTerm term) {
804
		Integer result = null;
805
		if (term == null){
806
			return null;
807
		//present
808
		}else if (term.isInstanceOf(PresenceAbsenceTerm.class)) {
809
			PresenceAbsenceTerm presenceTerm = CdmBase.deproxy(term, PresenceAbsenceTerm.class);
810
			if (presenceTerm.equals(PresenceAbsenceTerm.PRESENT()) ||
811
					presenceTerm.equals(PresenceAbsenceTerm.INTRODUCED_DOUBTFULLY_INTRODUCED()) ||
812
					presenceTerm.equals(PresenceAbsenceTerm.NATIVE_DOUBTFULLY_NATIVE())) {
813
				result = STATUS_PRESENT;
814
			} else if (presenceTerm.equals(PresenceAbsenceTerm.NATIVE())) {
815
				result = STATUS_NATIVE;
816
			} else if (presenceTerm.equals(PresenceAbsenceTerm.INTRODUCED()) ||
817
					presenceTerm.equals(PresenceAbsenceTerm.CASUAL()) ||
818
					presenceTerm.equals(PresenceAbsenceTerm.INTRODUCED_UNCERTAIN_DEGREE_OF_NATURALISATION())) {
819
				result = STATUS_INTRODUCED;
820
			} else if (presenceTerm.equals(PresenceAbsenceTerm.NATURALISED())
821
					|| presenceTerm.equals(PresenceAbsenceTerm.NATURALISED())) {
822
				result = STATUS_NATURALISED;
823
			} else if (presenceTerm.equals(PresenceAbsenceTerm.INVASIVE())) {
824
				result = STATUS_INVASIVE;
825
			} else if (presenceTerm.equals(PresenceAbsenceTerm.CULTIVATED())) {
826
				result = STATUS_MANAGED;
827
			} else if (presenceTerm.equals(PresenceAbsenceTerm.PRESENT_DOUBTFULLY())||
828
					presenceTerm.equals(PresenceAbsenceTerm.INTRODUCED_PRESENCE_QUESTIONABLE()) ||
829
					presenceTerm.equals(PresenceAbsenceTerm.NATIVE_PRESENCE_QUESTIONABLE() )) {
830
				result = STATUS_DOUBTFUL;
831
			//absent
832
			}else if (presenceTerm.equals(PresenceAbsenceTerm.ABSENT()) || presenceTerm.equals(PresenceAbsenceTerm.NATIVE_FORMERLY_NATIVE()) ||
833
					presenceTerm.equals(PresenceAbsenceTerm.CULTIVATED_REPORTED_IN_ERROR()) || presenceTerm.equals(PresenceAbsenceTerm.INTRODUCED_REPORTED_IN_ERROR()) ||
834
					presenceTerm.equals(PresenceAbsenceTerm.INTRODUCED_FORMERLY_INTRODUCED()) || presenceTerm.equals(PresenceAbsenceTerm.NATIVE_REPORTED_IN_ERROR() ) ) {
835
				result = STATUS_ABSENT;
836
			}else if (presenceTerm.getUuid().equals(BerlinModelTransformer.uuidStatusUndefined)){
837
			    logger.warn("Status undefined is mapped present for now. Needs further checking. (E+M specific)");
838
			    result = STATUS_PRESENT;
839
			} else {
840
				logger.error("PresenceAbsenceTerm could not be translated to datawarehouse occurrence status id: " + presenceTerm.getLabel());
841
			}
842
		}
843
		return result;
844
	}
845

    
846
	@Override
847
	public String getCacheByPresenceAbsenceTerm(PresenceAbsenceTerm status) throws UndefinedTransformerMethodException {
848
		if (status == null){
849
			return null;
850
		}else{
851
			return this.occurrenceStatusCacheMap.get(getKeyByPresenceAbsenceTerm(status));
852
		}
853
	}
854

    
855
	@Override
856
	public Object getKeyByPresenceAbsenceTerm(PresenceAbsenceTerm status) throws UndefinedTransformerMethodException {
857
		return presenceAbsenceTerm2OccurrenceStatusId(status);
858
	}
859

    
860
	@Override
861
	public String getCacheByNamedArea(NamedArea namedArea) throws UndefinedTransformerMethodException {
862
		NamedArea area = CdmBase.deproxy(namedArea, NamedArea.class);
863
		if (area == null){
864
			return null;
865
		}else{
866
			return this.areaCacheMap.get(getKeyByNamedArea(area));
867
		}
868
	}
869

    
870
	@Override
871
	public Object getKeyByNamedArea(NamedArea area) throws UndefinedTransformerMethodException {
872
		NamedArea namedArea = CdmBase.deproxy(area, NamedArea.class);
873

    
874
		if (area == null) {
875
			return null;
876
		//TDWG areas
877
		} else if (area.getVocabulary().getUuid().equals(NamedArea.uuidTdwgAreaVocabulary)) {
878
			String abbrevLabel = namedArea.getRepresentation(Language.DEFAULT()).getAbbreviatedLabel();
879
			Integer result = this.tdwgKeyMap.get(abbrevLabel);
880
			if (result == null){
881
				logger.warn("Unknown TDWGArea: " + area.getTitleCache());
882
			}
883
			return result;
884
		//countries
885
		}else if (namedArea.isInstanceOf(Country.class)){
886
			if (namedArea.equals(Country.UKRAINE())) { return AREA_UKRAINE_INCLUDING_CRIMEA; }
887
			else if (namedArea.equals(Country.AZERBAIJANREPUBLICOF())) { return AREA_AZERBAIJAN_INCLUDING_NAKHICHEVAN; }
888
			else if (namedArea.equals(Country.GEORGIA())) { return AREA_GEORGIA; }
889
			else if (namedArea.equals(Country.RUSSIANFEDERATION())) { return AREA_THE_RUSSIAN_FEDERATION; }
890
			else if (namedArea.equals(Country.UNITEDKINGDOMOFGREATBRITAINANDNORTHERNIRELAND())) { return AREA_UNITED_KINGDOM; }
891
			else if (namedArea.equals(Country.DENMARKKINGDOMOF())) { return AREA_DENMARK_COUNTRY; }
892
			else if (namedArea.equals(Country.TURKEYREPUBLICOF())) { return AREA_TURKEY_COUNTRY; }
893
			else {
894
				logger.warn("Unknown Country: " + area.getTitleCache());
895
			}
896
		}else{  //Non TDWG, non country
897
			//EM
898
//			if ( namedArea.getUuid().equals(BerlinModelTransformer.uuidMadeira)){ return AREA_MADEIRA; }
899
//			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidDesertas)) { return AREA_DESERTAS; }
900
//			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidPortoSanto)) { return AREA_PORTO_SANTO; }
901
//			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidFlores)) { return AREA_FLORES; }
902
//			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidCorvo)) { return AREA_CORVO; }
903
//			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidFaial)) { return AREA_FAIAL; }
904
//			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidGraciosa)) { return AREA_GRACIOSA; }
905
//			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidSaoJorge)) { return AREA_SAO_JORGE; }
906
//			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidSaoMiguel)) { return AREA_SAO_MIGUEL; }
907
//			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidPico)) { return AREA_PICO; }
908
//			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidSantaMaria)) { return AREA_SANTA_MARIA; }
909
//			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidTerceira)) { return AREA_TERCEIRA; }
910
//			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidGranCanaria)) { return AREA_GRAN_CANARIA; }
911
//			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidFuerteventura)) { return AREA_FUERTEVENTURA_WITH_LOBOS; }
912
//			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidGomera)) { return AREA_GOMERA; }
913
//			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidHierro)) { return AREA_HIERRO; }
914
//			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidLanzaroteWithGraciosa)) { return AREA_LANZAROTE_WITH_GRACIOSA; }
915
//			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidLaPalma)) { return AREA_LA_PALMA; }
916
//			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidTenerife)) { return AREA_TENERIFE; }
917
//			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidIbizaWithFormentera)) { return AREA_IBIZA_WITH_FORMENTERA; }
918
//			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidMallorca)) { return AREA_MALLORCA; }
919
//			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidMenorca)) { return AREA_MENORCA; }
920
//
921
//			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidUssr)) { return AREA_FORMER_USSR; }
922
//			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidRussiaBaltic)) { return AREA_RUSSIA_BALTIC; }
923
//			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidRussiaSouthEast)) { return AREA_RUSSIA_SOUTHEAST; }
924
//			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidRussiaSouthWest)) { return AREA_RUSSIA_SOUTHWEST; }
925
//			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidRussiaCentral)) { return AREA_RUSSIA_CENTRAL; }
926
//			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidRussiaNorthern)) { return AREA_RUSSIA_NORTHERN; }
927
//
928
//			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidTurkey)) { return AREA_TURKEY; }
929
//			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidEastAegeanIslands)) { return AREA_EAST_AEGEAN_ISLANDS; }
930
//			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidTurkishEastAegeanIslands)) { return AREA_TURKISH_EAST_AEGEAN_ISLANDS; }
931
//			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidSerbiaMontenegro)) { return AREA_SERBIA_WITH_MONTENEGRO; }
932
//			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidSerbia)) { return AREA_SERBIA_INCLUDING_VOJVODINA_AND_WITH_KOSOVO; }
933
//			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidCaucasia)) { return AREA_CAUCASUS_REGION; }
934
//			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidUkraineAndCrimea)) { return AREA_UKRAINE_INCLUDING_CRIMEA; }
935
//			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidAzerbaijanNakhichevan)) { return AREA_AZERBAIJAN_INCLUDING_NAKHICHEVAN; }
936

    
937
			if (namedArea.getUuid().equals(BerlinModelTransformer.uuidEM)) {
938
//				logger.warn("E+M area not available in PESI");
939
				return null;
940
			}
941
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidEUR)) { logger.warn("EUR area not available in PESI"); return null; }
942
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidAb)) { return AREA_AZERBAIJAN_INCLUDING_NAKHICHEVAN; }
943
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidAb_A)) { return AREA_AZERBAIJAN; }
944
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidAb_N)) { return AREA_NAKHICHEVAN; }
945
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidAE)) { return AREA_EAST_AEGEAN_ISLANDS; }
946
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidAE_G)) { return AREA_GREEK_EAST_AEGEAN_ISLANDS; }
947
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidAE_T)) { return AREA_TURKISH_EAST_AEGEAN_ISLANDS; }
948
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidAg)) { return AREA_ALGERIA; }
949
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidAl)) { return AREA_ALBANIA; }
950
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidAr)) { return AREA_ARMENIA; }
951
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidAu)) { return AREA_AUSTRIA_WITH_LIECHTENSTEIN; }
952
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidAu_A)) { return AREA_AUSTRIA; }
953
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidAu_L)) { return AREA_LIECHTENSTEIN; }
954
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidAz)) { return AREA_AZORES; }
955
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidAz_C)) { return AREA_CORVO; }
956
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidAz_F)) { return AREA_FAIAL; }
957
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidAz_G)) { return AREA_GRACIOSA; }
958
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidAz_J)) { return AREA_SAO_JORGE; }
959
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidAz_L)) { return AREA_FLORES; }
960
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidAz_M)) { return AREA_SAO_MIGUEL; }
961
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidAz_P)) { return AREA_PICO; }
962
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidAz_S)) { return AREA_SANTA_MARIA; }
963
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidAz_T)) { return AREA_TERCEIRA; }
964
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidBe)) { return AREA_BELGIUM_WITH_LUXEMBOURG; }
965
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidBe_B)) { return AREA_BELGIUM; }
966
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidBe_L)) { return AREA_LUXEMBOURG; }
967
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidBH)) { return AREA_BOSNIA_HERZEGOVINA; }
968
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidBl)) { return AREA_BALEARES; }
969
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidBl_I)) { return AREA_IBIZA_WITH_FORMENTERA; }
970
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidBl_M)) { return AREA_MALLORCA; }
971
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidBl_N)) { return AREA_MENORCA; }
972
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidBr)) { return AREA_GREAT_BRITAIN; }
973
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidBt)) { return AREA_BALTIC_STATES_ESTONIA_LATVIA_LITHUANIA_AND_KALININGRAD_REGION; }
974
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidBu)) { return AREA_BULGARIA; }
975
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidBy)) { return AREA_BELARUS; }
976
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidCa)) { return AREA_CANARY_ISLANDS; }
977
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidCa_C)) { return AREA_GRAN_CANARIA; }
978
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidCa_F)) { return AREA_FUERTEVENTURA_WITH_LOBOS; }
979
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidCa_G)) { return AREA_GOMERA; }
980
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidCa_H)) { return AREA_HIERRO; }
981
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidCa_L)) { return AREA_LANZAROTE_WITH_GRACIOSA; }
982
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidCa_P)) { return AREA_LA_PALMA; }
983
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidCa_T)) { return AREA_TENERIFE; }
984
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidCc)) { return AREA_CAUCASUS_REGION; }
985
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidCg)) { return AREA_MONTENEGRO; }
986
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidCo)) { return AREA_CORSE; }
987
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidCr)) { return AREA_CRETE_WITH_KARPATHOS_KASOS_AND_GAVDHOS; }
988
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidCs)) { return AREA_CZECH_REPUBLIC; }
989
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidCt)) { return AREA_CROATIA; }
990
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidCy)) { return AREA_CYPRUS; }
991
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidCz)) { return AREA_FORMER_CZECHOSLOVAKIA; }
992
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidDa)) { return AREA_DENMARK_WITH_BORNHOLM; }
993
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidEg)) { return AREA_EGYPT; }
994
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidEs)) { return AREA_ESTONIA; }
995
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidFa)) { return AREA_FAROE_ISLANDS; }
996
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidFe)) { return AREA_FINLAND_WITH_AHVENANMAA; }
997
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidGa)) { return AREA_FRANCE; }
998
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidGa_C)) { return AREA_CHANNEL_ISLANDS; }
999
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidGa_F)) { return AREA_FRENCH_MAINLAND; }
1000
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidGa_M)) { return AREA_MONACO; }
1001

    
1002
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidGe)) { return AREA_GERMANY; }
1003
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidGg)) { return AREA_GEORGIA; }
1004

    
1005
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidGg_G)) { return AREA_GEORGIA_G; }
1006
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidGg_A)) { return AREA_ABKHAZIA; }
1007
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidGg_D)) { return AREA_ADZARIA; }
1008

    
1009
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidGr)) { return AREA_GREECE_WITH_CYCLADES_AND_MORE_ISLANDS; }
1010
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidHb)) { return AREA_IRELAND; }
1011
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidHb_E)) { return AREA_REPUBLIC_OF_IRELAND; }
1012
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidHb_N)) { return AREA_NORTHERN_IRELAND; }
1013
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidHe)) { return AREA_SWITZERLAND; }
1014
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidHo)) { return AREA_NETHERLANDS; }
1015
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidHs)) { return AREA_SPAIN; }
1016
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidHs_A)) { return AREA_ANDORRA; }
1017
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidHs_G)) { return AREA_GIBRALTAR; }
1018
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidHs_S)) { return AREA_KINGDOM_OF_SPAIN; }
1019
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidHu)) { return AREA_HUNGARY; }
1020
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidIJ)) { return AREA_ISRAEL_JORDAN; }
1021
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidIr)) { return AREA_ISRAEL; }
1022
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidIs)) { return AREA_ICELAND; }
1023
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidIt)) { return AREA_ITALY; }
1024
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidIt_I)) { return AREA_ITALIAN_MAINLAND; }
1025
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidIt_S)) { return AREA_SAN_MARINO; }
1026
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidJo)) { return AREA_JORDAN; }
1027
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidJu)) { return AREA_FORMER_JUGOSLAVIA; }
1028
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidLa)) { return AREA_LATVIA; }
1029
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidLe)) { return AREA_LEBANON; }
1030
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidLi)) { return AREA_LIBYA; }
1031
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidLS)) { return AREA_LEBANON_SYRIA; }
1032
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidLt)) { return AREA_LITHUANIA; }
1033
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidLu)) { return AREA_PORTUGUESE_MAINLAND; }
1034
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidMa)) { return AREA_MOROCCO; }
1035
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidMd)) { return AREA_MADEIRA; }
1036
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidMd_D)) { return AREA_DESERTAS; }
1037
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidMd_M)) { return AREA_MADEIRA; }
1038
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidMd_P)) { return AREA_PORTO_SANTO; }
1039
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidMk)) { return AREA_THE_FORMER_JUGOSLAV_REPUBLIC_OF_MAKEDONIJA; }
1040
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidMo)) { return AREA_MOLDOVA; }
1041
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidNo)) { return AREA_NORWEGIAN_MAINLAND; }
1042
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidPo)) { return AREA_POLAND; }
1043
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidRf)) { return AREA_THE_RUSSIAN_FEDERATION; }
1044
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidRf_A)) { return AREA_NOVAYA_ZEMLYA_AND_FRANZ_JOSEPH_LAND; }
1045
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidRf_C)) { return AREA_CENTRAL_EUROPEAN_RUSSIA; }
1046
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidRf_CS)) { return AREA_NORTH_CAUCASUS; }
1047
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidRf_E)) { return AREA_EASTERN_EUROPEAN_RUSSIA; }
1048
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidRf_K)) { return AREA_KALININGRAD; }
1049
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidRf_N)) { return AREA_NORTHERN_EUROPEAN_RUSSIA; }
1050
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidRf_NW)) { return AREA_NORTHWEST_EUROPEAN_RUSSIA; }
1051
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidRf_S)) { return AREA_SOUTH_EUROPEAN_RUSSIA; }
1052
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidRm)) { return AREA_ROMANIA; }
1053
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidRs)) { return AREA_FORMER_USSR; }
1054
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidRs_B)) { return AREA_RUSSIA_BALTIC; }
1055
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidRs_C)) { return AREA_RUSSIA_CENTRAL; }
1056
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidRs_E)) { return AREA_RUSSIA_SOUTHEAST; }
1057
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidRs_K)) { return AREA_CRIMEA; }
1058
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidRs_N)) { return AREA_RUSSIA_NORTHERN; }
1059
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidRs_W)) { return AREA_RUSSIA_SOUTHWEST; }
1060
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidSa)) { return AREA_SARDEGNA; }
1061
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidSb)) { return AREA_SVALBARD_WITH_BJORNOYA_AND_JAN_MAYEN; }
1062
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidSg)) { return AREA_SELVAGENS_ISLANDS; }
1063
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidSi)) { return AREA_SICILY_WITH_MALTA; }
1064
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidSi_M)) { return AREA_MALTA; }
1065
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidSi_S)) { return AREA_SICILY; }
1066
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidSk)) { return AREA_SLOVAKIA; }
1067
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidSl)) { return AREA_SLOVENIA; }
1068
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidSM)) { return AREA_SERBIA_WITH_MONTENEGRO; }
1069
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidSn)) { return AREA_SINAI; }
1070
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidSr)) { return AREA_SERBIA_INCLUDING_VOJVODINA_AND_WITH_KOSOVO; }
1071
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidSu)) { return AREA_SWEDEN; }
1072
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidSy)) { return AREA_SYRIA; }
1073
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidTcs)) { return AREA_TRANSCAUCASUS; }
1074
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidTn)) { return AREA_TUNISIA; }
1075
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidTu)) { return AREA_TURKEY; }
1076
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidTu_A)) { return AREA_ASIATIC_TURKEY; }
1077
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidTu_E)) { return AREA_EUROPEAN_TURKEY; }
1078
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidUk)) { return AREA_UKRAINE_INCLUDING_CRIMEA; }
1079
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidUk_K)) { return AREA_CRIMEA; }
1080
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidUk_U)) { return AREA_UKRAINE; }
1081

    
1082

    
1083

    
1084
			/*FE
1085
			else if (namedArea.getUuid().equals(FaunaEuropaeaTransformer.uuidAreaAFR)) { return AREA_AFRO_TROPICAL_REGION; }
1086
			else if (namedArea.getUuid().equals(FaunaEuropaeaTransformer.uuidAreaAUS)) { return AREA_AUSTRALIAN_REGION; }
1087
			else if (namedArea.getUuid().equals(FaunaEuropaeaTransformer.uuidAreaEPA)) { return AREA_EAST_PALAEARCTIC; }
1088
			else if (namedArea.getUuid().equals(FaunaEuropaeaTransformer.uuidAreaGR_AEG)) { return AREA_NORTH_AEGEAN_ISLANDS; }
1089
			else if (namedArea.getUuid().equals(FaunaEuropaeaTransformer.uuidAreaGR_CYC)) { return AREA_CYCLADES_ISLANDS; }
1090
			else if (namedArea.getUuid().equals(FaunaEuropaeaTransformer.uuidAreaGR_DOD)) { return AREA_DODECANESE_ISLANDS; }
1091
			else if (namedArea.getUuid().equals(FaunaEuropaeaTransformer.uuidAreaGR_CR)) { return AREA_CRETE; }
1092
			else if (namedArea.getUuid().equals(FaunaEuropaeaTransformer.uuidAreaGR_GRC)) { return AREA_GREEK_MAINLAND; }
1093
			else if (namedArea.getUuid().equals(FaunaEuropaeaTransformer.uuidAreaNAF)) { return AREA_NORTHERN_AFRICA; }
1094
			else if (namedArea.getUuid().equals(FaunaEuropaeaTransformer.uuidAreaNEA)) { return AREA_NEARCTIC_REGION; }
1095
			else if (namedArea.getUuid().equals(FaunaEuropaeaTransformer.uuidAreaNEO)) { return AREA_NEOTROPICAL_REGION; }
1096
			else if (namedArea.getUuid().equals(FaunaEuropaeaTransformer.uuidAreaNRE)) { return AREA_NEAR_EAST; }
1097
			else if (namedArea.getUuid().equals(FaunaEuropaeaTransformer.uuidAreaORR)) { return AREA_ORIENTAL_REGION; }
1098
			else if (namedArea.getUuid().equals(FaunaEuropaeaTransformer.uuidAreaUA)) { return AREA_UKRAINE_INCLUDING_CRIMEA; }
1099
			else if (namedArea.getUuid().equals(FaunaEuropaeaTransformer.uuidAreaRU_FJL)) { return AREA_FRANZ_JOSEF_LAND; }
1100
			else if (namedArea.getUuid().equals(FaunaEuropaeaTransformer.uuidAreaRU_NOZ)) { return AREA_NOVAYA_ZEMLYA; }
1101
*/
1102

    
1103
			//ERMS
1104
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidEuropeanMarineWaters)) { return AREA_EUROPEAN_MARINE_WATERS; }
1105
			else if (//(namedArea.getRepresentation(Language.DEFAULT()).getAbbreviatedLabel()).equals("MES") ||   /carefull: NPE!
1106
					(namedArea.getUuid().equals(ErmsTransformer.uuidMediterraneanSea))) { return AREA_MEDITERRANEAN_SEA; } // abbreviated label missing
1107
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidWhiteSea)) { return AREA_WHITE_SEA; }
1108
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidNorthSea)) { return AREA_NORTH_SEA; }
1109
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidBalticSea)) { return AREA_BALTIC_SEA; }
1110
			else if (//(namedArea.getRepresentation(Language.DEFAULT()).getAbbreviatedLabel()).equals("BLS") ||   /carefull: NPE!
1111
					(namedArea.getUuid().equals(ErmsTransformer.uuidBlackSea))) { return AREA_BLACK_SEA; } // abbreviated label missing
1112
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidBarentsSea)) { return AREA_BARENTS_SEA; }
1113
			else if (//(namedArea.getRepresentation(Language.DEFAULT()).getAbbreviatedLabel()).equals("CAS") ||   /carefull: NPE!
1114
					(namedArea.getUuid().equals(ErmsTransformer.uuidCaspianSea))) { return AREA_CASPIAN_SEA; } // abbreviated label missing
1115
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidPortugueseExclusiveEconomicZone)) { return AREA_PORTUGUESE_EXCLUSIVE_ECONOMIC_ZONE; }
1116
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidBelgianExclusiveEconomicZone)) { return AREA_BELGIAN_EXCLUSIVE_ECONOMIC_ZONE; }
1117
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidFrenchExclusiveEconomicZone)) { return AREA_FRENCH_EXCLUSIVE_ECONOMIC_ZONE; }
1118
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidEnglishChannel)) { return AREA_ENGLISH_CHANNEL; }
1119
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidAdriaticSea)) { return AREA_ADRIATIC_SEA; }
1120
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidBiscayBay)) { return AREA_BISCAY_BAY; }
1121
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidDutchExclusiveEconomicZone)) { return AREA_DUTCH_EXCLUSIVE_ECONOMIC_ZONE; }
1122
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidUnitedKingdomExclusiveEconomicZone)) { return AREA_UNITED_KINGDOM_EXCLUSIVE_ECONOMIC_ZONE; }
1123
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidSpanishExclusiveEconomicZone)) { return AREA_SPANISH_EXCLUSIVE_ECONOMIC_ZONE; }
1124
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidEgyptianExclusiveEconomicZone)) { return AREA_EGYPTIAN_EXCLUSIVE_ECONOMIC_ZONE; }
1125
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidTirrenoSea)) { return AREA_TIRRENO_SEA; }
1126
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidIcelandicExclusiveEconomicZone)) { return AREA_ICELANDIC_EXCLUSIVE_ECONOMIC_ZONE; }
1127
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidIrishExclusiveeconomicZone)) { return AREA_IRISH_EXCLUSIVE_ECONOMIC_ZONE; }
1128
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidIrishSea)) { return AREA_IRISH_SEA; }
1129
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidIsraeliExclusiveEconomicZone)){ return 218;}
1130
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidItalianExclusiveEconomicZone)) { return AREA_ITALIAN_EXCLUSIVE_ECONOMIC_ZONE; }
1131
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidNorwegianSea)) { return AREA_NORWEGIAN_SEA; }
1132
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidMoroccanExclusiveEconomicZone)) { return AREA_MOROCCAN_EXCLUSIVE_ECONOMIC_ZONE; }
1133
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidNorwegianExclusiveEconomicZone)) { return AREA_NORWEGIAN_EXCLUSIVE_ECONOMIC_ZONE; }
1134
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidSkagerrak)) { return AREA_SKAGERRAK; }
1135
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidTunisianExclusiveEconomicZone)) { return AREA_TUNISIAN_EXCLUSIVE_ECONOMIC_ZONE; }
1136
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidWaddenSea)) { return AREA_WADDEN_SEA; }
1137
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidBeltSea)) { return AREA_BELT_SEA; }
1138
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidMarmaraSea)) { return AREA_MARMARA_SEA; }
1139
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidSeaofAzov)) { return AREA_SEA_OF_AZOV; }
1140
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidAegeanSea)) { return AREA_AEGEAN_SEA; }
1141
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidBulgarianExclusiveEconomicZone)) { return AREA_BULGARIAN_EXCLUSIVE_ECONOMIC_ZONE; }
1142
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidSouthBalticproper)) { return AREA_SOUTH_BALTIC_PROPER; }
1143
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidBalticProper)) { return AREA_BALTIC_PROPER; }
1144
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidNorthBalticproper)) { return AREA_NORTH_BALTIC_PROPER; }
1145
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidArchipelagoSea)) { return AREA_ARCHIPELAGO_SEA; }
1146
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidBothnianSea)) { return AREA_BOTHNIAN_SEA; }
1147
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidGermanExclusiveEconomicZone)) { return AREA_GERMAN_EXCLUSIVE_ECONOMIC_ZONE; }
1148
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidSwedishExclusiveEconomicZone)) { return AREA_SWEDISH_EXCLUSIVE_ECONOMIC_ZONE; }
1149
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidUkrainianExclusiveEconomicZone)) { return AREA_UKRAINIAN_EXCLUSIVE_ECONOMIC_ZONE; }
1150
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidMadeiranExclusiveEconomicZone)) { return AREA_MADEIRAN_EXCLUSIVE_ECONOMIC_ZONE; }
1151
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidLebaneseExclusiveEconomicZone)) { return AREA_LEBANESE_EXCLUSIVE_ECONOMIC_ZONE; }
1152
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidSpanishExclusiveEconomicZoneMediterraneanpart)) { return AREA_SPANISH_EXCLUSIVE_ECONOMIC_ZONE_MEDITERRANEAN_PART; }
1153
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidEstonianExclusiveEconomicZone)) { return AREA_ESTONIAN_EXCLUSIVE_ECONOMIC_ZONE; }
1154
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidCroatianExclusiveEconomicZone)) { return AREA_CROATIAN_EXCLUSIVE_ECONOMIC_ZONE; }
1155
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidBalearSea)) { return AREA_BALEAR_SEA; }
1156
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidTurkishExclusiveEconomicZone)) { return AREA_TURKISH_EXCLUSIVE_ECONOMIC_ZONE; }
1157
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidDanishExclusiveEconomicZone)) { return AREA_DANISH_EXCLUSIVE_ECONOMIC_ZONE; }
1158

    
1159
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidAlboranSea)) { return 219; }
1160
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidAlgeria)) { return 220; }
1161
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidAngola)) { return 221; }
1162
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidAustralianExclusiveEconomicZone)) { return 222; }
1163
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidBahamas)) { return 223; }
1164
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidBalearicSea)) { return 224; }
1165
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidBelgium)) { return 225; }
1166
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidBelize)) { return 226; }
1167
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidBrazil)) { return 227; }
1168
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidBulgaria)) { return 228; }
1169
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidCanada)) { return 229; }
1170
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidCapeVerde)) { return 230; }
1171
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidCapeVerdeanExclusiveEconomicZone)) { return 231; }
1172
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidCaribbeanSea)) { return 210; }
1173
            else if (namedArea.getUuid().equals(ErmsTransformer.uuidChile)) { return 232; }
1174
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidColombia)) { return 233; }
1175
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidCostaRica)) { return 234; }
1176
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidCroatia)) { return 235; }
1177
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidCuba)) { return 236; }
1178
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidDenmark)) { return 292; }
1179
            else if (namedArea.getUuid().equals(ErmsTransformer.uuidEgypt)) { return 237; }
1180
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidEstonia)) { return 238; }
1181
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidFaeroeExclusiveEconomicZone)) { return 239; }
1182
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidFrance)) { return 240; }
1183
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidGhana)) { return 241; }
1184
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidGreece)) { return 242; }
1185
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidGreekExclusiveEconomicZone)) { return AREA_GREEK_EXCLUSIVE_ECONOMIC_ZONE; }
1186
            else if (namedArea.getUuid().equals(ErmsTransformer.uuidGulfOfBothnia)) { return 243; }
1187
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidGulfOfFinland)) { return 244; }
1188
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidGulfOfGuinea)) { return 245; }
1189
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidGulfOfMexico)) { return 246; }
1190
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidGulfOfRiga)) { return 247; }
1191
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidIceland)) { return 248; }
1192
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidIonianSea)) { return 249; }
1193
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidIreland)) { return 250; }
1194
            else if (namedArea.getUuid().equals(ErmsTransformer.uuidItaly)) { return 251; }
1195
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidJamaica)) { return 252; }
1196
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidKattegat)) { return 253; }
1197
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidLevantineSea)) { return 254; }
1198
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidLigurianSea)) { return 255; }
1199
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidMalteseExclusiveEconomicZone)) { return 256; }
1200
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidMauritanianExclusiveEconomicZone)) { return 257; }
1201
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidMediterraneanSea_EasternBasin)) { return 258; }
1202
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidMediterraneanSea_WesternBasin)) { return 259; }
1203
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidMexico)) { return 260; }
1204
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidMorocco)) { return 261; }
1205
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidNetherlands)) { return 262; }
1206
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidNewZealand)) { return 263; }
1207
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidNewZealandExclusiveEconomicZone)) { return 264; }
1208
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidNorthAtlanticOcean)) { return 265; }
1209
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidNorway)) { return 266; }
1210
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidPanama)) { return 267; }
1211
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidPanamanianExclusiveEconomicZone)) { return 268; }
1212
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidPolishExclusiveEconomicZone)) { return 216; }
1213
            else if (namedArea.getUuid().equals(ErmsTransformer.uuidPortugal)) { return 269; }
1214
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidPortugueseExclusiveEconomicZone_Azores)) { return 270; }
1215
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidPortugueseExclusiveEconomicZone_Madeira)) { return 271; }
1216
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidRedSea)) { return 272; }
1217
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidRussianExclusiveEconomicZone)) { return 217; }
1218
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidSeaOfMarmara)) { return 273; }
1219
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidSenegaleseExclusiveEconomicZone)) { return 274; }
1220
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidSingapore)) { return 275; }
1221
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidSlovenianExclusiveEconomicZone)) { return 276; }
1222
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidSouthAfrica)) { return 277; }
1223
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidSouthAfricanExclusiveEconomicZone)) { return 278; }
1224
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidSouthChinaSea)) { return 279; }
1225
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidSpain)) { return 280; }
1226
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidSpanishExclusiveEconomicZone_CanaryIslands)) { return 281; }
1227
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidSriLankanExclusiveEconomicZone)) { return 282; }
1228
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidStraitOfGibraltar)) { return 283; }
1229
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidSweden)) { return 284; }
1230
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidTunisia)) { return 285; }
1231
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidTurkey)) { return 286; }
1232
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidTyrrhenianSea)) { return 287; }
1233
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidUnitedKingdom)) { return 288; }
1234
	        else if (namedArea.getUuid().equals(ErmsTransformer.uuidUnitedStates)) { return 291; }
1235
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidUnitedStatesExclusiveEconomicZone_Alaska)) { return 289; }
1236
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidVenezuela)) { return 290; }
1237

    
1238
			else {
1239
				logger.warn("Unknown NamedArea Area: " + area.getTitleCache());
1240
			}
1241

    
1242
		}
1243
		return null;
1244
	}
1245

    
1246

    
1247
	/**
1248
	 * Returns the PESI SourceUseId for a given CDM sourceUseId.
1249
	 * @param sourceUseId
1250
	 * @return
1251
	 */
1252
	public static Integer sourceUseIdSourceUseId(Integer sourceUseId) {
1253
		// TODO: CDM sourceUseId and PESI sourceUseId are equal for now.
1254
		Integer result = null;
1255
		switch (sourceUseId) {
1256
			case 3: return ADDITIONAL_SOURCE;
1257
			case 4: return SOURCE_OF_SYNONYMY;
1258
			case 8: return NOMENCLATURAL_REFERENCE;
1259
		}
1260
		return result;
1261
	}
1262

    
1263
	@Override
1264
	public Object getKeyByLanguage(Language language) throws UndefinedTransformerMethodException {
1265
		return language2LanguageId(language);
1266
	}
1267

    
1268
	@Override
1269
	public String getCacheByLanguage(Language language) throws UndefinedTransformerMethodException {
1270
		if (language == null){
1271
			return null;
1272
		}else{
1273
			return this.languageCacheMap.get(getKeyByLanguage(language));
1274
		}
1275
	}
1276

    
1277
	/**
1278
	 * Returns the identifier of the given Language.
1279
	 */
1280
	public static Integer language2LanguageId(Language language) {
1281
		if (language == null ) {
1282
			return null;
1283
		}
1284
		Integer result;
1285
		if ((result = languageCodeToKeyMap.get(language.getIso639_1())) != null){
1286
		    return result;
1287
		}else if ((result = languageCodeToKeyMap.get(language.getIdInVocabulary())) != null){
1288
            return result;
1289

    
1290
		} else {
1291
			logger.warn("Unknown Language: " + language.getTitleCache());
1292
			return null;
1293
		}
1294
	}
1295

    
1296
	/**
1297
	 * Returns the NodeCategoryCache for a given TextData.
1298
	 */
1299
	@Override
1300
    public String getCacheByFeature(Feature feature) {
1301
		if (feature == null){
1302
			return null;
1303
		}else{
1304
			return this.featureCacheMap.get(feature2NoteCategoryFk(feature));
1305
		}
1306
	}
1307

    
1308
	/**
1309
	 * Returns the NodeCategoryFk for a given TextData.
1310
	 */
1311
	public static Integer feature2NoteCategoryFk(Feature feature) {
1312
		if (feature == null) {
1313
			return null;
1314
		}
1315

    
1316
		if (feature.equals(Feature.DESCRIPTION())) {
1317
			return NoteCategory_description;
1318
		} else if (feature.equals(Feature.ECOLOGY())) {
1319
			return NoteCategory_ecology;
1320
		} else if (feature.equals(Feature.PHENOLOGY())) {
1321
			return NoteCategory_phenology;
1322
		} else if (feature.equals(Feature.DIAGNOSIS())) {
1323
            return NoteCategory_Diagnosis;
1324
        } else if (feature.equals(Feature.COMMON_NAME())) {
1325
			return NoteCategory_Common_names;
1326
		} else if (feature.equals(Feature.OCCURRENCE())) {
1327
			return NoteCategory_Occurrence;
1328
		} else if (feature.equals(Feature.DISTRIBUTION())) {
1329
			return NoteCategory_Distribution;
1330
		} else if (feature.equals(Feature.ETYMOLOGY())) {
1331
            return NoteCategory_Etymology;
1332
        } else if (feature.getUuid().equals(ErmsTransformer.uuidAcknowledgments)){
1333
		    return NoteCategory_Acknowledgments;
1334
		} else if (feature.getUuid().equals(ErmsTransformer.uuidAdditionalinformation)) {
1335
		    return NoteCategory_Additional_information;
1336
		} else if (feature.getUuid().equals(ErmsTransformer.uuidAlienSpecies)) {
1337
		    return NoteCategory_Alien_Species;
1338
		} else if (feature.getUuid().equals(ErmsTransformer.uuidAuthority)) {
1339
		    return NoteCategory_Authority;
1340
		} else if (feature.getUuid().equals(ErmsTransformer.uuidDepthRange)) {
1341
		    return NoteCategory_Depth_Range;
1342
		} else if (feature.getUuid().equals(ErmsTransformer.uuidBiology)) {
1343
		    return NoteCategory_Biology;
1344
		} else if (feature.getUuid().equals(ErmsTransformer.uuidClassification)) {
1345
		    return NoteCategory_Classification;
1346
		} else if (feature.getUuid().equals(ErmsTransformer.uuidDiet)) {
1347
		    return NoteCategory_Diet;
1348
		} else if (feature.getUuid().equals(ErmsTransformer.uuidDimensions)) {
1349
		    return NoteCategory_Dimensions;
1350
		} else if (feature.getUuid().equals(ErmsTransformer.uuidEditorsComment)) {
1351
		    return NoteCategory_Editors_Comment;
1352
		} else if (feature.getUuid().equals(ErmsTransformer.uuidEnvironment)) {
1353
		    return NoteCategory_Environment;
1354
		} else if (feature.getUuid().equals(ErmsTransformer.uuidFossilRange)) {
1355
		    return NoteCategory_Fossil_Range;
1356
		} else if (feature.getUuid().equals(ErmsTransformer.uuidGrammaticalGender)) {
1357
		    return NoteCategory_Grammatical_Gender;
1358
		} else if (feature.getUuid().equals(ErmsTransformer.uuidHabitat)) {
1359
		    return NoteCategory_Habitat;
1360
		} else if (feature.getUuid().equals(ErmsTransformer.uuidHomonymy)) {
1361
		    return NoteCategory_Homonymy;
1362
		} else if (feature.getUuid().equals(ErmsTransformer.uuidIdentification)) {
1363
		    return NoteCategory_Identification;
1364
		} else if (feature.getUuid().equals(ErmsTransformer.uuidIntroducedSpeciesRemark)) {
1365
		    return NoteCategory_Introduced_Species_Remark;
1366
		} else if (feature.getUuid().equals(ErmsTransformer.uuidMorphology)) {
1367
		    return NoteCategory_Morphology;
1368
		} else if (feature.getUuid().equals(ErmsTransformer.uuidNewCombination)) {
1369
		    return NoteCategory_New_Combination;
1370
		} else if (feature.getUuid().equals(ErmsTransformer.uuidNomenclature)) {
1371
		    return NoteCategory_Nomenclature;
1372
		} else if (feature.getUuid().equals(ErmsTransformer.uuidNote)){
1373
		    return NoteCategory_Note;
1374
		} else if (feature.getUuid().equals(ErmsTransformer.uuidOriginalCombination)) {
1375
		    return NoteCategory_Original_Combination;
1376
		} else if (feature.getUuid().equals(ErmsTransformer.uuidOriginalDescription)) {
1377
		    return NoteCategory_Original_Description;
1378
		} else if (feature.getUuid().equals(ErmsTransformer.uuidOriginalpublication)) {
1379
		    return NoteCategory_Original_publication;
1380
		} else if (feature.getUuid().equals(ErmsTransformer.uuidPublicationdate)) {
1381
            return NoteCategory_Publication_date;
1382
        } else if (feature.getUuid().equals(ErmsTransformer.uuidRank)) {
1383
		    return NoteCategory_Rank;
1384
		} else if (feature.getUuid().equals(ErmsTransformer.uuidRemark)) {
1385
		    return NoteCategory_Remark;
1386
		} else if (feature.getUuid().equals(ErmsTransformer.uuidReproduction)) {
1387
		    return NoteCategory_Reproduction;
1388
		} else if (feature.getUuid().equals(ErmsTransformer.uuidSpelling)) {
1389
		    return NoteCategory_Spelling;
1390
		} else if (feature.getUuid().equals(ErmsTransformer.uuidSpecimen)) {
1391
            return NoteCategory_Specimen;
1392
        } else if (feature.getUuid().equals(ErmsTransformer.uuidStatus)){
1393
		    return NoteCategory_Status;
1394
		} else if (feature.getUuid().equals(ErmsTransformer.uuidSynonymy)) {
1395
		    return NoteCategory_Synonymy;
1396
		} else if (feature.getUuid().equals(ErmsTransformer.uuidSyntype)) {
1397
		    return NoteCategory_Syntype;
1398
		} else if (feature.getUuid().equals(ErmsTransformer.uuidSystematics)) {
1399
		    return NoteCategory_Systematics;
1400
		} else if (feature.getUuid().equals(ErmsTransformer.uuidTaxonomicRemarks)) {
1401
			return NoteCategory_Taxonomic_Remarks;
1402
		} else if (feature.getUuid().equals(ErmsTransformer.uuidTaxonomy)) {
1403
			return NoteCategory_Taxonomy;
1404
		} else if (feature.getUuid().equals(ErmsTransformer.uuidTaxonomicstatus)) {
1405
			return NoteCategory_Taxonomic_status;
1406
		} else if (feature.getUuid().equals(ErmsTransformer.uuidTypelocality)) {
1407
		    return NoteCategory_Type_locality;
1408
		} else if (feature.getUuid().equals(ErmsTransformer.uuidTypeMaterial)) {
1409
		    return NoteCategory_Type_Material;
1410
		} else if (feature.getUuid().equals(ErmsTransformer.uuidTypeSpecimen)) {
1411
		    return NoteCategory_Type_Specimen;
1412
        } else if (feature.getUuid().equals(ErmsTransformer.uuidTypespecies)) {
1413
            return NoteCategory_Type_species;
1414
		} else if (feature.getUuid().equals(ErmsTransformer.uuidTaxonomicRemark)) {
1415
			return NoteCategory_Taxonomic_Remark;
1416
		} else if (feature.getUuid().equals(ErmsTransformer.uuidValidity)) {
1417
			return NoteCategory_Validity;
1418

    
1419
//        } else if (feature.getUuid().equals(ErmsTransformer.uuidSourceOfSynonymy)) {
1420
//		    logger.debug("Source of synonymy not yet handled");
1421
//		    return null;
1422
		} else if (feature.equals(Feature.CITATION())) {
1423
			return null;  //citations are handled differently
1424
		} else if (feature.getUuid().equals(BerlinModelTransformer.uuidFeatureMaps)){
1425
			return NoteCategory_Link_to_maps;
1426
		} else if (feature.getUuid().equals(BerlinModelTransformer.uuidFeatureUse)){
1427
			return NoteCategory_Use;
1428
		} else if (feature.getUuid().equals(BerlinModelTransformer.uuidFeatureComments)){
1429
			return NoteCategory_Comments;
1430
		} else if (feature.getUuid().equals(BerlinModelTransformer.uuidFeatureConservationStatus)){
1431
			return NoteCategory_Conservation_Status;
1432

    
1433
		//E+M
1434
		} else if (feature.getUuid().equals(BerlinModelTransformer.uuidFeatureDistrEM)){
1435
			return NoteCategory_general_distribution_euromed;
1436
		} else if (feature.getUuid().equals(BerlinModelTransformer.uuidFeatureDistrWorld)){
1437
			return NoteCategory_general_distribution_world;
1438
		} else if (feature.getUuid().equals(BerlinModelTransformer.uuidFeatureEditorBrackets)){
1439
			return NoteCategory_Editor_Brackets;
1440
		} else if (feature.getUuid().equals(BerlinModelTransformer.uuidFeatureEditorParenthesis)){
1441
			return NoteCategory_Editor_Parenthesis;
1442
		} else if (feature.getUuid().equals(BerlinModelTransformer.uuidFeatureInedited)){
1443
			return NoteCategory_Inedited;
1444
		} else if (feature.getUuid().equals(BerlinModelTransformer.uuidFeatureCommentsEditing)){
1445
			return NoteCategory_Comments_on_editing_process;
1446

    
1447
		}else{
1448
			logger.warn("Unhandled Feature: " + feature.getTitleCache());
1449
			return null;
1450
		}
1451
	}
1452

    
1453
	/**
1454
	 * Returns the string representation for a given rank.
1455
	 */
1456
	public String getCacheByRankAndKingdom(Rank rank, Integer pesiKingdomId) {
1457
		if (rank == null){
1458
			return null;
1459
		}else if (pesiKingdomId == null && rank.equals(Rank.DOMAIN())){  //might be Superdomain in future
1460
		    return this.rankCacheMap.get(0).get(0);
1461
		}else{
1462
		    Map<Integer, String> rankMap = this.rankCacheMap.get(pesiKingdomId);
1463
		    if (rankMap != null){
1464
		        return rankMap.get(rank2RankId(rank, pesiKingdomId));
1465
		    }else{
1466
		        logger.warn("RankCacheMap is null for " + pesiKingdomId);
1467
		        return null;
1468
		    }
1469
		}
1470
	}
1471

    
1472
	/**
1473
	 * Returns the identifier of a PESI specific kingdom for a given CDM nomenclatural code.
1474
	 * @param nomenclaturalCode
1475
	 * @return KINGDOM_ANIMALIA for NomenclaturalCode.ICZN, KINGDOM_PLANTAE for NomenclaturalCode.ICNAFP
1476
	 */
1477
	public static Integer nomenclaturalCode2Kingdom(NomenclaturalCode nomenclaturalCode) {
1478
		Integer result = null;
1479
		// TODO: This needs to be refined. For now we differentiate between animalia, plantae and bacteria only.
1480
		if (nomenclaturalCode.equals(NomenclaturalCode.ICZN)) {
1481
			result = KINGDOM_ANIMALIA;
1482
		} else if (nomenclaturalCode.equals(NomenclaturalCode.ICNAFP)) {
1483
			result = KINGDOM_PLANTAE;
1484
		} else if (nomenclaturalCode.equals(NomenclaturalCode.ICNB)) {
1485
			result = KINGDOM_BACTERIA;
1486
//		} else if (nomenclaturalCode.equals(NomenclaturalCode.)) { // Biota
1487
//			result =
1488
		} else {
1489
 			logger.error("NomenclaturalCode not yet considered: " + nomenclaturalCode.getUuid() + " (" +  nomenclaturalCode.getTitleCache() + ")");
1490
		}
1491
		return result;
1492
	}
1493

    
1494
	/**
1495
	 * Returns the RankId for a Rank.
1496
	 * @param rank
1497
	 * @return
1498
	 */
1499
	public static Integer rank2RankId (Rank rank, Integer pesiKingdomId) {
1500
		Integer result = null;
1501
		if (rank == null) {
1502
			return null;
1503
		}else if (rank.equals(Rank.DOMAIN())){
1504
		    return KINGDOM_NULL;
1505
		}else if (rank.equals(Rank.KINGDOM())) {
1506
            result = Kingdom;
1507
        }else if (rank.equals(Rank.SUBKINGDOM())) {
1508
            result = Subkingdom;
1509
        } else if (rank.equals(Rank.PHYLUM())) {
1510
            result = Phylum;
1511
        }else if (rank.equals(Rank.DIVISION())) {  //same as Phylum
1512
            result = Division;
1513
        }else if (rank.equals(Rank.SUBPHYLUM())) {
1514
            result = Subphylum;
1515
        }else if (rank.equals(Rank.SUBDIVISION())) { //same as Subphylum
1516
            result = Subdivision;
1517
        }else if (rank.equals(Rank.CLASS())) {
1518
            result = Class;
1519
        } else if (rank.equals(Rank.SUBCLASS())) {
1520
            result = Subclass;
1521
        } else if (rank.equals(Rank.ORDER())) {
1522
            result = Order;
1523
        } else if (rank.equals(Rank.SUBORDER())) {
1524
            result = Suborder;
1525
        } else if (rank.equals(Rank.FAMILY())) {
1526
            result = Family;
1527
        } else if (rank.equals(Rank.SUBFAMILY())) {
1528
            result = Subfamily;
1529
        } else if (rank.equals(Rank.TRIBE())) {
1530
            result = Tribe;
1531
        } else if (rank.equals(Rank.SUBTRIBE())) {
1532
            result = Subtribe;
1533
        } else if (rank.equals(Rank.GENUS())) {
1534
            result = Genus;
1535
        } else if (rank.equals(Rank.SUBGENUS())) {
1536
            result = Subgenus;
1537
        } else if (rank.equals(Rank.SPECIES())) {
1538
            result = Species;
1539
        } else if (rank.equals(Rank.SUBSPECIES())) {
1540
            result = Subspecies;
1541
        } else if (rank.equals(Rank.VARIETY())) {
1542
            result = Variety;
1543
        } else if (rank.equals(Rank.FORM())) {
1544
            result = Forma;
1545
        } else
1546

    
1547
		// We differentiate between Animalia and Plantae only for now.
1548
		if (pesiKingdomId != null && pesiKingdomId.intValue() == KINGDOM_ANIMALIA) {
1549
			if (rank.equals(Rank.INFRAKINGDOM())) {result = Infrakingdom;
1550
            } else if (rank.equals(Rank.SUPERPHYLUM())) {result = Superphylum;
1551
			} else if (rank.equals(Rank.INFRAPHYLUM())) {result = Infraphylum;
1552
			} else if (rank.equals(Rank.SUPERCLASS())) {result = Superclass;
1553
			} else if (rank.equals(Rank.INFRACLASS())) {result = Infraclass;
1554
            } else if (rank.getUuid().equals(ErmsTransformer.uuidRankSubterclass)) {result = Subterclass;
1555
			} else if (rank.equals(Rank.SUPERORDER())) {result = Superorder;
1556
			} else if (rank.equals(Rank.INFRAORDER())) {result = Infraorder;
1557
			} else if (rank.getUuid().equals(ErmsTransformer.uuidRankParvorder)) {result = Parvorder;
1558
            } else if (rank.equals(Rank.SECTION_ZOOLOGY())) {result = Animalia_Section;
1559
			} else if (rank.equals(Rank.SUBSECTION_ZOOLOGY())) {result = Animalia_Subsection;
1560
			} else if (rank.equals(Rank.SUPERFAMILY())) {result = Superfamily;
1561
			} else if (rank.equals(Rank.NATIO())) {result = Natio;
1562
			} else if (rank.equals(Rank.SUBVARIETY())) {result = Subvariety;
1563
			} else if (rank.equals(Rank.SUBFORM())) {result = Subform;
1564
            } else {
1565
				//TODO Exception
1566
				logger.warn("Rank for Kingdom Animalia not yet supported in CDM: "+ rank.getLabel());
1567
				return null;
1568
			}
1569
		} else if (pesiKingdomId != null && pesiKingdomId.intValue() == KINGDOM_PLANTAE) {
1570
			if (rank.equals(Rank.INFRAKINGDOM())) {result = Infrakingdom;
1571
            } else if (rank.equals(Rank.SUPERORDER())) {result = Superorder;
1572
			} else if (rank.equals(Rank.SECTION_BOTANY())) {result = Bot_Section;
1573
			} else if (rank.equals(Rank.SUBSECTION_BOTANY())) {result = Bot_Subsection;
1574
			} else if (rank.equals(Rank.SERIES())) {result = Series;
1575
			} else if (rank.equals(Rank.SUBSERIES())) {result = Subseries;
1576
			} else if (rank.equals(Rank.SPECIESAGGREGATE() )) {result = Aggregate;
1577
			} else if (rank.equals(Rank.SPECIESGROUP())) {
1578
				logger.warn("Rank Species Group not yet implemented");
1579
				result = null;
1580
			} else if (rank.getUuid().equals(Rank.uuidCollSpecies)) {result = Coll_Species;
1581
			} else if (rank.equals(Rank.GREX())) {result = Grex;
1582
			} else if (rank.getUuid().equals(Rank.uuidProles) ) {result = Proles;
1583
			} else if (rank.getUuid().equals(Rank.uuidRace)) {result = Race;
1584
			} else if (rank.equals(Rank.CONVAR())) {result = Convarietas;
1585
			} else if (rank.equals(Rank.SUBVARIETY())) {result = Subvariety;
1586
			} else if (rank.equals(Rank.SUBFORM())) {result = Subform;
1587
			} else if (rank.equals(Rank.SPECIALFORM())) {result = Forma_spec;
1588
			} else if (rank.equals(Rank.INFRAGENERICTAXON())) {result = Taxa_infragen;
1589
			} else if (rank.equals(Rank.INFRASPECIFICTAXON())) {result = Taxa_infraspec;
1590
			} else {
1591
				//TODO Exception
1592
				logger.warn("Rank for Kingdom Plantae not yet supported in CDM: "+ rank.getLabel());
1593
				return null;
1594
			}
1595
		} else if (pesiKingdomId != null && pesiKingdomId.intValue() == KINGDOM_FUNGI) {
1596
		    if (rank.equals(Rank.SECTION_BOTANY())) { result = Bot_Section;}
1597
		    else if (rank.equals(Rank.SUBSECTION_BOTANY())) { result = Bot_Subsection;}
1598
		    else if (rank.equals(Rank.SUBVARIETY())) { result = Subvariety; }
1599
		    else if (rank.equals(Rank.SUBFORM())) { result = Subform;}
1600
		    else {
1601
		        //TODO Exception
1602
		        logger.warn("Rank for Kingdom Fungi not yet supported in CDM: "+ rank.getLabel());
1603
		        return null;
1604
		    }
1605
        }else if (pesiKingdomId != null && pesiKingdomId.intValue() == KINGDOM_PROTOZOA) {
1606
            if (rank.equals(Rank.INFRAKINGDOM())) { result = Infrakingdom; }
1607
            else if (rank.equals(Rank.SUPERCLASS())) { result = Superclass; }
1608
            else if (rank.equals(Rank.INFRACLASS())) { result = Infraclass; }
1609
            else if (rank.equals(Rank.SUPERORDER())) { result = Superorder; }
1610
            else if (rank.equals(Rank.INFRAORDER())) { result = Infraorder; }
1611
            else if (rank.equals(Rank.SUPERFAMILY())) { result = Superfamily; }
1612
            else {
1613
                //TODO Exception
1614
                logger.warn("Rank for Kingdom Protozoa not yet supported in CDM: "+ rank.getLabel());
1615
                return null;
1616
            }
1617
        } else if (pesiKingdomId != null && pesiKingdomId.intValue() == KINGDOM_BACTERIA) {
1618
            if (rank.equals(Rank.SUPERCLASS())) { result = Superclass; }
1619
            else if (rank.equals(Rank.INFRACLASS())) { result = Infraclass; }
1620
            else if (rank.equals(Rank.SUPERORDER())) { result = Superorder; }
1621
            else if (rank.equals(Rank.INFRAORDER())) { result = Infraorder; }
1622
            else if (rank.equals(Rank.SUPERFAMILY())) { result = Superfamily; }
1623
            else {
1624
                //TODO Exception
1625
                logger.warn("Rank for Kingdom Bacteria not yet supported in CDM: "+ rank.getLabel());
1626
                return null;
1627
            }
1628
        }else if (pesiKingdomId != null && pesiKingdomId.intValue() == KINGDOM_CHROMISTA) {
1629
            if (rank.equals(Rank.INFRAKINGDOM())) { result = Infrakingdom; }
1630
            else if (rank.equals(Rank.INFRAPHYLUM())) { result = Infraphylum; }
1631
            else if (rank.equals(Rank.SUPERCLASS())) { result = Superclass; }
1632
            else if (rank.equals(Rank.INFRACLASS())) { result = Infraclass; }
1633
            else if (rank.equals(Rank.SUPERORDER())) { result = Superorder; }
1634
            else if (rank.equals(Rank.INFRAORDER())) { result = Infraorder; }
1635
            else if (rank.equals(Rank.SUPERFAMILY())) { result = Superfamily; }
1636
            else if (rank.equals(Rank.SECTION_BOTANY())) { result = Bot_Section;}
1637
            else if (rank.equals(Rank.SUBSECTION_BOTANY())) { result = Bot_Subsection;}
1638
            else if (rank.equals(Rank.SUBVARIETY())) { result = Subvariety; }
1639
            else {
1640
                //TODO Exception
1641
                logger.warn("Rank for Kingdom Chromista not yet supported in CDM: "+ rank.getLabel());
1642
                return null;
1643
            }
1644
        }else{
1645
			//TODO Exception
1646
			logger.warn("Kingdom not yet supported in CDM: "+ pesiKingdomId);
1647
			return null;
1648
		}
1649
		return result;
1650
	}
1651

    
1652
	public static Integer nameTypeDesignationStatus2TypeDesignationStatusId(NameTypeDesignationStatus nameTypeDesignationStatus) {
1653
		if (nameTypeDesignationStatus == null) {
1654
			return null;
1655
		}
1656
		if (nameTypeDesignationStatus.equals(NameTypeDesignationStatus.ORIGINAL_DESIGNATION())) {
1657
			return TYPE_BY_ORIGINAL_DESIGNATION;
1658
		} else if (nameTypeDesignationStatus.equals(NameTypeDesignationStatus.SUBSEQUENT_DESIGNATION())) {
1659
			return TYPE_BY_SUBSEQUENT_DESIGNATION;
1660
		} else if (nameTypeDesignationStatus.equals(NameTypeDesignationStatus.MONOTYPY())) {
1661
			return TYPE_BY_MONOTYPY;
1662
		} else {
1663
			//TODO Figure out a way to handle this gracefully.
1664
			logger.warn("Name Type Designation Status not yet supported in PESI: "+ nameTypeDesignationStatus.getLabel());
1665
			return null;
1666
		}
1667

    
1668
	}
1669

    
1670
	/**
1671
	 *
1672
	 * @param nameTypeDesignationStatus
1673
	 * @return
1674
	 */
1675
	public static String nameTypeDesignationStatus2TypeDesignationStatusCache(NameTypeDesignationStatus nameTypeDesignationStatus) {
1676
		if (nameTypeDesignationStatus == null) {
1677
			return null;
1678
		}
1679
		if (nameTypeDesignationStatus.equals(NameTypeDesignationStatus.ORIGINAL_DESIGNATION())) {
1680
			return TYPE_STR_BY_ORIGINAL_DESIGNATION;
1681
		} else if (nameTypeDesignationStatus.equals(NameTypeDesignationStatus.SUBSEQUENT_DESIGNATION())) {
1682
			return TYPE_STR_BY_SUBSEQUENT_DESIGNATION;
1683
		} else if (nameTypeDesignationStatus.equals(NameTypeDesignationStatus.MONOTYPY())) {
1684
			return TYPE_STR_BY_MONOTYPY;
1685
		} else {
1686
			//TODO Figure out a way to handle this gracefully.
1687
			logger.warn("Name Type Designation Status not yet supported in PESI: "+ nameTypeDesignationStatus.getLabel());
1688
			return null;
1689
		}
1690
	}
1691

    
1692
	/**
1693
	 * @see PesiTaxonExport#doPhaseUpdates(PesiExportState) for further transformation
1694
	 * @param taxonBase
1695
	 * @return
1696
	 */
1697
	public static Integer taxonBase2statusFk (TaxonBase<?> taxonBase){
1698
		if (taxonBase == null){
1699
			return null;
1700
		}
1701
		if (taxonBase.isInstanceOf(Taxon.class)){
1702
			Taxon taxon = CdmBase.deproxy(taxonBase, Taxon.class);
1703
			if (taxon.getTaxonNodes().size() == 0){
1704
				return T_STATUS_NOT_ACCEPTED;
1705
			}else{
1706
				return T_STATUS_ACCEPTED;
1707
			}
1708
		}else if (taxonBase.isInstanceOf(Synonym.class)){
1709
			return T_STATUS_SYNONYM;
1710
		}else{
1711
			logger.warn("Unknown ");
1712
			return T_STATUS_UNRESOLVED;
1713
		}
1714
		//TODO
1715
//		public static int T_STATUS_PARTIAL_SYN = 3;
1716
//		public static int T_STATUS_PRO_PARTE_SYN = 4;
1717
//		public static int T_STATUS_UNRESOLVED = 5;
1718
//		public static int T_STATUS_ORPHANED = 6;
1719
	}
1720

    
1721
//	/**
1722
//	 *
1723
//	 * @param taxonBase
1724
//	 * @return
1725
//	 */
1726
//	public static String taxonBase2statusCache (TaxonBase<?> taxonBase){
1727
//		if (taxonBase == null){return null;}
1728
//		if (taxonBase.isInstanceOf(Taxon.class)){
1729
//			Taxon taxon = CdmBase.deproxy(taxonBase, Taxon.class);
1730
//			if (taxon.getTaxonNodes().size() == 0){
1731
//				return T_STATUS_STR_NOT_ACCEPTED;
1732
//			}else{
1733
//				return T_STATUS_STR_ACCEPTED;
1734
//			}
1735
//		}else if (taxonBase.isInstanceOf(Synonym.class)){
1736
//			return T_STATUS_STR_SYNONYM;
1737
//		}else{
1738
//			logger.warn("Unknown ");
1739
//			return T_STATUS_STR_UNRESOLVED;
1740
//		}
1741
//		//TODO
1742
//		public static int T_STATUS_STR_PARTIAL_SYN = 3;
1743
//		public static int T_STATUS_STR_PRO_PARTE_SYN = 4;
1744
//		public static int T_STATUS_STR_UNRESOLVED = 5;
1745
//		public static int T_STATUS_STR_ORPHANED = 6;
1746
//	}
1747

    
1748
	/**
1749
	 * Returns the {@link SourceCategory SourceCategory} representation of the given {@link ReferenceType ReferenceType} in PESI.
1750
	 * @param reference The {@link Reference Reference}.
1751
	 * @return The {@link SourceCategory SourceCategory} representation in PESI.
1752
	 */
1753
	public static Integer reference2SourceCategoryFK(Reference reference) {
1754
		if (reference == null){
1755
			return null;
1756
		} else if (reference.getType().equals(ReferenceType.Article)) {
1757
			return REF_ARTICLE_IN_PERIODICAL;
1758
		} else if (reference.getType().equals(ReferenceType.Book)) {
1759
			return REF_BOOK;
1760
		} else if (reference.getType().equals(ReferenceType.BookSection)) {
1761
			return REF_PART_OF_OTHER;
1762
		} else if (reference.getType().equals(ReferenceType.Section)) {
1763
			return REF_PART_OF_OTHER;
1764
		} else if (reference.getType().equals(ReferenceType.Database)) {
1765
			return REF_DATABASE;
1766
		} else if (reference.getType().equals(ReferenceType.WebPage)) {
1767
			return REF_WEBSITE;
1768
		} else if (reference.getType().equals(ReferenceType.CdDvd)) {
1769
			return REF_NOT_APPLICABLE;
1770
		} else if (reference.getType().equals(ReferenceType.Journal)) {
1771
			return REF_JOURNAL;
1772
		} else if (reference.getType().equals(ReferenceType.PrintSeries)) {
1773
			return REF_PUBLISHED;
1774
		} else if (reference.getType().equals(ReferenceType.Proceedings)) {
1775
			return REF_PUBLISHED;
1776
		} else if (reference.getType().equals(ReferenceType.Patent)) {
1777
			return REF_NOT_APPLICABLE;
1778
		} else if (reference.getType().equals(ReferenceType.PersonalCommunication)) {
1779
			return REF_INFORMAL;
1780
		} else if (reference.getType().equals(ReferenceType.Report)) {
1781
			return REF_NOT_APPLICABLE;
1782
		} else if (reference.getType().equals(ReferenceType.Thesis)) {
1783
			return REF_NOT_APPLICABLE;
1784
		} else if (reference.getType().equals(ReferenceType.Generic)) {
1785
            if(reference.hasMarker(ErmsTransformer.uuidMarkerRefPublication, true)){
1786
                return REF_PUBLICATION;
1787
            }else if(reference.hasMarker(ErmsTransformer.uuidMarkerRefInformal, true)){
1788
                return REF_INFORMAL;
1789
            }else if(reference.hasMarker(ErmsTransformer.uuidMarkerRefTypeI, true)){
1790
                logger.warn("ERMS ref type 'i' is not yet correctly matched to PESI");
1791
                return REF_INFORMAL;
1792
            }else{
1793
                return REF_UNRESOLVED;
1794
            }
1795
        } else {
1796
			logger.warn("Reference type not yet supported in PESI: "+ reference.getType());
1797
			return null;
1798
		}
1799
	}
1800

    
1801
	/**
1802
	 * Returns the {@link SourceCategoryCache SourceCategoryCache}.
1803
	 * @param reference The {@link Reference Reference}.
1804
	 * @return The {@link SourceCategoryCache SourceCategoryCache}.
1805
	 */
1806
	public String getCacheByReference(Reference reference) {
1807
		if (reference == null){
1808
			return null;
1809
		}else{
1810
			return this.sourceCategoryCacheMap.get(reference2SourceCategoryFK(reference));
1811
		}
1812
	}
1813

    
1814
	@Override
1815
    public String getCacheByNomStatus(NomenclaturalStatusType status) {
1816
		if (status == null){
1817
			return null;
1818
		}else{
1819
			return this.nameStatusCacheMap.get(nomStatus2nomStatusFk(status));
1820
		}
1821
	}
1822

    
1823
	public static Integer nomStatus2nomStatusFk (NomenclaturalStatusType status){
1824
		if (status == null){
1825
			return null;
1826
		}
1827
		if (status.equals(NomenclaturalStatusType.INVALID())) {return NAME_ST_NOM_INVAL;
1828
		}else if (status.equals(NomenclaturalStatusType.ILLEGITIMATE())) {return NAME_ST_NOM_ILLEG;
1829
		}else if (status.equals(NomenclaturalStatusType.NUDUM())) {return NAME_ST_NOM_NUD;
1830
		}else if (status.equals(NomenclaturalStatusType.REJECTED())) {return NAME_ST_NOM_REJ;
1831
		}else if (status.equals(NomenclaturalStatusType.REJECTED_PROP())) {return NAME_ST_NOM_REJ_PROP;
1832
		}else if (status.equals(NomenclaturalStatusType.UTIQUE_REJECTED())) {return NAME_ST_NOM_UTIQUE_REJ;
1833
		}else if (status.equals(NomenclaturalStatusType.UTIQUE_REJECTED_PROP())) {return NAME_ST_NOM_UTIQUE_REJ_PROP;
1834
		}else if (status.equals(NomenclaturalStatusType.CONSERVED())) {return NAME_ST_NOM_CONS;
1835

    
1836
		}else if (status.equals(NomenclaturalStatusType.CONSERVED_PROP())) {return NAME_ST_NOM_CONS_PROP;
1837
		}else if (status.equals(NomenclaturalStatusType.ORTHOGRAPHY_CONSERVED())) {return NAME_ST_ORTH_CONS;
1838
		}else if (status.equals(NomenclaturalStatusType.ORTHOGRAPHY_CONSERVED_PROP())) {return NAME_ST_ORTH_CONS_PROP;
1839
		}else if (status.equals(NomenclaturalStatusType.SUPERFLUOUS())) {return NAME_ST_NOM_SUPERFL;
1840
		}else if (status.equals(NomenclaturalStatusType.AMBIGUOUS())) {return NAME_ST_NOM_AMBIG;
1841
		}else if (status.equals(NomenclaturalStatusType.PROVISIONAL())) {return NAME_ST_NOM_PROVIS;
1842
		}else if (status.equals(NomenclaturalStatusType.DOUBTFUL())) {return NAME_ST_NOM_DUB;
1843
		}else if (status.equals(NomenclaturalStatusType.NOVUM())) {return NAME_ST_NOM_NOV;
1844

    
1845
		}else if (status.equals(NomenclaturalStatusType.CONFUSUM())) {return NAME_ST_NOM_CONFUS;
1846
		}else if (status.equals(NomenclaturalStatusType.ALTERNATIVE())) {return NAME_ST_NOM_ALTERN;
1847
		}else if (status.equals(NomenclaturalStatusType.COMBINATION_INVALID())) {return NAME_ST_COMB_INVAL;
1848
		}else if (status.equals(NomenclaturalStatusType.LEGITIMATE())) {return NAME_ST_LEGITIMATE;
1849

    
1850
		}else if (status.getUuid().equals(BerlinModelTransformer.uuidNomStatusCombIned)||
1851
		        //FIXME deduplicate COMB_NOV
1852
		        status.equals(NomenclaturalStatusType.COMB_NOV())) {return NAME_ST_COMB_INED;
1853
		}else if (status.getUuid().equals(BerlinModelTransformer.uuidNomStatusNomOrthCons)) {return NAME_ST_NOM_AND_ORTH_CONS;
1854
		}else if (status.getUuid().equals(BerlinModelTransformer.uuidNomStatusSpNovIned)) {return NAME_ST_SP_NOV_INED;
1855

    
1856

    
1857
		// The following are non-existent in CDM
1858
//		}else if (status.equals(NomenclaturalStatusType.)) {return NAME_ST_COMB_AND_STAT_INED;
1859
//		}else if (status.equals(NomenclaturalStatusType.)) {return NAME_ST_NOM_NOV_INED;
1860
		}else if (status.getUuid().equals(ErmsTransformer.uuidNomStatusAlternateRepresentation)) {return NAME_ST_ALTERNATE_REPRESENTATION;
1861
		}else if (status.getUuid().equals(uuidNomStatusTemporaryName)) {return NAME_ST_TEMPORARY_NAME;
1862
		}else if (status.getUuid().equals(ErmsTransformer.uuidNomStatusSpeciesInquirenda)) {return NAME_ST_SPECIES_INQUIRENDA;
1863

    
1864
		//TODO
1865
		}else {
1866
			//TODO Exception
1867
			logger.warn("NomStatus type not yet supported by PESI export: "+ status);
1868
			return null;
1869
		}
1870
	}
1871

    
1872
	/**
1873
	 * Returns the RelTaxonQualifierCache for a given taxonRelation.
1874
	 * @param relation
1875
	 * @return
1876
	 */
1877
	public String getCacheByRelationshipType(RelationshipBase relation, NomenclaturalCode code){
1878
		if (relation == null){
1879
			return null;
1880
		}else{
1881
			String result;
1882
			Integer key = taxonRelation2RelTaxonQualifierFk(relation);
1883
			if (code.equals(NomenclaturalCode.ICZN)){
1884
				result = this.taxRelZooQualifierCacheMap.get(key);
1885
				if (result == null){
1886
					result = this.taxRelQualifierCacheMap.get(key);
1887
				}
1888
			}else{
1889
				result = this.taxRelQualifierCacheMap.get(key);
1890
			}
1891
			return result;
1892
		}
1893
	}
1894

    
1895
    public String getCacheBySynonymType(Synonym synonym, NomenclaturalCode code){
1896
        if (synonym == null){
1897
            return null;
1898
        }else{
1899
            String result;
1900
            Integer key = synonym2RelTaxonQualifierFk(synonym);
1901
            if (code.equals(NomenclaturalCode.ICZN)){
1902
                result = this.taxRelZooQualifierCacheMap.get(key);
1903
                if (result == null){
1904
                    result = this.taxRelQualifierCacheMap.get(key);
1905
                }
1906
            }else{
1907
                result = this.taxRelQualifierCacheMap.get(key);
1908
            }
1909
            return result;
1910
        }
1911
    }
1912

    
1913
    public static Integer synonym2RelTaxonQualifierFk(Synonym synonym) {
1914
        if (synonym == null || synonym.getType() == null){
1915
            return null;
1916
        }
1917
        SynonymType type = synonym.getType();
1918
        if (type.equals(SynonymType.SYNONYM_OF())) {return IS_SYNONYM_OF;
1919
        }else if (type.equals(SynonymType.HOMOTYPIC_SYNONYM_OF())) {return IS_HOMOTYPIC_SYNONYM_OF;
1920
        }else if (type.equals(SynonymType.HETEROTYPIC_SYNONYM_OF())) {return IS_HETEROTYPIC_SYNONYM_OF;
1921
        }else if (type.equals(SynonymType.INFERRED_EPITHET_OF())) {return IS_INFERRED_EPITHET_FOR;
1922
        }else if (type.equals(SynonymType.INFERRED_GENUS_OF())) {return IS_INFERRED_GENUS_FOR;
1923
        }else if (type.equals(SynonymType.POTENTIAL_COMBINATION_OF())) {return IS_POTENTIAL_COMBINATION_FOR;
1924
        }else if (type.equals(SynonymType.INFERRED_SYNONYM_OF())) {
1925
            logger.warn("Inferred synonynm type not yet implemented. Should it realy exist?");
1926
            return null;
1927
        }else{
1928
            logger.warn("Unhandled synonym type: " + type.getTitleCache());
1929
            return null;
1930
        }
1931
//              return IS_PRO_PARTE_SYNONYM_OF;
1932
//              return IS_PARTIAL_SYNONYM_OF;
1933
//              return IS_PRO_PARTE_AND_HOMOTYPIC_SYNONYM_OF;
1934
//              return IS_PARTIAL_AND_HOMOTYPIC_SYNONYM_OF;
1935
//              return IS_PRO_PARTE_AND_HETEROTYPIC_SYNONYM_OF;
1936
//              return IS_PARTIAL_AND_HETEROTYPIC_SYNONYM_OF;
1937
    }
1938

    
1939

    
1940
	/**
1941
	 * Returns the RelTaxonQualifierFk for a TaxonRelation.
1942
	 * @param relation
1943
	 * @return
1944
	 */
1945
	public static Integer taxonRelation2RelTaxonQualifierFk(RelationshipBase<?,?,?> relation) {
1946
		if (relation == null || relation.getType() == null) {
1947
			return null;
1948
		}
1949
		RelationshipTermBase<?> type = relation.getType();
1950
		if (type.equals(TaxonRelationshipType.MISAPPLIED_NAME_FOR())) {
1951
			return IS_MISAPPLIED_NAME_FOR;
1952
	    //TODO
1953
//		} else if (type.equals(TaxonRelationshipType.PRO_PARTE_MISAPPLIED_NAME_FOR())) {
1954
//            return IS_PRO_PARTE_MISAPPLIED_NAME_FOR;
1955
        } else if (type.equals(TaxonRelationshipType.PRO_PARTE_SYNONYM_FOR())) {
1956
		    return IS_PRO_PARTE_SYNONYM_OF;
1957
		} else if (type.equals(TaxonRelationshipType.PARTIAL_SYNONYM_FOR())) {
1958
            return IS_PARTIAL_SYNONYM_OF;
1959
        } else if (type.equals(NameRelationshipType.BASIONYM())) {
1960
			return IS_BASIONYM_FOR;
1961
		} else if (type.equals(NameRelationshipType.LATER_HOMONYM())) {
1962
			return IS_LATER_HOMONYM_OF;
1963
		} else if (type.equals(NameRelationshipType.REPLACED_SYNONYM())) {
1964
			return IS_REPLACED_SYNONYM_FOR;
1965
		} else if (type.equals(NameRelationshipType.VALIDATED_BY_NAME())) {
1966
			return IS_VALIDATION_OF;
1967
		} else if (type.equals(NameRelationshipType.LATER_VALIDATED_BY_NAME())) {
1968
			return IS_LATER_VALIDATION_OF;
1969
		} else if (type.equals(NameRelationshipType.CONSERVED_AGAINST())) {
1970
			return IS_CONSERVED_AGAINST;
1971
		} else if (type.equals(NameRelationshipType.TREATED_AS_LATER_HOMONYM())) {
1972
			return IS_TREATED_AS_LATER_HOMONYM_OF;
1973
		} else if (type.equals(NameRelationshipType.ORTHOGRAPHIC_VARIANT())) {
1974
			return IS_ORTHOGRAPHIC_VARIANT_OF;
1975
		} else if (type.equals(NameRelationshipType.ALTERNATIVE_NAME())) {
1976
			return IS_ALTERNATIVE_NAME_FOR;
1977
		} else if (type.equals(HybridRelationshipType.FEMALE_PARENT())) {
1978
			return IS_FEMALE_PARENT_OF;
1979
		} else if (type.equals(HybridRelationshipType.MALE_PARENT())) {
1980
			return IS_MALE_PARENT_OF;
1981
		} else if (type.equals(HybridRelationshipType.FIRST_PARENT())) {
1982
			return IS_FIRST_PARENT_OF;
1983
		} else if (type.equals(HybridRelationshipType.SECOND_PARENT())) {
1984
			return IS_SECOND_PARENT_OF;
1985
		} else if (type.getUuid().equals(TaxonRelationshipType.uuidSynonymOfTaxonRelationship)) {
1986
			return IS_SYNONYM_OF;
1987
	    } else if (type.getUuid().equals(TaxonRelationshipType.uuidHeterotypicSynonymTaxonRelationship)) {
1988
	        return IS_HETEROTYPIC_SYNONYM_OF;
1989
	    } else if (type.getUuid().equals(TaxonRelationshipType.uuidHomotypicSynonymTaxonRelationship)) {
1990
	        return IS_HOMOTYPIC_SYNONYM_OF;
1991
		} else {
1992
			logger.warn("No equivalent RelationshipType found in datawarehouse for: " + type.getTitleCache());
1993
		}
1994

    
1995
		// The following have no equivalent attribute in CDM
1996
//		IS_TYPE_OF
1997
//		IS_CONSERVED_TYPE_OF
1998
//		IS_REJECTED_TYPE_OF
1999
//		IS_REJECTED_IN_FAVOUR_OF
2000
//		HAS_SAME_TYPE_AS
2001
//		IS_LECTOTYPE_OF
2002
//		TYPE_NOT_DESIGNATED
2003

    
2004

    
2005
		return null;
2006
	}
2007
	/**
2008
     * FIXME still needed?
2009
     * Returns the RelTaxonQualifierFk for a TaxonRelation.
2010
     * @param relation
2011
     * @return
2012
     */
2013
	public static Integer synonymrelation2RelTaxonQualifierFk(Synonym syn) {
2014
        if (syn.getAcceptedTaxon() == null) {
2015
            return null;
2016
        }
2017
        if (syn.getType().equals(SynonymType.HETEROTYPIC_SYNONYM_OF())){
2018
            return IS_HETEROTYPIC_SYNONYM_OF;
2019
        } else if (syn.getType().equals(SynonymType.HOMOTYPIC_SYNONYM_OF())){
2020
            return IS_HOMOTYPIC_SYNONYM_OF;
2021
        }else if (syn.getType().equals(SynonymType.INFERRED_EPITHET_OF())) {
2022
            return IS_INFERRED_EPITHET_FOR;
2023
        } else if (syn.getType().equals(SynonymType.INFERRED_GENUS_OF())) {
2024
            return IS_INFERRED_GENUS_FOR;
2025
        } else if (syn.getType().equals(SynonymType.POTENTIAL_COMBINATION_OF())) {
2026
            return IS_POTENTIAL_COMBINATION_FOR;
2027
        }
2028
        return IS_SYNONYM_OF;
2029

    
2030
	}
2031

    
2032
	/**
2033
	 * Returns the StatusFk for a given StatusCache.
2034
	 * @param StatusCache
2035
	 * @return
2036
	 */
2037
	public Integer statusCache2StatusFk(String StatusCache) {
2038
		Integer result = null;
2039
		if (StatusCache.equalsIgnoreCase("Checked by Taxonomic Editor: included in ERMS 1.1")) {
2040
			return 0;
2041
		} else if (StatusCache.equalsIgnoreCase("Added by Database Management Team")) {
2042
			return 2;
2043
		} else if (StatusCache.equalsIgnoreCase("Checked by Taxonomic Editor")) {
2044
			return 3;
2045
		} else if (StatusCache.equalsIgnoreCase("Edited by Database Management Team")) {
2046
			return 4;
2047
		} else {
2048
			logger.error("StatusFk could not be determined. StatusCache unknown: " + StatusCache);
2049
		}
2050

    
2051
		return result;
2052
	}
2053

    
2054
	/**
2055
	 * Returns the FossilStatusFk for a given FossilStatusCache.
2056
	 * @param fossilStatusCache
2057
	 * @return
2058
	 */
2059
	public Integer fossilStatusCache2FossilStatusFk(String fossilStatusCache) {
2060
		Integer result = null;
2061
		if (fossilStatusCache.equalsIgnoreCase("recent only")) {
2062
			return 1;
2063
		} else if (fossilStatusCache.equalsIgnoreCase("fossil only")) {
2064
			return 2;
2065
		} else if (fossilStatusCache.equalsIgnoreCase("recent + fossil")) {
2066
			return 3;
2067
		} else {
2068
			logger.error("FossilStatusFk could not be determined. FossilStatusCache unknown: " + fossilStatusCache);
2069
		}
2070

    
2071
		return result;
2072
	}
2073

    
2074
	/**
2075
	 * Returns the NoteCategoryFk for a given UUID representing an ExtensionType.
2076
	 * @param uuid
2077
	 * @return
2078
	 */
2079
	public static Integer getNoteCategoryFk(UUID uuid) {
2080
		Integer result = null;
2081
		if (uuid.equals(uuidExtTaxComment)) {
2082
			result = 270;
2083
		} else if (uuid.equals(uuidExtFauComment)) {
2084
			result = 281;
2085
		} else if (uuid.equals(uuidExtFauExtraCodes)) {
2086
			result = 278;
2087
		}
2088
		return result;
2089
	}
2090

    
2091
	/**
2092
	 * Returns the NoteCategoryCache for a given UUID representing an ExtensionType.
2093
	 * @param uuid
2094
	 * @return
2095
	 */
2096
	public static String getNoteCategoryCache(UUID uuid) {
2097
		String result = null;
2098
		if (uuid.equals(uuidExtTaxComment)) {
2099
			result = "Taxonomy";
2100
		} else if (uuid.equals(uuidExtFauComment)) {
2101
			result = "Biology";
2102
		} else if (uuid.equals(uuidExtFauExtraCodes)) {
2103
			result = "Distribution";
2104
		}
2105
		return result;
2106
	}
2107

    
2108
	public static Integer getQualityStatusKeyBySource(EnumSet<PesiSource> sources, TaxonName taxonName) {
2109
		if (sources.contains(PesiSource.EM)){
2110
			return QUALITY_STATUS_ADD_BY_DBMT;
2111
		}else if (sources.contains(PesiSource.ERMS)){
2112
			Set<String> statusSet = getAllQualityStatus(taxonName);
2113
			if (statusSet.size() > 1){
2114
				logger.warn("ERMS TaxonName has more than 1 quality status: " + taxonName.getTitleCache() + "; lisd=" + taxonName.getLsid());
2115
			}
2116
			if (statusSet.contains("Checked by Taxonomic Editor: included in ERMS 1.1")){
2117
				return QUALITY_STATUS_CHECKED_EDITOR_ERMS_1_1;
2118
			}else if (statusSet.contains("Added by Database Management Team")){
2119
				return QUALITY_STATUS_ADD_BY_DBMT;
2120
			}else if (statusSet.contains("Checked by Taxonomic Editor")){
2121
				return QUALITY_STATUS_CHECKED_EDITOR;
2122
			}else if (statusSet.contains("Edited by Database Management Team")){
2123
				return QUALITY_STATUS_EDITED_BY_DBMT;
2124
			}else{
2125
				logger.warn("Unknown ERMS quality status: " + statusSet.iterator().next() + " for taxon name " + taxonName.getTitleCache());
2126
				return null;
2127
			}
2128
		}else{
2129
			return null;   // TODO needs to be implemented for others
2130
		}
2131
	}
2132

    
2133

    
2134
	private static Set<String> getAllQualityStatus(TaxonName taxonName) {
2135
		Set<String> result = new HashSet<>();
2136
		for (TaxonBase<?> taxonBase : taxonName.getTaxonBases()){
2137
			result.addAll(taxonBase.getExtensions(ErmsTransformer.uuidExtQualityStatus));
2138
		}
2139
		return result;
2140
	}
2141

    
2142
	@Override
2143
	public String getQualityStatusCacheByKey(Integer qualityStatusId) throws UndefinedTransformerMethodException {
2144
		if (qualityStatusId == null){
2145
			return null;
2146
		}else{
2147
			return this.qualityStatusCacheMap.get(qualityStatusId);
2148
		}
2149
	}
2150

    
2151

    
2152
	public Object getSourceUseCacheByKey(Integer sourceUseFk) {
2153
		if (sourceUseFk == null){
2154
			return null;
2155
		}else{
2156
			return this.sourceUseCacheMap.get(sourceUseFk);
2157
		}
2158
	}
2159

    
2160
	//TODO create a reverse map
2161
	public Integer getSourceUseKeyCacheByCache(String sourceUseCache) {
2162
        if (sourceUseCache == null){
2163
            return null;
2164
        }else{
2165
            for (Integer key: sourceUseCacheMap.keySet()){
2166
                if (sourceUseCacheMap.get(key).equalsIgnoreCase(sourceUseCache)){
2167
                    return key;
2168
                }
2169
            }
2170
        }
2171
        return null;
2172
    }
2173

    
2174
	@Override
2175
	public String getTaxonStatusCacheByKey(Integer taxonStatusId) throws UndefinedTransformerMethodException {
2176
		if (taxonStatusId == null){
2177
			return null;
2178
		}else{
2179
			return this.taxonStatusCacheMap.get(taxonStatusId);
2180
		}
2181
	}
2182

    
2183
	public static String getOriginalDbBySources(EnumSet<PesiSource> sources) {
2184
		String result = "";
2185
		if (sources.contains(PesiSource.EM)){
2186
			result = CdmUtils.concat(",", result,  SOURCE_STR_EM);
2187
		}
2188
		if (sources.contains(PesiSource.FE)){
2189
			result = CdmUtils.concat(",", result,  SOURCE_STR_FE);
2190
		}
2191
		if (sources.contains(PesiSource.IF)){
2192
			result = CdmUtils.concat(",", result,  SOURCE_STR_IF);
2193
		}
2194
		if (sources.contains(PesiSource.ERMS)){
2195
			result = CdmUtils.concat(",", result,  SOURCE_STR_ERMS);
2196
		}
2197

    
2198
		return result;
2199
	}
2200

    
2201
    public static Integer pesiKingdomId(String titleCache) {
2202
        return pesiKingdomMap.get(titleCache);
2203
    }
2204
}
(14-14/14)