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

org.jboss.weld.interceptor.builder.InterceptionModelBuilder Maven / Gradle / Ivy

Go to download

This jar bundles all the bits of Weld and CDI required for running in a Servlet container.

The newest version!
/*
 * JBoss, Home of Professional Open Source
 * Copyright 2009, Red Hat, Inc. and/or its affiliates, and individual
 * contributors by the @authors tag. See the copyright.txt in the
 * distribution for a full listing of individual contributors.
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 * http://www.apache.org/licenses/LICENSE-2.0
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */
package org.jboss.weld.interceptor.builder;

import java.lang.annotation.Annotation;
import java.lang.reflect.Constructor;
import java.lang.reflect.Member;
import java.lang.reflect.Method;
import java.util.ArrayList;
import java.util.Collection;
import java.util.Collections;
import java.util.EnumMap;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import java.util.Map.Entry;
import java.util.Set;

import org.jboss.weld.interceptor.reader.TargetClassInterceptorMetadata;
import org.jboss.weld.interceptor.spi.metadata.InterceptorClassMetadata;
import org.jboss.weld.interceptor.spi.model.InterceptionModel;
import org.jboss.weld.interceptor.spi.model.InterceptionType;
import org.jboss.weld.util.collections.ImmutableList;
import org.jboss.weld.util.collections.ImmutableMap;
import org.jboss.weld.util.collections.ImmutableSet;

/**
 * This builder shouldn't be reused.
 *
 * @author Marius Bogoevici
 * @author Marko Luksa
 * @author Martin Kouba
 */
public class InterceptionModelBuilder {

    private boolean isModelBuilt = false;

    private boolean hasExternalNonConstructorInterceptors;

    private final ImmutableSet.Builder methodsIgnoringGlobalInterceptors;

    private final ImmutableSet.Builder> allInterceptors;

    private final Map>> globalInterceptors;

    private final Map>>> methodBoundInterceptors;

    private TargetClassInterceptorMetadata targetClassInterceptorMetadata;

    private final ImmutableMap.Builder> memberInterceptorBindings;

    private Set classInterceptorBindings;

    public InterceptionModelBuilder() {
        this.methodsIgnoringGlobalInterceptors = ImmutableSet.builder();
        this.allInterceptors = ImmutableSet.builder();
        this.globalInterceptors = new EnumMap<>(InterceptionType.class);
        this.methodBoundInterceptors = new EnumMap<>(InterceptionType.class);
        this.memberInterceptorBindings = ImmutableMap.builder();
    }

    /**
     * @return an immutable {@link InterceptionModel} instance
     */
    public InterceptionModel build() {
        checkModelNotBuilt();
        isModelBuilt = true;
        return new InterceptionModelImpl(this);
    }

    public void interceptMethod(jakarta.enterprise.inject.spi.InterceptionType interceptionType, Method method,
            Collection> interceptors, Set interceptorBindings) {
        checkModelNotBuilt();
        InterceptionType weldInterceptionType = InterceptionType.valueOf(interceptionType);
        if (weldInterceptionType.isLifecycleCallback()) {
            throw new IllegalArgumentException("Illegal interception type: " + interceptionType);
        }
        if (null == methodBoundInterceptors.get(weldInterceptionType)) {
            methodBoundInterceptors.put(weldInterceptionType, new HashMap<>());
        }
        List> interceptorsList = methodBoundInterceptors.get(weldInterceptionType).get(method);
        if (interceptorsList == null) {
            interceptorsList = new ArrayList<>();
            methodBoundInterceptors.get(weldInterceptionType).put(method, interceptorsList);
        }
        interceptorsList.addAll(interceptors);
        intercept(weldInterceptionType, interceptors);

        if (interceptorBindings != null) {
            // WELD-1742 Associate method interceptor bindings
            memberInterceptorBindings.put(method, interceptorBindings);
        }
    }

    public void interceptGlobal(jakarta.enterprise.inject.spi.InterceptionType interceptionType, Constructor constructor,
            Collection> interceptors, Set interceptorBindings) {
        checkModelNotBuilt();
        InterceptionType weldInterceptionType = InterceptionType.valueOf(interceptionType);

        List> interceptorsList = globalInterceptors.get(weldInterceptionType);
        if (interceptorsList == null) {
            interceptorsList = new ArrayList<>();
            globalInterceptors.put(weldInterceptionType, interceptorsList);
        }
        interceptorsList.addAll(interceptors);
        intercept(weldInterceptionType, interceptors);

        if (constructor != null) {
            // WELD-1742 Associate constructor interceptor bindings
            memberInterceptorBindings.put(constructor, interceptorBindings);
        }
    }

    private void intercept(InterceptionType interceptionType, Collection> interceptors) {
        if (interceptionType != InterceptionType.AROUND_CONSTRUCT) {
            hasExternalNonConstructorInterceptors = true;
        }
        allInterceptors.addAll(interceptors);
    }

    public void addMethodIgnoringGlobalInterceptors(Method method) {
        checkModelNotBuilt();
        this.methodsIgnoringGlobalInterceptors.add(method);
    }

    boolean isHasExternalNonConstructorInterceptors() {
        return hasExternalNonConstructorInterceptors;
    }

    Set getMethodsIgnoringGlobalInterceptors() {
        return methodsIgnoringGlobalInterceptors.build();
    }

    Set> getAllInterceptors() {
        return allInterceptors.build();
    }

    Map>> getGlobalInterceptors() {
        if (globalInterceptors.isEmpty()) {
            return Collections.emptyMap();
        }
        ImmutableMap.Builder>> builder = ImmutableMap.builder();
        for (Entry>> entry : globalInterceptors.entrySet()) {
            builder.put(entry.getKey(), ImmutableList.copyOf(entry.getValue()));
        }
        return builder.build();
    }

    Map>>> getMethodBoundInterceptors() {
        if (methodBoundInterceptors.isEmpty()) {
            return Collections.emptyMap();
        }
        ImmutableMap.Builder>>> builder = ImmutableMap.builder();
        for (Entry>>> entry : methodBoundInterceptors
                .entrySet()) {
            ImmutableMap.Builder>> metadataBuilder = ImmutableMap.builder();
            for (Entry>> metadataEntry : entry.getValue().entrySet()) {
                metadataBuilder.put(metadataEntry.getKey(), ImmutableList.copyOf(metadataEntry.getValue()));
            }
            builder.put(entry.getKey(), metadataBuilder.build());
        }
        return builder.build();
    }

    private void checkModelNotBuilt() {
        if (isModelBuilt) {
            throw new IllegalStateException("InterceptionModelBuilder cannot be reused");
        }
    }

    TargetClassInterceptorMetadata getTargetClassInterceptorMetadata() {
        return targetClassInterceptorMetadata;
    }

    public void setTargetClassInterceptorMetadata(TargetClassInterceptorMetadata targetClassInterceptorMetadata) {
        this.targetClassInterceptorMetadata = targetClassInterceptorMetadata;
    }

    Collection getClassInterceptorBindings() {
        return classInterceptorBindings;
    }

    public void setClassInterceptorBindings(Set classInterceptorBindings) {
        this.classInterceptorBindings = classInterceptorBindings;
    }

    Map> getMemberInterceptorBindings() {
        return memberInterceptorBindings.build();
    }

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy