2021-04-30 17:20:15 +00:00
|
|
|
package com.lagradost.cloudstream3
|
|
|
|
|
2021-07-17 21:36:50 +00:00
|
|
|
import android.content.ComponentName
|
2021-07-04 00:59:51 +00:00
|
|
|
import android.content.Intent
|
2021-07-19 13:19:47 +00:00
|
|
|
import android.content.res.ColorStateList
|
2021-09-03 09:13:34 +00:00
|
|
|
import android.content.res.Configuration
|
2021-04-30 17:20:15 +00:00
|
|
|
import android.os.Bundle
|
2022-01-07 19:27:25 +00:00
|
|
|
import android.view.KeyEvent
|
2022-03-03 11:26:26 +00:00
|
|
|
import android.view.Menu
|
|
|
|
import android.view.MenuItem
|
2022-01-07 19:27:25 +00:00
|
|
|
import android.view.WindowManager
|
2022-03-03 11:26:26 +00:00
|
|
|
import androidx.annotation.IdRes
|
2021-04-30 17:20:15 +00:00
|
|
|
import androidx.appcompat.app.AppCompatActivity
|
2021-09-20 21:11:36 +00:00
|
|
|
import androidx.core.view.isVisible
|
2022-03-03 11:26:26 +00:00
|
|
|
import androidx.navigation.NavController
|
2021-12-12 02:33:17 +00:00
|
|
|
import androidx.navigation.NavDestination
|
2022-03-03 11:26:26 +00:00
|
|
|
import androidx.navigation.NavDestination.Companion.hierarchy
|
|
|
|
import androidx.navigation.NavGraph.Companion.findStartDestination
|
|
|
|
import androidx.navigation.NavOptions
|
2021-04-30 17:20:15 +00:00
|
|
|
import androidx.navigation.findNavController
|
2021-09-20 21:11:36 +00:00
|
|
|
import androidx.navigation.ui.setupWithNavController
|
2021-08-30 21:42:58 +00:00
|
|
|
import androidx.preference.PreferenceManager
|
2021-09-23 18:08:57 +00:00
|
|
|
import com.google.android.gms.cast.framework.*
|
2021-11-25 22:36:35 +00:00
|
|
|
import com.google.android.material.navigationrail.NavigationRailView
|
2021-08-06 20:55:11 +00:00
|
|
|
import com.jaredrummler.android.colorpicker.ColorPickerDialogListener
|
2022-03-16 15:29:11 +00:00
|
|
|
import com.lagradost.cloudstream3.APIHolder.allProviders
|
2021-07-30 01:14:53 +00:00
|
|
|
import com.lagradost.cloudstream3.APIHolder.apis
|
2021-09-12 14:10:22 +00:00
|
|
|
import com.lagradost.cloudstream3.APIHolder.getApiDubstatusSettings
|
2022-01-07 19:27:25 +00:00
|
|
|
import com.lagradost.cloudstream3.CommonActivity.backEvent
|
|
|
|
import com.lagradost.cloudstream3.CommonActivity.loadThemes
|
|
|
|
import com.lagradost.cloudstream3.CommonActivity.onColorSelectedEvent
|
|
|
|
import com.lagradost.cloudstream3.CommonActivity.onDialogDismissedEvent
|
|
|
|
import com.lagradost.cloudstream3.CommonActivity.onUserLeaveHint
|
|
|
|
import com.lagradost.cloudstream3.CommonActivity.updateLocale
|
2021-09-12 15:57:07 +00:00
|
|
|
import com.lagradost.cloudstream3.mvvm.logError
|
2021-12-05 16:22:30 +00:00
|
|
|
import com.lagradost.cloudstream3.network.Requests
|
2021-07-08 19:39:49 +00:00
|
|
|
import com.lagradost.cloudstream3.receivers.VideoDownloadRestartReceiver
|
2021-11-12 16:55:54 +00:00
|
|
|
import com.lagradost.cloudstream3.syncproviders.OAuth2API.Companion.OAuth2Apis
|
|
|
|
import com.lagradost.cloudstream3.syncproviders.OAuth2API.Companion.OAuth2accountApis
|
|
|
|
import com.lagradost.cloudstream3.syncproviders.OAuth2API.Companion.appString
|
2021-09-12 14:10:22 +00:00
|
|
|
import com.lagradost.cloudstream3.ui.APIRepository
|
2021-07-30 01:14:53 +00:00
|
|
|
import com.lagradost.cloudstream3.ui.download.DOWNLOAD_NAVIGATE_TO
|
2022-01-18 14:10:01 +00:00
|
|
|
import com.lagradost.cloudstream3.ui.result.ResultFragment
|
2022-02-18 19:54:55 +00:00
|
|
|
import com.lagradost.cloudstream3.ui.settings.SettingsFragment.Companion.isEmulatorSettings
|
2021-10-30 18:14:12 +00:00
|
|
|
import com.lagradost.cloudstream3.ui.settings.SettingsFragment.Companion.isTvSettings
|
2021-09-24 22:51:08 +00:00
|
|
|
import com.lagradost.cloudstream3.utils.AppUtils.isCastApiAvailable
|
2022-01-07 19:27:25 +00:00
|
|
|
import com.lagradost.cloudstream3.utils.AppUtils.loadCache
|
2021-07-30 01:14:53 +00:00
|
|
|
import com.lagradost.cloudstream3.utils.AppUtils.loadResult
|
2022-03-16 15:29:11 +00:00
|
|
|
import com.lagradost.cloudstream3.utils.AppUtils.tryParseJson
|
2022-03-04 15:39:56 +00:00
|
|
|
import com.lagradost.cloudstream3.utils.BackupUtils.setUpBackup
|
2022-03-16 15:29:11 +00:00
|
|
|
import com.lagradost.cloudstream3.utils.Coroutines.main
|
2021-07-17 15:56:26 +00:00
|
|
|
import com.lagradost.cloudstream3.utils.DataStore.getKey
|
2021-07-17 21:36:50 +00:00
|
|
|
import com.lagradost.cloudstream3.utils.DataStore.removeKey
|
2022-03-16 15:29:11 +00:00
|
|
|
import com.lagradost.cloudstream3.utils.DataStore.setKey
|
2021-07-17 21:36:50 +00:00
|
|
|
import com.lagradost.cloudstream3.utils.DataStoreHelper.setViewPos
|
2021-08-15 17:38:41 +00:00
|
|
|
import com.lagradost.cloudstream3.utils.InAppUpdater.Companion.runAutoUpdate
|
2022-02-18 19:54:55 +00:00
|
|
|
import com.lagradost.cloudstream3.utils.UIHelper.changeStatusBarState
|
2021-08-24 22:19:15 +00:00
|
|
|
import com.lagradost.cloudstream3.utils.UIHelper.checkWrite
|
2022-02-05 01:05:13 +00:00
|
|
|
import com.lagradost.cloudstream3.utils.UIHelper.colorFromAttribute
|
2021-08-24 22:19:15 +00:00
|
|
|
import com.lagradost.cloudstream3.utils.UIHelper.getResourceColor
|
2021-11-12 16:55:54 +00:00
|
|
|
import com.lagradost.cloudstream3.utils.UIHelper.hideKeyboard
|
2021-09-23 10:50:10 +00:00
|
|
|
import com.lagradost.cloudstream3.utils.UIHelper.navigate
|
2021-08-24 22:19:15 +00:00
|
|
|
import com.lagradost.cloudstream3.utils.UIHelper.requestRW
|
2021-07-30 01:14:53 +00:00
|
|
|
import kotlinx.android.synthetic.main.activity_main.*
|
2022-02-04 20:49:35 +00:00
|
|
|
import kotlinx.android.synthetic.main.fragment_result_swipe.*
|
2022-03-16 15:29:11 +00:00
|
|
|
import kotlinx.coroutines.Dispatchers
|
|
|
|
import kotlinx.coroutines.runBlocking
|
|
|
|
import kotlinx.coroutines.withContext
|
2022-01-07 19:27:25 +00:00
|
|
|
import java.io.File
|
2021-08-15 17:38:41 +00:00
|
|
|
import kotlin.concurrent.thread
|
2021-04-30 17:20:15 +00:00
|
|
|
|
2021-08-24 22:19:15 +00:00
|
|
|
|
2021-07-17 21:36:50 +00:00
|
|
|
const val VLC_PACKAGE = "org.videolan.vlc"
|
|
|
|
const val VLC_INTENT_ACTION_RESULT = "org.videolan.vlc.player.result"
|
|
|
|
val VLC_COMPONENT: ComponentName =
|
|
|
|
ComponentName(VLC_PACKAGE, "org.videolan.vlc.gui.video.VideoPlayerActivity")
|
|
|
|
const val VLC_REQUEST_CODE = 42
|
|
|
|
|
|
|
|
const val VLC_FROM_START = -1
|
|
|
|
const val VLC_FROM_PROGRESS = -2
|
|
|
|
const val VLC_EXTRA_POSITION_OUT = "extra_position"
|
|
|
|
const val VLC_EXTRA_DURATION_OUT = "extra_duration"
|
|
|
|
const val VLC_LAST_ID_KEY = "vlc_last_open_id"
|
2022-01-07 19:27:25 +00:00
|
|
|
|
2021-12-05 16:22:30 +00:00
|
|
|
// Short name for requests client to make it nicer to use
|
|
|
|
var app = Requests()
|
|
|
|
|
2021-06-14 16:58:43 +00:00
|
|
|
|
2021-08-06 20:55:11 +00:00
|
|
|
class MainActivity : AppCompatActivity(), ColorPickerDialogListener {
|
|
|
|
override fun onColorSelected(dialogId: Int, color: Int) {
|
|
|
|
onColorSelectedEvent.invoke(Pair(dialogId, color))
|
|
|
|
}
|
|
|
|
|
|
|
|
override fun onDialogDismissed(dialogId: Int) {
|
|
|
|
onDialogDismissedEvent.invoke(dialogId)
|
|
|
|
}
|
2021-06-10 23:00:22 +00:00
|
|
|
|
2021-09-03 09:13:34 +00:00
|
|
|
override fun onConfigurationChanged(newConfig: Configuration) {
|
|
|
|
super.onConfigurationChanged(newConfig)
|
|
|
|
updateLocale() // android fucks me by chaining lang when rotating the phone
|
2021-12-12 02:33:17 +00:00
|
|
|
findNavController(R.id.nav_host_fragment).currentDestination?.let { updateNavBar(it) }
|
|
|
|
}
|
|
|
|
|
2022-01-07 19:27:25 +00:00
|
|
|
private fun updateNavBar(destination: NavDestination) {
|
2021-12-12 02:33:17 +00:00
|
|
|
this.hideKeyboard()
|
|
|
|
|
|
|
|
// Fucks up anime info layout since that has its own layout
|
|
|
|
cast_mini_controller_holder?.isVisible =
|
|
|
|
!listOf(R.id.navigation_results, R.id.navigation_player).contains(destination.id)
|
|
|
|
|
|
|
|
val isNavVisible = listOf(
|
|
|
|
R.id.navigation_home,
|
|
|
|
R.id.navigation_search,
|
|
|
|
R.id.navigation_downloads,
|
|
|
|
R.id.navigation_settings,
|
|
|
|
R.id.navigation_download_child
|
|
|
|
).contains(destination.id)
|
|
|
|
|
2022-01-07 19:27:25 +00:00
|
|
|
val landscape = when (resources.configuration.orientation) {
|
2021-12-12 02:33:17 +00:00
|
|
|
Configuration.ORIENTATION_LANDSCAPE -> {
|
|
|
|
true
|
|
|
|
}
|
|
|
|
Configuration.ORIENTATION_PORTRAIT -> {
|
|
|
|
false
|
|
|
|
}
|
|
|
|
else -> {
|
|
|
|
false
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
nav_view?.isVisible = isNavVisible && !landscape
|
|
|
|
nav_rail_view?.isVisible = isNavVisible && landscape
|
2021-09-03 09:13:34 +00:00
|
|
|
}
|
|
|
|
|
2021-11-25 22:36:35 +00:00
|
|
|
//private var mCastSession: CastSession? = null
|
2021-09-30 12:16:23 +00:00
|
|
|
lateinit var mSessionManager: SessionManager
|
|
|
|
private val mSessionManagerListener: SessionManagerListener<Session> by lazy { SessionManagerListenerImpl() }
|
2021-09-23 18:08:57 +00:00
|
|
|
|
|
|
|
private inner class SessionManagerListenerImpl : SessionManagerListener<Session> {
|
|
|
|
override fun onSessionStarting(session: Session) {
|
|
|
|
}
|
|
|
|
|
|
|
|
override fun onSessionStarted(session: Session, sessionId: String) {
|
|
|
|
invalidateOptionsMenu()
|
|
|
|
}
|
|
|
|
|
|
|
|
override fun onSessionStartFailed(session: Session, i: Int) {
|
|
|
|
}
|
|
|
|
|
|
|
|
override fun onSessionEnding(session: Session) {
|
|
|
|
}
|
|
|
|
|
|
|
|
override fun onSessionResumed(session: Session, wasSuspended: Boolean) {
|
|
|
|
invalidateOptionsMenu()
|
|
|
|
}
|
|
|
|
|
|
|
|
override fun onSessionResumeFailed(session: Session, i: Int) {
|
|
|
|
}
|
|
|
|
|
|
|
|
override fun onSessionSuspended(session: Session, i: Int) {
|
|
|
|
}
|
|
|
|
|
|
|
|
override fun onSessionEnded(session: Session, error: Int) {
|
|
|
|
}
|
|
|
|
|
|
|
|
override fun onSessionResuming(session: Session, s: String) {
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
override fun onResume() {
|
|
|
|
super.onResume()
|
2021-09-24 22:51:08 +00:00
|
|
|
try {
|
2021-09-30 12:16:23 +00:00
|
|
|
if (isCastApiAvailable()) {
|
2021-11-25 22:36:35 +00:00
|
|
|
//mCastSession = mSessionManager.currentCastSession
|
2021-09-24 22:51:08 +00:00
|
|
|
mSessionManager.addSessionManagerListener(mSessionManagerListener)
|
|
|
|
}
|
2021-09-30 12:16:23 +00:00
|
|
|
} catch (e: Exception) {
|
2021-09-24 22:51:08 +00:00
|
|
|
logError(e)
|
|
|
|
}
|
2021-09-23 18:08:57 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
override fun onPause() {
|
|
|
|
super.onPause()
|
2021-09-24 22:51:08 +00:00
|
|
|
try {
|
2021-09-30 12:16:23 +00:00
|
|
|
if (isCastApiAvailable()) {
|
2021-09-24 22:51:08 +00:00
|
|
|
mSessionManager.removeSessionManagerListener(mSessionManagerListener)
|
2021-11-25 22:36:35 +00:00
|
|
|
//mCastSession = null
|
2021-09-24 22:51:08 +00:00
|
|
|
}
|
2021-09-30 12:16:23 +00:00
|
|
|
} catch (e: Exception) {
|
2021-09-24 22:51:08 +00:00
|
|
|
logError(e)
|
|
|
|
}
|
2021-09-23 18:08:57 +00:00
|
|
|
}
|
|
|
|
|
2021-11-28 12:18:01 +00:00
|
|
|
|
2021-11-26 23:19:17 +00:00
|
|
|
override fun dispatchKeyEvent(event: KeyEvent?): Boolean {
|
2022-01-07 19:27:25 +00:00
|
|
|
CommonActivity.dispatchKeyEvent(this, event)?.let {
|
|
|
|
return it
|
2021-11-27 18:49:51 +00:00
|
|
|
}
|
2021-11-26 23:19:17 +00:00
|
|
|
return super.dispatchKeyEvent(event)
|
|
|
|
}
|
|
|
|
|
2021-10-27 14:54:57 +00:00
|
|
|
override fun onKeyDown(keyCode: Int, event: KeyEvent?): Boolean {
|
2022-01-07 19:27:25 +00:00
|
|
|
CommonActivity.onKeyDown(this, keyCode, event)
|
2021-10-30 18:14:12 +00:00
|
|
|
|
2021-10-27 14:54:57 +00:00
|
|
|
return super.onKeyDown(keyCode, event)
|
|
|
|
}
|
|
|
|
|
2021-05-22 22:25:56 +00:00
|
|
|
|
2021-06-10 23:00:22 +00:00
|
|
|
override fun onUserLeaveHint() {
|
|
|
|
super.onUserLeaveHint()
|
2022-01-07 19:27:25 +00:00
|
|
|
onUserLeaveHint(this)
|
2021-06-10 23:00:22 +00:00
|
|
|
}
|
2021-05-22 22:25:56 +00:00
|
|
|
|
2021-05-18 13:43:32 +00:00
|
|
|
override fun onBackPressed() {
|
2022-02-05 01:05:13 +00:00
|
|
|
this.window?.navigationBarColor =
|
|
|
|
this.colorFromAttribute(R.attr.primaryGrayBackground)
|
2021-09-02 16:51:13 +00:00
|
|
|
this.updateLocale()
|
2021-09-24 22:51:08 +00:00
|
|
|
backEvent.invoke(true)
|
2021-05-18 13:43:32 +00:00
|
|
|
super.onBackPressed()
|
2021-09-03 09:13:34 +00:00
|
|
|
this.updateLocale()
|
2021-05-18 13:43:32 +00:00
|
|
|
}
|
2021-04-30 17:20:15 +00:00
|
|
|
|
2021-07-04 00:59:51 +00:00
|
|
|
override fun onActivityResult(requestCode: Int, resultCode: Int, data: Intent?) {
|
2021-07-17 21:36:50 +00:00
|
|
|
if (VLC_REQUEST_CODE == requestCode) {
|
|
|
|
if (resultCode == RESULT_OK && data != null) {
|
|
|
|
val pos: Long =
|
2022-01-07 19:27:25 +00:00
|
|
|
data.getLongExtra(
|
|
|
|
VLC_EXTRA_POSITION_OUT,
|
|
|
|
-1
|
|
|
|
) //Last position in media when player exited
|
2021-07-17 21:36:50 +00:00
|
|
|
val dur: Long =
|
2022-01-07 19:27:25 +00:00
|
|
|
data.getLongExtra(
|
|
|
|
VLC_EXTRA_DURATION_OUT,
|
|
|
|
-1
|
|
|
|
) //Last position in media when player exited
|
2021-07-17 21:36:50 +00:00
|
|
|
val id = getKey<Int>(VLC_LAST_ID_KEY)
|
2021-07-18 13:02:30 +00:00
|
|
|
println("SET KEY $id at $pos / $dur")
|
2021-07-17 21:36:50 +00:00
|
|
|
if (dur > 0 && pos > 0) {
|
|
|
|
setViewPos(id, pos, dur)
|
|
|
|
}
|
|
|
|
removeKey(VLC_LAST_ID_KEY)
|
2022-01-18 14:10:01 +00:00
|
|
|
ResultFragment.updateUI()
|
2021-07-17 21:36:50 +00:00
|
|
|
}
|
|
|
|
}
|
2021-07-04 00:59:51 +00:00
|
|
|
super.onActivityResult(requestCode, resultCode, data)
|
|
|
|
}
|
|
|
|
|
2021-07-08 17:46:47 +00:00
|
|
|
override fun onDestroy() {
|
|
|
|
val broadcastIntent = Intent()
|
|
|
|
broadcastIntent.action = "restart_service"
|
|
|
|
broadcastIntent.setClass(this, VideoDownloadRestartReceiver::class.java)
|
|
|
|
this.sendBroadcast(broadcastIntent)
|
|
|
|
super.onDestroy()
|
|
|
|
}
|
|
|
|
|
2021-07-30 01:14:53 +00:00
|
|
|
override fun onNewIntent(intent: Intent?) {
|
|
|
|
handleAppIntent(intent)
|
|
|
|
super.onNewIntent(intent)
|
|
|
|
}
|
|
|
|
|
|
|
|
private fun handleAppIntent(intent: Intent?) {
|
|
|
|
if (intent == null) return
|
|
|
|
val str = intent.dataString
|
2022-01-07 19:27:25 +00:00
|
|
|
loadCache()
|
2021-07-30 01:14:53 +00:00
|
|
|
if (str != null) {
|
2021-11-07 22:10:19 +00:00
|
|
|
if (str.contains(appString)) {
|
|
|
|
for (api in OAuth2Apis) {
|
|
|
|
if (str.contains("/${api.redirectUrl}")) {
|
2021-12-16 23:45:20 +00:00
|
|
|
api.handleRedirect(str)
|
2021-11-07 22:10:19 +00:00
|
|
|
}
|
|
|
|
}
|
2021-07-30 01:14:53 +00:00
|
|
|
} else {
|
2021-11-07 22:10:19 +00:00
|
|
|
if (str.startsWith(DOWNLOAD_NAVIGATE_TO)) {
|
|
|
|
this.navigate(R.id.navigation_downloads)
|
|
|
|
} else {
|
|
|
|
for (api in apis) {
|
|
|
|
if (str.startsWith(api.mainUrl)) {
|
|
|
|
loadResult(str, api.name)
|
|
|
|
break
|
|
|
|
}
|
2021-07-30 01:14:53 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-03-03 11:26:26 +00:00
|
|
|
private fun NavDestination.matchDestination(@IdRes destId: Int): Boolean =
|
|
|
|
hierarchy.any { it.id == destId }
|
|
|
|
|
|
|
|
private fun onNavDestinationSelected(item: MenuItem, navController: NavController): Boolean {
|
|
|
|
val builder = NavOptions.Builder().setLaunchSingleTop(true).setRestoreState(true)
|
|
|
|
.setEnterAnim(R.anim.enter_anim)
|
|
|
|
.setExitAnim(R.anim.exit_anim)
|
|
|
|
.setPopEnterAnim(R.anim.pop_enter)
|
|
|
|
.setPopExitAnim(R.anim.pop_exit)
|
|
|
|
if (item.order and Menu.CATEGORY_SECONDARY == 0) {
|
|
|
|
builder.setPopUpTo(
|
|
|
|
navController.graph.findStartDestination().id,
|
|
|
|
inclusive = false,
|
|
|
|
saveState = true
|
|
|
|
)
|
|
|
|
}
|
|
|
|
val options = builder.build()
|
|
|
|
return try {
|
|
|
|
navController.navigate(item.itemId, null, options)
|
|
|
|
navController.currentDestination?.matchDestination(item.itemId) == true
|
|
|
|
} catch (e: IllegalArgumentException) {
|
|
|
|
false
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-04-30 17:20:15 +00:00
|
|
|
override fun onCreate(savedInstanceState: Bundle?) {
|
2021-11-08 18:13:39 +00:00
|
|
|
// init accounts
|
|
|
|
for (api in OAuth2accountApis) {
|
2021-12-16 23:45:20 +00:00
|
|
|
api.init()
|
2021-11-08 18:13:39 +00:00
|
|
|
}
|
2022-03-16 15:29:11 +00:00
|
|
|
|
|
|
|
// must give benenes to get beta providers
|
|
|
|
val hasBenene = try {
|
|
|
|
val settingsManager = PreferenceManager.getDefaultSharedPreferences(this)
|
|
|
|
val count = settingsManager.getInt(getString(R.string.benene_count), 0)
|
|
|
|
count > 30
|
|
|
|
} catch (e: Exception) {
|
|
|
|
e.printStackTrace()
|
|
|
|
false
|
|
|
|
}
|
|
|
|
|
|
|
|
// this pulls the latest data so ppl don't have to update to simply change provider url
|
|
|
|
try {
|
|
|
|
runBlocking {
|
|
|
|
withContext(Dispatchers.IO) {
|
|
|
|
val cacheStr: String? = getKey(PROVIDER_STATUS_KEY)
|
|
|
|
val cache : HashMap<String, ProvidersInfoJson>? = cacheStr?.let { tryParseJson(cacheStr) }
|
|
|
|
if (cache != null) {
|
|
|
|
// if cache is found then spin up a new request, but dont wait
|
|
|
|
main {
|
|
|
|
try {
|
|
|
|
val txt = app.get(PROVIDER_STATUS_URL).text
|
|
|
|
val newCache = tryParseJson<HashMap<String, ProvidersInfoJson>>(txt)
|
|
|
|
setKey(PROVIDER_STATUS_KEY, txt)
|
|
|
|
MainAPI.overrideData = newCache // update all new providers
|
|
|
|
for (api in apis) { // update current providers
|
|
|
|
newCache?.get(api.javaClass.simpleName)?.let { data ->
|
|
|
|
api.overrideWithNewData(data)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
} catch (e : Exception) {
|
|
|
|
logError(e)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
cache
|
|
|
|
} else {
|
|
|
|
// if it is the first time the user has used the app then wait for a request to update all providers
|
|
|
|
val txt = app.get(PROVIDER_STATUS_URL).text
|
|
|
|
setKey(PROVIDER_STATUS_KEY, txt)
|
|
|
|
val newCache = tryParseJson<HashMap<String, ProvidersInfoJson>>(txt)
|
|
|
|
newCache
|
|
|
|
}?.let { providersJsonMap ->
|
|
|
|
MainAPI.overrideData = providersJsonMap
|
|
|
|
val acceptableProviders =
|
|
|
|
providersJsonMap.filter { it.value.status == PROVIDER_STATUS_OK || it.value.status == PROVIDER_STATUS_SLOW }
|
|
|
|
.map { it.key }.toSet()
|
|
|
|
|
|
|
|
val restrictedApis =
|
|
|
|
if (hasBenene) providersJsonMap.filter { it.value.status == PROVIDER_STATUS_BETA_ONLY }
|
|
|
|
.map { it.key }.toSet() else emptySet()
|
|
|
|
|
|
|
|
apis = allProviders.filter { api ->
|
|
|
|
val name = api.javaClass.simpleName
|
|
|
|
acceptableProviders.contains(name) || restrictedApis.contains(name)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
} catch (e: Exception) {
|
|
|
|
apis = allProviders
|
|
|
|
e.printStackTrace()
|
|
|
|
logError(e)
|
|
|
|
}
|
|
|
|
|
2022-01-07 19:27:25 +00:00
|
|
|
loadThemes(this)
|
2021-09-02 16:51:13 +00:00
|
|
|
updateLocale()
|
2021-12-05 16:22:30 +00:00
|
|
|
app.initClient(this)
|
2021-04-30 17:20:15 +00:00
|
|
|
super.onCreate(savedInstanceState)
|
2021-09-24 22:51:08 +00:00
|
|
|
try {
|
2021-09-30 12:16:23 +00:00
|
|
|
if (isCastApiAvailable()) {
|
2021-09-24 22:51:08 +00:00
|
|
|
mSessionManager = CastContext.getSharedInstance(this).sessionManager
|
|
|
|
}
|
2021-09-30 12:16:23 +00:00
|
|
|
} catch (e: Exception) {
|
2021-09-24 22:51:08 +00:00
|
|
|
logError(e)
|
|
|
|
}
|
2021-07-30 01:14:53 +00:00
|
|
|
|
2021-07-28 01:04:32 +00:00
|
|
|
window.setSoftInputMode(WindowManager.LayoutParams.SOFT_INPUT_STATE_ALWAYS_HIDDEN)
|
2021-06-29 23:14:48 +00:00
|
|
|
|
2021-10-30 18:14:12 +00:00
|
|
|
if (isTvSettings()) {
|
|
|
|
setContentView(R.layout.activity_main_tv)
|
|
|
|
} else {
|
|
|
|
setContentView(R.layout.activity_main)
|
|
|
|
}
|
|
|
|
|
2022-02-18 19:54:55 +00:00
|
|
|
changeStatusBarState(isEmulatorSettings())
|
|
|
|
|
2021-07-30 01:14:53 +00:00
|
|
|
// val navView: BottomNavigationView = findViewById(R.id.nav_view)
|
2022-03-04 15:39:56 +00:00
|
|
|
setUpBackup()
|
2022-01-07 19:27:25 +00:00
|
|
|
|
|
|
|
CommonActivity.init(this)
|
2021-06-10 23:00:22 +00:00
|
|
|
|
2021-04-30 17:20:15 +00:00
|
|
|
val navController = findNavController(R.id.nav_host_fragment)
|
2021-07-19 13:19:47 +00:00
|
|
|
|
2021-09-20 21:11:36 +00:00
|
|
|
/*navOptions = NavOptions.Builder()
|
2021-07-19 13:19:47 +00:00
|
|
|
.setLaunchSingleTop(true)
|
|
|
|
.setEnterAnim(R.anim.nav_enter_anim)
|
|
|
|
.setExitAnim(R.anim.nav_exit_anim)
|
|
|
|
.setPopEnterAnim(R.anim.nav_pop_enter)
|
|
|
|
.setPopExitAnim(R.anim.nav_pop_exit)
|
|
|
|
.setPopUpTo(navController.graph.startDestination, false)
|
2021-09-20 21:11:36 +00:00
|
|
|
.build()*/
|
2021-11-25 17:26:14 +00:00
|
|
|
nav_view?.setupWithNavController(navController)
|
2021-11-25 22:36:35 +00:00
|
|
|
val navRail = findViewById<NavigationRailView?>(R.id.nav_rail_view)
|
|
|
|
navRail?.setupWithNavController(navController)
|
2022-03-03 11:26:26 +00:00
|
|
|
|
|
|
|
navRail?.setOnItemSelectedListener { item ->
|
|
|
|
onNavDestinationSelected(
|
|
|
|
item,
|
|
|
|
navController
|
|
|
|
)
|
|
|
|
}
|
|
|
|
nav_view?.setOnItemSelectedListener { item ->
|
|
|
|
onNavDestinationSelected(
|
|
|
|
item,
|
|
|
|
navController
|
|
|
|
)
|
|
|
|
}
|
2021-09-20 21:11:36 +00:00
|
|
|
navController.addOnDestinationChangedListener { _, destination, _ ->
|
2021-12-12 02:33:17 +00:00
|
|
|
updateNavBar(destination)
|
2021-09-20 21:11:36 +00:00
|
|
|
}
|
2022-03-03 11:26:26 +00:00
|
|
|
|
2022-01-07 19:27:25 +00:00
|
|
|
loadCache()
|
2021-07-19 13:19:47 +00:00
|
|
|
|
2021-09-20 21:11:36 +00:00
|
|
|
/*nav_view.setOnNavigationItemSelectedListener { item ->
|
2021-07-19 13:19:47 +00:00
|
|
|
when (item.itemId) {
|
2021-07-28 01:04:32 +00:00
|
|
|
R.id.navigation_home -> {
|
|
|
|
navController.navigate(R.id.navigation_home, null, navOptions)
|
|
|
|
}
|
2021-07-19 13:19:47 +00:00
|
|
|
R.id.navigation_search -> {
|
|
|
|
navController.navigate(R.id.navigation_search, null, navOptions)
|
|
|
|
}
|
|
|
|
R.id.navigation_downloads -> {
|
|
|
|
navController.navigate(R.id.navigation_downloads, null, navOptions)
|
|
|
|
}
|
|
|
|
R.id.navigation_settings -> {
|
|
|
|
navController.navigate(R.id.navigation_settings, null, navOptions)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
true
|
2021-09-20 21:11:36 +00:00
|
|
|
}*/
|
2021-07-19 13:19:47 +00:00
|
|
|
|
2021-11-26 23:19:17 +00:00
|
|
|
val rippleColor = ColorStateList.valueOf(getResourceColor(R.attr.colorPrimary, 0.1f))
|
2021-11-25 17:26:14 +00:00
|
|
|
nav_view?.itemRippleColor = rippleColor
|
2021-11-25 22:36:35 +00:00
|
|
|
navRail?.itemRippleColor = rippleColor
|
2021-05-20 21:25:41 +00:00
|
|
|
|
|
|
|
if (!checkWrite()) {
|
|
|
|
requestRW()
|
|
|
|
if (checkWrite()) return
|
|
|
|
}
|
2021-06-14 00:00:29 +00:00
|
|
|
CastButtonFactory.setUpMediaRouteButton(this, media_route_button)
|
2021-06-14 16:58:43 +00:00
|
|
|
|
2021-07-15 16:45:25 +00:00
|
|
|
// THIS IS CURRENTLY REMOVED BECAUSE HIGHER VERS OF ANDROID NEEDS A NOTIFICATION
|
|
|
|
//if (!VideoDownloadManager.isMyServiceRunning(this, VideoDownloadKeepAliveService::class.java)) {
|
|
|
|
// val mYourService = VideoDownloadKeepAliveService()
|
|
|
|
// val mServiceIntent = Intent(this, mYourService::class.java).putExtra(START_VALUE_KEY, RESTART_ALL_DOWNLOADS_AND_QUEUE)
|
|
|
|
// this.startService(mServiceIntent)
|
|
|
|
//}
|
2021-07-17 15:56:26 +00:00
|
|
|
//settingsManager.getBoolean("disable_automatic_data_downloads", true) &&
|
2021-07-25 14:25:09 +00:00
|
|
|
|
|
|
|
// TODO RETURN TO TRUE
|
|
|
|
/*
|
2021-07-17 21:36:50 +00:00
|
|
|
if (isUsingMobileData()) {
|
2021-07-17 15:56:26 +00:00
|
|
|
Toast.makeText(this, "Downloads not resumed on mobile data", Toast.LENGTH_LONG).show()
|
|
|
|
} else {
|
|
|
|
val keys = getKeys(VideoDownloadManager.KEY_RESUME_PACKAGES)
|
|
|
|
val resumePkg = keys.mapNotNull { k -> getKey<VideoDownloadManager.DownloadResumePackage>(k) }
|
|
|
|
|
|
|
|
// To remove a bug where this is permanent
|
|
|
|
removeKeys(VideoDownloadManager.KEY_RESUME_PACKAGES)
|
|
|
|
|
|
|
|
for (pkg in resumePkg) { // ADD ALL CURRENT DOWNLOADS
|
|
|
|
VideoDownloadManager.downloadFromResume(this, pkg, false)
|
|
|
|
}
|
2021-07-08 17:46:47 +00:00
|
|
|
|
2021-07-17 15:56:26 +00:00
|
|
|
// ADD QUEUE
|
|
|
|
// array needed because List gets cast exception to linkedList for some unknown reason
|
|
|
|
val resumeQueue =
|
|
|
|
getKey<Array<VideoDownloadManager.DownloadQueueResumePackage>>(VideoDownloadManager.KEY_RESUME_QUEUE_PACKAGES)
|
|
|
|
|
|
|
|
resumeQueue?.sortedBy { it.index }?.forEach {
|
|
|
|
VideoDownloadManager.downloadFromResume(this, it.pkg)
|
|
|
|
}
|
2021-07-25 14:25:09 +00:00
|
|
|
}*/
|
|
|
|
|
|
|
|
|
2021-06-14 00:00:29 +00:00
|
|
|
/*
|
|
|
|
val castContext = CastContext.getSharedInstance(applicationContext)
|
|
|
|
fun buildMediaQueueItem(video: String): MediaQueueItem {
|
|
|
|
// val movieMetadata = MediaMetadata(MediaMetadata.MEDIA_TYPE_PHOTO)
|
|
|
|
//movieMetadata.putString(MediaMetadata.KEY_TITLE, "CloudStream")
|
|
|
|
val mediaInfo = MediaInfo.Builder(Uri.parse(video).toString())
|
|
|
|
.setStreamType(MediaInfo.STREAM_TYPE_NONE)
|
|
|
|
.setContentType(MimeTypes.IMAGE_JPEG)
|
|
|
|
// .setMetadata(movieMetadata).build()
|
|
|
|
.build()
|
|
|
|
return MediaQueueItem.Builder(mediaInfo).build()
|
|
|
|
}*/
|
|
|
|
/*
|
|
|
|
castContext.addCastStateListener { state ->
|
|
|
|
if (state == CastState.CONNECTED) {
|
|
|
|
println("TESTING")
|
|
|
|
val isCasting = castContext?.sessionManager?.currentCastSession?.remoteMediaClient?.currentItem != null
|
|
|
|
if(!isCasting) {
|
|
|
|
val castPlayer = CastPlayer(castContext)
|
|
|
|
println("LOAD ITEM")
|
|
|
|
|
|
|
|
castPlayer.loadItem(buildMediaQueueItem("https://cdn.discordapp.com/attachments/551382684560261121/730169809408622702/ChromecastLogo6.png"),0)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}*/
|
2021-07-31 22:11:56 +00:00
|
|
|
/*thread {
|
|
|
|
createISO()
|
|
|
|
}*/
|
2021-08-19 20:05:18 +00:00
|
|
|
|
2021-09-30 12:16:23 +00:00
|
|
|
var providersAndroidManifestString = "Current androidmanifest should be:\n"
|
2022-03-16 15:29:11 +00:00
|
|
|
for (api in allProviders) {
|
2021-09-30 12:16:23 +00:00
|
|
|
providersAndroidManifestString += "<data android:scheme=\"https\" android:host=\"${
|
|
|
|
api.mainUrl.removePrefix(
|
|
|
|
"https://"
|
|
|
|
)
|
|
|
|
}\" android:pathPrefix=\"/\"/>\n"
|
2021-08-19 20:05:18 +00:00
|
|
|
}
|
2021-09-30 12:16:23 +00:00
|
|
|
|
|
|
|
println(providersAndroidManifestString)
|
|
|
|
|
2021-07-30 01:14:53 +00:00
|
|
|
handleAppIntent(intent)
|
2021-08-15 17:38:41 +00:00
|
|
|
|
|
|
|
thread {
|
|
|
|
runAutoUpdate()
|
|
|
|
}
|
2021-08-30 21:42:58 +00:00
|
|
|
|
2021-09-12 14:10:22 +00:00
|
|
|
APIRepository.dubStatusActive = getApiDubstatusSettings()
|
|
|
|
|
2022-01-07 19:27:25 +00:00
|
|
|
try {
|
|
|
|
// this ensures that no unnecessary space is taken
|
|
|
|
loadCache()
|
|
|
|
File(filesDir, "exoplayer").deleteRecursively() // old cache
|
|
|
|
File(cacheDir, "exoplayer").deleteOnExit() // current cache
|
|
|
|
} catch (e: Exception) {
|
|
|
|
logError(e)
|
|
|
|
}
|
2022-03-16 15:29:11 +00:00
|
|
|
println("Loaded everything")
|
2021-09-07 19:16:12 +00:00
|
|
|
/*
|
|
|
|
val relativePath = (Environment.DIRECTORY_DOWNLOADS) + File.separatorChar
|
|
|
|
val displayName = "output.dex" //""output.dex"
|
|
|
|
val file = getExternalFilesDir(null)?.absolutePath + File.separatorChar + displayName//"${Environment.getExternalStorageDirectory()}${File.separatorChar}$relativePath$displayName"
|
|
|
|
println(file)
|
|
|
|
|
|
|
|
val realFile = File(file)
|
|
|
|
println("REAALFILE: ${realFile.exists()} at ${realFile.length()}" )
|
|
|
|
val src = ExtensionManager.getSourceFromDex(this, "com.example.testdex2.TestClassToDex", File(file))
|
|
|
|
val output = src?.doMath()
|
|
|
|
println("MASTER OUTPUT = $output")*/
|
2021-04-30 17:20:15 +00:00
|
|
|
}
|
|
|
|
}
|