X-Git-Url: https://git.nmode.ca/signal-cli/blobdiff_plain/46a4c2c0d0a36b7f230fc2c2d47aa371a6e02d35..d51dd7ae575222b0baea7265c18ebc79f4a7b001:/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..71da4df5 100644 --- a/src/main/java/org/asamk/signal/json/JsonReaction.java +++ b/src/main/java/org/asamk/signal/json/JsonReaction.java @@ -1,28 +1,31 @@ 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 org.asamk.signal.manager.api.MessageEnvelope; + +import java.util.UUID; + +public record JsonReaction( + String emoji, + @Deprecated String targetAuthor, + String targetAuthorNumber, + String targetAuthorUuid, + long targetSentTimestamp, + boolean isRemove +) { + + static JsonReaction from(MessageEnvelope.Data.Reaction reaction) { + final var emoji = reaction.emoji(); + final var address = reaction.targetAuthor(); + final var targetAuthor = address.getLegacyIdentifier(); + final var targetAuthorNumber = address.number().orElse(null); + final var targetAuthorUuid = address.uuid().map(UUID::toString).orElse(null); + final var targetSentTimestamp = reaction.targetSentTimestamp(); + final var isRemove = reaction.isRemove(); + return new JsonReaction(emoji, + targetAuthor, + targetAuthorNumber, + targetAuthorUuid, + targetSentTimestamp, + isRemove); } }