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

jakarta.ejb.spi.HandleDelegate 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) 1997, 2020 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 jakarta.ejb.spi;

import java.io.IOException;
import java.io.ObjectOutputStream;
import java.io.ObjectInputStream;

import jakarta.ejb.EJBObject;
import jakarta.ejb.EJBHome;

/**
 * The HandleDelegate interface is implemented by the enterprise bean container. It is used by portable
 * implementations of jakarta.ejb.Handle and jakarta.ejb.HomeHandle. It is not used by
 * enterprise bean components or by client components. It provides methods to serialize and deserialize EJBObject and
 * EJBHome references to streams.
 *
 * 

* The HandleDelegate object is obtained by JNDI lookup at the reserved name * "java:comp/HandleDelegate". * * @since EJB 2.0 */ public interface HandleDelegate { /** * Serialize the EJBObject reference corresponding to a Handle. * *

* This method is called from the writeObject method of portable Handle implementation classes. The * ostream object is the same object that was passed in to the Handle class's writeObject * method. * * @param ejbObject The EJBObject reference to be serialized. * @param ostream The output stream. * @exception IOException The EJBObject could not be serialized because of a system-level failure. */ public void writeEJBObject(EJBObject ejbObject, ObjectOutputStream ostream) throws IOException; /** * Deserialize the EJBObject reference corresponding to a Handle. * *

* The readEJBObject method is called from the readObject method of portable * Handle implementation classes. The istream object is the same object that was passed in to * the Handle class's readObject method. WhenreadEJBObject is called, istream * must point to the location in the stream at which the EJBObject reference can be read. The container must ensure that * the EJBObject reference is capable of performing invocations immediately after deserialization. * * @param istream The input stream. * @return The deserialized EJBObject reference. * @exception IOException The EJBObject could not be deserialized because of a system-level failure. * @exception ClassNotFoundException The EJBObject could not be deserialized because some class could not be found. */ public jakarta.ejb.EJBObject readEJBObject(ObjectInputStream istream) throws IOException, ClassNotFoundException; /** * Serialize the EJBHome reference corresponding to a HomeHandle. * *

* This method is called from the writeObject method of portable HomeHandle implementation * classes. The ostream object is the same object that was passed in to the Handle class's * writeObject method. * * @param ejbHome The EJBHome reference to be serialized. * @param ostream The output stream. * @exception IOException The EJBObject could not be serialized because of a system-level failure. */ public void writeEJBHome(EJBHome ejbHome, ObjectOutputStream ostream) throws IOException; /** * Deserialize the EJBHome reference corresponding to a HomeHandle. * *

* The readEJBHome method is called from the readObject method of portable * HomeHandle implementation classes. The istream object is the same object that was passed in * to the HomeHandle class's readObject method. When readEJBHome is called, * istream must point to the location in the stream at which the EJBHome reference can be read. The * container must ensure that the EJBHome reference is capable of performing invocations immediately after * deserialization. * * @param istream The input stream. * @return The deserialized EJBHome reference. * @exception IOException The EJBHome could not be deserialized because of a system-level failure. * @exception ClassNotFoundException The EJBHome could not be deserialized because some class could not be found. */ public jakarta.ejb.EJBHome readEJBHome(ObjectInputStream istream) throws IOException, ClassNotFoundException; }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy