X-Git-Url: https://git.nmode.ca/signal-cli/blobdiff_plain/46a4c2c0d0a36b7f230fc2c2d47aa371a6e02d35..HEAD:/src/main/java/org/asamk/signal/json/JsonMention.java diff --git a/src/main/java/org/asamk/signal/json/JsonMention.java b/src/main/java/org/asamk/signal/json/JsonMention.java index b6243041..c4c962a0 100644 --- a/src/main/java/org/asamk/signal/json/JsonMention.java +++ b/src/main/java/org/asamk/signal/json/JsonMention.java @@ -1,26 +1,17 @@ package org.asamk.signal.json; -import com.fasterxml.jackson.annotation.JsonProperty; +import org.asamk.signal.manager.api.MessageEnvelope; -import org.asamk.signal.manager.Manager; -import org.whispersystems.signalservice.api.messages.SignalServiceDataMessage; -import org.whispersystems.signalservice.api.push.SignalServiceAddress; +import java.util.UUID; -public class JsonMention { +public record JsonMention(@Deprecated String name, String number, String uuid, int start, int length) { - @JsonProperty - final String name; - - @JsonProperty - final int start; - - @JsonProperty - final int length; - - JsonMention(SignalServiceDataMessage.Mention mention, Manager m) { - this.name = m.resolveSignalServiceAddress(new SignalServiceAddress(mention.getUuid(), null)) - .getLegacyIdentifier(); - this.start = mention.getStart(); - this.length = mention.getLength(); + static JsonMention from(MessageEnvelope.Data.Mention mention) { + final var address = mention.recipient(); + return new JsonMention(address.getLegacyIdentifier(), + address.number().orElse(null), + address.uuid().map(UUID::toString).orElse(null), + mention.start(), + mention.length()); } }