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, 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 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