summaryrefslogtreecommitdiff
path: root/src/main/kotlin
diff options
context:
space:
mode:
authorPaul-Christian Volkmer2024-02-29 13:15:57 +0100
committerGitHub2024-02-29 13:15:57 +0100
commit4568f491f5d9750ba1a28703e7874b07182f59d3 (patch)
tree2f92d63c3d98fa013885513ae081b93a221f0ded /src/main/kotlin
parent46ddaf10f7a5f0f3da121ef219442109a209db0b (diff)
parent952ad8c0cfc64cf9c5e02f1b4f7fc2466f9f2bb3 (diff)
Merge pull request #46 from CCC-MF/issue_42_kafka
Dateneingang über Apache-Kafka als Alternative zu HTTP-Request
Diffstat (limited to 'src/main/kotlin')
-rw-r--r--src/main/kotlin/dev/dnpm/etl/processor/config/AppKafkaConfiguration.kt6
-rw-r--r--src/main/kotlin/dev/dnpm/etl/processor/input/KafkaInputListener.kt23
2 files changed, 22 insertions, 7 deletions
diff --git a/src/main/kotlin/dev/dnpm/etl/processor/config/AppKafkaConfiguration.kt b/src/main/kotlin/dev/dnpm/etl/processor/config/AppKafkaConfiguration.kt
index 0977527..3799762 100644
--- a/src/main/kotlin/dev/dnpm/etl/processor/config/AppKafkaConfiguration.kt
+++ b/src/main/kotlin/dev/dnpm/etl/processor/config/AppKafkaConfiguration.kt
@@ -25,6 +25,7 @@ import dev.dnpm.etl.processor.monitoring.ConnectionCheckService
import dev.dnpm.etl.processor.monitoring.KafkaConnectionCheckService
import dev.dnpm.etl.processor.output.KafkaMtbFileSender
import dev.dnpm.etl.processor.output.MtbFileSender
+import dev.dnpm.etl.processor.services.RequestProcessor
import dev.dnpm.etl.processor.services.kafka.KafkaResponseProcessor
import org.slf4j.LoggerFactory
import org.springframework.boot.autoconfigure.condition.ConditionalOnMissingBean
@@ -97,9 +98,10 @@ class AppKafkaConfiguration {
@Bean
@ConditionalOnProperty(value = ["app.kafka.input-topic"])
fun kafkaInputListener(
- applicationEventPublisher: ApplicationEventPublisher,
+ requestProcessor: RequestProcessor,
+ objectMapper: ObjectMapper
): KafkaInputListener {
- return KafkaInputListener(applicationEventPublisher)
+ return KafkaInputListener(requestProcessor, objectMapper)
}
@Bean
diff --git a/src/main/kotlin/dev/dnpm/etl/processor/input/KafkaInputListener.kt b/src/main/kotlin/dev/dnpm/etl/processor/input/KafkaInputListener.kt
index ee6b56e..63bf60a 100644
--- a/src/main/kotlin/dev/dnpm/etl/processor/input/KafkaInputListener.kt
+++ b/src/main/kotlin/dev/dnpm/etl/processor/input/KafkaInputListener.kt
@@ -19,15 +19,28 @@
package dev.dnpm.etl.processor.input
+import com.fasterxml.jackson.databind.ObjectMapper
+import de.ukw.ccc.bwhc.dto.Consent
import de.ukw.ccc.bwhc.dto.MtbFile
+import dev.dnpm.etl.processor.services.RequestProcessor
import org.apache.kafka.clients.consumer.ConsumerRecord
-import org.springframework.context.ApplicationEventPublisher
+import org.slf4j.LoggerFactory
import org.springframework.kafka.listener.MessageListener
class KafkaInputListener(
- private val applicationEventPublisher: ApplicationEventPublisher
-) : MessageListener<String, MtbFile> {
- override fun onMessage(data: ConsumerRecord<String, MtbFile>) {
- TODO("Not yet implemented")
+ private val requestProcessor: RequestProcessor,
+ private val objectMapper: ObjectMapper
+) : MessageListener<String, String> {
+ private val logger = LoggerFactory.getLogger(KafkaInputListener::class.java)
+
+ override fun onMessage(data: ConsumerRecord<String, String>) {
+ val mtbFile = objectMapper.readValue(data.value(), MtbFile::class.java)
+ if (mtbFile.consent.status == Consent.Status.ACTIVE) {
+ logger.debug("Accepted MTB File for processing")
+ requestProcessor.processMtbFile(mtbFile)
+ } else {
+ logger.debug("Accepted MTB File and process deletion")
+ requestProcessor.processDeletion(mtbFile.patient.id)
+ }
}
} \ No newline at end of file