package org.asamk.signal.manager;
-import org.whispersystems.signalservice.internal.util.Base64;
-
-import java.security.NoSuchAlgorithmException;
-import java.security.SecureRandom;
+import org.asamk.signal.util.RandomUtils;
+import org.signal.zkgroup.InvalidInputException;
+import org.signal.zkgroup.profiles.ProfileKey;
+import org.whispersystems.util.Base64;
class KeyUtils {
return getSecret(52);
}
- static byte[] createProfileKey() {
- return getSecretBytes(32);
+ static ProfileKey createProfileKey() {
+ try {
+ return new ProfileKey(getSecretBytes(32));
+ } catch (InvalidInputException e) {
+ throw new AssertionError("Profile key is guaranteed to be 32 bytes here");
+ }
}
static String createPassword() {
return getSecretBytes(16);
}
+ static byte[] createUnrestrictedUnidentifiedAccess() {
+ return getSecretBytes(16);
+ }
+
private static String getSecret(int size) {
byte[] secret = getSecretBytes(size);
return Base64.encodeBytes(secret);
private static byte[] getSecretBytes(int size) {
byte[] secret = new byte[size];
- getSecureRandom().nextBytes(secret);
+ RandomUtils.getSecureRandom().nextBytes(secret);
return secret;
}
-
- private static SecureRandom getSecureRandom() {
- try {
- return SecureRandom.getInstance("SHA1PRNG");
- } catch (NoSuchAlgorithmException e) {
- throw new AssertionError(e);
- }
- }
}