Project

General

Profile

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

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

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

    
24
import eu.etaxonomy.cdm.common.CdmUtils;
25
import eu.etaxonomy.cdm.io.berlinModel.BerlinModelTransformer;
26
import eu.etaxonomy.cdm.io.common.Source;
27
import eu.etaxonomy.cdm.io.common.mapping.UndefinedTransformerMethodException;
28
import eu.etaxonomy.cdm.io.common.mapping.out.ExportTransformerBase;
29
import eu.etaxonomy.cdm.io.common.mapping.out.IExportTransformer;
30
import eu.etaxonomy.cdm.io.pesi.erms.ErmsTransformer;
31
import eu.etaxonomy.cdm.io.pesi.faunaEuropaea.FaunaEuropaeaTransformer;
32
import eu.etaxonomy.cdm.model.common.CdmBase;
33
import eu.etaxonomy.cdm.model.common.Language;
34
import eu.etaxonomy.cdm.model.common.RelationshipBase;
35
import eu.etaxonomy.cdm.model.common.RelationshipTermBase;
36
import eu.etaxonomy.cdm.model.description.AbsenceTerm;
37
import eu.etaxonomy.cdm.model.description.Feature;
38
import eu.etaxonomy.cdm.model.description.PresenceAbsenceTermBase;
39
import eu.etaxonomy.cdm.model.description.PresenceTerm;
40
import eu.etaxonomy.cdm.model.location.NamedArea;
41
import eu.etaxonomy.cdm.model.location.TdwgArea;
42
import eu.etaxonomy.cdm.model.location.WaterbodyOrCountry;
43
import eu.etaxonomy.cdm.model.name.HybridRelationshipType;
44
import eu.etaxonomy.cdm.model.name.NameRelationshipType;
45
import eu.etaxonomy.cdm.model.name.NameTypeDesignationStatus;
46
import eu.etaxonomy.cdm.model.name.NomenclaturalCode;
47
import eu.etaxonomy.cdm.model.name.NomenclaturalStatusType;
48
import eu.etaxonomy.cdm.model.name.Rank;
49
import eu.etaxonomy.cdm.model.name.TaxonNameBase;
50
import eu.etaxonomy.cdm.model.occurrence.Fossil;
51
import eu.etaxonomy.cdm.model.reference.Reference;
52
import eu.etaxonomy.cdm.model.reference.ReferenceType;
53
import eu.etaxonomy.cdm.model.taxon.Synonym;
54
import eu.etaxonomy.cdm.model.taxon.SynonymRelationship;
55
import eu.etaxonomy.cdm.model.taxon.SynonymRelationshipType;
56
import eu.etaxonomy.cdm.model.taxon.Taxon;
57
import eu.etaxonomy.cdm.model.taxon.TaxonBase;
58
import eu.etaxonomy.cdm.model.taxon.TaxonRelationshipType;
59
import eu.etaxonomy.cdm.strategy.exceptions.UnknownCdmTypeException;
60

    
61
/**
62
 * @author e.-m.lee
63
 * @author a.mueller (update)
64
 * @date 16.02.2010
65
 *
66
 */
67
public final class PesiTransformer extends ExportTransformerBase implements IExportTransformer{
68
	private static final Logger logger = Logger.getLogger(PesiTransformer.class);
69

    
70
	public static final String AUCT_STRING = "auct.";
71
	
72
	
73
	//source identifiers
74
	public static final int SOURCE_EM = 1;
75
	public static final int SOURCE_FE = 2;
76
	public static final int SOURCE_IF = 3;
77
	public static final int SOURCE_ERMS = 4;
78
	
79
	//sourceRefUUIDs
80
	public static final UUID uuidSourceRefEuroMed = UUID.fromString("0603a84a-f024-4454-ab92-9e2ac0139126");
81
	public static final UUID uuidSourceRefFaunaEuropaea = UUID.fromString("6786d863-75d4-4796-b916-c1c3dff4cb70");
82
	public static final UUID uuidSourceRefErms = UUID.fromString("7744bc26-f914-42c4-b54a-dd2a030a8bb7");
83
	public static final UUID uuidSourceRefIndexFungorum = UUID.fromString("8de25d27-7d40-47f4-af3b-59d64935a843");
84
	public static final UUID uuidSourceRefAuct = UUID.fromString("5f79f96c-c100-4cd8-b78e-2b2dacf09a23");
85
	
86
	public static final String SOURCE_STR_EM = "E+M";
87
	public static final String SOURCE_STR_FE = "FaEu";
88
	public static final String SOURCE_STR_IF = "IF";
89
	public static final String SOURCE_STR_ERMS = "ERMS";
90

    
91
	// status keys
92
	public static int QUALITY_STATUS_CHECKED_EDITOR_ERMS_1_1 = 0;
93
	public static int QUALITY_STATUS_ADD_BY_DBMT= 2;
94
	public static int QUALITY_STATUS_CHECKED_EDITOR = 3;
95
	public static int QUALITY_STATUS_EDITED_BY_DBMT = 4;
96
	
97
	// marker type
98
	public static final UUID uuidMarkerGuidIsMissing = UUID.fromString("24e70843-05e2-44db-954b-84df0d23ea20");
99
	public static final UUID uuidMarkerTypeHasNoLastAction = UUID.fromString("99652d5a-bc92-4251-b57d-0fec4d258ab7");
100
//	public static final UUID uuidMarkerFossil = UUID.fromString("761ce108-031a-4e07-b444-f8d757070312");
101
	
102
	
103
	//extension type uuids
104
	public static final UUID cacheCitationUuid = UUID.fromString("29656168-32d6-4301-9067-d57c63be5c67");
105
	//public static final UUID expertUserIdUuid = UUID.fromString("e25813d3-c67c-4585-9aa0-970fafde50b4");
106
	//public static final UUID speciesExpertUserIdUuid = UUID.fromString("6d42abd8-8894-4980-ae07-e918affd4172");
107
	public static final UUID expertNameUuid = BerlinModelTransformer.uuidExpertName;
108
	public static final UUID speciesExpertNameUuid = BerlinModelTransformer.uuidSpeciesExpertName; 
109
	public static final UUID lastActionDateUuid = UUID.fromString("8d0a7d81-bb83-4576-84c3-8c906ef039b2");
110
	public static final UUID lastActionUuid = UUID.fromString("bc20d5bc-6161-4279-9499-89ea26ce5f6a");
111
	public static final UUID taxCommentUuid = UUID.fromString("8041a752-0479-4626-ab1b-b266b751f816");
112
	public static final UUID fauCommentUuid = UUID.fromString("054f773a-41c8-4ad5-83e3-981320c1c126");
113
	public static final UUID fauExtraCodesUuid = UUID.fromString("b8c7e77d-9869-4787-bed6-b4b302dbc5f5");
114

    
115
	// References
116
	public static int REF_ARTICLE_IN_PERIODICAL = 1;
117
	public static int REF_PART_OF_OTHER = 2;
118
	public static int REF_BOOK = 3;
119
	public static int REF_DATABASE = 4;
120
	public static int REF_INFORMAL = 5;
121
	public static int REF_NOT_APPLICABLE = 6;
122
	public static int REF_WEBSITE = 7;
123
	public static int REF_PUBLISHED = 8;
124
	public static int REF_JOURNAL = 9;
125
	public static int REF_UNRESOLVED = 10;
126
	public static int REF_PUBLICATION = 11;
127
	public static String REF_STR_UNRESOLVED = "unresolved";
128
	
129
	// NameStatus
130
	public static int NAME_ST_NOM_INVAL = 1;
131
	public static int NAME_ST_NOM_ILLEG = 2;
132
	public static int NAME_ST_NOM_NUD = 3;
133
	public static int NAME_ST_NOM_REJ = 4;
134
	public static int NAME_ST_NOM_REJ_PROP = 5;
135
	public static int NAME_ST_NOM_UTIQUE_REJ = 6;
136
	public static int NAME_ST_NOM_UTIQUE_REJ_PROP = 7;
137
	public static int NAME_ST_NOM_CONS = 8;
138
	public static int NAME_ST_NOM_CONS_PROP = 9;
139
	public static int NAME_ST_ORTH_CONS = 10;
140
	public static int NAME_ST_ORTH_CONS_PROP = 11;
141
	public static int NAME_ST_NOM_SUPERFL = 12;
142
	public static int NAME_ST_NOM_AMBIG = 13;
143
	public static int NAME_ST_NOM_PROVIS = 14;
144
	public static int NAME_ST_NOM_DUB = 15;
145
	public static int NAME_ST_NOM_NOV = 16;
146
	public static int NAME_ST_NOM_CONFUS = 17;
147
	public static int NAME_ST_NOM_ALTERN = 18;
148
	public static int NAME_ST_COMB_INVAL = 19;
149
	public static int NAME_ST_LEGITIMATE = 20; // PESI specific from here
150
	public static int NAME_ST_COMB_INED = 21;
151
	public static int NAME_ST_COMB_AND_STAT_INED = 22;
152
	public static int NAME_ST_NOM_AND_ORTH_CONS = 23;
153
	public static int NAME_ST_NOM_NOV_INED = 24;
154
	public static int NAME_ST_SP_NOV_INED = 25;
155
	public static int NAME_ST_ALTERNATE_REPRESENTATION = 26;
156
	public static int NAME_ST_TEMPORARY_NAME = 27;
157
	public static int NAME_ST_SPECIES_INQUIRENDA = 28;
158

    
159
	// TaxonStatus
160
	public static int T_STATUS_ACCEPTED = 1;
161
	public static int T_STATUS_SYNONYM = 2;
162
	public static int T_STATUS_PARTIAL_SYN = 3;
163
	public static int T_STATUS_PRO_PARTE_SYN = 4;
164
	public static int T_STATUS_UNRESOLVED = 5;
165
	public static int T_STATUS_ORPHANED = 6;
166
	public static int T_STATUS_UNACCEPTED = 7;
167
	public static int T_STATUS_NOT_ACCEPTED = 8;
168
	
169
	// TypeDesginationStatus //	 -> not a table anymore
170
	public static int TYPE_BY_ORIGINAL_DESIGNATION = 1;
171
	public static int TYPE_BY_SUBSEQUENT_DESIGNATION = 2;
172
	public static int TYPE_BY_MONOTYPY = 3;
173
	public static String TYPE_STR_BY_ORIGINAL_DESIGNATION = "Type by original designation";
174
	public static String TYPE_STR_BY_SUBSEQUENT_DESIGNATION = "Type by subsequent designation";
175
	public static String TYPE_STR_BY_MONOTYPY = "Type by monotypy";
176
	
177
	// RelTaxonQualifier
178
	public static int IS_BASIONYM_FOR = 1;
179
	public static int IS_LATER_HOMONYM_OF = 2;
180
	public static int IS_REPLACED_SYNONYM_FOR = 3;
181
	public static int IS_VALIDATION_OF = 4;
182
	public static int IS_LATER_VALIDATION_OF = 5;
183
	public static int IS_TYPE_OF = 6;
184
	public static int IS_CONSERVED_TYPE_OF = 7;
185
	public static int IS_REJECTED_TYPE_OF = 8;
186
	public static int IS_FIRST_PARENT_OF = 9;
187
	public static int IS_SECOND_PARENT_OF = 10;
188
	public static int IS_FEMALE_PARENT_OF = 11;
189
	public static int IS_MALE_PARENT_OF = 12;
190
	public static int IS_CONSERVED_AGAINST = 13;
191
	public static int IS_REJECTED_IN_FAVOUR_OF = 14;
192
	public static int IS_TREATED_AS_LATER_HOMONYM_OF = 15;
193
	public static int IS_ORTHOGRAPHIC_VARIANT_OF = 16;
194
	public static int IS_ALTERNATIVE_NAME_FOR = 17;
195
	public static int HAS_SAME_TYPE_AS = 18;
196
	public static int IS_LECTOTYPE_OF = 61;
197
	public static int TYPE_NOT_DESIGNATED = 62;
198
	public static int IS_TAXONOMICALLY_INCLUDED_IN = 101;
199
	public static int IS_SYNONYM_OF = 102;
200
	public static int IS_MISAPPLIED_NAME_FOR = 103;
201
	public static int IS_PRO_PARTE_SYNONYM_OF = 104;
202
	public static int IS_PARTIAL_SYNONYM_OF = 105;
203
	public static int IS_HETEROTYPIC_SYNONYM_OF = 106;
204
	public static int IS_HOMOTYPIC_SYNONYM_OF = 107;
205
	public static int IS_PRO_PARTE_AND_HOMOTYPIC_SYNONYM_OF = 201;
206
	public static int IS_PRO_PARTE_AND_HETEROTYPIC_SYNONYM_OF = 202;
207
	public static int IS_PARTIAL_AND_HOMOTYPIC_SYNONYM_OF = 203;
208
	public static int IS_PARTIAL_AND_HETEROTYPIC_SYNONYM_OF = 204;
209
	public static int IS_INFERRED_EPITHET_FOR = 301;
210
	public static int IS_INFERRED_GENUS_FOR = 302;
211
	public static int IS_POTENTIAL_COMBINATION_FOR = 303;
212

    
213
		
214
	//namespaces
215
	public static String STR_NAMESPACE_NOMINAL_TAXON = "Nominal taxon from TAX_ID:";
216
	public static String STR_NAMESPACE_INFERRED_EPITHET = "Inferred epithet from TAX_ID:";
217
	public static String STR_NAMESPACE_INFERRED_GENUS = "Inferred genus from TAX_ID:";
218
	public static String STR_NAMESPACE_POTENTIAL_COMBINATION = "Potential combination from TAX_ID:";
219

    
220

    
221
	// Kingdoms
222
	public static int KINGDOM_NULL = 0;
223
	public static int KINGDOM_ANIMALIA = 2;
224
	public static int KINGDOM_PLANTAE = 3;
225
	public static int KINGDOM_FUNGI = 4;
226
	public static int KINGDOM_PROTOZOA = 5;
227
	public static int KINGDOM_BACTERIA = 6;
228
	public static int KINGDOM_CHROMISTA = 7;
229

    
230
	// Animalia Ranks
231
	public static int Animalia_Kingdom = 10;
232
	public static int Animalia_Subkingdom = 20;
233
	public static int Animalia_Superphylum = 23;
234
	public static int Animalia_Phylum = 30;
235
	public static int Animalia_Subphylum = 40;
236
	public static int Animalia_Infraphylum = 45;
237
	public static int Animalia_Superclass = 50;
238
	public static int Animalia_Class = 60;
239
	public static int Animalia_Subclass = 70;
240
	public static int Animalia_Infraclass = 80;
241
	public static int Animalia_Superorder = 90;
242
	public static int Animalia_Order = 100;
243
	public static int Animalia_Suborder = 110;
244
	public static int Animalia_Infraorder = 120;
245
	public static int Animalia_Section = 121;
246
	public static int Animalia_Subsection = 122;
247
	public static int Animalia_Superfamily = 130;
248
	public static int Animalia_Family = 140;
249
	public static int Animalia_Subfamily = 150;
250
	public static int Animalia_Tribe = 160;
251
	public static int Animalia_Subtribe = 170;
252
	public static int Animalia_Genus = 180;
253
	public static int Animalia_Subgenus = 190;
254
	public static int Animalia_Species =220;
255
	public static int Animalia_Subspecies = 230;
256
	public static int Animalia_Natio = 235;
257
	public static int Animalia_Variety = 240;
258
	public static int Animalia_Subvariety = 250;
259
	public static int Animalia_Forma = 260;
260

    
261
	// Plantae Ranks
262
	public static int Plantae_Kingdom = 10;
263
	public static int Plantae_Subkingdom = 20;
264
	public static int Plantae_Division = 30;
265
	public static int Plantae_Subdivision = 40;
266
	public static int Plantae_Class = 60;
267
	public static int Plantae_Subclass = 70;
268
	public static int Plantae_Order = 100;
269
	public static int Plantae_Suborder = 110;
270
	public static int Plantae_Family = 140;
271
	public static int Plantae_Subfamily = 150;
272
	public static int Plantae_Tribe	= 160;
273
	public static int Plantae_Subtribe = 170;
274
	public static int Plantae_Genus = 180;
275
	public static int Plantae_Subgenus = 190;
276
	public static int Plantae_Section = 200;
277
	public static int Plantae_Subsection = 210;
278
	public static int Plantae_Series = 212;
279
	public static int Plantae_Subseries	= 214;
280
	public static int Plantae_Aggregate	= 216;
281
	public static int Plantae_Coll_Species = 218;
282
	public static int Plantae_Species = 220;
283
	public static int Plantae_Grex = 225;
284
	public static int Plantae_Subspecies = 230;
285
	public static int Plantae_Proles = 232;
286
	public static int Plantae_Race = 234;
287
	public static int Plantae_Convarietas = 236;
288
	public static int Plantae_Variety = 240;
289
	public static int Plantae_Subvariety = 250;
290
	public static int Plantae_Forma	= 260;
291
	public static int Plantae_Subforma = 270;
292
	public static int Plantae_Forma_spec = 275;
293
	public static int Plantae_Taxa_infragen = 280;
294
	public static int Plantae_Taxa_infraspec = 285;
295
	
296
	// Fungi Ranks
297
	public static int Fungi_Kingdom = 10;
298
	public static int Fungi_Subkingdom = 20;
299
	public static int Fungi_Division = 30;
300
	public static int Fungi_Subdivision = 40;
301
	public static int Fungi_Class	= 60;
302
	public static int Fungi_Subclass = 70;
303
	public static int Fungi_Order	= 100;
304
	public static int Fungi_Suborder = 110;
305
	public static int Fungi_Family = 140;
306
	public static int Fungi_Subfamily = 150;
307
	public static int Fungi_Tribe = 160;
308
	public static int Fungi_Subtribe = 170;
309
	public static int Fungi_Genus = 180;
310
	public static int Fungi_Subgenus = 190;
311
	public static int Fungi_Section = 200;
312
	public static int Fungi_Subsection = 210;
313
	public static int Fungi_Species = 220;
314
	public static int Fungi_Subspecies = 230;
315
	public static int Fungi_Variety = 240;
316
	public static int Fungi_Subvariety = 250;
317
	public static int Fungi_Forma	= 260;
318
	public static int Fungi_Subforma = 270;
319
	
320
	//Protozoa Ranks
321
	public static int Protozoa_Kingdom = 10;
322
	public static int Protozoa_Subkingdom = 20;
323
	public static int Protozoa_Phylum = 30;
324
	public static int Protozoa_Subphylum = 40;
325
	public static int Protozoa_Superclass = 50;
326
	public static int Protozoa_Class	= 60;
327
	public static int Protozoa_Subclass = 70;
328
	public static int Protozoa_Infraclass = 80;
329
	public static int Protozoa_Superorder = 90;
330
	public static int Protozoa_Order	= 100;
331
	public static int Protozoa_Suborder = 110;
332
	public static int Protozoa_Infraorder = 120;
333
	public static int Protozoa_Superfamily = 130;
334
	public static int Protozoa_Family = 140;
335
	public static int Protozoa_Subfamily = 150;
336
	public static int Protozoa_Tribe	= 160;
337
	public static int Protozoa_Subtribe = 170;
338
	public static int Protozoa_Genus	= 180;
339
	public static int Protozoa_Subgenus = 190;
340
	public static int Protozoa_Species = 220;
341
	public static int Protozoa_Subspecies = 230;
342
	public static int Protozoa_Variety = 240;
343
	public static int Protozoa_Forma	= 260;
344
	
345
	// Bacteria Ranks
346
	public static int Bacteria_Kingdom = 10;
347
	public static int Bacteria_Subkingdom = 20;
348
	public static int Bacteria_Phylum = 30;
349
	public static int Bacteria_Subphylum	= 40;
350
	public static int Bacteria_Superclass = 50;
351
	public static int Bacteria_Class	= 60;
352
	public static int Bacteria_Subclass = 70;
353
	public static int Bacteria_Infraclass = 80;
354
	public static int Bacteria_Superorder = 90;
355
	public static int Bacteria_Order	= 100;
356
	public static int Bacteria_Suborder = 110;
357
	public static int Bacteria_Infraorder = 120;
358
	public static int Bacteria_Superfamily = 130;
359
	public static int Bacteria_Family = 140;
360
	public static int Bacteria_Subfamily	= 150;
361
	public static int Bacteria_Tribe	= 160;
362
	public static int Bacteria_Subtribe = 170;
363
	public static int Bacteria_Genus	= 180;
364
	public static int Bacteria_Subgenus = 190;
365
	public static int Bacteria_Species = 220;
366
	public static int Bacteria_Subspecies = 230;
367
	public static int Bacteria_Variety = 240;
368
	public static int Bacteria_Forma	= 260;
369

    
370
	// Chromista Ranks
371
	public static int Chromista_Kingdom = 10;
372
	public static int Chromista_Subkingdom = 20;
373
	public static int Chromista_Infrakingdom = 25;
374
	public static int Chromista_Phylum = 30;
375
	public static int Chromista_Subphylum = 40;
376
	public static int Chromista_Superclass = 50;
377
	public static int Chromista_Class = 60;
378
	public static int Chromista_Subclass = 70;
379
	public static int Chromista_Infraclass = 80;
380
	public static int Chromista_Superorder = 90;
381
	public static int Chromista_Order = 100;
382
	public static int Chromista_Suborder = 110;
383
	public static int Chromista_Infraorder = 120;
384
	public static int Chromista_Superfamily	= 130;
385
	public static int Chromista_Family = 140;
386
	public static int Chromista_Subfamily = 150;
387
	public static int Chromista_Tribe = 160;
388
	public static int Chromista_Subtribe = 170;
389
	public static int Chromista_Genus = 180;
390
	public static int Chromista_Subgenus = 190;
391
	public static int Chromista_Section = 200;
392
	public static int Chromista_Subsection = 210;
393
	public static int Chromista_Species	= 220;
394
	public static int Chromista_Subspecies = 230;
395
	public static int Chromista_Variety	= 240;
396
	public static int Chromista_Subvariety = 250;
397
	public static int Chromista_Forma = 260;
398
	
399
	// NoteCategory
400
	public static int NoteCategory_description = 1;
401
	public static int NoteCategory_ecology = 4;
402
	public static int NoteCategory_phenology	= 5;
403
	public static int NoteCategory_general_distribution_euromed = 10;
404
	public static int NoteCategory_general_distribution_world = 11;
405
	public static int NoteCategory_Common_names = 12;
406
	public static int NoteCategory_Occurrence = 13;
407
	public static int NoteCategory_Maps =14;
408
	public static int NoteCategory_Link_to_maps = 20;
409
	public static int NoteCategory_Link_to_images = 21;
410
	public static int NoteCategory_Link_to_taxonomy = 22;
411
	public static int NoteCategory_Link_to_general_information = 23;
412
	public static int NoteCategory_undefined_link = 24;
413
	public static int NoteCategory_Editor_Braces = 249;
414
	public static int NoteCategory_Editor_Brackets = 250;
415
	public static int NoteCategory_Editor_Parenthesis = 251;
416
	public static int NoteCategory_Inedited = 252;
417
	public static int NoteCategory_Comments_on_editing_process = 253;
418
	public static int NoteCategory_Publication_date = 254;
419
	public static int NoteCategory_Morphology = 255;
420
	public static int NoteCategory_Acknowledgments = 257;
421
	public static int NoteCategory_Original_publication = 258;
422
	public static int NoteCategory_Type_locality	= 259;
423
	public static int NoteCategory_Environment = 260;
424
	public static int NoteCategory_Spelling = 261;
425
	public static int NoteCategory_Systematics = 262;
426
	public static int NoteCategory_Remark = 263;
427
	public static int NoteCategory_Date_of_publication = 264;
428
	public static int NoteCategory_Additional_information = 266;
429
	public static int NoteCategory_Status = 267;
430
	public static int NoteCategory_Nomenclature = 268;
431
	public static int NoteCategory_Homonymy = 269;
432
	public static int NoteCategory_Taxonomy = 270;
433
	public static int NoteCategory_Taxonomic_status = 272;
434
	public static int NoteCategory_Authority	= 273;
435
	public static int NoteCategory_Identification = 274;
436
	public static int NoteCategory_Validity = 275;
437
	public static int NoteCategory_Classification = 276;
438
	public static int NoteCategory_Distribution = 278;
439
	public static int NoteCategory_Synonymy = 279;
440
	public static int NoteCategory_Habitat = 280;
441
	public static int NoteCategory_Biology = 281;
442
	public static int NoteCategory_Diagnosis	= 282;
443
	public static int NoteCategory_Host = 283;
444
	public static int NoteCategory_Note = 284;
445
	public static int NoteCategory_Rank = 285;
446
	public static int NoteCategory_Taxonomic_Remark = 286;
447
	public static int NoteCategory_Taxonomic_Remarks = 287;
448

    
449
	public static int NoteCategory_Conservation_Status= 301;
450
	public static int NoteCategory_Use = 302;
451
	public static int NoteCategory_Comments = 303;
452

    
453
	
454
	// Language
455
	public static int Language_Albanian = 1;
456
	public static int Language_Arabic = 2;
457
	public static int Language_Armenian = 3;
458
	public static int Language_Azerbaijan = 4;
459
	public static int Language_Belarusian = 5;
460
	public static int Language_Bulgarian = 6;
461
	public static int Language_Catalan = 7;
462
	public static int Language_Croat = 8;
463
	public static int Language_Czech = 9;
464
	public static int Language_Danish = 10;
465
	public static int Language_Dutch = 11;
466
	public static int Language_English = 12;
467
	public static int Language_Euskera = 13;
468
	public static int Language_Estonian = 14;
469
	public static int Language_Finnish = 15;
470
	public static int Language_French = 16;
471
	public static int Language_Georgian = 17;
472
	public static int Language_German = 18;
473
	public static int Language_Greek = 19;
474
	public static int Language_Hungarian = 20;
475
	public static int Language_Icelandic = 21;
476
	public static int Language_Irish_Gaelic = 22;
477
	public static int Language_Israel_Hebrew = 23;
478
	public static int Language_Italian = 24;
479
	public static int Language_Latvian = 25;
480
	public static int Language_Lithuanian = 26;
481
	public static int Language_Macedonian = 27;
482
	public static int Language_Maltese = 28;
483
	public static int Language_Moldovian = 29;
484
	public static int Language_Norwegian = 30;
485
	public static int Language_Polish = 31;
486
	public static int Language_Portuguese = 32;
487
	public static int Language_Roumanian = 33;
488
	public static int Language_Russian = 34;
489
	public static int Language_Russian_Caucasian = 35;
490
	public static int Language_Russian_Altaic_kalmyk_oirat = 36;
491
	public static int Language_Russian_Altaic_karachay_balkar = 37;
492
	public static int Language_Russian_Altaic_kumyk = 38;
493
	public static int Language_Russian_Altaic_nogai = 39;
494
	public static int Language_Russian_Altaic_north_azerbaijani = 40;
495
	public static int Language_Russian_Indo_european_russian = 41;
496
	public static int Language_Russian_Indo_european_kalmyk_oirat = 42;
497
	public static int Language_Russian_Indo_european_osetin = 43;
498
	public static int Language_Russian_North_caucasian_abaza = 44;
499
	public static int Language_Russian_North_caucasian_adyghe = 45;
500
	public static int Language_Russian_North_caucasian_chechen = 46;
501
	public static int Language_Russian_North_caucasian_kabardian = 47;
502
	public static int Language_Russian_North_caucasian_lak = 48;
503
	public static int Language_Russian_North_caucasian_avar = 49;
504
	public static int Language_Russian_North_caucasian_in = 50;
505
	public static int Language_Russian_Uralic_chuvash = 51;
506
	public static int Language_Russian_Uralic_udmurt = 52;
507
	public static int Language_Serbian = 53;
508
	public static int Language_Slovak = 54;
509
	public static int Language_Slovene = 55;
510
	public static int Language_Spanish_Castillian = 56;
511
	public static int Language_Swedish = 57;
512
	public static int Language_Turkish = 58;
513
	public static int Language_Ukraine = 59;
514
	public static int Language_Welsh = 60;
515
	public static int Language_Corsican = 61;
516

    
517
	// FossilStatus
518
	public static int FOSSILSTATUS_RECENT_ONLY = 1;
519
	public static int FOSSILSTATUS_FOSSIL_ONLY = 2;
520
	public static int FOSSILSTATUS_RECENT_FOSSIL = 3;
521
	public static String STR_FOSSIL_ONLY = "fossil only";  //still used for Index Fungorum
522
	
523
	// SourceUse
524
	public static int ORIGINAL_DESCRIPTION = 1;
525
	public static int BASIS_OF_RECORD = 2;
526
	public static int ADDITIONAL_SOURCE = 3;
527
	public static int SOURCE_OF_SYNONYMY = 4;
528
	public static int REDESCRIPTION = 5;
529
	public static int NEW_COMBINATION_REFERENCE = 6;
530
	public static int STATUS_SOURCE = 7;
531
	public static int NOMENCLATURAL_REFERENCE = 8;
532
	public static String STR_NOMENCLATURAL_REFERENCE = "nomenclatural reference";
533

    
534
	// Area
535
	public static int AREA_EAST_AEGEAN_ISLANDS = 1;
536
	public static int AREA_GREEK_EAST_AEGEAN_ISLANDS = 2;
537
	public static int AREA_TURKISH_EAST_AEGEAN_ISLANDS = 3;
538
	public static int AREA_ALBANIA = 4;
539
	public static int AREA_AUSTRIA_WITH_LIECHTENSTEIN = 5;
540
	public static int AREA_AUSTRIA = 6;
541
	public static int AREA_LIECHTENSTEIN = 7;
542
	public static int AREA_AZORES = 8;
543
	public static int AREA_CORVO = 9;
544
	public static int AREA_FAIAL = 10;
545
	public static int AREA_GRACIOSA = 11;
546
	public static int AREA_SAO_JORGE = 12;
547
	public static int AREA_FLORES = 13;
548
	public static int AREA_SAO_MIGUEL = 14;
549
	public static int AREA_PICO = 15;
550
	public static int AREA_SANTA_MARIA = 16;
551
	public static int AREA_TERCEIRA = 17;
552
	public static int AREA_BELGIUM_WITH_LUXEMBOURG = 18;
553
	public static int AREA_BELGIUM = 19;
554
	public static int AREA_LUXEMBOURG = 20;
555
	public static int AREA_BOSNIA_HERZEGOVINA = 21;
556
	public static int AREA_BALEARES = 22;
557
	public static int AREA_IBIZA_WITH_FORMENTERA = 23;
558
	public static int AREA_MALLORCA = 24;
559
	public static int AREA_MENORCA = 25;
560
	public static int AREA_GREAT_BRITAIN = 26;
561
	public static int AREA_BALTIC_STATES_ESTONIA_LATVIA_LITHUANIA_AND_KALININGRAD_REGION = 27;
562
	public static int AREA_BULGARIA = 28;
563
	public static int AREA_BELARUS = 29;
564
	public static int AREA_CANARY_ISLANDS = 30;
565
	public static int AREA_GRAN_CANARIA = 31;
566
	public static int AREA_FUERTEVENTURA_WITH_LOBOS = 32;
567
	public static int AREA_GOMERA = 33;
568
	public static int AREA_HIERRO = 34;
569
	public static int AREA_LANZAROTE_WITH_GRACIOSA = 35;
570
	public static int AREA_LA_PALMA = 36;
571
	public static int AREA_TENERIFE = 37;
572
	public static int AREA_MONTENEGRO = 38;
573
	public static int AREA_CORSE = 39;
574
	public static int AREA_CRETE_WITH_KARPATHOS_KASOS_AND_GAVDHOS = 40;
575
	public static int AREA_CZECH_REPUBLIC = 41;
576
	public static int AREA_CROATIA = 42;
577
	public static int AREA_CYPRUS = 43;
578
	public static int AREA_FORMER_CZECHOSLOVAKIA = 44;
579
	public static int AREA_DENMARK_WITH_BORNHOLM = 45;
580
	public static int AREA_ESTONIA = 46;
581
	public static int AREA_FAROE_ISLANDS = 47;
582
	public static int AREA_FINLAND_WITH_AHVENANMAA = 48;
583
	public static int AREA_FRANCE = 49;
584
	public static int AREA_CHANNEL_ISLANDS = 50;
585
	public static int AREA_FRENCH_MAINLAND = 51;
586
	public static int AREA_MONACO = 52;
587
	public static int AREA_GERMANY = 53;
588
	public static int AREA_GREECE_WITH_CYCLADES_AND_MORE_ISLANDS = 54;
589
	public static int AREA_IRELAND = 55;
590
	public static int AREA_REPUBLIC_OF_IRELAND = 56;
591
	public static int AREA_NORTHERN_IRELAND = 57;
592
	public static int AREA_SWITZERLAND = 58;
593
	public static int AREA_NETHERLANDS = 59;
594
	public static int AREA_SPAIN = 60;
595
	public static int AREA_ANDORRA = 61;
596
	public static int AREA_GIBRALTAR = 62;
597
	public static int AREA_KINGDOM_OF_SPAIN = 63;
598
	public static int AREA_HUNGARY = 64;
599
	public static int AREA_ICELAND = 65;
600
	public static int AREA_ITALY = 66;
601
	public static int AREA_ITALIAN_MAINLAND = 67;
602
	public static int AREA_SAN_MARINO = 68;
603
	public static int AREA_FORMER_JUGOSLAVIA = 69;
604
	public static int AREA_LATVIA = 70;
605
	public static int AREA_LITHUANIA = 71;
606
	public static int AREA_PORTUGUESE_MAINLAND = 72;
607
	public static int AREA_MADEIRA_ARCHIPELAGO = 73;
608
	public static int AREA_DESERTAS = 74;
609
	public static int AREA_MADEIRA = 75;
610
	public static int AREA_PORTO_SANTO = 76;
611
	public static int AREA_THE_FORMER_JUGOSLAV_REPUBLIC_OF_MAKEDONIJA = 77;
612
	public static int AREA_MOLDOVA = 78;
613
	public static int AREA_NORWEGIAN_MAINLAND = 79;
614
	public static int AREA_POLAND = 80;
615
	public static int AREA_THE_RUSSIAN_FEDERATION = 81;
616
	public static int AREA_NOVAYA_ZEMLYA_AND_FRANZ_JOSEPH_LAND = 82;
617
	public static int AREA_CENTRAL_EUROPEAN_RUSSIA = 83;
618
	public static int AREA_EASTERN_EUROPEAN_RUSSIA = 84;
619
	public static int AREA_KALININGRAD = 85;
620
	public static int AREA_NORTHERN_EUROPEAN_RUSSIA = 86;
621
	public static int AREA_NORTHWEST_EUROPEAN_RUSSIA = 87;
622
	public static int AREA_SOUTH_EUROPEAN_RUSSIA = 88;
623
	public static int AREA_ROMANIA = 89;
624
	public static int AREA_FORMER_USSR = 90;
625
	public static int AREA_RUSSIA_BALTIC = 91;
626
	public static int AREA_RUSSIA_CENTRAL = 92;
627
	public static int AREA_RUSSIA_SOUTHEAST = 93;
628
	public static int AREA_RUSSIA_NORTHERN = 94;
629
	public static int AREA_RUSSIA_SOUTHWEST = 95;
630
	public static int AREA_SARDEGNA = 96;
631
	public static int AREA_SVALBARD_WITH_BJORNOYA_AND_JAN_MAYEN = 97;
632
	public static int AREA_SELVAGENS_ISLANDS = 98;
633
	public static int AREA_SICILY_WITH_MALTA = 99;
634
	public static int AREA_MALTA = 100;
635
	public static int AREA_SICILY = 101;
636
	public static int AREA_SLOVAKIA = 102;
637
	public static int AREA_SLOVENIA = 103;
638
	public static int AREA_SERBIA_WITH_MONTENEGRO = 104;
639
	public static int AREA_SERBIA_INCLUDING_VOJVODINA_AND_WITH_KOSOVO = 105;
640
	public static int AREA_SWEDEN = 106;
641
	public static int AREA_EUROPEAN_TURKEY = 107;
642
	public static int AREA_UKRAINE_INCLUDING_CRIMEA = 108;
643
	public static int AREA_CRIMEA = 109;
644
	public static int AREA_UKRAINE = 110;
645
	public static int AREA_GREEK_MAINLAND = 111;
646
	public static int AREA_CRETE = 112;
647
	public static int AREA_DODECANESE_ISLANDS = 113;
648
	public static int AREA_CYCLADES_ISLANDS = 114;
649
	public static int AREA_NORTH_AEGEAN_ISLANDS = 115;
650
	public static int AREA_VATICAN_CITY = 116;
651
	public static int AREA_FRANZ_JOSEF_LAND = 117;
652
	public static int AREA_NOVAYA_ZEMLYA = 118;
653
	public static int AREA_AZERBAIJAN_INCLUDING_NAKHICHEVAN = 119;
654
	public static int AREA_AZERBAIJAN = 120;
655
	public static int AREA_NAKHICHEVAN = 121;
656
	public static int AREA_ALGERIA = 122;
657
	public static int AREA_ARMENIA = 123;
658
	public static int AREA_CAUCASUS_REGION = 124;
659
	public static int AREA_EGYPT = 125;
660
	public static int AREA_GEORGIA = 126;
661
	public static int AREA_ISRAEL_JORDAN = 127;
662
	public static int AREA_ISRAEL = 128;
663
	public static int AREA_JORDAN = 129;
664
	public static int AREA_LEBANON = 130;
665
	public static int AREA_LIBYA = 131;
666
	public static int AREA_LEBANON_SYRIA = 132;
667
	public static int AREA_MOROCCO = 133;
668
	public static int AREA_NORTH_CAUCASUS = 134;
669
	public static int AREA_SINAI = 135;
670
	public static int AREA_SYRIA = 136;
671
	public static int AREA_TUNISIA = 137;
672
	public static int AREA_ASIATIC_TURKEY = 138;
673
	public static int AREA_TURKEY = 139;
674
	public static int AREA_NORTHERN_AFRICA = 140;
675
	public static int AREA_AFRO_TROPICAL_REGION = 141;
676
	public static int AREA_AUSTRALIAN_REGION = 142;
677
	public static int AREA_EAST_PALAEARCTIC = 143;
678
	public static int AREA_NEARCTIC_REGION = 144;
679
	public static int AREA_NEOTROPICAL_REGION = 145;
680
	public static int AREA_NEAR_EAST = 146;
681
	public static int AREA_ORIENTAL_REGION = 147;
682
	public static int AREA_EUROPEAN_MARINE_WATERS = 148;
683
	public static int AREA_MEDITERRANEAN_SEA = 149;
684
	public static int AREA_WHITE_SEA = 150;
685
	public static int AREA_NORTH_SEA = 151;
686
	public static int AREA_BALTIC_SEA = 152;
687
	public static int AREA_BLACK_SEA = 153;
688
	public static int AREA_BARENTS_SEA = 154;
689
	public static int AREA_CASPIAN_SEA = 155;
690
	public static int AREA_PORTUGUESE_EXCLUSIVE_ECONOMIC_ZONE = 156;
691
	public static int AREA_BELGIAN_EXCLUSIVE_ECONOMIC_ZONE = 157;
692
	public static int AREA_FRENCH_EXCLUSIVE_ECONOMIC_ZONE = 158;
693
	public static int AREA_ENGLISH_CHANNEL = 159;
694
	public static int AREA_ADRIATIC_SEA = 160;
695
	public static int AREA_BISCAY_BAY = 161;
696
	public static int AREA_DUTCH_EXCLUSIVE_ECONOMIC_ZONE = 162;
697
	public static int AREA_UNITED_KINGDOM_EXCLUSIVE_ECONOMIC_ZONE = 163;
698
	public static int AREA_SPANISH_EXCLUSIVE_ECONOMIC_ZONE = 164;
699
	public static int AREA_EGYPTIAN_EXCLUSIVE_ECONOMIC_ZONE = 165;
700
	public static int AREA_GRECIAN_EXCLUSIVE_ECONOMIC_ZONE = 166;
701
	public static int AREA_TIRRENO_SEA = 167;
702
	public static int AREA_ICELANDIC_EXCLUSIVE_ECONOMIC_ZONE = 168;
703
	public static int AREA_IRISH_EXCLUSIVE_ECONOMIC_ZONE = 169;
704
	public static int AREA_IRISH_SEA = 170;
705
	public static int AREA_ITALIAN_EXCLUSIVE_ECONOMIC_ZONE = 171;
706
	public static int AREA_NORWEGIAN_SEA = 172;
707
	public static int AREA_MOROCCAN_EXCLUSIVE_ECONOMIC_ZONE = 173;
708
	public static int AREA_NORWEGIAN_EXCLUSIVE_ECONOMIC_ZONE = 174;
709
	public static int AREA_SKAGERRAK = 175;
710
	public static int AREA_TUNISIAN_EXCLUSIVE_ECONOMIC_ZONE = 176;
711
	public static int AREA_WADDEN_SEA = 177;
712
	public static int AREA_BELT_SEA = 178;
713
	public static int AREA_MARMARA_SEA = 179;
714
	public static int AREA_SEA_OF_AZOV = 180;
715
	public static int AREA_AEGEAN_SEA = 181;
716
	public static int AREA_BULGARIAN_EXCLUSIVE_ECONOMIC_ZONE = 182;
717
	public static int AREA_SOUTH_BALTIC_PROPER = 183;
718
	public static int AREA_BALTIC_PROPER = 184;
719
	public static int AREA_NORTH_BALTIC_PROPER = 185;
720
	public static int AREA_ARCHIPELAGO_SEA = 186;
721
	public static int AREA_BOTHNIAN_SEA = 187;
722
	public static int AREA_GERMAN_EXCLUSIVE_ECONOMIC_ZONE = 188;
723
	public static int AREA_SWEDISH_EXCLUSIVE_ECONOMIC_ZONE = 189;
724
	public static int AREA_UKRAINIAN_EXCLUSIVE_ECONOMIC_ZONE = 190;
725
	public static int AREA_MADEIRAN_EXCLUSIVE_ECONOMIC_ZONE = 191;
726
	public static int AREA_LEBANESE_EXCLUSIVE_ECONOMIC_ZONE = 192;
727
	public static int AREA_SPANISH_EXCLUSIVE_ECONOMIC_ZONE_MEDITERRANEAN_PART = 193;
728
	public static int AREA_ESTONIAN_EXCLUSIVE_ECONOMIC_ZONE = 194;
729
	public static int AREA_CROATIAN_EXCLUSIVE_ECONOMIC_ZONE = 195;
730
	public static int AREA_BALEAR_SEA = 196;
731
	public static int AREA_TURKISH_EXCLUSIVE_ECONOMIC_ZONE = 197;
732
	public static int AREA_DANISH_EXCLUSIVE_ECONOMIC_ZONE = 198;
733
	public static int AREA_TRANSCAUCASUS = 199;
734
	
735
	public static int AREA_UNITED_KINGDOM = 203;
736
	public static int AREA_DENMARK_COUNTRY = 204;
737
	public static int AREA_TURKEY_COUNTRY = 205;
738
	public static int AREA_SPAIN_COUNTRY = 206;
739
	public static int AREA_GREECE_COUNTRY = 207;
740
	public static int AREA_PORTUGAL_COUNTRY = 208;
741

    
742
	// OccurrenceStatus
743
	public static int STATUS_PRESENT = 1;
744
	public static int STATUS_ABSENT = 2;
745
	public static int STATUS_NATIVE = 3;
746
	public static int STATUS_INTRODUCED = 4;
747
	public static int STATUS_NATURALISED = 5;
748
	public static int STATUS_INVASIVE = 6;
749
	public static int STATUS_MANAGED = 7;
750
	public static int STATUS_DOUBTFUL = 8;
751

    
752
	private Map<String, Integer> tdwgKeyMap = new HashMap<String, Integer>();
753
	private Map<Integer, String> areaCacheMap = new HashMap<Integer, String>();
754
	private Map<Integer, String> languageCacheMap  = new HashMap<Integer, String>();
755
	private Map<Integer, String> featureCacheMap  = new HashMap<Integer, String>();
756
	private Map<Integer, String> nameStatusCacheMap  = new HashMap<Integer, String>();
757
	private Map<Integer, String> qualityStatusCacheMap  = new HashMap<Integer, String>();
758
	private Map<Integer, String> taxonStatusCacheMap  = new HashMap<Integer, String>();
759
	private Map<Integer, String> taxRelQualifierCacheMap  = new HashMap<Integer, String>();
760
	private Map<Integer, String> taxRelZooQualifierCacheMap  = new HashMap<Integer, String>();
761
	private Map<Integer, String> sourceUseCacheMap  = new HashMap<Integer, String>();
762
	private Map<Integer, String> fossilStatusCacheMap  = new HashMap<Integer, String>();
763
	private Map<Integer, String> typeDesigStatusCacheMap  = new HashMap<Integer, String>();
764
	private Map<Integer, String> sourceCategoryCacheMap  = new HashMap<Integer, String>();
765
	private Map<Integer, String> occurrenceStatusCacheMap  = new HashMap<Integer, String>();
766
	private Map<Integer, Map<Integer, String>> rankCacheMap  = new  HashMap<Integer, Map<Integer, String>>();
767
	private Map<Integer, Map<Integer, String>> rankAbbrevCacheMap  = new  HashMap<Integer, Map<Integer, String>>();
768
	
769
	
770
	private Source destination;
771
	
772
	public PesiTransformer(Source destination) {
773
		super();
774
		this.destination = destination;
775
		fillMaps();
776
	}
777

    
778
	private void fillMaps() {
779
		//TDWG
780
		try {
781
			String sql = " SELECT AreaId, AreaName, AreaTdwgCode, AreaEmCode, AreaFaEuCode FROM Area";
782
			ResultSet rs = destination.getResultSet(sql);
783
			while (rs.next()){
784
				String tdwg = rs.getString("AreaTdwgCode");
785
				Integer id = rs.getInt("AreaId");
786
				String label = rs.getString("AreaName");
787
				
788
				if (StringUtils.isNotBlank(tdwg)){
789
					this.tdwgKeyMap.put(tdwg, id);
790
				}
791
				this.areaCacheMap.put(id, label);
792
			}
793
			
794
			//rankCache
795
			sql = " SELECT KingdomId, RankId, Rank, RankAbbrev  FROM Rank";
796
			rs = destination.getResultSet(sql);
797
			while (rs.next()){
798
				String rank = rs.getString("Rank");
799
				String abbrev = rs.getString("RankAbbrev");
800
				Integer rankId = rs.getInt("RankId");
801
				Integer kingdomId = rs.getInt("KingdomId");
802
				
803
				//rank str
804
				Map<Integer, String> kingdomMap = rankCacheMap.get(kingdomId);
805
				if (kingdomMap == null){
806
					kingdomMap = new HashMap<Integer, String>();
807
					rankCacheMap.put(kingdomId, kingdomMap);
808
				}
809
				kingdomMap.put(rankId, rank);
810
				
811
				//rank abbrev
812
				Map<Integer, String> kingdomAbbrevMap = rankAbbrevCacheMap.get(kingdomId);
813
				if (kingdomAbbrevMap == null){
814
					kingdomAbbrevMap = new HashMap<Integer, String>();
815
					rankAbbrevCacheMap.put(kingdomId, kingdomAbbrevMap);
816
				}
817
				if (StringUtils.isNotBlank(abbrev)){
818
					kingdomAbbrevMap.put(rankId, abbrev);
819
				}
820
				
821
			}
822
			
823
			//languageCache
824
			fillSingleMap(languageCacheMap,"Language");
825

    
826
			//feature / note category
827
			fillSingleMap(featureCacheMap,"NoteCategory");
828
			
829
			//nameStatusCache
830
			fillSingleMap(nameStatusCacheMap,"NameStatus", "NomStatus");
831

    
832
			//qualityStatusCache
833
			fillSingleMap(qualityStatusCacheMap,"QualityStatus");
834

    
835
			//taxonStatusCache
836
			fillSingleMap(taxonStatusCacheMap,"TaxonStatus", "Status");
837
			
838
			//sourceUse
839
			fillSingleMap(sourceUseCacheMap,"SourceUse");
840

    
841
			//fossil status
842
			fillSingleMap(fossilStatusCacheMap,"FossilStatus");
843
			
844
			//fossil status
845
			fillSingleMap(typeDesigStatusCacheMap,"FossilStatus");
846

    
847
			//fossil status
848
			fillSingleMap(occurrenceStatusCacheMap,"OccurrenceStatus");
849
			
850
			//source category
851
			fillSingleMap(sourceCategoryCacheMap,"SourceCategory", "Category", "SourceCategoryId");
852
			
853
			//RelTaxonQualifier
854
			sql = " SELECT QualifierId, Qualifier, ZoologQualifier FROM RelTaxonQualifier ";
855
			rs = destination.getResultSet(sql);
856
			while (rs.next()){
857
				Integer key = rs.getInt("QualifierId");
858
				String cache = rs.getString("Qualifier");
859
				if (StringUtils.isNotBlank(cache)){
860
					this.taxRelQualifierCacheMap.put(key, cache);
861
				}
862
				String zoologCache = rs.getString("ZoologQualifier");
863
				if (StringUtils.isNotBlank(zoologCache)){
864
					this.taxRelZooQualifierCacheMap.put(key, zoologCache);
865
				}
866
			}
867
					
868
		} catch (SQLException e) {
869
			logger.error("SQLException when trying to read area map", e);
870
			e.printStackTrace();
871
		}
872
		
873
	}
874

    
875
	private void fillSingleMap(Map<Integer, String> map, String tableName) throws SQLException {
876
		fillSingleMap(map, tableName, tableName,  tableName + "Id");
877
	}
878
	
879
	private void fillSingleMap(Map<Integer, String> map, String tableName, String attr) throws SQLException {
880
			fillSingleMap(map, tableName, attr,  attr + "Id");
881
	}
882
	
883
	private void fillSingleMap(Map<Integer, String> map, String tableName, String attr, String idAttr) throws SQLException {
884
		String sql;
885
		ResultSet rs;
886
		sql = " SELECT %s, %s FROM %s ";
887
		sql = String.format(sql, idAttr, attr, tableName);
888
		rs = destination.getResultSet(sql);
889
		while (rs.next()){
890
			Integer key = rs.getInt(idAttr);
891
			String cache = rs.getString(attr);
892
			if (StringUtils.isNotBlank(cache)){
893
				map.put(key, cache);
894
			} 
895
		}
896
	}
897

    
898
	/**
899
	 * Converts the databaseString to its abbreviation if its known.
900
	 * Otherwise the databaseString is returned.
901
	 * @param databaseString
902
	 * @return
903
	 */
904
	public static String databaseString2Abbreviation(String databaseString) {
905
		String result = databaseString;
906
		if (databaseString.equals("Fauna Europaea database")) {
907
			result = "FaEu";
908
		}
909
		return result;
910
	}
911

    
912
	
913
	/**
914
	 * Returns the OccurrenceStatusId for a given PresenceAbsenceTerm.
915
	 * @param term
916
	 * @return
917
	 * @throws UnknownCdmTypeException 
918
	 */
919
	public static Integer presenceAbsenceTerm2OccurrenceStatusId(PresenceAbsenceTermBase<?> term) {
920
		Integer result = null;
921
		if (term == null){
922
			return null;
923
		//present
924
		}else if (term.isInstanceOf(PresenceTerm.class)) {
925
			PresenceTerm presenceTerm = CdmBase.deproxy(term, PresenceTerm.class);
926
			if (presenceTerm.equals(PresenceTerm.PRESENT()) || 
927
					presenceTerm.equals(PresenceTerm.INTRODUCED_DOUBTFULLY_INTRODUCED()) || 
928
					presenceTerm.equals(PresenceTerm.NATIVE_DOUBTFULLY_NATIVE())) {
929
				result = STATUS_PRESENT;
930
			} else if (presenceTerm.equals(PresenceTerm.NATIVE())) {
931
				result = STATUS_NATIVE;
932
			} else if (presenceTerm.equals(PresenceTerm.INTRODUCED()) || 
933
					presenceTerm.equals(PresenceTerm.INTRODUCED_ADVENTITIOUS()) ||
934
					presenceTerm.equals(PresenceTerm.INTRODUCED_UNCERTAIN_DEGREE_OF_NATURALISATION())) {
935
				result = STATUS_INTRODUCED;
936
			} else if (presenceTerm.equals(PresenceTerm.NATURALISED()) 
937
					|| presenceTerm.equals(PresenceTerm.INTRODUCED_NATURALIZED())) {
938
				result = STATUS_NATURALISED;
939
			} else if (presenceTerm.equals(PresenceTerm.INVASIVE())) {
940
				result = STATUS_INVASIVE;
941
			} else if (presenceTerm.equals(PresenceTerm.CULTIVATED())) {
942
				result = STATUS_MANAGED;
943
			} else if (presenceTerm.equals(PresenceTerm.PRESENT_DOUBTFULLY())||
944
					presenceTerm.equals(PresenceTerm.INTRODUCED_PRESENCE_QUESTIONABLE()) ||
945
					presenceTerm.equals(PresenceTerm.NATIVE_PRESENCE_QUESTIONABLE() )) {
946
				result = STATUS_DOUBTFUL;
947
			} else {
948
				logger.error("PresenceTerm could not be translated to datawarehouse occurrence status id: " + presenceTerm.getLabel());
949
			}
950
		//absent	
951
		} else if (term.isInstanceOf(AbsenceTerm.class)) {
952
			AbsenceTerm absenceTerm = CdmBase.deproxy(term, AbsenceTerm.class);
953
			if (absenceTerm.equals(AbsenceTerm.ABSENT()) || absenceTerm.equals(AbsenceTerm.NATIVE_FORMERLY_NATIVE()) ||
954
					absenceTerm.equals(AbsenceTerm.CULTIVATED_REPORTED_IN_ERROR()) || absenceTerm.equals(AbsenceTerm.INTRODUCED_REPORTED_IN_ERROR()) ||
955
					absenceTerm.equals(AbsenceTerm.INTRODUCED_FORMERLY_INTRODUCED()) || absenceTerm.equals(AbsenceTerm.NATIVE_REPORTED_IN_ERROR() ) ) {
956
				result = STATUS_ABSENT;
957
			} else {
958
				logger.error("AbsenceTerm could not be translated to datawarehouse occurrence status id: " + absenceTerm.getLabel());
959
			}
960
		}
961
		return result;
962
	}
963
	
964

    
965
	@Override
966
	public String getCacheByPresenceAbsenceTerm(PresenceAbsenceTermBase status) throws UndefinedTransformerMethodException {
967
		if (status == null){
968
			return null;
969
		}else{
970
			return this.occurrenceStatusCacheMap.get(getKeyByPresenceAbsenceTerm(status)); 
971
		}
972
	}
973
	
974
	@Override
975
	public Object getKeyByPresenceAbsenceTerm(PresenceAbsenceTermBase status) throws UndefinedTransformerMethodException {
976
		return presenceAbsenceTerm2OccurrenceStatusId(status);
977
	}
978
	
979
	
980
	
981
	@Override
982
	public String getCacheByNamedArea(NamedArea namedArea) throws UndefinedTransformerMethodException {
983
		NamedArea area = CdmBase.deproxy(namedArea, NamedArea.class);
984
		if (area == null){
985
			return null;
986
		}else{
987
			return this.areaCacheMap.get(getKeyByNamedArea(area)); 
988
		}
989
	}
990
	
991
	
992
	@Override
993
	public Object getKeyByNamedArea(NamedArea area) throws UndefinedTransformerMethodException {
994
		NamedArea namedArea = CdmBase.deproxy(area, NamedArea.class);
995

    
996
		if (area == null) {
997
			return null;
998
		//TDWG areas
999
		} else if (area.isInstanceOf(TdwgArea.class)) {
1000
			String abbrevLabel = namedArea.getRepresentation(Language.DEFAULT()).getAbbreviatedLabel();
1001
			Integer result = this.tdwgKeyMap.get(abbrevLabel);
1002
			if (result == null){
1003
				logger.warn("Unknown TDWGArea: " + area.getTitleCache());
1004
			}
1005
			return result;
1006
		//countries & Waterbodies
1007
		}else if (namedArea.isInstanceOf(WaterbodyOrCountry.class)){
1008
			if (namedArea.equals(WaterbodyOrCountry.UKRAINE())) { return AREA_UKRAINE_INCLUDING_CRIMEA; }
1009
			else if (namedArea.equals(WaterbodyOrCountry.AZERBAIJANREPUBLICOF())) { return AREA_AZERBAIJAN_INCLUDING_NAKHICHEVAN; }
1010
			else if (namedArea.equals(WaterbodyOrCountry.GEORGIA())) { return AREA_GEORGIA; }
1011
			else if (namedArea.equals(WaterbodyOrCountry.RUSSIANFEDERATION())) { return AREA_THE_RUSSIAN_FEDERATION; }
1012
			else if (namedArea.equals(WaterbodyOrCountry.UNITEDKINGDOMOFGREATBRITAINANDNORTHERNIRELAND())) { return AREA_UNITED_KINGDOM; }
1013
			else if (namedArea.equals(WaterbodyOrCountry.DENMARKKINGDOMOF())) { return AREA_DENMARK_COUNTRY; }
1014
			else if (namedArea.equals(WaterbodyOrCountry.TURKEYREPUBLICOF())) { return AREA_TURKEY_COUNTRY; }
1015
			else {
1016
				logger.warn("Unknown Waterbody/Country: " + area.getTitleCache());
1017
			}
1018
		}else{  //Non TDWG, non country
1019
			//EM
1020
			if ( namedArea.getUuid().equals(BerlinModelTransformer.uuidMadeira)){ return AREA_MADEIRA; }
1021
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidDesertas)) { return AREA_DESERTAS; }
1022
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidPortoSanto)) { return AREA_PORTO_SANTO; }
1023
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidFlores)) { return AREA_FLORES; }
1024
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidCorvo)) { return AREA_CORVO; }
1025
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidFaial)) { return AREA_FAIAL; }
1026
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidGraciosa)) { return AREA_GRACIOSA; }
1027
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidSaoJorge)) { return AREA_SAO_JORGE; }
1028
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidSaoMiguel)) { return AREA_SAO_MIGUEL; }
1029
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidPico)) { return AREA_PICO; }
1030
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidSantaMaria)) { return AREA_SANTA_MARIA; }
1031
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidTerceira)) { return AREA_TERCEIRA; }
1032
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidGranCanaria)) { return AREA_GRAN_CANARIA; }
1033
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidFuerteventura)) { return AREA_FUERTEVENTURA_WITH_LOBOS; }
1034
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidGomera)) { return AREA_GOMERA; }
1035
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidHierro)) { return AREA_HIERRO; }
1036
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidLanzaroteWithGraciosa)) { return AREA_LANZAROTE_WITH_GRACIOSA; }
1037
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidLaPalma)) { return AREA_LA_PALMA; }
1038
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidTenerife)) { return AREA_TENERIFE; }
1039
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidIbizaWithFormentera)) { return AREA_IBIZA_WITH_FORMENTERA; }
1040
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidMallorca)) { return AREA_MALLORCA; }
1041
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidMenorca)) { return AREA_MENORCA; }
1042
			
1043
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidUssr)) { return AREA_FORMER_USSR; }
1044
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidRussiaBaltic)) { return AREA_RUSSIA_BALTIC; }
1045
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidRussiaSouthEast)) { return AREA_RUSSIA_SOUTHEAST; }
1046
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidRussiaSouthWest)) { return AREA_RUSSIA_SOUTHWEST; }
1047
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidRussiaCentral)) { return AREA_RUSSIA_CENTRAL; }
1048
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidRussiaNorthern)) { return AREA_RUSSIA_NORTHERN; }
1049
			
1050
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidTurkey)) { return AREA_TURKEY; }
1051
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidEastAegeanIslands)) { return AREA_EAST_AEGEAN_ISLANDS; }
1052
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidTurkishEastAegeanIslands)) { return AREA_TURKISH_EAST_AEGEAN_ISLANDS; }
1053
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidSerbiaMontenegro)) { return AREA_SERBIA_WITH_MONTENEGRO; }
1054
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidSerbia)) { return AREA_SERBIA_INCLUDING_VOJVODINA_AND_WITH_KOSOVO; }
1055
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidCaucasia)) { return AREA_CAUCASUS_REGION; }
1056
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidUkraineAndCrimea)) { return AREA_UKRAINE_INCLUDING_CRIMEA; }
1057
			else if (namedArea.getUuid().equals(BerlinModelTransformer.uuidAzerbaijanNakhichevan)) { return AREA_AZERBAIJAN_INCLUDING_NAKHICHEVAN; }
1058
			
1059
			//FE
1060
			else if (namedArea.getUuid().equals(FaunaEuropaeaTransformer.uuidAreaAFR)) { return AREA_AFRO_TROPICAL_REGION; }
1061
			else if (namedArea.getUuid().equals(FaunaEuropaeaTransformer.uuidAreaAUS)) { return AREA_AUSTRALIAN_REGION; }
1062
			else if (namedArea.getUuid().equals(FaunaEuropaeaTransformer.uuidAreaEPA)) { return AREA_EAST_PALAEARCTIC; }
1063
			else if (namedArea.getUuid().equals(FaunaEuropaeaTransformer.uuidAreaGR_AEG)) { return AREA_NORTH_AEGEAN_ISLANDS; }
1064
			else if (namedArea.getUuid().equals(FaunaEuropaeaTransformer.uuidAreaGR_CYC)) { return AREA_CYCLADES_ISLANDS; }
1065
			else if (namedArea.getUuid().equals(FaunaEuropaeaTransformer.uuidAreaGR_DOD)) { return AREA_DODECANESE_ISLANDS; }
1066
			else if (namedArea.getUuid().equals(FaunaEuropaeaTransformer.uuidAreaGR_CR)) { return AREA_CRETE; }
1067
			else if (namedArea.getUuid().equals(FaunaEuropaeaTransformer.uuidAreaGR_GRC)) { return AREA_GREEK_MAINLAND; }
1068
			else if (namedArea.getUuid().equals(FaunaEuropaeaTransformer.uuidAreaNAF)) { return AREA_NORTHERN_AFRICA; }
1069
			else if (namedArea.getUuid().equals(FaunaEuropaeaTransformer.uuidAreaNEA)) { return AREA_NEARCTIC_REGION; }
1070
			else if (namedArea.getUuid().equals(FaunaEuropaeaTransformer.uuidAreaNEO)) { return AREA_NEOTROPICAL_REGION; }
1071
			else if (namedArea.getUuid().equals(FaunaEuropaeaTransformer.uuidAreaNRE)) { return AREA_NEAR_EAST; }
1072
			else if (namedArea.getUuid().equals(FaunaEuropaeaTransformer.uuidAreaORR)) { return AREA_ORIENTAL_REGION; }
1073
			else if (namedArea.getUuid().equals(FaunaEuropaeaTransformer.uuidAreaUA)) { return AREA_UKRAINE_INCLUDING_CRIMEA; }
1074
			else if (namedArea.getUuid().equals(FaunaEuropaeaTransformer.uuidAreaRU_FJL)) { return AREA_FRANZ_JOSEF_LAND; }
1075
			else if (namedArea.getUuid().equals(FaunaEuropaeaTransformer.uuidAreaRU_NOZ)) { return AREA_NOVAYA_ZEMLYA; }
1076
			
1077

    
1078
			//ERMS
1079
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidEuropeanMarineWaters)) { return AREA_EUROPEAN_MARINE_WATERS; }
1080
			else if ((namedArea.getRepresentation(Language.DEFAULT()).getAbbreviatedLabel()).equals("MES") ||
1081
					(namedArea.getUuid().equals(ErmsTransformer.uuidMediterraneanSea))) { return AREA_MEDITERRANEAN_SEA; } // abbreviated label missing
1082
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidWhiteSea)) { return AREA_WHITE_SEA; }
1083
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidNorthSea)) { return AREA_NORTH_SEA; }
1084
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidBalticSea)) { return AREA_BALTIC_SEA; }
1085
			else if ((namedArea.getRepresentation(Language.DEFAULT()).getAbbreviatedLabel()).equals("BLS") ||
1086
					(namedArea.getUuid().equals(ErmsTransformer.uuidBlackSea))) { return AREA_BLACK_SEA; } // abbreviated label missing
1087
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidBarentsSea)) { return AREA_BARENTS_SEA; }
1088
			else if ((namedArea.getRepresentation(Language.DEFAULT()).getAbbreviatedLabel()).equals("CAS") ||
1089
					(namedArea.getUuid().equals(ErmsTransformer.uuidCaspianSea))) { return AREA_CASPIAN_SEA; } // abbreviated label missingelse if (namedArea.getUuid().equals(ErmsTransformer.uuidPortugueseExclusiveEconomicZone)) { return AREA_PORTUGUESE_EXCLUSIVE_ECONOMIC_ZONE; }
1090
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidBelgianExclusiveEconomicZone)) { return AREA_BELGIAN_EXCLUSIVE_ECONOMIC_ZONE; }
1091
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidFrenchExclusiveEconomicZone)) { return AREA_FRENCH_EXCLUSIVE_ECONOMIC_ZONE; }
1092
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidEnglishChannel)) { return AREA_ENGLISH_CHANNEL; }
1093
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidAdriaticSea)) { return AREA_ADRIATIC_SEA; }
1094
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidBiscayBay)) { return AREA_BISCAY_BAY; }
1095
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidDutchExclusiveEconomicZone)) { return AREA_DUTCH_EXCLUSIVE_ECONOMIC_ZONE; }
1096
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidUnitedKingdomExclusiveEconomicZone)) { return AREA_UNITED_KINGDOM_EXCLUSIVE_ECONOMIC_ZONE; }
1097
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidSpanishExclusiveEconomicZone)) { return AREA_SPANISH_EXCLUSIVE_ECONOMIC_ZONE; }
1098
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidEgyptianExclusiveEconomicZone)) { return AREA_EGYPTIAN_EXCLUSIVE_ECONOMIC_ZONE; }
1099
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidGrecianExclusiveEconomicZone)) { return AREA_GRECIAN_EXCLUSIVE_ECONOMIC_ZONE; }
1100
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidTirrenoSea)) { return AREA_TIRRENO_SEA; }
1101
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidIcelandicExclusiveEconomicZone)) { return AREA_ICELANDIC_EXCLUSIVE_ECONOMIC_ZONE; }
1102
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidIrishExclusiveeconomicZone)) { return AREA_IRISH_EXCLUSIVE_ECONOMIC_ZONE; }
1103
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidIrishSea)) { return AREA_IRISH_SEA; }
1104
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidItalianExclusiveEconomicZone)) { return AREA_ITALIAN_EXCLUSIVE_ECONOMIC_ZONE; }
1105
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidNorwegianSea)) { return AREA_NORWEGIAN_SEA; }
1106
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidMoroccanExclusiveEconomicZone)) { return AREA_MOROCCAN_EXCLUSIVE_ECONOMIC_ZONE; }
1107
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidNorwegianExclusiveEconomicZone)) { return AREA_NORWEGIAN_EXCLUSIVE_ECONOMIC_ZONE; }
1108
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidSkagerrak)) { return AREA_SKAGERRAK; }
1109
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidTunisianExclusiveEconomicZone)) { return AREA_TUNISIAN_EXCLUSIVE_ECONOMIC_ZONE; }
1110
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidWaddenSea)) { return AREA_WADDEN_SEA; }
1111
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidBeltSea)) { return AREA_BELT_SEA; }
1112
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidMarmaraSea)) { return AREA_MARMARA_SEA; }
1113
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidSeaofAzov)) { return AREA_SEA_OF_AZOV; }
1114
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidAegeanSea)) { return AREA_AEGEAN_SEA; }
1115
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidBulgarianExclusiveEconomicZone)) { return AREA_BULGARIAN_EXCLUSIVE_ECONOMIC_ZONE; }
1116
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidSouthBalticproper)) { return AREA_SOUTH_BALTIC_PROPER; }
1117
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidBalticProper)) { return AREA_BALTIC_PROPER; }
1118
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidNorthBalticproper)) { return AREA_NORTH_BALTIC_PROPER; }
1119
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidArchipelagoSea)) { return AREA_ARCHIPELAGO_SEA; }
1120
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidBothnianSea)) { return AREA_BOTHNIAN_SEA; }
1121
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidGermanExclusiveEconomicZone)) { return AREA_GERMAN_EXCLUSIVE_ECONOMIC_ZONE; }
1122
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidSwedishExclusiveEconomicZone)) { return AREA_SWEDISH_EXCLUSIVE_ECONOMIC_ZONE; }
1123
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidUkrainianExclusiveEconomicZone)) { return AREA_UKRAINIAN_EXCLUSIVE_ECONOMIC_ZONE; }
1124
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidMadeiranExclusiveEconomicZone)) { return AREA_MADEIRAN_EXCLUSIVE_ECONOMIC_ZONE; }
1125
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidLebaneseExclusiveEconomicZone)) { return AREA_LEBANESE_EXCLUSIVE_ECONOMIC_ZONE; }
1126
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidSpanishExclusiveEconomicZoneMediterraneanpart)) { return AREA_SPANISH_EXCLUSIVE_ECONOMIC_ZONE_MEDITERRANEAN_PART; }
1127
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidEstonianExclusiveEconomicZone)) { return AREA_ESTONIAN_EXCLUSIVE_ECONOMIC_ZONE; }
1128
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidCroatianExclusiveEconomicZone)) { return AREA_CROATIAN_EXCLUSIVE_ECONOMIC_ZONE; }
1129
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidBalearSea)) { return AREA_BALEAR_SEA; }
1130
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidTurkishExclusiveEconomicZone)) { return AREA_TURKISH_EXCLUSIVE_ECONOMIC_ZONE; }
1131
			else if (namedArea.getUuid().equals(ErmsTransformer.uuidDanishExclusiveEconomicZone)) { return AREA_DANISH_EXCLUSIVE_ECONOMIC_ZONE; }
1132

    
1133
			
1134
			else {
1135
				logger.warn("Unknown NamedArea Area: " + area.getTitleCache());
1136
			}
1137

    
1138
		}
1139
		return null;
1140
	}
1141
	
1142

    
1143
	/**
1144
	 * Returns the PESI SourceUseId for a given CDM sourceUseId.
1145
	 * @param sourceUseId
1146
	 * @return
1147
	 */
1148
	public static Integer sourceUseIdSourceUseId(Integer sourceUseId) {
1149
		// TODO: CDM sourceUseId and PESI sourceUseId are equal for now.
1150
		Integer result = null;
1151
		switch (sourceUseId) {
1152
			case 3: return ADDITIONAL_SOURCE;
1153
			case 4: return SOURCE_OF_SYNONYMY;
1154
			case 8: return NOMENCLATURAL_REFERENCE;
1155
		}
1156
		return result;
1157
	}
1158

    
1159
	
1160
	/**
1161
	 * Returns the FossilStatusCache to a given Fossil.
1162
	 * @param fossil
1163
	 * @return
1164
	 */
1165
	public static String fossil2FossilStatusCache(Fossil fossil) {
1166
		String result = null;
1167
		return result;
1168
	}
1169

    
1170
	/**
1171
	 * Returns the FossilStatusId to a given Fossil.
1172
	 * @param fossil
1173
	 * @return
1174
	 */
1175
	public static Integer fossil2FossilStatusId(Fossil fossil) {
1176
		Integer result = null;
1177
		return result;
1178
	}
1179
	
1180
	
1181
	
1182
	@Override
1183
	public Object getKeyByLanguage(Language language) throws UndefinedTransformerMethodException {
1184
		return language2LanguageId(language);
1185
	}
1186

    
1187
	@Override
1188
	public String getCacheByLanguage(Language language) throws UndefinedTransformerMethodException {
1189
		if (language == null){
1190
			return null;
1191
		}else{
1192
			return this.languageCacheMap.get(getKeyByLanguage(language)); 
1193
		}
1194
	}
1195

    
1196
	
1197
	/**
1198
	 * Returns the identifier of the given Language.
1199
	 * @param language
1200
	 * @return
1201
	 */
1202
	public static Integer language2LanguageId(Language language) {
1203
		if (language == null ) {
1204
			return null;
1205
		}
1206
		if (language.equals(Language.ALBANIAN())) {
1207
			return Language_Albanian;
1208
		} else if (language.equals(Language.ARABIC())) {
1209
			return Language_Arabic;
1210
		} else if (language.equals(Language.ARMENIAN())) {
1211
			return Language_Armenian;
1212
		} else if (language.equals(Language.AZERBAIJANI())) {
1213
			return Language_Azerbaijan;
1214
		} else if (language.equals(Language.BELORUSSIAN())) {
1215
			return Language_Belarusian;
1216
		} else if (language.equals(Language.BULGARIAN())) {
1217
			return Language_Bulgarian;
1218
		} else if (language.equals(Language.CATALAN_VALENCIAN())) {
1219
			return Language_Catalan;
1220
		} else if (language.equals(Language.CROATIAN())) {
1221
			return Language_Croat;
1222
		} else if (language.equals(Language.CZECH())) {
1223
			return Language_Czech;
1224
		} else if (language.equals(Language.DANISH())) {
1225
			return Language_Danish;
1226
		} else if (language.equals(Language.DUTCH_MIDDLE())) {
1227
			return Language_Dutch;
1228
		} else if (language.equals(Language.ENGLISH())) {
1229
			return Language_English;
1230
//		} else if (language.equals(Language.)) {
1231
//			return Language_Euskera;
1232
		} else if (language.equals(Language.ESTONIAN())) {
1233
			return Language_Estonian;
1234
		} else if (language.equals(Language.FINNISH())) {
1235
			return Language_Finnish;
1236
		} else if (language.equals(Language.FRENCH())) {
1237
			return Language_French;
1238
		} else if (language.equals(Language.GEORGIAN())) {
1239
			return Language_Georgian;
1240
		} else if (language.equals(Language.GERMAN())) {
1241
			return Language_German;
1242
		} else if (language.equals(Language.GREEK_MODERN())) {
1243
			return Language_Greek;
1244
		} else if (language.equals(Language.HUNGARIAN())) {
1245
			return Language_Hungarian;
1246
		} else if (language.equals(Language.ICELANDIC())) {
1247
			return Language_Icelandic;
1248
		} else if (language.equals(Language.IRISH())) {
1249
			return Language_Irish_Gaelic;
1250
		} else if (language.equals(Language.HEBREW())) {
1251
			return Language_Israel_Hebrew;
1252
		} else if (language.equals(Language.ITALIAN())) {
1253
			return Language_Italian;
1254
		} else if (language.equals(Language.LATVIAN())) {
1255
			return Language_Latvian;
1256
		} else if (language.equals(Language.LITHUANIAN())) {
1257
			return Language_Lithuanian;
1258
		} else if (language.equals(Language.MACEDONIAN())) {
1259
			return Language_Macedonian;
1260
		} else if (language.equals(Language.MALTESE())) {
1261
			return Language_Maltese;
1262
		} else if (language.equals(Language.MOLDAVIAN())) {
1263
			return Language_Moldovian;
1264
		} else if (language.equals(Language.NORWEGIAN())) {
1265
			return Language_Norwegian;
1266
		} else if (language.equals(Language.POLISH())) {
1267
			return Language_Polish;
1268
		} else if (language.equals(Language.PORTUGUESE())) {
1269
			return Language_Portuguese;
1270
		} else if (language.equals(Language.ROMANIAN())) {
1271
			return Language_Roumanian;
1272
		} else if (language.equals(Language.RUSSIAN())) {
1273
			return Language_Russian;
1274
//		} else if (language.equals(Language.)) {
1275
//			return Language_Russian_Caucasian;
1276
//		} else if (language.equals(Language.)) {
1277
//			return Language_Russian_Altaic_kalmyk_oirat;
1278
//		} else if (language.equals(Language.)) {
1279
//			return Language_Russian_Altaic_karachay_balkar;
1280
//		} else if (language.equals(Language.)) {
1281
//			return Language_Russian_Altaic_kumyk;
1282
//		} else if (language.equals(Language.)) {
1283
//			return Language_Russian_Altaic_nogai;
1284
//		} else if (language.equals(Language.)) {
1285
//			return Language_Russian_Altaic_north_azerbaijani;
1286
//		} else if (language.equals(Language.)) {
1287
//			return Language_Russian_Indo_european_russian;
1288
//		} else if (language.equals(Language.)) {
1289
//			return Language_Russian_Indo_european_kalmyk_oirat;
1290
//		} else if (language.equals(Language.)) {
1291
//			return Language_Russian_Indo_european_osetin;
1292
//		} else if (language.equals(Language.)) {
1293
//			return Language_Russian_North_caucasian_abaza;
1294
//		} else if (language.equals(Language.)) {
1295
//			return Language_Russian_North_caucasian_adyghe;
1296
//		} else if (language.equals(Language.)) {
1297
//			return Language_Russian_North_caucasian_chechen;
1298
//		} else if (language.equals(Language.)) {
1299
//			return Language_Russian_North_caucasian_kabardian;
1300
//		} else if (language.equals(Language.)) {
1301
//			return Language_Russian_North_caucasian_lak;
1302
//		} else if (language.equals(Language.)) {
1303
//			return Language_Russian_North_caucasian_avar;
1304
//		} else if (language.equals(Language.)) {
1305
//			return Language_Russian_North_caucasian_in;
1306
//		} else if (language.equals(Language.)) {
1307
//			return Language_Russian_Uralic_chuvash;
1308
//		} else if (language.equals(Language.)) {
1309
//			return Language_Russian_Uralic_udmurt;
1310
		} else if (language.equals(Language.SERBIAN())) {
1311
			return Language_Serbian;
1312
		} else if (language.equals(Language.SLOVAK())) {
1313
			return Language_Slovak;
1314
		} else if (language.equals(Language.SLOVENIAN())) {
1315
			return Language_Slovene;
1316
		} else if (language.equals(Language.SPANISH_CATALAN())) {
1317
			return Language_Spanish_Castillian;
1318
		} else if (language.equals(Language.SWEDISH())) {
1319
			return Language_Swedish;
1320
		} else if (language.equals(Language.TURKISH())) {
1321
			return Language_Turkish;
1322
		} else if (language.equals(Language.UKRAINIAN())) {
1323
			return Language_Ukraine;
1324
		} else if (language.equals(Language.WELSH())) {
1325
			return Language_Welsh;
1326
		} else if (language.equals(Language.CORSICAN())) {
1327
			return Language_Corsican;
1328
		} else {
1329
			logger.debug("Unknown Language: " + language.getTitleCache());
1330
			return null;
1331
		}
1332
	}
1333
	
1334
	/**
1335
	 * Returns the NodeCategoryCache for a given TextData.
1336
	 * @param feature
1337
	 * @return
1338
	 */
1339
	public String getCacheByFeature(Feature feature) {
1340
		if (feature == null){
1341
			return null;
1342
		}else{
1343
			return this.featureCacheMap.get(feature2NoteCategoryFk(feature)); 
1344
		}
1345
	}
1346

    
1347
	/**
1348
	 * Returns the NodeCategoryFk for a given TextData.
1349
	 * @param feature
1350
	 * @return
1351
	 */
1352
	public static Integer feature2NoteCategoryFk(Feature feature) {
1353
		if (feature == null) {
1354
			return null;
1355
		}
1356

    
1357
		if (feature.equals(Feature.DESCRIPTION())) {
1358
			return NoteCategory_description;
1359
		} else if (feature.equals(Feature.ECOLOGY())) {
1360
			return NoteCategory_ecology;
1361
		} else if (feature.equals(Feature.PHENOLOGY())) {
1362
			return NoteCategory_phenology;
1363
		} else if (feature.equals(Feature.COMMON_NAME())) {
1364
			return NoteCategory_Common_names;
1365
		} else if (feature.equals(Feature.OCCURRENCE())) {
1366
			return NoteCategory_Occurrence;
1367
		} else if (feature.equals(Feature.DISTRIBUTION())) {
1368
			return NoteCategory_Distribution;
1369
		} else if (feature.getUuid().equals(ErmsTransformer.uuidRemark)) {
1370
			return NoteCategory_Remark;
1371
		} else if (feature.getUuid().equals(ErmsTransformer.uuidAdditionalinformation)) {
1372
			return NoteCategory_Additional_information;
1373
		} else if (feature.getUuid().equals(ErmsTransformer.uuidSpelling)) {
1374
			return NoteCategory_Spelling;
1375
		} else if (feature.getUuid().equals(ErmsTransformer.uuidDateofPublication)) {
1376
			return NoteCategory_Date_of_publication;
1377
		} else if (feature.getUuid().equals(ErmsTransformer.uuidSystematics)) {
1378
			return NoteCategory_Systematics;
1379
		} else if (feature.getUuid().equals(ErmsTransformer.uuidClassification)) {
1380
			return NoteCategory_Classification;
1381
		} else if (feature.getUuid().equals(ErmsTransformer.uuidEnvironment)) {
1382
			return NoteCategory_Environment;
1383
		} else if (feature.getUuid().equals(ErmsTransformer.uuidHabitat)) {
1384
			return NoteCategory_Habitat;
1385
		} else if (feature.getUuid().equals(ErmsTransformer.uuidAuthority)) {
1386
			return NoteCategory_Authority;
1387
		} else if (feature.getUuid().equals(ErmsTransformer.uuidMorphology)) {
1388
			return NoteCategory_Morphology;
1389
		} else if (feature.getUuid().equals(ErmsTransformer.uuidTaxonomicRemarks)) {
1390
			return NoteCategory_Taxonomic_Remarks;
1391
		} else if (feature.getUuid().equals(ErmsTransformer.uuidNote)){
1392
			return NoteCategory_Note;
1393
		} else if (feature.getUuid().equals(ErmsTransformer.uuidTaxonomy)) {
1394
			return NoteCategory_Taxonomy;
1395
		} else if (feature.getUuid().equals(ErmsTransformer.uuidTaxonomicstatus)) {
1396
			return NoteCategory_Taxonomic_status;
1397
		} else if (feature.getUuid().equals(ErmsTransformer.uuidStatus)){
1398
			return NoteCategory_Status;
1399
		} else if (feature.getUuid().equals(ErmsTransformer.uuidRank)) {
1400
			return NoteCategory_Rank;
1401
		} else if (feature.getUuid().equals(ErmsTransformer.uuidHomonymy)) {
1402
			return NoteCategory_Homonymy;
1403
		} else if (feature.getUuid().equals(ErmsTransformer.uuidNomenclature)) {
1404
			return NoteCategory_Nomenclature;
1405
		} else if (feature.getUuid().equals(ErmsTransformer.uuidTaxonomicRemark)) {
1406
			return NoteCategory_Taxonomic_Remark;
1407
		} else if (feature.getUuid().equals(ErmsTransformer.uuidAcknowledgments)){
1408
			return NoteCategory_Acknowledgments;
1409
		} else if (feature.getUuid().equals(ErmsTransformer.uuidOriginalpublication)) {
1410
			return NoteCategory_Original_publication;
1411
		} else if (feature.getUuid().equals(ErmsTransformer.uuidTypelocality)) {
1412
			return NoteCategory_Type_locality;
1413
		} else if (feature.getUuid().equals(ErmsTransformer.uuidValidity)) {
1414
			return NoteCategory_Validity;
1415
		} else if (feature.getUuid().equals(ErmsTransformer.uuidIdentification)) {
1416
			return NoteCategory_Identification;
1417
		} else if (feature.getUuid().equals(ErmsTransformer.uuidSynonymy)) {
1418
			return NoteCategory_Synonymy;
1419
		} else if (feature.equals(Feature.CITATION())) {
1420
			return null;  //citations are handled differently
1421
		} else if (feature.getUuid().equals(BerlinModelTransformer.uuidFeatureMaps)){
1422
			return NoteCategory_Link_to_maps;
1423
		} else if (feature.getUuid().equals(BerlinModelTransformer.uuidFeatureUse)){
1424
			return NoteCategory_Use;
1425
		} else if (feature.getUuid().equals(BerlinModelTransformer.uuidFeatureComments)){
1426
			return NoteCategory_Comments;
1427
		} else if (feature.getUuid().equals(BerlinModelTransformer.uuidFeatureConservationStatus)){
1428
			return NoteCategory_Conservation_Status;
1429
		
1430
		//E+M
1431
		} else if (feature.getUuid().equals(BerlinModelTransformer.uuidFeatureDistrEM)){
1432
			return NoteCategory_general_distribution_euromed;
1433
		} else if (feature.getUuid().equals(BerlinModelTransformer.uuidFeatureDistrWorld)){
1434
			return NoteCategory_general_distribution_world;
1435
		} else if (feature.getUuid().equals(BerlinModelTransformer.uuidFeatureEditorBrackets)){
1436
			return NoteCategory_Editor_Brackets;
1437
		} else if (feature.getUuid().equals(BerlinModelTransformer.uuidFeatureEditorParenthesis)){
1438
			return NoteCategory_Editor_Parenthesis;
1439
		} else if (feature.getUuid().equals(BerlinModelTransformer.uuidFeatureInedited)){
1440
			return NoteCategory_Inedited;
1441
		} else if (feature.getUuid().equals(BerlinModelTransformer.uuidFeatureCommentsEditing)){
1442
			return NoteCategory_Comments_on_editing_process;
1443
			
1444
			
1445
			// TODO: Unknown NoteCategories
1446
//			NoteCategory_Common_names = 12;
1447
//			NoteCategory_Maps =14;
1448

    
1449
//			NoteCategory_Link_to_images = 21;
1450
//			NoteCategory_Link_to_taxonomy = 22;
1451
//			NoteCategory_Link_to_general_information = 23;
1452
//			NoteCategory_undefined_link = 24;
1453
//			NoteCategory_Editor_Braces = 249;
1454

    
1455
//			NoteCategory_Publication_date = 254;
1456
//			NoteCategory_Distribution = 278;
1457
//			NoteCategory_Biology = 281;
1458
//			NoteCategory_Diagnosis	= 282;
1459
//			NoteCategory_Host = 283;
1460

    
1461
		}else{
1462
			logger.warn("Unhandled Feature: " + feature.getTitleCache());
1463
			return null;
1464
		}
1465
	}
1466

    
1467
	/**
1468
	 * Returns the string representation for a given rank.
1469
	 * @param rank
1470
	 * @param pesiKingdomId
1471
	 * @return
1472
	 */
1473
	public String getCacheByRankAndKingdom(Rank rank, Integer pesiKingdomId) {
1474
		if (rank == null){
1475
			return null;
1476
		}else{
1477
			return this.rankCacheMap.get(pesiKingdomId).get(rank2RankId(rank, pesiKingdomId)); 
1478
		}
1479
	}
1480
	
1481
	/**
1482
	 * Returns the abbreviation for a given rank.
1483
	 * Currently unused.
1484
	 * @param rank
1485
	 * @param pesiKingdomId
1486
	 * @return
1487
	 */
1488
	public String getCacheAbbrevByRankAndKingdom(Rank rank, Integer pesiKingdomId) {
1489
		if (rank == null){
1490
			return null;
1491
		}else{
1492
			return this.rankAbbrevCacheMap.get(pesiKingdomId).get(rank2RankId(rank, pesiKingdomId)); 
1493
		}
1494
	}
1495

    
1496
	/**
1497
	 * Returns the identifier of a PESI specific kingdom for a given CDM nomenclatural code.
1498
	 * @param nomenclaturalCode
1499
	 * @return KINGDOM_ANIMALIA for NomenclaturalCode.ICZN, KINGDOM_PLANTAE for NomenclaturalCode.ICBN
1500
	 */
1501
	public static Integer nomenClaturalCode2Kingdom(NomenclaturalCode nomenclaturalCode) {
1502
		Integer result = null;
1503
		// TODO: This needs to be refined. For now we differentiate between Animalia and Plantae only.
1504
		if (nomenclaturalCode.equals(NomenclaturalCode.ICZN)) {
1505
			result = KINGDOM_ANIMALIA;
1506
		} else if (nomenclaturalCode.equals(NomenclaturalCode.ICBN)) {
1507
			result = KINGDOM_PLANTAE;
1508
		} else if (nomenclaturalCode.equals(NomenclaturalCode.ICNB)) {
1509
			result = KINGDOM_BACTERIA;
1510
//		} else if (nomenclaturalCode.equals(NomenclaturalCode.)) { // Biota
1511
//			result = 
1512
		} else {
1513
			logger.error("NomenclaturalCode not yet considered: " + nomenclaturalCode.getUuid() + " (" +  nomenclaturalCode.getTitleCache() + ")");
1514
		}
1515
		return result;
1516
	}
1517
	
1518
	/**
1519
	 * Returns the RankId for a Rank.
1520
	 * @param rank
1521
	 * @return
1522
	 */
1523
	public static Integer rank2RankId (Rank rank, Integer pesiKingdomId) {
1524
		Integer result = null;
1525
		if (rank == null) {
1526
			return null;
1527
		}
1528
		
1529
		// We differentiate between Animalia and Plantae only for now.
1530
		if (pesiKingdomId != null && pesiKingdomId.intValue() == KINGDOM_ANIMALIA) {
1531
			if (rank.equals(Rank.KINGDOM())) {
1532
				result = Animalia_Kingdom;
1533
			} else if (rank.equals(Rank.SUBKINGDOM())) {
1534
				result = Animalia_Subkingdom;
1535
			} else if (rank.equals(Rank.SUPERPHYLUM())) {
1536
				result = Animalia_Superphylum;
1537
			} else if (rank.equals(Rank.PHYLUM())) {
1538
				result = Animalia_Phylum;
1539
			} else if (rank.equals(Rank.SUBPHYLUM())) {
1540
				result = Animalia_Subphylum;
1541
			} else if (rank.equals(Rank.INFRAPHYLUM())) {
1542
				result = Animalia_Infraphylum;
1543
			} else if (rank.equals(Rank.SUPERCLASS())) {
1544
				result = Animalia_Superclass;
1545
			} else if (rank.equals(Rank.CLASS())) {
1546
				result = Animalia_Class;
1547
			} else if (rank.equals(Rank.SUBCLASS())) {
1548
				result = Animalia_Subclass;
1549
			} else if (rank.equals(Rank.INFRACLASS())) {
1550
				result = Animalia_Infraclass;
1551
			} else if (rank.equals(Rank.SUPERORDER())) {
1552
				result = Animalia_Superorder;
1553
			} else if (rank.equals(Rank.ORDER())) {
1554
				result = Animalia_Order;
1555
			} else if (rank.equals(Rank.SUBORDER())) {
1556
				result = Animalia_Suborder;
1557
			} else if (rank.equals(Rank.INFRAORDER())) {
1558
				result = Animalia_Infraorder;
1559
			} else if (rank.equals(Rank.SECTION_ZOOLOGY())) {
1560
				result = Animalia_Section;
1561
			} else if (rank.equals(Rank.SUBSECTION_ZOOLOGY())) {
1562
				result = Animalia_Subsection;
1563
			} else if (rank.equals(Rank.SUPERFAMILY())) {
1564
				result = Animalia_Superfamily;
1565
			} else if (rank.equals(Rank.FAMILY())) {
1566
				result = Animalia_Family;
1567
			} else if (rank.equals(Rank.SUBFAMILY())) {
1568
				result = Animalia_Subfamily;
1569
			} else if (rank.equals(Rank.TRIBE())) {
1570
				result = Animalia_Tribe;
1571
			} else if (rank.equals(Rank.SUBTRIBE())) {
1572
				result = Animalia_Subtribe;
1573
			} else if (rank.equals(Rank.GENUS())) {
1574
				result = Animalia_Genus;
1575
			} else if (rank.equals(Rank.SUBGENUS())) {
1576
				result = Animalia_Subgenus;
1577
			} else if (rank.equals(Rank.SPECIES())) {
1578
				result = Animalia_Species;
1579
			} else if (rank.equals(Rank.SUBSPECIES())) {
1580
				result = Animalia_Subspecies;
1581
//			} else if (rank.equals(Rank.)) { // not yet specified
1582
//				result = Animalia_Natio;
1583
			} else if (rank.equals(Rank.VARIETY())) {
1584
				result = Animalia_Variety;
1585
			} else if (rank.equals(Rank.SUBVARIETY())) {
1586
				result = Animalia_Subvariety;
1587
			} else if (rank.equals(Rank.FORM())) {
1588
				result = Animalia_Forma;
1589
			} else {
1590
				//TODO Exception
1591
				logger.warn("Rank for Kingdom Animalia not yet supported in CDM: "+ rank.getLabel());
1592
				return null;
1593
			}
1594
		} else if (pesiKingdomId != null && pesiKingdomId.intValue() == KINGDOM_PLANTAE) {
1595
			if (rank.equals(Rank.KINGDOM())) {
1596
				result = Plantae_Kingdom;
1597
			} else if (rank.equals(Rank.SUBKINGDOM())) {
1598
				result = Plantae_Subkingdom;
1599
			} else if (rank.equals(Rank.DIVISION())) {
1600
				result = Plantae_Division;
1601
			} else if (rank.equals(Rank.SUBDIVISION())) {
1602
				result = Plantae_Subdivision;
1603
			} else if (rank.equals(Rank.CLASS())) {
1604
				result = Plantae_Class;
1605
			} else if (rank.equals(Rank.SUBCLASS())) {
1606
				result = Plantae_Subclass;
1607
			} else if (rank.equals(Rank.ORDER())) {
1608
				result = Plantae_Order;
1609
			} else if (rank.equals(Rank.SUBORDER())) {
1610
				result = Plantae_Suborder;
1611
			} else if (rank.equals(Rank.FAMILY())) {
1612
				result = Plantae_Family;
1613
			} else if (rank.equals(Rank.SUBFAMILY())) {
1614
				result = Plantae_Subfamily;
1615
			} else if (rank.equals(Rank.TRIBE())) {
1616
				result = Plantae_Tribe;
1617
			} else if (rank.equals(Rank.SUBTRIBE())) {
1618
				result = Plantae_Subtribe;
1619
			} else if (rank.equals(Rank.GENUS())) {
1620
				result = Plantae_Genus;
1621
			} else if (rank.equals(Rank.SUBGENUS())) {
1622
				result = Plantae_Subgenus;
1623
			} else if (rank.equals(Rank.SECTION_BOTANY())) {
1624
				result = Plantae_Section;
1625
			} else if (rank.equals(Rank.SUBSECTION_BOTANY())) {
1626
				result = Plantae_Subsection;
1627
			} else if (rank.equals(Rank.SERIES())) {
1628
				result = Plantae_Series;
1629
			} else if (rank.equals(Rank.SUBSERIES())) {
1630
				result = Plantae_Subseries;
1631
			} else if (rank.equals(Rank.SPECIESAGGREGATE() )) {
1632
				result = Plantae_Aggregate;
1633
			} else if (rank.equals(Rank.SPECIESGROUP())) {
1634
				logger.warn("Rank Species Group not yet implemented");
1635
				result = null;
1636
			} else if (rank.getUuid().equals(BerlinModelTransformer.uuidRankCollSpecies)) { 
1637
				result = Plantae_Coll_Species;
1638
			} else if (rank.equals(Rank.SPECIES())) {
1639
				result = Plantae_Species;
1640
			} else if (rank.equals(Rank.SUBSPECIES())) {
1641
				result = Plantae_Subspecies;
1642
			} else if (rank.equals(Rank.GREX())) {
1643
				result = Plantae_Grex;
1644
			} else if (rank.getUuid().equals(BerlinModelTransformer.uuidRankProles) ) {
1645
				result = Plantae_Proles;
1646
			} else if (rank.getUuid().equals(BerlinModelTransformer.uuidRankRace)) {
1647
				result = Plantae_Race;
1648
			} else if (rank.equals(Rank.CONVAR())) {
1649
				result = Plantae_Convarietas;
1650
			} else if (rank.equals(Rank.VARIETY())) {
1651
				result = Plantae_Variety;
1652
			} else if (rank.equals(Rank.SUBVARIETY())) {
1653
				result = Plantae_Subvariety;
1654
			} else if (rank.equals(Rank.FORM())) {
1655
				result = Plantae_Forma;
1656
			} else if (rank.equals(Rank.SUBFORM())) {
1657
				result = Plantae_Subforma;
1658
//			} else if (rank.equals(Rank.)) { // not yet specified
1659
//				result = Plantae_Forma_spec;
1660
			} else if (rank.equals(Rank.INFRAGENERICTAXON())) { 
1661
				result = Plantae_Taxa_infragen;
1662
			} else if (rank.equals(Rank.INFRASPECIFICTAXON())) { 
1663
				result = Plantae_Taxa_infraspec;
1664
			} else {
1665
				//TODO Exception
1666
				logger.warn("Rank for Kingdom Plantae not yet supported in CDM: "+ rank.getLabel());
1667
				return null;
1668
			}
1669
		} else if (pesiKingdomId != null && pesiKingdomId.intValue() == KINGDOM_BACTERIA) {
1670
			if (rank.equals(Rank.KINGDOM())) { result = Bacteria_Kingdom; }
1671
			else if (rank.equals(Rank.SUBKINGDOM())) { result = Bacteria_Subkingdom; }
1672
			else if (rank.equals(Rank.PHYLUM())) { result = Bacteria_Phylum; }
1673
			else if (rank.equals(Rank.SUBPHYLUM())) { result = Bacteria_Subphylum; }
1674
			else if (rank.equals(Rank.SUPERCLASS())) { result = Bacteria_Superclass; }
1675
			else if (rank.equals(Rank.CLASS())) { result = Bacteria_Class; }
1676
			else if (rank.equals(Rank.SUBCLASS())) { result = Bacteria_Subclass; }
1677
			else if (rank.equals(Rank.INFRACLASS())) { result = Bacteria_Infraclass; }
1678
			else if (rank.equals(Rank.SUPERORDER())) { result = Bacteria_Superorder; }
1679
			else if (rank.equals(Rank.ORDER())) { result = Bacteria_Order; }
1680
			else if (rank.equals(Rank.SUBORDER())) { result = Bacteria_Suborder; }
1681
			else if (rank.equals(Rank.INFRAORDER())) { result = Bacteria_Infraorder; }
1682
			else if (rank.equals(Rank.SUPERFAMILY())) { result = Bacteria_Superfamily; }
1683
			else if (rank.equals(Rank.FAMILY())) { result = Bacteria_Family; }
1684
			else if (rank.equals(Rank.SUBFAMILY())) { result = Bacteria_Subfamily; }
1685
			else if (rank.equals(Rank.TRIBE())) { result = Bacteria_Tribe; }
1686
			else if (rank.equals(Rank.SUBTRIBE())) { result = Bacteria_Subtribe; }
1687
			else if (rank.equals(Rank.GENUS())) { result = Bacteria_Genus; }
1688
			else if (rank.equals(Rank.SUBGENUS())) { result = Bacteria_Subgenus; }
1689
			else if (rank.equals(Rank.SPECIES())) { result = Bacteria_Species; }
1690
			else if (rank.equals(Rank.SUBSPECIES())) { result = Bacteria_Subspecies; }
1691
			else if (rank.equals(Rank.VARIETY())) { result = Bacteria_Variety; }
1692
			else if (rank.equals(Rank.FORM())) { result = Bacteria_Forma; }
1693
		} else {
1694
			//TODO Exception
1695
			logger.warn("Kingdom not yet supported in CDM: "+ pesiKingdomId);
1696
			return null;
1697
		}
1698
		return result;
1699
	}
1700

    
1701
	/**
1702
	 * 
1703
	 * @param nameTypeDesignationStatus
1704
	 * @return
1705
	 */
1706
	public static Integer nameTypeDesignationStatus2TypeDesignationStatusId(NameTypeDesignationStatus nameTypeDesignationStatus) {
1707
		if (nameTypeDesignationStatus == null) {
1708
			return null;
1709
		}
1710
		if (nameTypeDesignationStatus.equals(NameTypeDesignationStatus.ORIGINAL_DESIGNATION())) {
1711
			return TYPE_BY_ORIGINAL_DESIGNATION;
1712
		} else if (nameTypeDesignationStatus.equals(NameTypeDesignationStatus.SUBSEQUENT_DESIGNATION())) {
1713
			return TYPE_BY_SUBSEQUENT_DESIGNATION;
1714
		} else if (nameTypeDesignationStatus.equals(NameTypeDesignationStatus.MONOTYPY())) {
1715
			return TYPE_BY_MONOTYPY;
1716
		} else {
1717
			//TODO Figure out a way to handle this gracefully.
1718
			logger.warn("Name Type Designation Status not yet supported in PESI: "+ nameTypeDesignationStatus.getLabel());
1719
			return null;
1720
		}
1721

    
1722
	}
1723

    
1724
	/**
1725
	 * 
1726
	 * @param nameTypeDesignationStatus
1727
	 * @return
1728
	 */
1729
	public static String nameTypeDesignationStatus2TypeDesignationStatusCache(NameTypeDesignationStatus nameTypeDesignationStatus) {
1730
		if (nameTypeDesignationStatus == null) {
1731
			return null;
1732
		}
1733
		if (nameTypeDesignationStatus.equals(NameTypeDesignationStatus.ORIGINAL_DESIGNATION())) {
1734
			return TYPE_STR_BY_ORIGINAL_DESIGNATION;
1735
		} else if (nameTypeDesignationStatus.equals(NameTypeDesignationStatus.SUBSEQUENT_DESIGNATION())) {
1736
			return TYPE_STR_BY_SUBSEQUENT_DESIGNATION;
1737
		} else if (nameTypeDesignationStatus.equals(NameTypeDesignationStatus.MONOTYPY())) {
1738
			return TYPE_STR_BY_MONOTYPY;
1739
		} else {
1740
			//TODO Figure out a way to handle this gracefully.
1741
			logger.warn("Name Type Designation Status not yet supported in PESI: "+ nameTypeDesignationStatus.getLabel());
1742
			return null;
1743
		}
1744

    
1745
	}
1746

    
1747
	/**
1748
	 * @see PesiTaxonExport#doPhaseUpdates(PesiExportState) for further transformation
1749
	 * @param taxonBase
1750
	 * @return
1751
	 */
1752
	public static Integer taxonBase2statusFk (TaxonBase<?> taxonBase){
1753
		if (taxonBase == null){
1754
			return null;
1755
		}		
1756
		if (taxonBase.isInstanceOf(Taxon.class)){
1757
			Taxon taxon = CdmBase.deproxy(taxonBase, Taxon.class);
1758
			if (taxon.getTaxonNodes().size() == 0){
1759
				return T_STATUS_NOT_ACCEPTED;
1760
			}else{
1761
				return T_STATUS_ACCEPTED;
1762
			}
1763
		}else if (taxonBase.isInstanceOf(Synonym.class)){
1764
			return T_STATUS_SYNONYM;
1765
		}else{
1766
			logger.warn("Unknown ");
1767
			return T_STATUS_UNRESOLVED;
1768
		}
1769
		//TODO 
1770
//		public static int T_STATUS_PARTIAL_SYN = 3;
1771
//		public static int T_STATUS_PRO_PARTE_SYN = 4;
1772
//		public static int T_STATUS_UNRESOLVED = 5;
1773
//		public static int T_STATUS_ORPHANED = 6;
1774
	}
1775

    
1776
//	/**
1777
//	 * 
1778
//	 * @param taxonBase
1779
//	 * @return
1780
//	 */
1781
//	public static String taxonBase2statusCache (TaxonBase<?> taxonBase){
1782
//		if (taxonBase == null){return null;}
1783
//		if (taxonBase.isInstanceOf(Taxon.class)){
1784
//			Taxon taxon = CdmBase.deproxy(taxonBase, Taxon.class);
1785
//			if (taxon.getTaxonNodes().size() == 0){
1786
//				return T_STATUS_STR_NOT_ACCEPTED;
1787
//			}else{
1788
//				return T_STATUS_STR_ACCEPTED;
1789
//			}
1790
//		}else if (taxonBase.isInstanceOf(Synonym.class)){
1791
//			return T_STATUS_STR_SYNONYM;
1792
//		}else{
1793
//			logger.warn("Unknown ");
1794
//			return T_STATUS_STR_UNRESOLVED;
1795
//		}
1796
//		//TODO 
1797
//		public static int T_STATUS_STR_PARTIAL_SYN = 3;
1798
//		public static int T_STATUS_STR_PRO_PARTE_SYN = 4;
1799
//		public static int T_STATUS_STR_UNRESOLVED = 5;
1800
//		public static int T_STATUS_STR_ORPHANED = 6;
1801
//	}
1802
		
1803
	/**
1804
	 * Returns the {@link SourceCategory SourceCategory} representation of the given {@link ReferenceType ReferenceType} in PESI.
1805
	 * @param reference The {@link Reference Reference}.
1806
	 * @return The {@link SourceCategory SourceCategory} representation in PESI.
1807
	 */
1808
	public static Integer reference2SourceCategoryFK(Reference<?> reference) {
1809
		if (reference == null){
1810
			return null;
1811
		} else if (reference.getType().equals(ReferenceType.Article)) {
1812
			return REF_ARTICLE_IN_PERIODICAL;
1813
		} else if (reference.getType().equals(ReferenceType.Book)) {
1814
			return REF_BOOK;
1815
		} else if (reference.getType().equals(ReferenceType.BookSection)) {
1816
			return REF_PART_OF_OTHER;
1817
		} else if (reference.getType().equals(ReferenceType.Database)) {
1818
			return REF_DATABASE;
1819
		} else if (reference.getType().equals(ReferenceType.WebPage)) {
1820
			return REF_WEBSITE;
1821
		} else if (reference.getType().equals(ReferenceType.CdDvd)) {
1822
			return REF_NOT_APPLICABLE;
1823
		} else if (reference.getType().equals(ReferenceType.Journal)) {
1824
			return REF_JOURNAL;
1825
		} else if (reference.getType().equals(ReferenceType.Generic)) {
1826
			return REF_UNRESOLVED;
1827
		} else if (reference.getType().equals(ReferenceType.PrintSeries)) {
1828
			return REF_PUBLISHED;
1829
		} else if (reference.getType().equals(ReferenceType.Proceedings)) {
1830
			return REF_PUBLISHED;
1831
		} else if (reference.getType().equals(ReferenceType.Patent)) {
1832
			return REF_NOT_APPLICABLE;
1833
		} else if (reference.getType().equals(ReferenceType.PersonalCommunication)) {
1834
			return REF_INFORMAL;
1835
		} else if (reference.getType().equals(ReferenceType.Report)) {
1836
			return REF_NOT_APPLICABLE;
1837
		} else if (reference.getType().equals(ReferenceType.Thesis)) {
1838
			return REF_NOT_APPLICABLE;
1839
		} else {
1840
			logger.warn("Reference type not yet supported in PESI: "+ reference.getType());
1841
			return null;
1842
		}
1843
	}
1844
	
1845
	/**
1846
	 * Returns the {@link SourceCategoryCache SourceCategoryCache}.
1847
	 * @param reference The {@link Reference Reference}.
1848
	 * @return The {@link SourceCategoryCache SourceCategoryCache}.
1849
	 */
1850
	public String getCacheByReference(Reference<?> reference) {
1851
		if (reference == null){
1852
			return null;
1853
		}else{
1854
			return this.sourceCategoryCacheMap.get(reference2SourceCategoryFK(reference)); 
1855
		}
1856
	}
1857

    
1858
	/**
1859
	 * 
1860
	 * @param status
1861
	 * @return
1862
	 */
1863
	public String getCacheByNomStatus(NomenclaturalStatusType status) {
1864
		if (status == null){
1865
			return null;
1866
		}else{
1867
			return this.nameStatusCacheMap.get(nomStatus2nomStatusFk(status)); 
1868
		}
1869
	}
1870
	
1871
	/**
1872
	 * 
1873
	 * @param status
1874
	 * @return
1875
	 */
1876
	public static Integer nomStatus2nomStatusFk (NomenclaturalStatusType status){
1877
		if (status == null){
1878
			return null;
1879
		}
1880
		if (status.equals(NomenclaturalStatusType.INVALID())) {return NAME_ST_NOM_INVAL;
1881
		}else if (status.equals(NomenclaturalStatusType.ILLEGITIMATE())) {return NAME_ST_NOM_ILLEG;
1882
		}else if (status.equals(NomenclaturalStatusType.NUDUM())) {return NAME_ST_NOM_NUD;
1883
		}else if (status.equals(NomenclaturalStatusType.REJECTED())) {return NAME_ST_NOM_REJ;
1884
		}else if (status.equals(NomenclaturalStatusType.REJECTED_PROP())) {return NAME_ST_NOM_REJ_PROP;
1885
		}else if (status.equals(NomenclaturalStatusType.UTIQUE_REJECTED())) {return NAME_ST_NOM_UTIQUE_REJ;
1886
		}else if (status.equals(NomenclaturalStatusType.UTIQUE_REJECTED_PROP())) {return NAME_ST_NOM_UTIQUE_REJ_PROP;
1887
		}else if (status.equals(NomenclaturalStatusType.CONSERVED())) {return NAME_ST_NOM_CONS;
1888
		
1889
		}else if (status.equals(NomenclaturalStatusType.CONSERVED_PROP())) {return NAME_ST_NOM_CONS_PROP;
1890
		}else if (status.equals(NomenclaturalStatusType.ORTHOGRAPHY_CONSERVED())) {return NAME_ST_ORTH_CONS;
1891
		}else if (status.equals(NomenclaturalStatusType.ORTHOGRAPHY_CONSERVED_PROP())) {return NAME_ST_ORTH_CONS_PROP;
1892
		}else if (status.equals(NomenclaturalStatusType.SUPERFLUOUS())) {return NAME_ST_NOM_SUPERFL;
1893
		}else if (status.equals(NomenclaturalStatusType.AMBIGUOUS())) {return NAME_ST_NOM_AMBIG;
1894
		}else if (status.equals(NomenclaturalStatusType.PROVISIONAL())) {return NAME_ST_NOM_PROVIS;
1895
		}else if (status.equals(NomenclaturalStatusType.DOUBTFUL())) {return NAME_ST_NOM_DUB;
1896
		}else if (status.equals(NomenclaturalStatusType.NOVUM())) {return NAME_ST_NOM_NOV;
1897
		
1898
		}else if (status.equals(NomenclaturalStatusType.CONFUSUM())) {return NAME_ST_NOM_CONFUS;
1899
		}else if (status.equals(NomenclaturalStatusType.ALTERNATIVE())) {return NAME_ST_NOM_ALTERN;
1900
		}else if (status.equals(NomenclaturalStatusType.COMBINATION_INVALID())) {return NAME_ST_COMB_INVAL;
1901
		}else if (status.equals(NomenclaturalStatusType.LEGITIMATE())) {return NAME_ST_LEGITIMATE;
1902
		
1903
		}else if (status.getUuid().equals(BerlinModelTransformer.uuidNomStatusCombIned)) {return NAME_ST_COMB_INED;
1904
		}else if (status.getUuid().equals(BerlinModelTransformer.uuidNomStatusNomOrthCons)) {return NAME_ST_NOM_AND_ORTH_CONS;
1905
		}else if (status.getUuid().equals(BerlinModelTransformer.uuidNomStatusSpNovIned)) {return NAME_ST_SP_NOV_INED;
1906
		
1907
		
1908
		// The following are non-existent in CDM
1909
//		}else if (status.equals(NomenclaturalStatusType.)) {return NAME_ST_COMB_AND_STAT_INED;
1910
//		}else if (status.equals(NomenclaturalStatusType.)) {return NAME_ST_NOM_NOV_INED;
1911
//		}else if (status.equals(NomenclaturalStatusType.)) {return NAME_ST_ALTERNATE_REPRESENTATION;
1912
		}else if (status.getUuid().equals(FaunaEuropaeaTransformer.uuidNomStatusTempNamed)) {return NAME_ST_TEMPORARY_NAME;
1913
//		}else if (status.equals(NomenclaturalStatusType.)) {return NAME_ST_SPECIES_INQUIRENDA;
1914

    
1915
		//TODO
1916
		}else {
1917
			//TODO Exception
1918
			logger.warn("NomStatus type not yet supported by PESI export: "+ status);
1919
			return null;
1920
		}
1921
	}
1922
	
1923
	/**
1924
	 * Returns the RelTaxonQualifierCache for a given taxonRelation.
1925
	 * @param relation
1926
	 * @return
1927
	 */
1928
	public String getCacheByRelationshipType(RelationshipBase relation, NomenclaturalCode code){
1929
		if (relation == null){
1930
			return null;
1931
		}else{
1932
			String result; 
1933
			Integer key = taxonRelation2RelTaxonQualifierFk(relation);
1934
			if (code.equals(NomenclaturalCode.ICZN)){
1935
				result = this.taxRelZooQualifierCacheMap.get(key);
1936
				if (result == null){
1937
					this.taxRelQualifierCacheMap.get(key); 
1938
				}
1939
			}else{
1940
				result = this.taxRelQualifierCacheMap.get(key); 
1941
			}
1942
			return result;
1943
		}
1944
	}
1945
	
1946
	/**
1947
	 * Returns the RelTaxonQualifierFk for a TaxonRelation.
1948
	 * @param relation
1949
	 * @return
1950
	 */
1951
	public static Integer taxonRelation2RelTaxonQualifierFk(RelationshipBase<?,?,?> relation) {
1952
		if (relation == null) {
1953
			return null;
1954
		}
1955
		RelationshipTermBase<?> type = relation.getType();
1956
		if (type.equals(TaxonRelationshipType.MISAPPLIED_NAME_FOR())) {
1957
			return IS_MISAPPLIED_NAME_FOR;
1958
		} else if (type.equals(SynonymRelationshipType.SYNONYM_OF())) {
1959
			SynonymRelationship synRel = CdmBase.deproxy(relation, SynonymRelationship.class);
1960
			if (synRel.isProParte()){
1961
				return IS_PRO_PARTE_SYNONYM_OF;
1962
			}else if (synRel.isPartial()){
1963
				return IS_PARTIAL_SYNONYM_OF;
1964
			}else{
1965
				return IS_SYNONYM_OF;
1966
			}
1967
		} else if (type.equals(SynonymRelationshipType.HOMOTYPIC_SYNONYM_OF())) {
1968
			SynonymRelationship synRel = CdmBase.deproxy(relation, SynonymRelationship.class);
1969
			if (synRel.isProParte()){
1970
				return IS_PRO_PARTE_AND_HOMOTYPIC_SYNONYM_OF;
1971
			}else if (synRel.isPartial()){
1972
				return IS_PARTIAL_AND_HOMOTYPIC_SYNONYM_OF;
1973
			}else{
1974
				return IS_HOMOTYPIC_SYNONYM_OF;
1975
			}
1976
		} else if (type.equals(SynonymRelationshipType.HETEROTYPIC_SYNONYM_OF())) {
1977
			SynonymRelationship synRel = CdmBase.deproxy(relation, SynonymRelationship.class);
1978
			if (synRel.isProParte()){
1979
				return IS_PRO_PARTE_AND_HETEROTYPIC_SYNONYM_OF;
1980
			}else if (synRel.isPartial()){
1981
				return IS_PARTIAL_AND_HETEROTYPIC_SYNONYM_OF;
1982
			}else{
1983
				return IS_HETEROTYPIC_SYNONYM_OF;
1984
			}
1985
		} else if (type.equals(SynonymRelationshipType.INFERRED_EPITHET_OF())) {
1986
			return IS_INFERRED_EPITHET_FOR;
1987
		} else if (type.equals(SynonymRelationshipType.INFERRED_GENUS_OF())) {
1988
			return IS_INFERRED_GENUS_FOR;
1989
		} else if (type.equals(SynonymRelationshipType.POTENTIAL_COMBINATION_OF())) {
1990
			return IS_POTENTIAL_COMBINATION_FOR;
1991
		} else if (type.equals(NameRelationshipType.BASIONYM())) {
1992
			return IS_BASIONYM_FOR;
1993
		} else if (type.equals(NameRelationshipType.LATER_HOMONYM())) {
1994
			return IS_LATER_HOMONYM_OF;
1995
		} else if (type.equals(NameRelationshipType.REPLACED_SYNONYM())) {
1996
			return IS_REPLACED_SYNONYM_FOR;
1997
		} else if (type.equals(NameRelationshipType.VALIDATED_BY_NAME())) {
1998
			return IS_VALIDATION_OF;
1999
		} else if (type.equals(NameRelationshipType.LATER_VALIDATED_BY_NAME())) {
2000
			return IS_LATER_VALIDATION_OF;
2001
		} else if (type.equals(NameRelationshipType.CONSERVED_AGAINST())) {
2002
			return IS_CONSERVED_AGAINST;
2003
		} else if (type.equals(NameRelationshipType.TREATED_AS_LATER_HOMONYM())) {
2004
			return IS_TREATED_AS_LATER_HOMONYM_OF;
2005
		} else if (type.equals(NameRelationshipType.ORTHOGRAPHIC_VARIANT())) {
2006
			return IS_ORTHOGRAPHIC_VARIANT_OF;
2007
		} else if (type.equals(NameRelationshipType.ALTERNATIVE_NAME())) {
2008
			return IS_ALTERNATIVE_NAME_FOR;
2009
		} else if (type.equals(HybridRelationshipType.FEMALE_PARENT())) {
2010
			return IS_FEMALE_PARENT_OF;
2011
		} else if (type.equals(HybridRelationshipType.MALE_PARENT())) {
2012
			return IS_MALE_PARENT_OF;
2013
		} else if (type.equals(HybridRelationshipType.FIRST_PARENT())) {
2014
			return IS_FIRST_PARENT_OF;
2015
		} else if (type.equals(HybridRelationshipType.SECOND_PARENT())) {
2016
			return IS_SECOND_PARENT_OF;
2017
		} else if (type.getUuid().equals(ErmsTransformer.uuidTaxRelTypeIsTaxonSynonymOf)) {
2018
			return IS_SYNONYM_OF;
2019
		} else {
2020
			logger.warn("No equivalent RelationshipType found in datawarehouse for: " + type.getTitleCache());
2021
		}
2022

    
2023
		// The following have no equivalent attribute in CDM
2024
//		IS_TYPE_OF
2025
//		IS_CONSERVED_TYPE_OF
2026
//		IS_REJECTED_TYPE_OF
2027
//		IS_REJECTED_IN_FAVOUR_OF
2028
//		HAS_SAME_TYPE_AS
2029
//		IS_LECTOTYPE_OF
2030
//		TYPE_NOT_DESIGNATED
2031

    
2032

    
2033
		return null;
2034
	}
2035
	
2036
	/**
2037
	 * Returns the StatusFk for a given StatusCache.
2038
	 * @param StatusCache
2039
	 * @return
2040
	 */
2041
	public Integer StatusCache2StatusFk(String StatusCache) {
2042
		Integer result = null;
2043
		if (StatusCache.equalsIgnoreCase("Checked by Taxonomic Editor: included in ERMS 1.1")) {
2044
			return 0;
2045
		} else if (StatusCache.equalsIgnoreCase("Added by Database Management Team")) {
2046
			return 2;
2047
		} else if (StatusCache.equalsIgnoreCase("Checked by Taxonomic Editor")) {
2048
			return 3;
2049
		} else if (StatusCache.equalsIgnoreCase("Edited by Database Management Team")) {
2050
			return 4;
2051
		} else {
2052
			logger.error("StatusFk could not be determined. StatusCache unknown: " + StatusCache);
2053
		}
2054
		
2055
		return result;
2056
	}
2057
	
2058
	/**
2059
	 * Returns the FossilStatusFk for a given FossilStatusCache.
2060
	 * @param fossilStatusCache
2061
	 * @return
2062
	 */
2063
	public Integer FossilStatusCache2FossilStatusFk(String fossilStatusCache) {
2064
		Integer result = null;
2065
		if (fossilStatusCache.equalsIgnoreCase("recent only")) {
2066
			return 1;
2067
		} else if (fossilStatusCache.equalsIgnoreCase("fossil only")) {
2068
			return 2;
2069
		} else if (fossilStatusCache.equalsIgnoreCase("recent + fossil")) {
2070
			return 3;
2071
		} else {
2072
			logger.error("FossilStatusFk could not be determined. FossilStatusCache unknown: " + fossilStatusCache);
2073
		}
2074
		
2075
		return result;
2076
	}
2077

    
2078
	/**
2079
	 * Returns the NoteCategoryFk for a given UUID representing an ExtensionType.
2080
	 * @param uuid
2081
	 * @return
2082
	 */
2083
	public static Integer getNoteCategoryFk(UUID uuid) {
2084
		Integer result = null;
2085
		if (uuid.equals(taxCommentUuid)) {
2086
			result = 270;
2087
		} else if (uuid.equals(fauCommentUuid)) {
2088
			result = 281;
2089
		} else if (uuid.equals(fauExtraCodesUuid)) {
2090
			result = 278;
2091
		}
2092
		return result;
2093
	}
2094
	
2095
	/**
2096
	 * Returns the NoteCategoryCache for a given UUID representing an ExtensionType.
2097
	 * @param uuid
2098
	 * @return
2099
	 */
2100
	public static String getNoteCategoryCache(UUID uuid) {
2101
		String result = null;
2102
		if (uuid.equals(taxCommentUuid)) {
2103
			result = "Taxonomy";
2104
		} else if (uuid.equals(fauCommentUuid)) {
2105
			result = "Biology";
2106
		} else if (uuid.equals(fauExtraCodesUuid)) {
2107
			result = "Distribution";
2108
		}
2109
		return result;
2110
	}
2111

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

    
2137
	
2138
	private static Set<String> getAllQualityStatus(TaxonNameBase<?, ?> taxonName) {
2139
		Set<String> result = new HashSet<String>();
2140
		for (TaxonBase<?> taxonBase : taxonName.getTaxonBases()){
2141
			result.addAll(taxonBase.getExtensions(ErmsTransformer.uuidQualityStatus));
2142
		}
2143
		return result;
2144
	}
2145

    
2146
	@Override
2147
	public String getQualityStatusCacheByKey(Integer qualityStatusId) throws UndefinedTransformerMethodException {
2148
		if (qualityStatusId == null){
2149
			return null;
2150
		}else{
2151
			return this.qualityStatusCacheMap.get(qualityStatusId); 
2152
		}
2153
	}
2154
	
2155

    
2156
	public Object getSourceUseCacheByKey(Integer sourceUseFk) {
2157
		if (sourceUseFk == null){
2158
			return null;
2159
		}else{
2160
			return this.sourceUseCacheMap.get(sourceUseFk); 
2161
		}
2162
	}
2163
	
2164
	@Override
2165
	public String getTaxonStatusCacheByKey(Integer taxonStatusId) throws UndefinedTransformerMethodException {
2166
		if (taxonStatusId == null){
2167
			return null;
2168
		}else{
2169
			return this.taxonStatusCacheMap.get(taxonStatusId); 
2170
		}
2171
	}
2172

    
2173
	public static String getOriginalDbBySources(BitSet sources) {
2174
		String result = "";
2175
		if (sources.get(SOURCE_EM)){
2176
			result = CdmUtils.concat(",", result,  SOURCE_STR_EM);
2177
		}
2178
		if (sources.get(SOURCE_FE)){
2179
			result = CdmUtils.concat(",", result,  SOURCE_STR_FE);
2180
		}
2181
		if (sources.get(SOURCE_IF)){
2182
			result = CdmUtils.concat(",", result,  SOURCE_STR_IF);
2183
		}
2184
		if (sources.get(SOURCE_ERMS)){
2185
			result = CdmUtils.concat(",", result,  SOURCE_STR_ERMS);
2186
		}
2187
		
2188
		return result;
2189
	}
2190

    
2191

    
2192
	
2193
}
(12-12/12)