aboutsummaryrefslogtreecommitdiff
path: root/app/src/main/java/moe/yuuta/workmode/Setup.kt
blob: 0553ea61b293fcfd9dfd4c1e405e68f52f7652f8 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
package moe.yuuta.workmode

import android.content.Context
import android.content.Intent
import android.os.Bundle
import androidx.core.content.FileProvider
import com.crashlytics.android.Crashlytics
import com.crashlytics.android.answers.Answers
import com.elvishew.xlog.LogConfiguration
import com.elvishew.xlog.LogUtils
import com.elvishew.xlog.XLog
import com.elvishew.xlog.interceptor.BlacklistTagsFilterInterceptor
import com.elvishew.xlog.printer.AndroidPrinter
import com.elvishew.xlog.printer.file.FilePrinter
import com.elvishew.xlog.printer.file.clean.FileLastModifiedCleanStrategy
import io.fabric.sdk.android.Fabric
import moe.yuuta.workmode.utils.Utils
import java.io.File
import java.text.SimpleDateFormat
import java.util.*

object Setup {
    val FABRIC_ENABLE = !BuildConfig.DEBUG && BuildConfig.FABRIC_KEY != "disabled"

    fun getLogsPath(context: Context): File =
            File(context.applicationContext.dataDir.absolutePath + "/logs")

    fun initLogs(logsPath: String) {
        val config = LogConfiguration.Builder()
                .tag("WorkMode")
                .addInterceptor(BlacklistTagsFilterInterceptor("FCore"))
                .addObjectFormatter(Bundle::class.java) {
                    return@addObjectFormatter Utils.dumpExtras(it)
                }
                .build()

        val androidPrinter = AndroidPrinter()
        val filePrinter = FilePrinter
                .Builder(logsPath)
                .cleanStrategy(FileLastModifiedCleanStrategy(1000 * 60 * 60 * 24 * 5))
                .build()

        XLog.init(config, androidPrinter, filePrinter)
    }

    internal fun buildShareLogsIntent(context: Context): Intent {
        val zipFile = File("${context.externalCacheDir.absolutePath}/logs/logs-" +
                "${SimpleDateFormat("yyyy-mm-dd-H-m-s", Locale.US).format(Date())}.zip")
        LogUtils.compress(Setup.getLogsPath(context).absolutePath,
                zipFile.absolutePath)
        val fileUri = FileProvider.getUriForFile(
                context,
                BuildConfig.APPLICATION_ID + ".fileprovider",
                zipFile)
        if (fileUri == null || !zipFile.exists()) {
            throw NullPointerException()
        }
        val intent = Intent()
        intent.action = Intent.ACTION_SEND
        intent.addFlags(Intent.FLAG_GRANT_READ_URI_PERMISSION)
        var type = context.contentResolver.getType(fileUri)
        if (type == null || type.trim().equals("")) {
            type = "application/zip"
        }
        intent.type = type
        intent.putExtra(Intent.EXTRA_STREAM, fileUri)
        return intent
    }

    internal fun initFabric(context: Context) {
        if (FABRIC_ENABLE) {
            Fabric.with(Fabric.Builder(context)
                    .kits(Crashlytics(), Answers())
                    .build())
        }
    }
}