2 * Copyright (C) 2007 EDIT
3 * European Distributed Institute of Taxonomy
4 * http://www.e-taxonomy.eu
6 * The contents of this file are subject to the Mozilla Public License Version 1.1
7 * See LICENSE.TXT at the top of this package for the full license terms.
10 package eu
.etaxonomy
.cdm
.app
.eflora
;
13 import java
.util
.List
;
14 import java
.util
.UUID
;
16 import org
.apache
.log4j
.Logger
;
17 import org
.springframework
.transaction
.TransactionStatus
;
19 import eu
.etaxonomy
.cdm
.api
.application
.CdmApplicationController
;
20 import eu
.etaxonomy
.cdm
.api
.application
.ICdmApplicationConfiguration
;
21 import eu
.etaxonomy
.cdm
.api
.service
.ITermService
;
22 import eu
.etaxonomy
.cdm
.common
.monitor
.DefaultProgressMonitor
;
23 import eu
.etaxonomy
.cdm
.common
.monitor
.IProgressMonitor
;
24 import eu
.etaxonomy
.cdm
.database
.DbSchemaValidation
;
25 import eu
.etaxonomy
.cdm
.database
.ICdmDataSource
;
26 import eu
.etaxonomy
.cdm
.database
.update
.CdmUpdater
;
27 import eu
.etaxonomy
.cdm
.io
.common
.CdmDefaultImport
;
28 import eu
.etaxonomy
.cdm
.io
.common
.CdmImportBase
.TermMatchMode
;
29 import eu
.etaxonomy
.cdm
.io
.common
.IImportConfigurator
.CHECK
;
30 import eu
.etaxonomy
.cdm
.io
.common
.mapping
.IInputTransformer
;
31 import eu
.etaxonomy
.cdm
.io
.common
.mapping
.UndefinedTransformerMethodException
;
32 import eu
.etaxonomy
.cdm
.io
.eflora
.EfloraImportConfigurator
;
33 import eu
.etaxonomy
.cdm
.io
.eflora
.centralAfrica
.ericaceae
.CentralAfricaEricaceaeImportConfigurator
;
34 import eu
.etaxonomy
.cdm
.io
.eflora
.centralAfrica
.ericaceae
.CentralAfricaEricaceaeTransformer
;
35 import eu
.etaxonomy
.cdm
.io
.specimen
.excel
.in
.SpecimenCdmExcelImportConfigurator
;
36 import eu
.etaxonomy
.cdm
.model
.agent
.Team
;
37 import eu
.etaxonomy
.cdm
.model
.common
.Language
;
38 import eu
.etaxonomy
.cdm
.model
.common
.OrderedTermVocabulary
;
39 import eu
.etaxonomy
.cdm
.model
.common
.TermType
;
40 import eu
.etaxonomy
.cdm
.model
.description
.Feature
;
41 import eu
.etaxonomy
.cdm
.model
.description
.FeatureNode
;
42 import eu
.etaxonomy
.cdm
.model
.description
.FeatureTree
;
43 import eu
.etaxonomy
.cdm
.model
.description
.PolytomousKey
;
44 import eu
.etaxonomy
.cdm
.model
.location
.NamedArea
;
45 import eu
.etaxonomy
.cdm
.model
.location
.NamedAreaLevel
;
46 import eu
.etaxonomy
.cdm
.model
.location
.NamedAreaType
;
47 import eu
.etaxonomy
.cdm
.model
.name
.NomenclaturalCode
;
48 import eu
.etaxonomy
.cdm
.model
.reference
.Reference
;
49 import eu
.etaxonomy
.cdm
.model
.reference
.ReferenceFactory
;
56 public class CentralAfricaEricaceaeActivator
{
57 private static final Logger logger
= Logger
.getLogger(CentralAfricaEricaceaeActivator
.class);
59 //database validation status (create, update, validate ...)
60 static DbSchemaValidation hbm2dll
= DbSchemaValidation
.VALIDATE
;
61 static final URI source
= EfloraSources
.ericacea_local();
63 static final URI specimenSource
= EfloraSources
.vittaria_specimen_pesiimport3();
66 static final ICdmDataSource cdmDestination
= CdmDestinations
.cdm_flora_central_africa_local();
68 // static final ICdmDataSource cdmDestination = CdmDestinations.cdm_flora_central_africa_preview();
69 // static final ICdmDataSource cdmDestination = CdmDestinations.cdm_flora_central_africa_production();
70 // static final ICdmDataSource cdmDestination = CdmDestinations.localH2();
71 // static final ICdmDataSource cdmDestination = CdmDestinations.cdm_local_postgres_CdmTest();
72 // static final ICdmDataSource cdmDestination = CdmDestinations.cdm_test_local_mysql();
73 // static final ICdmDataSource cdmDestination = CdmDestinations.cdm_campanulaceae_production();
76 public static final UUID featureTreeUuid
= UUID
.fromString("051d35ee-22f1-42d8-be07-9e9bfec5bcf7");
78 public static UUID defaultLanguageUuid
= Language
.uuidFrench
;
81 static final UUID classificationUuid
= UUID
.fromString("10e5efcc-6e13-4abc-ad42-e0b46e50cbe7");
83 NomenclaturalCode nc
= NomenclaturalCode
.ICNAFP
;
86 static final CHECK check
= CHECK
.IMPORT_WITHOUT_CHECK
;
88 static boolean doPrintKeys
= false;
91 private boolean includeEricaceae
= false;
92 static final boolean doTaxa
= false;
93 static final boolean doDeduplicate
= false;
96 private boolean doNewNamedAreas
= false;
97 private boolean doFeatureTree
= false;
99 private boolean doSpecimen
= true;
100 private TermMatchMode specimenAreaMatchMode
= TermMatchMode
.UUID_ABBREVLABEL
;
103 private void doImport(ICdmDataSource cdmDestination
){
105 // CdmUpdater su = CdmUpdater.NewInstance();
106 // IProgressMonitor monitor = DefaultProgressMonitor.NewInstance();
109 // su.updateToCurrentVersion(cdmDestination, monitor);
110 // } catch (Exception e) {
111 // e.printStackTrace();
118 CentralAfricaEricaceaeImportConfigurator config
= CentralAfricaEricaceaeImportConfigurator
.NewInstance(source
, cdmDestination
);
119 config
.setClassificationUuid(classificationUuid
);
120 config
.setDoTaxa(doTaxa
);
121 config
.setCheck(check
);
122 config
.setDefaultLanguageUuid(defaultLanguageUuid
);
123 config
.setDoPrintKeys(doPrintKeys
);
124 config
.setDbSchemaValidation(hbm2dll
);
125 config
.setNomenclaturalCode(nc
);
127 CdmDefaultImport
<EfloraImportConfigurator
> myImport
= new CdmDefaultImport
<EfloraImportConfigurator
>();
131 if (includeEricaceae
){
132 System
.out
.println("Start import from ("+ source
.toString() + ") ...");
133 config
.setSourceReference(getSourceReference(config
.getSourceReferenceTitle()));
134 myImport
.invoke(config
);
135 System
.out
.println("End import from ("+ source
.toString() + ")...");
139 FeatureTree tree
= makeFeatureNode(myImport
.getCdmAppController().getTermService());
140 myImport
.getCdmAppController().getFeatureTreeService().saveOrUpdate(tree
);
145 TransactionStatus tx
= myImport
.getCdmAppController().startTransaction();
146 List
<PolytomousKey
> keys
= myImport
.getCdmAppController().getPolytomousKeyService().list(PolytomousKey
.class, null, null, null, null);
147 for(PolytomousKey key
: keys
){
148 key
.print(System
.out
);
149 System
.out
.println();
151 myImport
.getCdmAppController().commitTransaction(tx
);
156 ICdmApplicationConfiguration app
= myImport
.getCdmAppController();
158 app
= CdmApplicationController
.NewInstance(cdmDestination
, hbm2dll
, false);
160 app
.getAgentService().updateTitleCache(Team
.class, null, null, null);
162 // int count = app.getAgentService().deduplicate(Person.class, null, null);
164 // logger.warn("Deduplicated " + count + " persons.");
165 //// count = app.getAgentService().deduplicate(Team.class, null, null);
166 //// logger.warn("Deduplicated " + count + " teams.");
167 // count = app.getReferenceService().deduplicate(Reference.class, null, null);
168 // logger.warn("Deduplicated " + count + " references.");
172 newNamedAreas(myImport
);
176 logger
.warn("Start specimen import");
177 ICdmApplicationConfiguration app
= myImport
.getCdmAppController();
178 SpecimenCdmExcelImportConfigurator specimenConfig
= SpecimenCdmExcelImportConfigurator
.NewInstance(specimenSource
, cdmDestination
);
179 specimenConfig
.setCdmAppController((CdmApplicationController
)app
);
180 specimenConfig
.setAreaMatchMode(specimenAreaMatchMode
);
181 specimenConfig
.setNomenclaturalCode(nc
);
183 config
.setDbSchemaValidation(DbSchemaValidation
.VALIDATE
);
184 specimenConfig
.setSourceReference(getSourceReference(specimenConfig
.getSourceReferenceTitle()));
186 CdmDefaultImport
<SpecimenCdmExcelImportConfigurator
> specimenImport
= new CdmDefaultImport
<SpecimenCdmExcelImportConfigurator
>();
187 specimenImport
.setCdmAppController(app
);
188 specimenImport
.invoke(specimenConfig
);
197 private void newNamedAreas(CdmDefaultImport
<EfloraImportConfigurator
> myImport
) {
198 ICdmApplicationConfiguration app
= myImport
.getCdmAppController();
200 app
= CdmApplicationController
.NewInstance(cdmDestination
, hbm2dll
, false);
202 TransactionStatus tx
= app
.startTransaction();
204 OrderedTermVocabulary
<NamedArea
> areaVoc
= OrderedTermVocabulary
.NewInstance(TermType
.NamedArea
, "Phytogeographic Regions of Central Africa", "Phytogeographic Regions of Central Africa", "FdAC regions", null);
205 app
.getVocabularyService().save(areaVoc
);
207 NamedAreaLevel level
= NamedAreaLevel
.NewInstance("Phytogeographic Regions of Central Africa", "Phytogeographic Regions of Central Africa", "FdAC regions");
208 ITermService termService
= app
.getTermService();
210 termService
.save(level
);
212 NamedArea area
= NamedArea
.NewInstance("C\u00F4tier", "C\u00F4tier", "I");
213 area
.setLevel(level
);
214 area
.setType(NamedAreaType
.NATURAL_AREA());
215 areaVoc
.addTerm(area
);
216 termService
.save(area
);
219 area
= NamedArea
.NewInstance("Mayumbe", "Mayumbe", "II");
220 area
.setLevel(level
);
221 area
.setType(NamedAreaType
.NATURAL_AREA());
222 areaVoc
.addTerm(area
);
223 termService
.save(area
);
225 area
= NamedArea
.NewInstance("Bas-Congo", "Bas-Congo", "III");
226 area
.setLevel(level
);
227 area
.setType(NamedAreaType
.NATURAL_AREA());
228 areaVoc
.addTerm(area
);
229 termService
.save(area
);
231 area
= NamedArea
.NewInstance("Kasai", "Kasai", "IV");
232 area
.setLevel(level
);
233 area
.setType(NamedAreaType
.NATURAL_AREA());
234 areaVoc
.addTerm(area
);
235 termService
.save(area
);
237 area
= NamedArea
.NewInstance("Bas-Katanga", "Bas-Katanga", "V");
238 area
.setLevel(level
);
239 area
.setType(NamedAreaType
.NATURAL_AREA());
240 areaVoc
.addTerm(area
);
241 termService
.save(area
);
243 area
= NamedArea
.NewInstance("Forestier Central", "Forestier Central", "VI");
244 area
.setLevel(level
);
245 area
.setType(NamedAreaType
.NATURAL_AREA());
246 areaVoc
.addTerm(area
);
247 termService
.save(area
);
249 area
= NamedArea
.NewInstance("Ubangi-Uele", "Ubangi-Uele", "VII");
250 area
.setLevel(level
);
251 area
.setType(NamedAreaType
.NATURAL_AREA());
252 areaVoc
.addTerm(area
);
253 termService
.save(area
);
255 area
= NamedArea
.NewInstance("Lac Albert", "Lac Albert", "VIII");
256 area
.setLevel(level
);
257 area
.setType(NamedAreaType
.NATURAL_AREA());
258 areaVoc
.addTerm(area
);
259 termService
.save(area
);
261 area
= NamedArea
.NewInstance("Lacs \u00C9douard et Kivu", "Lacs \u00C9douard et Kivu", "IX");
262 area
.setLevel(level
);
263 area
.setType(NamedAreaType
.NATURAL_AREA());
264 areaVoc
.addTerm(area
);
265 termService
.save(area
);
267 area
= NamedArea
.NewInstance("Rwanda-Burundi", "Rwanda-Burundi", "X");
268 area
.setLevel(level
);
269 area
.setType(NamedAreaType
.NATURAL_AREA());
270 areaVoc
.addTerm(area
);
271 termService
.save(area
);
273 area
= NamedArea
.NewInstance("Haut-Katanga", "Haut-Katanga", "XI");
274 area
.setLevel(level
);
275 area
.setType(NamedAreaType
.NATURAL_AREA());
276 areaVoc
.addTerm(area
);
277 termService
.save(area
);
279 app
.getVocabularyService().save(areaVoc
);
281 app
.commitTransaction(tx
);
285 private Reference
<?
> getSourceReference(String string
) {
286 Reference
<?
> result
= ReferenceFactory
.newGeneric();
287 result
.setTitleCache(string
, true);
291 private FeatureTree
makeFeatureNode(ITermService service
){
292 CentralAfricaEricaceaeTransformer transformer
= new CentralAfricaEricaceaeTransformer();
294 FeatureTree result
= FeatureTree
.NewInstance(featureTreeUuid
);
295 result
.setTitleCache("Central Africa Ericaceae Feature Tree", true);
296 FeatureNode root
= result
.getRoot();
299 newNode
= FeatureNode
.NewInstance(Feature
.DESCRIPTION());
300 root
.addChild(newNode
);
302 addFeataureNodesByStringList(descriptionFeatureList
, newNode
, transformer
, service
);
304 addFeataureNodesByStringList(generellDescriptionsList
, root
, transformer
, service
);
307 newNode
= FeatureNode
.NewInstance(Feature
.DISTRIBUTION());
308 root
.addChild(newNode
);
310 newNode
= FeatureNode
.NewInstance(Feature
.ECOLOGY());
311 root
.addChild(newNode
);
312 addFeataureNodesByStringList(habitatEcologyList
, root
, transformer
, service
);
314 newNode
= FeatureNode
.NewInstance(Feature
.USES());
315 root
.addChild(newNode
);
317 addFeataureNodesByStringList(chomosomesList
, root
, transformer
, service
);
319 newNode
= FeatureNode
.NewInstance(Feature
.COMMON_NAME());
320 root
.addChild(newNode
);
322 newNode
= FeatureNode
.NewInstance(Feature
.CITATION());
323 root
.addChild(newNode
);
328 private static String
[] chomosomesList
= new String
[]{
333 private static String
[] habitatEcologyList
= new String
[]{
339 private static String
[] generellDescriptionsList
= new String
[]{
341 "Morphology and anatomy",
343 "Vegetative morphology and anatomy",
349 "Fruits and embryology",
353 "Chromosome numbers",
354 "Phytochemistry and Chemotaxonomy",
359 private static String
[] descriptionFeatureList
= new String
[]{
368 "Flowering branchlets",
375 "flower-bearing stems",
383 "Young inflorescences",
421 "Infructescences", //order not consistent (sometimes before "Flowers")
445 public void addFeataureNodesByStringList(String
[] featureStringList
, FeatureNode root
, IInputTransformer transformer
, ITermService termService
){
447 for (String featureString
: featureStringList
){
449 featureUuid
= transformer
.getFeatureUuid(featureString
);
450 Feature feature
= (Feature
)termService
.find(featureUuid
);
451 if (feature
!= null){
452 FeatureNode child
= FeatureNode
.NewInstance(feature
);
453 root
.addChild(child
);
456 } catch (UndefinedTransformerMethodException e
) {
457 logger
.error("getFeatureUuid is not implemented in transformer. Features could not be added");
466 public static void main(String
[] args
) {
467 CentralAfricaEricaceaeActivator me
= new CentralAfricaEricaceaeActivator();
468 me
.doImport(cdmDestination
);