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

org.infinispan.lock.impl.entries.ClusteredLockValue Maven / Gradle / Ivy

package org.infinispan.lock.impl.entries;

import java.io.IOException;
import java.io.ObjectInput;
import java.io.ObjectOutput;
import java.util.Collections;
import java.util.Objects;
import java.util.Set;

import org.infinispan.commons.marshall.AdvancedExternalizer;
import org.infinispan.commons.marshall.MarshallUtil;
import org.infinispan.lock.impl.externalizers.ExternalizerIds;

/**
 * Lock object inside the cache. Holds the lock owner, the lock request id and the status of the lock.
 *
 * @author Katia Aresti, [email protected]
 * @since 9.2
 */
public class ClusteredLockValue {

   public static final ClusteredLockValue INITIAL_STATE = new ClusteredLockValue();
   public static final AdvancedExternalizer EXTERNALIZER = new Externalizer();
   private final String requestId;
   private final Object owner;
   private final ClusteredLockState state;

   public ClusteredLockValue(String requestId, Object owner, ClusteredLockState state) {
      this.requestId = requestId;
      this.owner = owner;
      this.state = state;
   }

   private ClusteredLockValue() {
      this.requestId = null;
      this.owner = null;
      this.state = ClusteredLockState.RELEASED;
   }

   public ClusteredLockState getState() {
      return state;
   }

   @Override
   public boolean equals(Object o) {
      if (this == o) {
         return true;
      }
      if (o == null || getClass() != o.getClass()) {
         return false;
      }
      ClusteredLockValue that = (ClusteredLockValue) o;
      return Objects.equals(requestId, that.requestId) && Objects.equals(owner, that.owner) && Objects.equals(state, that.state);
   }

   @Override
   public int hashCode() {
      return Objects.hash(requestId, owner, state);
   }

   @Override
   public String toString() {
      return "ClusteredLockValue{" +
            " requestId=" + requestId +
            " owner=" + owner +
            " state=" + state +
            '}';
   }

   public String getRequestId() {
      return requestId;
   }

   public Object getOwner() {
      return owner;
   }

   private static class Externalizer implements AdvancedExternalizer {

      @Override
      public Set> getTypeClasses() {
         return Collections.singleton(ClusteredLockValue.class);
      }

      @Override
      public Integer getId() {
         return ExternalizerIds.CLUSTERED_LOCK_VALUE;
      }

      @Override
      public void writeObject(ObjectOutput output, ClusteredLockValue object) throws IOException {
         MarshallUtil.marshallString(object.requestId, output);
         output.writeObject(object.owner);
         MarshallUtil.marshallEnum(object.state, output);
      }

      @Override
      public ClusteredLockValue readObject(ObjectInput input) throws IOException, ClassNotFoundException {
         String requestId = MarshallUtil.unmarshallString(input);
         Object owner = input.readObject();
         ClusteredLockState state = MarshallUtil.unmarshallEnum(input, ClusteredLockState::valueOf);
         return new ClusteredLockValue(requestId, owner, state);
      }
   }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy