org.eclipse.jnosql.databases.elasticsearch.mapping.DocumentManagerSupplier Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of jnosql-elasticsearch Show documentation
Show all versions of jnosql-elasticsearch Show documentation
The Eclipse JNoSQL layer to Elasticsearch
The newest version!
/*
* Copyright (c) 2022 Eclipse Contribuitor
* All rights reserved. This program and the accompanying materials
* and Apache License v2.0 which accompanies this distribution.
* The Eclipse Public License is available at http://www.eclipse.org/legal/epl-v10.html
* and the Apache License v2.0 is available at http://www.opensource.org/licenses/apache2.0.php.
* You may elect to redistribute this code under either of these licenses.
*/
package org.eclipse.jnosql.databases.elasticsearch.mapping;
import jakarta.data.exceptions.MappingException;
import jakarta.enterprise.context.ApplicationScoped;
import jakarta.enterprise.inject.Disposes;
import jakarta.enterprise.inject.Produces;
import jakarta.enterprise.inject.Typed;
import org.eclipse.jnosql.communication.Settings;
import org.eclipse.jnosql.databases.elasticsearch.communication.ElasticsearchDocumentConfiguration;
import org.eclipse.jnosql.databases.elasticsearch.communication.ElasticsearchDocumentManager;
import org.eclipse.jnosql.databases.elasticsearch.communication.ElasticsearchDocumentManagerFactory;
import org.eclipse.jnosql.mapping.core.config.MicroProfileSettings;
import java.util.Optional;
import java.util.function.Supplier;
import java.util.logging.Level;
import java.util.logging.Logger;
import static org.eclipse.jnosql.mapping.core.config.MappingConfigurations.DOCUMENT_DATABASE;
@ApplicationScoped
class DocumentManagerSupplier implements Supplier {
private static final Logger LOGGER = Logger.getLogger(DocumentManagerSupplier.class.getName());
@Override
@Produces
@Typed(ElasticsearchDocumentManager.class)
public ElasticsearchDocumentManager get() {
Settings settings = MicroProfileSettings.INSTANCE;
ElasticsearchDocumentConfiguration configuration = new ElasticsearchDocumentConfiguration();
ElasticsearchDocumentManagerFactory factory = configuration.apply(settings);
Optional database = settings.get(DOCUMENT_DATABASE, String.class);
String db = database.orElseThrow(() -> new MappingException("Please, inform the database filling up the property "
+ DOCUMENT_DATABASE));
ElasticsearchDocumentManager manager = factory.apply(db);
LOGGER.log(Level.FINEST, "Starting a ElasticsearchDocumentManager instance using Eclipse MicroProfile Config," +
" database name: " + db);
return manager;
}
public void close(@Disposes ElasticsearchDocumentManager manager) {
LOGGER.log(Level.FINEST, "Closing ElasticsearchDocumentManager resource, database name: " + manager.name());
manager.close();
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy