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.List;
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<JsonMention> mentions;
- List<JsonQuotedAttachment> attachments;
+ @JsonProperty
+ final String authorUuid;
+
+ @JsonProperty
+ final String text;
+
+ @JsonProperty
+ @JsonInclude(JsonInclude.Include.NON_NULL)
+ final List<JsonMention> mentions;
+
+ @JsonProperty
+ final List<JsonQuotedAttachment> 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().toString();
this.text = quote.getText();
if (quote.getMentions() != null && quote.getMentions().size() > 0) {
.stream()
.map(quotedMention -> new JsonMention(quotedMention, m))
.collect(Collectors.toList());
+ } else {
+ this.mentions = null;
}
if (quote.getAttachments().size() > 0) {