more codes
This commit is contained in:
@@ -115,57 +115,7 @@ class EmailIngestionService(
|
||||
return
|
||||
}
|
||||
|
||||
val extracted = extractBookingDetails(body)
|
||||
inbound.extractedData = objectMapper.writeValueAsString(extracted)
|
||||
|
||||
val otaBookingId = extracted["otaBookingId"]?.takeIf { !it.contains("NONE", true) }
|
||||
if (!otaBookingId.isNullOrBlank() &&
|
||||
inboundEmailRepo.existsByPropertyIdAndOtaBookingId(property.id!!, otaBookingId)
|
||||
) {
|
||||
inbound.status = InboundEmailStatus.SKIPPED
|
||||
inbound.processedAt = OffsetDateTime.now()
|
||||
inboundEmailRepo.save(inbound)
|
||||
return
|
||||
}
|
||||
|
||||
inbound.otaBookingId = otaBookingId
|
||||
inboundEmailRepo.save(inbound)
|
||||
|
||||
val isCancel = extracted["isCancel"]?.contains("YES", ignoreCase = true) == true
|
||||
if (isCancel) {
|
||||
if (otaBookingId.isNullOrBlank()) {
|
||||
inbound.status = InboundEmailStatus.SKIPPED
|
||||
inbound.processedAt = OffsetDateTime.now()
|
||||
inboundEmailRepo.save(inbound)
|
||||
return
|
||||
}
|
||||
val booking = bookingRepo.findByPropertyIdAndSourceBookingId(property.id!!, otaBookingId)
|
||||
if (booking != null) {
|
||||
booking.status = BookingStatus.CANCELLED
|
||||
bookingRepo.save(booking)
|
||||
inbound.booking = booking
|
||||
}
|
||||
inbound.status = InboundEmailStatus.CANCELLED
|
||||
inbound.processedAt = OffsetDateTime.now()
|
||||
inboundEmailRepo.save(inbound)
|
||||
return
|
||||
}
|
||||
|
||||
val sourceBookingId = otaBookingId ?: "email:$messageId"
|
||||
if (bookingRepo.existsByPropertyIdAndSourceBookingId(property.id!!, sourceBookingId)) {
|
||||
inbound.status = InboundEmailStatus.SKIPPED
|
||||
inbound.processedAt = OffsetDateTime.now()
|
||||
inboundEmailRepo.save(inbound)
|
||||
return
|
||||
}
|
||||
|
||||
val guest = resolveGuest(property, extracted)
|
||||
val emailUrl = "${publicBaseUrl}/properties/${property.id}/inbound-emails/${inbound.id}/file"
|
||||
val booking = createBooking(property, guest, extracted, sourceBookingId, emailUrl)
|
||||
inbound.booking = booking
|
||||
inbound.status = InboundEmailStatus.CREATED
|
||||
inbound.processedAt = OffsetDateTime.now()
|
||||
inboundEmailRepo.save(inbound)
|
||||
handleExtracted(property, inbound, body, "email:$messageId")
|
||||
}
|
||||
|
||||
private fun extractBookingDetails(body: String): Map<String, String> {
|
||||
@@ -241,6 +191,65 @@ class EmailIngestionService(
|
||||
return bookingRepo.save(booking)
|
||||
}
|
||||
|
||||
fun ingestManualPdf(property: Property, inbound: InboundEmail, body: String) {
|
||||
inboundEmailRepo.save(inbound)
|
||||
handleExtracted(property, inbound, body, "manual:${inbound.id}")
|
||||
}
|
||||
|
||||
private fun handleExtracted(property: Property, inbound: InboundEmail, body: String, fallbackKey: String) {
|
||||
val extracted = extractBookingDetails(body)
|
||||
inbound.extractedData = objectMapper.writeValueAsString(extracted)
|
||||
|
||||
val otaBookingId = extracted["otaBookingId"]?.takeIf { !it.contains("NONE", true) }
|
||||
if (!otaBookingId.isNullOrBlank() &&
|
||||
inboundEmailRepo.existsByPropertyIdAndOtaBookingId(property.id!!, otaBookingId)
|
||||
) {
|
||||
inbound.status = InboundEmailStatus.SKIPPED
|
||||
inbound.processedAt = OffsetDateTime.now()
|
||||
inboundEmailRepo.save(inbound)
|
||||
return
|
||||
}
|
||||
|
||||
inbound.otaBookingId = otaBookingId
|
||||
inboundEmailRepo.save(inbound)
|
||||
|
||||
val isCancel = extracted["isCancel"]?.contains("YES", ignoreCase = true) == true
|
||||
if (isCancel) {
|
||||
if (otaBookingId.isNullOrBlank()) {
|
||||
inbound.status = InboundEmailStatus.SKIPPED
|
||||
inbound.processedAt = OffsetDateTime.now()
|
||||
inboundEmailRepo.save(inbound)
|
||||
return
|
||||
}
|
||||
val booking = bookingRepo.findByPropertyIdAndSourceBookingId(property.id!!, otaBookingId)
|
||||
if (booking != null) {
|
||||
booking.status = BookingStatus.CANCELLED
|
||||
bookingRepo.save(booking)
|
||||
inbound.booking = booking
|
||||
}
|
||||
inbound.status = InboundEmailStatus.CANCELLED
|
||||
inbound.processedAt = OffsetDateTime.now()
|
||||
inboundEmailRepo.save(inbound)
|
||||
return
|
||||
}
|
||||
|
||||
val sourceBookingId = otaBookingId ?: fallbackKey
|
||||
if (bookingRepo.existsByPropertyIdAndSourceBookingId(property.id!!, sourceBookingId)) {
|
||||
inbound.status = InboundEmailStatus.SKIPPED
|
||||
inbound.processedAt = OffsetDateTime.now()
|
||||
inboundEmailRepo.save(inbound)
|
||||
return
|
||||
}
|
||||
|
||||
val guest = resolveGuest(property, extracted)
|
||||
val emailUrl = "${publicBaseUrl}/properties/${property.id}/inbound-emails/${inbound.id}/file"
|
||||
val booking = createBooking(property, guest, extracted, sourceBookingId, emailUrl)
|
||||
inbound.booking = booking
|
||||
inbound.status = InboundEmailStatus.CREATED
|
||||
inbound.processedAt = OffsetDateTime.now()
|
||||
inboundEmailRepo.save(inbound)
|
||||
}
|
||||
|
||||
private fun buildMessageId(message: Message): String? {
|
||||
val header = message.getHeader("Message-ID")?.firstOrNull()
|
||||
if (!header.isNullOrBlank()) return header
|
||||
|
||||
Reference in New Issue
Block a user