org.elasticmq.persistence.sql.DBMessage.scala Maven / Gradle / Ivy
The newest version!
package org.elasticmq.persistence.sql
import org.elasticmq._
import org.elasticmq.actor.queue.InternalMessage
import org.elasticmq.persistence.sql.SerializableAttributeProtocol._
import org.elasticmq.util.OffsetDateTimeUtil
import scalikejdbc.WrappedResultSet
import spray.json._
case class DBMessage(
messageId: String,
deliveryReceipts: Array[Byte],
nextDelivery: Long,
content: Array[Byte],
attributes: Array[Byte],
created: Long,
received: Option[Long],
receiveCount: Int,
groupId: Option[String],
deduplicationId: Option[String],
tracingId: Option[String],
sequenceNumber: Option[String]
) {
def toInternalMessage: InternalMessage = {
val serializedAttrs = new String(attributes).parseJson
.convertTo[List[SerializableAttribute]]
.map { attr =>
(
attr.key,
attr.primaryDataType match {
case "String" => StringMessageAttribute(attr.stringValue, attr.customType)
case "Number" => NumberMessageAttribute(attr.stringValue, attr.customType)
case "Binary" => BinaryMessageAttribute.fromBase64(attr.stringValue, attr.customType)
}
)
}
.toMap
val serializedDeliveryReceipts = new String(deliveryReceipts).parseJson.convertTo[List[String]]
val firstReceive =
received.map(time => OnDateTimeReceived(OffsetDateTimeUtil.ofEpochMilli(time))).getOrElse(NeverReceived)
InternalMessage(
messageId,
serializedDeliveryReceipts.toBuffer,
nextDelivery,
new String(content),
serializedAttrs,
Map.empty,
OffsetDateTimeUtil.ofEpochMilli(created),
orderIndex = 0,
firstReceive,
receiveCount,
isFifo = false,
groupId,
deduplicationId.map(id => DeduplicationId(id)),
tracingId.map(TracingId.apply),
sequenceNumber
)
}
}
object DBMessage {
def apply(rs: WrappedResultSet) = new DBMessage(
rs.string("message_id"),
rs.bytes("delivery_receipts"),
rs.long("next_delivery"),
rs.bytes("content"),
rs.bytes("attributes"),
rs.long("created"),
rs.longOpt("received"),
rs.int("receive_count"),
rs.stringOpt("group_id"),
rs.stringOpt("deduplication_id"),
rs.stringOpt("tracing_id"),
rs.stringOpt("sequence_number")
)
def from(message: InternalMessage): DBMessage = {
val deliveryReceipts = message.deliveryReceipts.toList
val attributes = message.messageAttributes.toList.map { case (k, v) =>
v match {
case StringMessageAttribute(stringValue, customType) =>
SerializableAttribute(k, "String", stringValue, customType)
case NumberMessageAttribute(stringValue, customType) =>
SerializableAttribute(k, "Number", stringValue, customType)
case attr: BinaryMessageAttribute => SerializableAttribute(k, "Binary", attr.asBase64, attr.customType)
}
}
val received = message.firstReceive match {
case NeverReceived => None
case OnDateTimeReceived(when) => Some(when.toInstant.toEpochMilli)
}
val deduplicationId = message.messageDeduplicationId.map(_.id)
new DBMessage(
message.id,
deliveryReceipts.toJson.toString.getBytes,
message.nextDelivery,
message.content.getBytes,
attributes.toJson.toString.getBytes,
message.created.toInstant.toEpochMilli,
received,
message.receiveCount,
message.messageGroupId,
deduplicationId,
message.tracingId.map(_.id),
message.sequenceNumber
)
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy