X-Git-Url: https://git.nmode.ca/signal-cli/blobdiff_plain/ae41d0c5026fe868c6198e1005344fc78b6e0a2c..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 27766bda..072b2e3b 100644 --- a/src/main/java/org/asamk/signal/json/JsonSyncMessage.java +++ b/src/main/java/org/asamk/signal/json/JsonSyncMessage.java @@ -1,11 +1,12 @@ package org.asamk.signal.json; -import org.asamk.Signal; -import org.whispersystems.signalservice.api.messages.multidevice.ReadMessage; -import org.whispersystems.signalservice.api.messages.multidevice.SignalServiceSyncMessage; -import org.whispersystems.signalservice.api.push.SignalServiceAddress; +import com.fasterxml.jackson.annotation.JsonInclude; + +import org.asamk.signal.manager.Manager; +import org.asamk.signal.manager.api.GroupId; +import org.asamk.signal.manager.api.MessageEnvelope; +import org.asamk.signal.manager.api.RecipientAddress; -import java.util.ArrayList; import java.util.List; enum JsonSyncMessageType { @@ -14,37 +15,50 @@ enum JsonSyncMessageType { REQUEST_SYNC } -class JsonSyncMessage { - - JsonSyncDataMessage sentMessage; - List blockedNumbers; - List readMessages; - JsonSyncMessageType type; +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(SignalServiceSyncMessage syncMessage) { - if (syncMessage.getSent().isPresent()) { - this.sentMessage = new JsonSyncDataMessage(syncMessage.getSent().get()); - } - if (syncMessage.getBlockedList().isPresent()) { - this.blockedNumbers = new ArrayList<>(syncMessage.getBlockedList().get().getAddresses().size()); - for (SignalServiceAddress address : syncMessage.getBlockedList().get().getAddresses()) { - this.blockedNumbers.add(address.getNumber().get()); - } - } - if (syncMessage.getRead().isPresent()) { - this.readMessages = syncMessage.getRead().get(); + 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.blocked().isPresent()) { + blockedNumbers = syncMessage.blocked() + .get() + .recipients() + .stream() + .map(RecipientAddress::getLegacyIdentifier) + .toList(); + blockedGroupIds = syncMessage.blocked().get().groupIds().stream().map(GroupId::toBase64).toList(); + } else { + blockedNumbers = null; + blockedGroupIds = null; } - if (syncMessage.getContacts().isPresent()) { - this.type = JsonSyncMessageType.CONTACTS_SYNC; - } else if (syncMessage.getGroups().isPresent()) { - this.type = JsonSyncMessageType.GROUPS_SYNC; - } else if (syncMessage.getRequest().isPresent()) { - this.type = JsonSyncMessageType.REQUEST_SYNC; - } - } + final var readMessages = !syncMessage.read().isEmpty() ? syncMessage.read() + .stream() + .map(JsonSyncReadMessage::from) + .toList() : null; - JsonSyncMessage(Signal.SyncMessageReceived messageReceived) { - sentMessage = new JsonSyncDataMessage(messageReceived); + final JsonSyncMessageType type; + if (syncMessage.contacts().isPresent()) { + type = JsonSyncMessageType.CONTACTS_SYNC; + } else if (syncMessage.groups().isPresent()) { + type = JsonSyncMessageType.GROUPS_SYNC; + } else { + type = null; + } + return new JsonSyncMessage(sentMessage, sentStoryMessage, blockedNumbers, blockedGroupIds, readMessages, type); } }