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
|
package eu.etaxonomy.cdm.io.berlinModel.out;
|
10
|
|
11
|
import java.sql.SQLException;
|
12
|
import java.util.ArrayList;
|
13
|
import java.util.List;
|
14
|
|
15
|
import org.apache.log4j.Logger;
|
16
|
import org.springframework.stereotype.Component;
|
17
|
import org.springframework.transaction.TransactionStatus;
|
18
|
|
19
|
import eu.etaxonomy.cdm.io.berlinModel.BerlinModelTransformer;
|
20
|
import eu.etaxonomy.cdm.io.berlinModel.out.mapper.RefDetailMapper;
|
21
|
import eu.etaxonomy.cdm.io.berlinModel.out.mapper.TeamOrPersonMapper;
|
22
|
import eu.etaxonomy.cdm.io.common.Source;
|
23
|
import eu.etaxonomy.cdm.io.common.mapping.out.CdmDbExportMapping;
|
24
|
import eu.etaxonomy.cdm.io.common.mapping.out.CollectionExportMapping;
|
25
|
import eu.etaxonomy.cdm.io.common.mapping.out.CreatedAndNotesMapper;
|
26
|
import eu.etaxonomy.cdm.io.common.mapping.out.DbBooleanMapper;
|
27
|
import eu.etaxonomy.cdm.io.common.mapping.out.DbExtensionMapper;
|
28
|
import eu.etaxonomy.cdm.io.common.mapping.out.DbMarkerMapper;
|
29
|
import eu.etaxonomy.cdm.io.common.mapping.out.DbObjectMapper;
|
30
|
import eu.etaxonomy.cdm.io.common.mapping.out.DbStringMapper;
|
31
|
import eu.etaxonomy.cdm.io.common.mapping.out.IExportTransformer;
|
32
|
import eu.etaxonomy.cdm.io.common.mapping.out.IdMapper;
|
33
|
import eu.etaxonomy.cdm.io.common.mapping.out.MethodMapper;
|
34
|
import eu.etaxonomy.cdm.model.common.CdmBase;
|
35
|
import eu.etaxonomy.cdm.model.common.ExtensionType;
|
36
|
import eu.etaxonomy.cdm.model.common.MarkerType;
|
37
|
import eu.etaxonomy.cdm.model.name.INonViralName;
|
38
|
import eu.etaxonomy.cdm.model.name.NomenclaturalStatus;
|
39
|
import eu.etaxonomy.cdm.model.name.TaxonName;
|
40
|
|
41
|
|
42
|
/**
|
43
|
* @author a.mueller
|
44
|
* @since 20.03.2008
|
45
|
*/
|
46
|
@Component
|
47
|
public class BerlinModelTaxonNameExport extends BerlinModelExportBase<TaxonName> {
|
48
|
|
49
|
private static final long serialVersionUID = 4478799976310317219L;
|
50
|
private static final Logger logger = Logger.getLogger(BerlinModelTaxonNameExport.class);
|
51
|
|
52
|
private static int modCount = 2500;
|
53
|
private static final String dbTableName = "Name";
|
54
|
private static final String pluralString = "TaxonNames";
|
55
|
private static final Class<? extends CdmBase> standardMethodParameter = TaxonName.class;
|
56
|
|
57
|
public BerlinModelTaxonNameExport(){
|
58
|
super();
|
59
|
}
|
60
|
|
61
|
/* (non-Javadoc)
|
62
|
* @see eu.etaxonomy.cdm.io.common.CdmIoBase#doCheck(eu.etaxonomy.cdm.io.common.IImportConfigurator)
|
63
|
*/
|
64
|
@Override
|
65
|
protected boolean doCheck(BerlinModelExportState state){
|
66
|
boolean result = true;
|
67
|
logger.warn("Checking for " + pluralString + " not yet fully implemented");
|
68
|
List<TaxonName> list = getObjectList();
|
69
|
checkRank(list);
|
70
|
|
71
|
//result &= checkRank(config);
|
72
|
|
73
|
return result;
|
74
|
}
|
75
|
|
76
|
private boolean checkRank(List<TaxonName> list){
|
77
|
List<TaxonName> errorNames = new ArrayList<>();
|
78
|
for (TaxonName name : list){
|
79
|
if (name.getRank() == null) {
|
80
|
;
|
81
|
}
|
82
|
errorNames.add(name);
|
83
|
}
|
84
|
if (errorNames.size() >0){
|
85
|
System.out.println("The following names have no Rank:\n=======================");
|
86
|
for (TaxonName name : errorNames){
|
87
|
System.out.println(" " + name.toString());
|
88
|
System.out.println(" " + name.getUuid());
|
89
|
System.out.println(" " + name.getTitleCache());
|
90
|
}
|
91
|
return false;
|
92
|
}else{
|
93
|
return true;
|
94
|
}
|
95
|
}
|
96
|
|
97
|
private CdmDbExportMapping<BerlinModelExportState, BerlinModelExportConfigurator, IExportTransformer> getMapping(){
|
98
|
String tableName = dbTableName;
|
99
|
CdmDbExportMapping<BerlinModelExportState, BerlinModelExportConfigurator, IExportTransformer> mapping = new CdmDbExportMapping<BerlinModelExportState, BerlinModelExportConfigurator, IExportTransformer>(tableName);
|
100
|
mapping.addMapper(IdMapper.NewInstance("NameId"));
|
101
|
mapping.addMapper(MethodMapper.NewInstance("RankFk", this));
|
102
|
mapping.addMapper(MethodMapper.NewInstance("SupraGenericName", this));
|
103
|
mapping.addMapper(MethodMapper.NewInstance("Genus", this));
|
104
|
mapping.addMapper(MethodMapper.NewInstance("NameCache", this));
|
105
|
mapping.addMapper(MethodMapper.NewInstance("FullNameCache", this));
|
106
|
mapping.addMapper(MethodMapper.NewInstance("PreliminaryFlag", this));
|
107
|
mapping.addMapper(DbStringMapper.NewInstance("infraGenericEpithet", "GenusSubDivisionEpi"));
|
108
|
mapping.addMapper(DbStringMapper.NewInstance("SpecificEpithet", "SpeciesEpi"));
|
109
|
mapping.addMapper(DbStringMapper.NewInstance("infraSpecificEpithet", "InfraSpeciesEpi"));
|
110
|
mapping.addMapper(DbStringMapper.NewInstance("appendedPhrase", "UnnamedNamePhrase"));
|
111
|
mapping.addMapper(DbBooleanMapper.NewInstance("isHybridFormula", "HybridFormulaFlag", false, false));
|
112
|
mapping.addMapper(DbBooleanMapper.NewInstance("isMonomHybrid", "MonomHybFlag", false, false));
|
113
|
mapping.addMapper(DbBooleanMapper.NewInstance("isBinomHybrid", "BinomHybFlag", false, false));
|
114
|
mapping.addMapper(DbBooleanMapper.NewInstance("isTrinomHybrid", "TrinomHybFlag", false, false));
|
115
|
mapping.addMapper(DbStringMapper.NewFacultativeInstance("cultivarName", "CultivarName"));
|
116
|
|
117
|
mapping.addMapper(TeamOrPersonMapper.NewInstance("combinationAuthorship", "AuthorTeamFk"));
|
118
|
mapping.addMapper(TeamOrPersonMapper.NewInstance("exCombinationAuthorship", "ExAuthorTeamFk"));
|
119
|
mapping.addMapper(TeamOrPersonMapper.NewInstance("basionymAuthorship", "BasAuthorTeamFk"));
|
120
|
mapping.addMapper(TeamOrPersonMapper.NewInstance("exBasionymAuthorship", "ExBasAuthorTeamFk"));
|
121
|
|
122
|
mapping.addMapper(DbObjectMapper.NewInstance("nomenclaturalReference", "NomRefFk"));
|
123
|
mapping.addMapper(RefDetailMapper.NewInstance("nomenclaturalMicroReference","nomenclaturalReference", "NomRefDetailFk"));
|
124
|
mapping.addMapper(CreatedAndNotesMapper.NewInstance(false));
|
125
|
ExtensionType sourceAccExtensionType = (ExtensionType)getTermService().find(BerlinModelTransformer.SOURCE_ACC_UUID);
|
126
|
if (sourceAccExtensionType != null){
|
127
|
mapping.addMapper(DbExtensionMapper.NewInstance(sourceAccExtensionType, "Source_Acc"));
|
128
|
}
|
129
|
mapping.addCollectionMapping(getNomStatusMapping());
|
130
|
|
131
|
|
132
|
|
133
|
//TODO
|
134
|
//CultivarGroupName
|
135
|
//NameSourceRefFk
|
136
|
// ,[Source_ACC]
|
137
|
|
138
|
//publicationYear
|
139
|
//originalPublicationYear
|
140
|
//breed
|
141
|
// INonViralName n = null;
|
142
|
//n.getNomenclaturalMicroReference()
|
143
|
return mapping;
|
144
|
}
|
145
|
|
146
|
private CollectionExportMapping getNomStatusMapping(){
|
147
|
String tableName = "NomStatusRel";
|
148
|
String collectionAttribute = "status";
|
149
|
IdMapper parentMapper = IdMapper.NewInstance("NameFk");
|
150
|
CollectionExportMapping mapping = CollectionExportMapping.NewInstance(tableName, collectionAttribute, parentMapper);
|
151
|
mapping.addMapper(MethodMapper.NewInstance("NomStatusFk", this.getClass(), "getNomStatusFk", NomenclaturalStatus.class));
|
152
|
mapping.addMapper(DbObjectMapper.NewInstance("citation", "NomStatusRefFk"));
|
153
|
mapping.addMapper(RefDetailMapper.NewInstance("citationMicroReference","citation", "NomStatusRefDetailFk"));
|
154
|
mapping.addMapper(DbMarkerMapper.NewInstance(MarkerType.IS_DOUBTFUL(), "DoubtfulFlag", false));
|
155
|
mapping.addMapper(CreatedAndNotesMapper.NewInstance());
|
156
|
|
157
|
return mapping;
|
158
|
}
|
159
|
|
160
|
@Override
|
161
|
protected void doInvoke(BerlinModelExportState state){
|
162
|
try{
|
163
|
logger.info("start make "+pluralString+" ...");
|
164
|
boolean success = true ;
|
165
|
doDelete(state);
|
166
|
|
167
|
TransactionStatus txStatus = startTransaction(true);
|
168
|
logger.info("load "+pluralString+" ...");
|
169
|
List<TaxonName> names = getObjectList();
|
170
|
|
171
|
CdmDbExportMapping<BerlinModelExportState, BerlinModelExportConfigurator, IExportTransformer> mapping = getMapping();
|
172
|
mapping.initialize(state);
|
173
|
logger.info("save "+pluralString+" ...");
|
174
|
int count = 0;
|
175
|
for (TaxonName name : names){
|
176
|
doCount(count++, modCount, pluralString);
|
177
|
success &= mapping.invoke(name);
|
178
|
//TODO rank = null or rank < genus and genusOrUninomial != null
|
179
|
}
|
180
|
commitTransaction(txStatus);
|
181
|
logger.info("end make " + pluralString+ " ..." + getSuccessString(success));
|
182
|
|
183
|
if (!success){
|
184
|
String message = "An undefined error occurred during Taxonname export";
|
185
|
state.getResult().addError(message);
|
186
|
}
|
187
|
return;
|
188
|
}catch(SQLException e){
|
189
|
e.printStackTrace();
|
190
|
logger.error(e.getMessage());
|
191
|
state.getResult().addException(e);
|
192
|
return;
|
193
|
}
|
194
|
}
|
195
|
|
196
|
protected List<TaxonName> getObjectList(){
|
197
|
List<TaxonName> list = getNameService().list(null,100000000, null,null,null);
|
198
|
return list;
|
199
|
}
|
200
|
|
201
|
|
202
|
protected boolean doDelete(BerlinModelExportState state){
|
203
|
BerlinModelExportConfigurator bmeConfig = state.getConfig();
|
204
|
|
205
|
String sql;
|
206
|
Source destination = bmeConfig.getDestination();
|
207
|
//RelPTaxon
|
208
|
sql = "DELETE FROM RelPTaxon";
|
209
|
destination.setQuery(sql);
|
210
|
destination.update(sql);
|
211
|
//Fact
|
212
|
sql = "DELETE FROM Fact";
|
213
|
destination.setQuery(sql);
|
214
|
destination.update(sql);
|
215
|
//PTaxon
|
216
|
sql = "DELETE FROM PTaxon";
|
217
|
destination.setQuery(sql);
|
218
|
destination.update(sql);
|
219
|
|
220
|
//NameHistory
|
221
|
sql = "DELETE FROM NameHistory";
|
222
|
destination.setQuery(sql);
|
223
|
destination.update(sql);
|
224
|
//RelName
|
225
|
sql = "DELETE FROM RelName";
|
226
|
destination.setQuery(sql);
|
227
|
destination.update(sql);
|
228
|
//NomStatusRel
|
229
|
sql = "DELETE FROM NomStatusRel";
|
230
|
destination.setQuery(sql);
|
231
|
destination.update(sql);
|
232
|
//Name
|
233
|
sql = "DELETE FROM Name";
|
234
|
destination.setQuery(sql);
|
235
|
destination.update(sql);
|
236
|
return true;
|
237
|
}
|
238
|
|
239
|
|
240
|
/* (non-Javadoc)
|
241
|
* @see eu.etaxonomy.cdm.io.common.CdmIoBase#isIgnore(eu.etaxonomy.cdm.io.common.IImportConfigurator)
|
242
|
*/
|
243
|
@Override
|
244
|
protected boolean isIgnore(BerlinModelExportState state){
|
245
|
return ! state.getConfig().isDoTaxonNames();
|
246
|
}
|
247
|
|
248
|
//called by MethodMapper
|
249
|
@SuppressWarnings("unused")
|
250
|
private static Integer getRankFk(INonViralName name){
|
251
|
Integer result = BerlinModelTransformer.rank2RankId(name.getRank());
|
252
|
if (result == null){
|
253
|
logger.warn ("Rank = null is not allowed in Berlin Model. Rank was changed to KINGDOM: " + name);
|
254
|
result = 1;
|
255
|
}
|
256
|
return result;
|
257
|
}
|
258
|
|
259
|
//called by MethodMapper
|
260
|
@SuppressWarnings("unused")
|
261
|
private static Integer getNomStatusFk(NomenclaturalStatus status){
|
262
|
return BerlinModelTransformer.nomStatus2nomStatusFk(status.getType());
|
263
|
}
|
264
|
|
265
|
//called by MethodMapper
|
266
|
@SuppressWarnings("unused")
|
267
|
private static String getSupraGenericName(INonViralName name){
|
268
|
if (name.isSupraGeneric()){
|
269
|
return name.getGenusOrUninomial();
|
270
|
}else{
|
271
|
return null;
|
272
|
}
|
273
|
}
|
274
|
|
275
|
//called by MethodMapper
|
276
|
@SuppressWarnings("unused")
|
277
|
private static String getGenus(INonViralName name){
|
278
|
if (! name.isSupraGeneric()){
|
279
|
return name.getGenusOrUninomial();
|
280
|
}else{
|
281
|
return null;
|
282
|
}
|
283
|
}
|
284
|
|
285
|
//called by MethodMapper
|
286
|
@SuppressWarnings("unused")
|
287
|
private static String getNameCache(INonViralName name){
|
288
|
if (name.isProtectedNameCache()){
|
289
|
return name.getNameCache();
|
290
|
}else{
|
291
|
return null;
|
292
|
}
|
293
|
}
|
294
|
|
295
|
//called by MethodMapper
|
296
|
@SuppressWarnings("unused")
|
297
|
private static String getFullNameCache(INonViralName name){
|
298
|
if (name.isProtectedTitleCache()){
|
299
|
return name.getTitleCache();
|
300
|
}else{
|
301
|
return null;
|
302
|
}
|
303
|
}
|
304
|
|
305
|
//called by MethodMapper
|
306
|
@SuppressWarnings("unused")
|
307
|
private static Boolean getPreliminaryFlag(INonViralName name){
|
308
|
if (name.isProtectedTitleCache() || name.isProtectedNameCache()){
|
309
|
if (name.isProtectedTitleCache() && name.isProtectedNameCache()){
|
310
|
logger.warn("protectedTitleCache and protectedNameCache do not have the same value for name " + name.getTitleCache() + ". This can not be mapped appropriately to the Berlin Model ");
|
311
|
}
|
312
|
return true;
|
313
|
}else{
|
314
|
return false;
|
315
|
}
|
316
|
}
|
317
|
|
318
|
|
319
|
|
320
|
/* (non-Javadoc)
|
321
|
* @see eu.etaxonomy.cdm.io.berlinModel.out.BerlinModelExportBase#getStandardMethodParameter()
|
322
|
*/
|
323
|
@Override
|
324
|
public Class<? extends CdmBase> getStandardMethodParameter() {
|
325
|
return standardMethodParameter;
|
326
|
}
|
327
|
|
328
|
}
|