All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.eclipse.jnosql.mapping.reflection.DefaultEntitiesMetadata Maven / Gradle / Ivy

/*
 *  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.mapping.reflection;


import jakarta.annotation.PostConstruct;
import jakarta.enterprise.context.ApplicationScoped;
import jakarta.inject.Inject;
import org.eclipse.jnosql.mapping.metadata.ClassConverter;
import org.eclipse.jnosql.mapping.metadata.ClassInformationNotFoundException;
import org.eclipse.jnosql.mapping.metadata.EntitiesMetadata;
import org.eclipse.jnosql.mapping.metadata.EntityMetadata;
import org.eclipse.jnosql.mapping.metadata.GroupEntityMetadata;
import org.eclipse.jnosql.mapping.metadata.InheritanceMetadata;

import java.util.Locale;
import java.util.Map;
import java.util.Objects;
import java.util.Optional;
import java.util.concurrent.ConcurrentHashMap;
import java.util.function.Function;
import java.util.stream.Collectors;

/**
 * The default implementation of {@link EntityMetadata}.
 * It's storage the class information in a {@link ConcurrentHashMap}
 */
@ApplicationScoped
class DefaultEntitiesMetadata implements EntitiesMetadata {

    private final Map mappings;

    private final  Map, EntityMetadata> classes;

    private final  Map findBySimpleName;

    private final  Map findByClassName;


    private final ClassConverter converter;

    @Inject
    private GroupEntityMetadata extension;

    public DefaultEntitiesMetadata() {
        this.mappings = new ConcurrentHashMap<>();
        this.classes = new ConcurrentHashMap<>();
        this.findBySimpleName = new ConcurrentHashMap<>();
        this.findByClassName = new ConcurrentHashMap<>();
        this.converter = new ReflectionClassConverter();
    }

    @PostConstruct
    public void init() {
        classes.putAll(extension.classes());
        extension.mappings().forEach((k, v) -> mappings.put(k.toUpperCase(Locale.US), v));
        mappings.values().forEach(r -> {
            findBySimpleName.put(r.simpleName(), r);
            findByClassName.put(r.className(), r);
        });
    }

    EntityMetadata load(Class type) {
        EntityMetadata metadata = converter.apply(type);
        if (metadata.hasEntityName()) {
            mappings.put(type.getName().toUpperCase(Locale.US), metadata);
        }
        this.findBySimpleName.put(type.getSimpleName(), metadata);
        this.findByClassName.put(type.getName(), metadata);
        return metadata;
    }

    @Override
    public EntityMetadata get(Class entity) {
        return classes.computeIfAbsent(entity, this::load);
    }

    @Override
    public Map findByParentGroupByDiscriminatorValue(Class parent) {
        Objects.requireNonNull(parent, "parent is required");
        return this.classes.values().stream()
                .flatMap(c -> c.inheritance().stream())
                .filter(p -> p.isParent(parent))
                .collect(Collectors.toMap(InheritanceMetadata::discriminatorValue, Function.identity()));
    }

    @Override
    public EntityMetadata findByName(String name) {
        Objects.requireNonNull(name, "name is required");
        return Optional.ofNullable(mappings.get(name.toUpperCase(Locale.US)))
                .orElseThrow(() -> new ClassInformationNotFoundException("There is not entity found with the name: " + name));

    }

    @Override
    public Optional findBySimpleName(String name) {
        Objects.requireNonNull(name, "name is required");
        return Optional.ofNullable(findBySimpleName.get(name));
    }

    @Override
    public Optional findByClassName(String name) {
        Objects.requireNonNull(name, "name is required");
        return Optional.ofNullable(findByClassName.get(name));
    }

    @Override
    public String toString() {
        return "DefaultEntitiesMetadata{" + "mappings-size=" + mappings.size() +
                ", classes=" + classes +
                ", classConverter=" + converter +
                ", extension=" + extension +
                '}';
    }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy