org.infinispan.lock.impl.functions.LockFunction Maven / Gradle / Ivy
package org.infinispan.lock.impl.functions;
import java.io.IOException;
import java.io.ObjectInput;
import java.io.ObjectOutput;
import java.util.Collections;
import java.util.Set;
import java.util.function.Function;
import org.infinispan.commons.logging.LogFactory;
import org.infinispan.commons.marshall.AdvancedExternalizer;
import org.infinispan.commons.marshall.MarshallUtil;
import org.infinispan.functional.EntryView;
import org.infinispan.lock.impl.entries.ClusteredLockKey;
import org.infinispan.lock.impl.entries.ClusteredLockState;
import org.infinispan.lock.impl.entries.ClusteredLockValue;
import org.infinispan.lock.impl.externalizers.ExternalizerIds;
import org.infinispan.lock.logging.Log;
/**
* Lock function that allows to acquire the lock by a requestor, if such action is possible. It returns {@link
* Boolean#TRUE} when the lock is acquired and {@link Boolean#FALSE} when it is not.
*
* @author Katia Aresti, [email protected]
* @since 9.2
*/
public class LockFunction implements Function, Boolean> {
private static final Log log = LogFactory.getLog(LockFunction.class, Log.class);
public static final AdvancedExternalizer EXTERNALIZER = new Externalizer();
private final String requestId;
private final Object requestor;
public LockFunction(String requestId, Object requestor) {
this.requestId = requestId;
this.requestor = requestor;
}
@Override
public Boolean apply(EntryView.ReadWriteEntryView entryView) {
ClusteredLockValue lock = entryView.find().orElseThrow(() -> log.lockDeleted());
if (log.isTraceEnabled()) {
log.tracef("LOCK[%s] lock request by reqId %s requestor %s", entryView.key().getName(), requestId, requestor);
}
if (lock.getState() == ClusteredLockState.RELEASED) {
entryView.set(new ClusteredLockValue(requestId, requestor, ClusteredLockState.ACQUIRED));
if (log.isTraceEnabled()) {
log.tracef("LOCK[%s] lock acquired by %s %s", entryView.key().getName(), requestId, requestor);
}
return Boolean.TRUE;
} else if (lock.getState() == ClusteredLockState.ACQUIRED && lock.getRequestId().equals(requestId) && lock.getOwner().equals(requestor)) {
log.tracef("LOCK[%s] lock already acquired by %s %s", entryView.key().getName(), requestId, requestor);
return Boolean.TRUE;
}
if (log.isTraceEnabled()) {
log.tracef("LOCK[%s] lock not available, owned by %s %s", entryView.key().getName(), lock.getRequestId(), lock.getOwner());
}
return Boolean.FALSE;
}
private static class Externalizer implements AdvancedExternalizer {
@Override
public Set> getTypeClasses() {
return Collections.singleton(LockFunction.class);
}
@Override
public Integer getId() {
return ExternalizerIds.LOCK_FUNCTION;
}
@Override
public void writeObject(ObjectOutput output, LockFunction object) throws IOException {
MarshallUtil.marshallString(object.requestId, output);
output.writeObject(object.requestor);
}
@Override
public LockFunction readObject(ObjectInput input) throws IOException, ClassNotFoundException {
return new LockFunction(MarshallUtil.unmarshallString(input), input.readObject());
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy