package com.kmalbz import com.kmalbz.api.route.OutputServiceRDBServer import com.kmalbz.consumer.DatabaseConsumer import io.ktor.application.* import io.ktor.response.* import io.ktor.routing.* import io.ktor.http.* import io.ktor.gson.* import io.ktor.features.* import org.apache.http.HttpException import com.kmalbz.database.DatabaseFactory import com.kmalbz.database.dao.SampleObjects import io.ktor.util.KtorExperimentalAPI import com.rabbitmq.client.* import com.typesafe.config.ConfigFactory import io.ktor.config.HoconApplicationConfig import org.jetbrains.exposed.sql.SchemaUtils import org.jetbrains.exposed.sql.transactions.transaction import org.koin.ktor.ext.Koin fun main(args: Array): Unit = io.ktor.server.netty.EngineMain.main(args) @KtorExperimentalAPI @Suppress("unused") // Referenced in application.conf fun Application.module() { install(ContentNegotiation) { gson { } } install(Koin) { printLogger() modules(com.kmalbz.di.injectionModule) } DatabaseFactory.init() transaction{ SchemaUtils.create(SampleObjects) } val appConfig = HoconApplicationConfig(ConfigFactory.load()) val factory = ConnectionFactory() factory.host = appConfig.property("ktor.mq.host").getString() factory.username = appConfig.property("ktor.mq.username").getString() factory.password = appConfig.property("ktor.mq.password").getString() val connection = factory.newConnection() val channel = connection.createChannel() val rabbitExchangeName = appConfig.property("ktor.mq.exchange").getString() channel.exchangeDeclare(rabbitExchangeName, BuiltinExchangeType.FANOUT) val queueName = channel.queueDeclare().queue channel.queueBind(queueName, rabbitExchangeName, "") channel.basicConsume(queueName, true, DatabaseConsumer()) routing { install(StatusPages) { exception { call.respond(HttpStatusCode.BadRequest) } exception { call.respond(HttpStatusCode.NotAcceptable) } } OutputServiceRDBServer().apply { registerOutput() } } }