X-Git-Url: https://git.nmode.ca/signal-cli/blobdiff_plain/62687d103fab1ade650b920008060c220361d581..3533500b736ce382b9cc1d53d29ff267324bf4be:/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 6f512016..072b2e3b 100644 --- a/src/main/java/org/asamk/signal/json/JsonSyncMessage.java +++ b/src/main/java/org/asamk/signal/json/JsonSyncMessage.java @@ -2,9 +2,10 @@ package org.asamk.signal.json; 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.groups.GroupId; -import org.asamk.signal.manager.storage.recipients.RecipientAddress; +import org.asamk.signal.manager.api.RecipientAddress; import java.util.List; @@ -16,29 +17,19 @@ 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(MessageEnvelope.Sync syncMessage) { - final var sentMessage = syncMessage.sent().isPresent() - ? JsonSyncDataMessage.from(syncMessage.sent().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; @@ -55,7 +46,7 @@ record JsonSyncMessage( blockedGroupIds = null; } - final var readMessages = syncMessage.read().size() > 0 ? syncMessage.read() + final var readMessages = !syncMessage.read().isEmpty() ? syncMessage.read() .stream() .map(JsonSyncReadMessage::from) .toList() : null; @@ -68,6 +59,6 @@ record JsonSyncMessage( } else { type = null; } - return new JsonSyncMessage(sentMessage, blockedNumbers, blockedGroupIds, readMessages, type); + return new JsonSyncMessage(sentMessage, sentStoryMessage, blockedNumbers, blockedGroupIds, readMessages, type); } }