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
- ${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
image: kuperiu/drone-teams
settings:

View File

@ -11,4 +11,4 @@ USER $APPLICATION_USER
COPY ./build/libs/sample-service-consumer.jar /app/sample-service-consumer.jar
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 {
application
kotlin("jvm") version "1.5.10"
kotlin("plugin.serialization") version "1.5.10"
id("com.github.johnrengelman.shadow") version "7.0.0"
}
@ -16,7 +17,19 @@ repositories {
jcenter()
}
buildscript {
repositories { mavenCentral() }
dependencies {
val kotlinVersion = "1.5.10"
classpath(kotlin("gradle-plugin", version = kotlinVersion))
classpath(kotlin("serialization", version = kotlinVersion))
}
}
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.viartemev:the-white-rabbit:0.0.6")
implementation("com.zaxxer:HikariCP:5.0.0")
@ -26,7 +39,6 @@ dependencies {
implementation("org.jetbrains.exposed:exposed-java-time:0.33.1")
implementation("io.insert-koin:koin-core:3.1.2")
implementation("org.postgresql:postgresql:42.2.23")
implementation("com.google.code.gson:gson:2.8.7")
}
tasks {

View File

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

View File

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

View File

@ -7,5 +7,5 @@ data class EnvConfig (
var mqExchange: String = System.getenv("MQ_EXCHANGE") ?: "sample",
var dbJdbc: String = System.getenv("DB_JDBC") ?: "jdbc:postgresql://localhost:5432/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.sql.*
import org.jetbrains.exposed.sql.`java-time`.date
import java.time.LocalDate
import org.jetbrains.exposed.sql.`java-time`.datetime
import java.time.LocalDateTime
object SampleObjects : IntIdTable() {
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_date: Column<LocalDate> = date("device_date")
val device_date: Column<LocalDateTime> = datetime("device_date")
override val primaryKey = PrimaryKey(id, name = "PK_SampleObject_Id")
}

View File

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

View File

@ -16,10 +16,10 @@ class ConsumerWrapper {
val inputConnection = factory.newConnection()
val inputChannel = inputConnection.createChannel()
inputChannel.exchangeDeclare(envConfig.mqExchange, BuiltinExchangeType.FANOUT)
inputChannel.exchangeDeclare(envConfig.mqExchange, BuiltinExchangeType.DIRECT)
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,26 +1,27 @@
package mq
import api.ApiObject
import com.google.gson.Gson
import com.rabbitmq.client.AMQP
import com.rabbitmq.client.Consumer
import com.rabbitmq.client.Envelope
import com.rabbitmq.client.ShutdownSignalException
import kotlinx.serialization.json.*
import com.rabbitmq.client.*
import database.service.ISampleObjectService
import kotlinx.serialization.decodeFromString
import org.koin.core.component.KoinComponent
import org.koin.core.component.inject
class DatabaseConsumer: Consumer, KoinComponent {
class DatabaseConsumer (channel: Channel) : Consumer, KoinComponent {
private val resultObjectService: ISampleObjectService by inject()
private val gson = Gson()
private val basicChannel = channel
override fun handleConsumeOk(consumerTag: String?) {
}
override fun handleCancelOk(p0: String?) {
throw UnsupportedOperationException()
}
override fun handleRecoverOk(p0: String?) {
throw UnsupportedOperationException()
}
override fun handleCancel(p0: String?) {
throw UnsupportedOperationException()
}
@ -29,9 +30,20 @@ class DatabaseConsumer: Consumer, KoinComponent {
println("got shutdown signal")
}
override fun handleDelivery(consumerTag : String?, envelope : Envelope?, basicProperties : AMQP.BasicProperties?, body : ByteArray?) {
override fun handleDelivery(
consumerTag: String?,
envelope: Envelope?,
basicProperties: AMQP.BasicProperties?,
body: ByteArray?
) {
try {
val rawJson = body!!.toString(Charsets.UTF_8)
val apiObject = gson.fromJson(rawJson, ApiObject::class.java)
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)
}
}
}