X-Git-Url: https://git.nmode.ca/signal-cli/blobdiff_plain/a8bbdb54d006f157a009ece0cae5bf72fb636ced..caa4fa0180a84cca10a1b363d25147d03ccb0387:/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 31c6b68e..94996ee3 100644 --- a/src/main/java/org/asamk/signal/util/Util.java +++ b/src/main/java/org/asamk/signal/util/Util.java @@ -5,23 +5,28 @@ import com.fasterxml.jackson.annotation.PropertyAccessor; import com.fasterxml.jackson.core.JsonGenerator; import com.fasterxml.jackson.databind.ObjectMapper; -import org.asamk.signal.manager.groups.GroupId; -import org.asamk.signal.manager.groups.GroupIdFormatException; -import org.whispersystems.libsignal.util.guava.Optional; -import org.whispersystems.signalservice.api.push.SignalServiceAddress; +import org.slf4j.Logger; +import org.slf4j.LoggerFactory; +import java.net.URLDecoder; +import java.nio.charset.StandardCharsets; import java.util.Arrays; +import java.util.HashMap; import java.util.List; import java.util.Locale; +import java.util.Map; +import java.util.Optional; import java.util.stream.Collectors; public class Util { + private static final Logger logger = LoggerFactory.getLogger(Util.class); + private Util() { } public static String getStringIfNotBlank(Optional value) { - var string = value.orNull(); + var string = value.orElse(null); if (string == null || string.isBlank()) { return null; } @@ -34,38 +39,49 @@ public class Util { } private static String toCamelCaseString(List strings) { - if (strings.size() == 0) { + if (strings.isEmpty()) { return ""; } - return strings.get(0) + strings.stream() + return strings.getFirst() + strings.stream() .skip(1) - .filter(s -> s.length() > 0) + .filter(s -> !s.isEmpty()) .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).append(" "); + f.append(digits, i * partSize, (i * partSize) + partSize); + if (i != partCount - 1) { + f.append(" "); + } } return f.toString(); } - public static GroupId decodeGroupId(String groupId) throws GroupIdFormatException { - return GroupId.fromBase64(groupId); - } - - public static String getLegacyIdentifier(final SignalServiceAddress address) { - return address.getNumber().or(() -> address.getUuid().get().toString()); - } - 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; } + + public static Map getQueryMap(String query) { + var params = query.split("&"); + var map = new HashMap(); + for (var param : params) { + final var paramParts = param.split("="); + var name = URLDecoder.decode(paramParts[0], StandardCharsets.UTF_8); + var value = paramParts.length == 1 ? null : URLDecoder.decode(paramParts[1], StandardCharsets.UTF_8); + map.put(name, value); + } + return map; + } }