Project

General

Profile

Download (4.01 KB) Statistics
| Branch: | Tag: | 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.berlinModel.in.validation;
12

    
13
import java.sql.ResultSet;
14
import java.sql.SQLException;
15

    
16
import org.apache.log4j.Logger;
17

    
18
import eu.etaxonomy.cdm.io.berlinModel.in.BerlinModelImportConfigurator;
19
import eu.etaxonomy.cdm.io.berlinModel.in.BerlinModelImportState;
20
import eu.etaxonomy.cdm.io.common.IOValidator;
21
import eu.etaxonomy.cdm.io.common.Source;
22

    
23
/**
24
 * @author a.mueller
25
 * @created 17.02.2010
26
 * @version 1.0
27
 */
28
public class BerlinModelTaxonRelationImportValidator implements IOValidator<BerlinModelImportState> {
29
	private static final Logger logger = Logger.getLogger(BerlinModelTaxonRelationImportValidator.class);
30

    
31
	/* (non-Javadoc)
32
	 * @see eu.etaxonomy.cdm.io.common.IOValidator#validate(eu.etaxonomy.cdm.io.common.IoStateBase)
33
	 */
34
	public boolean validate(BerlinModelImportState state) {
35
		boolean result = true;
36
		BerlinModelImportConfigurator bmiConfig = state.getConfig();
37
		logger.warn("Checking for TaxonRelations not yet fully implemented");
38
		result &= checkInActivatedStatus(bmiConfig);
39
		
40
		return result;
41
	}
42
	
43
	
44
	private boolean checkInActivatedStatus(BerlinModelImportConfigurator bmiConfig){
45
		try {
46
			boolean result = true;
47
			Source source = bmiConfig.getSource();
48
			String strSQL = 
49
				" SELECT RelPTaxon.RelPTaxonId, RelPTaxon.RelQualifierFk, FromName.FullNameCache AS FromName, RelPTaxon.PTNameFk1 AS FromNameID, "  +
50
		    			" Status.Status AS FromStatus, ToName.FullNameCache AS ToName, RelPTaxon.PTNameFk2 AS ToNameId, ToStatus.Status AS ToStatus, FromTaxon.DoubtfulFlag AS doubtfulFrom, ToTaxon.DoubtfulFlag AS doubtfulTo" + 
51
    			" FROM PTaxon AS FromTaxon " + 
52
    				" INNER JOIN RelPTaxon ON FromTaxon.PTNameFk = RelPTaxon.PTNameFk1 AND FromTaxon.PTRefFk = RelPTaxon.PTRefFk1 " + 
53
    				" INNER JOIN PTaxon AS ToTaxon ON RelPTaxon.PTNameFk2 = ToTaxon.PTNameFk AND RelPTaxon.PTRefFk2 = ToTaxon.PTRefFk " + 
54
    				" INNER JOIN Name AS ToName ON ToTaxon.PTNameFk = ToName.NameId " + 
55
    				" INNER JOIN Name AS FromName ON FromTaxon.PTNameFk = FromName.NameId " + 
56
    				" INNER JOIN Status ON FromTaxon.StatusFk = Status.StatusId AND FromTaxon.StatusFk = Status.StatusId " + 
57
    				" INNER JOIN Status AS ToStatus ON ToTaxon.StatusFk = ToStatus.StatusId AND ToTaxon.StatusFk = ToStatus.StatusId " +
58
				" WHERE (RelPTaxon.RelQualifierFk = - 99)";
59
			
60
			ResultSet rs = source.getResultSet(strSQL);
61
			boolean firstRow = true;
62
			int i = 0;
63
			while (rs.next()){
64
				i++;
65
				if (firstRow){
66
					System.out.println("========================================================");
67
					logger.warn("There are TaxonRelationships with status 'inactivated'(-99)!");
68
					System.out.println("========================================================");
69
				}
70
				
71
				int relPTaxonId = rs.getInt("RelPTaxonId");
72
				String fromName = rs.getString("FromName");
73
				int fromNameID = rs.getInt("FromNameID");
74
				String fromStatus = rs.getString("FromStatus");
75
				
76
				String toName = rs.getString("ToName");
77
				int toNameId = rs.getInt("ToNameId");
78
				String toStatus = rs.getString("ToStatus");
79
				String doubtfulFrom = String.valueOf(rs.getObject("doubtfulFrom"));
80
				String doubtfulTo = String.valueOf(rs.getObject("doubtfulTo"));
81
				
82
				
83
				System.out.println("RelPTaxonId:" + relPTaxonId + 
84
						"\n  FromName: " + fromName + "\n  FromNameID: " + fromNameID + "\n  FromStatus: " + fromStatus + "\n  FromDoubtful: " + doubtfulFrom + 
85
						"\n  ToName: " + toName + "\n  ToNameId: " + toNameId + "\n  ToStatus: " + toStatus + "\n  ToDoubtful: " + doubtfulTo );
86
				result = firstRow = false;
87
			}
88
			if (i > 0){
89
				System.out.println(" ");
90
			}
91
			
92
			return result;
93
		} catch (SQLException e) {
94
			e.printStackTrace();
95
			return false;
96
		}
97
	}
98
	
99

    
100

    
101
}
(15-15/19)