Request both versions simultaneously

This commit is contained in:
Kirill Kamakin
2022-10-29 18:26:29 +02:00
parent 7702dbebd1
commit f2b20024eb
2 changed files with 27 additions and 17 deletions

View File

@@ -7,9 +7,9 @@ import javax.inject.Singleton
@Singleton @Singleton
class AuthDataSourceImpl @Inject constructor( class AuthDataSourceImpl @Inject constructor(
private val V0Source: MealieDataSourceV0, private val v0Source: MealieDataSourceV0,
) : AuthDataSource { ) : AuthDataSource {
override suspend fun authenticate(username: String, password: String, baseUrl: String): String = override suspend fun authenticate(username: String, password: String, baseUrl: String): String =
V0Source.authenticate(baseUrl, username, password) v0Source.authenticate(baseUrl, username, password)
} }

View File

@@ -16,6 +16,9 @@ import gq.kirmanak.mealient.extensions.runCatchingExceptCancel
import gq.kirmanak.mealient.extensions.toFullRecipeInfo import gq.kirmanak.mealient.extensions.toFullRecipeInfo
import gq.kirmanak.mealient.extensions.toRecipeSummaryInfo import gq.kirmanak.mealient.extensions.toRecipeSummaryInfo
import gq.kirmanak.mealient.extensions.toVersionInfo import gq.kirmanak.mealient.extensions.toVersionInfo
import kotlinx.coroutines.async
import kotlinx.coroutines.awaitAll
import kotlinx.coroutines.coroutineScope
import javax.inject.Inject import javax.inject.Inject
import javax.inject.Singleton import javax.inject.Singleton
@@ -23,31 +26,38 @@ import javax.inject.Singleton
class MealieDataSourceWrapper @Inject constructor( class MealieDataSourceWrapper @Inject constructor(
private val baseURLStorage: BaseURLStorage, private val baseURLStorage: BaseURLStorage,
private val authRepo: AuthRepo, private val authRepo: AuthRepo,
private val V0source: MealieDataSourceV0, private val v0source: MealieDataSourceV0,
private val V1Source: MealieDataSourceV1, private val v1Source: MealieDataSourceV1,
) : AddRecipeDataSource, RecipeDataSource, VersionDataSource { ) : AddRecipeDataSource, RecipeDataSource, VersionDataSource {
override suspend fun addRecipe(recipe: AddRecipeRequestV0): String = override suspend fun addRecipe(recipe: AddRecipeRequestV0): String =
withAuthHeader { token -> V0source.addRecipe(getUrl(), token, recipe) } withAuthHeader { token -> v0source.addRecipe(getUrl(), token, recipe) }
override suspend fun getVersionInfo(baseUrl: String): VersionInfo = override suspend fun getVersionInfo(baseUrl: String): VersionInfo {
runCatchingExceptCancel { val responses = coroutineScope {
V0source.getVersionInfo(baseUrl).toVersionInfo() val v0Deferred = async {
}.getOrElse { runCatchingExceptCancel { v0source.getVersionInfo(baseUrl).toVersionInfo() }
if (it is NetworkError.NotMealie) {
V1Source.getVersionInfo(baseUrl).toVersionInfo()
} else {
throw it
} }
val v1Deferred = async {
runCatchingExceptCancel { v1Source.getVersionInfo(baseUrl).toVersionInfo() }
}
listOf(v0Deferred, v1Deferred).awaitAll()
} }
val firstSuccess = responses.firstNotNullOfOrNull { it.getOrNull() }
if (firstSuccess == null) {
throw responses.firstNotNullOf { it.exceptionOrNull() }
} else {
return firstSuccess
}
}
override suspend fun requestRecipes(start: Int, limit: Int): List<RecipeSummaryInfo> = override suspend fun requestRecipes(start: Int, limit: Int): List<RecipeSummaryInfo> =
withAuthHeader { token -> withAuthHeader { token ->
val url = getUrl() val url = getUrl()
if (isV1()) { if (isV1()) {
V1Source.requestRecipes(url, token, start, limit).map { it.toRecipeSummaryInfo() } v1Source.requestRecipes(url, token, start, limit).map { it.toRecipeSummaryInfo() }
} else { } else {
V0source.requestRecipes(url, token, start, limit).map { it.toRecipeSummaryInfo() } v0source.requestRecipes(url, token, start, limit).map { it.toRecipeSummaryInfo() }
} }
} }
@@ -55,9 +65,9 @@ class MealieDataSourceWrapper @Inject constructor(
withAuthHeader { token -> withAuthHeader { token ->
val url = getUrl() val url = getUrl()
if (isV1()) { if (isV1()) {
V1Source.requestRecipeInfo(url, token, slug).toFullRecipeInfo() v1Source.requestRecipeInfo(url, token, slug).toFullRecipeInfo()
} else { } else {
V0source.requestRecipeInfo(url, token, slug).toFullRecipeInfo() v0source.requestRecipeInfo(url, token, slug).toFullRecipeInfo()
} }
} }