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

de.mkammerer.argon2.Argon2 Maven / Gradle / Ivy

There is a newer version: 2.11
Show newest version
package de.mkammerer.argon2;

import java.nio.charset.Charset;

/**
 * Argon2 password hashing function.
 * 

* All implementing classes need to be thread safe. */ public interface Argon2 { /** * Hashes a password. *

* Uses UTF-8 encoding. * * @param iterations Number of iterations * @param memory Sets memory usage to x kibibytes * @param parallelism Number of threads and compute lanes * @param password Password to hash * @return Hashed password. * @deprecated Use the {@link #hash(int, int, int, char[])} method instead. Will be removed in version 3. */ @Deprecated String hash(int iterations, int memory, int parallelism, String password); /** * Hashes a password. * * @param iterations Number of iterations * @param memory Sets memory usage to x kibibytes * @param parallelism Number of threads and compute lanes * @param password Password to hash * @param charset Charset of the password * @return Hashed password. * @deprecated Use the {@link #hash(int, int, int, char[], Charset)} method instead. Will be removed in version 3. */ @Deprecated String hash(int iterations, int memory, int parallelism, String password, Charset charset); /** * Hashes a password. *

* Uses UTF-8 encoding. * * @param iterations Number of iterations * @param memory Sets memory usage to x kibibytes * @param parallelism Number of threads and compute lanes * @param password Password to hash * @return Hashed password. */ String hash(int iterations, int memory, int parallelism, char[] password); /** * Hashes a password. * * @param iterations Number of iterations * @param memory Sets memory usage to x kibibytes * @param parallelism Number of threads and compute lanes * @param password Password to hash * @param charset Charset of the password * @return Hashed password. */ String hash(int iterations, int memory, int parallelism, char[] password, Charset charset); /** * Hashes the given data. * * @param iterations Number of iterations * @param memory Sets memory usage to x kibibytes * @param parallelism Number of threads and compute lanes * @param data Data to hash * @return Hashed data. */ String hash(int iterations, int memory, int parallelism, byte[] data); /** * Verifies a password against a hash. *

* Uses UTF-8 encoding. * * @param hash Hash. * @param password Password. * @return True if the password matches the hash, false otherwise. * @deprecated Use the {@link #verify(String, char[])} method instead. Will be removed in version 3. */ @Deprecated boolean verify(String hash, String password); /** * Verifies a password against a hash. * * @param hash Hash. * @param password Password. * @param charset Charset of the password * @return True if the password matches the hash, false otherwise. * @deprecated Use the {@link #verify(String, char[], Charset)} method instead. Will be removed in version 3. */ @Deprecated boolean verify(String hash, String password, Charset charset); /** * Verifies a password against a hash. *

* Uses UTF-8 encoding. * * @param hash Hash. * @param password Password. * @return True if the password matches the hash, false otherwise. */ boolean verify(String hash, char[] password); /** * Verifies a password against a hash. * * @param hash Hash. * @param password Password. * @param charset Charset of the password * @return True if the password matches the hash, false otherwise. */ boolean verify(String hash, char[] password, Charset charset); /** * Verifies the given data against a hash. * * @param hash Hash. * @param data Data. * @return True if the data matches the hash, false otherwise. */ boolean verify(String hash, byte[] data); /** * Wipes the data from the given array. *

* Use this method after hash creation / verification on the array which contains the user password. * * @param array The array to wipe. */ void wipeArray(char[] array); /** * Wipes the data from the given array. *

* Use this method after hash creation / verification on the array which contains the user password. * * @param array The array to wipe. */ void wipeArray(byte[] array); /** * Checks if the given hash uses obsolete parameters like iterations, memory, parallelism. *

* If one of the hash's parameters doesn't match the required minimum, this method will return true. * * @param hash a hash created by {@link #hash(int, int, int, char[], java.nio.charset.Charset) hash} * @param iterations number of minimum iterations * @param memory minimum memory usage * @param parallelism minimum of parallelism * @return {@code true} if the hash should be rehashed to match the given parameters, or {@code false} otherwise. * @throws IllegalArgumentException if the hash is invalid */ boolean needsRehash(String hash, int iterations, int memory, int parallelism); }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy