/* * * * 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.model.ElasticSearchEntity; import com.vsct.dt.hesperides.indexation.model.TemplateIndexation; import org.slf4j.Logger; import org.slf4j.LoggerFactory; /** * Created by william_montaz on 09/12/2014. */ public final class IndexNewTemplateCommand implements ElasticSearchIndexationCommand<TemplateIndexation> { private static final Logger LOGGER = LoggerFactory.getLogger(IndexNewTemplateCommand.class); private final TemplateIndexation template; public IndexNewTemplateCommand(final TemplateIndexation template) { this.template = template; } @Override public Void index(final ElasticSearchClient elasticSearchClient) { String propertiesAsString = null; try { propertiesAsString = ElasticSearchMappers.TEMPLATE_WRITER.writeValueAsString(template); } catch (final JsonProcessingException e) { LOGGER.error("Could not serialize template "+template); throw new RuntimeException(e); } ElasticSearchEntity<TemplateIndexation> entity = elasticSearchClient.withResponseReader(ElasticSearchMappers.ES_ENTITY_TEMPLATE_READER) .post("/templates/" + template.getId(), propertiesAsString); LOGGER.info("Successfully indexed new template {}", template); return null; } }