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

jakarta.enterprise.inject.build.compatible.spi.SyntheticBeanDisposer Maven / Gradle / Ivy

/*
 * Copyright (c) 2021 Red Hat and others
 *
 * This program and the accompanying materials are made available under the
 * Apache Software License 2.0 which is available at:
 * https://www.apache.org/licenses/LICENSE-2.0.
 *
 * SPDX-License-Identifier: Apache-2.0
 */

package jakarta.enterprise.inject.build.compatible.spi;

import jakarta.enterprise.inject.Instance;

/**
 * Destruction function for a synthetic bean defined by {@link SyntheticBeanBuilder}.
 * CDI container will create an instance of the destruction function every time when it needs
 * to destroy an instance of the synthetic bean. Implementations must be {@code public}
 * classes with a {@code public} zero-parameter constructor; they must not be beans.
 *
 * @param  the bean class of the synthetic bean
 * @since 4.0
 */
public interface SyntheticBeanDisposer {
    /**
     * Destroys an instance of the synthetic bean.
     * 

* The {@link Instance} parameter may be used to simulate disposer method parameter injection. * All {@code @Dependent} bean instances obtained from the {@code Instance} during execution * are destroyed when execution completes. *

* Trying to look up {@code InjectionPoint} from the {@code Instance} parameter is invalid. *

* The parameter map contains the same values that were passed to the {@link SyntheticBeanBuilder} * that defined the synthetic bean. * * @param instance the synthetic bean instance, never {@code null} * @param lookup an {@link Instance} that can be used to lookup other beans, never {@code null} * @param params the parameter map, never {@code null} */ void dispose(T instance, Instance lookup, Parameters params); }