/*
*
* * 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;
}
}