69: Replace Moshi with kotlinx.serialization r=msfjarvis a=msfjarvis

More work towards #67

bors r+

Co-authored-by: Harsh Shandilya <me@msfjarvis.dev>
This commit is contained in:
bors[bot] 2020-11-07 05:49:58 +00:00 committed by GitHub
commit 800c91c637
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
11 changed files with 63 additions and 52 deletions

View file

@ -4,6 +4,7 @@ plugins {
id("com.android.application") id("com.android.application")
kotlin("android") kotlin("android")
kotlin("kapt") kotlin("kapt")
kotlin("plugin.serialization") version "1.4.10"
id("dagger.hilt.android.plugin") id("dagger.hilt.android.plugin")
`lobsters-plugin` `lobsters-plugin`
`core-library-desugaring` `core-library-desugaring`
@ -90,9 +91,9 @@ dependencies {
implementation(Dependencies.ThirdParty.Roomigrant.runtime) implementation(Dependencies.ThirdParty.Roomigrant.runtime)
implementation(Dependencies.AndroidX.material) implementation(Dependencies.AndroidX.material)
implementation(Dependencies.AndroidX.Hilt.dagger) implementation(Dependencies.AndroidX.Hilt.dagger)
implementation(Dependencies.ThirdParty.Moshi.lib)
implementation(Dependencies.ThirdParty.accompanist) implementation(Dependencies.ThirdParty.accompanist)
implementation(Dependencies.Kotlin.Coroutines.android) implementation(Dependencies.Kotlin.Coroutines.android)
implementation(Dependencies.Kotlin.Serialization.json)
implementation(Dependencies.ThirdParty.customtabs) implementation(Dependencies.ThirdParty.customtabs)
androidTestImplementation(Dependencies.Testing.daggerHilt) androidTestImplementation(Dependencies.Testing.daggerHilt)
testImplementation(Dependencies.Testing.junit) testImplementation(Dependencies.Testing.junit)

View file

@ -0,0 +1,10 @@
-keepattributes *Annotation*, InnerClasses
-dontnote kotlinx.serialization.AnnotationsKt # core serialization annotations
-keep,includedescriptorclasses class dev.msfjarvis.lobsters.model.**$$serializer { *; }
-keepclassmembers class dev.msfjarvis.lobsters.model.** {
*** Companion;
}
-keepclasseswithmembers class dev.msfjarvis.lobsters.model.** {
kotlinx.serialization.KSerializer serializer(...);
}

View file

@ -1,24 +1,24 @@
package dev.msfjarvis.lobsters.data.source package dev.msfjarvis.lobsters.data.source
import androidx.room.TypeConverter import androidx.room.TypeConverter
import com.squareup.moshi.Moshi
import dev.msfjarvis.lobsters.model.Submitter import dev.msfjarvis.lobsters.model.Submitter
import dev.msfjarvis.lobsters.model.SubmitterJsonAdapter import kotlinx.serialization.decodeFromString
import kotlinx.serialization.encodeToString
import kotlinx.serialization.json.Json
object LobstersApiTypeConverters { object LobstersApiTypeConverters {
private val moshi = Moshi.Builder().build()
private const val SEPARATOR = "," private const val SEPARATOR = ","
@TypeConverter @TypeConverter
@JvmStatic @JvmStatic
fun toSubmitterUser(value: String?): Submitter? { fun toSubmitterUser(value: String?): Submitter? {
return value?.let { SubmitterJsonAdapter(moshi).fromJson(value) } return value?.let { Json.decodeFromString(value) }
} }
@TypeConverter @TypeConverter
@JvmStatic @JvmStatic
fun fromSubmitterUser(value: Submitter?): String? { fun fromSubmitterUser(value: Submitter?): String? {
return value?.let { SubmitterJsonAdapter(moshi).toJson(value) } return value?.let { Json.encodeToString(value) }
} }
@TypeConverter @TypeConverter

View file

@ -136,7 +136,7 @@ fun PreviewLobstersItem() {
"sevan", "sevan",
null, null,
null, null,
null, emptyList(),
), ),
listOf("openbsd"), listOf("openbsd"),
) )

View file

@ -9,12 +9,19 @@ private const val DAGGER_HILT_VERSION = "2.29.1-alpha"
object Dependencies { object Dependencies {
const val COMPOSE_VERSION = "1.0.0-alpha06" const val COMPOSE_VERSION = "1.0.0-alpha06"
object Kotlin { object Kotlin {
object Coroutines { object Coroutines {
private const val version = "1.4.1" private const val version = "1.4.1"
const val android = "org.jetbrains.kotlinx:kotlinx-coroutines-android:$version" const val android = "org.jetbrains.kotlinx:kotlinx-coroutines-android:$version"
const val core = "org.jetbrains.kotlinx:kotlinx-coroutines-core:$version" const val core = "org.jetbrains.kotlinx:kotlinx-coroutines-core:$version"
} }
object Serialization {
private const val version = "1.0.1"
const val json = "org.jetbrains.kotlinx:kotlinx-serialization-json:$version"
}
} }
object AndroidX { object AndroidX {
@ -70,19 +77,12 @@ object Dependencies {
const val accompanist = "dev.chrisbanes.accompanist:accompanist-coil:0.3.2" const val accompanist = "dev.chrisbanes.accompanist:accompanist-coil:0.3.2"
const val customtabs = "saschpe.android:customtabs:3.0.2" const val customtabs = "saschpe.android:customtabs:3.0.2"
const val retrofitSerialization = "com.jakewharton.retrofit:retrofit2-kotlinx-serialization-converter:0.8.0"
object Moshi {
private const val version = "1.11.0"
const val codegen = "com.squareup.moshi:moshi-kotlin-codegen:$version"
const val lib = "com.squareup.moshi:moshi:$version"
}
object Retrofit { object Retrofit {
private const val version = "2.9.0" private const val version = "2.9.0"
const val lib = "com.squareup.retrofit2:retrofit:$version" const val lib = "com.squareup.retrofit2:retrofit:$version"
const val moshi = "com.squareup.retrofit2:converter-moshi:$version"
} }
object Roomigrant { object Roomigrant {

View file

@ -1,15 +1,14 @@
plugins { plugins {
id("com.android.library") id("com.android.library")
kotlin("android") kotlin("android")
kotlin("kapt") kotlin("plugin.serialization") version "1.4.10"
`lobsters-plugin` `lobsters-plugin`
} }
dependencies { dependencies {
implementation(project(":model")) implementation(project(":model"))
implementation(Dependencies.ThirdParty.Retrofit.lib) implementation(Dependencies.Kotlin.Serialization.json)
implementation(Dependencies.ThirdParty.Retrofit.moshi) implementation(Dependencies.ThirdParty.retrofitSerialization)
kaptTest(Dependencies.ThirdParty.Moshi.codegen)
testImplementation(Dependencies.Testing.junit) testImplementation(Dependencies.Testing.junit)
testImplementation(Dependencies.Kotlin.Coroutines.core) testImplementation(Dependencies.Kotlin.Coroutines.core)
testImplementation(Dependencies.Testing.mockWebServer) testImplementation(Dependencies.Testing.mockWebServer)

View file

@ -1,13 +1,15 @@
package dev.msfjarvis.lobsters.api package dev.msfjarvis.lobsters.api
import com.jakewharton.retrofit2.converter.kotlinx.serialization.asConverterFactory
import kotlinx.serialization.json.Json
import okhttp3.MediaType
import retrofit2.Retrofit import retrofit2.Retrofit
import retrofit2.converter.moshi.MoshiConverterFactory
object ApiClient { object ApiClient {
inline fun <reified T> getClient(baseUrl: String): T { inline fun <reified T> getClient(baseUrl: String): T {
return Retrofit.Builder() return Retrofit.Builder()
.baseUrl(baseUrl) .baseUrl(baseUrl)
.addConverterFactory(MoshiConverterFactory.create()) .addConverterFactory(Json.asConverterFactory(MediaType.get("application/json")))
.build() .build()
.create(T::class.java) .create(T::class.java)
} }

View file

@ -1,11 +1,10 @@
plugins { plugins {
id("com.android.library") id("com.android.library")
kotlin("android") kotlin("android")
kotlin("kapt") kotlin("plugin.serialization") version "1.4.10"
`lobsters-plugin` `lobsters-plugin`
} }
dependencies { dependencies {
kapt(Dependencies.ThirdParty.Moshi.codegen) implementation(Dependencies.Kotlin.Serialization.json)
implementation(Dependencies.ThirdParty.Moshi.lib)
} }

View file

@ -1,12 +1,12 @@
package dev.msfjarvis.lobsters.model package dev.msfjarvis.lobsters.model
import com.squareup.moshi.Json import kotlinx.serialization.SerialName
import com.squareup.moshi.JsonClass import kotlinx.serialization.Serializable
@JsonClass(generateAdapter = true) @Serializable
class KeybaseSignature( class KeybaseSignature(
@Json(name = "kb_username") @SerialName("kb_username")
val kbUsername: String, val kbUsername: String,
@Json(name = "sig_hash") @SerialName("sig_hash")
val sigHash: String val sigHash: String
) )

View file

@ -1,26 +1,26 @@
package dev.msfjarvis.lobsters.model package dev.msfjarvis.lobsters.model
import com.squareup.moshi.Json import kotlinx.serialization.SerialName
import com.squareup.moshi.JsonClass import kotlinx.serialization.Serializable
@JsonClass(generateAdapter = true) @Serializable
class LobstersPost( class LobstersPost(
@Json(name = "short_id") @SerialName("short_id")
val shortId: String, val shortId: String,
@Json(name = "short_id_url") @SerialName("short_id_url")
val shortIdUrl: String, val shortIdUrl: String,
@Json(name = "created_at") @SerialName("created_at")
val createdAt: String, val createdAt: String,
val title: String, val title: String,
val url: String, val url: String,
val score: Long, val score: Long,
val flags: Long, val flags: Long,
@Json(name = "comment_count") @SerialName("comment_count")
val commentCount: Long, val commentCount: Long,
val description: String, val description: String,
@Json(name = "comments_url") @SerialName("comments_url")
val commentsUrl: String, val commentsUrl: String,
@Json(name = "submitter_user") @SerialName("submitter_user")
val submitterUser: Submitter, val submitterUser: Submitter,
val tags: List<String>, val tags: List<String>,
) )

View file

@ -1,27 +1,27 @@
package dev.msfjarvis.lobsters.model package dev.msfjarvis.lobsters.model
import com.squareup.moshi.Json import kotlinx.serialization.SerialName
import com.squareup.moshi.JsonClass import kotlinx.serialization.Serializable
@JsonClass(generateAdapter = true) @Serializable
class Submitter( class Submitter(
val username: String, val username: String,
@Json(name = "created_at") @SerialName("created_at")
val createdAt: String, val createdAt: String,
@Json(name = "is_admin") @SerialName("is_admin")
val isAdmin: Boolean, val isAdmin: Boolean,
val about: String, val about: String,
@Json(name = "is_moderator") @SerialName("is_moderator")
val isModerator: Boolean, val isModerator: Boolean,
val karma: Long = 0, val karma: Long = 0,
@Json(name = "avatar_url") @SerialName("avatar_url")
val avatarUrl: String, val avatarUrl: String,
@Json(name = "invited_by_user") @SerialName("invited_by_user")
val invitedByUser: String, val invitedByUser: String,
@Json(name = "github_username") @SerialName("github_username")
val githubUsername: String?, val githubUsername: String? = null,
@Json(name = "twitter_username") @SerialName("twitter_username")
val twitterUsername: String?, val twitterUsername: String? = null,
@Json(name = "keybase_signatures") @SerialName("keybase_signatures")
val keybaseSignatures: List<KeybaseSignature>? val keybaseSignatures: List<KeybaseSignature> = emptyList()
) )