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

org.eclipse.persistence.internal.sessions.coordination.rmi.RMIRemoteCommandConnectionImpl Maven / Gradle / Ivy

There is a newer version: 4.0.2
Show newest version
/*
 * Copyright (c) 1998, 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,
 * or the Eclipse Distribution License v. 1.0 which is available at
 * http://www.eclipse.org/org/documents/edl-v10.php.
 *
 * SPDX-License-Identifier: EPL-2.0 OR BSD-3-Clause
 */

// Contributors:
//     Oracle - initial API and implementation from Oracle TopLink
package org.eclipse.persistence.internal.sessions.coordination.rmi;

import org.eclipse.persistence.sessions.coordination.Command;
import org.eclipse.persistence.sessions.coordination.RemoteCommandManager;
import org.eclipse.persistence.internal.helper.Helper;
import java.rmi.*;
import java.rmi.server.UnicastRemoteObject;

/**
 * 

* Purpose: The implementation for the remote RMI object used for * transporting the remote command. *

* Description: This implementation class is the RMI remote object that is * wrapped by the conection abstraction. It is the first point of entry of the * command into the remote service. It simply hands the command to the RCM to be * processed. * * @see org.eclipse.persistence.sessions.coordination.Command * @see org.eclipse.persistence.sessions.coordination.RemoteCommandManager * @since OracleAS TopLink 10g (9.0.4) */ public class RMIRemoteCommandConnectionImpl extends UnicastRemoteObject implements RMIRemoteCommandConnection { RemoteCommandManager rcm; public RMIRemoteCommandConnectionImpl(RemoteCommandManager rcm) throws RemoteException { super(); this.rcm = rcm; } /** * INTERNAL: * No support currently exists for returning the result of the command execution. * Currently only null is returned on success. On failure an error string is * returned (to avoid returning an object/exception that may not exist on the * sending side). */ public Object executeCommand(Command command) throws RemoteException { try { rcm.processCommandFromRemoteConnection(command); } catch (Exception e) { // Log the problem Object[] args = { Helper.getShortClassName(command), Helper.printStackTraceToString(e) }; rcm.logWarning("error_executing_remote_command", args); // Return the string in case the exception doesn't exist on the other side return e.toString(); } // Success - return null return null; } /** * INTERNAL: * No support currently exists for returning the result of the command execution. * Currently only null is returned on success. On failure an error string is * returned (to avoid returning an object/exception that may not exist on the * sending side). */ public Object executeCommand(byte[] command) throws RemoteException { try { this.rcm.processCommandFromRemoteConnection(command); } catch (Exception e) { // Log the problem Object[] args = { Helper.getShortClassName(command), Helper.printStackTraceToString(e) }; this.rcm.logWarning("error_executing_remote_command", args); // Return the string in case the exception doesn't exist on the other side return e.toString(); } // Success - return null return null; } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy