X-Git-Url: https://git.nmode.ca/signal-cli/blobdiff_plain/46a4c2c0d0a36b7f230fc2c2d47aa371a6e02d35..cd29144e81701698092f3334bee0c99c0f77f202:/src/main/java/org/asamk/signal/json/JsonReaction.java diff --git a/src/main/java/org/asamk/signal/json/JsonReaction.java b/src/main/java/org/asamk/signal/json/JsonReaction.java index 2fa15b48..9dc64591 100644 --- a/src/main/java/org/asamk/signal/json/JsonReaction.java +++ b/src/main/java/org/asamk/signal/json/JsonReaction.java @@ -1,28 +1,32 @@ package org.asamk.signal.json; -import com.fasterxml.jackson.annotation.JsonProperty; - import org.asamk.signal.manager.Manager; import org.whispersystems.signalservice.api.messages.SignalServiceDataMessage.Reaction; -public class JsonReaction { - - @JsonProperty - final String emoji; - - @JsonProperty - final String targetAuthor; - - @JsonProperty - final long targetSentTimestamp; - - @JsonProperty - final boolean isRemove; - - JsonReaction(Reaction reaction, Manager m) { - this.emoji = reaction.getEmoji(); - this.targetAuthor = m.resolveSignalServiceAddress(reaction.getTargetAuthor()).getLegacyIdentifier(); - this.targetSentTimestamp = reaction.getTargetSentTimestamp(); - this.isRemove = reaction.isRemove(); +import static org.asamk.signal.util.Util.getLegacyIdentifier; + +public record JsonReaction( + String emoji, + @Deprecated String targetAuthor, + String targetAuthorNumber, + String targetAuthorUuid, + long targetSentTimestamp, + boolean isRemove +) { + + static JsonReaction from(Reaction reaction, Manager m) { + final var emoji = reaction.getEmoji(); + final var address = m.resolveSignalServiceAddress(reaction.getTargetAuthor()); + final var targetAuthor = getLegacyIdentifier(address); + final var targetAuthorNumber = address.getNumber().orNull(); + final var targetAuthorUuid = address.getUuid().toString(); + final var targetSentTimestamp = reaction.getTargetSentTimestamp(); + final var isRemove = reaction.isRemove(); + return new JsonReaction(emoji, + targetAuthor, + targetAuthorNumber, + targetAuthorUuid, + targetSentTimestamp, + isRemove); } }