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