diff --git a/.coderabbit.yaml b/.coderabbit.yaml
index 992d2a1051c133f6d9c71b0400fd983991958c63..34d8a2cc66e7f0b4f072606b1c844b0d237fa282 100644
--- a/.coderabbit.yaml
+++ b/.coderabbit.yaml
@@ -10,6 +10,6 @@ reviews:
collapse_walkthrough: true
auto_review:
enabled: true
- drafts: true
+ drafts: false
chat:
auto_reply: false
diff --git a/app/src/main/AndroidManifest.xml b/app/src/main/AndroidManifest.xml
index 4b789577b3f30108069c8b05478e75a20382c512..fe79aa0933f8fd69ee2db6a916b70b323660e5a6 100644
--- a/app/src/main/AndroidManifest.xml
+++ b/app/src/main/AndroidManifest.xml
@@ -21,7 +21,7 @@
xmlns:tools="http://schemas.android.com/tools">
@@ -124,7 +124,7 @@
-
@@ -175,8 +175,8 @@
diff --git a/app/src/main/java/foundation/e/apps/data/AppSourcesContainer.kt b/app/src/main/java/foundation/e/apps/data/AppSourcesContainer.kt
index f6735a11749f4014c82554c7e6d6d2d5995a6c12..c32a2fe17a5fb8a1388eaf63df0e5434b45a2924 100644
--- a/app/src/main/java/foundation/e/apps/data/AppSourcesContainer.kt
+++ b/app/src/main/java/foundation/e/apps/data/AppSourcesContainer.kt
@@ -19,15 +19,15 @@
package foundation.e.apps.data
-import foundation.e.apps.data.cleanapk.repositories.CleanApkRepository
+import foundation.e.apps.data.cleanapk.repositories.CleanApkAppsRepository
+import foundation.e.apps.data.cleanapk.repositories.CleanApkPwaRepository
import foundation.e.apps.data.playstore.PlayStoreRepository
import javax.inject.Inject
-import javax.inject.Named
import javax.inject.Singleton
@Singleton
class AppSourcesContainer @Inject constructor(
- @Named("gplayRepository") val gplayRepo: PlayStoreRepository,
- @Named("cleanApkAppsRepository") val cleanApkAppsRepo: CleanApkRepository,
- @Named("cleanApkPWARepository") val cleanApkPWARepo: CleanApkRepository
+ val gplayRepo: PlayStoreRepository,
+ val cleanApkAppsRepo: CleanApkAppsRepository,
+ val cleanApkPWARepo: CleanApkPwaRepository
)
diff --git a/app/src/main/java/foundation/e/apps/data/NetworkHandler.kt b/app/src/main/java/foundation/e/apps/data/NetworkHandler.kt
index f5c5cdd50a9099331500746b5aa7f51ba3e1757e..5b13f55916a7e14764235f19d845d66adb695315 100644
--- a/app/src/main/java/foundation/e/apps/data/NetworkHandler.kt
+++ b/app/src/main/java/foundation/e/apps/data/NetworkHandler.kt
@@ -18,9 +18,9 @@
package foundation.e.apps.data
+import foundation.e.apps.data.login.exceptions.CustomException
import foundation.e.apps.data.playstore.utils.GPlayHttpClient
import foundation.e.apps.data.playstore.utils.GplayHttpRequestException
-import foundation.e.apps.data.login.exceptions.GPlayException
import kotlinx.coroutines.delay
import timber.log.Timber
import java.net.SocketTimeoutException
@@ -55,9 +55,15 @@ private fun handleSocketTimeoutException(e: SocketTimeoutException): ResultS
private fun resultSupremeGplayHttpRequestException(e: GplayHttpRequestException): ResultSupreme {
val message = extractErrorMessage(e)
- val exception = GPlayException(e.status == GPlayHttpClient.STATUS_CODE_TIMEOUT, message)
+ val error = if (e.status == GPlayHttpClient.STATUS_CODE_TIMEOUT) {
+ CustomException.Error.TIMEOUT_ERROR
+ } else {
+ CustomException.Error.UNKNOWN_ERROR
+ }
+
+ val exception = CustomException(error, message)
- return if (exception.isTimeout) {
+ return if (error == CustomException.Error.TIMEOUT_ERROR) {
ResultSupreme.Timeout(exception = exception)
} else {
ResultSupreme.Error(message, exception)
diff --git a/app/src/main/java/foundation/e/apps/data/ResultSupreme.kt b/app/src/main/java/foundation/e/apps/data/ResultSupreme.kt
index a7a773f60ae33131d12c9ec6f68cae8adda48356..70eb4ff6ec0ff8909285879c967bf88c794d00a2 100644
--- a/app/src/main/java/foundation/e/apps/data/ResultSupreme.kt
+++ b/app/src/main/java/foundation/e/apps/data/ResultSupreme.kt
@@ -18,6 +18,7 @@
package foundation.e.apps.data
import foundation.e.apps.data.enums.ResultStatus
+import foundation.e.apps.data.login.exceptions.CustomException
import java.util.concurrent.TimeoutException
private const val UNKNOWN_ERROR = "Unknown error!"
@@ -60,7 +61,7 @@ sealed class ResultSupreme {
data?.let {
setData(it)
}
- this.exception = exception
+ this.exception?.encapsulatedException = exception
}
}
@@ -76,7 +77,7 @@ sealed class ResultSupreme {
*/
constructor(message: String, exception: Exception? = null) : this() {
this.message = message
- this.exception = exception
+ this.exception?.encapsulatedException = exception
}
/**
@@ -111,7 +112,7 @@ sealed class ResultSupreme {
/**
* Exception from try-catch block for error cases.
*/
- var exception: Exception? = null
+ var exception: CustomException? = null
fun isValidData() = data != null
@@ -155,7 +156,7 @@ sealed class ResultSupreme {
this.data = data
} else {
this.message = message.ifBlank { status.message }
- this.exception = exception
+ this.exception?.encapsulatedException = exception
}
}
return resultObject
diff --git a/app/src/main/java/foundation/e/apps/data/StoreRepository.kt b/app/src/main/java/foundation/e/apps/data/StoreRepository.kt
index 0f8e1e426c64c77e188da2034144dd184235a017..e1c04d98e371777d4f7278de0318ca78535a6841 100644
--- a/app/src/main/java/foundation/e/apps/data/StoreRepository.kt
+++ b/app/src/main/java/foundation/e/apps/data/StoreRepository.kt
@@ -18,7 +18,9 @@
package foundation.e.apps.data
+import foundation.e.apps.data.application.data.Application
+
interface StoreRepository {
- suspend fun getHomeScreenData(): Any
- suspend fun getAppDetails(packageNameOrId: String): Any?
+ suspend fun getHomeScreenData(): Map>
+ suspend fun getAppDetails(packageNameOrId: String): Application
}
diff --git a/app/src/main/java/foundation/e/apps/data/application/ApplicationDataManager.kt b/app/src/main/java/foundation/e/apps/data/application/ApplicationDataManager.kt
index 7fafbccd5f5edfb25a7e02bca9df5654a97f8805..8885da06f438d18de161e02479927c04e6e09576 100644
--- a/app/src/main/java/foundation/e/apps/data/application/ApplicationDataManager.kt
+++ b/app/src/main/java/foundation/e/apps/data/application/ApplicationDataManager.kt
@@ -26,17 +26,16 @@ import foundation.e.apps.data.enums.FilterLevel
import foundation.e.apps.data.enums.Origin
import foundation.e.apps.data.enums.Status
import foundation.e.apps.data.playstore.PlayStoreRepository
-import foundation.e.apps.install.pkg.PWAManager
+import foundation.e.apps.install.pkg.PwaManager
import foundation.e.apps.install.pkg.AppLoungePackageManager
import javax.inject.Inject
-import javax.inject.Named
import javax.inject.Singleton
@Singleton
class ApplicationDataManager @Inject constructor(
- @Named("gplayRepository") private val gplayRepository: PlayStoreRepository,
+ private val gPlayRepository: PlayStoreRepository,
private val appLoungePackageManager: AppLoungePackageManager,
- private val pwaManager: PWAManager
+ private val pwaManager: PwaManager
) {
suspend fun updateFilterLevel(authData: AuthData?, application: Application) {
application.filterLevel = getAppFilterLevel(application, authData)
@@ -81,7 +80,7 @@ class ApplicationDataManager @Inject constructor(
* Example: com.skype.m2
*/
private suspend fun isApplicationVisible(application: Application): Boolean {
- return kotlin.runCatching { gplayRepository.getAppDetails(application.package_name) }.isSuccess
+ return kotlin.runCatching { gPlayRepository.getAppDetails(application.package_name) }.isSuccess
}
/*
@@ -90,7 +89,7 @@ class ApplicationDataManager @Inject constructor(
*/
private suspend fun isDownloadable(application: Application): Boolean {
return kotlin.runCatching {
- gplayRepository.getDownloadInfo(
+ gPlayRepository.getDownloadInfo(
application.package_name,
application.latest_version_code,
application.offer_type,
diff --git a/app/src/main/java/foundation/e/apps/data/application/apps/AppsApiImpl.kt b/app/src/main/java/foundation/e/apps/data/application/apps/AppsApiImpl.kt
index e4847beced933d98557325c576edf5aea4a854e1..beb4238d951e857f4963b51334a6afbc2441bdc0 100644
--- a/app/src/main/java/foundation/e/apps/data/application/apps/AppsApiImpl.kt
+++ b/app/src/main/java/foundation/e/apps/data/application/apps/AppsApiImpl.kt
@@ -21,7 +21,6 @@ package foundation.e.apps.data.application.apps
import android.content.Context
import com.aurora.gplayapi.data.models.App
import com.aurora.gplayapi.data.models.AuthData
-import com.aurora.gplayapi.data.models.ContentRating
import dagger.hilt.android.qualifiers.ApplicationContext
import foundation.e.apps.data.AppSourcesContainer
import foundation.e.apps.data.application.ApplicationDataManager
@@ -38,7 +37,7 @@ import foundation.e.apps.data.preference.AppLoungePreference
import foundation.e.apps.ui.applicationlist.ApplicationDiffUtil
import retrofit2.Response
import javax.inject.Inject
-import foundation.e.apps.data.cleanapk.data.app.Application as CleanApkApplication
+import foundation.e.apps.data.cleanapk.data.app.CleanApkApplication
class AppsApiImpl @Inject constructor(
@ApplicationContext private val context: Context,
@@ -61,8 +60,7 @@ class AppsApiImpl @Inject constructor(
if (result?.hasSingleResult() == true) {
application =
- (appSources.cleanApkAppsRepo.getAppDetails(result.apps[0]._id)
- as Response).body()?.app ?: Application()
+ appSources.cleanApkAppsRepo.getAppDetails(result.apps[0]._id)
}
application.updateFilterLevel(null)
@@ -190,18 +188,16 @@ class AppsApiImpl @Inject constructor(
authData: AuthData,
origin: Origin
): Pair {
- var application: Application?
+ var application: Application
val result = handleNetworkResult {
application = if (origin == Origin.CLEANAPK) {
- (appSources.cleanApkAppsRepo.getAppDetails(id)
- as Response).body()?.app
+ appSources.cleanApkAppsRepo.getAppDetails(id)
} else {
- val app = appSources.gplayRepo.getAppDetails(packageName) as App?
- app?.toApplication(context)
+ appSources.gplayRepo.getAppDetails(packageName)
}
- application?.let {
+ application.let {
applicationDataManager.updateStatus(it)
it.updateType()
it.updateSource(context)
diff --git a/app/src/main/java/foundation/e/apps/data/application/home/HomeApiImpl.kt b/app/src/main/java/foundation/e/apps/data/application/home/HomeApiImpl.kt
index 53a4024276f1a9cd564337967f7d6f1fecffd79b..6ed63a29c8319ef3ef640269c5cec955f80bead3 100644
--- a/app/src/main/java/foundation/e/apps/data/application/home/HomeApiImpl.kt
+++ b/app/src/main/java/foundation/e/apps/data/application/home/HomeApiImpl.kt
@@ -21,18 +21,14 @@ package foundation.e.apps.data.application.home
import android.content.Context
import androidx.lifecycle.LiveData
import androidx.lifecycle.liveData
-import com.aurora.gplayapi.data.models.App
import com.aurora.gplayapi.data.models.AuthData
import dagger.hilt.android.qualifiers.ApplicationContext
-import foundation.e.apps.R
import foundation.e.apps.data.AppSourcesContainer
import foundation.e.apps.data.ResultSupreme
import foundation.e.apps.data.application.ApplicationDataManager
import foundation.e.apps.data.application.data.Home
import foundation.e.apps.data.application.search.FusedHomeDeferred
import foundation.e.apps.data.application.search.SearchApi
-import foundation.e.apps.data.application.utils.toApplication
-import foundation.e.apps.data.cleanapk.data.home.HomeScreen
import foundation.e.apps.data.enums.ResultStatus
import foundation.e.apps.data.enums.Source
import foundation.e.apps.data.handleNetworkResult
@@ -44,10 +40,8 @@ import kotlinx.coroutines.MainScope
import kotlinx.coroutines.async
import kotlinx.coroutines.coroutineScope
import kotlinx.coroutines.launch
-import retrofit2.Response
import timber.log.Timber
import javax.inject.Inject
-import foundation.e.apps.data.cleanapk.data.home.Home as CleanApkHome
class HomeApiImpl @Inject constructor(
@ApplicationContext private val context: Context,
@@ -142,87 +136,19 @@ class HomeApiImpl @Inject constructor(
priorList: MutableList,
appType: String
): MutableList {
- val response = if (appType == SearchApi.APP_TYPE_OPEN) {
- (appSources.cleanApkAppsRepo.getHomeScreenData() as Response).body()
+ val homes = if (appType == SearchApi.APP_TYPE_OPEN) {
+ appSources.cleanApkAppsRepo.getHomeScreenData()
} else {
- (appSources.cleanApkPWARepo.getHomeScreenData() as Response).body()
+ appSources.cleanApkPWARepo.getHomeScreenData()
}
- response?.home?.let {
- priorList.addAll(generateCleanAPKHome(it, appType))
+ homes.forEach { (title, list) ->
+ priorList.add(Home(title, list, appType))
}
return priorList
}
- private suspend fun generateCleanAPKHome(home: CleanApkHome, appType: String): List {
- val list = mutableListOf()
- val headings = if (appType == SearchApi.APP_TYPE_OPEN) {
- getOpenSourceHomeCategories()
- } else {
- getPWAHomeCategories()
- }
-
- headings.forEach { (key, value) ->
- when (key) {
- "top_updated_apps" -> {
- applicationDataManager.prepareApps(home.top_updated_apps, list, value)
- }
-
- "top_updated_games" -> {
- applicationDataManager.prepareApps(home.top_updated_games, list, value)
- }
-
- "popular_apps" -> {
- applicationDataManager.prepareApps(home.popular_apps, list, value)
- }
-
- "popular_games" -> {
- applicationDataManager.prepareApps(home.popular_games, list, value)
- }
-
- "popular_apps_in_last_24_hours" -> {
- applicationDataManager.prepareApps(
- home.popular_apps_in_last_24_hours,
- list,
- value
- )
- }
-
- "popular_games_in_last_24_hours" -> {
- applicationDataManager.prepareApps(
- home.popular_games_in_last_24_hours,
- list,
- value
- )
- }
-
- "discover" -> {
- applicationDataManager.prepareApps(home.discover, list, value)
- }
- }
- }
-
- return list.map {
- it.source = appType
- it
- }
- }
-
- private fun getPWAHomeCategories() = mapOf(
- "popular_apps" to context.getString(R.string.popular_apps),
- "popular_games" to context.getString(R.string.popular_games),
- "discover" to context.getString(R.string.discover_pwa)
- )
-
- private fun getOpenSourceHomeCategories() = mapOf(
- "top_updated_apps" to context.getString(R.string.top_updated_apps),
- "top_updated_games" to context.getString(R.string.top_updated_games),
- "popular_apps_in_last_24_hours" to context.getString(R.string.popular_apps_in_last_24_hours),
- "popular_games_in_last_24_hours" to context.getString(R.string.popular_games_in_last_24_hours),
- "discover" to context.getString(R.string.discover)
- )
-
private fun setHomeErrorMessage(apiStatus: ResultStatus, source: Source) {
if (apiStatus != ResultStatus.OK) {
apiStatus.message = when (source) {
@@ -239,11 +165,11 @@ class HomeApiImpl @Inject constructor(
priorList: MutableList
): List {
val list = mutableListOf()
- val gplayHomeData =
- appSources.gplayRepo.getHomeScreenData() as Map>
+ val gplayHomeData = appSources.gplayRepo.getHomeScreenData()
+
gplayHomeData.map {
val fusedApps = it.value.map { app ->
- app.toApplication(context).apply {
+ app.apply {
applicationDataManager.updateStatus(this)
applicationDataManager.updateFilterLevel(authData, this)
}
@@ -277,5 +203,4 @@ class HomeApiImpl @Inject constructor(
)
}
}
-
}
diff --git a/app/src/main/java/foundation/e/apps/data/cleanapk/ApplicationDeserializer.kt b/app/src/main/java/foundation/e/apps/data/cleanapk/ApplicationDeserializer.kt
index 5d9b3910bef7caa82031b8ba1bead5754d493cb9..b5c69ee734d5f01da702f5ddda33e2d0ec0089ce 100644
--- a/app/src/main/java/foundation/e/apps/data/cleanapk/ApplicationDeserializer.kt
+++ b/app/src/main/java/foundation/e/apps/data/cleanapk/ApplicationDeserializer.kt
@@ -22,22 +22,22 @@ import com.google.gson.Gson
import com.google.gson.JsonDeserializationContext
import com.google.gson.JsonDeserializer
import com.google.gson.JsonElement
-import foundation.e.apps.data.cleanapk.data.app.Application
+import foundation.e.apps.data.cleanapk.data.app.CleanApkApplication
-class ApplicationDeserializer : JsonDeserializer {
+class ApplicationDeserializer : JsonDeserializer {
override fun deserialize(
json: JsonElement?,
typeOfT: java.lang.reflect.Type?,
context: JsonDeserializationContext?
- ): Application {
+ ): CleanApkApplication {
val gson = Gson()
- val application = gson.fromJson(json?.asJsonObject?.toString(), Application::class.java)
- val lastUpdate = application.app.latest_downloaded_version
+ val cleanApkApplication = gson.fromJson(json?.asJsonObject?.toString(), CleanApkApplication::class.java)
+ val lastUpdate = cleanApkApplication.app.latest_downloaded_version
val lastUpdateJson = json?.asJsonObject?.get("app")?.asJsonObject?.get(lastUpdate)?.asJsonObject
val lastUpdatedOn = lastUpdateJson
?.asJsonObject?.get("update_on")?.asString ?: ""
- application.app.updatedOn = lastUpdatedOn
- application.app.latest_version_code = lastUpdateJson?.get("version_code")?.asInt ?: -1
- return application
+ cleanApkApplication.app.updatedOn = lastUpdatedOn
+ cleanApkApplication.app.latest_version_code = lastUpdateJson?.get("version_code")?.asInt ?: -1
+ return cleanApkApplication
}
}
diff --git a/app/src/main/java/foundation/e/apps/data/cleanapk/CleanApkAppDetailsRetrofit.kt b/app/src/main/java/foundation/e/apps/data/cleanapk/CleanApkAppDetailsRetrofit.kt
deleted file mode 100644
index 69574481db52aeda77f3c62983461a499f8a35f8..0000000000000000000000000000000000000000
--- a/app/src/main/java/foundation/e/apps/data/cleanapk/CleanApkAppDetailsRetrofit.kt
+++ /dev/null
@@ -1,36 +0,0 @@
-/*
- *
- * * Copyright ECORP SAS 2022
- * * Apps Quickly and easily install Android apps onto your device!
- * *
- * * This program is free software: you can redistribute it and/or modify
- * * it under the terms of the GNU General Public License as published by
- * * the Free Software Foundation, either version 3 of the License, or
- * * (at your option) any later version.
- * *
- * * This program is distributed in the hope that it will be useful,
- * * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- * * GNU General Public License for more details.
- * *
- * * You should have received a copy of the GNU General Public License
- * * along with this program. If not, see .
- *
- */
-
-package foundation.e.apps.data.cleanapk
-
-import foundation.e.apps.data.cleanapk.data.app.Application
-import retrofit2.Response
-import retrofit2.http.GET
-import retrofit2.http.Query
-
-interface CleanApkAppDetailsRetrofit {
-
- @GET("apps?action=app_detail")
- suspend fun getAppOrPWADetailsByID(
- @Query("id") id: String,
- @Query("architectures") architectures: List? = null,
- @Query("type") type: String? = null
- ): Response
-}
diff --git a/app/src/main/java/foundation/e/apps/data/cleanapk/CleanApkRetrofit.kt b/app/src/main/java/foundation/e/apps/data/cleanapk/CleanApkRetrofit.kt
index 3da3d4014c5d119b0b23b1d3bfb72832fe78f6e8..1e88833987942f8df0af439aecdabfd83bab0400 100644
--- a/app/src/main/java/foundation/e/apps/data/cleanapk/CleanApkRetrofit.kt
+++ b/app/src/main/java/foundation/e/apps/data/cleanapk/CleanApkRetrofit.kt
@@ -18,10 +18,10 @@
package foundation.e.apps.data.cleanapk
-import foundation.e.apps.data.cleanapk.data.app.Application
+import foundation.e.apps.data.cleanapk.data.app.CleanApkApplication
import foundation.e.apps.data.cleanapk.data.categories.Categories
import foundation.e.apps.data.cleanapk.data.download.Download
-import foundation.e.apps.data.cleanapk.data.home.HomeScreen
+import foundation.e.apps.data.cleanapk.data.home.HomeScreenResponse
import foundation.e.apps.data.cleanapk.data.search.Search
import retrofit2.Response
import retrofit2.http.GET
@@ -48,7 +48,7 @@ interface CleanApkRetrofit {
suspend fun getHomeScreenData(
@Query("type") type: String = APP_TYPE_ANY,
@Query("source") source: String = APP_SOURCE_ANY,
- ): Response
+ ): Response
// TODO: Reminder that this function is for search App and PWA both
@GET("apps?action=app_detail")
@@ -56,7 +56,7 @@ interface CleanApkRetrofit {
@Query("id") id: String,
@Query("architectures") architectures: List? = null,
@Query("type") type: String? = null
- ): Response
+ ): Response
@GET("apps?action=search")
suspend fun searchApps(
diff --git a/app/src/main/java/foundation/e/apps/data/cleanapk/data/app/Application.kt b/app/src/main/java/foundation/e/apps/data/cleanapk/data/app/CleanApkApplication.kt
similarity index 81%
rename from app/src/main/java/foundation/e/apps/data/cleanapk/data/app/Application.kt
rename to app/src/main/java/foundation/e/apps/data/cleanapk/data/app/CleanApkApplication.kt
index 906d9b2d0a17384ff555de8830d6f01756472513..4ba0b0c7b5a79ad3296059d33a9b835bd1b2754e 100644
--- a/app/src/main/java/foundation/e/apps/data/cleanapk/data/app/Application.kt
+++ b/app/src/main/java/foundation/e/apps/data/cleanapk/data/app/CleanApkApplication.kt
@@ -18,9 +18,9 @@
package foundation.e.apps.data.cleanapk.data.app
-import foundation.e.apps.data.application.data.Application as AppLoungeApplication
+import foundation.e.apps.data.application.data.Application
-data class Application(
- val app: AppLoungeApplication = AppLoungeApplication(),
+data class CleanApkApplication(
+ val app: Application = Application(),
val success: Boolean = false
)
diff --git a/app/src/main/java/foundation/e/apps/data/cleanapk/data/home/Home.kt b/app/src/main/java/foundation/e/apps/data/cleanapk/data/home/CleanApkHome.kt
similarity index 86%
rename from app/src/main/java/foundation/e/apps/data/cleanapk/data/home/Home.kt
rename to app/src/main/java/foundation/e/apps/data/cleanapk/data/home/CleanApkHome.kt
index 8e50e09c383b1ab92f15c25c3b7650a06a4e44dc..7118307bed1fb092e5a35f0e7c272d0949e5cd88 100644
--- a/app/src/main/java/foundation/e/apps/data/cleanapk/data/home/Home.kt
+++ b/app/src/main/java/foundation/e/apps/data/cleanapk/data/home/CleanApkHome.kt
@@ -21,13 +21,11 @@ package foundation.e.apps.data.cleanapk.data.home
import foundation.e.apps.data.enums.Origin
import foundation.e.apps.data.application.data.Application
-data class Home(
+data class CleanApkHome(
val top_updated_apps: List = emptyList(),
val top_updated_games: List = emptyList(),
val popular_apps: List = emptyList(),
val popular_games: List = emptyList(),
- val popular_apps_in_last_24_hours: List = emptyList(),
- val popular_games_in_last_24_hours: List = emptyList(),
val discover: List = emptyList(),
var origin: Origin = Origin.CLEANAPK // Origin
)
diff --git a/app/src/main/java/foundation/e/apps/data/cleanapk/data/home/HomeScreen.kt b/app/src/main/java/foundation/e/apps/data/cleanapk/data/home/HomeScreenResponse.kt
similarity index 89%
rename from app/src/main/java/foundation/e/apps/data/cleanapk/data/home/HomeScreen.kt
rename to app/src/main/java/foundation/e/apps/data/cleanapk/data/home/HomeScreenResponse.kt
index 27d0f7db4f115c2b493d5596a812f9c526054f4e..9c64a8a752248048f4340bdc6d7405f314facaea 100644
--- a/app/src/main/java/foundation/e/apps/data/cleanapk/data/home/HomeScreen.kt
+++ b/app/src/main/java/foundation/e/apps/data/cleanapk/data/home/HomeScreenResponse.kt
@@ -18,7 +18,7 @@
package foundation.e.apps.data.cleanapk.data.home
-data class HomeScreen(
- val home: Home = Home(),
+data class HomeScreenResponse(
+ val home: CleanApkHome = CleanApkHome(),
val success: Boolean = false
)
diff --git a/app/src/main/java/foundation/e/apps/data/cleanapk/repositories/CleanApkAppsRepositoryImpl.kt b/app/src/main/java/foundation/e/apps/data/cleanapk/repositories/CleanApkAppsRepository.kt
similarity index 73%
rename from app/src/main/java/foundation/e/apps/data/cleanapk/repositories/CleanApkAppsRepositoryImpl.kt
rename to app/src/main/java/foundation/e/apps/data/cleanapk/repositories/CleanApkAppsRepository.kt
index e51a82823645d903fa0a85179db5745242cd9e48..b97b3ce301573483c072b9021990feda76ab1cdd 100644
--- a/app/src/main/java/foundation/e/apps/data/cleanapk/repositories/CleanApkAppsRepositoryImpl.kt
+++ b/app/src/main/java/foundation/e/apps/data/cleanapk/repositories/CleanApkAppsRepository.kt
@@ -18,26 +18,38 @@
package foundation.e.apps.data.cleanapk.repositories
-import foundation.e.apps.data.cleanapk.CleanApkAppDetailsRetrofit
+import android.content.Context
+import dagger.hilt.android.qualifiers.ApplicationContext
+import foundation.e.apps.data.application.data.Application
import foundation.e.apps.data.cleanapk.CleanApkDownloadInfoFetcher
import foundation.e.apps.data.cleanapk.CleanApkRetrofit
-import foundation.e.apps.data.cleanapk.data.app.Application
+import foundation.e.apps.data.cleanapk.data.app.CleanApkApplication
import foundation.e.apps.data.cleanapk.data.categories.Categories
import foundation.e.apps.data.cleanapk.data.download.Download
-import foundation.e.apps.data.cleanapk.data.home.HomeScreen
import foundation.e.apps.data.cleanapk.data.search.Search
import retrofit2.Response
+import javax.inject.Inject
-class CleanApkAppsRepositoryImpl(
+class CleanApkAppsRepository @Inject constructor(
private val cleanApkRetrofit: CleanApkRetrofit,
- private val cleanApkAppDetailsRetrofit: CleanApkAppDetailsRetrofit
+ private val homeConverter: HomeConverter
) : CleanApkRepository, CleanApkDownloadInfoFetcher {
- override suspend fun getHomeScreenData(): Response {
- return cleanApkRetrofit.getHomeScreenData(
+ override suspend fun getHomeScreenData(): Map> {
+
+ val response = cleanApkRetrofit.getHomeScreenData(
CleanApkRetrofit.APP_TYPE_ANY,
CleanApkRetrofit.APP_SOURCE_FOSS
)
+
+ val home = response.body()?.home ?: throw IllegalStateException("No home data found")
+ val listHome = homeConverter.toGenericHome(home, CleanApkRetrofit.APP_TYPE_ANY)
+ val map = mutableMapOf>()
+ listHome.forEach {
+ map[it.title] = it.list
+ }
+
+ return map
}
override suspend fun getSearchResult(query: String, searchBy: String?): Response {
@@ -75,8 +87,9 @@ class CleanApkAppsRepositoryImpl(
return cleanApkRetrofit.checkAvailablePackages(packageNames)
}
- override suspend fun getAppDetails(packageNameOrId: String): Response {
- return cleanApkAppDetailsRetrofit.getAppOrPWADetailsByID(packageNameOrId, null, null)
+ override suspend fun getAppDetails(packageNameOrId: String): Application {
+ val response = cleanApkRetrofit.getAppOrPWADetailsByID(packageNameOrId, null, null)
+ return response.body()?.app ?: throw IllegalStateException("No app data found")
}
override suspend fun getDownloadInfo(idOrPackageName: String, versionCode: Any?): Response {
diff --git a/app/src/main/java/foundation/e/apps/data/cleanapk/repositories/CleanApkPWARepository.kt b/app/src/main/java/foundation/e/apps/data/cleanapk/repositories/CleanApkPwaRepository.kt
similarity index 62%
rename from app/src/main/java/foundation/e/apps/data/cleanapk/repositories/CleanApkPWARepository.kt
rename to app/src/main/java/foundation/e/apps/data/cleanapk/repositories/CleanApkPwaRepository.kt
index 8e8f84f6aac496bda4c4d5cfe5dc5f4588ee35d9..edf52f91e318cf10b35949471dc3d199e1600ec5 100644
--- a/app/src/main/java/foundation/e/apps/data/cleanapk/repositories/CleanApkPWARepository.kt
+++ b/app/src/main/java/foundation/e/apps/data/cleanapk/repositories/CleanApkPwaRepository.kt
@@ -18,27 +18,40 @@
package foundation.e.apps.data.cleanapk.repositories
-import foundation.e.apps.data.cleanapk.CleanApkAppDetailsRetrofit
+import android.content.Context
+import dagger.hilt.android.qualifiers.ApplicationContext
+import foundation.e.apps.data.application.data.Application
import foundation.e.apps.data.cleanapk.CleanApkRetrofit
-import foundation.e.apps.data.cleanapk.data.app.Application
import foundation.e.apps.data.cleanapk.data.categories.Categories
import foundation.e.apps.data.cleanapk.data.search.Search
import retrofit2.Response
+import javax.inject.Inject
-class CleanApkPWARepository(
- private val cleanAPKRetrofit: CleanApkRetrofit,
- private val cleanApkAppDetailsRetrofit: CleanApkAppDetailsRetrofit
+class CleanApkPwaRepository @Inject constructor(
+ private val cleanApkRetrofit: CleanApkRetrofit,
+ private val homeConverter: HomeConverter,
+ @ApplicationContext val context: Context
) : CleanApkRepository {
- override suspend fun getHomeScreenData(): Any {
- return cleanAPKRetrofit.getHomeScreenData(
+ override suspend fun getHomeScreenData(): Map> {
+ val response = cleanApkRetrofit.getHomeScreenData(
CleanApkRetrofit.APP_TYPE_PWA,
CleanApkRetrofit.APP_SOURCE_ANY
)
+
+ val home = response.body()?.home ?: throw IllegalStateException("No home data found")
+
+ val listHome = homeConverter.toGenericHome(home, CleanApkRetrofit.APP_TYPE_PWA)
+ val map = mutableMapOf>()
+ listHome.forEach {
+ map[it.title] = it.list
+ }
+
+ return map
}
override suspend fun getSearchResult(query: String, searchBy: String?): Response {
- return cleanAPKRetrofit.searchApps(
+ return cleanApkRetrofit.searchApps(
query,
CleanApkRetrofit.APP_SOURCE_ANY,
CleanApkRetrofit.APP_TYPE_PWA,
@@ -49,7 +62,7 @@ class CleanApkPWARepository(
}
override suspend fun getAppsByCategory(category: String, paginationParameter: Any?): Response {
- return cleanAPKRetrofit.listApps(
+ return cleanApkRetrofit.listApps(
category,
CleanApkRetrofit.APP_SOURCE_ANY,
CleanApkRetrofit.APP_TYPE_PWA,
@@ -59,17 +72,18 @@ class CleanApkPWARepository(
}
override suspend fun getCategories(): Response {
- return cleanAPKRetrofit.getCategoriesList(
+ return cleanApkRetrofit.getCategoriesList(
CleanApkRetrofit.APP_TYPE_PWA,
CleanApkRetrofit.APP_SOURCE_ANY
)
}
override suspend fun checkAvailablePackages(packageNames: List): Response {
- return cleanAPKRetrofit.checkAvailablePackages(packageNames)
+ return cleanApkRetrofit.checkAvailablePackages(packageNames)
}
- override suspend fun getAppDetails(packageNameOrId: String): Response {
- return cleanApkAppDetailsRetrofit.getAppOrPWADetailsByID(packageNameOrId, null, null)
+ override suspend fun getAppDetails(packageNameOrId: String): Application {
+ val response = cleanApkRetrofit.getAppOrPWADetailsByID(packageNameOrId, null, null)
+ return response.body()?.app ?: throw IllegalStateException("No app data found")
}
}
diff --git a/app/src/main/java/foundation/e/apps/data/cleanapk/repositories/HomeConverter.kt b/app/src/main/java/foundation/e/apps/data/cleanapk/repositories/HomeConverter.kt
new file mode 100644
index 0000000000000000000000000000000000000000..a5ecafbfcbb06d7218a633e577c48883202406e2
--- /dev/null
+++ b/app/src/main/java/foundation/e/apps/data/cleanapk/repositories/HomeConverter.kt
@@ -0,0 +1,58 @@
+package foundation.e.apps.data.cleanapk.repositories
+
+import android.content.Context
+import dagger.hilt.android.qualifiers.ApplicationContext
+import foundation.e.apps.R
+import foundation.e.apps.data.application.ApplicationDataManager
+import foundation.e.apps.data.application.data.Home
+import foundation.e.apps.data.cleanapk.data.home.CleanApkHome
+import javax.inject.Inject
+
+class HomeConverter @Inject constructor(
+ @ApplicationContext val context: Context,
+ private val applicationDataManager: ApplicationDataManager
+) {
+
+ suspend fun toGenericHome(cleanApkHome: CleanApkHome, appType: String): List {
+ val list = mutableListOf()
+
+ openSourceCategories.forEach { (key, value) ->
+ when (key) {
+ "top_updated_apps" -> {
+ applicationDataManager.prepareApps(cleanApkHome.top_updated_apps, list, value)
+ }
+
+ "top_updated_games" -> {
+ applicationDataManager.prepareApps(cleanApkHome.top_updated_games, list, value)
+ }
+
+ "popular_apps" -> {
+ applicationDataManager.prepareApps(cleanApkHome.popular_apps, list, value)
+ }
+
+ "popular_games" -> {
+ applicationDataManager.prepareApps(cleanApkHome.popular_games, list, value)
+ }
+
+ "discover" -> {
+ applicationDataManager.prepareApps(cleanApkHome.discover, list, value)
+ }
+ }
+ }
+
+ return list.map {
+ it.source = appType
+ it
+ }
+ }
+
+ private val openSourceCategories: Map by lazy {
+ mapOf(
+ "top_updated_apps" to context.getString(R.string.top_updated_apps),
+ "top_updated_games" to context.getString(R.string.top_updated_games),
+ "popular_apps" to context.getString(R.string.popular_apps),
+ "popular_games" to context.getString(R.string.popular_games),
+ "discover" to context.getString(R.string.discover)
+ )
+ }
+}
\ No newline at end of file
diff --git a/app/src/main/java/foundation/e/apps/data/fdroid/FdroidRepository.kt b/app/src/main/java/foundation/e/apps/data/fdroid/FDroidRepository.kt
similarity index 95%
rename from app/src/main/java/foundation/e/apps/data/fdroid/FdroidRepository.kt
rename to app/src/main/java/foundation/e/apps/data/fdroid/FDroidRepository.kt
index 978b36e0543f1173c0099de96499ee6bfd75fdc2..34fd7c4dd4a821015482a4f7c1a1bee71d472e1c 100644
--- a/app/src/main/java/foundation/e/apps/data/fdroid/FdroidRepository.kt
+++ b/app/src/main/java/foundation/e/apps/data/fdroid/FDroidRepository.kt
@@ -10,7 +10,7 @@ import javax.inject.Inject
import javax.inject.Singleton
@Singleton
-class FdroidRepository @Inject constructor(
+class FDroidRepository @Inject constructor(
private val fdroidApi: FdroidApiInterface,
private val fdroidDao: FdroidDao,
) : IFdroidRepository {
@@ -54,7 +54,7 @@ class FdroidRepository @Inject constructor(
return result?.authorName ?: FdroidEntity.DEFAULT_FDROID_AUTHOR_NAME
}
- override suspend fun isFdroidApplicationSigned(context: Context, packageName: String, apkFilePath: String, signature: String): Boolean {
+ override suspend fun isFDroidApplicationSigned(context: Context, packageName: String, apkFilePath: String, signature: String): Boolean {
if (isFdroidApplication(packageName)) {
return ApkSignatureManager.verifyFdroidSignature(context, apkFilePath, signature, packageName)
}
diff --git a/app/src/main/java/foundation/e/apps/data/fdroid/IFdroidRepository.kt b/app/src/main/java/foundation/e/apps/data/fdroid/IFdroidRepository.kt
index 51bdaefabdfd3a7655c92ead9d22014b9b9492de..84f411e4477296da22c3a4595ab7af893b48d078 100644
--- a/app/src/main/java/foundation/e/apps/data/fdroid/IFdroidRepository.kt
+++ b/app/src/main/java/foundation/e/apps/data/fdroid/IFdroidRepository.kt
@@ -33,7 +33,7 @@ interface IFdroidRepository {
suspend fun getAuthorName(application: Application): String
- suspend fun isFdroidApplicationSigned(
+ suspend fun isFDroidApplicationSigned(
context: Context,
packageName: String,
apkFilePath: String,
diff --git a/app/src/main/java/foundation/e/apps/data/install/AppManagerImpl.kt b/app/src/main/java/foundation/e/apps/data/install/AppManagerImpl.kt
index 94f2b2f6126893719b3aa9be968c51aeeb4a077c..183a65d08c344cc32f8f3c35d95b40782ec2ca3b 100644
--- a/app/src/main/java/foundation/e/apps/data/install/AppManagerImpl.kt
+++ b/app/src/main/java/foundation/e/apps/data/install/AppManagerImpl.kt
@@ -35,7 +35,7 @@ import foundation.e.apps.data.install.models.AppInstall
import foundation.e.apps.data.parentalcontrol.ContentRatingDao
import foundation.e.apps.data.parentalcontrol.ContentRatingEntity
import foundation.e.apps.install.download.data.DownloadProgressLD
-import foundation.e.apps.install.pkg.PWAManager
+import foundation.e.apps.install.pkg.PwaManager
import foundation.e.apps.install.pkg.AppLoungePackageManager
import kotlinx.coroutines.DelicateCoroutinesApi
import kotlinx.coroutines.sync.Mutex
@@ -53,7 +53,7 @@ class AppManagerImpl @Inject constructor(
private val downloadManager: DownloadManager,
private val notificationManager: NotificationManager,
private val appInstallRepository: AppInstallRepository,
- private val pwaManager: PWAManager,
+ private val pwaManager: PwaManager,
private val appLoungePackageManager: AppLoungePackageManager,
@Named("download") private val downloadNotificationChannel: NotificationChannel,
@Named("update") private val updateNotificationChannel: NotificationChannel,
diff --git a/app/src/main/java/foundation/e/apps/data/install/AppManagerWrapper.kt b/app/src/main/java/foundation/e/apps/data/install/AppManagerWrapper.kt
index 359681c6c01133a6f7a472b0f176759395e2e712..119b5653a84f76adbce3e4232f5f7ec2ffd5dc68 100644
--- a/app/src/main/java/foundation/e/apps/data/install/AppManagerWrapper.kt
+++ b/app/src/main/java/foundation/e/apps/data/install/AppManagerWrapper.kt
@@ -6,7 +6,7 @@ import androidx.annotation.RequiresApi
import androidx.lifecycle.LiveData
import foundation.e.apps.OpenForTesting
import foundation.e.apps.data.enums.Status
-import foundation.e.apps.data.fdroid.FdroidRepository
+import foundation.e.apps.data.fdroid.FDroidRepository
import foundation.e.apps.data.application.data.Application
import foundation.e.apps.data.install.models.AppInstall
import foundation.e.apps.install.download.data.DownloadProgress
@@ -18,7 +18,7 @@ import javax.inject.Singleton
@OpenForTesting
class AppManagerWrapper @Inject constructor(
private val appManager: AppManager,
- private val fdroidRepository: FdroidRepository
+ private val fDroidRepository: FDroidRepository
) {
fun createNotificationChannels() {
@@ -182,9 +182,9 @@ class AppManagerWrapper @Inject constructor(
return null
}
- suspend fun isFdroidApplicationSigned(context: Context, appInstall: AppInstall): Boolean {
+ suspend fun isFDroidApplicationSigned(context: Context, appInstall: AppInstall): Boolean {
val apkFilePath = appManager.getBaseApkPath(appInstall)
- return fdroidRepository.isFdroidApplicationSigned(context, appInstall.packageName, apkFilePath, appInstall.signature)
+ return fDroidRepository.isFDroidApplicationSigned(context, appInstall.packageName, apkFilePath, appInstall.signature)
}
fun isFusedDownloadInstalled(appInstall: AppInstall): Boolean {
diff --git a/app/src/main/java/foundation/e/apps/data/login/AuthObject.kt b/app/src/main/java/foundation/e/apps/data/login/AuthObject.kt
index e63f051de5d8438b1bd1ed2b3845ed4c5aeafb21..7d2eb7cf7944374bc5872d12dbff9f9d736d0947 100644
--- a/app/src/main/java/foundation/e/apps/data/login/AuthObject.kt
+++ b/app/src/main/java/foundation/e/apps/data/login/AuthObject.kt
@@ -21,8 +21,7 @@ import com.aurora.gplayapi.data.models.AuthData
import foundation.e.apps.data.ResultSupreme
import foundation.e.apps.data.enums.User
import foundation.e.apps.data.login.AuthObject.GPlayAuth
-import foundation.e.apps.data.login.exceptions.CleanApkException
-import foundation.e.apps.data.login.exceptions.GPlayValidationException
+import foundation.e.apps.data.login.exceptions.CustomException
/**
* Auth objects define which sources data is to be loaded from, for each source, also provides
@@ -48,10 +47,12 @@ sealed class AuthObject {
return GPlayAuth(
ResultSupreme.Error(
message = message,
- exception = GPlayValidationException(
+ exception = CustomException(
+ CustomException.Error.AUTHENTICATION_ERROR,
message,
this.user,
401,
+ CustomException.Type.GOOGLE_PLAY
)
).apply {
otherPayload = this@GPlayAuth.result.otherPayload
@@ -66,14 +67,15 @@ sealed class AuthObject {
return CleanApk(
ResultSupreme.Error(
message = "Unauthorized",
- exception = CleanApkException(
- isTimeout = false,
- message = "Unauthorized",
+ exception = CustomException(
+ CustomException.Error.AUTHENTICATION_ERROR,
+ "Unauthorized",
+ this.user
)
),
this.user,
)
}
}
- // Add more auth types here
+
}
diff --git a/app/src/main/java/foundation/e/apps/data/login/AuthenticatorRepository.kt b/app/src/main/java/foundation/e/apps/data/login/AuthenticatorRepository.kt
index 2e4bc761d4b32ade786abb2498b934fb02cedcd4..1533dd49838e822e91f567ba7ef50eeec37a49c3 100644
--- a/app/src/main/java/foundation/e/apps/data/login/AuthenticatorRepository.kt
+++ b/app/src/main/java/foundation/e/apps/data/login/AuthenticatorRepository.kt
@@ -20,7 +20,7 @@ package foundation.e.apps.data.login
import com.aurora.gplayapi.data.models.AuthData
import foundation.e.apps.data.ResultSupreme
import foundation.e.apps.data.enums.User
-import foundation.e.apps.data.login.exceptions.GPlayLoginException
+import foundation.e.apps.data.login.exceptions.CustomException
import javax.inject.Inject
import javax.inject.Singleton
@@ -31,8 +31,20 @@ class AuthenticatorRepository @Inject constructor(
private val authenticators: List,
) {
- var gplayAuth: AuthData? = null
- get() = field ?: throw GPlayLoginException(false, "AuthData is not available!", getUserType())
+ private var gPlayAuth: AuthData? = null
+
+ fun getGPlayAuthOrThrow(): AuthData {
+ return gPlayAuth ?: throw CustomException(
+ CustomException.Error.AUTHENTICATION_ERROR,
+ "AuthData is not available!",
+ getUserType(),
+ type = CustomException.Type.GOOGLE_PLAY
+ )
+ }
+
+ fun setGPlayAuth(auth: AuthData) {
+ gPlayAuth = auth
+ }
suspend fun getAuthObjects(clearAuthTypes: List = listOf()): List {
@@ -48,7 +60,7 @@ class AuthenticatorRepository @Inject constructor(
authObjectsLocal.add(authObject)
if (authObject is AuthObject.GPlayAuth) {
- gplayAuth = authObject.result.data
+ gPlayAuth = authObject.result.data
}
}
@@ -74,7 +86,7 @@ class AuthenticatorRepository @Inject constructor(
suspend fun getValidatedAuthData(): ResultSupreme {
val authDataValidator = (authenticators.find { it is AuthDataValidator } as AuthDataValidator)
val validateAuthData = authDataValidator.validateAuthData()
- this.gplayAuth = validateAuthData.data
+ this.gPlayAuth = validateAuthData.data
return validateAuthData
}
diff --git a/app/src/main/java/foundation/e/apps/data/login/api/PlayStoreLoginWrapper.kt b/app/src/main/java/foundation/e/apps/data/login/api/PlayStoreLoginWrapper.kt
index 4d013b2f058457ef1b0d7617826c8c586fa3367d..c1604c3a48539f3534a9e1125e972a1079896aa7 100644
--- a/app/src/main/java/foundation/e/apps/data/login/api/PlayStoreLoginWrapper.kt
+++ b/app/src/main/java/foundation/e/apps/data/login/api/PlayStoreLoginWrapper.kt
@@ -23,7 +23,7 @@ import foundation.e.apps.data.ResultSupreme
import foundation.e.apps.data.enums.User
import foundation.e.apps.data.playstore.utils.AC2DMUtil
import foundation.e.apps.data.handleNetworkResult
-import foundation.e.apps.data.login.exceptions.GPlayLoginException
+import foundation.e.apps.data.login.exceptions.CustomException
import foundation.e.apps.utils.eventBus.AppEvent
import foundation.e.apps.utils.eventBus.EventBus
import java.util.Locale
@@ -52,8 +52,20 @@ class PlayStoreLoginWrapper constructor(
return result.apply {
this.data?.locale = locale
this.exception = when (result) {
- is ResultSupreme.Timeout -> GPlayLoginException(true, "GPlay API timeout", user)
- is ResultSupreme.Error -> GPlayLoginException(false, result.message, user)
+ is ResultSupreme.Timeout ->
+ CustomException(
+ CustomException.Error.TIMEOUT_ERROR,
+ "GPlay API timeout",
+ user,
+ type = CustomException.Type.GOOGLE_PLAY
+ )
+ is ResultSupreme.Error ->
+ CustomException(
+ CustomException.Error.AUTHENTICATION_ERROR,
+ result.message,
+ user,
+ type = CustomException.Type.GOOGLE_PLAY
+ )
else -> {
EventBus.invokeEvent(AppEvent.SuccessfulLogin(user))
null
@@ -82,8 +94,19 @@ class PlayStoreLoginWrapper constructor(
}
return ResultSupreme.replicate(result, response).apply {
this.exception = when (result) {
- is ResultSupreme.Timeout -> GPlayLoginException(true, "GPlay API timeout", user)
- is ResultSupreme.Error -> GPlayLoginException(false, result.message, user)
+ is ResultSupreme.Timeout ->
+ CustomException(
+ CustomException.Error.TIMEOUT_ERROR,
+ "GPlay API timeout",
+ user,
+ type = CustomException.Type.GOOGLE_PLAY
+ )
+ is ResultSupreme.Error -> CustomException(
+ CustomException.Error.AUTHENTICATION_ERROR,
+ result.message,
+ user,
+ type = CustomException.Type.GOOGLE_PLAY
+ )
else -> null
}
}
@@ -129,8 +152,17 @@ class PlayStoreLoginWrapper constructor(
}
return result.apply {
this.exception = when (result) {
- is ResultSupreme.Timeout -> GPlayLoginException(true, "GPlay API timeout", User.GOOGLE)
- is ResultSupreme.Error -> GPlayLoginException(false, result.message, User.GOOGLE)
+ is ResultSupreme.Timeout -> CustomException(
+ CustomException.Error.TIMEOUT_ERROR,
+ "GPlay API timeout",
+ User.GOOGLE,
+ type = CustomException.Type.GOOGLE_PLAY
+ )
+ is ResultSupreme.Error -> CustomException(
+ CustomException.Error.AUTHENTICATION_ERROR,
+ result.message,
+ User.GOOGLE,
+ type = CustomException.Type.GOOGLE_PLAY)
else -> null
}
}
diff --git a/app/src/main/java/foundation/e/apps/data/login/exceptions/CleanApkException.kt b/app/src/main/java/foundation/e/apps/data/login/exceptions/CleanApkException.kt
deleted file mode 100644
index 293819914aac64751e60c5da12cf5b94caa2a5c2..0000000000000000000000000000000000000000
--- a/app/src/main/java/foundation/e/apps/data/login/exceptions/CleanApkException.kt
+++ /dev/null
@@ -1,26 +0,0 @@
-/*
- * Copyright (C) 2019-2022 E FOUNDATION
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU General Public License as published by
- * the Free Software Foundation, either version 3 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- * GNU General Public License for more details.
- *
- * You should have received a copy of the GNU General Public License
- * along with this program. If not, see .
- */
-
-package foundation.e.apps.data.login.exceptions
-
-/**
- * This exception is for all CleanApk data loading exceptions.
- */
-class CleanApkException(
- val isTimeout: Boolean,
- message: String? = null,
-) : LoginException(message)
diff --git a/app/src/main/java/foundation/e/apps/data/login/exceptions/GPlayValidationException.kt b/app/src/main/java/foundation/e/apps/data/login/exceptions/CustomException.kt
similarity index 63%
rename from app/src/main/java/foundation/e/apps/data/login/exceptions/GPlayValidationException.kt
rename to app/src/main/java/foundation/e/apps/data/login/exceptions/CustomException.kt
index 5b4322a4cc955487b91ee65578af872f7be67876..271a29bce74735cd75be79dfd1f3ced5b633b1e7 100644
--- a/app/src/main/java/foundation/e/apps/data/login/exceptions/GPlayValidationException.kt
+++ b/app/src/main/java/foundation/e/apps/data/login/exceptions/CustomException.kt
@@ -19,14 +19,23 @@ package foundation.e.apps.data.login.exceptions
import foundation.e.apps.data.enums.User
-/**
- * This exception is specifically used when a GPlay auth data could not be validated.
- * This is not the case as timeout, this exception usually means the server informed that the
- * current auth data is not valid.
- * Use [networkCode] to be sure that the server call was successful (should be 200).
- */
-class GPlayValidationException(
- message: String,
- user: User,
- val networkCode: Int,
-) : GPlayLoginException(false, message, user)
+class CustomException(
+ val error: Error? = null,
+ override val message: String? = null,
+ val user: User? = null,
+ val networkCode: Int = -1,
+ val type: Type? = null,
+ var encapsulatedException: Exception? = null
+) : Exception(message) {
+
+ enum class Error {
+ TIMEOUT_ERROR,
+ AUTHENTICATION_ERROR,
+ UNKNOWN_ERROR
+ }
+
+ enum class Type {
+ GOOGLE_PLAY,
+ CLEAN_PK
+ }
+}
diff --git a/app/src/main/java/foundation/e/apps/data/login/exceptions/GPlayException.kt b/app/src/main/java/foundation/e/apps/data/login/exceptions/GPlayException.kt
deleted file mode 100644
index 345208778528b1d12c330fe7477111c98c7e7501..0000000000000000000000000000000000000000
--- a/app/src/main/java/foundation/e/apps/data/login/exceptions/GPlayException.kt
+++ /dev/null
@@ -1,26 +0,0 @@
-/*
- * Copyright (C) 2019-2022 E FOUNDATION
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU General Public License as published by
- * the Free Software Foundation, either version 3 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- * GNU General Public License for more details.
- *
- * You should have received a copy of the GNU General Public License
- * along with this program. If not, see .
- */
-
-package foundation.e.apps.data.login.exceptions
-
-/**
- * This exception is for all Google Play network calls or other GPlay related exceptions.
- */
-open class GPlayException(
- val isTimeout: Boolean,
- message: String? = null,
-) : LoginException(message)
diff --git a/app/src/main/java/foundation/e/apps/data/login/exceptions/GPlayLoginException.kt b/app/src/main/java/foundation/e/apps/data/login/exceptions/GPlayLoginException.kt
deleted file mode 100644
index d6a64a7bb3d20c52243c9f30434122b431642716..0000000000000000000000000000000000000000
--- a/app/src/main/java/foundation/e/apps/data/login/exceptions/GPlayLoginException.kt
+++ /dev/null
@@ -1,31 +0,0 @@
-/*
- * Copyright (C) 2019-2022 MURENA SAS
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU General Public License as published by
- * the Free Software Foundation, either version 3 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- * GNU General Public License for more details.
- *
- * You should have received a copy of the GNU General Public License
- * along with this program. If not, see .
- */
-
-package foundation.e.apps.data.login.exceptions
-
-import foundation.e.apps.data.enums.User
-
-/**
- * Parent class for all GPlay login related errors.
- * Examples:
- * unable to get anonymous token, AuthData validation failed, aasToken error etc.
- */
-open class GPlayLoginException(
- isTimeout: Boolean,
- message: String? = null,
- val user: User,
-) : GPlayException(isTimeout, message)
diff --git a/app/src/main/java/foundation/e/apps/data/login/exceptions/LoginException.kt b/app/src/main/java/foundation/e/apps/data/login/exceptions/LoginException.kt
deleted file mode 100644
index e69cb47b51b084af03f8bc0414779598fe56e317..0000000000000000000000000000000000000000
--- a/app/src/main/java/foundation/e/apps/data/login/exceptions/LoginException.kt
+++ /dev/null
@@ -1,24 +0,0 @@
-/*
- * Copyright (C) 2019-2022 E FOUNDATION
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU General Public License as published by
- * the Free Software Foundation, either version 3 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- * GNU General Public License for more details.
- *
- * You should have received a copy of the GNU General Public License
- * along with this program. If not, see .
- */
-
-package foundation.e.apps.data.login.exceptions
-
-/**
- * Super class for all Login related exceptions.
- * https://gitlab.e.foundation/e/backlog/-/issues/5680
- */
-open class LoginException(message: String?) : Exception(message)
diff --git a/app/src/main/java/foundation/e/apps/data/login/exceptions/UnknownSourceException.kt b/app/src/main/java/foundation/e/apps/data/login/exceptions/UnknownSourceException.kt
deleted file mode 100644
index 3c881d9f6ac9cb31b253ea6a3829a8fb2410d4fc..0000000000000000000000000000000000000000
--- a/app/src/main/java/foundation/e/apps/data/login/exceptions/UnknownSourceException.kt
+++ /dev/null
@@ -1,23 +0,0 @@
-/*
- * Copyright (C) 2019-2022 E FOUNDATION
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU General Public License as published by
- * the Free Software Foundation, either version 3 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- * GNU General Public License for more details.
- *
- * You should have received a copy of the GNU General Public License
- * along with this program. If not, see .
- */
-
-package foundation.e.apps.data.login.exceptions
-
-/**
- * Generic exception class - used to define unknown errors.
- */
-class UnknownSourceException : LoginException("")
diff --git a/app/src/main/java/foundation/e/apps/data/playstore/PlayStoreRepository.kt b/app/src/main/java/foundation/e/apps/data/playstore/PlayStoreRepository.kt
index 03733b0d271499e289a93363e50c4ed76a31a9ae..22e0d88b7d49db73fbd94e3e992eb6db0b5c8b5e 100644
--- a/app/src/main/java/foundation/e/apps/data/playstore/PlayStoreRepository.kt
+++ b/app/src/main/java/foundation/e/apps/data/playstore/PlayStoreRepository.kt
@@ -18,36 +18,233 @@
package foundation.e.apps.data.playstore
+import android.content.Context
import com.aurora.gplayapi.SearchSuggestEntry
-import com.aurora.gplayapi.data.models.App
+import com.aurora.gplayapi.data.models.App as GplayApp
+import com.aurora.gplayapi.data.models.AuthData
import com.aurora.gplayapi.data.models.Category
import com.aurora.gplayapi.data.models.ContentRating
import com.aurora.gplayapi.data.models.File
import com.aurora.gplayapi.data.models.SearchBundle
+import com.aurora.gplayapi.data.models.StreamCluster
+import com.aurora.gplayapi.helpers.AppDetailsHelper
+import com.aurora.gplayapi.helpers.CategoryAppsHelper
+import com.aurora.gplayapi.helpers.CategoryHelper
+import com.aurora.gplayapi.helpers.Chart
+import com.aurora.gplayapi.helpers.ContentRatingHelper
+import com.aurora.gplayapi.helpers.PurchaseHelper
+import com.aurora.gplayapi.helpers.SearchHelper
+import com.aurora.gplayapi.helpers.TopChartsHelper
+import dagger.hilt.android.qualifiers.ApplicationContext
+import foundation.e.apps.R
import foundation.e.apps.data.StoreRepository
+import foundation.e.apps.data.application.data.Application
import foundation.e.apps.data.application.utils.CategoryType
+import foundation.e.apps.data.application.utils.toApplication
+import foundation.e.apps.data.login.AuthenticatorRepository
+import foundation.e.apps.data.playstore.utils.GPlayHttpClient
+import kotlinx.coroutines.Dispatchers
+import kotlinx.coroutines.withContext
+import timber.log.Timber
+import javax.inject.Inject
+
+class PlayStoreRepository @Inject constructor(
+ @ApplicationContext private val context: Context,
+ private val gPlayHttpClient: GPlayHttpClient,
+ private val authenticatorRepository: AuthenticatorRepository
+) : StoreRepository {
+
+ override suspend fun getHomeScreenData(): Map> {
+ val homeScreenData = mutableMapOf>()
+ val homeElements = createTopChartElements()
+ val authData = authenticatorRepository.getGPlayAuthOrThrow()
+
+ homeElements.forEach {
+ if (it.value.isEmpty()) return@forEach
+
+ val chart = it.value.keys.iterator().next()
+ val type = it.value.values.iterator().next()
+ val result = getTopApps(type, chart, authData)
+ homeScreenData[it.key] = result
+ }
+
+ return homeScreenData
+ }
+
+ private fun createTopChartElements() = mutableMapOf(
+ context.getString(R.string.topselling_free_apps) to mapOf(Chart.TOP_SELLING_FREE to TopChartsHelper.Type.APPLICATION),
+ context.getString(R.string.topselling_free_games) to mapOf(Chart.TOP_SELLING_FREE to TopChartsHelper.Type.GAME),
+ context.getString(R.string.topgrossing_apps) to mapOf(Chart.TOP_GROSSING to TopChartsHelper.Type.APPLICATION),
+ context.getString(R.string.topgrossing_games) to mapOf(Chart.TOP_GROSSING to TopChartsHelper.Type.GAME),
+ context.getString(R.string.movers_shakers_apps) to mapOf(Chart.MOVERS_SHAKERS to TopChartsHelper.Type.APPLICATION),
+ context.getString(R.string.movers_shakers_games) to mapOf(Chart.MOVERS_SHAKERS to TopChartsHelper.Type.GAME),
+ )
+
+ fun getSearchResult(
+ query: String,
+ subBundle: MutableSet?
+ ): Pair, MutableSet> {
+ val authData = authenticatorRepository.getGPlayAuthOrThrow()
+ val searchHelper = SearchHelper(authData).using(gPlayHttpClient)
+
+ Timber.d("Fetching search result for $query, subBundle: $subBundle")
+
+ val searchResult = if (subBundle != null) {
+ Timber.d("fetching next page search data...")
+ searchHelper.next(subBundle)
+ } else {
+ searchHelper.searchResults(query)
+ }
+
+ return getSearchResultPair(searchResult, query)
+ }
+
+ private fun getSearchResultPair(
+ searchBundle: SearchBundle,
+ query: String
+ ): Pair, MutableSet> {
+ val apps = searchBundle.appList
+ Timber.d("Found ${apps.size} apps for query, $query")
+ return Pair(apps, searchBundle.subBundles)
+ }
+
+ suspend fun getSearchSuggestions(query: String): List {
+ val authData = authenticatorRepository.getGPlayAuthOrThrow()
+
+ val searchData = mutableListOf()
+ withContext(Dispatchers.IO) {
+ val searchHelper = SearchHelper(authData).using(gPlayHttpClient)
+ searchData.addAll(searchHelper.searchSuggestions(query))
+ }
+ return searchData.filter { it.suggestedQuery.isNotBlank() }
+ }
+
+ fun getAppsByCategory(category: String, pageUrl: String?): StreamCluster {
+ val authData = authenticatorRepository.getGPlayAuthOrThrow()
+
+ val subCategoryHelper = CategoryAppsHelper(authData).using(gPlayHttpClient)
+
+ if (!pageUrl.isNullOrEmpty()) {
+ return subCategoryHelper.next(pageUrl)
+ }
+
+ return subCategoryHelper.getCategoryAppsList(category.uppercase())
+ }
+
+ suspend fun getCategories(type: CategoryType?): List {
+ val categoryList = mutableListOf()
+ if (type == null) {
+ return categoryList
+ }
+
+ val authData = authenticatorRepository.getGPlayAuthOrThrow()
+
+ withContext(Dispatchers.IO) {
+ val categoryHelper = CategoryHelper(authData).using(gPlayHttpClient)
+ categoryList.addAll(categoryHelper.getAllCategoriesList(getCategoryType(type)))
+ }
+ return categoryList
+ }
+
+ override suspend fun getAppDetails(packageNameOrId: String): Application {
+ var appDetails: GplayApp?
+ val authData = authenticatorRepository.getGPlayAuthOrThrow()
+
+ withContext(Dispatchers.IO) {
+ val appDetailsHelper = AppDetailsHelper(authData).using(gPlayHttpClient)
+ appDetails = appDetailsHelper.getAppByPackageName(packageNameOrId)
+ }
+
+ return appDetails?.toApplication(context) ?: Application()
+ }
+
+ suspend fun getAppsDetails(packageNamesOrIds: List): List {
+ val appDetailsList = mutableListOf()
+ val authData = authenticatorRepository.getGPlayAuthOrThrow()
+
+ withContext(Dispatchers.IO) {
+ val appDetailsHelper = AppDetailsHelper(authData).using(gPlayHttpClient)
+ appDetailsList.addAll(appDetailsHelper.getAppByPackageName(packageNamesOrIds))
+ }
+ return appDetailsList
+ }
+
+ private fun getCategoryType(type: CategoryType): Category.Type {
+ return if (type == CategoryType.APPLICATION) Category.Type.APPLICATION
+ else Category.Type.GAME
+ }
+
+ private suspend fun getTopApps(
+ type: TopChartsHelper.Type,
+ chart: Chart,
+ authData: AuthData
+ ): List {
+ val topApps = mutableListOf()
+ withContext(Dispatchers.IO) {
+ val topChartsHelper = TopChartsHelper(authData).using(gPlayHttpClient)
+ topApps.addAll(topChartsHelper.getCluster(type, chart).clusterAppList)
+ }
+
+ return topApps.map {
+ it.toApplication(context)
+ }
+ }
-interface PlayStoreRepository : StoreRepository {
- suspend fun getSearchResult(query: String, subBundle: MutableSet?): Pair, MutableSet>
- suspend fun getSearchSuggestions(query: String): List
- suspend fun getAppsByCategory(category: String, pageUrl: String? = null): Any
- suspend fun getCategories(type: CategoryType? = null): List
- suspend fun getAppsDetails(packageNamesOrIds: List): List
suspend fun getDownloadInfo(
idOrPackageName: String,
- versionCode: Any? = null,
- offerType: Int = -1
- ): List
+ versionCode: Any?,
+ offerType: Int
+ ): List {
+ val downloadData = mutableListOf()
+ val authData = authenticatorRepository.getGPlayAuthOrThrow()
+
+ withContext(Dispatchers.IO) {
+ val version = versionCode?.let { it as Int } ?: -1
+ val purchaseHelper = PurchaseHelper(authData).using(gPlayHttpClient)
+ downloadData.addAll(purchaseHelper.purchase(idOrPackageName, version, offerType))
+ }
+ return downloadData
+ }
+
suspend fun getOnDemandModule(
packageName: String,
moduleName: String,
versionCode: Int,
offerType: Int
- ): List
+ ): List {
+ val downloadData = mutableListOf()
+ val authData = authenticatorRepository.getGPlayAuthOrThrow()
+
+ withContext(Dispatchers.IO) {
+ val purchaseHelper = PurchaseHelper(authData).using(gPlayHttpClient)
+ downloadData.addAll(
+ purchaseHelper.getOnDemandModule(packageName, moduleName, versionCode, offerType)
+ )
+ }
+ return downloadData
+ }
suspend fun getContentRatingWithId(
appPackage: String,
contentRating: ContentRating
- ): ContentRating
- suspend fun getEnglishContentRating(packageName: String): ContentRating?
+ ): ContentRating {
+ val authData = authenticatorRepository.getGPlayAuthOrThrow()
+ val contentRatingHelper = ContentRatingHelper(authData)
+
+ return withContext(Dispatchers.IO) {
+ contentRatingHelper.updateContentRatingWithId(
+ appPackage,
+ contentRating
+ )
+ }
+ }
+
+ suspend fun getEnglishContentRating(packageName: String): ContentRating {
+ val authData = authenticatorRepository.getGPlayAuthOrThrow()
+ val contentRatingHelper = ContentRatingHelper(authData)
+
+ return withContext(Dispatchers.IO) {
+ contentRatingHelper.getEnglishContentRating(packageName)
+ }
+ }
}
diff --git a/app/src/main/java/foundation/e/apps/data/playstore/PlayStoreRepositoryImpl.kt b/app/src/main/java/foundation/e/apps/data/playstore/PlayStoreRepositoryImpl.kt
deleted file mode 100644
index 9ea9db7b9a003e58e63ced57f42345d2b4532e54..0000000000000000000000000000000000000000
--- a/app/src/main/java/foundation/e/apps/data/playstore/PlayStoreRepositoryImpl.kt
+++ /dev/null
@@ -1,241 +0,0 @@
-/*
- * Copyright (C) 2024 MURENA SAS
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU General Public License as published by
- * the Free Software Foundation, either version 3 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- * GNU General Public License for more details.
- *
- * You should have received a copy of the GNU General Public License
- * along with this program. If not, see .
- *
- */
-
-package foundation.e.apps.data.playstore
-
-import android.content.Context
-import com.aurora.gplayapi.SearchSuggestEntry
-import com.aurora.gplayapi.data.models.App
-import com.aurora.gplayapi.data.models.AuthData
-import com.aurora.gplayapi.data.models.Category
-import com.aurora.gplayapi.data.models.ContentRating
-import com.aurora.gplayapi.data.models.File
-import com.aurora.gplayapi.data.models.SearchBundle
-import com.aurora.gplayapi.data.models.StreamCluster
-import com.aurora.gplayapi.helpers.AppDetailsHelper
-import com.aurora.gplayapi.helpers.CategoryAppsHelper
-import com.aurora.gplayapi.helpers.CategoryHelper
-import com.aurora.gplayapi.helpers.Chart
-import com.aurora.gplayapi.helpers.ContentRatingHelper
-import com.aurora.gplayapi.helpers.PurchaseHelper
-import com.aurora.gplayapi.helpers.SearchHelper
-import com.aurora.gplayapi.helpers.TopChartsHelper
-import dagger.hilt.android.qualifiers.ApplicationContext
-import foundation.e.apps.R
-import foundation.e.apps.data.application.utils.CategoryType
-import foundation.e.apps.data.login.AuthenticatorRepository
-import foundation.e.apps.data.playstore.utils.GPlayHttpClient
-import kotlinx.coroutines.Dispatchers
-import kotlinx.coroutines.withContext
-import timber.log.Timber
-import javax.inject.Inject
-
-class PlayStoreRepositoryImpl @Inject constructor(
- @ApplicationContext private val context: Context,
- private val gPlayHttpClient: GPlayHttpClient,
- private val authenticatorRepository: AuthenticatorRepository
-) : PlayStoreRepository {
-
- override suspend fun getHomeScreenData(): Any {
- val homeScreenData = mutableMapOf>()
- val homeElements = createTopChartElements()
- val authData = authenticatorRepository.gplayAuth!!
-
- homeElements.forEach {
- val chart = it.value.keys.iterator().next()
- val type = it.value.values.iterator().next()
- val result = getTopApps(type, chart, authData)
- homeScreenData[it.key] = result
- }
-
- return homeScreenData
- }
-
- private fun createTopChartElements() = mutableMapOf(
- context.getString(R.string.topselling_free_apps) to mapOf(Chart.TOP_SELLING_FREE to TopChartsHelper.Type.APPLICATION),
- context.getString(R.string.topselling_free_games) to mapOf(Chart.TOP_SELLING_FREE to TopChartsHelper.Type.GAME),
- context.getString(R.string.topgrossing_apps) to mapOf(Chart.TOP_GROSSING to TopChartsHelper.Type.APPLICATION),
- context.getString(R.string.topgrossing_games) to mapOf(Chart.TOP_GROSSING to TopChartsHelper.Type.GAME),
- context.getString(R.string.movers_shakers_apps) to mapOf(Chart.MOVERS_SHAKERS to TopChartsHelper.Type.APPLICATION),
- context.getString(R.string.movers_shakers_games) to mapOf(Chart.MOVERS_SHAKERS to TopChartsHelper.Type.GAME),
- )
-
- override suspend fun getSearchResult(
- query: String,
- subBundle: MutableSet?
- ): Pair, MutableSet> {
- val authData = authenticatorRepository.gplayAuth!!
- val searchHelper = SearchHelper(authData).using(gPlayHttpClient)
-
- Timber.d("Fetching search result for $query, subBundle: $subBundle")
-
- subBundle?.let {
- val searchResult = searchHelper.next(it)
- Timber.d("fetching next page search data...")
- return getSearchResultPair(searchResult, query)
- }
-
- val searchResult = searchHelper.searchResults(query)
- return getSearchResultPair(searchResult, query)
- }
-
- private fun getSearchResultPair(
- searchBundle: SearchBundle,
- query: String
- ): Pair, MutableSet> {
- val apps = searchBundle.appList
- Timber.d("Found ${apps.size} apps for query, $query")
- return Pair(apps, searchBundle.subBundles)
- }
-
- override suspend fun getSearchSuggestions(query: String): List {
- val authData = authenticatorRepository.gplayAuth!!
-
- val searchData = mutableListOf()
- withContext(Dispatchers.IO) {
- val searchHelper = SearchHelper(authData).using(gPlayHttpClient)
- searchData.addAll(searchHelper.searchSuggestions(query))
- }
- return searchData.filter { it.suggestedQuery.isNotBlank() }
- }
-
- override suspend fun getAppsByCategory(category: String, pageUrl: String?): StreamCluster {
- val authData = authenticatorRepository.gplayAuth!!
-
- val subCategoryHelper = CategoryAppsHelper(authData).using(gPlayHttpClient)
-
- if (!pageUrl.isNullOrEmpty()) {
- return subCategoryHelper.next(pageUrl)
- }
-
- return subCategoryHelper.getCategoryAppsList(category.uppercase())
- }
-
- override suspend fun getCategories(type: CategoryType?): List {
- val categoryList = mutableListOf()
- if (type == null) {
- return categoryList
- }
-
- val authData = authenticatorRepository.gplayAuth!!
-
- withContext(Dispatchers.IO) {
- val categoryHelper = CategoryHelper(authData).using(gPlayHttpClient)
- categoryList.addAll(categoryHelper.getAllCategoriesList(getCategoryType(type)))
- }
- return categoryList
- }
-
- override suspend fun getAppDetails(packageNameOrId: String): App? {
- var appDetails: App?
- val authData = authenticatorRepository.gplayAuth!!
-
- withContext(Dispatchers.IO) {
- val appDetailsHelper = AppDetailsHelper(authData).using(gPlayHttpClient)
- appDetails = appDetailsHelper.getAppByPackageName(packageNameOrId)
- }
- return appDetails
- }
-
- override suspend fun getAppsDetails(packageNamesOrIds: List): List {
- val appDetailsList = mutableListOf()
- val authData = authenticatorRepository.gplayAuth!!
-
- withContext(Dispatchers.IO) {
- val appDetailsHelper = AppDetailsHelper(authData).using(gPlayHttpClient)
- appDetailsList.addAll(appDetailsHelper.getAppByPackageName(packageNamesOrIds))
- }
- return appDetailsList
- }
-
- private fun getCategoryType(type: CategoryType): Category.Type {
- return if (type == CategoryType.APPLICATION) Category.Type.APPLICATION
- else Category.Type.GAME
- }
-
- private suspend fun getTopApps(
- type: TopChartsHelper.Type,
- chart: Chart,
- authData: AuthData
- ): List {
- val topApps = mutableListOf()
- withContext(Dispatchers.IO) {
- val topChartsHelper = TopChartsHelper(authData).using(gPlayHttpClient)
- topApps.addAll(topChartsHelper.getCluster(type, chart).clusterAppList)
- }
- return topApps
- }
-
- override suspend fun getDownloadInfo(
- idOrPackageName: String,
- versionCode: Any?,
- offerType: Int
- ): List {
- val downloadData = mutableListOf()
- val authData = authenticatorRepository.gplayAuth!!
-
- withContext(Dispatchers.IO) {
- val version = versionCode?.let { it as Int } ?: -1
- val purchaseHelper = PurchaseHelper(authData).using(gPlayHttpClient)
- downloadData.addAll(purchaseHelper.purchase(idOrPackageName, version, offerType))
- }
- return downloadData
- }
-
- override suspend fun getOnDemandModule(
- packageName: String,
- moduleName: String,
- versionCode: Int,
- offerType: Int
- ): List {
- val downloadData = mutableListOf()
- val authData = authenticatorRepository.gplayAuth!!
-
- withContext(Dispatchers.IO) {
- val purchaseHelper = PurchaseHelper(authData).using(gPlayHttpClient)
- downloadData.addAll(
- purchaseHelper.getOnDemandModule(packageName, moduleName, versionCode, offerType)
- )
- }
- return downloadData
- }
-
- override suspend fun getContentRatingWithId(
- appPackage: String,
- contentRating: ContentRating
- ): ContentRating {
- val authData = authenticatorRepository.gplayAuth!!
- val contentRatingHelper = ContentRatingHelper(authData)
-
- return withContext(Dispatchers.IO) {
- contentRatingHelper.updateContentRatingWithId(
- appPackage,
- contentRating
- )
- }
- }
-
- override suspend fun getEnglishContentRating(packageName: String): ContentRating? {
- val authData = authenticatorRepository.gplayAuth ?: return null
- val contentRatingHelper = ContentRatingHelper(authData)
-
- return withContext(Dispatchers.IO) {
- contentRatingHelper.getEnglishContentRating(packageName)
- }
- }
-}
diff --git a/app/src/main/java/foundation/e/apps/data/updates/UpdatesManagerImpl.kt b/app/src/main/java/foundation/e/apps/data/updates/UpdatesManagerImpl.kt
index 4cf3cd31a098106fdce6cdc2c220b644c96e0f47..89628886b514083d3ab2b3b4cd1b1c8c26f3c1a0 100644
--- a/app/src/main/java/foundation/e/apps/data/updates/UpdatesManagerImpl.kt
+++ b/app/src/main/java/foundation/e/apps/data/updates/UpdatesManagerImpl.kt
@@ -29,8 +29,7 @@ import foundation.e.apps.data.enums.ResultStatus
import foundation.e.apps.data.enums.Status
import foundation.e.apps.data.enums.isUnFiltered
import foundation.e.apps.data.faultyApps.FaultyAppRepository
-import foundation.e.apps.data.fdroid.FdroidRepository
-import foundation.e.apps.data.playstore.PlayStoreRepositoryImpl
+import foundation.e.apps.data.fdroid.FDroidRepository
import foundation.e.apps.data.application.ApplicationRepository
import foundation.e.apps.data.application.search.SearchApi.Companion.APP_TYPE_ANY
import foundation.e.apps.data.application.data.Application
@@ -52,7 +51,7 @@ class UpdatesManagerImpl @Inject constructor(
private val applicationRepository: ApplicationRepository,
private val faultyAppRepository: FaultyAppRepository,
private val appLoungePreference: AppLoungePreference,
- private val fdroidRepository: FdroidRepository,
+ private val fDroidRepository: FDroidRepository,
private val blockedAppRepository: BlockedAppRepository,
private val systemAppsUpdatesRepository: SystemAppsUpdatesRepository,
) {
@@ -417,7 +416,7 @@ class UpdatesManagerImpl @Inject constructor(
// Received list has build info of the latest version at the bottom.
// We want it at the top.
val builds = handleNetworkResult {
- fdroidRepository.getBuildVersionInfo(packageName)?.asReversed() ?: listOf()
+ fDroidRepository.getBuildVersionInfo(packageName)?.asReversed() ?: listOf()
}.data
val matchingIndex = builds?.find {
diff --git a/app/src/main/java/foundation/e/apps/di/NamedRepositoryModule.kt b/app/src/main/java/foundation/e/apps/di/NamedRepositoryModule.kt
deleted file mode 100644
index e3d60030b145639369d39f8b2aa1c21a594a61ea..0000000000000000000000000000000000000000
--- a/app/src/main/java/foundation/e/apps/di/NamedRepositoryModule.kt
+++ /dev/null
@@ -1,72 +0,0 @@
-/*
- * Copyright MURENA SAS 2023
- * Apps Quickly and easily install Android apps onto your device!
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU General Public License as published by
- * the Free Software Foundation, either version 3 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- * GNU General Public License for more details.
- *
- * You should have received a copy of the GNU General Public License
- * along with this program. If not, see .
- */
-
-package foundation.e.apps.di
-
-import android.content.Context
-import dagger.Module
-import dagger.Provides
-import dagger.hilt.InstallIn
-import dagger.hilt.android.qualifiers.ApplicationContext
-import dagger.hilt.components.SingletonComponent
-import foundation.e.apps.data.cleanapk.CleanApkAppDetailsRetrofit
-import foundation.e.apps.data.cleanapk.CleanApkRetrofit
-import foundation.e.apps.data.cleanapk.repositories.CleanApkAppsRepositoryImpl
-import foundation.e.apps.data.cleanapk.repositories.CleanApkPWARepository
-import foundation.e.apps.data.cleanapk.repositories.CleanApkRepository
-import foundation.e.apps.data.playstore.PlayStoreRepository
-import foundation.e.apps.data.playstore.PlayStoreRepositoryImpl
-import foundation.e.apps.data.playstore.utils.GPlayHttpClient
-import foundation.e.apps.data.login.AuthenticatorRepository
-import javax.inject.Named
-import javax.inject.Singleton
-
-@InstallIn(SingletonComponent::class)
-@Module
-object NamedRepositoryModule {
- @Singleton
- @Provides
- @Named("gplayRepository")
- fun getGplayRepository(
- @ApplicationContext context: Context,
- gPlayHttpClient: GPlayHttpClient,
- authenticatorRepository: AuthenticatorRepository
- ): PlayStoreRepository {
- return PlayStoreRepositoryImpl(context, gPlayHttpClient, authenticatorRepository)
- }
-
- @Singleton
- @Provides
- @Named("cleanApkAppsRepository")
- fun getCleanApkAppsRepository(
- cleanAPKRetrofit: CleanApkRetrofit,
- cleanApkAppDetailsRetrofit: CleanApkAppDetailsRetrofit
- ): CleanApkRepository {
- return CleanApkAppsRepositoryImpl(cleanAPKRetrofit, cleanApkAppDetailsRetrofit)
- }
-
- @Singleton
- @Provides
- @Named("cleanApkPWARepository")
- fun getCleanApkPWARepository(
- cleanAPKRetrofit: CleanApkRetrofit,
- cleanApkAppDetailsRetrofit: CleanApkAppDetailsRetrofit
- ): CleanApkRepository {
- return CleanApkPWARepository(cleanAPKRetrofit, cleanApkAppDetailsRetrofit)
- }
-}
diff --git a/app/src/main/java/foundation/e/apps/di/RepositoryModule.kt b/app/src/main/java/foundation/e/apps/di/RepositoryModule.kt
index 7d548e66a0032888edcb20b4b8680e276bc30946..0eb1d9a690712169f524965c798cd24615c64235 100644
--- a/app/src/main/java/foundation/e/apps/di/RepositoryModule.kt
+++ b/app/src/main/java/foundation/e/apps/di/RepositoryModule.kt
@@ -26,10 +26,8 @@ import foundation.e.apps.data.exodus.repositories.AppPrivacyInfoRepositoryImpl
import foundation.e.apps.data.exodus.repositories.IAppPrivacyInfoRepository
import foundation.e.apps.data.exodus.repositories.PrivacyScoreRepository
import foundation.e.apps.data.exodus.repositories.PrivacyScoreRepositoryImpl
-import foundation.e.apps.data.fdroid.FdroidRepository
+import foundation.e.apps.data.fdroid.FDroidRepository
import foundation.e.apps.data.fdroid.IFdroidRepository
-import foundation.e.apps.data.playstore.PlayStoreRepository
-import foundation.e.apps.data.playstore.PlayStoreRepositoryImpl
import foundation.e.apps.data.install.AppManagerImpl
import foundation.e.apps.data.install.AppManager
import javax.inject.Singleton
@@ -47,13 +45,9 @@ interface RepositoryModule {
@Singleton
@Binds
- fun getFdroidRepository(fusedManagerImpl: FdroidRepository): IFdroidRepository
+ fun getFdroidRepository(fusedManagerImpl: FDroidRepository): IFdroidRepository
@Singleton
@Binds
fun getPrivacyScoreRepository(privacyScoreRepositoryImpl: PrivacyScoreRepositoryImpl): PrivacyScoreRepository
-
- @Singleton
- @Binds
- fun getPlayStoreRepository(playStoreRepository: PlayStoreRepositoryImpl): PlayStoreRepository
}
diff --git a/app/src/main/java/foundation/e/apps/di/network/NetworkModule.kt b/app/src/main/java/foundation/e/apps/di/network/NetworkModule.kt
index 6fbf75e992aecfa62bbfd5070412e21312e9db57..cdeb0e363459775920d9e9ad6dffd030804356fc 100644
--- a/app/src/main/java/foundation/e/apps/di/network/NetworkModule.kt
+++ b/app/src/main/java/foundation/e/apps/di/network/NetworkModule.kt
@@ -29,7 +29,7 @@ import dagger.Provides
import dagger.hilt.InstallIn
import dagger.hilt.components.SingletonComponent
import foundation.e.apps.data.cleanapk.ApplicationDeserializer
-import foundation.e.apps.data.cleanapk.data.app.Application
+import foundation.e.apps.data.cleanapk.data.app.CleanApkApplication
import okhttp3.Cache
import okhttp3.Interceptor
import okhttp3.OkHttpClient
@@ -58,7 +58,7 @@ object NetworkModule {
@Named("gsonCustomAdapter")
fun getGson(): Gson {
return GsonBuilder()
- .registerTypeAdapter(Application::class.java, ApplicationDeserializer())
+ .registerTypeAdapter(CleanApkApplication::class.java, ApplicationDeserializer())
.enableComplexMapKeySerialization()
.create()
}
diff --git a/app/src/main/java/foundation/e/apps/di/network/RetrofitApiModule.kt b/app/src/main/java/foundation/e/apps/di/network/RetrofitApiModule.kt
index 136add81108330203abad2575d74ecde0c3e9e46..2d6adc3e87631e63db6731cd0999c875d5b38471 100644
--- a/app/src/main/java/foundation/e/apps/di/network/RetrofitApiModule.kt
+++ b/app/src/main/java/foundation/e/apps/di/network/RetrofitApiModule.kt
@@ -24,7 +24,6 @@ import dagger.Module
import dagger.Provides
import dagger.hilt.InstallIn
import dagger.hilt.components.SingletonComponent
-import foundation.e.apps.data.cleanapk.CleanApkAppDetailsRetrofit
import foundation.e.apps.data.cleanapk.CleanApkRetrofit
import foundation.e.apps.data.ecloud.EcloudApiInterface
import foundation.e.apps.data.exodus.ExodusTrackerApi
@@ -48,27 +47,17 @@ import javax.inject.Singleton
class RetrofitApiModule {
@Singleton
@Provides
- fun provideCleanApkApi(okHttpClient: OkHttpClient, moshi: Moshi): CleanApkRetrofit {
- return Retrofit.Builder()
- .baseUrl(CleanApkRetrofit.BASE_URL)
- .client(okHttpClient)
- .addConverterFactory(MoshiConverterFactory.create(moshi))
- .build()
- .create(CleanApkRetrofit::class.java)
- }
-
- @Singleton
- @Provides
- fun provideCleanApkAppDetailsApi(
+ fun provideCleanApkApi(
okHttpClient: OkHttpClient,
@Named("gsonCustomAdapter") gson: Gson
- ): CleanApkAppDetailsRetrofit {
+ ): CleanApkRetrofit
+ {
return Retrofit.Builder()
.baseUrl(CleanApkRetrofit.BASE_URL)
.client(okHttpClient)
.addConverterFactory(GsonConverterFactory.create(gson))
.build()
- .create(CleanApkAppDetailsRetrofit::class.java)
+ .create(CleanApkRetrofit::class.java)
}
@Singleton
diff --git a/app/src/main/java/foundation/e/apps/install/download/DownloadManagerUtils.kt b/app/src/main/java/foundation/e/apps/install/download/DownloadManagerUtils.kt
index 2a8a45056e737e0cf3bfb0b2dbc91634a4308ec4..689f70343f4e535527464c51090b1e34d94fcaef 100644
--- a/app/src/main/java/foundation/e/apps/install/download/DownloadManagerUtils.kt
+++ b/app/src/main/java/foundation/e/apps/install/download/DownloadManagerUtils.kt
@@ -164,7 +164,7 @@ class DownloadManagerUtils @Inject constructor(
}
private suspend fun checkCleanApkSignatureOK(appInstall: AppInstall): Boolean {
- if (appInstall.origin != Origin.CLEANAPK || appManagerWrapper.isFdroidApplicationSigned(
+ if (appInstall.origin != Origin.CLEANAPK || appManagerWrapper.isFDroidApplicationSigned(
context, appInstall
)
) {
diff --git a/app/src/main/java/foundation/e/apps/install/pkg/PWAManager.kt b/app/src/main/java/foundation/e/apps/install/pkg/PwaManager.kt
similarity index 99%
rename from app/src/main/java/foundation/e/apps/install/pkg/PWAManager.kt
rename to app/src/main/java/foundation/e/apps/install/pkg/PwaManager.kt
index ccb37248b2107783c78545b7dbb6866d8be0a8d3..b1ea00b57efa1d0e304d4eb5db118b0dad21ad95 100644
--- a/app/src/main/java/foundation/e/apps/install/pkg/PWAManager.kt
+++ b/app/src/main/java/foundation/e/apps/install/pkg/PwaManager.kt
@@ -27,7 +27,7 @@ import javax.inject.Singleton
@Singleton
@OpenForTesting
-class PWAManager @Inject constructor(
+class PwaManager @Inject constructor(
@ApplicationContext private val context: Context,
private val appInstallRepository: AppInstallRepository,
) {
diff --git a/app/src/main/java/foundation/e/apps/install/receiver/PWAPlayerStatusReceiver.kt b/app/src/main/java/foundation/e/apps/install/receiver/PwaPlayerStatusReceiver.kt
similarity index 98%
rename from app/src/main/java/foundation/e/apps/install/receiver/PWAPlayerStatusReceiver.kt
rename to app/src/main/java/foundation/e/apps/install/receiver/PwaPlayerStatusReceiver.kt
index 9b3ed026761cde7a3e3bdcc20145ae6c2223b466..1339877cec6a6db214ff74ce468a39380ffcca38 100644
--- a/app/src/main/java/foundation/e/apps/install/receiver/PWAPlayerStatusReceiver.kt
+++ b/app/src/main/java/foundation/e/apps/install/receiver/PwaPlayerStatusReceiver.kt
@@ -39,7 +39,7 @@ import javax.inject.Inject
*/
@AndroidEntryPoint
@DelicateCoroutinesApi
-class PWAPlayerStatusReceiver : BroadcastReceiver() {
+class PwaPlayerStatusReceiver : BroadcastReceiver() {
companion object {
const val ACTION_PWA_ADDED = "foundation.e.pwaplayer.PWA_ADDED"
diff --git a/app/src/main/java/foundation/e/apps/install/splitinstall/SplitInstallBinder.kt b/app/src/main/java/foundation/e/apps/install/splitinstall/SplitInstallBinder.kt
index 8e5e5da16476f348421418b9f9ead522d1dfc6a2..6d61487dc0706ea3b62cb24caa1f71a375b7085b 100644
--- a/app/src/main/java/foundation/e/apps/install/splitinstall/SplitInstallBinder.kt
+++ b/app/src/main/java/foundation/e/apps/install/splitinstall/SplitInstallBinder.kt
@@ -26,7 +26,6 @@ import android.content.BroadcastReceiver
import android.content.Context
import android.content.Intent
import android.content.pm.PackageManager
-import android.os.Build
import androidx.core.app.ActivityCompat
import androidx.core.app.NotificationCompat
import androidx.core.app.NotificationManagerCompat
@@ -37,7 +36,7 @@ import foundation.e.apps.R
import foundation.e.apps.data.DownloadManager
import foundation.e.apps.data.application.ApplicationRepository
import foundation.e.apps.data.login.AuthenticatorRepository
-import foundation.e.apps.data.login.exceptions.GPlayLoginException
+import foundation.e.apps.data.login.exceptions.CustomException
import kotlinx.coroutines.CoroutineScope
import kotlinx.coroutines.Dispatchers
import kotlinx.coroutines.launch
@@ -71,13 +70,9 @@ class SplitInstallBinder(
coroutineScope.launch {
try {
authenticatorRepository.getValidatedAuthData()
- if (authenticatorRepository.gplayAuth == null) {
- Timber.w(AUTH_DATA_ERROR_MESSAGE)
- handleError(packageName)
- return@launch
- }
+ authenticatorRepository.getGPlayAuthOrThrow()
downloadModule(packageName, moduleName)
- } catch (exception: GPlayLoginException) {
+ } catch (exception: CustomException) {
Timber.w("$AUTH_DATA_ERROR_MESSAGE $exception")
handleError(packageName)
}
diff --git a/app/src/main/java/foundation/e/apps/provider/AgeRatingProvider.kt b/app/src/main/java/foundation/e/apps/provider/AgeRatingProvider.kt
index f3bf8552e22143907dc46b24c09c7a843879346c..0a72459d0ac7fe0b6f8b55e58f7d395f7f3a29ea 100644
--- a/app/src/main/java/foundation/e/apps/provider/AgeRatingProvider.kt
+++ b/app/src/main/java/foundation/e/apps/provider/AgeRatingProvider.kt
@@ -26,7 +26,6 @@ import android.content.UriMatcher
import android.database.Cursor
import android.database.MatrixCursor
import android.net.Uri
-import android.os.Build
import androidx.core.app.NotificationCompat
import dagger.hilt.EntryPoint
import dagger.hilt.InstallIn
@@ -44,7 +43,7 @@ import foundation.e.apps.data.blockedApps.BlockedAppRepository
import foundation.e.apps.data.enums.Origin
import foundation.e.apps.data.install.models.AppInstall
import foundation.e.apps.data.login.AuthenticatorRepository
-import foundation.e.apps.data.login.exceptions.GPlayLoginException
+import foundation.e.apps.data.login.exceptions.CustomException
import foundation.e.apps.data.parentalcontrol.ContentRatingDao
import foundation.e.apps.data.parentalcontrol.ContentRatingEntity
import foundation.e.apps.data.parentalcontrol.fdroid.FDroidAntiFeatureRepository
@@ -138,7 +137,7 @@ class AgeRatingProvider : ContentProvider() {
withContext(IO) {
try {
if (packageNames.isEmpty()) return@withContext cursor
- canSetupAuthData()
+ initAuthData()
ensureAgeGroupDataExists()
compileAppBlockList(cursor, packageNames)
@@ -198,10 +197,10 @@ class AgeRatingProvider : ContentProvider() {
* Setup AuthData for other APIs to access,
* if user has logged in with Google or Anonymous mode.
*/
- private fun canSetupAuthData() {
+ private fun initAuthData() {
val authData = dataStoreManager.getAuthData()
if (authData.email.isNotBlank() && authData.authToken.isNotBlank()) {
- authenticatorRepository.gplayAuth = authData
+ authenticatorRepository.setGPlayAuth(authData)
}
}
@@ -286,8 +285,9 @@ class AgeRatingProvider : ContentProvider() {
private fun hasAuthData(): Boolean {
return try {
- authenticatorRepository.gplayAuth != null
- } catch (e: GPlayLoginException) {
+ authenticatorRepository.getGPlayAuthOrThrow()
+ true
+ } catch (e: CustomException) {
Timber.e("No AuthData to check content rating")
false
}
diff --git a/app/src/main/java/foundation/e/apps/ui/AppInfoFetchViewModel.kt b/app/src/main/java/foundation/e/apps/ui/AppInfoFetchViewModel.kt
index a4fd28790c90d004f8c660029710e99ce9b3c37a..1630c4d679da19165c79a2ff265debfe82aad9e1 100644
--- a/app/src/main/java/foundation/e/apps/ui/AppInfoFetchViewModel.kt
+++ b/app/src/main/java/foundation/e/apps/ui/AppInfoFetchViewModel.kt
@@ -6,32 +6,31 @@ import androidx.lifecycle.liveData
import dagger.hilt.android.lifecycle.HiltViewModel
import foundation.e.apps.data.blockedApps.BlockedAppRepository
import foundation.e.apps.data.faultyApps.FaultyAppRepository
-import foundation.e.apps.data.fdroid.FdroidRepository
+import foundation.e.apps.data.fdroid.FDroidRepository
import foundation.e.apps.data.application.data.Application
import foundation.e.apps.data.playstore.PlayStoreRepository
import javax.inject.Inject
-import javax.inject.Named
/**
*
*/
@HiltViewModel
class AppInfoFetchViewModel @Inject constructor(
- private val fdroidRepository: FdroidRepository,
- @Named("gplayRepository") private val gplayRepository: PlayStoreRepository,
+ private val fDroidRepository: FDroidRepository,
+ private val gPlayRepository: PlayStoreRepository,
private val faultyAppRepository: FaultyAppRepository,
private val blockedAppRepository: BlockedAppRepository,
) : ViewModel() {
fun getAuthorName(application: Application) = liveData {
- val authorName = fdroidRepository.getAuthorName(application)
+ val authorName = fDroidRepository.getAuthorName(application)
emit(authorName)
}
fun isAppPurchased(app: Application): LiveData {
return liveData {
try {
- gplayRepository.getDownloadInfo(
+ gPlayRepository.getDownloadInfo(
app.package_name,
app.latest_version_code,
app.offer_type,
diff --git a/app/src/main/java/foundation/e/apps/ui/MainActivity.kt b/app/src/main/java/foundation/e/apps/ui/MainActivity.kt
index b897133a0e843325c1561710389ca1d108f12265..b3d40fdaa5e275220459e6e5167278eb848eaa0e 100644
--- a/app/src/main/java/foundation/e/apps/ui/MainActivity.kt
+++ b/app/src/main/java/foundation/e/apps/ui/MainActivity.kt
@@ -50,7 +50,7 @@ import foundation.e.apps.data.enums.User
import foundation.e.apps.data.install.models.AppInstall
import foundation.e.apps.data.login.AuthObject
import foundation.e.apps.data.login.PlayStoreAuthenticator
-import foundation.e.apps.data.login.exceptions.GPlayValidationException
+import foundation.e.apps.data.login.exceptions.CustomException
import foundation.e.apps.databinding.ActivityMainBinding
import foundation.e.apps.install.updates.UpdatesNotifier
import foundation.e.apps.ui.application.subFrags.ApplicationDialogFragment
@@ -356,7 +356,7 @@ class MainActivity : AppCompatActivity() {
gPlayAuthObject?.result?.run {
if (isSuccess()) {
viewModel.gPlayAuthData = data as AuthData
- } else if (exception is GPlayValidationException) {
+ } else if (exception?.type == CustomException.Type.GOOGLE_PLAY) {
val email = otherPayload.toString()
viewModel.uploadFaultyTokenToEcloud(
email,
diff --git a/app/src/main/java/foundation/e/apps/ui/MainActivityViewModel.kt b/app/src/main/java/foundation/e/apps/ui/MainActivityViewModel.kt
index e1b754c20f4591913f8d85151cdcd3f527898433..b06e667e25fefd2f66556c7582c3b0a238e2efaa 100644
--- a/app/src/main/java/foundation/e/apps/ui/MainActivityViewModel.kt
+++ b/app/src/main/java/foundation/e/apps/ui/MainActivityViewModel.kt
@@ -47,7 +47,7 @@ import foundation.e.apps.data.parentalcontrol.googleplay.GPlayContentRatingRepos
import foundation.e.apps.data.preference.AppLoungeDataStore
import foundation.e.apps.data.preference.getSync
import foundation.e.apps.install.pkg.AppLoungePackageManager
-import foundation.e.apps.install.pkg.PWAManager
+import foundation.e.apps.install.pkg.PwaManager
import foundation.e.apps.install.workmanager.AppInstallProcessor
import foundation.e.apps.utils.NetworkStatusManager
import kotlinx.coroutines.Dispatchers
@@ -60,7 +60,7 @@ class MainActivityViewModel @Inject constructor(
private val applicationRepository: ApplicationRepository,
private val appManagerWrapper: AppManagerWrapper,
private val appLoungePackageManager: AppLoungePackageManager,
- private val pwaManager: PWAManager,
+ private val pwaManager: PwaManager,
private val ecloudRepository: EcloudRepository,
private val blockedAppRepository: BlockedAppRepository,
private val gPlayContentRatingRepository: GPlayContentRatingRepository,
diff --git a/app/src/main/java/foundation/e/apps/ui/application/ApplicationFragment.kt b/app/src/main/java/foundation/e/apps/ui/application/ApplicationFragment.kt
index 126bc7d0ee73d6daf03945d7f27e710ee3375f8c..622071c8b788106143b192e3e8607a5a31ca32dc 100644
--- a/app/src/main/java/foundation/e/apps/ui/application/ApplicationFragment.kt
+++ b/app/src/main/java/foundation/e/apps/ui/application/ApplicationFragment.kt
@@ -61,13 +61,13 @@ import foundation.e.apps.data.enums.Status
import foundation.e.apps.data.enums.User
import foundation.e.apps.data.enums.isInitialized
import foundation.e.apps.data.login.AuthObject
-import foundation.e.apps.data.login.exceptions.GPlayLoginException
+import foundation.e.apps.data.login.exceptions.CustomException
import foundation.e.apps.databinding.FragmentApplicationBinding
import foundation.e.apps.di.CommonUtilsModule.LIST_OF_NULL
import foundation.e.apps.domain.ValidateAppAgeLimitUseCase.Companion.KEY_ANTI_FEATURES_NSFW
import foundation.e.apps.install.download.data.DownloadProgress
import foundation.e.apps.install.pkg.AppLoungePackageManager
-import foundation.e.apps.install.pkg.PWAManager
+import foundation.e.apps.install.pkg.PwaManager
import foundation.e.apps.ui.AppInfoFetchViewModel
import foundation.e.apps.ui.MainActivity
import foundation.e.apps.ui.MainActivityViewModel
@@ -130,7 +130,7 @@ class ApplicationFragment : TimeoutFragment(R.layout.fragment_application) {
lateinit var appLoungePackageManager: AppLoungePackageManager
@Inject
- lateinit var pwaManager: PWAManager
+ lateinit var pwaManager: PwaManager
private val applicationViewModel: ApplicationViewModel by viewModels()
private val privacyInfoViewModel: PrivacyInfoViewModel by viewModels()
@@ -621,21 +621,21 @@ class ApplicationFragment : TimeoutFragment(R.layout.fragment_application) {
}
override fun onTimeout(
- exception: Exception,
+ exception: CustomException,
predefinedDialog: AlertDialog.Builder
): AlertDialog.Builder? {
return predefinedDialog
}
override fun onSignInError(
- exception: GPlayLoginException,
+ exception: CustomException,
predefinedDialog: AlertDialog.Builder
): AlertDialog.Builder? {
return predefinedDialog
}
override fun onDataLoadError(
- exception: Exception,
+ exception: CustomException,
predefinedDialog: AlertDialog.Builder
): AlertDialog.Builder? {
return predefinedDialog
diff --git a/app/src/main/java/foundation/e/apps/ui/application/ApplicationViewModel.kt b/app/src/main/java/foundation/e/apps/ui/application/ApplicationViewModel.kt
index 3631984268053a4273c9cdadc5130a43ee5ba19d..19c2df2db58b519f04e86e5f847a203bdb00c29d 100644
--- a/app/src/main/java/foundation/e/apps/ui/application/ApplicationViewModel.kt
+++ b/app/src/main/java/foundation/e/apps/ui/application/ApplicationViewModel.kt
@@ -34,8 +34,7 @@ import foundation.e.apps.data.enums.Status
import foundation.e.apps.data.install.AppManagerWrapper
import foundation.e.apps.data.install.models.AppInstall
import foundation.e.apps.data.login.AuthObject
-import foundation.e.apps.data.login.exceptions.CleanApkException
-import foundation.e.apps.data.login.exceptions.GPlayException
+import foundation.e.apps.data.login.exceptions.CustomException
import foundation.e.apps.data.parentalcontrol.fdroid.FDroidAntiFeatureRepository
import foundation.e.apps.data.playstore.PlayStoreRepository
import foundation.e.apps.install.download.data.DownloadProgress
@@ -148,18 +147,20 @@ class ApplicationViewModel @Inject constructor(
updateAppContentRatingState(packageName, appData.first.contentRating)
val status = appData.second
+ val hasTimedOut = appData.second == ResultStatus.TIMEOUT
+ val error = if (hasTimedOut) {
+ CustomException.Error.TIMEOUT_ERROR
+ } else {
+ CustomException.Error.UNKNOWN_ERROR
+ }
if (appData.second != ResultStatus.OK) {
val exception =
- if (authData.aasToken.isNotBlank() || authData.authToken.isNotBlank())
- GPlayException(
- appData.second == ResultStatus.TIMEOUT,
- status.message.ifBlank { "Data load error" }
- )
- else CleanApkException(
- appData.second == ResultStatus.TIMEOUT,
- status.message.ifBlank { "Data load error" }
- )
+ if (authData.aasToken.isNotBlank() || authData.authToken.isNotBlank()) {
+ CustomException(error, status.message.ifBlank { "Data load error" }, type = CustomException.Type.GOOGLE_PLAY)
+ } else {
+ CustomException(error, status.message.ifBlank { "Data load error" })
+ }
exceptionsList.add(exception)
exceptionsLiveData.postValue(exceptionsList)
diff --git a/app/src/main/java/foundation/e/apps/ui/applicationlist/ApplicationListFragment.kt b/app/src/main/java/foundation/e/apps/ui/applicationlist/ApplicationListFragment.kt
index 909c6a89665ffd47323d059e665c4b13dc68e708..a3050985d8573e3c82c27f33a12f5753d4841405 100644
--- a/app/src/main/java/foundation/e/apps/ui/applicationlist/ApplicationListFragment.kt
+++ b/app/src/main/java/foundation/e/apps/ui/applicationlist/ApplicationListFragment.kt
@@ -36,10 +36,10 @@ import foundation.e.apps.data.enums.Status
import foundation.e.apps.data.application.ApplicationInstaller
import foundation.e.apps.data.application.data.Application
import foundation.e.apps.data.login.AuthObject
-import foundation.e.apps.data.login.exceptions.GPlayLoginException
+import foundation.e.apps.data.login.exceptions.CustomException
import foundation.e.apps.databinding.FragmentApplicationListBinding
import foundation.e.apps.install.download.data.DownloadProgress
-import foundation.e.apps.install.pkg.PWAManager
+import foundation.e.apps.install.pkg.PwaManager
import foundation.e.apps.install.pkg.AppLoungePackageManager
import foundation.e.apps.ui.AppInfoFetchViewModel
import foundation.e.apps.ui.AppProgressViewModel
@@ -62,7 +62,7 @@ class ApplicationListFragment :
lateinit var appLoungePackageManager: AppLoungePackageManager
@Inject
- lateinit var pwaManager: PWAManager
+ lateinit var pwaManager: PwaManager
// protected to avoid SyntheticAccessor
protected val viewModel: ApplicationListViewModel by viewModels()
@@ -270,21 +270,21 @@ class ApplicationListFragment :
}
override fun onTimeout(
- exception: Exception,
+ exception: CustomException,
predefinedDialog: AlertDialog.Builder
): AlertDialog.Builder? {
return predefinedDialog
}
override fun onSignInError(
- exception: GPlayLoginException,
+ exception: CustomException,
predefinedDialog: AlertDialog.Builder
): AlertDialog.Builder? {
return predefinedDialog
}
override fun onDataLoadError(
- exception: Exception,
+ exception: CustomException,
predefinedDialog: AlertDialog.Builder
): AlertDialog.Builder? {
return predefinedDialog
diff --git a/app/src/main/java/foundation/e/apps/ui/applicationlist/ApplicationListViewModel.kt b/app/src/main/java/foundation/e/apps/ui/applicationlist/ApplicationListViewModel.kt
index bf4272a17563055deaa5833684382af66772ddc6..dad65ee63eda340f977501100e3693b5c2a21be2 100644
--- a/app/src/main/java/foundation/e/apps/ui/applicationlist/ApplicationListViewModel.kt
+++ b/app/src/main/java/foundation/e/apps/ui/applicationlist/ApplicationListViewModel.kt
@@ -28,8 +28,7 @@ import foundation.e.apps.data.enums.Source
import foundation.e.apps.data.application.ApplicationRepository
import foundation.e.apps.data.application.data.Application
import foundation.e.apps.data.login.AuthObject
-import foundation.e.apps.data.login.exceptions.CleanApkException
-import foundation.e.apps.data.login.exceptions.GPlayException
+import foundation.e.apps.data.login.exceptions.CustomException
import foundation.e.apps.ui.parentFragment.LoadingViewModel
import kotlinx.coroutines.Dispatchers
import kotlinx.coroutines.launch
@@ -112,16 +111,21 @@ class ApplicationListViewModel @Inject constructor(
private fun getException(
authData: AuthData,
result: ResultSupreme, String>>
- ) = if (authData.aasToken.isNotBlank() || authData.authToken.isNotBlank()) {
- GPlayException(
- result.isTimeout(),
- result.message.ifBlank { "Data load error" }
- )
- } else {
- CleanApkException(
- result.isTimeout(),
- result.message.ifBlank { "Data load error" }
- )
+ ) : CustomException {
+ val error = if (result.isTimeout()) {
+ CustomException.Error.TIMEOUT_ERROR
+ } else {
+ CustomException.Error.UNKNOWN_ERROR
+ }
+
+ if (authData.aasToken.isNotBlank() || authData.authToken.isNotBlank()) {
+ return CustomException(error,
+ result.message.ifBlank { "Data load error" }, type = CustomException.Type.GOOGLE_PLAY
+ )
+ } else {
+ return CustomException(error, result.message.ifBlank { "Data load error" }
+ )
+ }
}
private fun updateNextPageUrl(nextPageUrl: String?) {
diff --git a/app/src/main/java/foundation/e/apps/ui/categories/AppsFragment.kt b/app/src/main/java/foundation/e/apps/ui/categories/AppsFragment.kt
index fadb8dd123421944ea4061f6d85a3a8cd96528c4..5842321bb0edd541d78b22d491475d187dd7b365 100644
--- a/app/src/main/java/foundation/e/apps/ui/categories/AppsFragment.kt
+++ b/app/src/main/java/foundation/e/apps/ui/categories/AppsFragment.kt
@@ -28,7 +28,7 @@ import dagger.hilt.android.AndroidEntryPoint
import foundation.e.apps.R
import foundation.e.apps.data.application.utils.CategoryType
import foundation.e.apps.data.login.AuthObject
-import foundation.e.apps.data.login.exceptions.GPlayLoginException
+import foundation.e.apps.data.login.exceptions.CustomException
import foundation.e.apps.databinding.FragmentAppsBinding
import foundation.e.apps.ui.MainActivityViewModel
import foundation.e.apps.ui.categories.model.CategoriesRVAdapter
@@ -80,21 +80,21 @@ class AppsFragment : TimeoutFragment(R.layout.fragment_apps) {
}
override fun onTimeout(
- exception: Exception,
+ exception: CustomException,
predefinedDialog: AlertDialog.Builder
): AlertDialog.Builder? {
return predefinedDialog
}
override fun onSignInError(
- exception: GPlayLoginException,
+ exception: CustomException,
predefinedDialog: AlertDialog.Builder
): AlertDialog.Builder? {
return predefinedDialog
}
override fun onDataLoadError(
- exception: Exception,
+ exception: CustomException,
predefinedDialog: AlertDialog.Builder
): AlertDialog.Builder? {
return predefinedDialog
diff --git a/app/src/main/java/foundation/e/apps/ui/categories/CategoriesViewModel.kt b/app/src/main/java/foundation/e/apps/ui/categories/CategoriesViewModel.kt
index 163562d95fefa79ca1f03537dc7d53be5f9eb4b1..228252f0114720620c0d037e3f885599f8067305 100644
--- a/app/src/main/java/foundation/e/apps/ui/categories/CategoriesViewModel.kt
+++ b/app/src/main/java/foundation/e/apps/ui/categories/CategoriesViewModel.kt
@@ -27,8 +27,7 @@ import foundation.e.apps.data.application.ApplicationRepository
import foundation.e.apps.data.application.data.Category
import foundation.e.apps.data.application.utils.CategoryType
import foundation.e.apps.data.login.AuthObject
-import foundation.e.apps.data.login.exceptions.CleanApkException
-import foundation.e.apps.data.login.exceptions.GPlayException
+import foundation.e.apps.data.login.exceptions.CustomException
import foundation.e.apps.ui.parentFragment.LoadingViewModel
import kotlinx.coroutines.launch
import javax.inject.Inject
@@ -67,17 +66,15 @@ class CategoriesViewModel @Inject constructor(
val status = categoriesData.second
+ val error = if (categoriesData.second == ResultStatus.TIMEOUT) {
+ CustomException.Error.TIMEOUT_ERROR
+ } else {
+ CustomException.Error.UNKNOWN_ERROR
+ }
+
if (status != ResultStatus.OK) {
val exception =
- if (authData.aasToken.isNotBlank() || authData.authToken.isNotBlank())
- GPlayException(
- categoriesData.second == ResultStatus.TIMEOUT,
- status.message.ifBlank { "Data load error" }
- )
- else CleanApkException(
- categoriesData.second == ResultStatus.TIMEOUT,
- status.message.ifBlank { "Data load error" }
- )
+ CustomException(error, status.message.ifBlank { "Data load error" })
exceptionsList.add(exception)
exceptionsLiveData.postValue(exceptionsList)
diff --git a/app/src/main/java/foundation/e/apps/ui/categories/GamesFragment.kt b/app/src/main/java/foundation/e/apps/ui/categories/GamesFragment.kt
index dbbf2ad7aa98c15c5c0294085e3362c51d36ced2..f245eec8cbc12abb68c7c003d080c6e53e06460f 100644
--- a/app/src/main/java/foundation/e/apps/ui/categories/GamesFragment.kt
+++ b/app/src/main/java/foundation/e/apps/ui/categories/GamesFragment.kt
@@ -28,7 +28,7 @@ import dagger.hilt.android.AndroidEntryPoint
import foundation.e.apps.R
import foundation.e.apps.data.application.utils.CategoryType
import foundation.e.apps.data.login.AuthObject
-import foundation.e.apps.data.login.exceptions.GPlayLoginException
+import foundation.e.apps.data.login.exceptions.CustomException
import foundation.e.apps.databinding.FragmentGamesBinding
import foundation.e.apps.ui.MainActivityViewModel
import foundation.e.apps.ui.categories.model.CategoriesRVAdapter
@@ -80,21 +80,21 @@ class GamesFragment : TimeoutFragment(R.layout.fragment_games) {
}
override fun onTimeout(
- exception: Exception,
+ exception: CustomException,
predefinedDialog: AlertDialog.Builder
): AlertDialog.Builder? {
return predefinedDialog
}
override fun onSignInError(
- exception: GPlayLoginException,
+ exception: CustomException,
predefinedDialog: AlertDialog.Builder
): AlertDialog.Builder? {
return predefinedDialog
}
override fun onDataLoadError(
- exception: Exception,
+ exception: CustomException,
predefinedDialog: AlertDialog.Builder
): AlertDialog.Builder? {
return predefinedDialog
diff --git a/app/src/main/java/foundation/e/apps/ui/home/HomeFragment.kt b/app/src/main/java/foundation/e/apps/ui/home/HomeFragment.kt
index 91ac8ad0ecbb3e775c0119ee75f75c6b2baf2423..8ada3f9cb2d8fbdf431229dd4472e9917de30876 100644
--- a/app/src/main/java/foundation/e/apps/ui/home/HomeFragment.kt
+++ b/app/src/main/java/foundation/e/apps/ui/home/HomeFragment.kt
@@ -33,12 +33,11 @@ import foundation.e.apps.data.enums.Status
import foundation.e.apps.data.application.ApplicationInstaller
import foundation.e.apps.data.application.data.Application
import foundation.e.apps.data.login.AuthObject
-import foundation.e.apps.data.login.exceptions.GPlayException
-import foundation.e.apps.data.login.exceptions.GPlayLoginException
+import foundation.e.apps.data.login.exceptions.CustomException
import foundation.e.apps.databinding.FragmentHomeBinding
import foundation.e.apps.di.CommonUtilsModule.safeNavigate
import foundation.e.apps.install.download.data.DownloadProgress
-import foundation.e.apps.install.pkg.PWAManager
+import foundation.e.apps.install.pkg.PwaManager
import foundation.e.apps.ui.AppInfoFetchViewModel
import foundation.e.apps.ui.AppProgressViewModel
import foundation.e.apps.ui.MainActivityViewModel
@@ -67,7 +66,7 @@ class HomeFragment : TimeoutFragment(R.layout.fragment_home), ApplicationInstall
private val appInfoFetchViewModel: AppInfoFetchViewModel by viewModels()
@Inject
- lateinit var pwaManager: PWAManager
+ lateinit var pwaManager: PwaManager
companion object {
private const val SCROLL_DELAY_IN_MILLIS = 500L
@@ -145,24 +144,20 @@ class HomeFragment : TimeoutFragment(R.layout.fragment_home), ApplicationInstall
}
override fun onTimeout(
- exception: Exception,
+ exception: CustomException,
predefinedDialog: AlertDialog.Builder
- ): AlertDialog.Builder? {
+ ): AlertDialog.Builder {
return predefinedDialog.apply {
- if (exception is GPlayException) {
- setMessage(R.string.timeout_desc_gplay)
- setNegativeButton(R.string.open_settings) { _, _ ->
- openSettings()
- }
- } else {
- setMessage(R.string.timeout_desc_cleanapk)
+ setMessage(R.string.timeout_desc_gplay)
+ setNegativeButton(R.string.open_settings) { _, _ ->
+ openSettings()
}
setCancelable(false)
}
}
override fun onSignInError(
- exception: GPlayLoginException,
+ exception: CustomException,
predefinedDialog: AlertDialog.Builder
): AlertDialog.Builder? {
return predefinedDialog.apply {
@@ -173,14 +168,12 @@ class HomeFragment : TimeoutFragment(R.layout.fragment_home), ApplicationInstall
}
override fun onDataLoadError(
- exception: Exception,
+ exception: CustomException,
predefinedDialog: AlertDialog.Builder
- ): AlertDialog.Builder? {
+ ): AlertDialog.Builder {
return predefinedDialog.apply {
- if (exception is GPlayException) {
- setNegativeButton(R.string.open_settings) { _, _ ->
- openSettings()
- }
+ setNegativeButton(R.string.open_settings) { _, _ ->
+ openSettings()
}
}
}
diff --git a/app/src/main/java/foundation/e/apps/ui/home/HomeViewModel.kt b/app/src/main/java/foundation/e/apps/ui/home/HomeViewModel.kt
index afd4f8cd2dfb6224109c08fda60540f41fe97799..74b43a2264bc736b09a823fe755c862f90722e04 100644
--- a/app/src/main/java/foundation/e/apps/ui/home/HomeViewModel.kt
+++ b/app/src/main/java/foundation/e/apps/ui/home/HomeViewModel.kt
@@ -28,8 +28,7 @@ import foundation.e.apps.data.ResultSupreme
import foundation.e.apps.data.application.ApplicationRepository
import foundation.e.apps.data.application.data.Home
import foundation.e.apps.data.login.AuthObject
-import foundation.e.apps.data.login.exceptions.CleanApkException
-import foundation.e.apps.data.login.exceptions.GPlayException
+import foundation.e.apps.data.login.exceptions.CustomException
import foundation.e.apps.ui.applicationlist.ApplicationDiffUtil
import foundation.e.apps.ui.parentFragment.LoadingViewModel
import kotlinx.coroutines.launch
@@ -83,16 +82,13 @@ class HomeViewModel @Inject constructor(
return@observe
}
- val exception =
- if (authData.aasToken.isNotBlank() || authData.authToken.isNotBlank())
- GPlayException(
- it.isTimeout(),
- it.message.ifBlank { "Data load error" }
- )
- else CleanApkException(
- it.isTimeout(),
- it.message.ifBlank { "Data load error" }
- )
+ val error = if (it.isTimeout()) {
+ CustomException.Error.TIMEOUT_ERROR
+ } else {
+ CustomException.Error.UNKNOWN_ERROR
+ }
+
+ val exception = CustomException(error, it.message.ifBlank { "Data load error" })
exceptionsList.add(exception)
exceptionsLiveData.postValue(exceptionsList)
diff --git a/app/src/main/java/foundation/e/apps/ui/parentFragment/LoadingViewModel.kt b/app/src/main/java/foundation/e/apps/ui/parentFragment/LoadingViewModel.kt
index a59e502ca0bc1aa937f4afe847ac73102c5ae07f..ac62485aca57ea168d05cd4bc517bab94164c086 100644
--- a/app/src/main/java/foundation/e/apps/ui/parentFragment/LoadingViewModel.kt
+++ b/app/src/main/java/foundation/e/apps/ui/parentFragment/LoadingViewModel.kt
@@ -20,8 +20,7 @@ package foundation.e.apps.ui.parentFragment
import androidx.lifecycle.MutableLiveData
import androidx.lifecycle.ViewModel
import foundation.e.apps.data.login.AuthObject
-import foundation.e.apps.data.login.exceptions.GPlayValidationException
-import foundation.e.apps.data.login.exceptions.UnknownSourceException
+import foundation.e.apps.data.login.exceptions.CustomException
abstract class LoadingViewModel : ViewModel() {
@@ -29,8 +28,8 @@ abstract class LoadingViewModel : ViewModel() {
private var autoRetried = false
}
- val exceptionsLiveData: MutableLiveData> = MutableLiveData()
- val exceptionsList = ArrayList()
+ val exceptionsLiveData: MutableLiveData> = MutableLiveData()
+ val exceptionsList = ArrayList()
/**
* Call this method from ViewModel.
@@ -53,11 +52,11 @@ abstract class LoadingViewModel : ViewModel() {
val failedAuthList = authObjectList.filter { !it.result.isSuccess() }
failedAuthList.forEach {
- exceptionsList.add(it.result.exception ?: UnknownSourceException())
+ exceptionsList.add(it.result.exception ?: CustomException())
}
exceptionsList.find {
- it is GPlayValidationException
+ it.type == CustomException.Type.GOOGLE_PLAY
}?.run {
if (!autoRetried && retryBlock(failedAuthList)) {
autoRetried = true
diff --git a/app/src/main/java/foundation/e/apps/ui/parentFragment/TimeoutFragment.kt b/app/src/main/java/foundation/e/apps/ui/parentFragment/TimeoutFragment.kt
index 6d3d162b8f2e58896832a8560047033049972e28..30e160d6e48e073a3326bdc1a9d05b00d00cafaf 100644
--- a/app/src/main/java/foundation/e/apps/ui/parentFragment/TimeoutFragment.kt
+++ b/app/src/main/java/foundation/e/apps/ui/parentFragment/TimeoutFragment.kt
@@ -35,11 +35,7 @@ import foundation.e.apps.data.enums.User
import foundation.e.apps.data.login.AuthObject
import foundation.e.apps.data.login.PlayStoreAuthenticator
import foundation.e.apps.ui.LoginViewModel
-import foundation.e.apps.data.login.exceptions.CleanApkException
-import foundation.e.apps.data.login.exceptions.GPlayException
-import foundation.e.apps.data.login.exceptions.GPlayLoginException
-import foundation.e.apps.data.login.exceptions.GPlayValidationException
-import foundation.e.apps.data.login.exceptions.UnknownSourceException
+import foundation.e.apps.data.login.exceptions.CustomException
import foundation.e.apps.databinding.DialogErrorLogBinding
import foundation.e.apps.ui.MainActivityViewModel
import timber.log.Timber
@@ -138,7 +134,7 @@ abstract class TimeoutFragment(@LayoutRes layoutId: Int) : Fragment(layoutId) {
* or null to not show anything.
*/
abstract fun onTimeout(
- exception: Exception,
+ exception: CustomException,
predefinedDialog: AlertDialog.Builder,
): AlertDialog.Builder?
@@ -162,7 +158,7 @@ abstract class TimeoutFragment(@LayoutRes layoutId: Int) : Fragment(layoutId) {
* or null to not show anything.
*/
abstract fun onSignInError(
- exception: GPlayLoginException,
+ exception: CustomException,
predefinedDialog: AlertDialog.Builder,
): AlertDialog.Builder?
@@ -181,7 +177,7 @@ abstract class TimeoutFragment(@LayoutRes layoutId: Int) : Fragment(layoutId) {
* 6. Dialog is cancellable.
*/
abstract fun onDataLoadError(
- exception: Exception,
+ exception: CustomException,
predefinedDialog: AlertDialog.Builder,
): AlertDialog.Builder?
@@ -248,7 +244,7 @@ abstract class TimeoutFragment(@LayoutRes layoutId: Int) : Fragment(layoutId) {
* instance if it deems fit. Else it may return null, in which case no timeout dialog
* is shown to the user.
*/
- fun showTimeout(exception: Exception) {
+ private fun showTimeout(exception: CustomException) {
val dialogView = DialogErrorLogBinding.inflate(requireActivity().layoutInflater)
dialogView.apply {
moreInfo.setOnClickListener {
@@ -296,7 +292,7 @@ abstract class TimeoutFragment(@LayoutRes layoutId: Int) : Fragment(layoutId) {
* instance if it deems fit. Else it may return null, at which case no error dialog
* is shown to the user.
*/
- fun showSignInError(exception: GPlayLoginException) {
+ fun showSignInError(exception: CustomException) {
val dialogView = DialogErrorLogBinding.inflate(requireActivity().layoutInflater)
dialogView.apply {
@@ -329,9 +325,10 @@ abstract class TimeoutFragment(@LayoutRes layoutId: Int) : Fragment(layoutId) {
setPositiveButton(R.string.retry) { _, _ ->
showLoadingUI()
- when (exception) {
- is GPlayValidationException -> clearAndRestartGPlayLogin()
- else -> loginViewModel.startLoginFlow()
+ if (exception.networkCode == 401) {
+ clearAndRestartGPlayLogin()
+ } else {
+ loginViewModel.startLoginFlow()
}
}
setNegativeButton(R.string.logout) { _, _ ->
@@ -356,7 +353,7 @@ abstract class TimeoutFragment(@LayoutRes layoutId: Int) : Fragment(layoutId) {
* instance if it deems fit. Else it may return null, at which case no error dialog
* is shown to the user.
*/
- fun showDataLoadError(exception: Exception) {
+ fun showDataLoadError(exception: CustomException) {
val dialogView = DialogErrorLogBinding.inflate(requireActivity().layoutInflater)
dialogView.apply {
moreInfo.setOnClickListener {
@@ -400,42 +397,27 @@ abstract class TimeoutFragment(@LayoutRes layoutId: Int) : Fragment(layoutId) {
* Common code to handle exceptions / errors during data loading.
* Can be overridden in child fragments.
*/
- open fun handleExceptionsCommon(exceptions: List) {
- val cleanApkException = exceptions.find { it is CleanApkException }?.run {
- this as CleanApkException
- }
- val gPlayException = exceptions.find { it is GPlayException }?.run {
- this as GPlayException
- }
- val unknownSourceException = exceptions.find { it is UnknownSourceException }
+ open fun handleExceptionsCommon(exceptions: List) {
- if (gPlayException?.message?.contains(STATUS_TOO_MANY_REQUESTS) == true) {
- return
- }
+ exceptions.forEach {
+ when {
+ it.type == CustomException.Type.GOOGLE_PLAY -> {
+ if (it.message?.contains(STATUS_TOO_MANY_REQUESTS) == true) {
+ return
+ }
- /*
- * Take caution altering the cases.
- * Cases to be defined from most restrictive to least restrictive.
- */
- when {
- // Handle timeouts
- cleanApkException?.isTimeout == true -> showTimeout(cleanApkException)
- gPlayException?.isTimeout == true -> showTimeout(gPlayException)
-
- // Handle sign-in error
- gPlayException is GPlayLoginException -> showSignInError(gPlayException)
-
- // Other errors - data loading error
- gPlayException != null -> showDataLoadError(gPlayException)
- cleanApkException != null -> showDataLoadError(cleanApkException)
-
- // Unknown exception
- unknownSourceException != null -> {
- showAndSetDialog(
+ if (it.error == CustomException.Error.AUTHENTICATION_ERROR) {
+ showSignInError(it)
+ }
+ }
+
+ it.error == CustomException.Error.TIMEOUT_ERROR -> showTimeout(it)
+
+ else -> showAndSetDialog(
AlertDialog.Builder(requireActivity())
.setTitle(R.string.unknown_error)
- .setPositiveButton(R.string.close, null)
- )
+ .setPositiveButton(R.string.close, null))
+
}
}
}
diff --git a/app/src/main/java/foundation/e/apps/ui/search/SearchFragment.kt b/app/src/main/java/foundation/e/apps/ui/search/SearchFragment.kt
index f813834094475c954945873169f8a15c5cf000af..0ae80fa78910b5190150db12691b2e6919257006 100644
--- a/app/src/main/java/foundation/e/apps/ui/search/SearchFragment.kt
+++ b/app/src/main/java/foundation/e/apps/ui/search/SearchFragment.kt
@@ -49,10 +49,10 @@ import foundation.e.apps.data.application.data.Application
import foundation.e.apps.data.enums.Status
import foundation.e.apps.data.install.models.AppInstall
import foundation.e.apps.data.login.AuthObject
-import foundation.e.apps.data.login.exceptions.GPlayLoginException
+import foundation.e.apps.data.login.exceptions.CustomException
import foundation.e.apps.databinding.FragmentSearchBinding
import foundation.e.apps.install.download.data.DownloadProgress
-import foundation.e.apps.install.pkg.PWAManager
+import foundation.e.apps.install.pkg.PwaManager
import foundation.e.apps.ui.AppInfoFetchViewModel
import foundation.e.apps.ui.AppProgressViewModel
import foundation.e.apps.ui.MainActivityViewModel
@@ -75,7 +75,7 @@ class SearchFragment :
ApplicationInstaller {
@Inject
- lateinit var pwaManager: PWAManager
+ lateinit var pwaManager: PwaManager
private var _binding: FragmentSearchBinding? = null
private val binding get() = _binding!!
@@ -344,21 +344,21 @@ class SearchFragment :
}
override fun onTimeout(
- exception: Exception,
+ exception: CustomException,
predefinedDialog: AlertDialog.Builder
): AlertDialog.Builder? {
return predefinedDialog
}
override fun onDataLoadError(
- exception: Exception,
+ exception: CustomException,
predefinedDialog: AlertDialog.Builder
): AlertDialog.Builder? {
return predefinedDialog
}
override fun onSignInError(
- exception: GPlayLoginException,
+ exception: CustomException,
predefinedDialog: AlertDialog.Builder
): AlertDialog.Builder? {
return predefinedDialog
diff --git a/app/src/main/java/foundation/e/apps/ui/search/SearchViewModel.kt b/app/src/main/java/foundation/e/apps/ui/search/SearchViewModel.kt
index 9d89d8f31ae6f51d828cf8944ea1dbac5b991ac6..61eb29a7c328e1fe635f66beca38a8e8b0e39f82 100644
--- a/app/src/main/java/foundation/e/apps/ui/search/SearchViewModel.kt
+++ b/app/src/main/java/foundation/e/apps/ui/search/SearchViewModel.kt
@@ -34,9 +34,7 @@ import foundation.e.apps.data.enums.Origin
import foundation.e.apps.data.exodus.repositories.IAppPrivacyInfoRepository
import foundation.e.apps.data.exodus.repositories.PrivacyScoreRepository
import foundation.e.apps.data.login.AuthObject
-import foundation.e.apps.data.login.exceptions.CleanApkException
-import foundation.e.apps.data.login.exceptions.GPlayException
-import foundation.e.apps.data.login.exceptions.UnknownSourceException
+import foundation.e.apps.data.login.exceptions.CustomException
import foundation.e.apps.di.CommonUtilsModule.LIST_OF_NULL
import foundation.e.apps.ui.parentFragment.LoadingViewModel
import kotlinx.coroutines.Dispatchers
@@ -151,20 +149,16 @@ class SearchViewModel @Inject constructor(
hasGPlayBeenFetched = false
emitFilteredResults(searchResultSupreme)
+
if (!searchResultSupreme.isSuccess()) {
- val exception =
- if (authData != null) {
- GPlayException(
- searchResultSupreme.isTimeout(),
- searchResultSupreme.message.ifBlank { DATA_LOAD_ERROR }
- )
- } else {
- CleanApkException(
- searchResultSupreme.isTimeout(),
- searchResultSupreme.message.ifBlank { DATA_LOAD_ERROR }
- )
- }
+ val error = if (searchResultSupreme.isTimeout()) {
+ CustomException.Error.TIMEOUT_ERROR
+ } else {
+ CustomException.Error.UNKNOWN_ERROR
+ }
+
+ val exception = CustomException(error, searchResultSupreme.message.ifBlank { DATA_LOAD_ERROR })
handleException(exception)
}
@@ -196,7 +190,7 @@ class SearchViewModel @Inject constructor(
val gplaySearchResult = applicationRepository.getGplaySearchResults(query, nextSubBundle)
if (!gplaySearchResult.isSuccess()) {
- handleException(gplaySearchResult.exception ?: UnknownSourceException())
+ handleException(gplaySearchResult.exception ?: CustomException())
}
nextSubBundle = gplaySearchResult.data?.second
@@ -219,7 +213,7 @@ class SearchViewModel @Inject constructor(
return currentAppList.distinctBy { it.package_name }
}
- private fun handleException(exception: Exception) {
+ private fun handleException(exception: CustomException) {
exceptionsList.add(exception)
exceptionsLiveData.postValue(exceptionsList)
}
diff --git a/app/src/main/java/foundation/e/apps/ui/updates/UpdatesFragment.kt b/app/src/main/java/foundation/e/apps/ui/updates/UpdatesFragment.kt
index 9ba5a6fee90445908456bbaa051122858cbb0e5d..f1629f5c887d138ae3890e485e8470a3ad8427cb 100644
--- a/app/src/main/java/foundation/e/apps/ui/updates/UpdatesFragment.kt
+++ b/app/src/main/java/foundation/e/apps/ui/updates/UpdatesFragment.kt
@@ -42,12 +42,11 @@ import foundation.e.apps.data.application.ApplicationInstaller
import foundation.e.apps.data.application.data.Application
import foundation.e.apps.data.install.models.AppInstall
import foundation.e.apps.data.login.AuthObject
-import foundation.e.apps.data.login.exceptions.GPlayException
-import foundation.e.apps.data.login.exceptions.GPlayLoginException
+import foundation.e.apps.data.login.exceptions.CustomException
import foundation.e.apps.databinding.FragmentUpdatesBinding
import foundation.e.apps.di.CommonUtilsModule.safeNavigate
import foundation.e.apps.install.download.data.DownloadProgress
-import foundation.e.apps.install.pkg.PWAManager
+import foundation.e.apps.install.pkg.PwaManager
import foundation.e.apps.install.updates.UpdatesWorkManager
import foundation.e.apps.install.workmanager.InstallWorkManager.INSTALL_WORK_NAME
import foundation.e.apps.ui.AppInfoFetchViewModel
@@ -73,7 +72,7 @@ class UpdatesFragment : TimeoutFragment(R.layout.fragment_updates), ApplicationI
private val binding get() = _binding!!
@Inject
- lateinit var pwaManager: PWAManager
+ lateinit var pwaManager: PwaManager
private val updatesViewModel: UpdatesViewModel by viewModels()
private val privacyInfoViewModel: PrivacyInfoViewModel by viewModels()
@@ -153,7 +152,14 @@ class UpdatesFragment : TimeoutFragment(R.layout.fragment_updates), ApplicationI
Timber.d("===>> observeupdate list called")
if (resultStatus != ResultStatus.OK) {
- val exception = GPlayException(resultStatus == ResultStatus.TIMEOUT)
+ val error = if (resultStatus == ResultStatus.TIMEOUT) {
+ CustomException.Error.TIMEOUT_ERROR
+ } else {
+ CustomException.Error.UNKNOWN_ERROR
+ }
+
+ val exception = CustomException(error, "exception")
+
val alertDialogBuilder = AlertDialog.Builder(requireContext())
onTimeout(exception, alertDialogBuilder)
}
@@ -238,11 +244,11 @@ class UpdatesFragment : TimeoutFragment(R.layout.fragment_updates), ApplicationI
}
override fun onTimeout(
- exception: Exception,
+ exception: CustomException,
predefinedDialog: AlertDialog.Builder
): AlertDialog.Builder? {
return predefinedDialog.apply {
- if (exception is GPlayException) {
+ if (exception.type == CustomException.Type.GOOGLE_PLAY) {
setMessage(R.string.timeout_desc_gplay)
setNegativeButton(R.string.open_settings) { _, _ ->
openSettings()
@@ -254,7 +260,7 @@ class UpdatesFragment : TimeoutFragment(R.layout.fragment_updates), ApplicationI
}
override fun onSignInError(
- exception: GPlayLoginException,
+ exception: CustomException,
predefinedDialog: AlertDialog.Builder
): AlertDialog.Builder? {
return predefinedDialog.apply {
@@ -265,11 +271,11 @@ class UpdatesFragment : TimeoutFragment(R.layout.fragment_updates), ApplicationI
}
override fun onDataLoadError(
- exception: Exception,
+ exception: CustomException,
predefinedDialog: AlertDialog.Builder
): AlertDialog.Builder? {
return predefinedDialog.apply {
- if (exception is GPlayException) {
+ if (exception.type == CustomException.Type.GOOGLE_PLAY) {
setNegativeButton(R.string.open_settings) { _, _ ->
openSettings()
}
diff --git a/app/src/main/java/foundation/e/apps/ui/updates/UpdatesViewModel.kt b/app/src/main/java/foundation/e/apps/ui/updates/UpdatesViewModel.kt
index 77214dc202ba5ba409265800f313295f2fe0b858..41f8d6871b255fca7385e838b1e7fc48732fc179 100644
--- a/app/src/main/java/foundation/e/apps/ui/updates/UpdatesViewModel.kt
+++ b/app/src/main/java/foundation/e/apps/ui/updates/UpdatesViewModel.kt
@@ -28,8 +28,7 @@ import foundation.e.apps.data.enums.Status
import foundation.e.apps.data.application.ApplicationRepository
import foundation.e.apps.data.application.data.Application
import foundation.e.apps.data.login.AuthObject
-import foundation.e.apps.data.login.exceptions.CleanApkException
-import foundation.e.apps.data.login.exceptions.GPlayException
+import foundation.e.apps.data.login.exceptions.CustomException
import foundation.e.apps.data.preference.AppLoungePreference
import foundation.e.apps.data.updates.UpdatesManagerRepository
import foundation.e.apps.ui.parentFragment.LoadingViewModel
@@ -73,18 +72,14 @@ class UpdatesViewModel @Inject constructor(
val status = updatesResult.second
if (status != ResultStatus.OK) {
- val exception =
- if (authData != null &&
- (authData.aasToken.isNotBlank() || authData.authToken.isNotBlank())
- ) {
- GPlayException(
- updatesResult.second == ResultStatus.TIMEOUT,
- status.message.ifBlank { "Data load error" }
- )
- } else CleanApkException(
- updatesResult.second == ResultStatus.TIMEOUT,
- status.message.ifBlank { "Data load error" }
- )
+
+ val error = if (updatesResult.second == ResultStatus.TIMEOUT) {
+ CustomException.Error.TIMEOUT_ERROR
+ } else {
+ CustomException.Error.UNKNOWN_ERROR
+ }
+
+ val exception = CustomException(error, status.message.ifBlank { "Data load error" })
exceptionsList.add(exception)
exceptionsLiveData.postValue(exceptionsList)
diff --git a/app/src/main/res/values-de/strings.xml b/app/src/main/res/values-de/strings.xml
index 261a9270e025ca93826ed2ec60df0c9703f5ed35..09e7cd96a96abf7461a9cc7ed64e0511802a311e 100644
--- a/app/src/main/res/values-de/strings.xml
+++ b/app/src/main/res/values-de/strings.xml
@@ -72,8 +72,6 @@
Entdecke
Top quelloffene aktualisierte Apps
Top quelloffene aktualisierte Spiele
- Beliebteste quelloffene Apps in den letzten 24 Stunden
- Beliebteste quelloffene Spiele in den letzten 24 Stunden
PWA beliebteste Apps
PWA beliebteste Spiele
Top kostenlose Apps
@@ -143,7 +141,6 @@
App Lounge-Version
Über
Bitte wähle mindestens eine Quelle von Apps aus.
- Entdecke PWA\'s
Anonymer Login ist fehlgeschlagen!
Das kann verursacht sein, weil ein Server nicht funktioniert.
\n
@@ -205,4 +202,4 @@
System-App
Achtung – Aktualisierung!
App Lounge wird vom System beendet, um eine Aktualisierung durchzuführen. Bitte führen Sie keine anderen Aktionen aus, bis App Lounge aktualisert und beendet ist.
-
\ No newline at end of file
+
diff --git a/app/src/main/res/values-es/strings.xml b/app/src/main/res/values-es/strings.xml
index ac9f8f58659b636eafdd00914d8ae24164f5a6a9..5e80a9a8b34b05bc374d9464841ef8a661a43dea 100644
--- a/app/src/main/res/values-es/strings.xml
+++ b/app/src/main/res/values-es/strings.xml
@@ -76,8 +76,6 @@
Explorar
Aplicaciones de código abierto más actualizadas
Juegos de código abierto más actualizados
- Juegos de código abierto más populares en las últimas 24 horas
- Aplicaciones de código abierto más populares en las últimas 24 horas
Aplicaciones PWA populares
Juegos PWA populares
Las mejores aplicaciones gratuitas
@@ -144,7 +142,6 @@
¡Límite de tiempo buscando aplicaciones!
No hay información de rastreo disponible para esta aplicación.
Actualización de %1$s aplicaciones completada en %2$s.
- Explorar PWA
La actualización de %1$s ha fallado debido a una regla de soporte (ubicación, versión del sistema operativo...).
Debido a un fallo temporal, no se pueden actualizar todas tus aplicaciones. Vuelve a intentarlo más tarde.
Actualizar todo ha fallado. Se harán reintentos automáticos.
@@ -203,4 +200,4 @@
Recopilando la clasificación de contenido de todas las aplicaciones que has instalado.
Advertencia del contenido
La aplicación puede contener desnudos, blasfemias, insultos, violencia, sexualidad intensa, incorrección política u otros temas potencialmente perturbadores. Esto es especialmente importante en entornos como lugares de trabajo, escuelas, entornos religiosos y familiares.
-
\ No newline at end of file
+
diff --git a/app/src/main/res/values-fi/strings.xml b/app/src/main/res/values-fi/strings.xml
index c254423c87db3d8e86f49e1d4c740dfcd0cd4b4b..ad26a3cfbe04e0c71cdc87dcbe1a0761d72a4a17 100644
--- a/app/src/main/res/values-fi/strings.xml
+++ b/app/src/main/res/values-fi/strings.xml
@@ -110,8 +110,6 @@
Top ilmaiset sovellukset
PWA Suositut pelit
PWA Suositut sovellukset
- Suosittuja avoimen lähdekoodin pelejä viimeisen 24 tunnin aikana
- Suosittuja avoimen lähdekoodin sovelluksia viimeisen 24 tunnin aikana
Avoimen lähdekoodin päivitettyjen pelien Top lista
Avoimen lähdekoodin päivitettyjen sovellusten Top lista
Tutustu
@@ -146,7 +144,6 @@
\n
\nAvaa asetukset ja etsi vain avoimen lähdekoodin sovelluksia tai PWA:ita.
Aikakatkaisu sovellusten hakemisessa!
- Tutustu PWA:n
Päivitysvirhe!
Päivitystä ei voida suorittaa koska allekirjoitus on ristiriidassa %1$s ja puhelimeesi asennetun version välillä. Voit korjata tämän poistamalla %1$s ja asentamalla se uudestaan App Loungesta.
Huomautus: Tämä viesti ei tule näkyviin uudelleen.
Google Play -sovelluksia ei voida näyttää, kun vain avoimen lähdekoodin sovellukset ovat valittuna.
@@ -171,4 +168,4 @@
PWA ja avoimen lähdekoodin sovellukset
Tili ei ole käytettävissä
Jakaa
-
\ No newline at end of file
+
diff --git a/app/src/main/res/values-fr/strings.xml b/app/src/main/res/values-fr/strings.xml
index 4540074cb786664817228f9b38b9c73a4f52652c..c5f7fe1f20693cd7ade12257f753b63494fe9d59 100644
--- a/app/src/main/res/values-fr/strings.xml
+++ b/app/src/main/res/values-fr/strings.xml
@@ -71,8 +71,6 @@
Découvrir
Top des apps Open Source mises à jour
Top des jeux Open Source mis à jour
- Jeux populaires Open Source dans les dernières 24h
- Apps populaires Open Source dans les dernières 24 h
Apps PWA populaires
Jeux PWA populaires
Top des apps gratuites
@@ -141,7 +139,6 @@
\nOuvrez les paramètres pour n\'afficher que les applications Open Source et PWA.
Expiration du délai de récupération des applications !
Aucune information concernant les pisteurs pour cette application.
- PWA à découvrir
Erreur lors de la mise à jour !
La mise à jour ne peut être appliquée car la signature de la mise à jour de %1$s ne correspond pas à la signature de la version installée sur votre téléphone. Pour y remédier vous pouvez désinstaller %1$s puis la réinstaller depuis App Lounge.
Note : Ce message ne s\'affichera plus.
Il est impossible d\'afficher les applications Google Play quand seules les applications Open Source sont sélectionnées.
@@ -203,4 +200,4 @@
Cliquer sur \"%1$s\" ouvrira un onglet dans votre navigateur avec le nom du paquet de l\'application pré-rempli.<br /><br /> Cliquez sur \"Perform analysis\" pour lancer l\'analyse par Exodus.<br /><br /> Quand le bouton \"See the report\" apparaît (cela peut prendre un moment selon l\'application) vous pouvez fermer l\'onglet et retourner sur la description de l\'application dans %2$s où vous devriez voir la note de Confidentialité. Parfois Exodus peut échouer à analyser l\'application.<br /><br />NB : cela peut prendre jusqu\'à 10 min pour que le score apparaisse dans la description de l\'application.
RENOUVELER LA SESSION
Application système
-
\ No newline at end of file
+
diff --git a/app/src/main/res/values-is/strings.xml b/app/src/main/res/values-is/strings.xml
index 8999fff64b5384b4d1330294bdd932d8dd03d2a2..05fdf538a3aadd6566a3412fee956f39c072a17d 100644
--- a/app/src/main/res/values-is/strings.xml
+++ b/app/src/main/res/values-is/strings.xml
@@ -120,7 +120,6 @@
Af hverju sé ég opnu hugbúnaðarútgáfuna\?
Forrit með opinn grunnkóða
Öll forrit eru af nýjustu útgáfu
- Kynntu þér PWA-vefforrit
Vinsæl PWA-vefforrit
Vinsælir PWA-leikir
Næ ekki að tengjast! Athugaðu internettenginguna þína og prófaðu svo aftur
@@ -134,8 +133,6 @@
Vinsælustu uppfærðu forritin með opinn grunnkóða
Vinsælustu uppfærðir leikir með opinn grunnkóða
Vinsælustu ókeypis og frjálsu forritin
- Vinsæl forrit síðasta sólahring með opinn grunnkóða
- Vinsæla leiki síðasta sólahring með opinn grunnkóða
Vinsælustu ókeypis og frjálsu leikirnir
Forrit með mestu innkomuna
Leikir með mestu innkomuna
@@ -204,4 +201,4 @@
Kerfisforrit
Aðvörun vegna uppfærslu!
App Lounge verður lokað af kerfinu á meðan það uppfærir sjálft sig. Vertu helst ekki að gera neitt annað þangað til uppfærslu App Lounge er lokið.
-
\ No newline at end of file
+
diff --git a/app/src/main/res/values-it/strings.xml b/app/src/main/res/values-it/strings.xml
index d5505806e1d19b2075318f6b11152fac47740507..fdee09cffa96d6323a8976a91b079df5628ada6b 100644
--- a/app/src/main/res/values-it/strings.xml
+++ b/app/src/main/res/values-it/strings.xml
@@ -75,8 +75,6 @@
Errore sconosciuto!
Aggiorna tutto
Scopri
- App Open Source più richieste nelle ultime 24 ore
- Giochi Open Source più richiesti nelle ultime 24 ore
App PWA più richieste
Giochi PWA più richiesti
Migliori App Open Source aggiornate
@@ -153,7 +151,6 @@
\nPuoi riprovare adesso o più tardi.
Si è verificato un errore durante il caricamento delle App.
Maggiori informazioni
- Scopri le PWA
Non posso avviare l\'App Google Play se sono permesse solo App open source.
Chiudi
Mensilmente
@@ -203,4 +200,4 @@
Avviso sui contenuti
App Lounge verrà chiusa dal sistema mentre installa l\'aggiornamento. Si prega di non effettuare alcuna attività su App Lounge finchè non sarà aggiornata e chiusa.
Avviso sull\'aggiornamento!
-
\ No newline at end of file
+
diff --git a/app/src/main/res/values-nb-rNO/strings.xml b/app/src/main/res/values-nb-rNO/strings.xml
index cb3ade70cc24cb026de6a77960adef04248ccf98..4ad70dd981e159fbad82b96942d569655c251f8b 100644
--- a/app/src/main/res/values-nb-rNO/strings.xml
+++ b/app/src/main/res/values-nb-rNO/strings.xml
@@ -52,7 +52,6 @@
Applikasjonsoppdateringer vil bli installert automatisk
Oppdateringer
Nedlastinger
- Oppdag PWA
Oppdag
%1$s sin oppdatering har mislyktes på grunn av et misforhold (lokasjon, operativsystemversjon…).
På gunn av en midlertidig feil kan ikke alle dine applikasjoner bli oppdatert. Prøv igjen senere.
@@ -164,9 +163,7 @@
Topp gratis applikasjoner
Mest populære spill
Topp gratis spill
- Populære åpen kildekode-applikasjoner de siste 24 timer
Populære PWA spill
- Populære åpen kildekode-spill de siste 24 timer
Mest innbringende applikasjoner
Mest innbringende spill
Ingen sporingsinformasjon tilgjengelig for denne applikasjonen.
@@ -202,4 +199,4 @@
Systemapplikasjon
Innholdsvarsel
Samler innholdsvurdering for alle applikasjonene du har installert.
-
\ No newline at end of file
+
diff --git a/app/src/main/res/values-nl/strings.xml b/app/src/main/res/values-nl/strings.xml
index 35a1480f330d0e4f0fb67936f3fd648967e21583..b8887c22fd8f9b585961de8e78c50b8e6eb0b2e2 100644
--- a/app/src/main/res/values-nl/strings.xml
+++ b/app/src/main/res/values-nl/strings.xml
@@ -47,7 +47,6 @@
Top Gratis Apps
PWA Populaire Spellen
PWA Populaire Apps
- Ontdek PWA
Ontdek
Update Fout!
Alle apps zijn up-to-date
@@ -152,8 +151,6 @@
Geen \"runtime android\" machtiging gevonden!
Top Populaire Games
Top Populaire Apps
- Open Source Populaire Games van de laatste 24 uur
- Open Source Populaire Apps van de laatste 24 uur
Open Source Top Geüpdatete Games
Open Source Top Geüpdatet Apps
De update voor %1$s is niet door een ondersteuning regel (locatie, OS versie...).
@@ -204,4 +201,4 @@
Deze app kan naaktheid, godslastering, laster, geweld, seksualiteit, politieke incorrectheid of andere mogelijk ongepaste onderwerpen bevatten. Dit is voornamelijk relevant in omgevingen als werkplekken, scholen, religieuze instellingen en gezinnen.
Attentie, update!
App Lounge zal door het systeem afgesloten worden tijdens zijn update. Voer a.u.b. geen andere taken uit totdat App Lounge geüpdatet en afgesloten is.
-
\ No newline at end of file
+
diff --git a/app/src/main/res/values-ru/strings.xml b/app/src/main/res/values-ru/strings.xml
index 32c8bdcb9d47031fe0f3747b7bc6695f5a7481c9..827fb00d85242c0836e4373bc057436629e7d7bf 100644
--- a/app/src/main/res/values-ru/strings.xml
+++ b/app/src/main/res/values-ru/strings.xml
@@ -118,12 +118,9 @@
Топ бесплатных приложений
Популярные PWA игры
Популярные PWA приложения
- Популярные Open Source игры за последние 24 часа
- Популярные Open Source приложения за последние 24 часа
Топ Open Source обновленных игр
Топ обновленных Open Source приложений
Откройте для себя
- Откройте для себя PWA
Обновление %1$s не произошло из-за поддержки (местоположения, версии ОС...).
Из-за временного сбоя все ваши приложения не могут быть обновлены. Пожалуйста, повторите попытку позже.
Обновить всё не удалось. Выполняются автоматические повторные попытки.
@@ -204,4 +201,4 @@
Запросить исходный отчёт
Анонимная учетная запись, которую вы используете в данный момент, недоступна. Пожалуйста, обновите сессию, чтобы получить другую.
ОБНОВИТЬ СЕССИИ
-
\ No newline at end of file
+
diff --git a/app/src/main/res/values-sv/strings.xml b/app/src/main/res/values-sv/strings.xml
index ba3250eab292960ca315774c229cf6d73e6d5e96..aa11e72a775f610cfca6777ab8197f3d4c78473f 100644
--- a/app/src/main/res/values-sv/strings.xml
+++ b/app/src/main/res/values-sv/strings.xml
@@ -110,9 +110,6 @@
Välj åtminstone en källa av applikationer.
Integritetsanalys
Har du problem\?
- Upptäck PWA
- Populäraste apparna de senaste 24 timmarna med öppen källkod
- Populäraste spelen de senaste 24 timmarna med öppen källkod
Populära PWA-appar
Populära PWA-spel
Hämtningar
@@ -204,4 +201,4 @@
Systemapp
Varning för uppdatering!
Systemet kommer stänga App Lounge medan uppdatering installeras för App Lounge. Undvik att något annat tills App Lounge är uppdaterat och har stängts.
-
\ No newline at end of file
+
diff --git a/app/src/main/res/values-tr/strings.xml b/app/src/main/res/values-tr/strings.xml
index e11370dde7d72d87fcb736922f710a13138cc272..c8afa6a5e4c8e1554e9ae8b2507a66403246570a 100644
--- a/app/src/main/res/values-tr/strings.xml
+++ b/app/src/main/res/values-tr/strings.xml
@@ -85,11 +85,8 @@
Geçici bir arıza nedeniyle uygulamalarınızın tümü güncellenemiyor. Lütfen daha sonra tekrar deneyin.
%1$s güncellemesi bir destek kuralı (konum, işletim sistemi sürümü...) nedeniyle başarısız oldu.
Keşfet
- PWA\'ları keşfedin
Açık Kaynaklı Tutan Güncel Oyunlar
Açık Kaynaklı Tutan Güncel Uygulamalar
- Son 24 Saatte Açık Kaynaklı Popüler Uygulamalar
- Son 24 Saatin Popüler Açık Kaynak Oyunları
PWA popüler uygulamalar
PWA Popüler Uygulamalar
En Çok Kazanan Uygulamalar
@@ -187,4 +184,4 @@
\n
\nTekrar denemek için Yeniden Dene\'ye basın.
%s ekstra modüller yüklemek istiyor. Bunları yükleyebilmek için AppLounge\'da tekrar oturum açmalısınız.
-
\ No newline at end of file
+
diff --git a/app/src/main/res/values-uk/strings.xml b/app/src/main/res/values-uk/strings.xml
index c40f460a8a0ce83df6f29105774f149f6a92ce9a..a02f1f8a6a7635f65400ef2ffc74dd455c525a8f 100644
--- a/app/src/main/res/values-uk/strings.xml
+++ b/app/src/main/res/values-uk/strings.xml
@@ -97,7 +97,6 @@
Оновлення не вдалося. Автоматичні повторні спроби уже в процесі.
Трендові додатки в Топі
Безкоштовні ігри в Топі
- Дослідити PWA
Дослідити
- %1$d оновлення застосунку доступне
@@ -122,8 +121,6 @@
Топ безкоштовних ігор
Популярні прогресивні веб-ігри
Популярні прогресивні веб-застосунки
- Популярні ігри з відкритим кодом за останню добу
- Популярні додатки з відкритим кодом за останню добу
Топ оновлених Ігор з відкритим кодом
Топ оновлених додатків з відкритим кодом
Оновлення %1$s не вдалося з причини підтримки (наприклад місцезнаходження, версія ОС…).
@@ -174,4 +171,4 @@
Зареєструватися
Обліковий запис недоступний
Поділитися
-
\ No newline at end of file
+
diff --git a/app/src/main/res/values/strings.xml b/app/src/main/res/values/strings.xml
index fa41bcdf6112f70981e43b1cec523b8900253c62..94f39e423e88aba14fa953f2acf380f485b46b09 100644
--- a/app/src/main/res/values/strings.xml
+++ b/app/src/main/res/values/strings.xml
@@ -147,11 +147,8 @@
App Lounge will be closed by the system while installing its own update. Kindly refrain from doing any other task till App Lounge is updated and closed.
Discover
- Discover PWA
Open Source Top Updated Apps
Open Source Top Updated Games
- Open Source Popular Apps In Last 24 Hours
- Open Source Popular Games In Last 24 Hours
PWA Popular Apps
PWA Popular Games
Top Free Apps
diff --git a/app/src/test/java/foundation/e/apps/UpdateManagerImptTest.kt b/app/src/test/java/foundation/e/apps/UpdateManagerImptTest.kt
index d483c05c5fb2a699a4edc3b7399e0891fa7a8ca4..eb5c7090f75e990c4e81b66afd6ae49a76037d6a 100644
--- a/app/src/test/java/foundation/e/apps/UpdateManagerImptTest.kt
+++ b/app/src/test/java/foundation/e/apps/UpdateManagerImptTest.kt
@@ -26,7 +26,7 @@ import foundation.e.apps.data.enums.Origin
import foundation.e.apps.data.enums.ResultStatus
import foundation.e.apps.data.enums.Status
import foundation.e.apps.data.faultyApps.FaultyAppRepository
-import foundation.e.apps.data.fdroid.FdroidRepository
+import foundation.e.apps.data.fdroid.FDroidRepository
import foundation.e.apps.data.application.ApplicationRepository
import foundation.e.apps.data.application.search.SearchApi
import foundation.e.apps.data.application.data.Application
@@ -77,7 +77,7 @@ class UpdateManagerImptTest {
private lateinit var blockedAppRepository: BlockedAppRepository
@Mock
- private lateinit var fdroidRepository: FdroidRepository
+ private lateinit var fDroidRepository: FDroidRepository
@Mock
private lateinit var systemAppsUpdatesRepository: SystemAppsUpdatesRepository
@@ -96,7 +96,7 @@ class UpdateManagerImptTest {
applicationRepository,
faultyAppRepository,
preferenceModule,
- fdroidRepository,
+ fDroidRepository,
blockedAppRepository,
systemAppsUpdatesRepository,
)
diff --git a/app/src/test/java/foundation/e/apps/apps/AppsApiTest.kt b/app/src/test/java/foundation/e/apps/apps/AppsApiTest.kt
index 861cacf8e20b41e1ef452be57dc613013ad24aad..8cda6e3cff0d20e7da276b0d901644618b302273 100644
--- a/app/src/test/java/foundation/e/apps/apps/AppsApiTest.kt
+++ b/app/src/test/java/foundation/e/apps/apps/AppsApiTest.kt
@@ -22,11 +22,9 @@ import android.content.Context
import android.text.format.Formatter
import androidx.arch.core.executor.testing.InstantTaskExecutorRule
import com.aurora.gplayapi.Constants
-import com.aurora.gplayapi.data.models.App
import com.aurora.gplayapi.data.models.AuthData
import foundation.e.apps.FakeAppLoungePreference
import foundation.e.apps.data.AppSourcesContainer
-import foundation.e.apps.data.cleanapk.repositories.CleanApkRepository
import foundation.e.apps.data.enums.FilterLevel
import foundation.e.apps.data.enums.Origin
import foundation.e.apps.data.enums.Status
@@ -34,8 +32,10 @@ import foundation.e.apps.data.application.ApplicationDataManager
import foundation.e.apps.data.application.apps.AppsApi
import foundation.e.apps.data.application.apps.AppsApiImpl
import foundation.e.apps.data.application.data.Application
+import foundation.e.apps.data.cleanapk.repositories.CleanApkAppsRepository
+import foundation.e.apps.data.cleanapk.repositories.CleanApkPwaRepository
import foundation.e.apps.data.playstore.PlayStoreRepository
-import foundation.e.apps.install.pkg.PWAManager
+import foundation.e.apps.install.pkg.PwaManager
import foundation.e.apps.install.pkg.AppLoungePackageManager
import foundation.e.apps.util.MainCoroutineRule
import kotlinx.coroutines.ExperimentalCoroutinesApi
@@ -67,7 +67,7 @@ class AppsApiTest {
var mainCoroutineRule = MainCoroutineRule()
@Mock
- private lateinit var pwaManager: PWAManager
+ private lateinit var pwaManager: PwaManager
@Mock
private lateinit var appLoungePackageManager: AppLoungePackageManager
@@ -76,10 +76,10 @@ class AppsApiTest {
private lateinit var context: Context
@Mock
- private lateinit var cleanApkAppsRepository: CleanApkRepository
+ private lateinit var cleanApkAppsRepository: CleanApkAppsRepository
@Mock
- private lateinit var cleanApkPWARepository: CleanApkRepository
+ private lateinit var cleanApkPWARepository: CleanApkPwaRepository
@Mock
private lateinit var gPlayAPIRepository: PlayStoreRepository
@@ -120,7 +120,7 @@ class AppsApiTest {
@Test
fun `is any app updated when new list is empty`() {
- val oldAppList = mutableListOf(
+ val oldAppList = mutableListOf(
Application(
_id = "111",
status = Status.UNAVAILABLE,
@@ -154,7 +154,7 @@ class AppsApiTest {
@Test
fun `is any app updated when any app is uninstalled`() {
- val oldAppList = mutableListOf(
+ val oldAppList = mutableListOf(
Application(
_id = "111",
status = Status.UNAVAILABLE,
@@ -175,7 +175,7 @@ class AppsApiTest {
)
)
- val newAppList = mutableListOf(
+ val newAppList = mutableListOf(
Application(
_id = "111",
status = Status.UNAVAILABLE,
@@ -202,7 +202,7 @@ class AppsApiTest {
@Test
fun `has any app install status changed when changed`() {
- val oldAppList = mutableListOf(
+ val oldAppList = mutableListOf(
Application(
_id = "111",
status = Status.UNAVAILABLE,
@@ -263,7 +263,7 @@ class AppsApiTest {
@Test
fun `has any app install status changed when not changed`() {
- val oldAppList = mutableListOf(
+ val oldAppList = mutableListOf(
Application(
_id = "111",
status = Status.UNAVAILABLE,
@@ -324,7 +324,7 @@ class AppsApiTest {
@Test
fun `has any app install status changed when installation_issue`() {
- val oldAppList = mutableListOf(
+ val oldAppList = mutableListOf(
Application(
_id = "111",
status = Status.INSTALLATION_ISSUE,
@@ -491,7 +491,7 @@ class AppsApiTest {
}
Mockito.`when`(gPlayAPIRepository.getAppDetails(fusedApp.package_name))
- .thenReturn(App(fusedApp.package_name))
+ .thenReturn(Application(fusedApp.package_name))
Mockito.`when`(
gPlayAPIRepository.getDownloadInfo(
@@ -533,7 +533,7 @@ class AppsApiTest {
}
Mockito.`when`(gPlayAPIRepository.getAppDetails(fusedApp.package_name))
- .thenReturn(App(fusedApp.package_name))
+ .thenReturn(Application(fusedApp.package_name))
Mockito.`when`(
gPlayAPIRepository.getDownloadInfo(
diff --git a/app/src/test/java/foundation/e/apps/category/CategoryApiTest.kt b/app/src/test/java/foundation/e/apps/category/CategoryApiTest.kt
index e6a96d7e2257c0e059a69b4d70b40ab335376c3b..ddf7a556a94b044727107c361de55c8b308179bc 100644
--- a/app/src/test/java/foundation/e/apps/category/CategoryApiTest.kt
+++ b/app/src/test/java/foundation/e/apps/category/CategoryApiTest.kt
@@ -29,10 +29,11 @@ import foundation.e.apps.data.application.category.CategoryApi
import foundation.e.apps.data.application.category.CategoryApiImpl
import foundation.e.apps.data.application.utils.CategoryType
import foundation.e.apps.data.cleanapk.data.categories.Categories
-import foundation.e.apps.data.cleanapk.repositories.CleanApkRepository
+import foundation.e.apps.data.cleanapk.repositories.CleanApkAppsRepository
+import foundation.e.apps.data.cleanapk.repositories.CleanApkPwaRepository
import foundation.e.apps.data.enums.ResultStatus
import foundation.e.apps.data.playstore.PlayStoreRepository
-import foundation.e.apps.install.pkg.PWAManager
+import foundation.e.apps.install.pkg.PwaManager
import foundation.e.apps.install.pkg.AppLoungePackageManager
import foundation.e.apps.util.MainCoroutineRule
import kotlinx.coroutines.ExperimentalCoroutinesApi
@@ -64,16 +65,16 @@ class CategoryApiTest {
private lateinit var context: Context
@Mock
- private lateinit var pwaManager: PWAManager
+ private lateinit var pwaManager: PwaManager
@Mock
private lateinit var appLoungePackageManager: AppLoungePackageManager
@Mock
- private lateinit var cleanApkAppsRepository: CleanApkRepository
+ private lateinit var cleanApkAppsRepository: CleanApkAppsRepository
@Mock
- private lateinit var cleanApkPWARepository: CleanApkRepository
+ private lateinit var cleanApkPWARepository: CleanApkPwaRepository
@Mock
private lateinit var gPlayAPIRepository: PlayStoreRepository
@@ -210,4 +211,4 @@ class CategoryApiTest {
Assert.assertEquals("getCategory", 11, categoryListResponse.first.size)
}
-}
\ No newline at end of file
+}
diff --git a/app/src/test/java/foundation/e/apps/fused/SearchApiImplTest.kt b/app/src/test/java/foundation/e/apps/fused/SearchApiImplTest.kt
index 117b5cc9fd7c071bb26aa42c9d9170805cb081c6..3bb56cea6c3ac1584290c6e5dc02cdcac6167195 100644
--- a/app/src/test/java/foundation/e/apps/fused/SearchApiImplTest.kt
+++ b/app/src/test/java/foundation/e/apps/fused/SearchApiImplTest.kt
@@ -26,7 +26,6 @@ import com.aurora.gplayapi.data.models.SearchBundle
import foundation.e.apps.FakeAppLoungePreference
import foundation.e.apps.data.AppSourcesContainer
import foundation.e.apps.data.cleanapk.data.search.Search
-import foundation.e.apps.data.cleanapk.repositories.CleanApkRepository
import foundation.e.apps.data.enums.Origin
import foundation.e.apps.data.enums.Status
import foundation.e.apps.data.application.search.SearchApiImpl
@@ -34,8 +33,10 @@ import foundation.e.apps.data.application.ApplicationDataManager
import foundation.e.apps.data.application.apps.AppsApi
import foundation.e.apps.data.application.apps.AppsApiImpl
import foundation.e.apps.data.application.data.Application
+import foundation.e.apps.data.cleanapk.repositories.CleanApkAppsRepository
+import foundation.e.apps.data.cleanapk.repositories.CleanApkPwaRepository
import foundation.e.apps.data.playstore.PlayStoreRepository
-import foundation.e.apps.install.pkg.PWAManager
+import foundation.e.apps.install.pkg.PwaManager
import foundation.e.apps.install.pkg.AppLoungePackageManager
import foundation.e.apps.util.MainCoroutineRule
import foundation.e.apps.utils.eventBus.EventBus
@@ -43,7 +44,6 @@ import kotlinx.coroutines.ExperimentalCoroutinesApi
import kotlinx.coroutines.delay
import kotlinx.coroutines.launch
import kotlinx.coroutines.test.runTest
-import okhttp3.ResponseBody
import okhttp3.ResponseBody.Companion.toResponseBody
import org.junit.After
import org.junit.Assert.assertEquals
@@ -76,7 +76,7 @@ class SearchApiImplTest {
private lateinit var fusedAPIImpl: SearchApiImpl
@Mock
- private lateinit var pwaManager: PWAManager
+ private lateinit var pwaManager: PwaManager
@Mock
private lateinit var appLoungePackageManager: AppLoungePackageManager
@@ -85,10 +85,10 @@ class SearchApiImplTest {
private lateinit var context: Context
@Mock
- private lateinit var cleanApkAppsRepository: CleanApkRepository
+ private lateinit var cleanApkAppsRepository: CleanApkAppsRepository
@Mock
- private lateinit var cleanApkPWARepository: CleanApkRepository
+ private lateinit var cleanApkPWARepository: CleanApkPwaRepository
@Mock
private lateinit var gPlayAPIRepository: PlayStoreRepository
@@ -148,7 +148,7 @@ class SearchApiImplTest {
@Ignore("Dependencies are not mockable")
@Test
fun `getSearchResult When all sources are selected`() = runTest {
- val appList = mutableListOf(
+ val appList = mutableListOf(
Application(
_id = "111",
status = Status.UNAVAILABLE,
@@ -174,7 +174,7 @@ class SearchApiImplTest {
val searchResult = Search(apps = appList, numberOfResults = 3, success = true)
val packageNameSearchResponse = Response.success(searchResult)
- val gplayPackageResult = App("com.search.package")
+ val gplayPackageResult = Application("com.search.package")
preferenceManagerModule.isPWASelectedFake = true
preferenceManagerModule.isOpenSourceelectedFake = true
@@ -196,7 +196,7 @@ class SearchApiImplTest {
private suspend fun setupMockingSearchApp(
packageNameSearchResponse: Response?,
- gplayPackageResult: App,
+ gplayPackageResult: Application,
gplayLivedata: Pair, MutableSet>,
willThrowException: Boolean = false
) {
@@ -231,7 +231,7 @@ class SearchApiImplTest {
).thenReturn(packageNameSearchResponse)
Mockito.`when`(cleanApkAppsRepository.getAppDetails(any()))
- .thenReturn(Response.error(404, "".toResponseBody()))
+ .thenReturn(Application())
Mockito.`when`(gPlayAPIRepository.getSearchResult(eq("com.search.package"), null))
.thenReturn(gplayLivedata)
@@ -266,7 +266,7 @@ class SearchApiImplTest {
val searchResult = Search(apps = appList, numberOfResults = 1, success = true)
val packageNameSearchResponse = Response.success(searchResult)
- val gplayPackageResult = App("com.search.package")
+ val gplayPackageResult = Application("com.search.package")
val gplayFlow: Pair, MutableSet> = Pair(
listOf(App("a.b.c"), App("c.d.e"), App("d.e.f"), App("d.e.g")), mutableSetOf()
diff --git a/app/src/test/java/foundation/e/apps/fusedManager/AppManagerWrapperTest.kt b/app/src/test/java/foundation/e/apps/fusedManager/AppManagerWrapperTest.kt
index 4fe3108f597214c3fd28921759c85640accd611e..fb77fcfce4cb48c54d54cfb54f06ae560566b8e8 100644
--- a/app/src/test/java/foundation/e/apps/fusedManager/AppManagerWrapperTest.kt
+++ b/app/src/test/java/foundation/e/apps/fusedManager/AppManagerWrapperTest.kt
@@ -21,7 +21,7 @@ package foundation.e.apps.fusedManager
import android.app.Application
import androidx.arch.core.executor.testing.InstantTaskExecutorRule
import foundation.e.apps.data.enums.Status
-import foundation.e.apps.data.fdroid.FdroidRepository
+import foundation.e.apps.data.fdroid.FDroidRepository
import foundation.e.apps.data.install.AppManagerWrapper
import foundation.e.apps.data.install.models.AppInstall
import foundation.e.apps.install.workmanager.InstallWorkManager
@@ -58,7 +58,7 @@ class AppManagerWrapperTest {
private lateinit var application: Application
@Mock
- private lateinit var fdroidRepository: FdroidRepository
+ private lateinit var fdroidRepository: FDroidRepository
private lateinit var appManagerWrapper: AppManagerWrapper
diff --git a/app/src/test/java/foundation/e/apps/home/HomeApiTest.kt b/app/src/test/java/foundation/e/apps/home/HomeApiTest.kt
index 34ad19888888cc14d79647d680cb97885a38588e..ab9348c9713c72b360e316edad42050b292c02ce 100644
--- a/app/src/test/java/foundation/e/apps/home/HomeApiTest.kt
+++ b/app/src/test/java/foundation/e/apps/home/HomeApiTest.kt
@@ -21,17 +21,18 @@ package foundation.e.apps.home
import android.content.Context
import android.text.format.Formatter
import androidx.arch.core.executor.testing.InstantTaskExecutorRule
-import com.aurora.gplayapi.data.models.App
import com.aurora.gplayapi.data.models.AuthData
import foundation.e.apps.FakeAppLoungePreference
import foundation.e.apps.data.AppSourcesContainer
import foundation.e.apps.data.application.ApplicationDataManager
+import foundation.e.apps.data.application.data.Application
import foundation.e.apps.data.application.home.HomeApi
import foundation.e.apps.data.application.home.HomeApiImpl
-import foundation.e.apps.data.cleanapk.repositories.CleanApkRepository
+import foundation.e.apps.data.cleanapk.repositories.CleanApkAppsRepository
+import foundation.e.apps.data.cleanapk.repositories.CleanApkPwaRepository
import foundation.e.apps.data.enums.Status
import foundation.e.apps.data.playstore.PlayStoreRepository
-import foundation.e.apps.install.pkg.PWAManager
+import foundation.e.apps.install.pkg.PwaManager
import foundation.e.apps.install.pkg.AppLoungePackageManager
import foundation.e.apps.util.MainCoroutineRule
import foundation.e.apps.util.getOrAwaitValue
@@ -67,7 +68,7 @@ class HomeApiTest {
private lateinit var applicationDataManager: ApplicationDataManager
@Mock
- private lateinit var pwaManager: PWAManager
+ private lateinit var pwaManager: PwaManager
@Mock
private lateinit var appLoungePackageManager: AppLoungePackageManager
@@ -76,10 +77,10 @@ class HomeApiTest {
private lateinit var context: Context
@Mock
- private lateinit var cleanApkAppsRepository: CleanApkRepository
+ private lateinit var cleanApkAppsRepository: CleanApkAppsRepository
@Mock
- private lateinit var cleanApkPWARepository: CleanApkRepository
+ private lateinit var cleanApkPWARepository: CleanApkPwaRepository
@Mock
private lateinit var gPlayAPIRepository: PlayStoreRepository
@@ -111,19 +112,19 @@ class HomeApiTest {
@Test
fun testHomeScreenDataWhenDataIsLimited() = runTest {
- val newAppList = mutableListOf(
- App("foundation.e.demoone"),
- App("foundation.e.demotwo"),
- App("foundation.e.demothree"),
+ val newAppList = mutableListOf(
+ Application("foundation.e.demoone"),
+ Application("foundation.e.demotwo"),
+ Application("foundation.e.demothree"),
)
- var newHomeData = mapOf>(Pair("Top Free Apps", newAppList))
+ val newHomeData = mapOf>(Pair("Top Free Apps", newAppList))
preferenceManagerModule.isGplaySelectedFake = true
formatterMocked.`when` { Formatter.formatFileSize(any(), any()) }.thenReturn("15MB")
Mockito.`when`(gPlayAPIRepository.getHomeScreenData()).thenReturn(newHomeData)
Mockito.`when`(gPlayAPIRepository.getAppDetails(ArgumentMatchers.anyString())).thenReturn(
- App("foundation.e.demothree")
+ Application("foundation.e.demothree")
)
Mockito.`when`(
gPlayAPIRepository.getDownloadInfo(
@@ -148,4 +149,4 @@ class HomeApiTest {
assert(hasLimitedDataFound)
}
-}
\ No newline at end of file
+}
diff --git a/app/src/test/java/foundation/e/apps/installProcessor/AppInstallProcessorTest.kt b/app/src/test/java/foundation/e/apps/installProcessor/AppInstallProcessorTest.kt
index 5d893eb60d086c3632f67da56f35607f86cb6992..28d386f684653e3a890eca986011359a7e28515d 100644
--- a/app/src/test/java/foundation/e/apps/installProcessor/AppInstallProcessorTest.kt
+++ b/app/src/test/java/foundation/e/apps/installProcessor/AppInstallProcessorTest.kt
@@ -21,10 +21,9 @@ package foundation.e.apps.installProcessor
import android.content.Context
import androidx.arch.core.executor.testing.InstantTaskExecutorRule
import com.aurora.gplayapi.data.models.AuthData
-import com.aurora.gplayapi.data.models.ContentRating
import foundation.e.apps.data.ResultSupreme
import foundation.e.apps.data.enums.Status
-import foundation.e.apps.data.fdroid.FdroidRepository
+import foundation.e.apps.data.fdroid.FDroidRepository
import foundation.e.apps.data.application.ApplicationRepository
import foundation.e.apps.data.enums.ResultStatus
import foundation.e.apps.data.install.AppInstallRepository
@@ -47,7 +46,6 @@ import org.junit.Test
import org.mockito.Mock
import org.mockito.Mockito
import org.mockito.MockitoAnnotations
-import kotlin.reflect.jvm.internal.ReflectProperties.Val
@OptIn(ExperimentalCoroutinesApi::class)
class AppInstallProcessorTest {
@@ -69,7 +67,7 @@ class AppInstallProcessorTest {
private lateinit var fakeFusedManager: AppManager
@Mock
- private lateinit var fakeFdroidRepository: FdroidRepository
+ private lateinit var fakeFDroidRepository: FDroidRepository
@Mock
private lateinit var context: Context
@@ -94,7 +92,7 @@ class AppInstallProcessorTest {
fakeFusedDownloadDAO = FakeAppInstallDAO()
appInstallRepository = AppInstallRepository(fakeFusedDownloadDAO)
fakeFusedManagerRepository =
- FakeAppManagerWrapper(fakeFusedDownloadDAO, fakeFusedManager, fakeFdroidRepository)
+ FakeAppManagerWrapper(fakeFusedDownloadDAO, fakeFusedManager, fakeFDroidRepository)
val appInstallComponents =
AppInstallComponents(appInstallRepository, fakeFusedManagerRepository)
diff --git a/app/src/test/java/foundation/e/apps/installProcessor/FakeAppManagerWrapper.kt b/app/src/test/java/foundation/e/apps/installProcessor/FakeAppManagerWrapper.kt
index eb026c5bac6f4d212f7119367ee84c543b075a42..3099e0914e817b807aa5cabda6fe894dbba3bbd6 100644
--- a/app/src/test/java/foundation/e/apps/installProcessor/FakeAppManagerWrapper.kt
+++ b/app/src/test/java/foundation/e/apps/installProcessor/FakeAppManagerWrapper.kt
@@ -19,7 +19,7 @@
package foundation.e.apps.installProcessor
import foundation.e.apps.data.enums.Status
-import foundation.e.apps.data.fdroid.FdroidRepository
+import foundation.e.apps.data.fdroid.FDroidRepository
import foundation.e.apps.data.install.AppManagerWrapper
import foundation.e.apps.data.install.AppManager
import foundation.e.apps.data.install.models.AppInstall
@@ -28,8 +28,8 @@ import kotlinx.coroutines.delay
class FakeAppManagerWrapper(
private val fusedDownloadDAO: FakeAppInstallDAO,
fusedManager: AppManager,
- fdroidRepository: FdroidRepository,
-) : AppManagerWrapper(fusedManager, fdroidRepository) {
+ fDroidRepository: FDroidRepository,
+) : AppManagerWrapper(fusedManager, fDroidRepository) {
var isAppInstalled = false
var installationStatus = Status.INSTALLED
var willDownloadFail = false
diff --git a/lint.xml b/lint.xml
index bfd91922ca850f47cc99a7682bc304a0d11e3c19..9debeab74fa18efb7d0a54b4a130841c3c9d72aa 100644
--- a/lint.xml
+++ b/lint.xml
@@ -34,6 +34,9 @@
+
+
+