* Implement ARGON2 hash #1150 * Fix argon hash verify * Add argon2 test * #1150 Account for Argon2 managing salts internally
32 lines
1.1 KiB
Java
32 lines
1.1 KiB
Java
package fr.xephi.authme.security.crypts;
|
|
|
|
import de.mkammerer.argon2.Argon2Constants;
|
|
import de.mkammerer.argon2.Argon2Factory;
|
|
import fr.xephi.authme.security.crypts.description.HasSalt;
|
|
import fr.xephi.authme.security.crypts.description.Recommendation;
|
|
import fr.xephi.authme.security.crypts.description.SaltType;
|
|
import fr.xephi.authme.security.crypts.description.Usage;
|
|
|
|
@Recommendation(Usage.RECOMMENDED)
|
|
@HasSalt(value = SaltType.TEXT, length = Argon2Constants.DEFAULT_SALT_LENGTH)
|
|
// Note: Argon2 is actually a salted algorithm but salt generation is handled internally
|
|
// and isn't exposed to the outside, so we treat it as an unsalted implementation
|
|
public class Argon2 extends UnsaltedMethod {
|
|
|
|
private de.mkammerer.argon2.Argon2 argon2;
|
|
|
|
public Argon2() {
|
|
argon2 = Argon2Factory.create();
|
|
}
|
|
|
|
@Override
|
|
public String computeHash(String password) {
|
|
return argon2.hash(2, 65536, 1, password);
|
|
}
|
|
|
|
@Override
|
|
public boolean comparePassword(String password, HashedPassword hashedPassword, String name) {
|
|
return argon2.verify(hashedPassword.getHash(), password);
|
|
}
|
|
}
|