/* * ============LICENSE_START======================================================= * dcaegen2-collectors-veshv * ================================================================================ * Copyright (C) 2018 NOKIA * ================================================================================ * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. * ============LICENSE_END========================================================= */ package org.onap.dcae.collectors.veshv.simulators.dcaeapp.impl import arrow.effects.IO import org.onap.dcae.collectors.veshv.simulators.dcaeapp.impl.adapters.KafkaSource import org.onap.dcae.collectors.veshv.utils.logging.Logger import reactor.kafka.receiver.ReceiverRecord import java.util.concurrent.ConcurrentLinkedQueue /** * @author Piotr Jaszczyk * @since June 2018 */ class ConsumerState(private val messages: ConcurrentLinkedQueue) { val messagesCount: Int by lazy { messages.size } val consumedMessages: List by lazy { messages.toList() } } interface ConsumerStateProvider { fun currentState(): ConsumerState fun reset(): IO } class Consumer : ConsumerStateProvider { private var consumedMessages: ConcurrentLinkedQueue = ConcurrentLinkedQueue() override fun currentState(): ConsumerState = ConsumerState(consumedMessages) override fun reset(): IO = IO { consumedMessages.clear() } fun update(record: ReceiverRecord) = IO { logger.trace { "Updating stats for message from ${record.topic()}:${record.partition()}" } consumedMessages.add(record.value()) } companion object { private val logger = Logger(Consumer::class) } } class ConsumerFactory(private val kafkaBootstrapServers: String) { fun createConsumerForTopics(kafkaTopics: Set): IO = KafkaSource.create(kafkaBootstrapServers, kafkaTopics.toSet()).start() }