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

javax.ejb.EJBContext Maven / Gradle / Ivy

The newest version!
/**
 * EasyBeans
 * Copyright (C) 2009 Bull S.A.S.
 * Contact: [email protected]
 *
 * This library is free software; you can redistribute it and/or
 * modify it under the terms of the GNU Lesser General Public
 * License as published by the Free Software Foundation; either
 * version 2.1 of the License, or any later version.
 *
 * This library is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
 * Lesser General Public License for more details.
 *
 * You should have received a copy of the GNU Lesser General Public
 * License along with this library; if not, write to the Free Software
 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307
 * USA
 *
 * --------------------------------------------------------------------------
 * $Id: EJBContext.java 6183 2012-03-07 13:35:28Z benoitf $
 * --------------------------------------------------------------------------
 */

package javax.ejb;

import java.security.Identity;
import java.security.Principal;
import java.util.Map;
import java.util.Properties;

import javax.transaction.UserTransaction;

/**
 * Allows to gets some info on the bean.
 * @see EJB 3.1 specification
 * @author Florent Benoit
 */
public interface EJBContext {

    /**
     * @return the Home(remote) interface of the bean. throws IllegalStateException if home is not retrieved
     */
    EJBHome getEJBHome() throws IllegalStateException;

    /**
     * @return the local home interface of the bean. throws IllegalStateException if local home is not retrieved
     */
    EJBLocalHome getEJBLocalHome() throws IllegalStateException;

    /**
     * @return deprecated
     * @deprecated
     */
    Properties getEnvironment();

    /**
     * @return deprecated
     * @deprecated
     */
    Identity getCallerIdentity();

    /**
     * @throws IllegalStateException if not authorized
     * @return the caller principal object.
     */
    Principal getCallerPrincipal() throws IllegalStateException;

    /**
     * @param role deprecated
     * @return deprecated
     * @deprecated
     */
    boolean isCallerInRole(final Identity role);

    /**
     * Check if the given role is in the roles of the current caller's principal.
     * @param roleName the role to check.
     * @return true if it is included, else false.
     * @throws IllegalStateException if not authorized
     */
    boolean isCallerInRole(final String roleName) throws IllegalStateException;

    /**
     * Gets the current transaction.
     * @return the transaction object
     * @throws IllegalStateException in case of Container Managed Transaction.
     */
    UserTransaction getUserTransaction() throws IllegalStateException;

    /**
     * Sets the current transaction in rollback only mode.
     * @throws IllegalStateException in CMT case
     */
    void setRollbackOnly() throws IllegalStateException;

    /**
     * Check if current transaction is marked as rollback only.
     * @return true if current tx is in rollback mode.
     * @throws IllegalStateException if used with CMT.
     */
    boolean getRollbackOnly() throws IllegalStateException;

    /**
     * Gets the timer service.
     * @return an instance of the timer service.
     * @throws IllegalStateException if used within a SFSB.
     */
    TimerService getTimerService() throws IllegalStateException;

    /**
     * Search the given name in java:comp/env ENC environment.
     * @param name the name to search
     * @return null if not found, else an instance of the object found.
     * @since EJB 3.0 version.
     * @throws IllegalArgumentException if the entry is not matching
     */
    Object lookup(final String name) throws IllegalArgumentException;

    /**
     * Enables a business method, lifecycle callback method, or timeout method to retrieve any interceptor/webservices context
     * associated with its invocation.
     * @return the shared context
     * @since EJB 3.1 version.
     */
    Map getContextData();
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy