DistributeurFabricantAssoIteStepConfig.java

package com.sintia.ffl.admin.optique.services.batch.refpromoteur.export.ite;

import com.sintia.ffl.admin.optique.dal.entities.DistributeurFabricantAssoIte;
import com.sintia.ffl.admin.staging.FileUtils;
import com.sintia.ffl.admin.staging.GenerericJDBCItemReadFromDB;
import com.sintia.ffl.admin.staging.step.export.jdbc.AbstractSinglePromoteurJDBCExportStepConfig;
import com.sintia.ffl.adminui.commons.enums.TypeStaging;
import com.sintia.ffl.core.commons.enums.CodePromoteur;
import org.springframework.batch.core.Step;

import org.springframework.batch.core.configuration.annotation.StepScope;
import org.springframework.batch.integration.async.AsyncItemWriter;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.batch.core.repository.JobRepository;
import org.springframework.transaction.PlatformTransactionManager;


import javax.sql.DataSource;
import java.io.IOException;
import java.sql.Timestamp;

@Configuration
public class DistributeurFabricantAssoIteStepConfig extends
        AbstractSinglePromoteurJDBCExportStepConfig<DistributeurFabricantAssoIte> {

    private static final String QUERY = "select d_creation , d_maj,  id_distributeur_fabricant_asso_ite, id_distributeur_ite, id_fabricant_ite, b_saisie " +
            "from distributeur_fabricant_asso_ite";

    public DistributeurFabricantAssoIteStepConfig() {
        super(TypeStaging.REF_PROMOTEUR,
                (rs, rowNum) -> {
                    Timestamp dCreation = rs.getTimestamp("d_creation");
                    Timestamp dMaj = rs.getTimestamp("d_maj");
                    return new DistributeurFabricantAssoIte(
                            rs.getInt("id_distributeur_fabricant_asso_ite"),
                            rs.getInt("id_distributeur_ite"),
                            rs.getInt("id_fabricant_ite"),
                            dCreation == null ? null : dCreation.toLocalDateTime(),
                            dMaj == null ? null : dMaj.toLocalDateTime(),
                            rs.getString("b_saisie")
                    );
                },
                CodePromoteur.ITE);
    }

    @Bean
    public Step distributeurFabricantAssoIteStep(JobRepository jobRepository, PlatformTransactionManager transactionManager, FileUtils fileUtils,
                                                 DataSource dataSource) throws IOException {
        return super.buildStep( jobRepository,  transactionManager, fileUtils, dataSource);
    }


    @Bean("distributeurFabricantAssoIteReader")
    @StepScope
    @Override
    protected GenerericJDBCItemReadFromDB<DistributeurFabricantAssoIte> reader(
            DataSource dataSource,
            @Value("#{jobParameters['idPromoteur']}") Integer idPromoteur,
            @Value("#{jobParameters['codePromoteur']}") String codePromoteur) throws IOException {
        return super.buildReader(dataSource, QUERY, codePromoteur);
    }


    @Bean("distributeurFabricantAssoIteWriter")
    @StepScope
    @Override
    public AsyncItemWriter<DistributeurFabricantAssoIte> writer(
            FileUtils fileUtils,
            @Value("#{jobParameters['envSource'] ?: 'pprod'}") String envSource,
            @Value("#{jobParameters['envCible'] ?: 'pprod'}") String envCible,
            @Value("#{jobParameters['codePromoteur']}") String codePromoteur
    ) throws IOException {
        return super.buildWriter(fileUtils, envSource, envCible, codePromoteur);
    }
}