2021-07-26 18:29:04 +00:00
|
|
|
package com.lagradost.cloudstream3
|
|
|
|
|
|
|
|
import android.app.Application
|
|
|
|
import android.content.Context
|
2021-07-30 01:14:53 +00:00
|
|
|
import android.widget.Toast
|
2021-07-26 18:29:04 +00:00
|
|
|
import com.google.auto.service.AutoService
|
2021-07-30 01:14:53 +00:00
|
|
|
import com.lagradost.cloudstream3.mvvm.normalSafeApiCall
|
2022-01-29 21:25:12 +00:00
|
|
|
import com.lagradost.cloudstream3.mvvm.suspendSafeApiCall
|
2021-12-16 23:45:20 +00:00
|
|
|
import com.lagradost.cloudstream3.utils.AppUtils.openBrowser
|
2021-07-30 01:14:53 +00:00
|
|
|
import com.lagradost.cloudstream3.utils.Coroutines.runOnMainThread
|
2021-12-16 23:45:20 +00:00
|
|
|
import com.lagradost.cloudstream3.utils.DataStore.getKey
|
|
|
|
import com.lagradost.cloudstream3.utils.DataStore.getKeys
|
|
|
|
import com.lagradost.cloudstream3.utils.DataStore.removeKey
|
|
|
|
import com.lagradost.cloudstream3.utils.DataStore.removeKeys
|
|
|
|
import com.lagradost.cloudstream3.utils.DataStore.setKey
|
2022-01-29 21:25:12 +00:00
|
|
|
import kotlinx.coroutines.runBlocking
|
2021-07-26 18:29:04 +00:00
|
|
|
import org.acra.ReportField
|
|
|
|
import org.acra.config.CoreConfiguration
|
|
|
|
import org.acra.data.CrashReportData
|
|
|
|
import org.acra.data.StringFormat
|
|
|
|
import org.acra.ktx.initAcra
|
|
|
|
import org.acra.sender.ReportSender
|
|
|
|
import org.acra.sender.ReportSenderFactory
|
2021-10-04 17:54:15 +00:00
|
|
|
import java.lang.ref.WeakReference
|
2021-07-26 18:29:04 +00:00
|
|
|
import kotlin.concurrent.thread
|
|
|
|
|
|
|
|
class CustomReportSender : ReportSender {
|
|
|
|
// Sends all your crashes to google forms
|
|
|
|
override fun send(context: Context, errorContent: CrashReportData) {
|
2021-07-30 01:14:53 +00:00
|
|
|
println("Sending report")
|
|
|
|
val url =
|
|
|
|
"https://docs.google.com/forms/u/0/d/e/1FAIpQLSeFmyBChi6HF3IkhTVWPiDXJtxt8W0Hf4Agljm_0-0_QuEYFg/formResponse"
|
|
|
|
val data = mapOf(
|
|
|
|
"entry.134906550" to errorContent.toJSON()
|
|
|
|
)
|
|
|
|
|
|
|
|
thread { // to not run it on main thread
|
2022-01-29 21:25:12 +00:00
|
|
|
runBlocking {
|
|
|
|
suspendSafeApiCall {
|
|
|
|
val post = app.post(url, data = data)
|
|
|
|
println("Report response: $post")
|
|
|
|
}
|
2021-07-26 18:29:04 +00:00
|
|
|
}
|
2021-07-30 01:14:53 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
runOnMainThread { // to run it on main looper
|
|
|
|
normalSafeApiCall {
|
|
|
|
Toast.makeText(context, R.string.acra_report_toast, Toast.LENGTH_SHORT).show()
|
|
|
|
}
|
2021-07-26 18:29:04 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
@AutoService(ReportSenderFactory::class)
|
|
|
|
class CustomSenderFactory : ReportSenderFactory {
|
|
|
|
override fun create(context: Context, config: CoreConfiguration): ReportSender {
|
|
|
|
return CustomReportSender()
|
|
|
|
}
|
|
|
|
|
|
|
|
override fun enabled(config: CoreConfiguration): Boolean {
|
|
|
|
return true
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
class AcraApplication : Application() {
|
|
|
|
override fun attachBaseContext(base: Context?) {
|
|
|
|
super.attachBaseContext(base)
|
2021-10-04 17:54:15 +00:00
|
|
|
context = base
|
2021-07-26 18:29:04 +00:00
|
|
|
|
|
|
|
initAcra {
|
|
|
|
//core configuration:
|
|
|
|
buildConfigClass = BuildConfig::class.java
|
|
|
|
reportFormat = StringFormat.JSON
|
|
|
|
|
|
|
|
reportContent = arrayOf(
|
|
|
|
ReportField.BUILD_CONFIG, ReportField.USER_CRASH_DATE,
|
|
|
|
ReportField.ANDROID_VERSION, ReportField.PHONE_MODEL,
|
|
|
|
ReportField.STACK_TRACE
|
|
|
|
)
|
|
|
|
|
2021-07-30 01:14:53 +00:00
|
|
|
// removed this due to bug when starting the app, moved it to when it actually crashes
|
2021-07-26 18:29:04 +00:00
|
|
|
//each plugin you chose above can be configured in a block like this:
|
2021-07-30 01:14:53 +00:00
|
|
|
/*toast {
|
2021-07-26 18:29:04 +00:00
|
|
|
text = getString(R.string.acra_report_toast)
|
|
|
|
//opening this block automatically enables the plugin.
|
2021-07-30 01:14:53 +00:00
|
|
|
}*/
|
2021-07-26 18:29:04 +00:00
|
|
|
}
|
|
|
|
}
|
2021-10-04 17:54:15 +00:00
|
|
|
|
|
|
|
companion object {
|
|
|
|
private var _context: WeakReference<Context>? = null
|
|
|
|
var context
|
|
|
|
get() = _context?.get()
|
|
|
|
private set(value) {
|
|
|
|
_context = WeakReference(value)
|
|
|
|
}
|
2021-12-16 23:45:20 +00:00
|
|
|
|
|
|
|
fun removeKeys(folder: String): Int? {
|
|
|
|
return context?.removeKeys(folder)
|
|
|
|
}
|
|
|
|
|
|
|
|
fun <T> setKey(path: String, value: T) {
|
|
|
|
context?.setKey(path, value)
|
|
|
|
}
|
|
|
|
|
|
|
|
fun <T> setKey(folder: String, path: String, value: T) {
|
|
|
|
context?.setKey(folder, path, value)
|
|
|
|
}
|
|
|
|
|
|
|
|
inline fun <reified T : Any> getKey(path: String, defVal: T?): T? {
|
|
|
|
return context?.getKey(path, defVal)
|
|
|
|
}
|
|
|
|
|
|
|
|
inline fun <reified T : Any> getKey(path: String): T? {
|
|
|
|
return context?.getKey(path)
|
|
|
|
}
|
|
|
|
|
|
|
|
inline fun <reified T : Any> getKey(folder: String, path: String): T? {
|
|
|
|
return context?.getKey(folder, path)
|
|
|
|
}
|
|
|
|
|
|
|
|
inline fun <reified T : Any> getKey(folder: String, path: String, defVal: T?): T? {
|
|
|
|
return context?.getKey(folder, path, defVal)
|
|
|
|
}
|
|
|
|
|
|
|
|
fun getKeys(folder: String): List<String>? {
|
|
|
|
return context?.getKeys(folder)
|
|
|
|
}
|
|
|
|
|
|
|
|
fun removeKey(folder: String, path: String) {
|
|
|
|
context?.removeKey(folder, path)
|
|
|
|
}
|
|
|
|
|
|
|
|
fun removeKey(path: String) {
|
|
|
|
context?.removeKey(path)
|
|
|
|
}
|
|
|
|
|
|
|
|
fun openBrowser(url: String) {
|
|
|
|
context?.openBrowser(url)
|
|
|
|
}
|
2021-10-04 17:54:15 +00:00
|
|
|
}
|
2021-07-26 18:29:04 +00:00
|
|
|
}
|