.class public Lcom/ea/nimble/Persistence; .super Ljava/lang/Object; .source "SourceFile" # interfaces .implements Lcom/ea/nimble/LogSource; # annotations .annotation system Ldalvik/annotation/MemberClasses; value = { Lcom/ea/nimble/Persistence$Storage; } .end annotation # static fields .field private static final PERSISTENCE_VERSION:I = 0x65 .field static final s_dataLock:Ljava/lang/Object; # instance fields .field private m_backUp:Z .field private m_changed:Z .field private m_content:Ljava/util/Map; .annotation system Ldalvik/annotation/Signature; value = { "Ljava/util/Map<", "Ljava/lang/String;", "[B>;" } .end annotation .end field .field private m_encryption:Z .field private final m_encryptor:Lcom/ea/nimble/Encryptor; .field private final m_identifier:Ljava/lang/String; .field private m_persistencePath:Ljava/lang/String; .field private final m_storage:Lcom/ea/nimble/Persistence$Storage; .field private final m_synchronizeTimer:Lcom/ea/nimble/Timer; # direct methods .method public static synthetic $r8$lambda$YNrsC2LI9jcht_Qhd_E1tZJaAUY(Lcom/ea/nimble/Persistence;)V .locals 0 .line 0 invoke-direct {p0}, Lcom/ea/nimble/Persistence;->lambda$new$0()V return-void .end method .method static constructor ()V .locals 1 .line 48 new-instance v0, Ljava/lang/Object; invoke-direct {v0}, Ljava/lang/Object;->()V sput-object v0, Lcom/ea/nimble/Persistence;->s_dataLock:Ljava/lang/Object; return-void .end method .method public constructor (Lcom/ea/nimble/Persistence;Ljava/lang/String;)V .locals 2 .line 62 invoke-direct {p0}, Ljava/lang/Object;->()V const/4 v0, 0x0 iput-object v0, p0, Lcom/ea/nimble/Persistence;->m_persistencePath:Ljava/lang/String; .line 44 new-instance v0, Lcom/ea/nimble/Timer; new-instance v1, Lcom/ea/nimble/Persistence$$ExternalSyntheticLambda0; invoke-direct {v1, p0}, Lcom/ea/nimble/Persistence$$ExternalSyntheticLambda0;->(Lcom/ea/nimble/Persistence;)V invoke-direct {v0, v1}, Lcom/ea/nimble/Timer;->(Ljava/lang/Runnable;)V iput-object v0, p0, Lcom/ea/nimble/Persistence;->m_synchronizeTimer:Lcom/ea/nimble/Timer; .line 63 new-instance v0, Ljava/util/HashMap; iget-object v1, p1, Lcom/ea/nimble/Persistence;->m_content:Ljava/util/Map; invoke-direct {v0, v1}, Ljava/util/HashMap;->(Ljava/util/Map;)V iput-object v0, p0, Lcom/ea/nimble/Persistence;->m_content:Ljava/util/Map; iput-object p2, p0, Lcom/ea/nimble/Persistence;->m_identifier:Ljava/lang/String; .line 65 iget-object p2, p1, Lcom/ea/nimble/Persistence;->m_storage:Lcom/ea/nimble/Persistence$Storage; iput-object p2, p0, Lcom/ea/nimble/Persistence;->m_storage:Lcom/ea/nimble/Persistence$Storage; .line 66 iget-object p2, p1, Lcom/ea/nimble/Persistence;->m_encryptor:Lcom/ea/nimble/Encryptor; iput-object p2, p0, Lcom/ea/nimble/Persistence;->m_encryptor:Lcom/ea/nimble/Encryptor; .line 67 iget-boolean p2, p1, Lcom/ea/nimble/Persistence;->m_encryption:Z iput-boolean p2, p0, Lcom/ea/nimble/Persistence;->m_encryption:Z .line 68 iget-boolean p1, p1, Lcom/ea/nimble/Persistence;->m_backUp:Z iput-boolean p1, p0, Lcom/ea/nimble/Persistence;->m_backUp:Z .line 69 invoke-direct {p0}, Lcom/ea/nimble/Persistence;->flagChange()V return-void .end method .method public constructor (Ljava/lang/String;Lcom/ea/nimble/Persistence$Storage;Lcom/ea/nimble/Encryptor;)V .locals 2 .line 51 invoke-direct {p0}, Ljava/lang/Object;->()V const/4 v0, 0x0 iput-object v0, p0, Lcom/ea/nimble/Persistence;->m_persistencePath:Ljava/lang/String; .line 44 new-instance v0, Lcom/ea/nimble/Timer; new-instance v1, Lcom/ea/nimble/Persistence$$ExternalSyntheticLambda0; invoke-direct {v1, p0}, Lcom/ea/nimble/Persistence$$ExternalSyntheticLambda0;->(Lcom/ea/nimble/Persistence;)V invoke-direct {v0, v1}, Lcom/ea/nimble/Timer;->(Ljava/lang/Runnable;)V iput-object v0, p0, Lcom/ea/nimble/Persistence;->m_synchronizeTimer:Lcom/ea/nimble/Timer; .line 52 new-instance v0, Ljava/util/HashMap; invoke-direct {v0}, Ljava/util/HashMap;->()V iput-object v0, p0, Lcom/ea/nimble/Persistence;->m_content:Ljava/util/Map; iput-object p1, p0, Lcom/ea/nimble/Persistence;->m_identifier:Ljava/lang/String; iput-object p2, p0, Lcom/ea/nimble/Persistence;->m_storage:Lcom/ea/nimble/Persistence$Storage; iput-object p3, p0, Lcom/ea/nimble/Persistence;->m_encryptor:Lcom/ea/nimble/Encryptor; const/4 p1, 0x0 iput-boolean p1, p0, Lcom/ea/nimble/Persistence;->m_encryption:Z iput-boolean p1, p0, Lcom/ea/nimble/Persistence;->m_backUp:Z iput-boolean p1, p0, Lcom/ea/nimble/Persistence;->m_changed:Z return-void .end method .method private clearSynchronizeTimer()V .locals 2 .line 413 invoke-static {p0}, Lcom/ea/nimble/Log$Helper;->LOGFUNC(Ljava/lang/Object;)V sget-object v0, Lcom/ea/nimble/Persistence;->s_dataLock:Ljava/lang/Object; .line 414 monitor-enter v0 :try_start_0 iget-object v1, p0, Lcom/ea/nimble/Persistence;->m_synchronizeTimer:Lcom/ea/nimble/Timer; .line 416 invoke-virtual {v1}, Lcom/ea/nimble/Timer;->cancel()V .line 417 monitor-exit v0 return-void :catchall_0 move-exception v1 monitor-exit v0 :try_end_0 .catchall {:try_start_0 .. :try_end_0} :catchall_0 throw v1 .end method .method private flagChange()V .locals 5 .line 422 invoke-static {p0}, Lcom/ea/nimble/Log$Helper;->LOGFUNC(Ljava/lang/Object;)V const/4 v0, 0x1 iput-boolean v0, p0, Lcom/ea/nimble/Persistence;->m_changed:Z sget-object v0, Lcom/ea/nimble/Persistence;->s_dataLock:Ljava/lang/Object; .line 427 monitor-enter v0 .line 429 :try_start_0 invoke-direct {p0}, Lcom/ea/nimble/Persistence;->clearSynchronizeTimer()V iget-object v1, p0, Lcom/ea/nimble/Persistence;->m_synchronizeTimer:Lcom/ea/nimble/Timer; const-wide/high16 v2, 0x3fe0000000000000L # 0.5 const/4 v4, 0x0 .line 430 invoke-virtual {v1, v2, v3, v4}, Lcom/ea/nimble/Timer;->schedule(DZ)V .line 431 monitor-exit v0 return-void :catchall_0 move-exception v1 monitor-exit v0 :try_end_0 .catchall {:try_start_0 .. :try_end_0} :catchall_0 throw v1 .end method .method public static getPersistenceDirectory(Lcom/ea/nimble/Persistence$Storage;)Ljava/io/File; .locals 5 .line 585 invoke-static {}, Lcom/ea/nimble/ApplicationEnvironment;->getComponent()Lcom/ea/nimble/IApplicationEnvironment; move-result-object v0 .line 586 sget-object v1, Lcom/ea/nimble/Persistence$1;->$SwitchMap$com$ea$nimble$Persistence$Storage:[I invoke-virtual {p0}, Ljava/lang/Enum;->ordinal()I move-result v2 aget v1, v1, v2 const/4 v2, 0x1 const/4 v3, 0x0 const-string v4, "Persistence" if-eq v1, v2, :cond_2 const/4 v2, 0x2 if-eq v1, v2, :cond_1 const/4 v2, 0x3 if-eq v1, v2, :cond_0 const/4 p0, 0x0 new-array p0, p0, [Ljava/lang/Object; const-string v0, "Unknown storage type" .line 598 invoke-static {v4, v0, p0}, Lcom/ea/nimble/Log$Helper;->LOGES(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V return-object v3 .line 595 :cond_0 invoke-interface {v0}, Lcom/ea/nimble/IApplicationEnvironment;->getTempPath()Ljava/lang/String; move-result-object v0 goto :goto_0 .line 592 :cond_1 invoke-interface {v0}, Lcom/ea/nimble/IApplicationEnvironment;->getCachePath()Ljava/lang/String; move-result-object v0 goto :goto_0 .line 589 :cond_2 invoke-interface {v0}, Lcom/ea/nimble/IApplicationEnvironment;->getDocumentPath()Ljava/lang/String; move-result-object v0 .line 601 :goto_0 new-instance v1, Ljava/io/File; new-instance v2, Ljava/lang/StringBuilder; invoke-direct {v2}, Ljava/lang/StringBuilder;->()V invoke-virtual {v2, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; sget-object v0, Ljava/io/File;->separator:Ljava/lang/String; invoke-virtual {v2, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; const-string v0, "persistence" invoke-virtual {v2, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v0 invoke-direct {v1, v0}, Ljava/io/File;->(Ljava/lang/String;)V .line 603 invoke-virtual {v1}, Ljava/io/File;->isDirectory()Z move-result v0 if-nez v0, :cond_3 invoke-virtual {v1}, Ljava/io/File;->mkdirs()Z move-result v0 if-nez v0, :cond_3 .line 605 invoke-virtual {v1}, Ljava/io/File;->toString()Ljava/lang/String; move-result-object v0 filled-new-array {p0, v0}, [Ljava/lang/Object; move-result-object p0 const-string v0, "Cannot create persistence folder in storage(%s) %s" invoke-static {v4, v0, p0}, Lcom/ea/nimble/Log$Helper;->LOGE(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V return-object v3 :cond_3 return-object v1 .end method .method public static getPersistenceDirectory(Lcom/ea/nimble/Persistence$Storage;Landroid/content/Context;)Ljava/io/File; .locals 4 .line 616 sget-object v0, Lcom/ea/nimble/Persistence$1;->$SwitchMap$com$ea$nimble$Persistence$Storage:[I invoke-virtual {p0}, Ljava/lang/Enum;->ordinal()I move-result v1 aget v0, v0, v1 const/4 v1, 0x1 const-string v2, "Nimble" const/4 v3, 0x0 if-eq v0, v1, :cond_1 const/4 v1, 0x2 if-eq v0, v1, :cond_0 const/4 v1, 0x3 if-eq v0, v1, :cond_0 const-string p0, "Persistence : Unknown storage type" .line 634 invoke-static {v2, p0}, Landroid/util/Log;->e(Ljava/lang/String;Ljava/lang/String;)I return-object v3 .line 627 :cond_0 invoke-virtual {p1}, Landroid/content/Context;->getCacheDir()Ljava/io/File; move-result-object p1 if-eqz p1, :cond_2 .line 630 invoke-virtual {p1}, Ljava/io/File;->getPath()Ljava/lang/String; move-result-object p1 goto :goto_0 .line 619 :cond_1 invoke-virtual {p1}, Landroid/content/Context;->getFilesDir()Ljava/io/File; move-result-object p1 if-eqz p1, :cond_2 .line 622 invoke-virtual {p1}, Ljava/io/File;->getPath()Ljava/lang/String; move-result-object p1 goto :goto_0 :cond_2 move-object p1, v3 :goto_0 if-nez p1, :cond_3 const-string p1, "Persistence : Could not build base path for storage(%s)" filled-new-array {p0}, [Ljava/lang/Object; move-result-object p0 .line 640 invoke-static {v2, p1, p0}, Lcom/ea/nimble/Log$Helper;->LOGE(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V return-object v3 :cond_3 const-string v0, "com.ea.nimble.configuration" .line 644 invoke-static {v0}, Lcom/ea/nimble/NimbleApplicationConfiguration;->getConfigValueAsString(Ljava/lang/String;)Ljava/lang/String; move-result-object v0 .line 646 new-instance v1, Ljava/lang/StringBuilder; invoke-direct {v1}, Ljava/lang/StringBuilder;->()V invoke-virtual {v1, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; sget-object p1, Ljava/io/File;->separator:Ljava/lang/String; invoke-virtual {v1, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v1, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v1, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v1, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; const-string v0, "persistence" invoke-virtual {v1, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v0 .line 648 sget-object v1, Lcom/ea/nimble/Persistence$Storage;->TEMP:Lcom/ea/nimble/Persistence$Storage; if-ne p0, v1, :cond_4 .line 650 new-instance v1, Ljava/lang/StringBuilder; invoke-direct {v1}, Ljava/lang/StringBuilder;->()V invoke-virtual {v1, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v1, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; const-string p1, "temp" invoke-virtual {v1, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v0 .line 653 :cond_4 new-instance p1, Ljava/io/File; invoke-direct {p1, v0}, Ljava/io/File;->(Ljava/lang/String;)V .line 655 invoke-virtual {p1}, Ljava/io/File;->isDirectory()Z move-result v1 if-nez v1, :cond_5 invoke-virtual {p1}, Ljava/io/File;->mkdirs()Z move-result v1 if-nez v1, :cond_5 const-string p1, "Persistence : Cannot create persistence folder in storage(%s) %s" filled-new-array {p0, v0}, [Ljava/lang/Object; move-result-object p0 .line 657 invoke-static {p1, p0}, Ljava/lang/String;->format(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String; move-result-object p0 invoke-static {v2, p0}, Landroid/util/Log;->e(Ljava/lang/String;Ljava/lang/String;)I return-object v3 :cond_5 return-object p1 .end method .method public static getPersistencePath(Ljava/lang/String;Lcom/ea/nimble/Persistence$Storage;)Ljava/lang/String; .locals 1 .line 681 invoke-static {p1}, Lcom/ea/nimble/Persistence;->getPersistenceDirectory(Lcom/ea/nimble/Persistence$Storage;)Ljava/io/File; move-result-object p1 if-nez p1, :cond_0 const/4 p0, 0x0 goto :goto_0 .line 682 :cond_0 new-instance v0, Ljava/lang/StringBuilder; invoke-direct {v0}, Ljava/lang/StringBuilder;->()V invoke-virtual {v0, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder; sget-object p1, Ljava/io/File;->separator:Ljava/lang/String; invoke-virtual {v0, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v0, p0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; const-string p0, ".dat" invoke-virtual {v0, p0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object p0 :goto_0 return-object p0 .end method .method public static getPersistencePath(Ljava/lang/String;Lcom/ea/nimble/Persistence$Storage;Landroid/content/Context;)Ljava/lang/String; .locals 0 .line 687 invoke-static {p1, p2}, Lcom/ea/nimble/Persistence;->getPersistenceDirectory(Lcom/ea/nimble/Persistence$Storage;Landroid/content/Context;)Ljava/io/File; move-result-object p1 if-nez p1, :cond_0 const/4 p0, 0x0 goto :goto_0 .line 688 :cond_0 new-instance p2, Ljava/lang/StringBuilder; invoke-direct {p2}, Ljava/lang/StringBuilder;->()V invoke-virtual {p2, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder; sget-object p1, Ljava/io/File;->separator:Ljava/lang/String; invoke-virtual {p2, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {p2, p0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; const-string p0, ".dat" invoke-virtual {p2, p0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {p2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object p0 :goto_0 return-object p0 .end method .method private synthetic lambda$new$0()V .locals 0 .line 44 invoke-virtual {p0}, Lcom/ea/nimble/Persistence;->synchronize()V return-void .end method .method private loadPersistenceData(ZLandroid/content/Context;)V .locals 8 .line 452 invoke-static {p0}, Lcom/ea/nimble/Log$Helper;->LOGFUNC(Ljava/lang/Object;)V .line 453 invoke-virtual {p0, p2}, Lcom/ea/nimble/Persistence;->getPersistencePath(Landroid/content/Context;)Ljava/lang/String; move-result-object p2 if-nez p2, :cond_0 return-void .line 460 :cond_0 new-instance v0, Ljava/io/File; invoke-direct {v0, p2}, Ljava/io/File;->(Ljava/lang/String;)V .line 461 invoke-virtual {v0}, Ljava/io/File;->exists()Z move-result v1 if-eqz v1, :cond_7 invoke-virtual {v0}, Ljava/io/File;->length()J move-result-wide v1 const-wide/16 v3, 0x0 cmp-long v1, v1, v3 if-nez v1, :cond_1 goto/16 :goto_4 .line 467 :cond_1 invoke-virtual {v0}, Ljava/io/File;->length()J move-result-wide v1 invoke-static {v1, v2}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long; move-result-object v1 filled-new-array {v1}, [Ljava/lang/Object; move-result-object v1 const-string v2, "Loading persistence file size %d" invoke-static {p0, v2, v1}, Lcom/ea/nimble/Log$Helper;->LOGD(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V const/4 v1, 0x1 const/4 v2, 0x0 const/4 v3, 0x2 const/4 v4, 0x0 .line 474 :try_start_0 new-instance v5, Ljava/io/FileInputStream; invoke-direct {v5, v0}, Ljava/io/FileInputStream;->(Ljava/io/File;)V :try_end_0 .catch Ljava/lang/Exception; {:try_start_0 .. :try_end_0} :catch_1 .catchall {:try_start_0 .. :try_end_0} :catchall_1 .line 475 :try_start_1 new-instance v0, Ljava/io/ObjectInputStream; invoke-direct {v0, v5}, Ljava/io/ObjectInputStream;->(Ljava/io/InputStream;)V .line 476 invoke-virtual {v0}, Ljava/io/ObjectInputStream;->readInt()I move-result v4 const/16 v6, 0x65 if-ne v4, v6, :cond_4 .line 482 invoke-virtual {v0}, Ljava/io/ObjectInputStream;->readBoolean()Z move-result v4 iput-boolean v4, p0, Lcom/ea/nimble/Persistence;->m_encryption:Z .line 483 invoke-virtual {v0}, Ljava/io/ObjectInputStream;->readBoolean()Z move-result v4 iput-boolean v4, p0, Lcom/ea/nimble/Persistence;->m_backUp:Z if-nez p1, :cond_3 .line 487 new-instance p1, Ljava/io/BufferedInputStream; invoke-direct {p1, v5}, Ljava/io/BufferedInputStream;->(Ljava/io/InputStream;)V iget-boolean v4, p0, Lcom/ea/nimble/Persistence;->m_encryption:Z if-eqz v4, :cond_2 iget-object v4, p0, Lcom/ea/nimble/Persistence;->m_encryptor:Lcom/ea/nimble/Encryptor; .line 491 invoke-virtual {v4, p1}, Lcom/ea/nimble/Encryptor;->decryptInputStream(Ljava/io/InputStream;)Ljava/io/ObjectInputStream; move-result-object p1 goto :goto_0 :catchall_0 move-exception p1 move-object v4, v5 goto :goto_3 :catch_0 move-exception p1 move-object v4, v5 goto :goto_1 .line 495 :cond_2 new-instance v4, Ljava/io/ObjectInputStream; invoke-direct {v4, p1}, Ljava/io/ObjectInputStream;->(Ljava/io/InputStream;)V move-object p1, v4 .line 497 :goto_0 invoke-virtual {p1}, Ljava/io/ObjectInputStream;->readObject()Ljava/lang/Object; move-result-object v4 check-cast v4, Ljava/util/Map; iput-object v4, p0, Lcom/ea/nimble/Persistence;->m_content:Ljava/util/Map; const-string v4, "Persistence file for id[%s] restored from storage %s" new-array v6, v3, [Ljava/lang/Object; iget-object v7, p0, Lcom/ea/nimble/Persistence;->m_identifier:Ljava/lang/String; aput-object v7, v6, v2 iget-object v7, p0, Lcom/ea/nimble/Persistence;->m_storage:Lcom/ea/nimble/Persistence$Storage; .line 498 invoke-virtual {v7}, Ljava/lang/Object;->toString()Ljava/lang/String; move-result-object v7 aput-object v7, v6, v1 invoke-static {p0, v4, v6}, Lcom/ea/nimble/Log$Helper;->LOGD(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V .line 499 invoke-virtual {p1}, Ljava/io/ObjectInputStream;->close()V .line 501 :cond_3 invoke-virtual {v0}, Ljava/io/ObjectInputStream;->close()V :try_end_1 .catch Ljava/lang/Exception; {:try_start_1 .. :try_end_1} :catch_0 .catchall {:try_start_1 .. :try_end_1} :catchall_0 .line 514 :try_start_2 invoke-virtual {v5}, Ljava/io/FileInputStream;->close()V :try_end_2 .catch Ljava/io/IOException; {:try_start_2 .. :try_end_2} :catch_2 goto :goto_2 .line 479 :cond_4 :try_start_3 new-instance p1, Ljava/io/InvalidClassException; const-string v0, "com.ea.nimble.Persistence" const-string v4, "Persistence version doesn\'t match" invoke-direct {p1, v0, v4}, Ljava/io/InvalidClassException;->(Ljava/lang/String;Ljava/lang/String;)V throw p1 :try_end_3 .catch Ljava/lang/Exception; {:try_start_3 .. :try_end_3} :catch_0 .catchall {:try_start_3 .. :try_end_3} :catchall_0 :catchall_1 move-exception p1 goto :goto_3 :catch_1 move-exception p1 :goto_1 :try_start_4 const-string v0, "Can\'t read persistence (%s) file, %s: %s" const/4 v5, 0x3 new-array v5, v5, [Ljava/lang/Object; iget-object v6, p0, Lcom/ea/nimble/Persistence;->m_identifier:Ljava/lang/String; aput-object v6, v5, v2 aput-object p2, v5, v1 .line 505 invoke-virtual {p1}, Ljava/lang/Object;->toString()Ljava/lang/String; move-result-object p2 aput-object p2, v5, v3 invoke-static {p0, v0, v5}, Lcom/ea/nimble/Log$Helper;->LOGE(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V .line 506 invoke-virtual {p1}, Ljava/lang/Throwable;->printStackTrace()V :try_end_4 .catchall {:try_start_4 .. :try_end_4} :catchall_1 if-eqz v4, :cond_5 .line 514 :try_start_5 invoke-virtual {v4}, Ljava/io/FileInputStream;->close()V :try_end_5 .catch Ljava/io/IOException; {:try_start_5 .. :try_end_5} :catch_2 :catch_2 :cond_5 :goto_2 return-void :goto_3 if-eqz v4, :cond_6 :try_start_6 invoke-virtual {v4}, Ljava/io/FileInputStream;->close()V :try_end_6 .catch Ljava/io/IOException; {:try_start_6 .. :try_end_6} :catch_3 .line 520 :catch_3 :cond_6 throw p1 :cond_7 :goto_4 iget-object p1, p0, Lcom/ea/nimble/Persistence;->m_identifier:Ljava/lang/String; iget-object p2, p0, Lcom/ea/nimble/Persistence;->m_storage:Lcom/ea/nimble/Persistence$Storage; .line 463 invoke-virtual {p2}, Ljava/lang/Object;->toString()Ljava/lang/String; move-result-object p2 filled-new-array {p1, p2}, [Ljava/lang/Object; move-result-object p1 const-string p2, "No persistence file for id[%s] to restore from storage %s" invoke-static {p0, p2, p1}, Lcom/ea/nimble/Log$Helper;->LOGD(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V return-void .end method .method private putValue(Ljava/lang/String;Ljava/io/Serializable;)V .locals 2 .annotation system Ldalvik/annotation/Throws; value = { Ljava/io/IOException; } .end annotation .line 436 invoke-static {p0}, Lcom/ea/nimble/Log$Helper;->LOGFUNC(Ljava/lang/Object;)V .line 437 new-instance v0, Ljava/io/ByteArrayOutputStream; invoke-direct {v0}, Ljava/io/ByteArrayOutputStream;->()V .line 438 new-instance v1, Ljava/io/ObjectOutputStream; invoke-direct {v1, v0}, Ljava/io/ObjectOutputStream;->(Ljava/io/OutputStream;)V .line 439 invoke-virtual {v1, p2}, Ljava/io/ObjectOutputStream;->writeObject(Ljava/lang/Object;)V .line 440 invoke-virtual {v1}, Ljava/io/ObjectOutputStream;->close()V .line 441 invoke-virtual {v0}, Ljava/io/ByteArrayOutputStream;->toByteArray()[B move-result-object p2 iget-object v0, p0, Lcom/ea/nimble/Persistence;->m_content:Ljava/util/Map; .line 442 invoke-interface {v0, p1}, Ljava/util/Map;->get(Ljava/lang/Object;)Ljava/lang/Object; move-result-object v0 check-cast v0, [B invoke-static {p2, v0}, Ljava/util/Arrays;->equals([B[B)Z move-result v0 if-nez v0, :cond_0 iget-object v0, p0, Lcom/ea/nimble/Persistence;->m_content:Ljava/util/Map; .line 444 invoke-interface {v0, p1, p2}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object; .line 445 invoke-direct {p0}, Lcom/ea/nimble/Persistence;->flagChange()V :cond_0 return-void .end method .method private savePersistenceData()V .locals 13 const-string v0, "Fail to save persistence file for id[%s] in storage %s: %s" .line 525 invoke-static {p0}, Lcom/ea/nimble/Log$Helper;->LOGFUNC(Ljava/lang/Object;)V const/4 v1, 0x0 .line 526 invoke-virtual {p0, v1}, Lcom/ea/nimble/Persistence;->getPersistencePath(Landroid/content/Context;)Ljava/lang/String; move-result-object v2 if-nez v2, :cond_0 return-void .line 531 :cond_0 new-instance v3, Ljava/io/File; invoke-direct {v3, v2}, Ljava/io/File;->(Ljava/lang/String;)V const/4 v2, 0x3 const/4 v4, 0x1 const/4 v5, 0x0 const/4 v6, 0x2 .line 535 :try_start_0 new-instance v7, Ljava/io/FileOutputStream; invoke-direct {v7, v3}, Ljava/io/FileOutputStream;->(Ljava/io/File;)V :try_end_0 .catch Ljava/io/IOException; {:try_start_0 .. :try_end_0} :catch_3 .catch Ljava/security/GeneralSecurityException; {:try_start_0 .. :try_end_0} :catch_2 .catchall {:try_start_0 .. :try_end_0} :catchall_1 .line 536 :try_start_1 new-instance v1, Ljava/io/ObjectOutputStream; invoke-direct {v1, v7}, Ljava/io/ObjectOutputStream;->(Ljava/io/OutputStream;)V const/16 v8, 0x65 .line 537 invoke-virtual {v1, v8}, Ljava/io/ObjectOutputStream;->writeInt(I)V iget-boolean v8, p0, Lcom/ea/nimble/Persistence;->m_encryption:Z .line 538 invoke-virtual {v1, v8}, Ljava/io/ObjectOutputStream;->writeBoolean(Z)V iget-boolean v8, p0, Lcom/ea/nimble/Persistence;->m_backUp:Z .line 539 invoke-virtual {v1, v8}, Ljava/io/ObjectOutputStream;->writeBoolean(Z)V .line 540 invoke-virtual {v1}, Ljava/io/ObjectOutputStream;->flush()V .line 541 new-instance v8, Ljava/io/BufferedOutputStream; invoke-direct {v8, v7}, Ljava/io/BufferedOutputStream;->(Ljava/io/OutputStream;)V iget-boolean v9, p0, Lcom/ea/nimble/Persistence;->m_encryption:Z if-eqz v9, :cond_1 iget-object v9, p0, Lcom/ea/nimble/Persistence;->m_encryptor:Lcom/ea/nimble/Encryptor; .line 545 invoke-virtual {v9, v8}, Lcom/ea/nimble/Encryptor;->encryptOutputStream(Ljava/io/OutputStream;)Ljava/io/ObjectOutputStream; move-result-object v8 goto :goto_0 :catchall_0 move-exception v0 move-object v1, v7 goto/16 :goto_5 :catch_0 move-exception v1 goto :goto_2 :catch_1 move-exception v1 goto :goto_3 .line 549 :cond_1 new-instance v9, Ljava/io/ObjectOutputStream; invoke-direct {v9, v8}, Ljava/io/ObjectOutputStream;->(Ljava/io/OutputStream;)V move-object v8, v9 :goto_0 iget-object v9, p0, Lcom/ea/nimble/Persistence;->m_content:Ljava/util/Map; .line 551 invoke-virtual {v8, v9}, Ljava/io/ObjectOutputStream;->writeObject(Ljava/lang/Object;)V const-string v9, "Synchronize persistence for id[%s] in storage %s" new-array v10, v6, [Ljava/lang/Object; iget-object v11, p0, Lcom/ea/nimble/Persistence;->m_identifier:Ljava/lang/String; aput-object v11, v10, v5 iget-object v11, p0, Lcom/ea/nimble/Persistence;->m_storage:Lcom/ea/nimble/Persistence$Storage; .line 552 invoke-virtual {v11}, Ljava/lang/Object;->toString()Ljava/lang/String; move-result-object v11 aput-object v11, v10, v4 invoke-static {p0, v9, v10}, Lcom/ea/nimble/Log$Helper;->LOGD(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V .line 553 invoke-virtual {v8}, Ljava/io/ObjectOutputStream;->close()V .line 554 invoke-virtual {v1}, Ljava/io/ObjectOutputStream;->close()V :try_end_1 .catch Ljava/io/IOException; {:try_start_1 .. :try_end_1} :catch_1 .catch Ljava/security/GeneralSecurityException; {:try_start_1 .. :try_end_1} :catch_0 .catchall {:try_start_1 .. :try_end_1} :catchall_0 .line 572 :goto_1 :try_start_2 invoke-virtual {v7}, Ljava/io/FileOutputStream;->close()V :try_end_2 .catch Ljava/io/IOException; {:try_start_2 .. :try_end_2} :catch_4 goto :goto_4 :catchall_1 move-exception v0 goto :goto_5 :catch_2 move-exception v7 move-object v12, v7 move-object v7, v1 move-object v1, v12 goto :goto_2 :catch_3 move-exception v7 move-object v12, v7 move-object v7, v1 move-object v1, v12 goto :goto_3 :goto_2 :try_start_3 new-array v2, v2, [Ljava/lang/Object; iget-object v8, p0, Lcom/ea/nimble/Persistence;->m_identifier:Ljava/lang/String; aput-object v8, v2, v5 iget-object v5, p0, Lcom/ea/nimble/Persistence;->m_storage:Lcom/ea/nimble/Persistence$Storage; .line 563 invoke-virtual {v5}, Ljava/lang/Object;->toString()Ljava/lang/String; move-result-object v5 aput-object v5, v2, v4 invoke-virtual {v1}, Ljava/lang/Object;->toString()Ljava/lang/String; move-result-object v4 aput-object v4, v2, v6 invoke-static {p0, v0, v2}, Lcom/ea/nimble/Log$Helper;->LOGE(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V .line 564 invoke-virtual {v1}, Ljava/lang/Throwable;->printStackTrace()V if-eqz v7, :cond_2 goto :goto_1 :goto_3 new-array v2, v2, [Ljava/lang/Object; iget-object v8, p0, Lcom/ea/nimble/Persistence;->m_identifier:Ljava/lang/String; aput-object v8, v2, v5 iget-object v5, p0, Lcom/ea/nimble/Persistence;->m_storage:Lcom/ea/nimble/Persistence$Storage; .line 558 invoke-virtual {v5}, Ljava/lang/Object;->toString()Ljava/lang/String; move-result-object v5 aput-object v5, v2, v4 invoke-virtual {v1}, Ljava/lang/Object;->toString()Ljava/lang/String; move-result-object v4 aput-object v4, v2, v6 invoke-static {p0, v0, v2}, Lcom/ea/nimble/Log$Helper;->LOGE(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V .line 559 invoke-virtual {v1}, Ljava/lang/Throwable;->printStackTrace()V :try_end_3 .catchall {:try_start_3 .. :try_end_3} :catchall_0 if-eqz v7, :cond_2 goto :goto_1 .line 579 :catch_4 :cond_2 :goto_4 invoke-virtual {v3}, Ljava/io/File;->length()J move-result-wide v0 invoke-static {v0, v1}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long; move-result-object v0 filled-new-array {v0}, [Ljava/lang/Object; move-result-object v0 const-string v1, "Saving persistence file size %d" invoke-static {p0, v1, v0}, Lcom/ea/nimble/Log$Helper;->LOGD(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V return-void :goto_5 if-eqz v1, :cond_3 .line 572 :try_start_4 invoke-virtual {v1}, Ljava/io/FileOutputStream;->close()V :try_end_4 .catch Ljava/io/IOException; {:try_start_4 .. :try_end_4} :catch_5 .line 578 :catch_5 :cond_3 throw v0 .end method # virtual methods .method public varargs addEntries([Ljava/lang/Object;)V .locals 6 .line 270 invoke-static {p0}, Lcom/ea/nimble/Log$Helper;->LOGPUBLICFUNC(Ljava/lang/Object;)V sget-object v0, Lcom/ea/nimble/Persistence;->s_dataLock:Ljava/lang/Object; .line 271 monitor-enter v0 const/4 v1, 0x0 const/4 v2, 0x0 move v3, v1 .line 274 :goto_0 :try_start_0 array-length v4, p1 if-ge v3, v4, :cond_2 .line 276 rem-int/lit8 v4, v3, 0x2 :try_end_0 .catchall {:try_start_0 .. :try_end_0} :catchall_0 const/4 v5, 0x1 if-nez v4, :cond_1 .line 280 :try_start_1 aget-object v2, p1, v3 check-cast v2, Ljava/lang/String; .line 281 invoke-static {v2}, Lcom/ea/nimble/Utility;->validString(Ljava/lang/String;)Z move-result v4 if-eqz v4, :cond_0 goto :goto_1 .line 283 :cond_0 new-instance p1, Ljava/lang/RuntimeException; const-string v2, "Invalid key" invoke-direct {p1, v2}, Ljava/lang/RuntimeException;->(Ljava/lang/String;)V throw p1 :try_end_1 .catch Ljava/lang/Exception; {:try_start_1 .. :try_end_1} :catch_0 .catchall {:try_start_1 .. :try_end_1} :catchall_0 :catchall_0 move-exception p1 goto :goto_2 :catch_0 :try_start_2 const-string p1, "Invalid key in NimblePersistence.addEntries at index %d, not a string" new-array v2, v5, [Ljava/lang/Object; .line 289 invoke-static {v3}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer; move-result-object v3 aput-object v3, v2, v1 invoke-static {p0, p1, v2}, Lcom/ea/nimble/Log$Helper;->LOGF(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V .line 290 monitor-exit v0 :try_end_2 .catchall {:try_start_2 .. :try_end_2} :catchall_0 return-void .line 298 :cond_1 :try_start_3 aget-object v4, p1, v3 check-cast v4, Ljava/io/Serializable; .line 299 invoke-direct {p0, v2, v4}, Lcom/ea/nimble/Persistence;->putValue(Ljava/lang/String;Ljava/io/Serializable;)V :try_end_3 .catch Ljava/lang/Exception; {:try_start_3 .. :try_end_3} :catch_1 .catchall {:try_start_3 .. :try_end_3} :catchall_0 :goto_1 add-int/lit8 v3, v3, 0x1 goto :goto_0 :catch_1 :try_start_4 const-string p1, "Invalid value for key %s" filled-new-array {v2}, [Ljava/lang/Object; move-result-object v2 .line 303 invoke-static {p0, p1, v2}, Lcom/ea/nimble/Log$Helper;->LOGD(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V const-string p1, "Invalid value in NimblePersistence.addEntries at index %d" new-array v2, v5, [Ljava/lang/Object; .line 304 invoke-static {v3}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer; move-result-object v3 aput-object v3, v2, v1 invoke-static {p0, p1, v2}, Lcom/ea/nimble/Log$Helper;->LOGF(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V .line 305 monitor-exit v0 return-void .line 309 :cond_2 monitor-exit v0 return-void :goto_2 monitor-exit v0 :try_end_4 .catchall {:try_start_4 .. :try_end_4} :catchall_0 throw p1 .end method .method public addEntriesFromMap(Ljava/util/Map;)V .locals 5 .annotation system Ldalvik/annotation/Signature; value = { "(", "Ljava/util/Map<", "Ljava/lang/String;", "Ljava/io/Serializable;", ">;)V" } .end annotation .line 321 invoke-static {p0}, Lcom/ea/nimble/Log$Helper;->LOGPUBLICFUNC(Ljava/lang/Object;)V sget-object v0, Lcom/ea/nimble/Persistence;->s_dataLock:Ljava/lang/Object; .line 322 monitor-enter v0 .line 325 :try_start_0 invoke-interface {p1}, Ljava/util/Map;->entrySet()Ljava/util/Set; move-result-object p1 invoke-interface {p1}, Ljava/util/Set;->iterator()Ljava/util/Iterator; move-result-object p1 :goto_0 invoke-interface {p1}, Ljava/util/Iterator;->hasNext()Z move-result v1 if-eqz v1, :cond_2 invoke-interface {p1}, Ljava/util/Iterator;->next()Ljava/lang/Object; move-result-object v1 check-cast v1, Ljava/util/Map$Entry; .line 327 invoke-interface {v1}, Ljava/util/Map$Entry;->getKey()Ljava/lang/Object; move-result-object v2 check-cast v2, Ljava/lang/String; .line 328 invoke-static {v2}, Lcom/ea/nimble/Utility;->validString(Ljava/lang/String;)Z move-result v3 const/4 v4, 0x0 if-nez v3, :cond_0 const-string v1, "Invalid key %s" filled-new-array {v2}, [Ljava/lang/Object; move-result-object v2 .line 330 invoke-static {p0, v1, v2}, Lcom/ea/nimble/Log$Helper;->LOGD(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V const-string v1, "Invalid key in NimblePersistence.addEntriesInDictionary, not a string, skip it" new-array v2, v4, [Ljava/lang/Object; .line 331 invoke-static {p0, v1, v2}, Lcom/ea/nimble/Log$Helper;->LOGE(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V goto :goto_0 :catchall_0 move-exception p1 goto :goto_1 .line 334 :cond_0 invoke-interface {v1}, Ljava/util/Map$Entry;->getValue()Ljava/lang/Object; move-result-object v1 check-cast v1, Ljava/io/Serializable; :try_end_0 .catchall {:try_start_0 .. :try_end_0} :catchall_0 if-eqz v1, :cond_1 .line 339 :try_start_1 invoke-direct {p0, v2, v1}, Lcom/ea/nimble/Persistence;->putValue(Ljava/lang/String;Ljava/io/Serializable;)V :try_end_1 .catch Ljava/io/IOException; {:try_start_1 .. :try_end_1} :catch_0 .catchall {:try_start_1 .. :try_end_1} :catchall_0 goto :goto_0 :catch_0 :cond_1 :try_start_2 const-string v1, "Invalid key %s" filled-new-array {v2}, [Ljava/lang/Object; move-result-object v2 .line 347 invoke-static {p0, v1, v2}, Lcom/ea/nimble/Log$Helper;->LOGD(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V const-string v1, "Invalid value in NimblePersistence.addEntries for key" new-array v2, v4, [Ljava/lang/Object; .line 348 invoke-static {p0, v1, v2}, Lcom/ea/nimble/Log$Helper;->LOGE(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V goto :goto_0 .line 351 :cond_2 monitor-exit v0 return-void :goto_1 monitor-exit v0 :try_end_2 .catchall {:try_start_2 .. :try_end_2} :catchall_0 throw p1 .end method .method public clean()V .locals 6 .line 359 invoke-static {p0}, Lcom/ea/nimble/Log$Helper;->LOGPUBLICFUNC(Ljava/lang/Object;)V sget-object v0, Lcom/ea/nimble/Persistence;->s_dataLock:Ljava/lang/Object; .line 360 monitor-enter v0 :try_start_0 iget-object v1, p0, Lcom/ea/nimble/Persistence;->m_content:Ljava/util/Map; .line 362 invoke-interface {v1}, Ljava/util/Map;->clear()V .line 363 invoke-direct {p0}, Lcom/ea/nimble/Persistence;->clearSynchronizeTimer()V const/4 v1, 0x0 .line 365 invoke-virtual {p0, v1}, Lcom/ea/nimble/Persistence;->getPersistencePath(Landroid/content/Context;)Ljava/lang/String; move-result-object v1 const/4 v2, 0x1 const/4 v3, 0x0 const/4 v4, 0x2 if-eqz v1, :cond_0 .line 368 new-instance v5, Ljava/io/File; invoke-direct {v5, v1}, Ljava/io/File;->(Ljava/lang/String;)V .line 369 invoke-virtual {v5}, Ljava/io/File;->exists()Z move-result v1 if-eqz v1, :cond_1 invoke-virtual {v5}, Ljava/io/File;->delete()Z move-result v1 if-nez v1, :cond_1 const-string v1, "Fail to clean persistence file for id[%s] in storage %s" new-array v4, v4, [Ljava/lang/Object; iget-object v5, p0, Lcom/ea/nimble/Persistence;->m_identifier:Ljava/lang/String; aput-object v5, v4, v3 iget-object v3, p0, Lcom/ea/nimble/Persistence;->m_storage:Lcom/ea/nimble/Persistence$Storage; .line 371 invoke-virtual {v3}, Ljava/lang/Object;->toString()Ljava/lang/String; move-result-object v3 aput-object v3, v4, v2 invoke-static {p0, v1, v4}, Lcom/ea/nimble/Log$Helper;->LOGE(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V goto :goto_0 :catchall_0 move-exception v1 goto :goto_1 :cond_0 const-string v1, "Could not get path to persistence for id[%s] in storage %s" new-array v4, v4, [Ljava/lang/Object; iget-object v5, p0, Lcom/ea/nimble/Persistence;->m_identifier:Ljava/lang/String; aput-object v5, v4, v3 iget-object v3, p0, Lcom/ea/nimble/Persistence;->m_storage:Lcom/ea/nimble/Persistence$Storage; .line 376 invoke-virtual {v3}, Ljava/lang/Object;->toString()Ljava/lang/String; move-result-object v3 aput-object v3, v4, v2 invoke-static {p0, v1, v4}, Lcom/ea/nimble/Log$Helper;->LOGE(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V .line 378 :cond_1 :goto_0 monitor-exit v0 return-void :goto_1 monitor-exit v0 :try_end_0 .catchall {:try_start_0 .. :try_end_0} :catchall_0 throw v1 .end method .method public getBackUp()Z .locals 1 .line 108 invoke-static {p0}, Lcom/ea/nimble/Log$Helper;->LOGPUBLICFUNC(Ljava/lang/Object;)V iget-boolean v0, p0, Lcom/ea/nimble/Persistence;->m_backUp:Z return v0 .end method .method public getBoolValue(Ljava/lang/String;)Z .locals 3 .line 241 invoke-static {p0}, Lcom/ea/nimble/Log$Helper;->LOGPUBLICFUNC(Ljava/lang/Object;)V .line 242 invoke-virtual {p0, p1}, Lcom/ea/nimble/Persistence;->getValue(Ljava/lang/String;)Ljava/io/Serializable; move-result-object p1 const/4 v0, 0x0 if-eqz p1, :cond_0 .line 247 :try_start_0 move-object v1, p1 check-cast v1, Ljava/lang/Boolean; invoke-virtual {v1}, Ljava/lang/Boolean;->booleanValue()Z move-result p1 :try_end_0 .catch Ljava/lang/ClassCastException; {:try_start_0 .. :try_end_0} :catch_0 return p1 .line 252 :catch_0 new-instance v1, Ljava/lang/StringBuilder; invoke-direct {v1}, Ljava/lang/StringBuilder;->()V const-string v2, "Invalid value is " invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {p1}, Ljava/lang/Object;->getClass()Ljava/lang/Class; move-result-object p1 invoke-virtual {p1}, Ljava/lang/Class;->getName()Ljava/lang/String; move-result-object p1 invoke-virtual {v1, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object p1 new-array v1, v0, [Ljava/lang/Object; invoke-static {p0, p1, v1}, Lcom/ea/nimble/Log$Helper;->LOGD(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V const-string p1, "Invalid value type for getBoolValue" new-array v1, v0, [Ljava/lang/Object; .line 253 invoke-static {p0, p1, v1}, Lcom/ea/nimble/Log$Helper;->LOGF(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V :cond_0 return v0 .end method .method public getEncryption()Z .locals 1 .line 92 invoke-static {p0}, Lcom/ea/nimble/Log$Helper;->LOGPUBLICFUNC(Ljava/lang/Object;)V iget-boolean v0, p0, Lcom/ea/nimble/Persistence;->m_encryption:Z return v0 .end method .method public getIdentifier()Ljava/lang/String; .locals 1 .line 80 invoke-static {p0}, Lcom/ea/nimble/Log$Helper;->LOGPUBLICFUNC(Ljava/lang/Object;)V iget-object v0, p0, Lcom/ea/nimble/Persistence;->m_identifier:Ljava/lang/String; return-object v0 .end method .method public getLogSourceTitle()Ljava/lang/String; .locals 1 const-string v0, "Persistence" return-object v0 .end method .method public getPersistencePath(Landroid/content/Context;)Ljava/lang/String; .locals 2 iget-object v0, p0, Lcom/ea/nimble/Persistence;->m_persistencePath:Ljava/lang/String; if-nez v0, :cond_1 if-nez p1, :cond_0 iget-object p1, p0, Lcom/ea/nimble/Persistence;->m_identifier:Ljava/lang/String; iget-object v0, p0, Lcom/ea/nimble/Persistence;->m_storage:Lcom/ea/nimble/Persistence$Storage; .line 669 invoke-static {p1, v0}, Lcom/ea/nimble/Persistence;->getPersistencePath(Ljava/lang/String;Lcom/ea/nimble/Persistence$Storage;)Ljava/lang/String; move-result-object p1 iput-object p1, p0, Lcom/ea/nimble/Persistence;->m_persistencePath:Ljava/lang/String; goto :goto_0 :cond_0 iget-object v0, p0, Lcom/ea/nimble/Persistence;->m_identifier:Ljava/lang/String; iget-object v1, p0, Lcom/ea/nimble/Persistence;->m_storage:Lcom/ea/nimble/Persistence$Storage; .line 673 invoke-static {v0, v1, p1}, Lcom/ea/nimble/Persistence;->getPersistencePath(Ljava/lang/String;Lcom/ea/nimble/Persistence$Storage;Landroid/content/Context;)Ljava/lang/String; move-result-object p1 iput-object p1, p0, Lcom/ea/nimble/Persistence;->m_persistencePath:Ljava/lang/String; :cond_1 :goto_0 iget-object p1, p0, Lcom/ea/nimble/Persistence;->m_persistencePath:Ljava/lang/String; return-object p1 .end method .method public getStorage()Lcom/ea/nimble/Persistence$Storage; .locals 1 .line 86 invoke-static {p0}, Lcom/ea/nimble/Log$Helper;->LOGPUBLICFUNC(Ljava/lang/Object;)V iget-object v0, p0, Lcom/ea/nimble/Persistence;->m_storage:Lcom/ea/nimble/Persistence$Storage; return-object v0 .end method .method public getStringValue(Ljava/lang/String;)Ljava/lang/String; .locals 2 .line 225 invoke-static {p0}, Lcom/ea/nimble/Log$Helper;->LOGPUBLICFUNC(Ljava/lang/Object;)V .line 226 invoke-virtual {p0, p1}, Lcom/ea/nimble/Persistence;->getValue(Ljava/lang/String;)Ljava/io/Serializable; move-result-object p1 .line 229 :try_start_0 check-cast p1, Ljava/lang/String; :try_end_0 .catch Ljava/lang/ClassCastException; {:try_start_0 .. :try_end_0} :catch_0 return-object p1 .line 233 :catch_0 new-instance v0, Ljava/lang/StringBuilder; invoke-direct {v0}, Ljava/lang/StringBuilder;->()V const-string v1, "Invalid value is " invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {p1}, Ljava/lang/Object;->getClass()Ljava/lang/Class; move-result-object p1 invoke-virtual {p1}, Ljava/lang/Class;->getName()Ljava/lang/String; move-result-object p1 invoke-virtual {v0, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object p1 const/4 v0, 0x0 new-array v1, v0, [Ljava/lang/Object; invoke-static {p0, p1, v1}, Lcom/ea/nimble/Log$Helper;->LOGD(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V const-string p1, "Invalid value type for getStringValueCall" new-array v0, v0, [Ljava/lang/Object; .line 234 invoke-static {p0, p1, v0}, Lcom/ea/nimble/Log$Helper;->LOGF(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V const/4 p1, 0x0 return-object p1 .end method .method public getValue(Ljava/lang/String;)Ljava/io/Serializable; .locals 5 .line 200 invoke-static {p0}, Lcom/ea/nimble/Log$Helper;->LOGPUBLICFUNC(Ljava/lang/Object;)V sget-object v0, Lcom/ea/nimble/Persistence;->s_dataLock:Ljava/lang/Object; .line 201 monitor-enter v0 :try_start_0 iget-object v1, p0, Lcom/ea/nimble/Persistence;->m_content:Ljava/util/Map; .line 203 invoke-interface {v1, p1}, Ljava/util/Map;->get(Ljava/lang/Object;)Ljava/lang/Object; move-result-object v1 check-cast v1, [B const/4 v2, 0x0 if-nez v1, :cond_0 .line 206 monitor-exit v0 :try_end_0 .catchall {:try_start_0 .. :try_end_0} :catchall_0 return-object v2 :catchall_0 move-exception p1 goto :goto_0 .line 211 :cond_0 :try_start_1 new-instance v3, Ljava/io/ByteArrayInputStream; invoke-direct {v3, v1}, Ljava/io/ByteArrayInputStream;->([B)V .line 212 new-instance v1, Ljava/io/ObjectInputStream; invoke-direct {v1, v3}, Ljava/io/ObjectInputStream;->(Ljava/io/InputStream;)V .line 213 invoke-virtual {v1}, Ljava/io/ObjectInputStream;->readObject()Ljava/lang/Object; move-result-object v1 check-cast v1, Ljava/io/Serializable; :try_end_1 .catch Ljava/lang/Exception; {:try_start_1 .. :try_end_1} :catch_0 .catchall {:try_start_1 .. :try_end_1} :catchall_0 :try_start_2 monitor-exit v0 return-object v1 :catch_0 move-exception v1 .line 217 new-instance v3, Ljava/lang/StringBuilder; invoke-direct {v3}, Ljava/lang/StringBuilder;->()V const-string v4, "PERSIST: Exception getting value, " invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v3, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; const-string p1, ":" invoke-virtual {v3, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v3, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder; invoke-virtual {v3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object p1 const/4 v1, 0x0 new-array v1, v1, [Ljava/lang/Object; invoke-static {p0, p1, v1}, Lcom/ea/nimble/Log$Helper;->LOGD(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V .line 218 monitor-exit v0 return-object v2 .line 220 :goto_0 monitor-exit v0 :try_end_2 .catchall {:try_start_2 .. :try_end_2} :catchall_0 throw p1 .end method .method public hasKey(Ljava/lang/String;)Z .locals 2 .line 157 invoke-static {p0}, Lcom/ea/nimble/Log$Helper;->LOGPUBLICFUNC(Ljava/lang/Object;)V sget-object v0, Lcom/ea/nimble/Persistence;->s_dataLock:Ljava/lang/Object; .line 158 monitor-enter v0 :try_start_0 iget-object v1, p0, Lcom/ea/nimble/Persistence;->m_content:Ljava/util/Map; .line 160 invoke-interface {v1, p1}, Ljava/util/Map;->get(Ljava/lang/Object;)Ljava/lang/Object; move-result-object p1 if-eqz p1, :cond_0 const/4 p1, 0x1 goto :goto_0 :cond_0 const/4 p1, 0x0 :goto_0 monitor-exit v0 return p1 :catchall_0 move-exception p1 .line 161 monitor-exit v0 :try_end_0 .catchall {:try_start_0 .. :try_end_0} :catchall_0 throw p1 .end method .method public merge(Lcom/ea/nimble/Persistence;Lcom/ea/nimble/PersistenceService$PersistenceMergePolicy;)V .locals 3 .line 125 invoke-static {p0}, Lcom/ea/nimble/Log$Helper;->LOGFUNC(Ljava/lang/Object;)V .line 126 sget-object v0, Lcom/ea/nimble/Persistence$1;->$SwitchMap$com$ea$nimble$PersistenceService$PersistenceMergePolicy:[I invoke-virtual {p2}, Ljava/lang/Enum;->ordinal()I move-result p2 aget p2, v0, p2 const/4 v0, 0x1 if-eq p2, v0, :cond_3 const/4 v0, 0x2 if-eq p2, v0, :cond_2 const/4 v0, 0x3 if-eq p2, v0, :cond_0 goto :goto_1 .line 135 :cond_0 iget-object p2, p1, Lcom/ea/nimble/Persistence;->m_content:Ljava/util/Map; invoke-interface {p2}, Ljava/util/Map;->keySet()Ljava/util/Set; move-result-object p2 invoke-interface {p2}, Ljava/util/Set;->iterator()Ljava/util/Iterator; move-result-object p2 :cond_1 :goto_0 invoke-interface {p2}, Ljava/util/Iterator;->hasNext()Z move-result v0 if-eqz v0, :cond_4 invoke-interface {p2}, Ljava/util/Iterator;->next()Ljava/lang/Object; move-result-object v0 check-cast v0, Ljava/lang/String; iget-object v1, p0, Lcom/ea/nimble/Persistence;->m_content:Ljava/util/Map; .line 137 invoke-interface {v1, v0}, Ljava/util/Map;->get(Ljava/lang/Object;)Ljava/lang/Object; move-result-object v1 if-nez v1, :cond_1 iget-object v1, p0, Lcom/ea/nimble/Persistence;->m_content:Ljava/util/Map; .line 139 iget-object v2, p1, Lcom/ea/nimble/Persistence;->m_content:Ljava/util/Map; invoke-interface {v2, v0}, Ljava/util/Map;->get(Ljava/lang/Object;)Ljava/lang/Object; move-result-object v2 check-cast v2, [B invoke-interface {v1, v0, v2}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object; goto :goto_0 :cond_2 iget-object p2, p0, Lcom/ea/nimble/Persistence;->m_content:Ljava/util/Map; .line 132 iget-object p1, p1, Lcom/ea/nimble/Persistence;->m_content:Ljava/util/Map; invoke-interface {p2, p1}, Ljava/util/Map;->putAll(Ljava/util/Map;)V goto :goto_1 .line 129 :cond_3 new-instance p2, Ljava/util/HashMap; iget-object p1, p1, Lcom/ea/nimble/Persistence;->m_content:Ljava/util/Map; invoke-direct {p2, p1}, Ljava/util/HashMap;->(Ljava/util/Map;)V iput-object p2, p0, Lcom/ea/nimble/Persistence;->m_content:Ljava/util/Map; :cond_4 :goto_1 return-void .end method .method public restore(ZLandroid/content/Context;)V .locals 1 .line 148 invoke-static {p0}, Lcom/ea/nimble/Log$Helper;->LOGFUNC(Ljava/lang/Object;)V sget-object v0, Lcom/ea/nimble/Persistence;->s_dataLock:Ljava/lang/Object; .line 149 monitor-enter v0 .line 151 :try_start_0 invoke-direct {p0, p1, p2}, Lcom/ea/nimble/Persistence;->loadPersistenceData(ZLandroid/content/Context;)V .line 152 monitor-exit v0 return-void :catchall_0 move-exception p1 monitor-exit v0 :try_end_0 .catchall {:try_start_0 .. :try_end_0} :catchall_0 throw p1 .end method .method public setBackUp(Z)V .locals 2 .line 114 invoke-static {p0}, Lcom/ea/nimble/Log$Helper;->LOGPUBLICFUNC(Ljava/lang/Object;)V iget-object v0, p0, Lcom/ea/nimble/Persistence;->m_storage:Lcom/ea/nimble/Persistence$Storage; .line 115 sget-object v1, Lcom/ea/nimble/Persistence$Storage;->DOCUMENT:Lcom/ea/nimble/Persistence$Storage; if-eq v0, v1, :cond_0 .line 117 new-instance p1, Ljava/lang/StringBuilder; invoke-direct {p1}, Ljava/lang/StringBuilder;->()V const-string v0, "Error: Backup flag not supported for storage: " invoke-virtual {p1, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; iget-object v0, p0, Lcom/ea/nimble/Persistence;->m_storage:Lcom/ea/nimble/Persistence$Storage; invoke-virtual {p1, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder; invoke-virtual {p1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object p1 const/4 v0, 0x0 new-array v0, v0, [Ljava/lang/Object; invoke-static {p0, p1, v0}, Lcom/ea/nimble/Log$Helper;->LOGF(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V return-void :cond_0 iput-boolean p1, p0, Lcom/ea/nimble/Persistence;->m_backUp:Z return-void .end method .method public setEncryption(Z)V .locals 1 .line 98 invoke-static {p0}, Lcom/ea/nimble/Log$Helper;->LOGPUBLICFUNC(Ljava/lang/Object;)V iget-boolean v0, p0, Lcom/ea/nimble/Persistence;->m_encryption:Z if-eq p1, v0, :cond_0 iput-boolean p1, p0, Lcom/ea/nimble/Persistence;->m_encryption:Z .line 102 invoke-direct {p0}, Lcom/ea/nimble/Persistence;->flagChange()V :cond_0 return-void .end method .method public setValue(Ljava/lang/String;Ljava/io/Serializable;)V .locals 3 .line 166 invoke-static {p0}, Lcom/ea/nimble/Log$Helper;->LOGPUBLICFUNC(Ljava/lang/Object;)V sget-object v0, Lcom/ea/nimble/Persistence;->s_dataLock:Ljava/lang/Object; .line 167 monitor-enter v0 .line 169 :try_start_0 invoke-static {p1}, Lcom/ea/nimble/Utility;->validString(Ljava/lang/String;)Z move-result v1 const/4 v2, 0x0 if-nez v1, :cond_0 .line 171 new-instance p2, Ljava/lang/StringBuilder; invoke-direct {p2}, Ljava/lang/StringBuilder;->()V const-string v1, "Key " invoke-virtual {p2, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {p2, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; const-string p1, " is an invalid string" invoke-virtual {p2, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {p2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object p1 new-array p2, v2, [Ljava/lang/Object; invoke-static {p0, p1, p2}, Lcom/ea/nimble/Log$Helper;->LOGD(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V const-string p1, "NimblePersistence cannot accept an invalid string as key" new-array p2, v2, [Ljava/lang/Object; .line 172 invoke-static {p0, p1, p2}, Lcom/ea/nimble/Log$Helper;->LOGE(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V .line 173 monitor-exit v0 return-void :catchall_0 move-exception p1 goto :goto_1 :cond_0 if-nez p2, :cond_2 iget-object p2, p0, Lcom/ea/nimble/Persistence;->m_content:Ljava/util/Map; .line 178 invoke-interface {p2, p1}, Ljava/util/Map;->get(Ljava/lang/Object;)Ljava/lang/Object; move-result-object p2 if-eqz p2, :cond_1 iget-object p2, p0, Lcom/ea/nimble/Persistence;->m_content:Ljava/util/Map; .line 180 invoke-interface {p2, p1}, Ljava/util/Map;->remove(Ljava/lang/Object;)Ljava/lang/Object; .line 181 invoke-direct {p0}, Lcom/ea/nimble/Persistence;->flagChange()V .line 183 :cond_1 monitor-exit v0 :try_end_0 .catchall {:try_start_0 .. :try_end_0} :catchall_0 return-void .line 188 :cond_2 :try_start_1 invoke-direct {p0, p1, p2}, Lcom/ea/nimble/Persistence;->putValue(Ljava/lang/String;Ljava/io/Serializable;)V :try_end_1 .catch Ljava/io/IOException; {:try_start_1 .. :try_end_1} :catch_0 .catchall {:try_start_1 .. :try_end_1} :catchall_0 goto :goto_0 .line 192 :catch_0 :try_start_2 new-instance p1, Ljava/lang/StringBuilder; invoke-direct {p1}, Ljava/lang/StringBuilder;->()V const-string v1, "Value " invoke-virtual {p1, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {p1, p2}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder; const-string p2, " was unable to be archived" invoke-virtual {p1, p2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {p1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object p1 new-array p2, v2, [Ljava/lang/Object; invoke-static {p0, p1, p2}, Lcom/ea/nimble/Log$Helper;->LOGD(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V const-string p1, "NimblePersistence cannot archive value" new-array p2, v2, [Ljava/lang/Object; .line 193 invoke-static {p0, p1, p2}, Lcom/ea/nimble/Log$Helper;->LOGF(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V .line 195 :goto_0 monitor-exit v0 return-void :goto_1 monitor-exit v0 :try_end_2 .catchall {:try_start_2 .. :try_end_2} :catchall_0 throw p1 .end method .method public synchronize()V .locals 5 .line 390 invoke-static {p0}, Lcom/ea/nimble/Log$Helper;->LOGPUBLICFUNC(Ljava/lang/Object;)V sget-object v0, Lcom/ea/nimble/Persistence;->s_dataLock:Ljava/lang/Object; .line 391 monitor-enter v0 :try_start_0 iget-boolean v1, p0, Lcom/ea/nimble/Persistence;->m_changed:Z if-nez v1, :cond_0 const-string v1, "Not synchronizing to persistence for id[%s] since there is no change" const/4 v2, 0x1 new-array v2, v2, [Ljava/lang/Object; iget-object v3, p0, Lcom/ea/nimble/Persistence;->m_identifier:Ljava/lang/String; const/4 v4, 0x0 aput-object v3, v2, v4 .line 395 invoke-static {p0, v1, v2}, Lcom/ea/nimble/Log$Helper;->LOGD(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V .line 396 monitor-exit v0 return-void :catchall_0 move-exception v1 goto :goto_0 .line 400 :cond_0 invoke-direct {p0}, Lcom/ea/nimble/Persistence;->clearSynchronizeTimer()V .line 402 invoke-direct {p0}, Lcom/ea/nimble/Persistence;->savePersistenceData()V iget-boolean v1, p0, Lcom/ea/nimble/Persistence;->m_backUp:Z if-eqz v1, :cond_1 .line 406 new-instance v1, Landroid/app/backup/BackupManager; invoke-static {}, Lcom/ea/nimble/ApplicationEnvironment;->getComponent()Lcom/ea/nimble/IApplicationEnvironment; move-result-object v2 invoke-interface {v2}, Lcom/ea/nimble/IApplicationEnvironment;->getApplicationContext()Landroid/content/Context; move-result-object v2 invoke-direct {v1, v2}, Landroid/app/backup/BackupManager;->(Landroid/content/Context;)V invoke-virtual {v1}, Landroid/app/backup/BackupManager;->dataChanged()V .line 408 :cond_1 monitor-exit v0 return-void :goto_0 monitor-exit v0 :try_end_0 .catchall {:try_start_0 .. :try_end_0} :catchall_0 throw v1 .end method