ref #8162 move OriginalSourceXXX to reference package in cdmlib-app
[cdmlib-apps.git] / app-import / src / main / java / eu / etaxonomy / cdm / app / wp6 / cichorieae / CichorieaeActivator.java
1 /**
2 * Copyright (C) 2007 EDIT
3 * European Distributed Institute of Taxonomy
4 * http://www.e-taxonomy.eu
5 *
6 * The contents of this file are subject to the Mozilla Public License Version 1.1
7 * See LICENSE.TXT at the top of this package for the full license terms.
8 */
9
10 package eu.etaxonomy.cdm.app.wp6.cichorieae;
11
12 import java.io.File;
13 import java.net.URI;
14 import java.net.URISyntaxException;
15 import java.util.UUID;
16
17 import org.apache.log4j.Logger;
18
19 import eu.etaxonomy.cdm.api.application.ICdmRepository;
20 import eu.etaxonomy.cdm.app.berlinModelImport.BerlinModelSources;
21 import eu.etaxonomy.cdm.app.berlinModelImport.TreeCreator;
22 import eu.etaxonomy.cdm.app.common.CdmDestinations;
23 import eu.etaxonomy.cdm.app.images.ImageImportConfigurator;
24 import eu.etaxonomy.cdm.database.DbSchemaValidation;
25 import eu.etaxonomy.cdm.database.ICdmDataSource;
26 import eu.etaxonomy.cdm.io.berlinModel.in.BerlinModelImportConfigurator;
27 import eu.etaxonomy.cdm.io.common.CdmDefaultImport;
28 import eu.etaxonomy.cdm.io.common.IImportConfigurator;
29 import eu.etaxonomy.cdm.io.common.IImportConfigurator.CHECK;
30 import eu.etaxonomy.cdm.io.common.IImportConfigurator.DO_REFERENCES;
31 import eu.etaxonomy.cdm.io.common.IImportConfigurator.EDITOR;
32 import eu.etaxonomy.cdm.io.common.ImportResult;
33 import eu.etaxonomy.cdm.io.common.Source;
34 import eu.etaxonomy.cdm.io.wp6.CichorieaeImageImport;
35 import eu.etaxonomy.cdm.model.description.Feature;
36 import eu.etaxonomy.cdm.model.description.FeatureNode;
37 import eu.etaxonomy.cdm.model.description.FeatureTree;
38 import eu.etaxonomy.cdm.model.name.NomenclaturalCode;
39 import eu.etaxonomy.cdm.model.name.TaxonName;
40
41
42 /**
43 * TODO add the following to a wiki page:
44 * HINT: If you are about to import into a mysql data base running under windows and if you wish to dump and restore the resulting data bas under another operation systen
45 * you must set the mysql system variable lower_case_table_names = 0 in order to create data base with table compatible names.
46 *
47 *
48 * @author a.mueller
49 *
50 */
51 public class CichorieaeActivator {
52 private static final Logger logger = Logger.getLogger(CichorieaeActivator.class);
53
54 //database validation status (create, update, validate ...)
55 static DbSchemaValidation hbm2dll = DbSchemaValidation.CREATE;
56 static final Source berlinModelSource = BerlinModelSources.EDIT_CICHORIEAE();
57 static final ICdmDataSource cdmDestination = CdmDestinations.cdm_test_local_mysql_test();
58
59 static final UUID secUuid = UUID.fromString("6924c75d-e0d0-4a6d-afb7-3dd8c71195ca");
60 static final UUID classificationUuid = UUID.fromString("534e190f-3339-49ba-95d9-fa27d5493e3e");
61 // static final UUID treeUuid = UUID.fromString("00db28a7-50e1-4abc-86ec-b2a8ce870de9");
62 static final int sourceSecId = 7800000;
63
64 static final UUID featureTreeUuid = UUID.fromString("ae9615b8-bc60-4ed0-ad96-897f9226d568");
65 static final Object[] featureKeyList = new Integer[]{1, 43, 31, 4, 12, 98, 41};
66
67 /* --------- MEDIA recources ------------ */
68 static final boolean stopOnMediaErrors = false;
69 static final String protologueUrlString = "http://wp5.e-taxonomy.eu/dataportal/cichorieae/media/protolog/";
70 //Mac
71 //static final File protologuePath = new File("/Volumes/protolog/protolog/");
72 //Windows
73 public static final String imageFolderString = "//media/editwp6/photos";
74 static final File protologuePath = new File("//media/editwp6/protolog");
75 // public static final File imageFolder = new File("/media/photos");
76 // static final File protologuePath = new File("/media/protolog");
77 /* -------------------------------------- */
78
79 // set to zero for unlimited nameFacts
80 static final int maximumNumberOfNameFacts = 0;
81 static final int recordsPerTransaction = 2000;
82
83 //should the other imports run as well?
84 static final boolean includeTaraxacum = true;
85 static final boolean includeImages = false;
86
87
88 //check - import
89 static final CHECK check = CHECK.CHECK_AND_IMPORT;
90
91 //editor - import
92 static final EDITOR editor = EDITOR.EDITOR_AS_EDITOR;
93
94 //NomenclaturalCode
95 static final NomenclaturalCode nomenclaturalCode = NomenclaturalCode.ICNAFP;
96
97 //ignore null
98 static final boolean ignoreNull = true;
99
100 static boolean useClassification = true;
101
102
103 // **************** ALL *********************
104
105 static final boolean doUser = true;
106 //authors
107 static final boolean doAuthors = true;
108 //references
109 static final DO_REFERENCES doReferences = DO_REFERENCES.ALL;
110 //names
111 static final boolean doTaxonNames = true;
112 static final boolean doRelNames = true;
113 static final boolean doNameStatus = true;
114 static final boolean doTypes = true;
115 static final boolean doNameFacts = true;
116
117 //taxa
118 static final boolean doTaxa = true;
119 static final boolean doRelTaxa = true;
120 static final boolean doFacts = false;
121 static final boolean doOccurences = false;
122 static final boolean doCommonNames = true;
123
124 //etc.
125 static final boolean doMarker = false;
126
127
128 // **************** SELECTED *********************
129 //
130 // static final boolean doUser = false;
131 // //authors
132 // static final boolean doAuthors = false;
133 // //references
134 // static final DO_REFERENCES doReferences = DO_REFERENCES.NONE;
135 // //names
136 // static final boolean doTaxonNames = false;
137 // static final boolean doRelNames = false;
138 // static final boolean doNameStatus = false;
139 // static final boolean doTypes = false;
140 // static final boolean doNameFacts = false;
141 //
142 // //taxa
143 // static final boolean doTaxa = false;
144 // static final boolean doRelTaxa = false;
145 // static final boolean doCommonNames = false;
146 // static final boolean doFacts = false;
147 // static final boolean doOccurences = false;
148 //
149 // //etc.
150 // static final boolean doMarker = false;
151
152
153 private ImportResult doInvoke(ICdmDataSource destination){
154 ImportResult success = new ImportResult();
155 Source source = berlinModelSource;
156
157 BerlinModelImportConfigurator bmImportConfigurator = BerlinModelImportConfigurator.NewInstance(source, destination);
158
159 bmImportConfigurator.setClassificationUuid(classificationUuid);
160 bmImportConfigurator.setSourceSecId(sourceSecId);
161
162 bmImportConfigurator.setNomenclaturalCode(nomenclaturalCode);
163
164 bmImportConfigurator.setIgnoreNull(ignoreNull);
165 bmImportConfigurator.setDoAuthors(doAuthors);
166 bmImportConfigurator.setDoReferences(doReferences);
167 bmImportConfigurator.setDoTaxonNames(doTaxonNames);
168 bmImportConfigurator.setDoRelNames(doRelNames);
169 bmImportConfigurator.setDoNameStatus(doNameStatus);
170 bmImportConfigurator.setDoTypes(doTypes);
171 bmImportConfigurator.setDoNameFacts(doNameFacts);
172 bmImportConfigurator.setUseClassification(useClassification);
173
174 bmImportConfigurator.setDoTaxa(doTaxa);
175 bmImportConfigurator.setDoRelTaxa(doRelTaxa);
176 bmImportConfigurator.setDoFacts(doFacts);
177 bmImportConfigurator.setDoOccurrence(doOccurences);
178 bmImportConfigurator.setDoCommonNames(doCommonNames);
179
180 bmImportConfigurator.setDoMarker(doMarker);
181 bmImportConfigurator.setDoUser(doUser);
182 bmImportConfigurator.setEditor(editor);
183 bmImportConfigurator.setDbSchemaValidation(hbm2dll);
184 bmImportConfigurator.setRecordsPerTransaction(recordsPerTransaction);
185
186
187 // protologueResourceLocations
188 if ( protologuePath.exists() && protologuePath.isDirectory()){
189 bmImportConfigurator.setMediaUrl(protologueUrlString);
190 bmImportConfigurator.setMediaPath(protologuePath);
191 }else{
192 if(stopOnMediaErrors){
193 logger.error("Could not configure protologue ResourceLocations -> will quit.");
194 System.exit(-1);
195 }
196 logger.error("Could not configure protologue ResourceLocations");
197 }
198
199 File imageFolder = new File(imageFolderString);
200 // also check the image source folder
201 if ( !imageFolder.exists() || !imageFolder.isDirectory()){
202 if(stopOnMediaErrors){
203 logger.error("Could not configure imageFolder -> will quit.");
204 System.exit(-1);
205 }
206 logger.error("Could not configure imageFolder");
207 }
208
209 // maximum number of name facts to import
210 bmImportConfigurator.setMaximumNumberOfNameFacts(maximumNumberOfNameFacts);
211
212
213 bmImportConfigurator.setCheck(check);
214 bmImportConfigurator.setEditor(editor);
215
216 // invoke import
217 CdmDefaultImport<BerlinModelImportConfigurator> bmImport = new CdmDefaultImport<BerlinModelImportConfigurator>();
218 success = bmImport.invoke(bmImportConfigurator);
219
220 if (doFacts && (bmImportConfigurator.getCheck().equals(CHECK.CHECK_AND_IMPORT) || bmImportConfigurator.getCheck().equals(CHECK.IMPORT_WITHOUT_CHECK) ) ){
221 ICdmRepository app = bmImport.getCdmAppController();
222 ISourceable obj = app.getCommonService().getSourcedObjectByIdInSource(TaxonName.class, "1000027", null);
223 logger.info(obj);
224
225 //make feature tree
226 FeatureTree tree = TreeCreator.flatTree(featureTreeUuid, bmImportConfigurator.getFeatureMap(), featureKeyList);
227 FeatureNode imageNode = FeatureNode.NewInstance(Feature.IMAGE());
228 tree.getRoot().addChild(imageNode);
229 FeatureNode distributionNode = FeatureNode.NewInstance(Feature.DISTRIBUTION());
230 tree.getRoot().addChild(distributionNode, 2);
231 app.getFeatureTreeService().saveOrUpdate(tree);
232 }
233
234 System.out.println("End import from BerlinModel ("+ source.getDatabase() + ")...");
235
236
237 try {
238 if (includeTaraxacum) {
239 System.out.println("Start Taraxacum import from BerlinModel ...");
240 TaraxacumActivator taraxacumActivator = new TaraxacumActivator();
241 ImportResult successTaraxacum = taraxacumActivator.doImport(destination, DbSchemaValidation.UPDATE);
242 success.merge(successTaraxacum);
243 logger.warn("Taraxacum import still needs to be tested");
244 System.out.println("End Taraxacum import from BerlinModel ...");
245 }
246 } catch (Exception e) {
247 success.addException(e);
248 logger.error("Exception occurred during Taraxacum import.");
249 e.printStackTrace();
250 }
251
252
253
254 if (includeImages) {
255 System.out.println("Start importing images ...");
256 CdmDefaultImport<IImportConfigurator> imageImporter = new CdmDefaultImport<IImportConfigurator>();
257 URI imageFolderCichorieae;
258 try {
259 imageFolderCichorieae = new URI(CichorieaeActivator.imageFolderString);
260 ImageImportConfigurator imageConfigurator = ImageImportConfigurator.NewInstance(
261 imageFolderCichorieae, destination, CichorieaeImageImport.class);
262 imageConfigurator.setSecUuid(secUuid);
263 imageConfigurator.setClassificationUuid(classificationUuid);
264 ImportResult resultImageImport = imageImporter.invoke(imageConfigurator);
265 success.merge(resultImageImport);
266 } catch (URISyntaxException e) {
267 e.printStackTrace();
268 }
269 System.out.println("End importing images ...");
270 }
271 logger.warn("!!!! NOTE: RefDetail notes and RelPTaxon notes are not imported automatically. Please check for these notes and import them manually.");
272
273 return success;
274
275 }
276
277 /**
278 * @param args
279 */
280 public static void main(String[] args) {
281 ICdmDataSource destination = CdmDestinations.chooseDestination(args) != null ? CdmDestinations.chooseDestination(args) : cdmDestination;
282
283 System.out.println("Start import from BerlinModel("+ berlinModelSource.getDatabase() + ") to " + destination.getDatabase() + " ...");
284 CichorieaeActivator me = new CichorieaeActivator();
285 me.doInvoke(destination);
286
287 }
288
289 }