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

org.apache.jackrabbit.jcr2spi.lock.LockStateManager 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.jcr2spi.lock;

import javax.jcr.RepositoryException;
import javax.jcr.lock.Lock;
import javax.jcr.lock.LockException;

import org.apache.jackrabbit.jcr2spi.state.NodeState;

/**
 * Defines the functionality needed for locking and unlocking nodes.
 */
public interface LockStateManager {

    /**
     * Lock a node. Checks whether the node is not locked and then
     * returns a lock object for this node.
     *
     * @param nodeState
     * @param isDeep whether the lock applies to this node only
     * @param isSessionScoped whether the lock is session scoped
     * @return lock object
     * @throws LockException if this node already is locked, or some descendant
     *         node is locked and isDeep is true
     * @see javax.jcr.Node#lock
     */
    Lock lock(NodeState nodeState, boolean isDeep, boolean isSessionScoped)
        throws LockException, RepositoryException;

    /**
     * Lock a node. Checks whether the node is not locked and then
     * returns a lock object for this node.
     *
     * @param nodeState
     * @param isDeep whether the lock applies to this node only
     * @param isSessionScoped whether the lock is session scoped
     * @param timeoutHint optional timeout hint.
     * @param ownerHint optional String defining the lock owner info to be
     * displayed.
     * @return lock object
     * @throws LockException if this node already is locked, or some descendant
     *         node is locked and isDeep is true
     * @see javax.jcr.Node#lock
     */
    Lock lock(NodeState nodeState, boolean isDeep, boolean isSessionScoped, long timeoutHint, String ownerHint)
        throws LockException, RepositoryException;

    /**
     * Removes the lock on a node.
     *
     * @param nodeState
     * @throws LockException if this node is not locked or the session does not
     * have the correct lock token
     * @see javax.jcr.Node#unlock
     */
    void unlock(NodeState nodeState) throws LockException, RepositoryException;


    /**
     * Returns the Lock object that applies to a node. This may be either a lock
     * on this node itself or a deep lock on a node above this node.
     *
     * @param nodeState
     * @return lock object
     * @throws LockException if this node is not locked
     * @see javax.jcr.Node#getLock
     */
    Lock getLock(NodeState nodeState) throws LockException, RepositoryException;

    /**
     * Returns true if this node is locked either as a result
     * of a lock held by this node or by a deep lock on a node above this
     * node; otherwise returns false.
     *
     * @param nodeState
     * @return true if this node is locked either as a result
     * of a lock held by this node or by a deep lock on a node above this
     * node; otherwise returns false
     * @throws RepositoryException If an error occurs.
     * @see javax.jcr.Node#isLocked
     */
    boolean isLocked(NodeState nodeState) throws RepositoryException;

    /**
     * Check whether the given node state is locked by somebody else than the
     * current session. Access is allowed if the node is not locked or
     * if the session itself holds the lock to this node, i.e. the session
     * contains the lock token for the lock. If the node is not locked at
     * all this method returns silently.
     *
     * @param nodeState
     * @throws LockException if write access to the specified node is not allowed
     * @throws RepositoryException if some other error occurs
     */
    void checkLock(NodeState nodeState) throws LockException, RepositoryException;

    /**
     *
     * @return The lock tokens associated with the Session this
     * lock manager has been created for.
     */
    public String[] getLockTokens() throws RepositoryException;

    /**
     * Invoked by a session to inform that a lock token has been added.
     *
     * @param lt added lock token
     */
    void addLockToken(String lt) throws LockException, RepositoryException;

    /**
     * Invoked by a session to inform that a lock token has been removed.
     *
     * @param lt removed lock token
     */
    void removeLockToken(String lt) throws LockException, RepositoryException;
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy