X-Git-Url: https://git.nmode.ca/signal-cli/blobdiff_plain/de273586b4106171a3940ce5ec2c2b3712430c8c..83c75acd0a52518fba5db1b4735f2dba8b5e746e:/src/main/java/org/asamk/signal/json/JsonAttachment.java diff --git a/src/main/java/org/asamk/signal/json/JsonAttachment.java b/src/main/java/org/asamk/signal/json/JsonAttachment.java index a96fc534..c75b3987 100644 --- a/src/main/java/org/asamk/signal/json/JsonAttachment.java +++ b/src/main/java/org/asamk/signal/json/JsonAttachment.java @@ -1,43 +1,34 @@ package org.asamk.signal.json; -import com.fasterxml.jackson.annotation.JsonProperty; - -import org.whispersystems.signalservice.api.messages.SignalServiceAttachment; - -class JsonAttachment { - - @JsonProperty - final String contentType; - - @JsonProperty - final String filename; - - @JsonProperty - final String id; - - @JsonProperty - final Long size; - - JsonAttachment(SignalServiceAttachment attachment) { - this.contentType = attachment.getContentType(); - - if (attachment.isPointer()) { - final var pointer = attachment.asPointer(); - this.id = pointer.getRemoteId().toString(); - this.filename = pointer.getFileName().orNull(); - this.size = pointer.getSize().transform(Integer::longValue).orNull(); - } else { - final var stream = attachment.asStream(); - this.id = null; - this.filename = stream.getFileName().orNull(); - this.size = stream.getLength(); - } - } - - JsonAttachment(String filename) { - this.filename = filename; - this.contentType = null; - this.id = null; - this.size = null; +import org.asamk.signal.manager.api.MessageEnvelope; + +record JsonAttachment( + String contentType, + String filename, + String id, + Long size, + Integer width, + Integer height, + String caption, + Long uploadTimestamp +) { + + static JsonAttachment from(MessageEnvelope.Data.Attachment attachment) { + final var id = attachment.id().orElse(null); + final var filename = attachment.fileName().orElse(null); + final var size = attachment.size().orElse(null); + final var width = attachment.width().orElse(null); + final var height = attachment.height().orElse(null); + final var caption = attachment.caption().orElse(null); + final var uploadTimestamp = attachment.uploadTimestamp().orElse(null); + + return new JsonAttachment(attachment.contentType(), + filename, + id, + size, + width, + height, + caption, + uploadTimestamp); } }