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

xdev.ui.locking.OnLoadPessimisticLockStrategy Maven / Gradle / Ivy

package xdev.ui.locking;

/*-
 * #%L
 * XDEV Application Framework
 * %%
 * Copyright (C) 2003 - 2020 XDEV Software
 * %%
 * This program 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.
 * 
 * This program 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 General Lesser Public License for more details.
 * 
 * You should have received a copy of the GNU General Lesser Public
 * License along with this program.  If not, see
 * .
 * #L%
 */


import xdev.db.locking.LockConstructionState;
import xdev.db.locking.LockFactory;
import xdev.db.locking.PessimisticLock;
import xdev.db.locking.PessimisticLockStrategy;
import xdev.db.locking.RowAlreadyLockedException;
import xdev.db.locking.VirtualTableLockingUtils;
import xdev.ui.WindowCountDown;
import xdev.vt.VirtualTable.VirtualTableRow;


/**
 * On-record-load lock strategy implementation of
 * {@link PessimisticLockStrategy}.
 * 

* {@link PessimisticLock#getLock()} is called instantly on record selection. * * @author XDEV Software jwill * @since 4.0 */ public class OnLoadPessimisticLockStrategy implements PessimisticLockStrategy// { /** * {@inheritDoc} */ @Override public void triggerLocking(VirtualTableRow record, Lockable lockable) throws RowAlreadyLockedException { // only lock persistent data if(!record.isNew()) { PessimisticLock recordLock = LockFactory.getPessimisticLock(record, lockable.getLockingTime()); // catch LockingExceptions here to limit the layer of user // interaction // with exception handling -> RAD API try { this.initLockRenewListener(recordLock,lockable,recordLock.getLock()); triggerLockTimeMonitoring(record,lockable); // release inhibition on successful lock request lockable.getLockNotificationStrategy().lockInUseNotificationFinished(recordLock, lockable); } catch(RowAlreadyLockedException e1) { triggerLockTimeMonitoring(record,lockable); lockable.getLockNotificationStrategy().lockInUseNotification(e1, LockFactory.getPessimisticLock(record,lockable.getLockingTime()),lockable); } } } protected void triggerLockTimeMonitoring(final VirtualTableRow record, final Lockable lockable) { final PessimisticLock recordLock = LockFactory.getPessimisticLock(record, lockable.getLockingTime()); new WindowCountDown(recordLock,lockable.getCountdownMonitors()); } private void initLockRenewListener(PessimisticLock lock, Lockable lockable, LockConstructionState state) { if(state.isInitial()) { // init renew lock mechanism if lock was successfully created. lock.addLockTimeoutListener(new RenewLockTimeoutListener(lockable,lock)); } } /** * {@inheritDoc} */ @Override public void releaseLocking(VirtualTableRow record, Lockable lockable) { PessimisticLock lock = LockFactory.getPessimisticLock(record,lockable.getLockingTime()); if(VirtualTableLockingUtils.isUserHoldsLock(lock)) { lock.removeLock(); } } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy