
org.eclipse.jnosql.databases.cassandra.mapping.CassandraExtension Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of jnosql-cassandra Show documentation
Show all versions of jnosql-cassandra Show documentation
The Eclipse JNoSQL layer to Cassandra
/*
* Copyright (c) 2022 Contributors to the Eclipse Foundation
* All rights reserved. This program and the accompanying materials
* are made available under the terms of the Eclipse Public License v1.0
* 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.
*
* Contributors:
*
* Otavio Santana
*/
package org.eclipse.jnosql.databases.cassandra.mapping;
import jakarta.enterprise.event.Observes;
import jakarta.enterprise.inject.spi.AfterBeanDiscovery;
import jakarta.enterprise.inject.spi.Extension;
import org.eclipse.jnosql.mapping.reflection.ClassScanner;
import java.util.Set;
import java.util.logging.Logger;
public class CassandraExtension implements Extension {
private static final Logger LOGGER = Logger.getLogger(CassandraExtension.class.getName());
void onAfterBeanDiscovery(@Observes final AfterBeanDiscovery afterBeanDiscovery) {
ClassScanner scanner = ClassScanner.INSTANCE;
Set> crudTypes = scanner.repositories(CassandraRepository.class);
LOGGER.info("Starting the onAfterBeanDiscovery with elements number: " + crudTypes.size());
crudTypes.forEach(type -> afterBeanDiscovery.addBean(new CassandraRepositoryBean(type)));
LOGGER.info("Finished the onAfterBeanDiscovery");
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy