もうこれはテンプレ化しておきます。
Retrofit の話が中心となります。
👉 Retrofit data:image/s3,"s3://crabby-images/cc0a0/cc0a0f60f2c5157f35cdde02bb6a344718915b6c" alt=""
Converter
data:image/s3,"s3://crabby-images/5ab4b/5ab4bec10e95c90e39cf0156761c9439a14a0e48" alt="Retrofit-Converters"
JSON 形式のレスポンスをパースして変換するのは、Gson か Moshi が人気のように思います。
var retrofit = Retrofit.Builder()
.baseUrl("https://api.example.com")
.addConverterFactory(GsonConverterFactory.create())
.build()
var retrofit = Retrofit.Builder()
.baseUrl("https://api.example.com")
.addConverterFactory(MoshiConverterFactory.create())
.build()
👉 retrofit/retrofit-converters at master · square/retrofit data:image/s3,"s3://crabby-images/5e009/5e00922bc3d938ed492ecda147606243d4bcc50a" alt=""
今回は、Kotlin Serialization を利用した「Kotlin Serialization Converter」を使います。
ExperimentalSerializationApi なのですがね。
val contentType = "application/json".toMediaType()
val retrofit = Retrofit.Builder()
.baseUrl("https://example.com/")
.addConverterFactory(Json.asConverterFactory(contentType))
.build()
👉 JakeWharton/retrofit2-kotlinx-serialization-converter: A Retrofit 2 Converter.Factory for Kotlin serialization. data:image/s3,"s3://crabby-images/1e77e/1e77e886ca8ebb96a34e5e224dc0fdef762a0552" alt=""
Call Adapter
data:image/s3,"s3://crabby-images/6f6e5/6f6e5e38ff30ca5796778c9b70509942adafb6d5" alt="Retrofit CallAdapters"
通信の非同期処理はどれに任せるか。
var retrofit = Retrofit.Builder()
.baseUrl("https://api.example.com")
.addCallAdapterFactory(RxJavaCallAdapterFactory.create())
.build()
👉 retrofit/retrofit-adapters at master · square/retrofit data:image/s3,"s3://crabby-images/18388/183880e081dc862852e62ca9dd8dc1285528f906" alt=""
Coroutine を使った Jake製の「Kotlin Coroutine Adapter」は 今では DEPRECATED。
👉 JakeWharton/retrofit2-kotlin-coroutines-adapter: A Retrofit 2 adapter for Kotlin coroutine's Deferred type. data:image/s3,"s3://crabby-images/46e56/46e56160132d10e2113230d12bb56a1db607b3b5" alt=""
Retrofit は 2.6.0+ で、内部に suspend function をサポートしてるので、特に、.addCallAdapterFactory()
を使わなくてもよい。
@GET("users/{id}")
suspend fun user(@Path("id") id: Long): User
👉 retrofit/CHANGELOG.md at master · square/retrofit data:image/s3,"s3://crabby-images/6db2a/6db2a9ab5184c17e2c6e8aca589a323337692d89" alt=""
HttpLoggingInterceptor
OkHttpClient に HTTP関連のログを吐かせます。
--> POST /greeting http/1.1
Host: example.com
Content-Type: plain/text
Content-Length: 3
Hi?
--> END POST
<-- 200 OK (22ms)
Content-Type: plain/text
Content-Length: 6
Hello!
<-- END HTTP
👉 HttpLoggingInterceptor.Level (OkHttp Logging Interceptor 3.14.0 API) data:image/s3,"s3://crabby-images/3b4af/3b4af738d5377f1041de4a5085ecba7e3ee84f73" alt=""
val logging = HttpLoggingInterceptor()
logging.setLevel(Level.BASIC)
val client = OkHttpClient.Builder()
.addInterceptor(logging)
.build()
👉 okhttp/okhttp-logging-interceptor at master · square/okhttp data:image/s3,"s3://crabby-images/d2975/d2975c8a7c2369239f46a08ea468f594e65e14ff" alt=""
まとめ
Dagger の Module にしておきます。
テンプレート化してください、と言わんばかりに
よく似たものをあちこちで見かけますよね。
見通しも良くなります。
コピペでどうぞ。
(おわり)