From b2cea5a2423b55cf6d9e5e5bfe9d2e06da53aadc Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=EC=9C=A4=EC=84=9D=EA=B7=9C?= Date: Mon, 27 Mar 2023 22:17:16 +0900 Subject: [PATCH] Add : DAuth Login --- .../dodamdodam/dauth_android/MainActivity.kt | 4 +- .../dauth/{RetrofitClient.kt => DAuth.kt} | 56 +++++++++---------- .../response/{Response.kt => BaseResponse.kt} | 2 +- .../dodamdodam/dauth/service/DAuthService.kt | 5 +- 4 files changed, 33 insertions(+), 34 deletions(-) rename dauth/src/main/java/kr/hs/dgsw/smartschool/dodamdodam/dauth/{RetrofitClient.kt => DAuth.kt} (77%) rename dauth/src/main/java/kr/hs/dgsw/smartschool/dodamdodam/dauth/response/{Response.kt => BaseResponse.kt} (90%) diff --git a/app/src/main/java/kr/hs/dgsw/smartschool/dodamdodam/dauth_android/MainActivity.kt b/app/src/main/java/kr/hs/dgsw/smartschool/dodamdodam/dauth_android/MainActivity.kt index 8fcac14..f5c6336 100644 --- a/app/src/main/java/kr/hs/dgsw/smartschool/dodamdodam/dauth_android/MainActivity.kt +++ b/app/src/main/java/kr/hs/dgsw/smartschool/dodamdodam/dauth_android/MainActivity.kt @@ -4,8 +4,8 @@ import androidx.appcompat.app.AppCompatActivity import android.os.Bundle import android.widget.Button import android.widget.Toast -import kr.hs.dgsw.smartschool.dodamdodam.dauth.RetrofitClient.loginForDodam -import kr.hs.dgsw.smartschool.dodamdodam.dauth.RetrofitClient.settingForDodam +import kr.hs.dgsw.smartschool.dodamdodam.dauth.DAuth.loginForDodam +import kr.hs.dgsw.smartschool.dodamdodam.dauth.DAuth.settingForDodam class MainActivity : AppCompatActivity() { override fun onCreate(savedInstanceState: Bundle?) { diff --git a/dauth/src/main/java/kr/hs/dgsw/smartschool/dodamdodam/dauth/RetrofitClient.kt b/dauth/src/main/java/kr/hs/dgsw/smartschool/dodamdodam/dauth/DAuth.kt similarity index 77% rename from dauth/src/main/java/kr/hs/dgsw/smartschool/dodamdodam/dauth/RetrofitClient.kt rename to dauth/src/main/java/kr/hs/dgsw/smartschool/dodamdodam/dauth/DAuth.kt index b90505d..37ff7b9 100644 --- a/dauth/src/main/java/kr/hs/dgsw/smartschool/dodamdodam/dauth/RetrofitClient.kt +++ b/dauth/src/main/java/kr/hs/dgsw/smartschool/dodamdodam/dauth/DAuth.kt @@ -12,30 +12,34 @@ import androidx.activity.result.ActivityResultLauncher import androidx.activity.result.contract.ActivityResultContracts import androidx.lifecycle.LifecycleOwner import androidx.lifecycle.MutableLiveData +import com.google.gson.Gson import com.google.gson.GsonBuilder import kotlinx.coroutines.CoroutineScope import kotlinx.coroutines.Dispatchers import kotlinx.coroutines.launch -import kotlinx.coroutines.withContext +import kr.hs.dgsw.smartschool.dodamdodam.dauth.DAuth.checkError import kr.hs.dgsw.smartschool.dodamdodam.dauth.request.LoginRequest import kr.hs.dgsw.smartschool.dodamdodam.dauth.request.TokenRequest import kr.hs.dgsw.smartschool.dodamdodam.dauth.response.TokenResponse import kr.hs.dgsw.smartschool.dodamdodam.dauth.service.DAuthService import okhttp3.OkHttpClient import okhttp3.logging.HttpLoggingInterceptor +import org.json.JSONObject +import retrofit2.HttpException +import retrofit2.Response import retrofit2.Retrofit import retrofit2.converter.gson.GsonConverterFactory import java.util.concurrent.TimeUnit -object RetrofitClient { +object DAuth { private const val DODAM_PACKAGE = "kr.hs.dgsw.smartschool.dodamdodam" private const val ACTIVITY_URL = "kr.hs.dgsw.smartschool.dodamdodam.features.dauth.DAuthActivity" private const val DAUTH_URL = "https://dauth.b1nd.com/api/" private const val BASE_URL = "https://dodam.b1nd.com/api/" - private var isInstalled = true - private val tokenData = MutableLiveData() + private var isInstalled = false + private val token = MutableLiveData() private val error = MutableLiveData() private val okHttpClient = OkHttpClient().newBuilder() @@ -62,18 +66,21 @@ object RetrofitClient { private val dAuth = dAuthRetrofit.create(DAuthService::class.java) - private suspend fun login(loginRequest: LoginRequest) = - withContext(CoroutineScope(Dispatchers.IO).coroutineContext) { - kotlin.runCatching { - dAuth.login(loginRequest) - } + private fun checkError(response: Response): T { + if (response.isSuccessful.not()) { + val errorBody = JSONObject(response.errorBody()!!.string()) + throw Throwable(errorBody.getString("message")) } - - private suspend fun getToken(tokenRequest: TokenRequest) = kotlin.runCatching { - dAuth.getToken(tokenRequest) + return response.body()!! } + private suspend fun login(loginRequest: LoginRequest) = kotlin.runCatching { + checkError(dAuth.login(loginRequest)) + } + private suspend fun getToken(tokenRequest: TokenRequest) = kotlin.runCatching { + checkError(dAuth.getToken(tokenRequest)) + } fun ComponentActivity.settingForDodam( clientId: String, @@ -85,7 +92,6 @@ object RetrofitClient { isInstalled = intent != null return registerForActivityResult(ActivityResultContracts.StartActivityForResult()) { result -> - if (result.resultCode == Activity.RESULT_OK) { val id = result.data?.getStringExtra("id") ?: "" @@ -95,23 +101,15 @@ object RetrofitClient { login(LoginRequest(id, pw, clientId, redirectUrl)) .onSuccess { val code = it.data.location.split("=", "&")[1] - getToken(TokenRequest(code, clientId, clientSecret)) - .onSuccess { token -> - Log.d("TOKEN", "settingForDodam: ${token.status} ${token.message} ${token.data}") -// launch(Dispatchers.Main) { -// tokenData.value = token.data -// } + getToken(TokenRequest(code, clientId, clientSecret)) + .onSuccess { tokenValue -> + token.postValue(tokenValue) }.onFailure { tokenError -> - Log.d("ERROR", "settingForDodam: ${tokenError.message}") - launch(Dispatchers.Main) { - error.value = Throwable(tokenError.message) - } + error.postValue(tokenError) } }.onFailure { - launch(Dispatchers.Main) { - error.value = Throwable(it.message) - } + error.postValue(Throwable(it)) } } } @@ -128,7 +126,7 @@ object RetrofitClient { if (isInstalled) register.launch(intent) else { - error.value = Throwable("도담도담을 설치해주세요") + error.postValue(Throwable("도담도담을 설치해주세요")) try { startActivity( @@ -147,11 +145,11 @@ object RetrofitClient { } } - tokenData.observe(this as LifecycleOwner) { + token.observe(this as LifecycleOwner) { onSuccess(it) } error.observe(this as LifecycleOwner) { - onFailure(it) + onFailure(Throwable(it.message!!.split(':').last())) } } } diff --git a/dauth/src/main/java/kr/hs/dgsw/smartschool/dodamdodam/dauth/response/Response.kt b/dauth/src/main/java/kr/hs/dgsw/smartschool/dodamdodam/dauth/response/BaseResponse.kt similarity index 90% rename from dauth/src/main/java/kr/hs/dgsw/smartschool/dodamdodam/dauth/response/Response.kt rename to dauth/src/main/java/kr/hs/dgsw/smartschool/dodamdodam/dauth/response/BaseResponse.kt index 06ad242..96d4c16 100644 --- a/dauth/src/main/java/kr/hs/dgsw/smartschool/dodamdodam/dauth/response/Response.kt +++ b/dauth/src/main/java/kr/hs/dgsw/smartschool/dodamdodam/dauth/response/BaseResponse.kt @@ -2,7 +2,7 @@ package kr.hs.dgsw.smartschool.dodamdodam.dauth.response import com.google.gson.annotations.SerializedName -data class Response( +data class BaseResponse( @field:SerializedName("status") val status: Int, @field:SerializedName("message") diff --git a/dauth/src/main/java/kr/hs/dgsw/smartschool/dodamdodam/dauth/service/DAuthService.kt b/dauth/src/main/java/kr/hs/dgsw/smartschool/dodamdodam/dauth/service/DAuthService.kt index 8b9b705..45fcf45 100644 --- a/dauth/src/main/java/kr/hs/dgsw/smartschool/dodamdodam/dauth/service/DAuthService.kt +++ b/dauth/src/main/java/kr/hs/dgsw/smartschool/dodamdodam/dauth/service/DAuthService.kt @@ -3,8 +3,9 @@ package kr.hs.dgsw.smartschool.dodamdodam.dauth.service import kr.hs.dgsw.smartschool.dodamdodam.dauth.request.LoginRequest import kr.hs.dgsw.smartschool.dodamdodam.dauth.request.TokenRequest import kr.hs.dgsw.smartschool.dodamdodam.dauth.response.LoginResponse -import kr.hs.dgsw.smartschool.dodamdodam.dauth.response.Response +import kr.hs.dgsw.smartschool.dodamdodam.dauth.response.BaseResponse import kr.hs.dgsw.smartschool.dodamdodam.dauth.response.TokenResponse +import retrofit2.Response import retrofit2.http.Body import retrofit2.http.POST @@ -12,7 +13,7 @@ interface DAuthService { @POST("auth/login") suspend fun login( @Body loginRequest: LoginRequest - ): Response + ): Response> @POST("token") suspend fun getToken(