X-Git-Url: https://git.nmode.ca/signal-cli/blobdiff_plain/67f62947c6d4cc5f4b9d4334bfe55b753bc6a12c..7f64a9812ca5bb10e8f57cacf3d22b904bd200b4:/src/main/java/org/asamk/signal/json/JsonQuote.java diff --git a/src/main/java/org/asamk/signal/json/JsonQuote.java b/src/main/java/org/asamk/signal/json/JsonQuote.java index 10cd0bf4..ecd31c1a 100644 --- a/src/main/java/org/asamk/signal/json/JsonQuote.java +++ b/src/main/java/org/asamk/signal/json/JsonQuote.java @@ -1,24 +1,49 @@ package org.asamk.signal.json; +import com.fasterxml.jackson.annotation.JsonInclude; +import com.fasterxml.jackson.annotation.JsonProperty; + import org.asamk.signal.manager.Manager; import org.whispersystems.signalservice.api.messages.SignalServiceDataMessage; import java.util.ArrayList; import java.util.List; +import java.util.UUID; import java.util.stream.Collectors; +import static org.asamk.signal.util.Util.getLegacyIdentifier; + public class JsonQuote { - long id; - String author; - String text; + @JsonProperty + final long id; + + @JsonProperty + @Deprecated + final String author; + + @JsonProperty + final String authorNumber; - List mentions; - List attachments; + @JsonProperty + final String authorUuid; + + @JsonProperty + final String text; + + @JsonProperty + @JsonInclude(JsonInclude.Include.NON_NULL) + final List mentions; + + @JsonProperty + final List attachments; JsonQuote(SignalServiceDataMessage.Quote quote, Manager m) { this.id = quote.getId(); - this.author = m.resolveSignalServiceAddress(quote.getAuthor()).getLegacyIdentifier(); + final var address = m.resolveSignalServiceAddress(quote.getAuthor()); + this.author = getLegacyIdentifier(address); + this.authorNumber = address.getNumber().orNull(); + this.authorUuid = address.getUuid().transform(UUID::toString).orNull(); this.text = quote.getText(); if (quote.getMentions() != null && quote.getMentions().size() > 0) { @@ -26,6 +51,8 @@ public class JsonQuote { .stream() .map(quotedMention -> new JsonMention(quotedMention, m)) .collect(Collectors.toList()); + } else { + this.mentions = null; } if (quote.getAttachments().size() > 0) {