.class final Lio/sentry/cache/CacheUtils; .super Ljava/lang/Object; .source "CacheUtils.java" # static fields .field private static final UTF_8:Ljava/nio/charset/Charset; # direct methods .method static constructor ()V .locals 1 const-string v0, "UTF-8" .line 27 invoke-static {v0}, Ljava/nio/charset/Charset;->forName(Ljava/lang/String;)Ljava/nio/charset/Charset; move-result-object v0 sput-object v0, Lio/sentry/cache/CacheUtils;->UTF_8:Ljava/nio/charset/Charset; return-void .end method .method constructor ()V .locals 0 .line 24 invoke-direct {p0}, Ljava/lang/Object;->()V return-void .end method .method static delete(Lio/sentry/SentryOptions;Ljava/lang/String;Ljava/lang/String;)V .locals 3 .line 60 invoke-static {p0, p1}, Lio/sentry/cache/CacheUtils;->ensureCacheDir(Lio/sentry/SentryOptions;Ljava/lang/String;)Ljava/io/File; move-result-object p1 if-nez p1, :cond_0 .line 62 invoke-virtual {p0}, Lio/sentry/SentryOptions;->getLogger()Lio/sentry/ILogger; move-result-object p0 sget-object p1, Lio/sentry/SentryLevel;->INFO:Lio/sentry/SentryLevel; const/4 p2, 0x0 new-array p2, p2, [Ljava/lang/Object; const-string v0, "Cache dir is not set, cannot delete from scope cache" invoke-interface {p0, p1, v0, p2}, Lio/sentry/ILogger;->log(Lio/sentry/SentryLevel;Ljava/lang/String;[Ljava/lang/Object;)V return-void .line 66 :cond_0 new-instance v0, Ljava/io/File; invoke-direct {v0, p1, p2}, Ljava/io/File;->(Ljava/io/File;Ljava/lang/String;)V .line 67 invoke-virtual {v0}, Ljava/io/File;->exists()Z move-result p1 if-eqz p1, :cond_1 .line 68 invoke-virtual {p0}, Lio/sentry/SentryOptions;->getLogger()Lio/sentry/ILogger; move-result-object p1 sget-object v1, Lio/sentry/SentryLevel;->DEBUG:Lio/sentry/SentryLevel; const-string v2, "Deleting %s from scope cache" filled-new-array {p2}, [Ljava/lang/Object; move-result-object p2 invoke-interface {p1, v1, v2, p2}, Lio/sentry/ILogger;->log(Lio/sentry/SentryLevel;Ljava/lang/String;[Ljava/lang/Object;)V .line 69 invoke-virtual {v0}, Ljava/io/File;->delete()Z move-result p1 if-nez p1, :cond_1 .line 70 invoke-virtual {p0}, Lio/sentry/SentryOptions;->getLogger()Lio/sentry/ILogger; move-result-object p0 sget-object p1, Lio/sentry/SentryLevel;->ERROR:Lio/sentry/SentryLevel; invoke-virtual {v0}, Ljava/io/File;->getAbsolutePath()Ljava/lang/String; move-result-object p2 filled-new-array {p2}, [Ljava/lang/Object; move-result-object p2 const-string v0, "Failed to delete: %s" invoke-interface {p0, p1, v0, p2}, Lio/sentry/ILogger;->log(Lio/sentry/SentryLevel;Ljava/lang/String;[Ljava/lang/Object;)V :cond_1 return-void .end method .method private static ensureCacheDir(Lio/sentry/SentryOptions;Ljava/lang/String;)Ljava/io/File; .locals 1 .line 107 invoke-virtual {p0}, Lio/sentry/SentryOptions;->getCacheDirPath()Ljava/lang/String; move-result-object p0 if-nez p0, :cond_0 const/4 p0, 0x0 return-object p0 .line 111 :cond_0 new-instance v0, Ljava/io/File; invoke-direct {v0, p0, p1}, Ljava/io/File;->(Ljava/lang/String;Ljava/lang/String;)V .line 112 invoke-virtual {v0}, Ljava/io/File;->mkdirs()Z return-object v0 .end method .method static read(Lio/sentry/SentryOptions;Ljava/lang/String;Ljava/lang/String;Ljava/lang/Class;Lio/sentry/JsonDeserializer;)Ljava/lang/Object; .locals 4 .annotation system Ldalvik/annotation/Signature; value = { "(", "Lio/sentry/SentryOptions;", "Ljava/lang/String;", "Ljava/lang/String;", "Ljava/lang/Class<", "TT;>;", "Lio/sentry/JsonDeserializer<", "TR;>;)TT;" } .end annotation .line 81 invoke-static {p0, p1}, Lio/sentry/cache/CacheUtils;->ensureCacheDir(Lio/sentry/SentryOptions;Ljava/lang/String;)Ljava/io/File; move-result-object p1 const/4 v0, 0x0 if-nez p1, :cond_0 .line 83 invoke-virtual {p0}, Lio/sentry/SentryOptions;->getLogger()Lio/sentry/ILogger; move-result-object p0 sget-object p1, Lio/sentry/SentryLevel;->INFO:Lio/sentry/SentryLevel; const/4 p2, 0x0 new-array p2, p2, [Ljava/lang/Object; const-string p3, "Cache dir is not set, cannot read from scope cache" invoke-interface {p0, p1, p3, p2}, Lio/sentry/ILogger;->log(Lio/sentry/SentryLevel;Ljava/lang/String;[Ljava/lang/Object;)V return-object v0 .line 87 :cond_0 new-instance v1, Ljava/io/File; invoke-direct {v1, p1, p2}, Ljava/io/File;->(Ljava/io/File;Ljava/lang/String;)V .line 88 invoke-virtual {v1}, Ljava/io/File;->exists()Z move-result p1 if-eqz p1, :cond_2 .line 89 :try_start_0 new-instance p1, Ljava/io/BufferedReader; new-instance v2, Ljava/io/InputStreamReader; new-instance v3, Ljava/io/FileInputStream; invoke-direct {v3, v1}, Ljava/io/FileInputStream;->(Ljava/io/File;)V sget-object v1, Lio/sentry/cache/CacheUtils;->UTF_8:Ljava/nio/charset/Charset; invoke-direct {v2, v3, v1}, Ljava/io/InputStreamReader;->(Ljava/io/InputStream;Ljava/nio/charset/Charset;)V invoke-direct {p1, v2}, Ljava/io/BufferedReader;->(Ljava/io/Reader;)V :try_end_0 .catchall {:try_start_0 .. :try_end_0} :catchall_2 if-nez p4, :cond_1 .line 92 :try_start_1 invoke-virtual {p0}, Lio/sentry/SentryOptions;->getSerializer()Lio/sentry/ISerializer; move-result-object p4 invoke-interface {p4, p1, p3}, Lio/sentry/ISerializer;->deserialize(Ljava/io/Reader;Ljava/lang/Class;)Ljava/lang/Object; move-result-object p3 :try_end_1 .catchall {:try_start_1 .. :try_end_1} :catchall_0 .line 96 :try_start_2 invoke-virtual {p1}, Ljava/io/Reader;->close()V :try_end_2 .catchall {:try_start_2 .. :try_end_2} :catchall_2 return-object p3 .line 94 :cond_1 :try_start_3 invoke-virtual {p0}, Lio/sentry/SentryOptions;->getSerializer()Lio/sentry/ISerializer; move-result-object v1 invoke-interface {v1, p1, p3, p4}, Lio/sentry/ISerializer;->deserializeCollection(Ljava/io/Reader;Ljava/lang/Class;Lio/sentry/JsonDeserializer;)Ljava/lang/Object; move-result-object p3 :try_end_3 .catchall {:try_start_3 .. :try_end_3} :catchall_0 .line 96 :try_start_4 invoke-virtual {p1}, Ljava/io/Reader;->close()V :try_end_4 .catchall {:try_start_4 .. :try_end_4} :catchall_2 return-object p3 :catchall_0 move-exception p3 .line 89 :try_start_5 invoke-virtual {p1}, Ljava/io/Reader;->close()V :try_end_5 .catchall {:try_start_5 .. :try_end_5} :catchall_1 goto :goto_0 :catchall_1 move-exception p1 :try_start_6 invoke-virtual {p3, p1}, Ljava/lang/Throwable;->addSuppressed(Ljava/lang/Throwable;)V :goto_0 throw p3 :try_end_6 .catchall {:try_start_6 .. :try_end_6} :catchall_2 :catchall_2 move-exception p1 .line 97 invoke-virtual {p0}, Lio/sentry/SentryOptions;->getLogger()Lio/sentry/ILogger; move-result-object p0 sget-object p3, Lio/sentry/SentryLevel;->ERROR:Lio/sentry/SentryLevel; const-string p4, "Error reading entity from scope cache: %s" filled-new-array {p2}, [Ljava/lang/Object; move-result-object p2 invoke-interface {p0, p3, p1, p4, p2}, Lio/sentry/ILogger;->log(Lio/sentry/SentryLevel;Ljava/lang/Throwable;Ljava/lang/String;[Ljava/lang/Object;)V goto :goto_1 .line 100 :cond_2 invoke-virtual {p0}, Lio/sentry/SentryOptions;->getLogger()Lio/sentry/ILogger; move-result-object p0 sget-object p1, Lio/sentry/SentryLevel;->DEBUG:Lio/sentry/SentryLevel; const-string p3, "No entry stored for %s" filled-new-array {p2}, [Ljava/lang/Object; move-result-object p2 invoke-interface {p0, p1, p3, p2}, Lio/sentry/ILogger;->log(Lio/sentry/SentryLevel;Ljava/lang/String;[Ljava/lang/Object;)V :goto_1 return-object v0 .end method .method static store(Lio/sentry/SentryOptions;Ljava/lang/Object;Ljava/lang/String;Ljava/lang/String;)V .locals 4 .annotation system Ldalvik/annotation/Signature; value = { "(", "Lio/sentry/SentryOptions;", "TT;", "Ljava/lang/String;", "Ljava/lang/String;", ")V" } .end annotation .line 34 invoke-static {p0, p2}, Lio/sentry/cache/CacheUtils;->ensureCacheDir(Lio/sentry/SentryOptions;Ljava/lang/String;)Ljava/io/File; move-result-object p2 if-nez p2, :cond_0 .line 36 invoke-virtual {p0}, Lio/sentry/SentryOptions;->getLogger()Lio/sentry/ILogger; move-result-object p0 sget-object p1, Lio/sentry/SentryLevel;->INFO:Lio/sentry/SentryLevel; const/4 p2, 0x0 new-array p2, p2, [Ljava/lang/Object; const-string p3, "Cache dir is not set, cannot store in scope cache" invoke-interface {p0, p1, p3, p2}, Lio/sentry/ILogger;->log(Lio/sentry/SentryLevel;Ljava/lang/String;[Ljava/lang/Object;)V return-void .line 40 :cond_0 new-instance v0, Ljava/io/File; invoke-direct {v0, p2, p3}, Ljava/io/File;->(Ljava/io/File;Ljava/lang/String;)V .line 41 invoke-virtual {v0}, Ljava/io/File;->exists()Z move-result p2 if-eqz p2, :cond_1 .line 42 invoke-virtual {p0}, Lio/sentry/SentryOptions;->getLogger()Lio/sentry/ILogger; move-result-object p2 sget-object v1, Lio/sentry/SentryLevel;->DEBUG:Lio/sentry/SentryLevel; const-string v2, "Overwriting %s in scope cache" filled-new-array {p3}, [Ljava/lang/Object; move-result-object v3 invoke-interface {p2, v1, v2, v3}, Lio/sentry/ILogger;->log(Lio/sentry/SentryLevel;Ljava/lang/String;[Ljava/lang/Object;)V .line 43 invoke-virtual {v0}, Ljava/io/File;->delete()Z move-result p2 if-nez p2, :cond_1 .line 44 invoke-virtual {p0}, Lio/sentry/SentryOptions;->getLogger()Lio/sentry/ILogger; move-result-object p2 sget-object v1, Lio/sentry/SentryLevel;->ERROR:Lio/sentry/SentryLevel; invoke-virtual {v0}, Ljava/io/File;->getAbsolutePath()Ljava/lang/String; move-result-object v2 filled-new-array {v2}, [Ljava/lang/Object; move-result-object v2 const-string v3, "Failed to delete: %s" invoke-interface {p2, v1, v3, v2}, Lio/sentry/ILogger;->log(Lio/sentry/SentryLevel;Ljava/lang/String;[Ljava/lang/Object;)V .line 48 :cond_1 :try_start_0 new-instance p2, Ljava/io/FileOutputStream; invoke-direct {p2, v0}, Ljava/io/FileOutputStream;->(Ljava/io/File;)V :try_end_0 .catchall {:try_start_0 .. :try_end_0} :catchall_4 .line 49 :try_start_1 new-instance v0, Ljava/io/BufferedWriter; new-instance v1, Ljava/io/OutputStreamWriter; sget-object v2, Lio/sentry/cache/CacheUtils;->UTF_8:Ljava/nio/charset/Charset; invoke-direct {v1, p2, v2}, Ljava/io/OutputStreamWriter;->(Ljava/io/OutputStream;Ljava/nio/charset/Charset;)V invoke-direct {v0, v1}, Ljava/io/BufferedWriter;->(Ljava/io/Writer;)V :try_end_1 .catchall {:try_start_1 .. :try_end_1} :catchall_2 .line 50 :try_start_2 invoke-virtual {p0}, Lio/sentry/SentryOptions;->getSerializer()Lio/sentry/ISerializer; move-result-object v1 invoke-interface {v1, p1, v0}, Lio/sentry/ISerializer;->serialize(Ljava/lang/Object;Ljava/io/Writer;)V :try_end_2 .catchall {:try_start_2 .. :try_end_2} :catchall_0 .line 51 :try_start_3 invoke-virtual {v0}, Ljava/io/Writer;->close()V :try_end_3 .catchall {:try_start_3 .. :try_end_3} :catchall_2 :try_start_4 invoke-virtual {p2}, Ljava/io/OutputStream;->close()V :try_end_4 .catchall {:try_start_4 .. :try_end_4} :catchall_4 goto :goto_2 :catchall_0 move-exception p1 .line 48 :try_start_5 invoke-virtual {v0}, Ljava/io/Writer;->close()V :try_end_5 .catchall {:try_start_5 .. :try_end_5} :catchall_1 goto :goto_0 :catchall_1 move-exception v0 :try_start_6 invoke-virtual {p1, v0}, Ljava/lang/Throwable;->addSuppressed(Ljava/lang/Throwable;)V :goto_0 throw p1 :try_end_6 .catchall {:try_start_6 .. :try_end_6} :catchall_2 :catchall_2 move-exception p1 :try_start_7 invoke-virtual {p2}, Ljava/io/OutputStream;->close()V :try_end_7 .catchall {:try_start_7 .. :try_end_7} :catchall_3 goto :goto_1 :catchall_3 move-exception p2 :try_start_8 invoke-virtual {p1, p2}, Ljava/lang/Throwable;->addSuppressed(Ljava/lang/Throwable;)V :goto_1 throw p1 :try_end_8 .catchall {:try_start_8 .. :try_end_8} :catchall_4 :catchall_4 move-exception p1 .line 52 invoke-virtual {p0}, Lio/sentry/SentryOptions;->getLogger()Lio/sentry/ILogger; move-result-object p0 sget-object p2, Lio/sentry/SentryLevel;->ERROR:Lio/sentry/SentryLevel; const-string v0, "Error persisting entity: %s" filled-new-array {p3}, [Ljava/lang/Object; move-result-object p3 invoke-interface {p0, p2, p1, v0, p3}, Lio/sentry/ILogger;->log(Lio/sentry/SentryLevel;Ljava/lang/Throwable;Ljava/lang/String;[Ljava/lang/Object;)V :goto_2 return-void .end method