X-Git-Url: https://git.nmode.ca/signal-cli/blobdiff_plain/d91e20e1f8a8626ce8e5d5f11535dc05f3c63f31..e03c48e0ae58c3d37e03dc3eb0e89d44b07d40f9:/src/main/java/org/asamk/signal/util/Util.java diff --git a/src/main/java/org/asamk/signal/util/Util.java b/src/main/java/org/asamk/signal/util/Util.java index 4eeabf1c..c844e2ea 100644 --- a/src/main/java/org/asamk/signal/util/Util.java +++ b/src/main/java/org/asamk/signal/util/Util.java @@ -1,31 +1,66 @@ -package org.asamk.signal; +package org.asamk.signal.util; -import java.io.File; -import java.io.IOException; -import java.security.NoSuchAlgorithmException; -import java.security.SecureRandom; +import com.fasterxml.jackson.annotation.JsonAutoDetect; +import com.fasterxml.jackson.annotation.PropertyAccessor; +import com.fasterxml.jackson.core.JsonGenerator; +import com.fasterxml.jackson.databind.ObjectMapper; -class Util { - public static String getSecret(int size) { - byte[] secret = getSecretBytes(size); - return Base64.encodeBytes(secret); +import java.util.Arrays; +import java.util.List; +import java.util.Locale; +import java.util.Optional; +import java.util.stream.Collectors; + +public class Util { + + private Util() { + } + + public static String getStringIfNotBlank(Optional value) { + var string = value.orElse(null); + if (string == null || string.isBlank()) { + return null; + } + return string; } - public static byte[] getSecretBytes(int size) { - byte[] secret = new byte[size]; - getSecureRandom().nextBytes(secret); - return secret; + public static String dashSeparatedToCamelCaseString(String s) { + var parts = s.split("-"); + return toCamelCaseString(Arrays.asList(parts)); } - private static SecureRandom getSecureRandom() { - try { - return SecureRandom.getInstance("SHA1PRNG"); - } catch (NoSuchAlgorithmException e) { - throw new AssertionError(e); + private static String toCamelCaseString(List strings) { + if (strings.size() == 0) { + return ""; + } + return strings.get(0) + strings.stream() + .skip(1) + .filter(s -> s.length() > 0) + .map(s -> Character.toUpperCase(s.charAt(0)) + s.substring(1).toLowerCase(Locale.ROOT)) + .collect(Collectors.joining()); + } + + public static String formatSafetyNumber(String digits) { + if (digits == null) { + return null; + } + + final var partCount = 12; + var partSize = digits.length() / partCount; + var f = new StringBuilder(digits.length() + partCount); + for (var i = 0; i < partCount; i++) { + f.append(digits, i * partSize, (i * partSize) + partSize); + if (i != partCount - 1) { + f.append(" "); + } } + return f.toString(); } - public static File createTempFile() throws IOException { - return File.createTempFile("signal_tmp_", ".tmp"); + public static ObjectMapper createJsonObjectMapper() { + var objectMapper = new ObjectMapper(); + objectMapper.setVisibility(PropertyAccessor.ALL, JsonAutoDetect.Visibility.PUBLIC_ONLY); + objectMapper.disable(JsonGenerator.Feature.AUTO_CLOSE_TARGET); + return objectMapper; } }