mirror of
https://github.com/msfjarvis/compose-lobsters
synced 2025-08-17 23:47:02 +05:30
Merge #69
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:
commit
800c91c637
11 changed files with 63 additions and 52 deletions
|
@ -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)
|
||||||
|
|
10
app/proguard-rules.pro
vendored
10
app/proguard-rules.pro
vendored
|
@ -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(...);
|
||||||
|
}
|
|
@ -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
|
||||||
|
|
|
@ -136,7 +136,7 @@ fun PreviewLobstersItem() {
|
||||||
"sevan",
|
"sevan",
|
||||||
null,
|
null,
|
||||||
null,
|
null,
|
||||||
null,
|
emptyList(),
|
||||||
),
|
),
|
||||||
listOf("openbsd"),
|
listOf("openbsd"),
|
||||||
)
|
)
|
||||||
|
|
|
@ -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 {
|
||||||
|
|
|
@ -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)
|
||||||
|
|
|
@ -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)
|
||||||
}
|
}
|
||||||
|
|
|
@ -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)
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -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
|
||||||
)
|
)
|
||||||
|
|
|
@ -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>,
|
||||||
)
|
)
|
||||||
|
|
|
@ -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()
|
||||||
)
|
)
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue