X-Git-Url: https://git.nmode.ca/signal-cli/blobdiff_plain/62687d103fab1ade650b920008060c220361d581..ae678871ec976f2bcf1cee969e555ca00239f7d8:/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..802c07d5 100644 --- a/src/main/java/org/asamk/signal/json/JsonSyncMessage.java +++ b/src/main/java/org/asamk/signal/json/JsonSyncMessage.java @@ -3,8 +3,8 @@ package org.asamk.signal.json; import com.fasterxml.jackson.annotation.JsonInclude; import org.asamk.signal.manager.api.MessageEnvelope; +import org.asamk.signal.manager.api.RecipientAddress; import org.asamk.signal.manager.groups.GroupId; -import org.asamk.signal.manager.storage.recipients.RecipientAddress; import java.util.List; @@ -16,30 +16,20 @@ 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() + final var sentMessage = syncMessage.sent().isPresent() && syncMessage.sent().get().story().isEmpty() ? JsonSyncDataMessage.from(syncMessage.sent().get()) : 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()) { @@ -68,6 +58,6 @@ record JsonSyncMessage( } else { type = null; } - return new JsonSyncMessage(sentMessage, blockedNumbers, blockedGroupIds, readMessages, type); + return new JsonSyncMessage(sentMessage, sentStoryMessage, blockedNumbers, blockedGroupIds, readMessages, type); } }