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

org.apache.jackrabbit.rmi.client.ClientObject Maven / Gradle / Ivy

/*
 * 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.client;

import javax.jcr.Item;
import javax.jcr.Node;
import javax.jcr.Session;
import javax.jcr.nodetype.NodeType;

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.remote.RemoteProperty;
import org.apache.jackrabbit.rmi.remote.RemoteVersion;
import org.apache.jackrabbit.rmi.remote.RemoteVersionHistory;

/**
 * Base class for client adapter objects. The only purpose of
 * this class is to centralize the handling of the
 * local adapter factory used by the client adapters to
 * instantiate new adapters.
 */
public class ClientObject {

    /** Local adapter factory. */
    private LocalAdapterFactory factory;

    /**
     * Creates a basic client adapter that uses the given factory
     * to create new adapters.
     *
     * @param factory local adapter factory
     */
    protected ClientObject(LocalAdapterFactory factory) {
        this.factory = factory;
    }

    /**
     * Returns the local adapter factory used to create new adapters.
     *
     * @return local adapter factory
     */
    protected LocalAdapterFactory getFactory() {
        return factory;
    }

    /**
     * Utility method to create a local adapter for a remote item.
     * This method introspects the remote reference to determine
     * whether to instantiate a {@link javax.jcr.Property},
     * a {@link Node Node}, or an {@link Item Item} adapter using
     * the local adapter factory.
     * 

* If the remote item is a {@link RemoteNode}, this method delegates * to {@link #getNode(Session, RemoteNode)}. * * @param session current session * @param remote remote item * @return local property, node, or item adapter */ protected Item getItem(Session session, RemoteItem remote) { if (remote instanceof RemoteProperty) { return factory.getProperty(session, (RemoteProperty) remote); } else if (remote instanceof RemoteNode) { return getNode(session, (RemoteNode) remote); } else { return factory.getItem(session, remote); } } /** * Utility method to create a local adapter for a remote node. * This method introspects the remote reference to determine * whether to instantiate a {@link Node Node}, * a {@link javax.jcr.version.VersionHistory VersionHistory}, or a * {@link Version Version} adapter using * the local adapter factory. * * @param session current session * @param remote remote node * @return local node, version, or version history adapter */ protected Node getNode(Session session, RemoteNode remote) { if (remote instanceof RemoteVersion) { return factory.getVersion(session, (RemoteVersion) remote); } else if (remote instanceof RemoteVersionHistory) { return factory.getVersionHistory(session, (RemoteVersionHistory) remote); } else { return factory.getNode(session, remote); } } /** * Utility method for creating an array of local node type adapters * for an array of remote node types. The node type adapters are created * using the local adapter factory. *

* A null input is treated as an empty array. * * @param remotes remote node types * @return local node type array */ protected NodeType[] getNodeTypeArray(RemoteNodeType[] remotes) { if (remotes != null) { NodeType[] types = new NodeType[remotes.length]; for (int i = 0; i < remotes.length; i++) { types[i] = factory.getNodeType(remotes[i]); } return types; } else { return new NodeType[0]; // for safety } } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy