Project

General

Profile

Download (3.56 KB) Statistics
| Branch: | Revision:
1
/**
2
* Copyright (C) 2016 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.app.cyprus;
10

    
11
import java.io.File;
12
import java.util.UUID;
13

    
14
import org.apache.log4j.Logger;
15

    
16
import eu.etaxonomy.cdm.app.common.CdmDestinations;
17
import eu.etaxonomy.cdm.common.URI;
18
import eu.etaxonomy.cdm.database.DatabaseTypeEnum;
19
import eu.etaxonomy.cdm.database.DbSchemaValidation;
20
import eu.etaxonomy.cdm.database.ICdmDataSource;
21
import eu.etaxonomy.cdm.io.common.CdmDefaultImport;
22
import eu.etaxonomy.cdm.io.common.IImportConfigurator.CHECK;
23
import eu.etaxonomy.cdm.io.common.ImportResult;
24
import eu.etaxonomy.cdm.io.fact.temporal.in.PhenologyExcelImportConfigurator;
25
import eu.etaxonomy.cdm.model.reference.Reference;
26
import eu.etaxonomy.cdm.model.reference.ReferenceFactory;
27

    
28
/**
29
 * Import for Flora of Cyprus flowering periods/phenology.
30
 *
31
 * https://dev.e-taxonomy.eu/redmine/issues/9030
32
 *
33
 * @author a.mueller
34
 * @since 11.06.2021
35
 */
36
public class CyprusPhenologyActivator {
37

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

    
41
    //database validation status (create, update, validate ...)
42

    
43
//    static final ICdmDataSource cdmDestination = CdmDestinations.localH2();
44
    static final ICdmDataSource cdmDestination = CdmDestinations.cdm_local_cyprus();
45
//    static final ICdmDataSource cdmDestination = CdmDestinations.cdm_production_cyprus();
46

    
47
    static DbSchemaValidation hbm2dll = cdmDestination.getDatabaseType() == DatabaseTypeEnum.H2 ? DbSchemaValidation.CREATE : DbSchemaValidation.VALIDATE;
48

    
49
    static final String fileName = "Cyprus_flowering-period.xls";
50

    
51
    static final UUID uuidSourceRef = UUID.fromString("fe24e1e9-b2df-446d-8abd-62d914d02e15");
52

    
53
    //check - import
54
    static final CHECK check = CHECK.IMPORT_WITHOUT_CHECK;
55

    
56
    private void doImport(ICdmDataSource cdmDestination){
57

    
58
        //make Source
59
        URI source = fileName();
60
//        URI source = uzbekistanChecklist_local();
61

    
62
        PhenologyExcelImportConfigurator config = PhenologyExcelImportConfigurator.NewInstance(source, cdmDestination);
63
        config.setCheck(check);
64
        config.setDbSchemaValidation(hbm2dll);
65
        config.setFloweringStartColumnLabel("flowering period start");
66
        config.setFloweringEndColumnLabel("flowering period end");
67
//        config.setFruitingStartColumnLabel("начало плодоношения");
68
//        config.setFruitingEndColumnLabel("конец плодоношения");
69

    
70
        config.setSourceReference(getSourceReference());
71

    
72
        CdmDefaultImport<PhenologyExcelImportConfigurator> myImport = new CdmDefaultImport<>();
73
        ImportResult result = myImport.invoke(config);
74
        System.out.println(result.createReport());
75
    }
76

    
77
    private URI fileName(){
78
        return URI.create("file:////BGBM-PESIHPC/Cyprus/" + fileName);
79
    }
80
    @SuppressWarnings("unused")
81
    private URI fileName_local(){
82
        File file = new File("C:\\Users\\a.mueller\\BGBM\\Data\\Cyprus\\" + fileName);
83
        return URI.fromFile(file);
84
    }
85

    
86
    private Reference getSourceReference(){
87
        Reference result = ReferenceFactory.newGeneric();
88
        result.setTitle(fileName);
89
        result.setUuid(uuidSourceRef);
90
        return result;
91
    }
92

    
93
    public static void main(String[] args) {
94
        CyprusPhenologyActivator me = new CyprusPhenologyActivator();
95
        me.doImport(cdmDestination);
96
        System.exit(0);
97
    }
98
}
(4-4/5)