Files
rr3-apk/smali_classes2/com/ea/nimble/PersistenceServiceImpl.smali
Daniel Elliott f3960ee359 Add Discord APKTool decompilation (Smali source for modding)
- Imported from https://github.com/supermegamestre/Project-Real-Resurrection-3
- APKTool decompilation (Smali bytecode) for modding and rebuilding APK
- Supports both 32-bit (armeabi-v7a) and 64-bit (arm64-v8a) architectures
- Includes full Smali source, resources, and native libraries
- Ready to rebuild APK after modifications with apktool b command
- Added comprehensive README-apktool.md with modding guide

This branch complements the JADX branches:
- Use JADX (main/discord-community) to UNDERSTAND code (readable Java)
- Use APKTool (this branch) to MODIFY and REBUILD APK (editable Smali)

Total: 44,417 files, 538.51 MB Smali source code
2026-02-18 16:13:44 -08:00

975 lines
25 KiB
Smali

.class public Lcom/ea/nimble/PersistenceServiceImpl;
.super Lcom/ea/nimble/Component;
.source "SourceFile"
# interfaces
.implements Lcom/ea/nimble/IPersistenceService;
.implements Lcom/ea/nimble/LogSource;
# instance fields
.field private m_encryptor:Lcom/ea/nimble/Encryptor;
.field protected m_persistences:Ljava/util/concurrent/ConcurrentMap;
.annotation system Ldalvik/annotation/Signature;
value = {
"Ljava/util/concurrent/ConcurrentMap<",
"Ljava/lang/String;",
"Lcom/ea/nimble/Persistence;",
">;"
}
.end annotation
.end field
# direct methods
.method public constructor <init>()V
.locals 0
.line 11
invoke-direct {p0}, Lcom/ea/nimble/Component;-><init>()V
return-void
.end method
.method private deletePath(Ljava/lang/String;)Z
.locals 4
.line 259
new-instance v0, Ljava/io/File;
invoke-direct {v0, p1}, Ljava/io/File;-><init>(Ljava/lang/String;)V
.line 260
invoke-virtual {v0}, Ljava/io/File;->isDirectory()Z
move-result p1
if-eqz p1, :cond_0
.line 262
invoke-virtual {v0}, Ljava/io/File;->list()[Ljava/lang/String;
move-result-object p1
const/4 v1, 0x0
.line 263
:goto_0
array-length v2, p1
if-ge v1, v2, :cond_0
.line 265
new-instance v2, Ljava/io/File;
aget-object v3, p1, v1
invoke-direct {v2, v0, v3}, Ljava/io/File;-><init>(Ljava/io/File;Ljava/lang/String;)V
.line 266
invoke-virtual {v2}, Ljava/io/File;->getPath()Ljava/lang/String;
move-result-object v2
invoke-direct {p0, v2}, Lcom/ea/nimble/PersistenceServiceImpl;->deletePath(Ljava/lang/String;)Z
add-int/lit8 v1, v1, 0x1
goto :goto_0
.line 271
:cond_0
invoke-virtual {v0}, Ljava/io/File;->delete()Z
move-result p1
return p1
.end method
.method private loadPersistenceById(Ljava/lang/String;Lcom/ea/nimble/Persistence$Storage;)Lcom/ea/nimble/Persistence;
.locals 5
.line 229
invoke-static {p0}, Lcom/ea/nimble/Log$Helper;->LOGFUNC(Ljava/lang/Object;)V
.line 230
sget-object v0, Lcom/ea/nimble/Persistence;->s_dataLock:Ljava/lang/Object;
monitor-enter v0
.line 232
:try_start_0
new-instance v1, Ljava/lang/StringBuilder;
invoke-direct {v1}, Ljava/lang/StringBuilder;-><init>()V
invoke-virtual {v1, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string v2, "-"
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {p2}, Ljava/lang/Object;->toString()Ljava/lang/String;
move-result-object v2
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v1
iget-object v2, p0, Lcom/ea/nimble/PersistenceServiceImpl;->m_persistences:Ljava/util/concurrent/ConcurrentMap;
.line 233
invoke-interface {v2, v1}, Ljava/util/Map;->get(Ljava/lang/Object;)Ljava/lang/Object;
move-result-object v2
check-cast v2, Lcom/ea/nimble/Persistence;
if-eqz v2, :cond_0
.line 236
monitor-exit v0
return-object v2
:catchall_0
move-exception p1
goto :goto_2
.line 239
:cond_0
invoke-static {p1, p2}, Lcom/ea/nimble/Persistence;->getPersistencePath(Ljava/lang/String;Lcom/ea/nimble/Persistence$Storage;)Ljava/lang/String;
move-result-object v2
const/4 v3, 0x0
if-eqz v2, :cond_1
.line 243
new-instance v4, Ljava/io/File;
invoke-direct {v4, v2}, Ljava/io/File;-><init>(Ljava/lang/String;)V
goto :goto_0
:cond_1
move-object v4, v3
:goto_0
if-eqz v4, :cond_3
.line 245
invoke-virtual {v4}, Ljava/io/File;->exists()Z
move-result v2
if-nez v2, :cond_2
goto :goto_1
.line 250
:cond_2
new-instance v2, Lcom/ea/nimble/Persistence;
iget-object v4, p0, Lcom/ea/nimble/PersistenceServiceImpl;->m_encryptor:Lcom/ea/nimble/Encryptor;
invoke-direct {v2, p1, p2, v4}, Lcom/ea/nimble/Persistence;-><init>(Ljava/lang/String;Lcom/ea/nimble/Persistence$Storage;Lcom/ea/nimble/Encryptor;)V
const/4 p1, 0x0
.line 251
invoke-virtual {v2, p1, v3}, Lcom/ea/nimble/Persistence;->restore(ZLandroid/content/Context;)V
iget-object p1, p0, Lcom/ea/nimble/PersistenceServiceImpl;->m_persistences:Ljava/util/concurrent/ConcurrentMap;
.line 252
invoke-interface {p1, v1, v2}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
.line 253
monitor-exit v0
return-object v2
.line 247
:cond_3
:goto_1
monitor-exit v0
return-object v3
.line 254
:goto_2
monitor-exit v0
:try_end_0
.catchall {:try_start_0 .. :try_end_0} :catchall_0
throw p1
.end method
.method private synchronize()V
.locals 2
.line 218
invoke-static {p0}, Lcom/ea/nimble/Log$Helper;->LOGFUNC(Ljava/lang/Object;)V
iget-object v0, p0, Lcom/ea/nimble/PersistenceServiceImpl;->m_persistences:Ljava/util/concurrent/ConcurrentMap;
.line 219
invoke-interface {v0}, Ljava/util/Map;->values()Ljava/util/Collection;
move-result-object v0
invoke-interface {v0}, Ljava/util/Collection;->iterator()Ljava/util/Iterator;
move-result-object v0
.line 220
:goto_0
invoke-interface {v0}, Ljava/util/Iterator;->hasNext()Z
move-result v1
if-eqz v1, :cond_0
.line 222
invoke-interface {v0}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v1
check-cast v1, Lcom/ea/nimble/Persistence;
.line 223
invoke-virtual {v1}, Lcom/ea/nimble/Persistence;->synchronize()V
goto :goto_0
:cond_0
return-void
.end method
# virtual methods
.method public cleanPersistenceReference(Ljava/lang/String;Lcom/ea/nimble/Persistence$Storage;)V
.locals 3
.line 97
invoke-static {p0}, Lcom/ea/nimble/Log$Helper;->LOGPUBLICFUNC(Ljava/lang/Object;)V
.line 98
invoke-static {p1}, Lcom/ea/nimble/Utility;->validString(Ljava/lang/String;)Z
move-result v0
if-nez v0, :cond_0
.line 100
new-instance p2, Ljava/lang/StringBuilder;
invoke-direct {p2}, Ljava/lang/StringBuilder;-><init>()V
const-string v0, "Invalid identifier "
invoke-virtual {p2, v0}, 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, " for persistence"
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
const/4 p2, 0x0
new-array p2, p2, [Ljava/lang/Object;
invoke-static {p0, p1, p2}, Lcom/ea/nimble/Log$Helper;->LOGF(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V
return-void
.line 104
:cond_0
sget-object v0, Lcom/ea/nimble/Persistence;->s_dataLock:Ljava/lang/Object;
monitor-enter v0
:try_start_0
iget-object v1, p0, Lcom/ea/nimble/PersistenceServiceImpl;->m_persistences:Ljava/util/concurrent/ConcurrentMap;
.line 106
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;
const-string p1, "-"
invoke-virtual {v2, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {p2}, Ljava/lang/Object;->toString()Ljava/lang/String;
move-result-object p1
invoke-virtual {v2, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p1
invoke-interface {v1, p1}, Ljava/util/Map;->remove(Ljava/lang/Object;)Ljava/lang/Object;
.line 107
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 getComponentId()Ljava/lang/String;
.locals 1
const-string v0, "com.ea.nimble.persistence"
return-object v0
.end method
.method public getLogSourceTitle()Ljava/lang/String;
.locals 1
const-string v0, "Persistence"
return-object v0
.end method
.method public getPersistence(Ljava/lang/String;Lcom/ea/nimble/Persistence$Storage;)Lcom/ea/nimble/Persistence;
.locals 4
.line 59
invoke-static {p0}, Lcom/ea/nimble/Log$Helper;->LOGPUBLICFUNC(Ljava/lang/Object;)V
.line 60
invoke-static {p1}, Lcom/ea/nimble/Utility;->validString(Ljava/lang/String;)Z
move-result v0
if-nez v0, :cond_0
.line 62
new-instance p2, Ljava/lang/StringBuilder;
invoke-direct {p2}, Ljava/lang/StringBuilder;-><init>()V
const-string v0, "Invalid identifier "
invoke-virtual {p2, v0}, 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, " for persistence"
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
const/4 p2, 0x0
new-array p2, p2, [Ljava/lang/Object;
invoke-static {p0, p1, p2}, Lcom/ea/nimble/Log$Helper;->LOGF(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V
const/4 p1, 0x0
return-object p1
.line 66
:cond_0
sget-object v0, Lcom/ea/nimble/Persistence;->s_dataLock:Ljava/lang/Object;
monitor-enter v0
.line 68
:try_start_0
invoke-direct {p0, p1, p2}, Lcom/ea/nimble/PersistenceServiceImpl;->loadPersistenceById(Ljava/lang/String;Lcom/ea/nimble/Persistence$Storage;)Lcom/ea/nimble/Persistence;
move-result-object v1
if-eqz v1, :cond_1
.line 71
monitor-exit v0
return-object v1
:catchall_0
move-exception p1
goto :goto_0
.line 75
:cond_1
new-instance v1, Lcom/ea/nimble/Persistence;
iget-object v2, p0, Lcom/ea/nimble/PersistenceServiceImpl;->m_encryptor:Lcom/ea/nimble/Encryptor;
invoke-direct {v1, p1, p2, v2}, Lcom/ea/nimble/Persistence;-><init>(Ljava/lang/String;Lcom/ea/nimble/Persistence$Storage;Lcom/ea/nimble/Encryptor;)V
iget-object v2, p0, Lcom/ea/nimble/PersistenceServiceImpl;->m_persistences:Ljava/util/concurrent/ConcurrentMap;
.line 76
new-instance v3, Ljava/lang/StringBuilder;
invoke-direct {v3}, Ljava/lang/StringBuilder;-><init>()V
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 {p2}, Ljava/lang/Object;->toString()Ljava/lang/String;
move-result-object p1
invoke-virtual {v3, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p1
invoke-interface {v2, p1, v1}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
.line 77
monitor-exit v0
return-object v1
.line 78
:goto_0
monitor-exit v0
:try_end_0
.catchall {:try_start_0 .. :try_end_0} :catchall_0
throw p1
.end method
.method public migratePersistence(Ljava/lang/String;Lcom/ea/nimble/Persistence$Storage;Ljava/lang/String;Lcom/ea/nimble/PersistenceService$PersistenceMergePolicy;)V
.locals 4
.line 170
invoke-static {p0}, Lcom/ea/nimble/Log$Helper;->LOGPUBLICFUNC(Ljava/lang/Object;)V
.line 171
invoke-static {p1}, Lcom/ea/nimble/Utility;->validString(Ljava/lang/String;)Z
move-result v0
const/4 v1, 0x0
if-eqz v0, :cond_6
invoke-static {p3}, Lcom/ea/nimble/Utility;->validString(Ljava/lang/String;)Z
move-result v0
if-nez v0, :cond_0
goto/16 :goto_3
.line 177
:cond_0
sget-object v0, Lcom/ea/nimble/Persistence;->s_dataLock:Ljava/lang/Object;
monitor-enter v0
.line 179
:try_start_0
new-instance v2, Ljava/lang/StringBuilder;
invoke-direct {v2}, Ljava/lang/StringBuilder;-><init>()V
invoke-virtual {v2, p3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string v3, "-"
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {p2}, Ljava/lang/Object;->toString()Ljava/lang/String;
move-result-object v3
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v2
.line 180
invoke-direct {p0, p1, p2}, Lcom/ea/nimble/PersistenceServiceImpl;->loadPersistenceById(Ljava/lang/String;Lcom/ea/nimble/Persistence$Storage;)Lcom/ea/nimble/Persistence;
move-result-object p1
if-nez p1, :cond_4
.line 183
sget-object p1, Lcom/ea/nimble/PersistenceService$PersistenceMergePolicy;->OVERWRITE:Lcom/ea/nimble/PersistenceService$PersistenceMergePolicy;
if-ne p4, p1, :cond_3
iget-object p1, p0, Lcom/ea/nimble/PersistenceServiceImpl;->m_persistences:Ljava/util/concurrent/ConcurrentMap;
.line 185
invoke-interface {p1, v2}, Ljava/util/Map;->remove(Ljava/lang/Object;)Ljava/lang/Object;
.line 187
invoke-static {p3, p2}, Lcom/ea/nimble/Persistence;->getPersistencePath(Ljava/lang/String;Lcom/ea/nimble/Persistence$Storage;)Ljava/lang/String;
move-result-object p1
if-eqz p1, :cond_1
.line 191
new-instance p2, Ljava/io/File;
invoke-direct {p2, p1}, Ljava/io/File;-><init>(Ljava/lang/String;)V
goto :goto_0
:catchall_0
move-exception p1
goto :goto_2
:cond_1
const/4 p2, 0x0
:goto_0
if-eqz p2, :cond_2
.line 193
invoke-virtual {p2}, Ljava/io/File;->delete()Z
move-result p2
if-nez p2, :cond_3
.line 195
:cond_2
new-instance p2, Ljava/lang/StringBuilder;
invoke-direct {p2}, Ljava/lang/StringBuilder;-><init>()V
const-string p3, "Could not delete file: "
invoke-virtual {p2, p3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
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, v1, [Ljava/lang/Object;
invoke-static {p0, p1, p2}, Lcom/ea/nimble/Log$Helper;->LOGE(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V
.line 198
:cond_3
monitor-exit v0
return-void
.line 200
:cond_4
invoke-direct {p0, p3, p2}, Lcom/ea/nimble/PersistenceServiceImpl;->loadPersistenceById(Ljava/lang/String;Lcom/ea/nimble/Persistence$Storage;)Lcom/ea/nimble/Persistence;
move-result-object p2
if-nez p2, :cond_5
.line 203
new-instance p2, Lcom/ea/nimble/Persistence;
invoke-direct {p2, p1, p3}, Lcom/ea/nimble/Persistence;-><init>(Lcom/ea/nimble/Persistence;Ljava/lang/String;)V
iget-object p1, p0, Lcom/ea/nimble/PersistenceServiceImpl;->m_persistences:Ljava/util/concurrent/ConcurrentMap;
.line 204
invoke-interface {p1, v2, p2}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
.line 205
invoke-virtual {p2}, Lcom/ea/nimble/Persistence;->synchronize()V
goto :goto_1
.line 209
:cond_5
invoke-virtual {p2, p1, p4}, Lcom/ea/nimble/Persistence;->merge(Lcom/ea/nimble/Persistence;Lcom/ea/nimble/PersistenceService$PersistenceMergePolicy;)V
.line 211
:goto_1
monitor-exit v0
return-void
:goto_2
monitor-exit v0
:try_end_0
.catchall {:try_start_0 .. :try_end_0} :catchall_0
throw p1
.line 173
:cond_6
:goto_3
new-instance p2, Ljava/lang/StringBuilder;
invoke-direct {p2}, Ljava/lang/StringBuilder;-><init>()V
const-string p4, "Invalid identifiers "
invoke-virtual {p2, p4}, 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, " or "
invoke-virtual {p2, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {p2, p3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string p1, " for component persistence"
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, v1, [Ljava/lang/Object;
invoke-static {p0, p1, p2}, Lcom/ea/nimble/Log$Helper;->LOGF(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V
return-void
.end method
.method public removePersistence(Ljava/lang/String;Lcom/ea/nimble/Persistence$Storage;)V
.locals 1
.line 84
invoke-static {p0}, Lcom/ea/nimble/Log$Helper;->LOGPUBLICFUNC(Ljava/lang/Object;)V
.line 85
invoke-static {p1}, Lcom/ea/nimble/Utility;->validString(Ljava/lang/String;)Z
move-result v0
if-nez v0, :cond_0
.line 87
new-instance p2, Ljava/lang/StringBuilder;
invoke-direct {p2}, Ljava/lang/StringBuilder;-><init>()V
const-string v0, "Invalid identifier "
invoke-virtual {p2, v0}, 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, " for persistence"
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
const/4 p2, 0x0
new-array p2, p2, [Ljava/lang/Object;
invoke-static {p0, p1, p2}, Lcom/ea/nimble/Log$Helper;->LOGF(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V
return-void
.line 91
:cond_0
invoke-virtual {p0, p1, p2}, Lcom/ea/nimble/PersistenceServiceImpl;->cleanPersistenceReference(Ljava/lang/String;Lcom/ea/nimble/Persistence$Storage;)V
return-void
.end method
.method public setup()V
.locals 1
.line 32
new-instance v0, Ljava/util/concurrent/ConcurrentHashMap;
invoke-direct {v0}, Ljava/util/concurrent/ConcurrentHashMap;-><init>()V
iput-object v0, p0, Lcom/ea/nimble/PersistenceServiceImpl;->m_persistences:Ljava/util/concurrent/ConcurrentMap;
.line 33
new-instance v0, Lcom/ea/nimble/Encryptor;
invoke-direct {v0}, Lcom/ea/nimble/Encryptor;-><init>()V
iput-object v0, p0, Lcom/ea/nimble/PersistenceServiceImpl;->m_encryptor:Lcom/ea/nimble/Encryptor;
return-void
.end method
.method public suspend()V
.locals 0
.line 39
invoke-direct {p0}, Lcom/ea/nimble/PersistenceServiceImpl;->synchronize()V
return-void
.end method
.method public teardown()V
.locals 2
.line 45
invoke-direct {p0}, Lcom/ea/nimble/PersistenceServiceImpl;->synchronize()V
.line 47
sget-object v0, Lcom/ea/nimble/Persistence;->s_dataLock:Ljava/lang/Object;
monitor-enter v0
const/4 v1, 0x0
:try_start_0
iput-object v1, p0, Lcom/ea/nimble/PersistenceServiceImpl;->m_persistences:Ljava/util/concurrent/ConcurrentMap;
iput-object v1, p0, Lcom/ea/nimble/PersistenceServiceImpl;->m_encryptor:Lcom/ea/nimble/Encryptor;
.line 51
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 wipeAllDataAndForceTerminate()V
.locals 6
.line 113
invoke-static {p0}, Lcom/ea/nimble/Log$Helper;->LOGPUBLICFUNC(Ljava/lang/Object;)V
.line 114
invoke-static {}, Lcom/ea/nimble/ApplicationEnvironment;->getComponent()Lcom/ea/nimble/IApplicationEnvironment;
move-result-object v0
invoke-interface {v0}, Lcom/ea/nimble/IApplicationEnvironment;->getDocumentPath()Ljava/lang/String;
move-result-object v0
.line 115
invoke-static {}, Lcom/ea/nimble/ApplicationEnvironment;->getComponent()Lcom/ea/nimble/IApplicationEnvironment;
move-result-object v1
invoke-interface {v1}, Lcom/ea/nimble/IApplicationEnvironment;->getTempPath()Ljava/lang/String;
move-result-object v1
.line 116
invoke-static {}, Lcom/ea/nimble/ApplicationEnvironment;->getComponent()Lcom/ea/nimble/IApplicationEnvironment;
move-result-object v2
invoke-interface {v2}, Lcom/ea/nimble/IApplicationEnvironment;->getCachePath()Ljava/lang/String;
move-result-object v2
.line 118
invoke-static {}, Lcom/ea/nimble/BaseCore;->getInstance()Lcom/ea/nimble/BaseCore;
move-result-object v3
invoke-virtual {v3}, Lcom/ea/nimble/BaseCore;->onApplicationQuit()V
const/4 v3, 0x0
:try_start_0
const-string v4, "!!! Wipe begin !!!"
new-array v5, v3, [Ljava/lang/Object;
.line 122
invoke-static {p0, v4, v5}, Lcom/ea/nimble/Log$Helper;->LOGW(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V
const-string v4, "Clearing DOC folder"
new-array v5, v3, [Ljava/lang/Object;
.line 125
invoke-static {p0, v4, v5}, Lcom/ea/nimble/Log$Helper;->LOGD(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V
.line 126
invoke-direct {p0, v0}, Lcom/ea/nimble/PersistenceServiceImpl;->deletePath(Ljava/lang/String;)Z
move-result v0
if-eqz v0, :cond_0
const-string v0, "Successfully deleted doc directory"
new-array v4, v3, [Ljava/lang/Object;
.line 128
invoke-static {p0, v0, v4}, Lcom/ea/nimble/Log$Helper;->LOGD(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V
goto :goto_0
:catch_0
move-exception v0
goto :goto_3
:cond_0
const-string v0, "Failed to delete doc directory"
new-array v4, v3, [Ljava/lang/Object;
.line 132
invoke-static {p0, v0, v4}, Lcom/ea/nimble/Log$Helper;->LOGE(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V
:goto_0
const-string v0, "Clearing TEMP folder"
new-array v4, v3, [Ljava/lang/Object;
.line 136
invoke-static {p0, v0, v4}, Lcom/ea/nimble/Log$Helper;->LOGD(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V
.line 137
invoke-direct {p0, v1}, Lcom/ea/nimble/PersistenceServiceImpl;->deletePath(Ljava/lang/String;)Z
move-result v0
if-eqz v0, :cond_1
const-string v0, "Successfully deleted temp directory"
new-array v1, v3, [Ljava/lang/Object;
.line 139
invoke-static {p0, v0, v1}, Lcom/ea/nimble/Log$Helper;->LOGD(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V
goto :goto_1
:cond_1
const-string v0, "Failed to delete temp directory"
new-array v1, v3, [Ljava/lang/Object;
.line 143
invoke-static {p0, v0, v1}, Lcom/ea/nimble/Log$Helper;->LOGE(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V
:goto_1
const-string v0, "Clearing CACHE folder"
new-array v1, v3, [Ljava/lang/Object;
.line 147
invoke-static {p0, v0, v1}, Lcom/ea/nimble/Log$Helper;->LOGD(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V
.line 148
invoke-direct {p0, v2}, Lcom/ea/nimble/PersistenceServiceImpl;->deletePath(Ljava/lang/String;)Z
move-result v0
if-eqz v0, :cond_2
const-string v0, "Successfully deleted cache directory"
new-array v1, v3, [Ljava/lang/Object;
.line 150
invoke-static {p0, v0, v1}, Lcom/ea/nimble/Log$Helper;->LOGD(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V
goto :goto_2
:cond_2
const-string v0, "Failed to delete cache directory"
new-array v1, v3, [Ljava/lang/Object;
.line 154
invoke-static {p0, v0, v1}, Lcom/ea/nimble/Log$Helper;->LOGE(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V
:goto_2
const-string v0, "!!! Wipe complete. Force terminating the application !!!"
new-array v1, v3, [Ljava/lang/Object;
.line 157
invoke-static {p0, v0, v1}, Lcom/ea/nimble/Log$Helper;->LOGW(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V
:try_end_0
.catch Ljava/lang/Exception; {:try_start_0 .. :try_end_0} :catch_0
goto :goto_4
.line 161
:goto_3
new-instance v1, Ljava/lang/StringBuilder;
invoke-direct {v1}, Ljava/lang/StringBuilder;-><init>()V
const-string v2, "!!! Wipe exception !!!\n"
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v0}, Ljava/lang/Object;->toString()Ljava/lang/String;
move-result-object v0
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
new-array v1, v3, [Ljava/lang/Object;
invoke-static {p0, v0, v1}, Lcom/ea/nimble/Log$Helper;->LOGE(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V
.line 164
:goto_4
invoke-static {v3}, Ljava/lang/System;->exit(I)V
return-void
.end method