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

com.helger.commons.messagedigest.IMessageDigestGenerator Maven / Gradle / Ivy

There is a newer version: 5.0.12
Show newest version
/**
 * Copyright (C) 2014-2015 Philip Helger (www.helger.com)
 * philip[at]helger[dot]com
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *         http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */
package com.helger.commons.messagedigest;

import java.nio.charset.Charset;
import java.security.Provider;

import javax.annotation.Nonnegative;
import javax.annotation.Nonnull;

import com.helger.commons.annotation.ReturnsMutableCopy;

/**
 * Base interface for a message digest generator (using hash algorithms like MD5
 * or SHA 512)
 *
 * @author Philip Helger
 */
public interface IMessageDigestGenerator
{
  /**
   * The default algorithm that should be used.
   */
  EMessageDigestAlgorithm DEFAULT_ALGORITHM = EMessageDigestAlgorithm.SHA_512;

  /**
   * @return The used security Provider. Should not be null.
   */
  @Nonnull
  Provider getSecurityProvider ();

  /**
   * @return The name of the hashing algorithm used.
   */
  @Nonnull
  String getAlgorithmName ();

  /**
   * @return Returns the length of the digest in bytes, or 0 if this operation
   *         is not supported by the provider.
   */
  @Nonnegative
  int getDigestLength ();

  /**
   * Update the hash with the given byte. After calling
   * {@link #getAllDigestBytes()} once, no further update is possible.
   *
   * @param aValue
   *        The byte value to update the hash
   * @return this
   */
  @Nonnull
  IMessageDigestGenerator update (byte aValue);

  /**
   * Update the hash with the bytes of the given string in the given charset.
   * After calling {@link #getAllDigestBytes()} once, no further update is
   * possible.
   *
   * @param sValue
   *        The string value to update the hash. May not be null.
   * @param aCharset
   *        The charset to be used for extraction of the bytes. May not be
   *        null.
   * @return this
   */
  @Nonnull
  IMessageDigestGenerator update (@Nonnull String sValue, @Nonnull Charset aCharset);

  /**
   * Update the hash with the given byte array. After calling
   * {@link #getAllDigestBytes()} once, no further update is possible.
   *
   * @param aValue
   *        The byte array to update the hash. May not be null.
   * @return this
   */
  @Nonnull
  IMessageDigestGenerator update (@Nonnull byte [] aValue);

  /**
   * Update the hash with a slice of the given byte array. After calling
   * {@link #getAllDigestBytes()} once, no further update is possible.
   *
   * @param aValue
   *        The byte array to update the hash. May not be null.
   * @param nOffset
   *        The offset within the byte array from which the value should be
   *        taken. May not be < 0.
   * @param nLength
   *        The number of bytes to use, starting from the passed offset. May not
   *        be < 0.
   * @return this
   */
  @Nonnull
  IMessageDigestGenerator update (@Nonnull byte [] aValue, @Nonnegative int nOffset, @Nonnegative int nLength);

  /**
   * Reset the current hash so that generation can start from scratch again.
   */
  void reset ();

  /**
   * Finish calculation of the hash value and return the digest. Afterwards no
   * update is possible before {@link #reset()} is called.
   *
   * @return A copy of the array with the message digest.
   */
  @Nonnull
  @ReturnsMutableCopy
  byte [] getAllDigestBytes ();

  /**
   * Get only a part of the digest, namely the first number of bytes. Calls
   * {@link #getAllDigestBytes()} internally so no further update is possible
   * after this method is called.
   *
   * @param nLength
   *        The number of bytes to be retrieved. Must be > 0.
   * @return A copy of the first n bytes of the message digest array.
   */
  @Nonnull
  @ReturnsMutableCopy
  byte [] getAllDigestBytes (@Nonnegative int nLength);

  /**
   * This method finalizes the hash generation and creates the index. Calls
   * {@link #getAllDigestBytes()} internally so no further update is possible
   * after this method is called.
   *
   * @return the generated hash value.
   */
  long getDigestLong ();

  /**
   * This method converts the current hash digest to a hex string. Calls
   * {@link #getAllDigestBytes()} internally so no further update is possible
   * after this method is called.
   *
   * @return The hex value of the hash digest. Never null.
   */
  @Nonnull
  String getDigestHexString ();
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy