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

org.apache.jackrabbit.rmi.server.ServerObject Maven / Gradle / Ivy

Go to download

JCR-RMI is a transparent Remote Method Invocation (RMI) layer for the Content Repository for Java Technology API (JCR). The layer makes it possible to remotely access JCR content repositories.

There is a newer version: 2.21.26-beta
Show newest version
/*
 * Licensed to the Apache Software Foundation (ASF) under one or more
 * contributor license agreements.  See the NOTICE file distributed with
 * this work for additional information regarding copyright ownership.
 * The ASF licenses this file to You under the Apache License, Version 2.0
 * (the "License"); you may not use this file except in compliance with
 * the License.  You may obtain a copy of the License at
 *
 *      http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */
package org.apache.jackrabbit.rmi.server;

import java.io.Serializable;
import java.rmi.RemoteException;
import java.rmi.server.UnicastRemoteObject;
import java.util.ArrayList;
import java.util.List;

import javax.jcr.AccessDeniedException;
import javax.jcr.InvalidItemStateException;
import javax.jcr.InvalidSerializedDataException;
import javax.jcr.Item;
import javax.jcr.ItemExistsException;
import javax.jcr.ItemNotFoundException;
import javax.jcr.LoginException;
import javax.jcr.MergeException;
import javax.jcr.NamespaceException;
import javax.jcr.NoSuchWorkspaceException;
import javax.jcr.Node;
import javax.jcr.PathNotFoundException;
import javax.jcr.Property;
import javax.jcr.ReferentialIntegrityException;
import javax.jcr.RepositoryException;
import javax.jcr.UnsupportedRepositoryOperationException;
import javax.jcr.Value;
import javax.jcr.ValueFormatException;
import javax.jcr.lock.LockException;
import javax.jcr.nodetype.ConstraintViolationException;
import javax.jcr.nodetype.NoSuchNodeTypeException;
import javax.jcr.nodetype.NodeType;
import javax.jcr.query.InvalidQueryException;
import javax.jcr.security.AccessControlException;
import javax.jcr.version.Version;
import javax.jcr.version.VersionException;
import javax.jcr.version.VersionHistory;

import org.apache.jackrabbit.rmi.remote.RemoteItem;
import org.apache.jackrabbit.rmi.remote.RemoteNode;
import org.apache.jackrabbit.rmi.remote.RemoteNodeType;
import org.apache.jackrabbit.rmi.value.SerialValueFactory;

/**
 * @deprecated RMI support is deprecated and will be removed in a future version of Jackrabbit; see Jira ticket JCR-4972 for more information.
 * 

* Base class for remote adapters. The purpose of this class is to * centralize the handling of the RemoteAdapterFactory instance used * to instantiate new server adapters. */ @Deprecated public class ServerObject extends UnicastRemoteObject { /** Factory for creating server adapters. */ private RemoteAdapterFactory factory; /** * Creates a basic server adapter that uses the given factory * to create new adapters. * * @param factory remote adapter factory * @throws RemoteException on RMI errors */ protected ServerObject(RemoteAdapterFactory factory) throws RemoteException { super(factory.getPortNumber()); this.factory = factory; } /** * Returns the remote adapter factory used to create new adapters. * * @return remote adapter factory */ protected RemoteAdapterFactory getFactory() { return factory; } /** * Returns a cleaned version of the given exception. In some cases * the underlying repository implementation may throw exceptions * that are either unserializable, use exception subclasses that are * only locally available, contain references to unserializable or * only locally available classes. This method returns a cleaned * version of such an exception. The returned exception contains only * the message string from the original exception, and uses the public * JCR exception class that most specifically matches the original * exception. * * @param ex the original exception * @return clean exception */ protected RepositoryException getRepositoryException( RepositoryException ex) { if (ex instanceof AccessDeniedException) { return new AccessDeniedException(ex.getMessage()); } else if (ex instanceof ConstraintViolationException) { return new ConstraintViolationException(ex.getMessage()); } else if (ex instanceof InvalidItemStateException) { return new InvalidItemStateException(ex.getMessage()); } else if (ex instanceof InvalidQueryException) { return new InvalidQueryException(ex.getMessage()); } else if (ex instanceof InvalidSerializedDataException) { return new InvalidSerializedDataException(ex.getMessage()); } else if (ex instanceof ItemExistsException) { return new ItemExistsException(ex.getMessage()); } else if (ex instanceof ItemNotFoundException) { return new ItemNotFoundException(ex.getMessage()); } else if (ex instanceof LockException) { return new LockException(ex.getMessage()); } else if (ex instanceof LoginException) { return new LoginException(ex.getMessage()); } else if (ex instanceof MergeException) { return new MergeException(ex.getMessage()); } else if (ex instanceof NamespaceException) { return new NamespaceException(ex.getMessage()); } else if (ex instanceof NoSuchNodeTypeException) { return new NoSuchNodeTypeException(ex.getMessage()); } else if (ex instanceof NoSuchWorkspaceException) { return new NoSuchWorkspaceException(ex.getMessage()); } else if (ex instanceof PathNotFoundException) { return new PathNotFoundException(ex.getMessage()); } else if (ex instanceof ReferentialIntegrityException) { return new ReferentialIntegrityException(ex.getMessage()); } else if (ex instanceof UnsupportedRepositoryOperationException) { return new UnsupportedRepositoryOperationException(ex.getMessage()); } else if (ex instanceof ValueFormatException) { return new ValueFormatException(ex.getMessage()); } else if (ex instanceof VersionException) { return new VersionException(ex.getMessage()); } else if (ex instanceof AccessControlException) { return new AccessControlException(ex.getMessage()); } else { return new RepositoryException(ex.getMessage()); } } /** * Utility method for creating a remote reference for a local item. * Unlike the factory method for creating remote item references, this * method introspects the type of the local item and returns the * corresponding node, property, or item remote reference using the * remote adapter factory. *

* If the item, this method calls the * {@link #getRemoteNode(Node)} to return the correct remote type. * * @param item local node, property, or item * @return remote node, property, or item reference * @throws RemoteException on RMI errors */ protected RemoteItem getRemoteItem(Item item) throws RemoteException { if (item instanceof Property) { return factory.getRemoteProperty((Property) item); } else if (item instanceof Node) { return getRemoteNode((Node) item); } else { return factory.getRemoteItem(item); } } /** * Utility method for creating a remote reference for a local node. * Unlike the factory method for creating remote node references, this * method introspects the type of the local node and returns the * corresponding node, version, or version history remote reference using * the remote adapter factory. * * @param node local version, versionhistory, or normal node * @return remote node, property, or item reference * @throws RemoteException on RMI errors */ protected RemoteNode getRemoteNode(Node node) throws RemoteException { if (node instanceof Version) { return factory.getRemoteVersion((Version) node); } else if (node instanceof VersionHistory) { return factory.getRemoteVersionHistory((VersionHistory) node); } else { return factory.getRemoteNode(node); } } /** * Utility method for creating an array of remote references for * local node types. The remote references are created using the * remote adapter factory. *

* A null input is treated as an empty array. * * @param types local node type array * @return remote node type array * @throws RemoteException on RMI errors */ protected RemoteNodeType[] getRemoteNodeTypeArray(NodeType[] types) throws RemoteException { if (types != null) { RemoteNodeType[] remotes = new RemoteNodeType[types.length]; for (int i = 0; i < types.length; i++) { remotes[i] = factory.getRemoteNodeType(types[i]); } return remotes; } else { return new RemoteNodeType[0]; // for safety } } /** * Utility method for preparing an array of values for serialization. * The returned array will contain serializable versions of all the * given values. *

* If the given array is null, then an empty array is * returned. * * @param values the values to be decorated * @return array of decorated values * @throws RepositoryException if the values can not be serialized */ protected Value[] getSerialValues(Value[] values) throws RepositoryException { List serials = new ArrayList(); if (values != null) { for (Value value : values) { if (value != null) { serials.add(getSerialValue(value)); } } } return serials.toArray(new Value[serials.size()]); } /** * Utility method for decorating a value. Note that the contents of the * original values will only be copied when the decorators are serialized. * Null referenced and already serializable values are passed as-is. * * @param value the value to be decorated, or null * @return the decorated value, or null * @throws RepositoryException if the value can not be serialized */ protected Value getSerialValue(Value value) throws RepositoryException { // if the value is null or already serializable, just return it if (value == null || value instanceof Serializable) { return value; } else { return SerialValueFactory.makeSerialValue(value); } } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy