Project

General

Profile

« Previous | Next » 

Revision 3796d5f7

Added by Andreas Müller about 11 years ago

latest for vibrant

View differences:

app-import/src/main/java/eu/etaxonomy/cdm/app/vibrant/IopiActivator.java
9 9

  
10 10
package eu.etaxonomy.cdm.app.vibrant;
11 11

  
12
import java.lang.reflect.Method;
13
import java.sql.ResultSet;
14
import java.sql.SQLException;
12 15
import java.util.UUID;
13 16

  
14 17
import org.apache.log4j.Logger;
......
25 28
import eu.etaxonomy.cdm.io.common.IImportConfigurator.EDITOR;
26 29
import eu.etaxonomy.cdm.io.common.Source;
27 30
import eu.etaxonomy.cdm.io.pesi.out.PesiTransformer;
31
import eu.etaxonomy.cdm.model.common.CdmBase;
32
import eu.etaxonomy.cdm.model.common.ExtensionType;
28 33
import eu.etaxonomy.cdm.model.name.NomenclaturalCode;
34
import eu.etaxonomy.cdm.model.name.NonViralName;
35
import eu.etaxonomy.cdm.model.name.Rank;
36
import eu.etaxonomy.cdm.model.name.TaxonNameBase;
37
import eu.etaxonomy.cdm.model.taxon.TaxonBase;
29 38

  
30 39

  
31 40
/**
......
38 47
 *
39 48
 */
40 49
public class IopiActivator {
41
	@SuppressWarnings("unused")
42 50
	private static final Logger logger = Logger.getLogger(IopiActivator.class);
43 51

  
44 52
	//database validation status (create, update, validate ...)
......
48 56
//	static final ICdmDataSource cdmDestination = CdmDestinations.cdm_test_local_mysql();
49 57
	static final ICdmDataSource cdmDestination = cdm_test_local_iopi();
50 58
	
51
	static final boolean useSingleClassification = false;
52
	static final Integer sourceSecId = null; //7000000; 
59
	static final boolean useSingleClassification = true;
60
	static final Integer sourceSecId = 1892; //7000000; 
53 61
	static final UUID classificationUuid = null; //UUID.fromString("aa3fbaeb-f5dc-4e75-8d60-c8f93beb7ba6");
54 62
	
55 63
	static final UUID sourceRefUuid = UUID.fromString("df68c748-3c64-4b96-9a47-db51fb9d387e");
......
74 82
	static boolean useClassification = true;
75 83
	
76 84
	
85
	//filter
86
	static String taxonTable = "v_cdm_exp_taxaAll";
87
	static String classificationQuery = " SELECT DISTINCT t.PTRefFk, r.RefCache FROM PTaxon t INNER JOIN Reference r ON t.PTRefFk = r.RefId WHERE t.PTRefFk = " + sourceSecId; 
88
	static String relPTaxonIdQuery = " SELECT r.RelPTaxonId " + 
89
					" FROM RelPTaxon AS r INNER JOIN v_cdm_exp_taxaDirect AS a ON r.PTNameFk2 = a.PTNameFk AND r.PTRefFk2 = a.PTRefFk ";
90
	static String nameIdTable = " v_cdm_exp_namesAll ";
91
	static String referenceIdTable = " v_cdm_exp_refAll ";
92
	static String factFilter = " factId IN ( SELECT factId FROM v_cdm_exp_factsAll )";
93
	static String authorTeamFilter = null; // " authorTeamId IN (SELECT authorTeamId FROM v_cdm_exp_authorTeamsAll) ";
94
	static String authorFilter = null;  // " authorId IN (SELECT authorId FROM v_cdm_exp_authorsAll) "; 
95
	//not used
96
	static String occurrenceFilter = " occurrenceId IN ( SELECT occurrenceId FROM v_cdm_exp_occurrenceAll )";
97
	static String occurrenceSourceFilter = " occurrenceFk IN ( SELECT occurrenceId FROM v_cdm_exp_occurrenceAll )"; 
98
	static String commonNameFilter = " commonNameId IN ( SELECT commonNameId FROM v_cdm_exp_commonNamesAll )";
99

  
100
	
101
	
77 102
// **************** ALL *********************	
78 103

  
79 104
	//authors
......
137 162
		
138 163
		config.setNomenclaturalCode(nomenclaturalCode);
139 164

  
165
		try {
166
			Method makeUrlMethod = MclActivator.class.getDeclaredMethod("makeUrlForTaxon", TaxonBase.class, ResultSet.class);
167
			config.setMakeUrlForTaxon(makeUrlMethod);
168
		} catch (Exception e) {
169
			e.printStackTrace();
170
			return;
171
		}
172
		
140 173
		config.setIgnoreNull(ignoreNull);
141 174
		config.setDoAuthors(doAuthors);
142 175
		config.setDoReferences(doReferences);
......
167 200
		config.setCheck(check);
168 201
		config.setEditor(editor);
169 202
		config.setRecordsPerTransaction(partitionSize);
203
		
204
//		filter
205
		config.setTaxonTable(taxonTable);
206
		config.setClassificationQuery(classificationQuery);
207
		config.setRelTaxaIdQuery(relPTaxonIdQuery);
208
		config.setNameIdTable(nameIdTable);
209
		config.setReferenceIdTable(referenceIdTable);
210
		config.setAuthorTeamFilter(authorTeamFilter);
211
		config.setAuthorFilter(authorFilter);
212
		config.setFactFilter(factFilter);
213
		config.setCommonNameFilter(commonNameFilter);
214
		config.setOccurrenceFilter(occurrenceFilter);
215
		config.setOccurrenceSourceFilter(occurrenceSourceFilter);
216
		config.setUseSingleClassification(useSingleClassification);
217
	
170 218

  
171 219
		
172 220
		// invoke import
......
197 245
		return CdmDestinations.makeDestination(dbType, cdmServer, cdmDB, -1, cdmUserName, null);
198 246
	}
199 247
	
248
	
249
	//for FAUNA Europaea (http://rbg-web2.rbge.org.uk/FE/fe.html)
250
	private static final String URLbase = "http://rbg-web2.rbge.org.uk/cgi-bin/nph-readbtree.pl/feout?FAMILY_XREF=%s&GENUS_XREF=%s&SPECIES_XREF=%s&TAXON_NAME_XREF=%s&RANK=%s";
251
	public static Method makeUrlForTaxon(TaxonBase<?> taxon, ResultSet rs){
252
		Method result = null;
253
		ExtensionType urlExtensionType = ExtensionType.URL();
254
		
255
		String family = "";
256
		String genus = "";
257
		String species = "";
258
		String taxonName = "";
259
		String rankStr = "";
260
			
261
		NonViralName<?>  name = CdmBase.deproxy(taxon.getName(), NonViralName.class);
262
		Rank rank = name.getRank();
263
		rankStr = transformFeRanks(rank);
264
			
265
		
266
		if (rank.equals(Rank.FAMILY())){
267
			family = name.getGenusOrUninomial();
268
			taxonName = name.getGenusOrUninomial();
269
		}else if (rank.isHigher(Rank.GENUS())){
270
			taxonName = name.getGenusOrUninomial();
271
		}else if (rank.isGenus()){
272
			genus = name.getGenusOrUninomial();
273
			rankStr = "genus";
274
		}else if (rank.isInfraGeneric()){
275
			genus = name.getGenusOrUninomial();
276
			taxonName = name.getInfraGenericEpithet();
277
		}else if (rank.isSpecies()){
278
			genus = name.getGenusOrUninomial();
279
			species = name.getSpecificEpithet();
280
			rankStr = "species";
281
		}else if (rank.isInfraSpecific()){
282
			genus = name.getGenusOrUninomial();
283
			species = name.getSpecificEpithet();
284
			taxonName = name.getInfraSpecificEpithet();
285
		}
286
		
287
		
288
		String url = String.format(URLbase ,family, genus, species, taxonName, rankStr);
289
		taxon.addExtension(url, urlExtensionType);
290
		
291
		return result;
292
	}
293
	
294
	private static String transformFeRanks(Rank rank){
295
		if (rank.equals(Rank.SPECIESAGGREGATE())){ return "agg.";
296
		}else if (rank.equals(Rank.CLASS())){ return "Class";
297
		}else if (rank.equals(Rank.DIVISION())){ return "Division";
298
		}else if (rank.equals(Rank.FAMILY())){ return "family";
299
		}else if (rank.equals(Rank.FORM())){ return "forma";
300
		}else if (rank.equals(Rank.GENUS())){ return "genus";
301
		}else if (rank.equals(Rank.GREX())){ return "grex";
302
		}else if (rank.equals(Rank.SPECIESGROUP())){ return "group";
303
		}else if (rank.equals(Rank.ORDER())){ return "Order";
304
//		}else if (rank.equals(Rank.PROL())){ return "proles";
305
//--		}else if (rank.equals(Rank.RACE())){ return "race";
306
		}else if (rank.equals(Rank.SECTION_BOTANY())){ return "Sect.";
307
		}else if (rank.equals(Rank.SERIES())){ return "Ser.";
308
		}else if (rank.equals(Rank.SPECIES())){ return "species";
309
		}else if (rank.equals(Rank.SUBCLASS())){ return "Subclass";
310
		}else if (rank.equals(Rank.SUBDIVISION())){ return "Subdivision";
311
		}else if (rank.equals(Rank.SUBFORM())){ return "Subf.";
312
		}else if (rank.equals(Rank.SUBGENUS())){ return "Subgen.";
313
		}else if (rank.equals(Rank.SUBORDER())){ return "Suborder";
314
		}else if (rank.equals(Rank.SUBSECTION_BOTANY())){ return "Subsect.";
315
		}else if (rank.equals(Rank.SUBSERIES())){ return "Subser.";
316
		}else if (rank.equals(Rank.SUBSPECIES())){ return "subsp";
317
		}else if (rank.equals(Rank.SUBVARIETY())){ return "subvar.";
318
		}else if (rank.equals(Rank.SUPERORDER())){ return "Superorder";
319
		}else if (rank.equals(Rank.TRIBE())){ return "Tribe";
320
		}else if (rank.equals(Rank.VARIETY())){ return "var.";
321
		}else{
322
			logger.debug("Rank not found: " + rank.getTitleCache());
323
			return "";
324
		}	
325
	}
326
	
200 327

  
201 328
}
app-import/src/main/java/eu/etaxonomy/cdm/app/vibrant/VibrantActivator.java
33 33
	private static final Logger logger = Logger.getLogger(VibrantActivator.class);
34 34

  
35 35
	//database validation status (create, update, validate ...)
36
	static DbSchemaValidation hbm2dll = DbSchemaValidation.VALIDATE;
36
	static DbSchemaValidation hbm2dll = DbSchemaValidation.CREATE;
37 37
	static final Source iopiSource = BerlinModelSources.iopi();
38 38
	static final Source mclSource = BerlinModelSources.mcl();
39 39
	static final Source emSource = BerlinModelSources.PESI3_euroMed();
......
69 69
			iopiActivator.importIopi(iopiSource, cdmRepository, hbm2dll);
70 70
			hbm2dll = DbSchemaValidation.NONE;
71 71
		}
72
		
73
		if (doEuroMed){
74
			logger.warn("DON'T FORGET to reset E+M filter");
75
			System.out.println("DON'T FORGET to reset E+M filter");
76
		}
72 77

  
73 78
	}
74 79
	

Also available in: Unified diff