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

org.infinispan.server.hotrod.KeyValueVersionConverter Maven / Gradle / Ivy

package org.infinispan.server.hotrod;

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

import org.infinispan.commons.io.UnsignedNumeric;
import org.infinispan.commons.marshall.AbstractExternalizer;
import org.infinispan.container.versioning.EntryVersion;
import org.infinispan.container.versioning.NumericVersion;
import org.infinispan.metadata.Metadata;
import org.infinispan.notifications.cachelistener.filter.CacheEventConverter;
import org.infinispan.notifications.cachelistener.filter.EventType;

class KeyValueVersionConverter implements CacheEventConverter {
   private final boolean returnOldValue;

   private KeyValueVersionConverter(boolean returnOldValue) {
      this.returnOldValue = returnOldValue;
   }

   public static KeyValueVersionConverter EXCLUDING_OLD_VALUE_CONVERTER = new KeyValueVersionConverter(false);
   public static KeyValueVersionConverter INCLUDING_OLD_VALUE_CONVERTER = new KeyValueVersionConverter(true);

   @Override
   public byte[] convert(byte[] key, byte[] oldValue, Metadata oldMetadata, byte[] newValue, Metadata newMetadata, EventType eventType) {
      int capacity = UnsignedNumeric.sizeUnsignedInt(key.length) + key.length +
            (newValue != null ? UnsignedNumeric.sizeUnsignedInt(newValue.length) + newValue.length + 8 : 0);

      if (newValue == null && returnOldValue && oldValue != null) {
         capacity += UnsignedNumeric.sizeUnsignedInt(oldValue.length) + oldValue.length + 8;
      }

      byte[] out = new byte[capacity];
      int offset = UnsignedNumeric.writeUnsignedInt(out, 0, key.length);
      offset += putBytes(key, offset, out);
      if (newValue != null) {
         offset += UnsignedNumeric.writeUnsignedInt(out, offset, newValue.length);
         offset += putBytes(newValue, offset, out);
         writeVersion(newMetadata, offset, out);
      }
      if (newValue == null && returnOldValue && oldValue != null) {
         offset += UnsignedNumeric.writeUnsignedInt(out, offset, oldValue.length);
         offset += putBytes(oldValue, offset, out);
         writeVersion(oldMetadata, offset, out);
      }
      return out;
   }

   private static void writeVersion(Metadata metadata, int offset, byte[] out) {
      if (metadata == null || metadata.version() == null) {
         return;
      }
      EntryVersion version = metadata.version();
      if (version instanceof NumericVersion) {
         putLong(((NumericVersion) version).getVersion(), offset, out);
      }
   }

   private static int putBytes(byte[] bytes, int offset, byte[] out) {
      System.arraycopy(bytes, 0, out, offset, bytes.length);
      return bytes.length;
   }

   private static int putLong(long l, int offset, byte[] out) {
      out[offset] = (byte) (l >> 56);
      out[offset + 1] = (byte) (l >> 48);
      out[offset + 2] = (byte) (l >> 40);
      out[offset + 3] = (byte) (l >> 32);
      out[offset + 4] = (byte) (l >> 24);
      out[offset + 5] = (byte) (l >> 16);
      out[offset + 6] = (byte) (l >> 8);
      out[offset + 7] = (byte) l;
      return offset + 8;
   }

   @Override
   public boolean useRequestFormat() {
      return true;
   }

   static class Externalizer extends AbstractExternalizer {
      @Override
      public Set> getTypeClasses() {
         return Collections.singleton(KeyValueVersionConverter.class);
      }

      @Override
      public void writeObject(ObjectOutput output, KeyValueVersionConverter object) throws IOException {
         output.writeBoolean(object.returnOldValue);
      }

      @Override
      public KeyValueVersionConverter readObject(ObjectInput input) throws IOException {
         boolean returnOldValue = input.readBoolean();
         return returnOldValue ? KeyValueVersionConverter.INCLUDING_OLD_VALUE_CONVERTER
               : KeyValueVersionConverter.EXCLUDING_OLD_VALUE_CONVERTER;
      }
   }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy