OrionUiSdkCrashHandler.smali
.class public Lcom/sdk/orion/ui/baselibrary/utils/OrionUiSdkCrashHandler;
.super Ljava/lang/Object;
# interfaces
.implements Ljava/lang/Thread$UncaughtExceptionHandler;
# static fields
.field public static final CRASH_FILE_PATH:Ljava/lang/String;
.field private static INSTANCE:Lcom/sdk/orion/ui/baselibrary/utils/OrionUiSdkCrashHandler; = null
.field public static final TAG:Ljava/lang/String; = "OrionUiSdkCrashHandler"
# instance fields
.field private formatter:Ljava/text/SimpleDateFormat;
.field private infos:Ljava/util/Map;
.annotation system Ldalvik/annotation/Signature;
value = {
"Ljava/util/Map",
"<",
"Ljava/lang/String;",
"Ljava/lang/String;",
">;"
}
.end annotation
.end field
.field private mContext:Landroid/content/Context;
.field private mDefaultHandler:Ljava/lang/Thread$UncaughtExceptionHandler;
# direct methods
.method static constructor <clinit>()V
.registers 2
new-instance v0, Ljava/lang/StringBuilder;
invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V
sget-object v1, Lcom/sdk/orion/ui/baselibrary/config/OrionConstant;->BASE_PATH:Ljava/lang/String;
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v0
const-string/jumbo v1, "temp/crashlog/"
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v0
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
sput-object v0, Lcom/sdk/orion/ui/baselibrary/utils/OrionUiSdkCrashHandler;->CRASH_FILE_PATH:Ljava/lang/String;
new-instance v0, Lcom/sdk/orion/ui/baselibrary/utils/OrionUiSdkCrashHandler;
invoke-direct {v0}, Lcom/sdk/orion/ui/baselibrary/utils/OrionUiSdkCrashHandler;-><init>()V
sput-object v0, Lcom/sdk/orion/ui/baselibrary/utils/OrionUiSdkCrashHandler;->INSTANCE:Lcom/sdk/orion/ui/baselibrary/utils/OrionUiSdkCrashHandler;
return-void
.end method
.method private constructor <init>()V
.registers 4
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
new-instance v0, Ljava/util/HashMap;
invoke-direct {v0}, Ljava/util/HashMap;-><init>()V
iput-object v0, p0, Lcom/sdk/orion/ui/baselibrary/utils/OrionUiSdkCrashHandler;->infos:Ljava/util/Map;
new-instance v0, Ljava/text/SimpleDateFormat;
const-string/jumbo v1, "yyyy-MM-dd-HH-mm-ss"
invoke-static {}, Ljava/util/Locale;->getDefault()Ljava/util/Locale;
move-result-object v2
invoke-direct {v0, v1, v2}, Ljava/text/SimpleDateFormat;-><init>(Ljava/lang/String;Ljava/util/Locale;)V
iput-object v0, p0, Lcom/sdk/orion/ui/baselibrary/utils/OrionUiSdkCrashHandler;->formatter:Ljava/text/SimpleDateFormat;
return-void
.end method
.method private collectDeviceInfo(Landroid/content/Context;)V
.registers 9
:try_start_0
invoke-virtual {p1}, Landroid/content/Context;->getPackageManager()Landroid/content/pm/PackageManager;
move-result-object v0
invoke-virtual {p1}, Landroid/content/Context;->getPackageName()Ljava/lang/String;
move-result-object v1
const/4 v2, 0x1
invoke-virtual {v0, v1, v2}, Landroid/content/pm/PackageManager;->getPackageInfo(Ljava/lang/String;I)Landroid/content/pm/PackageInfo;
move-result-object v1
if-eqz v1, :cond_3c
iget-object v0, v1, Landroid/content/pm/PackageInfo;->versionName:Ljava/lang/String;
if-nez v0, :cond_63
const-string/jumbo v0, "null"
:goto_16
new-instance v2, Ljava/lang/StringBuilder;
invoke-direct {v2}, Ljava/lang/StringBuilder;-><init>()V
iget v1, v1, Landroid/content/pm/PackageInfo;->versionCode:I
invoke-virtual {v2, v1}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
move-result-object v1
const-string/jumbo v2, ""
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v1
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v1
iget-object v2, p0, Lcom/sdk/orion/ui/baselibrary/utils/OrionUiSdkCrashHandler;->infos:Ljava/util/Map;
const-string/jumbo v3, "versionName"
invoke-interface {v2, v3, v0}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
iget-object v0, p0, Lcom/sdk/orion/ui/baselibrary/utils/OrionUiSdkCrashHandler;->infos:Ljava/util/Map;
const-string/jumbo v2, "versionCode"
invoke-interface {v0, v2, v1}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
:try_end_3c
.catch Landroid/content/pm/PackageManager$NameNotFoundException; {:try_start_0 .. :try_end_3c} :catch_66
:cond_3c
:goto_3c
const-class v0, Landroid/os/Build;
invoke-virtual {v0}, Ljava/lang/Class;->getDeclaredFields()[Ljava/lang/reflect/Field;
move-result-object v2
array-length v3, v2
const/4 v0, 0x0
move v1, v0
:goto_45
if-ge v1, v3, :cond_7c
aget-object v0, v2, v1
const/4 v4, 0x1
:try_start_4a
invoke-virtual {v0, v4}, Ljava/lang/reflect/Field;->setAccessible(Z)V
iget-object v4, p0, Lcom/sdk/orion/ui/baselibrary/utils/OrionUiSdkCrashHandler;->infos:Ljava/util/Map;
invoke-virtual {v0}, Ljava/lang/reflect/Field;->getName()Ljava/lang/String;
move-result-object v5
const/4 v6, 0x0
invoke-virtual {v0, v6}, Ljava/lang/reflect/Field;->get(Ljava/lang/Object;)Ljava/lang/Object;
move-result-object v0
invoke-virtual {v0}, Ljava/lang/Object;->toString()Ljava/lang/String;
move-result-object v0
invoke-interface {v4, v5, v0}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
:try_end_5f
.catch Ljava/lang/Exception; {:try_start_4a .. :try_end_5f} :catch_71
:goto_5f
add-int/lit8 v0, v1, 0x1
move v1, v0
goto :goto_45
:cond_63
:try_start_63
iget-object v0, v1, Landroid/content/pm/PackageInfo;->versionName:Ljava/lang/String;
:try_end_65
.catch Landroid/content/pm/PackageManager$NameNotFoundException; {:try_start_63 .. :try_end_65} :catch_66
goto :goto_16
:catch_66
move-exception v0
const-string/jumbo v1, "OrionUiSdkCrashHandler"
const-string/jumbo v2, "an error occured when collect package info"
invoke-static {v1, v2, v0}, Landroid/util/Log;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)I
goto :goto_3c
:catch_71
move-exception v0
const-string/jumbo v4, "OrionUiSdkCrashHandler"
const-string/jumbo v5, "an error occured when collect crash info"
invoke-static {v4, v5, v0}, Landroid/util/Log;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)I
goto :goto_5f
:cond_7c
return-void
.end method
.method public static getInstance()Lcom/sdk/orion/ui/baselibrary/utils/OrionUiSdkCrashHandler;
.registers 1
sget-object v0, Lcom/sdk/orion/ui/baselibrary/utils/OrionUiSdkCrashHandler;->INSTANCE:Lcom/sdk/orion/ui/baselibrary/utils/OrionUiSdkCrashHandler;
return-object v0
.end method
.method private handleException(Ljava/lang/Throwable;)V
.registers 3
if-nez p1, :cond_3
:goto_2
return-void
:cond_3
:try_start_3
iget-object v0, p0, Lcom/sdk/orion/ui/baselibrary/utils/OrionUiSdkCrashHandler;->mContext:Landroid/content/Context;
invoke-direct {p0, v0}, Lcom/sdk/orion/ui/baselibrary/utils/OrionUiSdkCrashHandler;->collectDeviceInfo(Landroid/content/Context;)V
invoke-direct {p0, p1}, Lcom/sdk/orion/ui/baselibrary/utils/OrionUiSdkCrashHandler;->saveCrashInfo2File(Ljava/lang/Throwable;)I
:try_end_b
.catch Ljava/lang/Exception; {:try_start_3 .. :try_end_b} :catch_c
goto :goto_2
:catch_c
move-exception v0
invoke-virtual {v0}, Ljava/lang/Exception;->printStackTrace()V
goto :goto_2
.end method
.method private saveCrashInfo2File(Ljava/lang/Throwable;)I
.registers 8
new-instance v2, Ljava/lang/StringBuffer;
invoke-direct {v2}, Ljava/lang/StringBuffer;-><init>()V
iget-object v0, p0, Lcom/sdk/orion/ui/baselibrary/utils/OrionUiSdkCrashHandler;->infos:Ljava/util/Map;
invoke-interface {v0}, Ljava/util/Map;->entrySet()Ljava/util/Set;
move-result-object v0
invoke-interface {v0}, Ljava/util/Set;->iterator()Ljava/util/Iterator;
move-result-object v3
:goto_f
invoke-interface {v3}, Ljava/util/Iterator;->hasNext()Z
move-result v0
if-eqz v0, :cond_4a
invoke-interface {v3}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v0
check-cast v0, Ljava/util/Map$Entry;
invoke-interface {v0}, Ljava/util/Map$Entry;->getKey()Ljava/lang/Object;
move-result-object v1
check-cast v1, Ljava/lang/String;
invoke-interface {v0}, Ljava/util/Map$Entry;->getValue()Ljava/lang/Object;
move-result-object v0
check-cast v0, Ljava/lang/String;
new-instance v4, Ljava/lang/StringBuilder;
invoke-direct {v4}, Ljava/lang/StringBuilder;-><init>()V
invoke-virtual {v4, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v1
const-string/jumbo v4, "="
invoke-virtual {v1, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v1
invoke-virtual {v1, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v0
const-string/jumbo v1, "\n"
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v0
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
invoke-virtual {v2, v0}, Ljava/lang/StringBuffer;->append(Ljava/lang/String;)Ljava/lang/StringBuffer;
goto :goto_f
:cond_4a
new-instance v1, Ljava/io/StringWriter;
invoke-direct {v1}, Ljava/io/StringWriter;-><init>()V
new-instance v3, Ljava/io/PrintWriter;
invoke-direct {v3, v1}, Ljava/io/PrintWriter;-><init>(Ljava/io/Writer;)V
invoke-virtual {p1, v3}, Ljava/lang/Throwable;->printStackTrace(Ljava/io/PrintWriter;)V
invoke-virtual {p1}, Ljava/lang/Throwable;->getCause()Ljava/lang/Throwable;
move-result-object v0
:goto_5b
if-eqz v0, :cond_65
invoke-virtual {v0, v3}, Ljava/lang/Throwable;->printStackTrace(Ljava/io/PrintWriter;)V
invoke-virtual {v0}, Ljava/lang/Throwable;->getCause()Ljava/lang/Throwable;
move-result-object v0
goto :goto_5b
:cond_65
invoke-virtual {v3}, Ljava/io/PrintWriter;->close()V
invoke-virtual {v1}, Ljava/lang/Object;->toString()Ljava/lang/String;
move-result-object v0
const-string/jumbo v1, "com.sdk.orion.ui"
invoke-virtual {v0, v1}, Ljava/lang/String;->contains(Ljava/lang/CharSequence;)Z
move-result v1
if-nez v1, :cond_77
const/4 v0, 0x0
:goto_76
return v0
:cond_77
invoke-virtual {v2, v0}, Ljava/lang/StringBuffer;->append(Ljava/lang/String;)Ljava/lang/StringBuffer;
invoke-virtual {v2}, Ljava/lang/StringBuffer;->toString()Ljava/lang/String;
move-result-object v0
invoke-static {v0}, Lcom/sdk/orion/ui/baselibrary/infoc/CrashLogReport;->report(Ljava/lang/String;)V
invoke-static {}, Ljava/lang/System;->currentTimeMillis()J
move-result-wide v0
iget-object v3, p0, Lcom/sdk/orion/ui/baselibrary/utils/OrionUiSdkCrashHandler;->formatter:Ljava/text/SimpleDateFormat;
new-instance v4, Ljava/util/Date;
invoke-direct {v4}, Ljava/util/Date;-><init>()V
invoke-virtual {v3, v4}, Ljava/text/SimpleDateFormat;->format(Ljava/util/Date;)Ljava/lang/String;
move-result-object v3
new-instance v4, Ljava/lang/StringBuilder;
invoke-direct {v4}, Ljava/lang/StringBuilder;-><init>()V
const-string/jumbo v5, "crash-"
invoke-virtual {v4, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v4
invoke-virtual {v4, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v3
const-string/jumbo v4, "-"
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v3
invoke-virtual {v3, v0, v1}, Ljava/lang/StringBuilder;->append(J)Ljava/lang/StringBuilder;
move-result-object v0
const-string/jumbo v1, ".log"
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v0
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
iget-object v1, p0, Lcom/sdk/orion/ui/baselibrary/utils/OrionUiSdkCrashHandler;->mContext:Landroid/content/Context;
const-string/jumbo v3, "android.permission.WRITE_EXTERNAL_STORAGE"
invoke-static {v1, v3}, Lcom/sdk/orion/ui/baselibrary/utils/PermissionUtils;->checkPermission(Landroid/content/Context;Ljava/lang/String;)Z
move-result v1
if-eqz v1, :cond_ca
sget-object v1, Lcom/sdk/orion/ui/baselibrary/utils/OrionUiSdkCrashHandler;->CRASH_FILE_PATH:Ljava/lang/String;
invoke-virtual {v2}, Ljava/lang/StringBuffer;->toString()Ljava/lang/String;
move-result-object v2
invoke-direct {p0, v1, v0, v2}, Lcom/sdk/orion/ui/baselibrary/utils/OrionUiSdkCrashHandler;->writeFileToSD(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)V
:cond_ca
const/4 v0, 0x1
goto :goto_76
.end method
.method private writeFileToSD(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)V
.registers 8
invoke-static {}, Landroid/os/Environment;->getExternalStorageState()Ljava/lang/String;
move-result-object v0
const-string/jumbo v1, "mounted"
invoke-virtual {v0, v1}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z
move-result v0
if-nez v0, :cond_e
:cond_d
:goto_d
return-void
:cond_e
const/4 v1, 0x0
:try_start_f
new-instance v0, Ljava/io/File;
invoke-direct {v0, p1}, Ljava/io/File;-><init>(Ljava/lang/String;)V
new-instance v3, Ljava/io/File;
new-instance v2, Ljava/lang/StringBuilder;
invoke-direct {v2}, Ljava/lang/StringBuilder;-><init>()V
invoke-virtual {v2, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v2
invoke-virtual {v2, p2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v2
invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v2
invoke-direct {v3, v2}, Ljava/io/File;-><init>(Ljava/lang/String;)V
invoke-virtual {v0}, Ljava/io/File;->exists()Z
move-result v2
if-nez v2, :cond_33
invoke-virtual {v0}, Ljava/io/File;->mkdirs()Z
:cond_33
invoke-virtual {v3}, Ljava/io/File;->exists()Z
move-result v0
if-nez v0, :cond_3c
invoke-virtual {v3}, Ljava/io/File;->createNewFile()Z
:cond_3c
new-instance v2, Ljava/io/FileOutputStream;
invoke-direct {v2, v3}, Ljava/io/FileOutputStream;-><init>(Ljava/io/File;)V
:try_end_41
.catch Ljava/lang/Exception; {:try_start_f .. :try_end_41} :catch_53
.catchall {:try_start_f .. :try_end_41} :catchall_62
:try_start_41
invoke-virtual {p3}, Ljava/lang/String;->getBytes()[B
move-result-object v0
invoke-virtual {v2, v0}, Ljava/io/FileOutputStream;->write([B)V
:try_end_48
.catch Ljava/lang/Exception; {:try_start_41 .. :try_end_48} :catch_71
.catchall {:try_start_41 .. :try_end_48} :catchall_6e
if-eqz v2, :cond_d
:try_start_4a
invoke-virtual {v2}, Ljava/io/FileOutputStream;->close()V
:try_end_4d
.catch Ljava/io/IOException; {:try_start_4a .. :try_end_4d} :catch_4e
goto :goto_d
:catch_4e
move-exception v0
invoke-virtual {v0}, Ljava/io/IOException;->printStackTrace()V
goto :goto_d
:catch_53
move-exception v0
:goto_54
:try_start_54
invoke-virtual {v0}, Ljava/lang/Exception;->printStackTrace()V
:try_end_57
.catchall {:try_start_54 .. :try_end_57} :catchall_62
if-eqz v1, :cond_d
:try_start_59
invoke-virtual {v1}, Ljava/io/FileOutputStream;->close()V
:try_end_5c
.catch Ljava/io/IOException; {:try_start_59 .. :try_end_5c} :catch_5d
goto :goto_d
:catch_5d
move-exception v0
invoke-virtual {v0}, Ljava/io/IOException;->printStackTrace()V
goto :goto_d
:catchall_62
move-exception v0
:goto_63
if-eqz v1, :cond_68
:try_start_65
invoke-virtual {v1}, Ljava/io/FileOutputStream;->close()V
:try_end_68
.catch Ljava/io/IOException; {:try_start_65 .. :try_end_68} :catch_69
:cond_68
:goto_68
throw v0
:catch_69
move-exception v1
invoke-virtual {v1}, Ljava/io/IOException;->printStackTrace()V
goto :goto_68
:catchall_6e
move-exception v0
move-object v1, v2
goto :goto_63
:catch_71
move-exception v0
move-object v1, v2
goto :goto_54
.end method
# virtual methods
.method public init(Landroid/content/Context;)V
.registers 3
iput-object p1, p0, Lcom/sdk/orion/ui/baselibrary/utils/OrionUiSdkCrashHandler;->mContext:Landroid/content/Context;
invoke-static {}, Ljava/lang/Thread;->getDefaultUncaughtExceptionHandler()Ljava/lang/Thread$UncaughtExceptionHandler;
move-result-object v0
iput-object v0, p0, Lcom/sdk/orion/ui/baselibrary/utils/OrionUiSdkCrashHandler;->mDefaultHandler:Ljava/lang/Thread$UncaughtExceptionHandler;
invoke-static {p0}, Ljava/lang/Thread;->setDefaultUncaughtExceptionHandler(Ljava/lang/Thread$UncaughtExceptionHandler;)V
return-void
.end method
.method public uncaughtException(Ljava/lang/Thread;Ljava/lang/Throwable;)V
.registers 4
invoke-direct {p0, p2}, Lcom/sdk/orion/ui/baselibrary/utils/OrionUiSdkCrashHandler;->handleException(Ljava/lang/Throwable;)V
iget-object v0, p0, Lcom/sdk/orion/ui/baselibrary/utils/OrionUiSdkCrashHandler;->mDefaultHandler:Ljava/lang/Thread$UncaughtExceptionHandler;
if-eqz v0, :cond_c
iget-object v0, p0, Lcom/sdk/orion/ui/baselibrary/utils/OrionUiSdkCrashHandler;->mDefaultHandler:Ljava/lang/Thread$UncaughtExceptionHandler;
invoke-interface {v0, p1, p2}, Ljava/lang/Thread$UncaughtExceptionHandler;->uncaughtException(Ljava/lang/Thread;Ljava/lang/Throwable;)V
:cond_c
return-void
.end method