Java tutorial
/* * * * This file is part of the Hesperides distribution. * * (https://github.com/voyages-sncf-technologies/hesperides) * * Copyright (c) 2016 VSCT. * * * * Hesperides is free software: you can redistribute it and/or modify * * it under the terms of the GNU General Public License as * * published by the Free Software Foundation, version 3. * * * * Hesperides is distributed in the hope that it will be useful, but * * WITHOUT ANY WARRANTY; without even the implied warranty of * * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * * General Public License for more details. * * * * You should have received a copy of the GNU General Public License * * along with this program. If not, see <http://www.gnu.org/licenses/>. * * */ package com.vsct.dt.hesperides.indexation.command; import com.fasterxml.jackson.core.JsonProcessingException; import com.vsct.dt.hesperides.indexation.ElasticSearchClient; import com.vsct.dt.hesperides.indexation.ElasticSearchIndexationCommand; import com.vsct.dt.hesperides.indexation.mapper.ElasticSearchMappers; import com.vsct.dt.hesperides.indexation.mapper.SingleToBulkMapper; import com.vsct.dt.hesperides.indexation.model.ElasticSearchEntity; import com.vsct.dt.hesperides.indexation.model.TemplateIndexation; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import java.util.List; import java.util.stream.Collectors; /** * Created by william_montaz on 09/12/2014. */ public final class IndexNewTemplateCommandBulk implements ElasticSearchIndexationCommand<TemplateIndexation> { private static final Logger LOGGER = LoggerFactory.getLogger(IndexNewTemplateCommandBulk.class); private final List<TemplateIndexation> templates; public IndexNewTemplateCommandBulk(final List<TemplateIndexation> templates) { this.templates = templates; } @Override public Void index(final ElasticSearchClient elasticSearchClient) { String body; List<SingleToBulkMapper> propertiesAsString; LOGGER.info("Index {} templates.", templates.size()); propertiesAsString = templates.stream().map(template -> { LOGGER.info("Index template with namespace {}.", template.getNamespace()); try { return new SingleToBulkMapper(template.getId(), ElasticSearchMappers.TEMPLATE_WRITER.writeValueAsString(template)); } catch (final JsonProcessingException e) { LOGGER.error("Could not serialize template " + template); throw new RuntimeException(e); } }).collect(Collectors.toList()); if (propertiesAsString != null && propertiesAsString.size() > 0) { body = propertiesAsString.stream().map(template -> template.toString()).collect(Collectors.joining("")); ElasticSearchEntity<TemplateIndexation> entity = elasticSearchClient .withResponseReader(ElasticSearchMappers.ES_ENTITY_TEMPLATE_READER) .post("/templates/_bulk", body); LOGGER.info("Successfully indexed new templates {}", propertiesAsString.size()); } return null; } }