DefaultCachedSettingsIo.smali
.class Lio/fabric/sdk/android/services/settings/DefaultCachedSettingsIo;
.super Ljava/lang/Object;
.source "DefaultCachedSettingsIo.java"
# interfaces
.implements Lio/fabric/sdk/android/services/settings/CachedSettingsIo;
# instance fields
.field private final kit:Lio/fabric/sdk/android/Kit;
# direct methods
.method public constructor <init>(Lio/fabric/sdk/android/Kit;)V
.registers 2
.line 40
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
.line 41
iput-object p1, p0, Lio/fabric/sdk/android/services/settings/DefaultCachedSettingsIo;->kit:Lio/fabric/sdk/android/Kit;
return-void
.end method
# virtual methods
.method public readCachedSettings()Lorg/json/JSONObject;
.registers 8
const-string v0, "Error while closing settings cache file."
.line 46
invoke-static {}, Lio/fabric/sdk/android/Fabric;->getLogger()Lio/fabric/sdk/android/Logger;
move-result-object v1
const-string v2, "Fabric"
const-string v3, "Reading cached settings..."
invoke-interface {v1, v2, v3}, Lio/fabric/sdk/android/Logger;->d(Ljava/lang/String;Ljava/lang/String;)V
const/4 v1, 0x0
.line 52
:try_start_e
new-instance v3, Ljava/io/File;
new-instance v4, Lio/fabric/sdk/android/services/persistence/FileStoreImpl;
iget-object v5, p0, Lio/fabric/sdk/android/services/settings/DefaultCachedSettingsIo;->kit:Lio/fabric/sdk/android/Kit;
invoke-direct {v4, v5}, Lio/fabric/sdk/android/services/persistence/FileStoreImpl;-><init>(Lio/fabric/sdk/android/Kit;)V
invoke-virtual {v4}, Lio/fabric/sdk/android/services/persistence/FileStoreImpl;->getFilesDir()Ljava/io/File;
move-result-object v4
const-string v5, "com.crashlytics.settings.json"
invoke-direct {v3, v4, v5}, Ljava/io/File;-><init>(Ljava/io/File;Ljava/lang/String;)V
.line 55
invoke-virtual {v3}, Ljava/io/File;->exists()Z
move-result v4
if-eqz v4, :cond_38
.line 56
new-instance v4, Ljava/io/FileInputStream;
invoke-direct {v4, v3}, Ljava/io/FileInputStream;-><init>(Ljava/io/File;)V
:try_end_2b
.catch Ljava/lang/Exception; {:try_start_e .. :try_end_2b} :catch_4b
.catchall {:try_start_e .. :try_end_2b} :catchall_47
.line 57
:try_start_2b
invoke-static {v4}, Lio/fabric/sdk/android/services/common/CommonUtils;->streamToString(Ljava/io/InputStream;)Ljava/lang/String;
move-result-object v3
.line 59
new-instance v5, Lorg/json/JSONObject;
invoke-direct {v5, v3}, Lorg/json/JSONObject;-><init>(Ljava/lang/String;)V
:try_end_34
.catch Ljava/lang/Exception; {:try_start_2b .. :try_end_34} :catch_36
.catchall {:try_start_2b .. :try_end_34} :catchall_5a
move-object v1, v4
goto :goto_42
:catch_36
move-exception v3
goto :goto_4d
.line 61
:cond_38
:try_start_38
invoke-static {}, Lio/fabric/sdk/android/Fabric;->getLogger()Lio/fabric/sdk/android/Logger;
move-result-object v3
const-string v4, "No cached settings found."
invoke-interface {v3, v2, v4}, Lio/fabric/sdk/android/Logger;->d(Ljava/lang/String;Ljava/lang/String;)V
:try_end_41
.catch Ljava/lang/Exception; {:try_start_38 .. :try_end_41} :catch_4b
.catchall {:try_start_38 .. :try_end_41} :catchall_47
move-object v5, v1
.line 66
:goto_42
invoke-static {v1, v0}, Lio/fabric/sdk/android/services/common/CommonUtils;->closeOrLog(Ljava/io/Closeable;Ljava/lang/String;)V
move-object v1, v5
goto :goto_59
:catchall_47
move-exception v2
move-object v4, v1
move-object v1, v2
goto :goto_5b
:catch_4b
move-exception v3
move-object v4, v1
.line 64
:goto_4d
:try_start_4d
invoke-static {}, Lio/fabric/sdk/android/Fabric;->getLogger()Lio/fabric/sdk/android/Logger;
move-result-object v5
const-string v6, "Failed to fetch cached settings"
invoke-interface {v5, v2, v6, v3}, Lio/fabric/sdk/android/Logger;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V
:try_end_56
.catchall {:try_start_4d .. :try_end_56} :catchall_5a
.line 66
invoke-static {v4, v0}, Lio/fabric/sdk/android/services/common/CommonUtils;->closeOrLog(Ljava/io/Closeable;Ljava/lang/String;)V
:goto_59
return-object v1
:catchall_5a
move-exception v1
:goto_5b
invoke-static {v4, v0}, Lio/fabric/sdk/android/services/common/CommonUtils;->closeOrLog(Ljava/io/Closeable;Ljava/lang/String;)V
throw v1
.end method
.method public writeCachedSettings(JLorg/json/JSONObject;)V
.registers 9
const-string v0, "Failed to close settings writer."
.line 74
invoke-static {}, Lio/fabric/sdk/android/Fabric;->getLogger()Lio/fabric/sdk/android/Logger;
move-result-object v1
const-string v2, "Fabric"
const-string v3, "Writing settings to cache file..."
invoke-interface {v1, v2, v3}, Lio/fabric/sdk/android/Logger;->d(Ljava/lang/String;Ljava/lang/String;)V
if-eqz p3, :cond_54
const/4 v1, 0x0
:try_start_10
const-string v3, "expires_at"
.line 80
invoke-virtual {p3, v3, p1, p2}, Lorg/json/JSONObject;->put(Ljava/lang/String;J)Lorg/json/JSONObject;
.line 82
new-instance p1, Ljava/io/FileWriter;
new-instance p2, Ljava/io/File;
new-instance v3, Lio/fabric/sdk/android/services/persistence/FileStoreImpl;
iget-object v4, p0, Lio/fabric/sdk/android/services/settings/DefaultCachedSettingsIo;->kit:Lio/fabric/sdk/android/Kit;
invoke-direct {v3, v4}, Lio/fabric/sdk/android/services/persistence/FileStoreImpl;-><init>(Lio/fabric/sdk/android/Kit;)V
invoke-virtual {v3}, Lio/fabric/sdk/android/services/persistence/FileStoreImpl;->getFilesDir()Ljava/io/File;
move-result-object v3
const-string v4, "com.crashlytics.settings.json"
invoke-direct {p2, v3, v4}, Ljava/io/File;-><init>(Ljava/io/File;Ljava/lang/String;)V
invoke-direct {p1, p2}, Ljava/io/FileWriter;-><init>(Ljava/io/File;)V
:try_end_2c
.catch Ljava/lang/Exception; {:try_start_10 .. :try_end_2c} :catch_42
.catchall {:try_start_10 .. :try_end_2c} :catchall_40
.line 84
:try_start_2c
invoke-virtual {p3}, Lorg/json/JSONObject;->toString()Ljava/lang/String;
move-result-object p2
invoke-virtual {p1, p2}, Ljava/io/FileWriter;->write(Ljava/lang/String;)V
.line 85
invoke-virtual {p1}, Ljava/io/FileWriter;->flush()V
:try_end_36
.catch Ljava/lang/Exception; {:try_start_2c .. :try_end_36} :catch_3d
.catchall {:try_start_2c .. :try_end_36} :catchall_3a
.line 89
invoke-static {p1, v0}, Lio/fabric/sdk/android/services/common/CommonUtils;->closeOrLog(Ljava/io/Closeable;Ljava/lang/String;)V
goto :goto_54
:catchall_3a
move-exception p2
move-object v1, p1
goto :goto_50
:catch_3d
move-exception p2
move-object v1, p1
goto :goto_43
:catchall_40
move-exception p2
goto :goto_50
:catch_42
move-exception p2
.line 87
:goto_43
:try_start_43
invoke-static {}, Lio/fabric/sdk/android/Fabric;->getLogger()Lio/fabric/sdk/android/Logger;
move-result-object p1
const-string p3, "Failed to cache settings"
invoke-interface {p1, v2, p3, p2}, Lio/fabric/sdk/android/Logger;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V
:try_end_4c
.catchall {:try_start_43 .. :try_end_4c} :catchall_40
.line 89
invoke-static {v1, v0}, Lio/fabric/sdk/android/services/common/CommonUtils;->closeOrLog(Ljava/io/Closeable;Ljava/lang/String;)V
goto :goto_54
:goto_50
invoke-static {v1, v0}, Lio/fabric/sdk/android/services/common/CommonUtils;->closeOrLog(Ljava/io/Closeable;Ljava/lang/String;)V
throw p2
:cond_54
:goto_54
return-void
.end method