Project

General

Profile

Download (4.57 KB) Statistics
| Branch: | Revision:
1
/**
2
* Copyright (C) 2019 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.greece;
10

    
11
import java.util.Calendar;
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.monitor.IProgressMonitor;
18
import eu.etaxonomy.cdm.database.DbSchemaValidation;
19
import eu.etaxonomy.cdm.database.ICdmDataSource;
20
import eu.etaxonomy.cdm.filter.TaxonNodeFilter.ORDER;
21
import eu.etaxonomy.cdm.io.cdm2cdm.Cdm2CdmImportConfigurator;
22
import eu.etaxonomy.cdm.io.common.CdmDefaultImport;
23
import eu.etaxonomy.cdm.io.common.IImportConfigurator.CHECK;
24
import eu.etaxonomy.cdm.io.common.ITaxonNodeOutStreamPartitioner;
25
import eu.etaxonomy.cdm.io.common.TaxonNodeOutStreamPartitioner;
26
import eu.etaxonomy.cdm.io.common.TaxonNodeOutStreamPartitionerConcurrent;
27
import eu.etaxonomy.cdm.model.common.VerbatimTimePeriod;
28
import eu.etaxonomy.cdm.model.reference.Reference;
29
import eu.etaxonomy.cdm.model.reference.ReferenceFactory;
30

    
31
/**
32
 * @author a.mueller
33
 * @since 17.08.2019
34
 */
35
public class BupleurumExportActivator {
36

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

    
40
    static final ICdmDataSource greeceSource = CdmDestinations.cdm_production_greece_checklist();
41
//    static final ICdmDataSource cdmDestination = CdmDestinations.cdm_local_test_mysql();
42
    static final ICdmDataSource cdmDestination = CdmDestinations.cdm_local_cdmtest_mysql();
43
//    static final ICdmDataSource cdmDestination = CdmDestinations.cdm_test_bupleurum
44

    
45
    static final String sourceRefTitle = "Flora of Greece";
46
    static final UUID sourceRefUuid = UUID.fromString("f88e33e5-1f6a-463e-b6fd-220d5e93d810");
47

    
48
    static final DbSchemaValidation schemaValidation = DbSchemaValidation.CREATE;
49

    
50
    //check - import
51
    static final CHECK check = CHECK.IMPORT_WITHOUT_CHECK;
52

    
53
    static final int partitionSize = 5000;
54

    
55
    static final boolean doTaxa = true;
56
    static final boolean doDescriptions = false;
57

    
58
    static final boolean doConcurrent = false;
59
    //auditing
60
    static final boolean registerAuditing = true;
61

    
62
// ***************** ALL ************************************************//
63

    
64
    UUID uuidBupleurumTaxonNodeFilter = UUID.fromString("51e768cf-321b-4108-8bee-46143996b033");
65

    
66
    private void doImport(ICdmDataSource source, ICdmDataSource destination, DbSchemaValidation hbm2dll){
67

    
68
        String importFrom = " import from "+ source.getDatabase() + " to "+ destination.getDatabase() + " ...";
69
        System.out.println("Start"+importFrom);
70

    
71
        Cdm2CdmImportConfigurator config = Cdm2CdmImportConfigurator.NewInstace(source, destination);
72
        config.setConcurrent(doConcurrent);
73
        config.setDoTaxa(doTaxa);
74
        config.setDoDescriptions(doDescriptions);
75
        config.setSourceReference(getSourceRef());
76

    
77
        IProgressMonitor monitor = config.getProgressMonitor();
78

    
79
        config.setDbSchemaValidation(hbm2dll);
80
        config.getTaxonNodeFilter().orSubtree(uuidBupleurumTaxonNodeFilter);
81
        config.getTaxonNodeFilter().setOrder(ORDER.TREEINDEX);
82
        if (doConcurrent){
83
            ITaxonNodeOutStreamPartitioner partitioner = TaxonNodeOutStreamPartitionerConcurrent
84
                    .NewInstance(config.getSource(), config.getTaxonNodeFilter(),
85
                            8, monitor, 1, TaxonNodeOutStreamPartitioner.fullPropertyPaths);
86
            config.setPartitioner(partitioner);
87
        }
88

    
89
        config.setCheck(check);
90
//        config.setRecordsPerTransaction(partitionSize);
91

    
92
        config.setRegisterAuditing(registerAuditing);
93

    
94
        // invoke import
95
        CdmDefaultImport<Cdm2CdmImportConfigurator> myImport = new CdmDefaultImport<>();
96
        myImport.invoke(config);
97

    
98
        System.out.println("End" + importFrom);
99
    }
100

    
101
    private Reference getSourceRef() {
102
        Reference ref = ReferenceFactory.newDatabase();
103
        ref.setTitle(sourceRefTitle);
104
        ref.setDatePublished(VerbatimTimePeriod.NewVerbatimInstance(Calendar.getInstance()));
105
        ref.setUuid(sourceRefUuid);
106
        return ref;
107
    }
108

    
109
    public static void main(String[] args) {
110
        ICdmDataSource cdmDB = CdmDestinations.chooseDestination(args) != null ? CdmDestinations.chooseDestination(args) : cdmDestination;
111
        BupleurumExportActivator myImport = new BupleurumExportActivator();
112
        myImport.doImport(greeceSource, cdmDB, schemaValidation);
113
        System.exit(0);
114
    }
115
}
(1-1/8)