Project

General

Profile

Download (4.59 KB) Statistics
| Branch: | Revision:
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.io.pesi.erms;
11

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

    
19
import org.apache.log4j.Logger;
20
import org.springframework.stereotype.Component;
21

    
22
import eu.etaxonomy.cdm.io.common.IOValidator;
23
import eu.etaxonomy.cdm.io.common.mapping.DbImportDescriptionElementSourceCreationMapper;
24
import eu.etaxonomy.cdm.io.common.mapping.DbImportMapping;
25
import eu.etaxonomy.cdm.io.pesi.erms.validation.ErmsNoteSourceImportValidator;
26
import eu.etaxonomy.cdm.model.common.CdmBase;
27
import eu.etaxonomy.cdm.model.description.CommonTaxonName;
28
import eu.etaxonomy.cdm.model.description.DescriptionElementSource;
29
import eu.etaxonomy.cdm.model.reference.Reference;
30

    
31
/**
32
 * @author a.mueller
33
 * @since 12.03.2010
34
 */
35
@Component
36
public class ErmsNotesSourcesImport extends ErmsImportBase<CommonTaxonName> {
37
    private static final long serialVersionUID = -5197101648269924453L;
38

    
39
    @SuppressWarnings("unused")
40
	private static final Logger logger = Logger.getLogger(ErmsNotesSourcesImport.class);
41

    
42

    
43
//************************** VARIABLES ********************************************
44

    
45
	private static String pluralString = "note sources";
46
	private static String dbTableName = "notes_sources";
47
	private static final Class<?> cdmTargetClass = DescriptionElementSource.class;
48

    
49
	private DbImportMapping<ErmsImportState, ErmsImportConfigurator> mapping;
50

    
51
//******************************************* CONSTRUCTOR *******************************
52

    
53
	/**
54
	 * @param dbTableName
55
	 * @param pluralString
56
	 * @param dbTableName
57
	 */
58
	public ErmsNotesSourcesImport() {
59
		super(pluralString, dbTableName, cdmTargetClass);
60
	}
61

    
62
	@Override
63
	protected String getRecordQuery(ErmsImportConfigurator config) {
64
		String strQuery =
65
			" SELECT * " +
66
			" FROM vernaculars_sources " +
67
			" WHERE vernacular_id IN (" + ID_LIST_TOKEN + ") AND " +
68
					" source_id IN (" + ID_LIST_TOKEN + ")";
69
		return strQuery;
70
	}
71

    
72
	@Override
73
	protected String getIdQuery() {
74
		String strQuery =
75
			" SELECT vernacular_id, source_id " +
76
			" FROM vernaculars_sources "
77
			;
78
		return strQuery;
79
	}
80

    
81
	@Override
82
	protected DbImportMapping<ErmsImportState, ErmsImportConfigurator> getMapping() {
83
		if (mapping == null){
84
			mapping = new DbImportMapping<>();
85
			String vernacularNamespace = ErmsImportBase.VERNACULAR_NAMESPACE;
86
			String referenceNamespace = ErmsImportBase.REFERENCE_NAMESPACE;
87
			mapping.addMapper(DbImportDescriptionElementSourceCreationMapper.NewInstance("vernacular_id", vernacularNamespace, "source_id", referenceNamespace ));
88
		}
89
		return mapping;
90
	}
91

    
92
	@Override
93
	public Map<Object, Map<String, ? extends CdmBase>> getRelatedObjectsForPartition(ResultSet rs, ErmsImportState state) {
94
		String nameSpace;
95
		Class<?> cdmClass;
96
		Set<String> idSet;
97
		Map<Object, Map<String, ? extends CdmBase>> result = new HashMap<>();
98

    
99
		try{
100
			Set<String> vernacularIdSet = new HashSet<String>();
101
			Set<String> sourceIdSet = new HashSet<String>();
102
			while (rs.next()){
103
				handleForeignKey(rs, vernacularIdSet, "vernacular_id");
104
				handleForeignKey(rs, sourceIdSet, "source_id");
105
			}
106

    
107
			//vernacular map
108
			nameSpace = ErmsImportBase.VERNACULAR_NAMESPACE;
109
			cdmClass = CommonTaxonName.class;
110
			idSet = vernacularIdSet;
111
			Map<String, CommonTaxonName> vernacularMap = (Map<String, CommonTaxonName>)getCommonService().getSourcedObjectsByIdInSource(cdmClass, idSet, nameSpace);
112
			result.put(nameSpace, vernacularMap);
113

    
114

    
115
			//reference map
116
			nameSpace = ErmsImportBase.REFERENCE_NAMESPACE;
117
			cdmClass = Reference.class;
118
			idSet = sourceIdSet;
119
			@SuppressWarnings("unchecked")
120
            Map<String, Reference> referenceMap = (Map<String, Reference>)getCommonService().getSourcedObjectsByIdInSource(cdmClass, idSet, nameSpace);
121
			result.put(nameSpace, referenceMap);
122

    
123
		} catch (SQLException e) {
124
			throw new RuntimeException(e);
125
		}
126
		return result;
127
	}
128

    
129
	@Override
130
	protected boolean doCheck(ErmsImportState state) {
131
		IOValidator<ErmsImportState> validator = new ErmsNoteSourceImportValidator();
132
		return validator.validate(state);
133
	}
134

    
135
	@Override
136
	protected boolean isIgnore(ErmsImportState state) {
137
		boolean isDo = state.getConfig().isDoVernaculars() && state.getConfig().isDoVernaculars();
138
		return ! isDo ;
139
	}
140
}
(10-10/17)