Compare commits

..

14 Commits

Author SHA1 Message Date
7aaa6988cd upload to docker hub
All checks were successful
continuous-integration/drone/push Build is passing
2022-01-31 23:13:20 +01:00
bb69905ede jolet
All checks were successful
continuous-integration/drone/push Build is passing
2021-08-19 04:22:06 +02:00
ce1aa81dbd fixes, hopefully
All checks were successful
continuous-integration/drone/push Build is passing
2021-08-19 04:12:00 +02:00
13eec03d8e fix typo
All checks were successful
continuous-integration/drone/push Build is passing
2021-08-18 17:01:29 +02:00
2ae6742cd5 use datetime
All checks were successful
continuous-integration/drone/push Build is passing
2021-08-18 15:31:12 +02:00
e4bcfab2af use kotlinx serialization
All checks were successful
continuous-integration/drone/push Build is passing
2021-08-18 14:01:16 +02:00
874480aadb Merge branch 'master' of ssh://git.kmlabz.com:2222/birbnetes/sample-service-consumer
All checks were successful
continuous-integration/drone/push Build is passing
2021-08-17 18:14:12 +02:00
1529649389 use iso format 2021-08-17 18:14:02 +02:00
489bd376e3 remove deprecated stuff
All checks were successful
continuous-integration/drone/push Build is passing
2021-08-17 17:59:31 +02:00
2180416004 requeue
All checks were successful
continuous-integration/drone/push Build is passing
2021-08-17 17:36:58 +02:00
4c0d87d1ea connect to db
All checks were successful
continuous-integration/drone/push Build is passing
2021-08-17 17:22:06 +02:00
1c76eefb1d exception message
All checks were successful
continuous-integration/drone/push Build is passing
2021-08-17 17:07:07 +02:00
ee3d9b0cd5 stacktrace tostring
All checks were successful
continuous-integration/drone/push Build is passing
2021-08-17 17:00:33 +02:00
d9ca774f57 print stacktrace
All checks were successful
continuous-integration/drone/push Build is passing
2021-08-17 16:41:56 +02:00
10 changed files with 79 additions and 32 deletions

View File

@ -30,6 +30,18 @@ steps:
- latest - latest
- ${DRONE_BUILD_NUMBER} - ${DRONE_BUILD_NUMBER}
- name: dockerhub
image: plugins/docker
settings:
repo: birbnetes/${DRONE_REPO_NAME}
username:
from_secret: DOCKERHUB_USER
password:
from_secret: DOCKERHUB_PASSWORD
tags:
- latest
- ${DRONE_BUILD_NUMBER}
- name: ms-teams - name: ms-teams
image: kuperiu/drone-teams image: kuperiu/drone-teams
settings: settings:

View File

@ -11,4 +11,4 @@ USER $APPLICATION_USER
COPY ./build/libs/sample-service-consumer.jar /app/sample-service-consumer.jar COPY ./build/libs/sample-service-consumer.jar /app/sample-service-consumer.jar
WORKDIR /app WORKDIR /app
CMD ["java", "-server", "-XX:+UnlockExperimentalVMOptions", "-XX:InitialRAMFraction=2", "-XX:MinRAMFraction=2", "-XX:MaxRAMFraction=2", "-XX:+UseG1GC", "-XX:MaxGCPauseMillis=100", "-XX:+UseStringDeduplication", "-jar", "sample-service-consumer.jar"] CMD ["java", "-server", "-XX:+UnlockExperimentalVMOptions", "-XX:+UseG1GC", "-XX:MaxGCPauseMillis=100", "-XX:+UseStringDeduplication", "-jar", "sample-service-consumer.jar"]

View File

@ -1,6 +1,7 @@
plugins { plugins {
application application
kotlin("jvm") version "1.5.10" kotlin("jvm") version "1.5.10"
kotlin("plugin.serialization") version "1.5.10"
id("com.github.johnrengelman.shadow") version "7.0.0" id("com.github.johnrengelman.shadow") version "7.0.0"
} }
@ -16,7 +17,19 @@ repositories {
jcenter() jcenter()
} }
buildscript {
repositories { mavenCentral() }
dependencies {
val kotlinVersion = "1.5.10"
classpath(kotlin("gradle-plugin", version = kotlinVersion))
classpath(kotlin("serialization", version = kotlinVersion))
}
}
dependencies { dependencies {
implementation("org.jetbrains.kotlinx:kotlinx-serialization-json:1.2.2")
implementation("org.jetbrains.kotlinx:kotlinx-datetime:0.2.1")
implementation("com.rabbitmq:amqp-client:5.13.0") implementation("com.rabbitmq:amqp-client:5.13.0")
implementation("com.viartemev:the-white-rabbit:0.0.6") implementation("com.viartemev:the-white-rabbit:0.0.6")
implementation("com.zaxxer:HikariCP:5.0.0") implementation("com.zaxxer:HikariCP:5.0.0")
@ -26,7 +39,6 @@ dependencies {
implementation("org.jetbrains.exposed:exposed-java-time:0.33.1") implementation("org.jetbrains.exposed:exposed-java-time:0.33.1")
implementation("io.insert-koin:koin-core:3.1.2") implementation("io.insert-koin:koin-core:3.1.2")
implementation("org.postgresql:postgresql:42.2.23") implementation("org.postgresql:postgresql:42.2.23")
implementation("com.google.code.gson:gson:2.8.7")
} }
tasks { tasks {

View File

@ -1,5 +1,9 @@
import database.DatabaseFactory
import database.dao.SampleObjects
import di.databasemodule import di.databasemodule
import mq.ConsumerWrapper import mq.ConsumerWrapper
import org.jetbrains.exposed.sql.SchemaUtils
import org.jetbrains.exposed.sql.transactions.transaction
import org.koin.core.context.GlobalContext.startKoin import org.koin.core.context.GlobalContext.startKoin
fun main(vararg args: String) { fun main(vararg args: String) {
@ -9,6 +13,11 @@ fun main(vararg args: String) {
modules(databasemodule) modules(databasemodule)
} }
DatabaseFactory.init()
transaction{
SchemaUtils.create(SampleObjects)
}
val consumerWrapper = ConsumerWrapper(); val consumerWrapper = ConsumerWrapper();
consumerWrapper.recieve(); consumerWrapper.recieve();
} }

View File

@ -1,10 +1,11 @@
package api package api
import com.google.gson.annotations.SerializedName import kotlinx.datetime.LocalDateTime
import java.time.LocalDate import kotlinx.serialization.Serializable
@Serializable
data class ApiObject( data class ApiObject(
@SerializedName("tag") val tag: String, val tag: String,
@SerializedName("device_id") val device_id: Int, val device_id: Int,
@SerializedName("device_date") val device_date: LocalDate val device_date: LocalDateTime
) )

View File

@ -7,5 +7,5 @@ data class EnvConfig (
var mqExchange: String = System.getenv("MQ_EXCHANGE") ?: "sample", var mqExchange: String = System.getenv("MQ_EXCHANGE") ?: "sample",
var dbJdbc: String = System.getenv("DB_JDBC") ?: "jdbc:postgresql://localhost:5432/sample-service", var dbJdbc: String = System.getenv("DB_JDBC") ?: "jdbc:postgresql://localhost:5432/sample-service",
var dbUsername: String = System.getenv("DB_USERNAME") ?: "sample-service", var dbUsername: String = System.getenv("DB_USERNAME") ?: "sample-service",
var dbPassowrd: String = System.getenv("DB_PASSOWRD") ?: "sample-service" var dbPassowrd: String = System.getenv("DB_PASSWORD") ?: "sample-service"
) )

View File

@ -2,13 +2,13 @@ package database.dao
import org.jetbrains.exposed.dao.id.IntIdTable import org.jetbrains.exposed.dao.id.IntIdTable
import org.jetbrains.exposed.sql.* import org.jetbrains.exposed.sql.*
import org.jetbrains.exposed.sql.`java-time`.date import org.jetbrains.exposed.sql.`java-time`.datetime
import java.time.LocalDate import java.time.LocalDateTime
object SampleObjects : IntIdTable() { object SampleObjects : IntIdTable() {
val tag: Column<String> = varchar("tag", 32) val tag: Column<String> = varchar("tag", 32)
val timestamp: Column<LocalDate> = date("timestamp").default(LocalDate.now()) val timestamp: Column<LocalDateTime> = datetime("timestamp").default(LocalDateTime.now())
val device_id: Column<Int> = integer("device_id") val device_id: Column<Int> = integer("device_id")
val device_date: Column<LocalDate> = date("device_date") val device_date: Column<LocalDateTime> = datetime("device_date")
override val primaryKey = PrimaryKey(id, name = "PK_SampleObject_Id") override val primaryKey = PrimaryKey(id, name = "PK_SampleObject_Id")
} }

View File

@ -2,6 +2,7 @@ package database.service
import database.model.SampleObject import database.model.SampleObject
import api.ApiObject import api.ApiObject
import kotlinx.datetime.toJavaLocalDateTime
import org.jetbrains.exposed.sql.transactions.transaction import org.jetbrains.exposed.sql.transactions.transaction
class SampleObjectService : ISampleObjectService { class SampleObjectService : ISampleObjectService {
@ -10,7 +11,7 @@ class SampleObjectService : ISampleObjectService {
transaction { transaction {
SampleObject.new { SampleObject.new {
tag = apiObject.tag tag = apiObject.tag
device_date = apiObject.device_date device_date = apiObject.device_date.toJavaLocalDateTime()
device_id = apiObject.device_id device_id = apiObject.device_id
} }
} }

View File

@ -16,10 +16,10 @@ class ConsumerWrapper {
val inputConnection = factory.newConnection() val inputConnection = factory.newConnection()
val inputChannel = inputConnection.createChannel() val inputChannel = inputConnection.createChannel()
inputChannel.exchangeDeclare(envConfig.mqExchange, BuiltinExchangeType.FANOUT) inputChannel.exchangeDeclare(envConfig.mqExchange, BuiltinExchangeType.DIRECT)
val inputQueueName = inputChannel.queueDeclare().queue val inputQueueName = inputChannel.queueDeclare().queue
inputChannel.queueBind(inputQueueName, envConfig.mqExchange, "") inputChannel.queueBind(inputQueueName, envConfig.mqExchange, "meta")
inputChannel.basicConsume(inputQueueName, true, DatabaseConsumer()) inputChannel.basicConsume(inputQueueName, false, DatabaseConsumer(inputChannel))
} }
} }

View File

@ -1,27 +1,28 @@
package mq package mq
import api.ApiObject import api.ApiObject
import com.google.gson.Gson import kotlinx.serialization.json.*
import com.rabbitmq.client.AMQP import com.rabbitmq.client.*
import com.rabbitmq.client.Consumer
import com.rabbitmq.client.Envelope
import com.rabbitmq.client.ShutdownSignalException
import database.service.ISampleObjectService import database.service.ISampleObjectService
import kotlinx.serialization.decodeFromString
import org.koin.core.component.KoinComponent import org.koin.core.component.KoinComponent
import org.koin.core.component.inject import org.koin.core.component.inject
class DatabaseConsumer: Consumer, KoinComponent { class DatabaseConsumer (channel: Channel) : Consumer, KoinComponent {
private val resultObjectService : ISampleObjectService by inject() private val resultObjectService: ISampleObjectService by inject()
private val gson = Gson() private val basicChannel = channel
override fun handleConsumeOk(consumerTag : String?) { override fun handleConsumeOk(consumerTag: String?) {
} }
override fun handleCancelOk(p0 : String?) {
override fun handleCancelOk(p0: String?) {
throw UnsupportedOperationException() throw UnsupportedOperationException()
} }
override fun handleRecoverOk(p0 : String?) {
override fun handleRecoverOk(p0: String?) {
throw UnsupportedOperationException() throw UnsupportedOperationException()
} }
override fun handleCancel(p0 : String?) {
override fun handleCancel(p0: String?) {
throw UnsupportedOperationException() throw UnsupportedOperationException()
} }
@ -29,9 +30,20 @@ class DatabaseConsumer: Consumer, KoinComponent {
println("got shutdown signal") println("got shutdown signal")
} }
override fun handleDelivery(consumerTag : String?, envelope : Envelope?, basicProperties : AMQP.BasicProperties?, body : ByteArray?) { override fun handleDelivery(
val rawJson = body!!.toString(Charsets.UTF_8) consumerTag: String?,
val apiObject = gson.fromJson(rawJson, ApiObject::class.java) envelope: Envelope?,
resultObjectService.addOne(apiObject) basicProperties: AMQP.BasicProperties?,
body: ByteArray?
) {
try {
val rawJson = body!!.toString(Charsets.UTF_8)
val apiObject = Json{ ignoreUnknownKeys = true }.decodeFromString<ApiObject>(rawJson)
resultObjectService.addOne(apiObject)
basicChannel.basicAck(envelope!!.deliveryTag,false)
} catch (e: Exception) {
println(e.message)
basicChannel.basicNack(envelope!!.deliveryTag, false, true)
} }
}
} }