Project

General

Profile

Download (4.6 KB) Statistics
| Branch: | Revision:
1
// $Id$
2
/**
3
* Copyright (C) 2007 EDIT
4
* European Distributed Institute of Taxonomy 
5
* http://www.e-taxonomy.eu
6
* 
7
* The contents of this file are subject to the Mozilla Public License Version 1.1
8
* See LICENSE.TXT at the top of this package for the full license terms.
9
*/
10

    
11
package eu.etaxonomy.cdm.io.pesi.erms;
12

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

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

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

    
32
/**
33
 * @author a.mueller
34
 * @created 12.03.2010
35
 */
36
@Component
37
public class ErmsNotesSourcesImport extends ErmsImportBase<CommonTaxonName> {
38
	@SuppressWarnings("unused")
39
	private static final Logger logger = Logger.getLogger(ErmsNotesSourcesImport.class);
40
	
41
	
42
//************************** VARIABLES ********************************************
43
	
44
	private static String pluralString = "note sources";
45
	private static String dbTableName = "notes_sources";
46
	private static final Class<?> cdmTargetClass = DescriptionElementSource.class;
47

    
48
	private DbImportMapping<?,?> mapping;
49

    
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

    
63
	/* (non-Javadoc)
64
	 * @see eu.etaxonomy.cdm.io.erms.ErmsImportBase#getRecordQuery(eu.etaxonomy.cdm.io.erms.ErmsImportConfigurator)
65
	 */
66
	@Override
67
	protected String getRecordQuery(ErmsImportConfigurator config) {
68
		String strQuery = 
69
			" SELECT * " + 
70
			" FROM vernaculars_sources " +
71
			" WHERE vernacular_id IN (" + ID_LIST_TOKEN + ") AND " +
72
					" source_id IN (" + ID_LIST_TOKEN + ")";
73
		return strQuery;
74
	}
75

    
76
	@Override
77
	protected String getIdQuery() {
78
		String strQuery = 
79
			" SELECT vernacular_id, source_id " + 
80
			" FROM vernaculars_sources " 
81
			;
82
		return strQuery;
83
	}
84
	
85
	@Override
86
	protected DbImportMapping<?,?> getMapping() {
87
		if (mapping == null){
88
			mapping = new DbImportMapping();
89
			String vernacularNamespace = ErmsVernacularImport.VERNACULAR_NAMESPACE;
90
			String referenceNamespace = ErmsReferenceImport.REFERENCE_NAMESPACE;
91
			mapping.addMapper(DbImportDescriptionElementSourceCreationMapper.NewInstance("vernacular_id", vernacularNamespace, "source_id", referenceNamespace ));
92
		}
93
		return mapping;
94
	}
95

    
96
	@Override
97
	public Map getRelatedObjectsForPartition(ResultSet rs, ErmsImportState state) {
98
		String nameSpace;
99
		Class<?> cdmClass;
100
		Set<String> idSet;
101
		Map<Object, Map<String, ? extends CdmBase>> result = new HashMap<Object, Map<String, ? extends CdmBase>>();
102
		
103
		try{
104
			Set<String> vernacularIdSet = new HashSet<String>();
105
			Set<String> sourceIdSet = new HashSet<String>();
106
			while (rs.next()){
107
				handleForeignKey(rs, vernacularIdSet, "vernacular_id");
108
				handleForeignKey(rs, sourceIdSet, "source_id");
109
			}
110
			
111
			//vernacular map
112
			nameSpace = ErmsVernacularImport.VERNACULAR_NAMESPACE;
113
			cdmClass = CommonTaxonName.class;
114
			idSet = vernacularIdSet;
115
			Map<String, CommonTaxonName> vernacularMap = (Map<String, CommonTaxonName>)getCommonService().getSourcedObjectsByIdInSource(cdmClass, idSet, nameSpace);
116
			result.put(nameSpace, vernacularMap);
117
			
118
			
119
			//reference map
120
			nameSpace = ErmsReferenceImport.REFERENCE_NAMESPACE;
121
			cdmClass = Reference.class;
122
			idSet = sourceIdSet;
123
			Map<String, Reference> referenceMap = (Map<String, Reference>)getCommonService().getSourcedObjectsByIdInSource(cdmClass, idSet, nameSpace);
124
			result.put(nameSpace, referenceMap);
125
	
126
		} catch (SQLException e) {
127
			throw new RuntimeException(e);
128
		}
129
		return result;
130
	}
131
	
132
	@Override
133
	protected boolean doCheck(ErmsImportState state) {
134
		IOValidator<ErmsImportState> validator = new ErmsNoteSourceImportValidator();
135
		return validator.validate(state);
136
	}
137
	
138
	@Override
139
	protected boolean isIgnore(ErmsImportState state) {
140
		boolean isDo = state.getConfig().isDoVernaculars() && state.getConfig().isDoVernaculars();
141
		return ! isDo ;
142
	}
143
}
(10-10/17)