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

javax.ejb.SessionContext Maven / Gradle / Ivy

Go to download

This artifact provides a single jar that contains all classes required to use remote Jakarta Enterprise Beans and Jakarta Messaging, including all dependencies. It is intended for use by those not using maven, maven users should just import the Jakarta Enterprise Beans and Jakarta Messaging BOM's instead (shaded JAR's cause lots of problems with maven, as it is very easy to inadvertently end up with different versions on classes on the class path).

There is a newer version: 35.0.0.Beta1
Show newest version
/*
 * Copyright (c) 2006, 2018 Oracle and/or its affiliates. All rights reserved.
 *
 * This program and the accompanying materials are made available under the
 * terms of the Eclipse Public License v. 2.0, which is available at
 * http://www.eclipse.org/legal/epl-2.0.
 *
 * This Source Code may also be made available under the following Secondary
 * Licenses when the conditions for such availability set forth in the
 * Eclipse Public License v. 2.0 are satisfied: GNU General Public License,
 * version 2 with the GNU Classpath Exception, which is available at
 * https://www.gnu.org/software/classpath/license.html.
 *
 * SPDX-License-Identifier: EPL-2.0 OR GPL-2.0 WITH Classpath-exception-2.0
 */

package javax.ejb;

import java.util.*;
import java.security.Identity;
import javax.xml.rpc.handler.MessageContext;

/**
 * The SessionContext interface provides access to the runtime session context 
 * that the container provides for a session bean instance. The 
 * container passes the SessionContext interface to an instance after the 
 * instance has been created. The session context remains associated with 
 * the instance for the lifetime of the instance.
 *
 * @since EJB 1.0
 */
public interface SessionContext extends EJBContext
{
    /**
     * Obtain a reference to the enterprise bean local object that is  
     * associated with the instance.
     *
     * 

An instance of a session bean can call this method at * anytime between the PostConstruct or * ejbCreate and PreDestroy or * ejbRemove methods, including from within these * methods. * *

An instance can use this method, for example, when it wants to * pass a reference to itself in a method argument or result. * * @return The enterprise bean local object currently associated with the instance. * * @exception IllegalStateException Thrown if the instance invokes this * method while the instance is in a state that does not allow the * instance to invoke this method, or if the instance does not have * a local interface. * * @since EJB 2.0 */ EJBLocalObject getEJBLocalObject() throws IllegalStateException; /** * Obtain a reference to the enterprise bean object that is currently associated with * the instance. * *

An instance of a session enterprise Bean can call this * method at anytime between the PostConstruct or * ejbCreate and the PreDestroy or * ejbRemove methods, including from within these * methods. * *

An instance can use this method, for example, when it wants to * pass a reference to itself in a method argument or result. * * @return The enterprise bean object currently associated with the instance. * * @exception IllegalStateException Thrown if the instance invokes this * method while the instance is in a state that does not allow the * instance to invoke this method, or if the instance does not have * a remote interface. */ EJBObject getEJBObject() throws IllegalStateException; /** * Obtain a reference to the JAX-RPC MessageContext. * *

An instance of a stateless session bean can call this method * from any business method invoked through its web service * endpoint interface. * *

Note: Support for web services invocations using JAX-RPC is optional as of EJB 3.2 * * @return The MessageContext for this web service invocation. * * @exception IllegalStateException Thrown if this method is invoked * while the instance is in a state that does not allow access * to this method. * * @since EJB 2.1 */ MessageContext getMessageContext() throws IllegalStateException; /** * Obtain an object that can be used to invoke the current bean through * a particular business interface view or its no-interface view. * * @param businessInterface One of the local business interfaces * or remote business interfaces for this session bean. * In addition, the bean class type can be used to acquire * a reference to the bean's no-interface view. * * @return The business object corresponding to the given business * interface or no-interface view. * * @exception IllegalStateException Thrown if invoked with a parameter * that does not correspond to one of the beans' business interfaces * or no-interface view. * * @since EJB 3.0 */ T getBusinessObject(Class businessInterface) throws IllegalStateException; /** * Obtain the business interface or no-interface view type through which the * current business method invocation was made. * * @exception IllegalStateException Thrown if this method is called * and the bean has not been invoked through a business interface or * no-interface view. * * @since EJB 3.0 */ Class getInvokedBusinessInterface() throws IllegalStateException; /** * Check whether a client invoked the cancel method on the * client Future object corresponding to the currently executing * asynchronous business method. * * @return true if the client has invoked Future.cancel with a value of * true for the mayInterruptIfRunning parameter. * * @exception IllegalStateException Thrown if not invoked from within an * asynchronous business method invocation with return type * Future<V>. * * @since EJB 3.1 */ boolean wasCancelCalled() throws IllegalStateException; }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy