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

jakarta.ejb.spi.HandleDelegate Maven / Gradle / Ivy

There is a newer version: 11.0.0-M4
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 - 2024 Weber Informatics LLC | Privacy Policy