All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.elasticmq.persistence.sql.DBMessage.scala Maven / Gradle / Ivy

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