data:image/s3,"s3://crabby-images/02ace/02ace956f9868cf2a1a780bd2c0a517cd3a46077" alt="JAR search and dependency download from the Maven repository"
io.provenance.p8e.shared.util.ProtoByteColumn.kt Maven / Gradle / Ivy
package io.provenance.p8e.shared.util
import com.google.protobuf.Message
import io.netty.buffer.ByteBufInputStream
import org.jetbrains.exposed.sql.Column
import org.jetbrains.exposed.sql.ColumnType
import org.jetbrains.exposed.sql.Table
import java.io.InputStream
import java.sql.ResultSet
fun T.protoBytes(name: String, message: R): Column =
registerColumn(name, ProtoByteAColumnType(message))
class ProtoByteAColumnType(private val message: T): ColumnType() {
override fun sqlType() = "bytea"
override fun notNullValueToDB(value: Any): Any =
when {
message::class.java.isInstance(value) -> message::class.java.cast(value).toByteArray()
value is ByteArray -> value
else -> throw IllegalStateException("Unknown type when serializing ${message::class.java.canonicalName}: ${value::class.java.canonicalName}")
}
override fun valueFromDB(value: Any): Any =
when (value) {
is ByteArray -> message.parserForType.parseFrom(value)
is Message -> value
is InputStream -> value.use { message.parserForType.parseFrom(it) }
is ByteBufInputStream -> throw IllegalStateException("Known bug when using ByteBufInputStream inside of valueFromDB due to race between GC and Ref Counting")
else -> throw IllegalStateException("Unknown type when serializing ${message::class.java.canonicalName}: ${value::class.java.canonicalName}")
}
override fun valueToDB(value: Any?): Any? = value?.let { notNullValueToDB(value) }
override fun readObject(
rs: ResultSet,
index: Int
): Any? {
return rs.getBinaryStream(index).use { it.readAllBytes() }
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy