X-Git-Url: https://git.nmode.ca/signal-cli/blobdiff_plain/ce7aa580b6f0580cdcf7fd68fcc8efba737d21ed..eac2a47163a07c2553fee8a0cfcdf3f1e6adafd2:/src/main/java/org/asamk/signal/json/JsonSyncMessage.java diff --git a/src/main/java/org/asamk/signal/json/JsonSyncMessage.java b/src/main/java/org/asamk/signal/json/JsonSyncMessage.java index 2628844f..072b2e3b 100644 --- a/src/main/java/org/asamk/signal/json/JsonSyncMessage.java +++ b/src/main/java/org/asamk/signal/json/JsonSyncMessage.java @@ -2,14 +2,12 @@ package org.asamk.signal.json; import com.fasterxml.jackson.annotation.JsonInclude; -import org.asamk.Signal; import org.asamk.signal.manager.Manager; -import org.asamk.signal.util.Util; -import org.whispersystems.signalservice.api.messages.multidevice.SignalServiceSyncMessage; +import org.asamk.signal.manager.api.GroupId; +import org.asamk.signal.manager.api.MessageEnvelope; +import org.asamk.signal.manager.api.RecipientAddress; -import java.util.Base64; import java.util.List; -import java.util.stream.Collectors; enum JsonSyncMessageType { CONTACTS_SYNC, @@ -19,70 +17,48 @@ enum JsonSyncMessageType { record JsonSyncMessage( @JsonInclude(JsonInclude.Include.NON_NULL) JsonSyncDataMessage sentMessage, + @JsonInclude(JsonInclude.Include.NON_NULL) JsonSyncStoryMessage sentStoryMessage, @JsonInclude(JsonInclude.Include.NON_NULL) List blockedNumbers, @JsonInclude(JsonInclude.Include.NON_NULL) List blockedGroupIds, @JsonInclude(JsonInclude.Include.NON_NULL) List readMessages, @JsonInclude(JsonInclude.Include.NON_NULL) JsonSyncMessageType type ) { - JsonSyncMessage( - final JsonSyncDataMessage sentMessage, - final List blockedNumbers, - final List blockedGroupIds, - final List readMessages, - final JsonSyncMessageType type - ) { - this.sentMessage = sentMessage; - this.blockedNumbers = blockedNumbers; - this.blockedGroupIds = blockedGroupIds; - this.readMessages = readMessages; - this.type = type; - } - - static JsonSyncMessage from(SignalServiceSyncMessage syncMessage, Manager m) { - final var sentMessage = syncMessage.getSent().isPresent() ? JsonSyncDataMessage.from(syncMessage.getSent() - .get(), m) : null; + static JsonSyncMessage from(MessageEnvelope.Sync syncMessage, Manager m) { + final var sentMessage = syncMessage.sent().isPresent() && syncMessage.sent().get().story().isEmpty() + ? JsonSyncDataMessage.from(syncMessage.sent().get(), m) + : null; + final var sentStoryMessage = syncMessage.sent().isPresent() && syncMessage.sent().get().story().isPresent() + ? JsonSyncStoryMessage.from(syncMessage.sent().get()) + : null; final List blockedNumbers; final List blockedGroupIds; - if (syncMessage.getBlockedList().isPresent()) { - final var base64 = Base64.getEncoder(); - blockedNumbers = syncMessage.getBlockedList() - .get() - .getAddresses() - .stream() - .map(Util::getLegacyIdentifier) - .collect(Collectors.toList()); - blockedGroupIds = syncMessage.getBlockedList() + if (syncMessage.blocked().isPresent()) { + blockedNumbers = syncMessage.blocked() .get() - .getGroupIds() + .recipients() .stream() - .map(base64::encodeToString) - .collect(Collectors.toList()); + .map(RecipientAddress::getLegacyIdentifier) + .toList(); + blockedGroupIds = syncMessage.blocked().get().groupIds().stream().map(GroupId::toBase64).toList(); } else { blockedNumbers = null; blockedGroupIds = null; } - final var readMessages = syncMessage.getRead().isPresent() ? syncMessage.getRead() - .get() + final var readMessages = !syncMessage.read().isEmpty() ? syncMessage.read() .stream() .map(JsonSyncReadMessage::from) - .collect(Collectors.toList()) : null; + .toList() : null; final JsonSyncMessageType type; - if (syncMessage.getContacts().isPresent()) { + if (syncMessage.contacts().isPresent()) { type = JsonSyncMessageType.CONTACTS_SYNC; - } else if (syncMessage.getGroups().isPresent()) { + } else if (syncMessage.groups().isPresent()) { type = JsonSyncMessageType.GROUPS_SYNC; - } else if (syncMessage.getRequest().isPresent()) { - type = JsonSyncMessageType.REQUEST_SYNC; } else { type = null; } - return new JsonSyncMessage(sentMessage, blockedNumbers, blockedGroupIds, readMessages, type); - } - - static JsonSyncMessage from(Signal.SyncMessageReceived messageReceived) { - return new JsonSyncMessage(JsonSyncDataMessage.from(messageReceived), null, null, null, null); + return new JsonSyncMessage(sentMessage, sentStoryMessage, blockedNumbers, blockedGroupIds, readMessages, type); } }