org.infinispan.xsite.statetransfer.XSiteState Maven / Gradle / Ivy
package org.infinispan.xsite.statetransfer;
import org.infinispan.commons.marshall.AbstractExternalizer;
import org.infinispan.container.entries.InternalCacheEntry;
import org.infinispan.marshall.core.Ids;
import org.infinispan.marshall.core.MarshalledEntry;
import org.infinispan.metadata.Metadata;
import java.io.IOException;
import java.io.ObjectInput;
import java.io.ObjectOutput;
import java.util.Collections;
import java.util.Set;
/**
* Represents the state of a single key to be sent to a backup site. It contains the only needed information, i.e., the
* key, current value and associated metadata.
*
* @author Pedro Ruivo
* @since 7.0
*/
public class XSiteState {
private final Object key;
private final Object value;
private final Metadata metadata;
private XSiteState(Object key, Object value, Metadata metadata) {
this.key = key;
this.value = value;
this.metadata = metadata;
}
public final Object key() {
return key;
}
public final Object value() {
return value;
}
public final Metadata metadata() {
return metadata;
}
public static XSiteState fromDataContainer(InternalCacheEntry entry) {
return new XSiteState(entry.getKey(), entry.getValue(), entry.getMetadata());
}
public static XSiteState fromCacheLoader(MarshalledEntry marshalledEntry) {
return new XSiteState(marshalledEntry.getKey(), marshalledEntry.getValue(), marshalledEntry.getMetadata());
}
@Override
public String toString() {
return "XSiteState{" +
"key=" + key +
", value=" + value +
", metadata=" + metadata +
'}';
}
public static class XSiteStateExternalizer extends AbstractExternalizer {
@Override
public Integer getId() {
return Ids.X_SITE_STATE;
}
@Override
public Set> getTypeClasses() {
return Collections.>singleton(XSiteState.class);
}
@Override
public void writeObject(ObjectOutput output, XSiteState object) throws IOException {
output.writeObject(object.key);
output.writeObject(object.value);
output.writeObject(object.metadata);
}
@Override
public XSiteState readObject(ObjectInput input) throws IOException, ClassNotFoundException {
return new XSiteState(input.readObject(), input.readObject(), (Metadata) input.readObject());
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy