/*
* Copyright (C) 2005-2010 Alfresco Software Limited.
*
* This file is part of Alfresco
*
* Alfresco is free software: you can redistribute it and/or modify
* it under the terms of the GNU Lesser General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* Alfresco is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public License
* along with Alfresco. If not, see .
*/
package org.alfresco.repo.lock;
import org.alfresco.error.AlfrescoRuntimeException;
import org.alfresco.service.namespace.QName;
/**
* Exception generated when a lock cannot be acquired.
*
* @author Derek Hulley
* @since 3.2
*/
public class LockAcquisitionException extends AlfrescoRuntimeException
{
private static final long serialVersionUID = 8215858379509645862L;
/**
*
* - 1: the qname
* - 2: the lock token
*
*/
public static final String ERR_FAILED_TO_ACQUIRE_LOCK = "system.locks.err.failed_to_acquire_lock";
/**
*
* - 1: the qname
* - 2: the lock token
*
*/
public static final String ERR_LOCK_RESOURCE_MISSING = "system.locks.err.lock_resource_missing";
/**
*
* - 1: the qname
* - 2: the lock token
* - 3: the actual update count
* - 4: the expected update count
*
*/
public static final String ERR_LOCK_UPDATE_COUNT = "system.locks.err.lock_update_count";
/**
*
* - 1: the qname
* - 2: the lock token
*
*/
public static final String ERR_FAILED_TO_RELEASE_LOCK = "system.locks.err.failed_to_release_lock";
/**
*
* - 1: the qname
* - 2: the lock token
* - 3: the existing other lock
*
*/
public static final String ERR_EXCLUSIVE_LOCK_EXISTS = "system.locks.err.excl_lock_exists";
/**
* @param lockQName the lock that was sought
* @param lockToken the lock token being used
*/
public LockAcquisitionException(QName lockQName, String lockToken)
{
super(ERR_FAILED_TO_ACQUIRE_LOCK, new Object[] {lockQName, lockToken});
}
/**
* @param msgId one of the message IDs defined
* @param args the arguments that apply
*/
public LockAcquisitionException(String msgId, Object ... args)
{
super(msgId, args);
}
/**
* @param cause an exception leading up to this
* @param msgId one of the message IDs defined
* @param args the arguments that apply
*/
public LockAcquisitionException(Throwable cause, String msgId, Object ... args)
{
super(msgId, args, cause);
}
}