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

com.manorrock.oyena.lifecycle.rest.DefaultRestMappingMatcher Maven / Gradle / Ivy

There is a newer version: 23.11.0
Show newest version
/*
 * Copyright (c) 2002-2023 Manorrock.com. All Rights Reserved.
 *
 * Redistribution and use in source and binary forms, with or without 
 * modification, are permitted provided that the following conditions are met:
 *
 *   1. Redistributions of source code must retain the above copyright notice, 
 *      this list of conditions and the following disclaimer.
 *   2. Redistributions in binary form must reproduce the above copyright notice,
 *      this list of conditions and the following disclaimer in the documentation
 *      and/or other materials provided with the distribution.
 *   3. Neither the name of the copyright holder nor the names of its 
 *      contributors may be used to endorse or promote products derived from this
 *      software without specific prior written permission.
 *
 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" 
 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 
 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
 * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
 * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
 * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
 * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
 */
package com.manorrock.oyena.lifecycle.rest;

import jakarta.enterprise.context.ApplicationScoped;
import jakarta.enterprise.inject.Any;
import jakarta.enterprise.inject.spi.AnnotatedMethod;
import jakarta.enterprise.inject.spi.AnnotatedType;
import jakarta.enterprise.inject.spi.Bean;
import jakarta.enterprise.inject.spi.CDI;
import jakarta.faces.context.FacesContext;
import java.util.Iterator;
import java.util.Set;
import java.util.regex.Pattern;

/**
 * The default REST mapping matcher.
 *
 * @author Manfred Riem ([email protected])
 */
@ApplicationScoped
public class DefaultRestMappingMatcher implements RestMappingMatcher {

    /**
     * Find the REST mapping for the given bean.
     *
     * @param facesContext the Faces context.
     * @param bean the bean.
     * @return the REST mapping match, or null if not found.
     */
    private RestMappingMatch determineRestMappingMatch(FacesContext facesContext, Bean bean) {
        RestMappingMatch result = null;
        Class clazz = bean.getBeanClass();
        AnnotatedType annotatedType = CDI.current().getBeanManager().createAnnotatedType(clazz);
        Set annotatedMethodSet = annotatedType.getMethods();
        for (AnnotatedMethod method : annotatedMethodSet) {
            if (method.isAnnotationPresent(RestPath.class)) {
                RestPath restPath = method.getAnnotation(RestPath.class);
                String path = restPath.value();
                String pathInfo = facesContext.getExternalContext().getRequestPathInfo();
                if (Pattern.matches(path, pathInfo)) {
                    result = new RestMappingMatch();
                    result.setBean(bean);
                    result.setMethod(method.getJavaMember());
                    result.setPathInfo(pathInfo);
                    result.setRestPath(path);
                }
            }
        }
        return result;
    }

    /**
     * Get the beans.
     *
     * @return the beans.
     */
    private Iterator> getBeans() {
        Set> beans = CDI.current().getBeanManager().getBeans(
                Object.class, Any.Literal.INSTANCE);
        return beans.iterator();
    }

    /**
     * Match the request to a REST mapping.
     *
     * @param facesContext the Faces context.
     * @return the REST mapping match.
     */
    @Override
    public RestMappingMatch match(FacesContext facesContext) {
        RestMappingMatch match = null;
        Iterator> beans = getBeans();
        while (beans.hasNext()) {
            Bean bean = beans.next();
            RestMappingMatch candidate = determineRestMappingMatch(facesContext, bean);
            if (match == null || (candidate != null && candidate.getLength() > match.getLength())) {
                match = candidate;
            }
        }
        return match;
    }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy