add DeviceDataService

This commit is contained in:
2024-11-14 13:07:57 +01:00
parent e78f46cf6a
commit 6e97eec364

View File

@@ -0,0 +1,43 @@
package ltd.hlaeja.service
import java.util.UUID
import ltd.hlaeja.library.deviceData.MeasurementData
import ltd.hlaeja.property.DeviceDataProperty
import mu.KotlinLogging
import org.springframework.http.HttpStatus.NOT_FOUND
import org.springframework.http.HttpStatus.NO_CONTENT
import org.springframework.http.HttpStatus.REQUEST_TIMEOUT
import org.springframework.stereotype.Service
import org.springframework.web.reactive.function.client.WebClient
import org.springframework.web.reactive.function.client.awaitBodilessEntity
import org.springframework.web.reactive.function.client.awaitBodyOrNull
import org.springframework.web.server.ResponseStatusException
private val log = KotlinLogging.logger {}
@Service
class DeviceDataService(
private val webClient: WebClient,
private val deviceDataProperty: DeviceDataProperty,
) {
suspend fun getMeasurement(
client: UUID,
node: UUID,
): MeasurementData.Response = webClient.get()
.uri("${deviceDataProperty.url}/client-$client/node-$node")
.also { log.debug("{}/client-{}/node-{}", deviceDataProperty.url, client, node) }
.retrieve()
.onStatus(NOT_FOUND::equals) { throw ResponseStatusException(NO_CONTENT) }
.awaitBodyOrNull<MeasurementData.Response>() ?: throw ResponseStatusException(REQUEST_TIMEOUT)
suspend fun addMeasurement(
client: UUID,
request: MeasurementData.Request,
) = webClient.post()
.uri("${deviceDataProperty.url}/client-$client")
.also { log.debug("{}/client-{}", deviceDataProperty.url, client) }
.bodyValue(request)
.retrieve()
.awaitBodilessEntity()
}