From c582912539506a66bb73e21778124c37dc7f0110 Mon Sep 17 00:00:00 2001 From: hfhbd <22521688+hfhbd@users.noreply.github.com> Date: Sun, 18 Aug 2024 23:53:17 +0200 Subject: [PATCH] Add basic UuidSerializer until a new kotlinx-serialization release --- .../api/android/kotlinx-uuid-core.api | 15 +++++++++++ .../api/jvm/kotlinx-uuid-core.api | 15 +++++++++++ .../app/softwork/uuid/BinarySerializer.kt | 13 +++++----- .../app/softwork/uuid/UuidSerializer.kt | 25 +++++++++++++++++++ .../softwork/uuid/UuidSerializationTest.kt | 23 +++++++++++++++++ .../api/kotlinx-uuid-sqldelight.api | 6 +++++ .../uuid/sqldelight/UuidByteArrayAdapter.kt | 2 +- .../uuid/sqldelight/UuidStringAdapter.kt | 2 +- 8 files changed, 92 insertions(+), 9 deletions(-) create mode 100644 kotlinx-uuid-core/src/commonMain/kotlin/app/softwork/uuid/UuidSerializer.kt create mode 100644 kotlinx-uuid-core/src/commonTest/kotlin/app/softwork/uuid/UuidSerializationTest.kt diff --git a/kotlinx-uuid-core/api/android/kotlinx-uuid-core.api b/kotlinx-uuid-core/api/android/kotlinx-uuid-core.api index 9bbdbc2..af7b88b 100644 --- a/kotlinx-uuid-core/api/android/kotlinx-uuid-core.api +++ b/kotlinx-uuid-core/api/android/kotlinx-uuid-core.api @@ -2,9 +2,12 @@ public final class app/softwork/uuid/BinarySerializer : kotlinx/serialization/KS public static final field INSTANCE Lapp/softwork/uuid/BinarySerializer; public synthetic fun deserialize (Lkotlinx/serialization/encoding/Decoder;)Ljava/lang/Object; public fun deserialize (Lkotlinx/serialization/encoding/Decoder;)Lkotlin/uuid/Uuid; + public fun equals (Ljava/lang/Object;)Z public fun getDescriptor ()Lkotlinx/serialization/descriptors/SerialDescriptor; + public fun hashCode ()I public synthetic fun serialize (Lkotlinx/serialization/encoding/Encoder;Ljava/lang/Object;)V public fun serialize (Lkotlinx/serialization/encoding/Encoder;Lkotlin/uuid/Uuid;)V + public fun toString ()Ljava/lang/String; } public final class app/softwork/uuid/NameBasedGeneratorKt { @@ -45,6 +48,18 @@ public final class app/softwork/uuid/UuidParceler : kotlinx/parcelize/Parceler { public fun write (Lkotlin/uuid/Uuid;Landroid/os/Parcel;I)V } +public final class app/softwork/uuid/UuidSerializer : kotlinx/serialization/KSerializer { + public static final field INSTANCE Lapp/softwork/uuid/UuidSerializer; + public synthetic fun deserialize (Lkotlinx/serialization/encoding/Decoder;)Ljava/lang/Object; + public fun deserialize (Lkotlinx/serialization/encoding/Decoder;)Lkotlin/uuid/Uuid; + public fun equals (Ljava/lang/Object;)Z + public fun getDescriptor ()Lkotlinx/serialization/descriptors/SerialDescriptor; + public fun hashCode ()I + public synthetic fun serialize (Lkotlinx/serialization/encoding/Encoder;Ljava/lang/Object;)V + public fun serialize (Lkotlinx/serialization/encoding/Encoder;Lkotlin/uuid/Uuid;)V + public fun toString ()Ljava/lang/String; +} + public final class app/softwork/uuid/Uuidv7Kt { public static final fun Uuidv7 (JLkotlin/random/Random;)Lkotlin/uuid/Uuid; public static final fun getUnixTimeStamp (Lkotlin/uuid/Uuid;)J diff --git a/kotlinx-uuid-core/api/jvm/kotlinx-uuid-core.api b/kotlinx-uuid-core/api/jvm/kotlinx-uuid-core.api index 4748545..3f32688 100644 --- a/kotlinx-uuid-core/api/jvm/kotlinx-uuid-core.api +++ b/kotlinx-uuid-core/api/jvm/kotlinx-uuid-core.api @@ -2,9 +2,12 @@ public final class app/softwork/uuid/BinarySerializer : kotlinx/serialization/KS public static final field INSTANCE Lapp/softwork/uuid/BinarySerializer; public synthetic fun deserialize (Lkotlinx/serialization/encoding/Decoder;)Ljava/lang/Object; public fun deserialize (Lkotlinx/serialization/encoding/Decoder;)Lkotlin/uuid/Uuid; + public fun equals (Ljava/lang/Object;)Z public fun getDescriptor ()Lkotlinx/serialization/descriptors/SerialDescriptor; + public fun hashCode ()I public synthetic fun serialize (Lkotlinx/serialization/encoding/Encoder;Ljava/lang/Object;)V public fun serialize (Lkotlinx/serialization/encoding/Encoder;Lkotlin/uuid/Uuid;)V + public fun toString ()Ljava/lang/String; } public final class app/softwork/uuid/NameBasedGeneratorKt { @@ -32,6 +35,18 @@ public final class app/softwork/uuid/UuidKt { public static final fun toUuidOrNull (Ljava/lang/String;)Lkotlin/uuid/Uuid; } +public final class app/softwork/uuid/UuidSerializer : kotlinx/serialization/KSerializer { + public static final field INSTANCE Lapp/softwork/uuid/UuidSerializer; + public synthetic fun deserialize (Lkotlinx/serialization/encoding/Decoder;)Ljava/lang/Object; + public fun deserialize (Lkotlinx/serialization/encoding/Decoder;)Lkotlin/uuid/Uuid; + public fun equals (Ljava/lang/Object;)Z + public fun getDescriptor ()Lkotlinx/serialization/descriptors/SerialDescriptor; + public fun hashCode ()I + public synthetic fun serialize (Lkotlinx/serialization/encoding/Encoder;Ljava/lang/Object;)V + public fun serialize (Lkotlinx/serialization/encoding/Encoder;Lkotlin/uuid/Uuid;)V + public fun toString ()Ljava/lang/String; +} + public final class app/softwork/uuid/Uuidv7Kt { public static final fun Uuidv7 (JLkotlin/random/Random;)Lkotlin/uuid/Uuid; public static final fun getUnixTimeStamp (Lkotlin/uuid/Uuid;)J diff --git a/kotlinx-uuid-core/src/commonMain/kotlin/app/softwork/uuid/BinarySerializer.kt b/kotlinx-uuid-core/src/commonMain/kotlin/app/softwork/uuid/BinarySerializer.kt index 35ce1ca..a9585c7 100644 --- a/kotlinx-uuid-core/src/commonMain/kotlin/app/softwork/uuid/BinarySerializer.kt +++ b/kotlinx-uuid-core/src/commonMain/kotlin/app/softwork/uuid/BinarySerializer.kt @@ -22,7 +22,7 @@ import kotlin.uuid.Uuid * Cbor.encodeToByteArray(BinarySerializer, myUUID) * ``` */ -public object BinarySerializer : KSerializer { +public data object BinarySerializer : KSerializer { private val serializer = LongArraySerializer() override val descriptor: SerialDescriptor = serializer.descriptor @@ -33,12 +33,11 @@ public object BinarySerializer : KSerializer { } override fun deserialize(decoder: Decoder): Uuid { - return decoder.decodeSerializableValue(serializer).let { array -> - if (array.size != 2) { - throw SerializationException("Uuid array should consist of 2 elements") - } - - Uuid.fromLongs(array[0], array[1]) + val array = decoder.decodeSerializableValue(serializer) + if (array.size != 2) { + throw SerializationException("Uuid array should consist of 2 elements") } + + return Uuid.fromLongs(array[0], array[1]) } } diff --git a/kotlinx-uuid-core/src/commonMain/kotlin/app/softwork/uuid/UuidSerializer.kt b/kotlinx-uuid-core/src/commonMain/kotlin/app/softwork/uuid/UuidSerializer.kt new file mode 100644 index 0000000..da83507 --- /dev/null +++ b/kotlinx-uuid-core/src/commonMain/kotlin/app/softwork/uuid/UuidSerializer.kt @@ -0,0 +1,25 @@ +package app.softwork.uuid + +import kotlinx.serialization.KSerializer +import kotlinx.serialization.descriptors.PrimitiveKind +import kotlinx.serialization.descriptors.PrimitiveSerialDescriptor +import kotlinx.serialization.descriptors.SerialDescriptor +import kotlinx.serialization.encoding.Decoder +import kotlinx.serialization.encoding.Encoder +import kotlin.uuid.Uuid + +/** + * This is the default [Uuid] serializer that encodes instances as primitive strings + * consisting of the canonical UUID string format. + */ +public data object UuidSerializer : KSerializer { + override val descriptor: SerialDescriptor = PrimitiveSerialDescriptor("kotlin.uuid.Uuid", PrimitiveKind.STRING) + + override fun serialize(encoder: Encoder, value: Uuid) { + encoder.encodeString(value.toString()) + } + + override fun deserialize(decoder: Decoder): Uuid { + return Uuid.parse(decoder.decodeString()) + } +} diff --git a/kotlinx-uuid-core/src/commonTest/kotlin/app/softwork/uuid/UuidSerializationTest.kt b/kotlinx-uuid-core/src/commonTest/kotlin/app/softwork/uuid/UuidSerializationTest.kt new file mode 100644 index 0000000..88acae8 --- /dev/null +++ b/kotlinx-uuid-core/src/commonTest/kotlin/app/softwork/uuid/UuidSerializationTest.kt @@ -0,0 +1,23 @@ +/* + * Copyright 2020-2020 JetBrains s.r.o and contributors. Use of this source code is governed by the Apache 2.0 license. + */ + +package app.softwork.uuid + +import kotlinx.serialization.* +import kotlinx.serialization.json.* +import kotlin.test.* +import kotlin.uuid.Uuid + +@ExperimentalSerializationApi +class UuidSerializationTest { + @Test + fun smokeTest() { + val value = Uuid.parse(SOME_UUID_STRING) + val encoded = Json.encodeToString(UuidSerializer, value) + assertEquals("\"$SOME_UUID_STRING\"", encoded) + val decoded = Json.decodeFromString(UuidSerializer, encoded) + + assertEquals(value, decoded) + } +} diff --git a/kotlinx-uuid-sqldelight/api/kotlinx-uuid-sqldelight.api b/kotlinx-uuid-sqldelight/api/kotlinx-uuid-sqldelight.api index c585ce1..945c490 100644 --- a/kotlinx-uuid-sqldelight/api/kotlinx-uuid-sqldelight.api +++ b/kotlinx-uuid-sqldelight/api/kotlinx-uuid-sqldelight.api @@ -4,6 +4,9 @@ public final class app/softwork/uuid/sqldelight/UuidByteArrayAdapter : app/cash/ public fun decode ([B)Lkotlin/uuid/Uuid; public synthetic fun encode (Ljava/lang/Object;)Ljava/lang/Object; public fun encode (Lkotlin/uuid/Uuid;)[B + public fun equals (Ljava/lang/Object;)Z + public fun hashCode ()I + public fun toString ()Ljava/lang/String; } public final class app/softwork/uuid/sqldelight/UuidStringAdapter : app/cash/sqldelight/ColumnAdapter { @@ -12,5 +15,8 @@ public final class app/softwork/uuid/sqldelight/UuidStringAdapter : app/cash/sql public fun decode (Ljava/lang/String;)Lkotlin/uuid/Uuid; public synthetic fun encode (Ljava/lang/Object;)Ljava/lang/Object; public fun encode (Lkotlin/uuid/Uuid;)Ljava/lang/String; + public fun equals (Ljava/lang/Object;)Z + public fun hashCode ()I + public fun toString ()Ljava/lang/String; } diff --git a/kotlinx-uuid-sqldelight/src/commonMain/kotlin/app/softwork/uuid/sqldelight/UuidByteArrayAdapter.kt b/kotlinx-uuid-sqldelight/src/commonMain/kotlin/app/softwork/uuid/sqldelight/UuidByteArrayAdapter.kt index 00a0eea..530da42 100644 --- a/kotlinx-uuid-sqldelight/src/commonMain/kotlin/app/softwork/uuid/sqldelight/UuidByteArrayAdapter.kt +++ b/kotlinx-uuid-sqldelight/src/commonMain/kotlin/app/softwork/uuid/sqldelight/UuidByteArrayAdapter.kt @@ -3,7 +3,7 @@ package app.softwork.uuid.sqldelight import app.cash.sqldelight.* import kotlin.uuid.Uuid -public object UuidByteArrayAdapter : ColumnAdapter { +public data object UuidByteArrayAdapter : ColumnAdapter { override fun decode(databaseValue: ByteArray): Uuid = Uuid.fromByteArray(databaseValue) override fun encode(value: Uuid): ByteArray = value.toByteArray() } diff --git a/kotlinx-uuid-sqldelight/src/commonMain/kotlin/app/softwork/uuid/sqldelight/UuidStringAdapter.kt b/kotlinx-uuid-sqldelight/src/commonMain/kotlin/app/softwork/uuid/sqldelight/UuidStringAdapter.kt index cb23d0d..e4b0619 100644 --- a/kotlinx-uuid-sqldelight/src/commonMain/kotlin/app/softwork/uuid/sqldelight/UuidStringAdapter.kt +++ b/kotlinx-uuid-sqldelight/src/commonMain/kotlin/app/softwork/uuid/sqldelight/UuidStringAdapter.kt @@ -3,7 +3,7 @@ package app.softwork.uuid.sqldelight import app.cash.sqldelight.* import kotlin.uuid.Uuid -public object UuidStringAdapter : ColumnAdapter { +public data object UuidStringAdapter : ColumnAdapter { override fun decode(databaseValue: String): Uuid = Uuid.parse(databaseValue) override fun encode(value: Uuid): String = value.toString() }