Check if the connected network is metered in NetworkHelper.

This commit is contained in:
Isira Seneviratne 2023-01-21 17:44:06 +05:30
parent aaebdc200d
commit 0d5a56da1c
3 changed files with 14 additions and 38 deletions

View File

@ -9,7 +9,7 @@ object DataSaverMode {
return when (pref) {
"enabled" -> true
"disabled" -> false
"metered" -> NetworkHelper.isNetworkMobile(context)
"metered" -> NetworkHelper.isNetworkMetered(context)
else -> throw IllegalArgumentException()
}
}

View File

@ -2,16 +2,14 @@ package com.github.libretube.util
import android.content.Context
import android.net.ConnectivityManager
import android.net.NetworkCapabilities
import android.os.Build
import androidx.core.content.getSystemService
object NetworkHelper {
/**
* Detect whether network is available
*/
fun isNetworkAvailable(context: Context): Boolean {
val connectivityManager =
context.getSystemService(Context.CONNECTIVITY_SERVICE) as ConnectivityManager
val connectivityManager = context.getSystemService<ConnectivityManager>()
// this seems to not recognize vpn connections
/*
@ -37,27 +35,15 @@ object NetworkHelper {
*/
@Suppress("DEPRECATION")
return connectivityManager.activeNetworkInfo?.isConnected ?: false
return connectivityManager?.activeNetworkInfo?.isConnected ?: false
}
/**
* Detect whether the current network is mobile data
* Detect whether the current network is metered
* @param context Context of the application
* @return isNetworkMobile
* @return whether the network is metered or not
*/
@Suppress("DEPRECATION")
fun isNetworkMobile(context: Context): Boolean {
val connectivityManager =
context.getSystemService(Context.CONNECTIVITY_SERVICE) as ConnectivityManager
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.M) {
val networkCapabilities = connectivityManager.getNetworkCapabilities(
connectivityManager.activeNetwork ?: return false
)
return networkCapabilities?.hasTransport(NetworkCapabilities.TRANSPORT_CELLULAR)
?: false
} else {
val activeNetwork = connectivityManager.getNetworkInfo(ConnectivityManager.TYPE_MOBILE)
return activeNetwork != null && activeNetwork.isConnected
}
fun isNetworkMetered(context: Context): Boolean {
return context.getSystemService<ConnectivityManager>()!!.isActiveNetworkMetered
}
}

View File

@ -33,14 +33,9 @@ object PlayerHelper {
/**
* Get the audio source following the users preferences
*/
fun getAudioSource(
context: Context,
audios: List<PipedStream>
): String {
fun getAudioSource(context: Context, audios: List<PipedStream>): String {
val audioFormat = PreferenceHelper.getString(PreferenceKeys.PLAYER_AUDIO_FORMAT, "all")
val audioPrefKey = if (
NetworkHelper.isNetworkMobile(context)
) {
val audioPrefKey = if (NetworkHelper.isNetworkMetered(context)) {
PreferenceKeys.PLAYER_AUDIO_QUALITY_MOBILE
} else {
PreferenceKeys.PLAYER_AUDIO_QUALITY
@ -351,17 +346,12 @@ object PlayerHelper {
)
fun getDefaultResolution(context: Context): String {
return if (NetworkHelper.isNetworkMobile(context)) {
PreferenceHelper.getString(
PreferenceKeys.DEFAULT_RESOLUTION_MOBILE,
""
)
val prefKey = if (NetworkHelper.isNetworkMetered(context)) {
PreferenceKeys.DEFAULT_RESOLUTION_MOBILE
} else {
PreferenceHelper.getString(
PreferenceKeys.DEFAULT_RESOLUTION,
""
)
PreferenceKeys.DEFAULT_RESOLUTION
}
return PreferenceHelper.getString(prefKey, "")
}
fun getIntentActon(context: Context): String {