Hashing.java

package redis.clients.jedis.util;

import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException;

/**
 * @deprecated Sharding/Sharded feature will be removed in next major release.
 */
@Deprecated
public interface Hashing {
  Hashing MURMUR_HASH = new MurmurHash();
  ThreadLocal<MessageDigest> md5Holder = new ThreadLocal<>();

  Hashing MD5 = new Hashing() {
    @Override
    public long hash(String key) {
      return hash(SafeEncoder.encode(key));
    }

    @Override
    public long hash(byte[] key) {
      try {
        if (md5Holder.get() == null) {
          md5Holder.set(MessageDigest.getInstance("MD5"));
        }
      } catch (NoSuchAlgorithmException e) {
        throw new IllegalStateException("++++ no md5 algorithm found");
      }
      MessageDigest md5 = md5Holder.get();

      md5.reset();
      md5.update(key);
      byte[] bKey = md5.digest();
      return ((long) (bKey[3] & 0xFF) << 24) | ((long) (bKey[2] & 0xFF) << 16)
          | ((long) (bKey[1] & 0xFF) << 8) | (long) (bKey[0] & 0xFF);
    }
  };

  long hash(String key);

  long hash(byte[] key);
}