Files
rr3-apk/smali_classes2/com/ea/nimble/SynergyEnvironmentImpl.smali
Daniel Elliott 201c19bc17 feat: Add first-launch server URL input dialog
Implements a setup dialog on first game launch that allows users to enter
their custom community server URL without rebuilding the APK.

Features:
- Server URL input dialog on first launch
- URL validation (format check)
- Connection test button
- SharedPreferences storage
- Priority: SharedPreferences > AndroidManifest.xml > EA defaults
- Activity restart flow for applying configuration

New files:
- CommunityServerManager.smali (URL management)
- ServerSetupActivity.smali + 4 inner classes (dialog UI)
- res/layout/activity_server_setup.xml (layout)
- SERVER-URL-INPUT-IMPLEMENTATION.md (docs)

Modified files:
- SynergyEnvironmentImpl.smali (SharedPreferences check priority)
- MainActivity.smali (first-launch check + onActivityResult)
- AndroidManifest.xml (declare ServerSetupActivity)

Benefits:
- One APK works with any server
- Easy server switching
- Lower barrier to entry for non-technical users
2026-02-21 23:32:06 -08:00

1424 lines
40 KiB
Smali

.class public Lcom/ea/nimble/SynergyEnvironmentImpl;
.super Lcom/ea/nimble/Component;
.source "SourceFile"
# interfaces
.implements Lcom/ea/nimble/ISynergyEnvironment;
.implements Lcom/ea/nimble/LogSource;
# static fields
.field private static final PERSISTENCE_DATA_ID:Ljava/lang/String; = "environmentData"
.field public static final SYNERGY_APP_VERSION_OK:I = 0x0
.field public static final SYNERGY_APP_VERSION_UPDATE_RECOMMENDED:I = 0x1
.field public static final SYNERGY_APP_VERSION_UPDATE_REQUIRED:I = 0x2
.field private static final SYNERGY_INT_SERVER_URL:Ljava/lang/String; = "https://director-int.sn.eamobile.com"
.field private static final SYNERGY_LIVE_SERVER_URL:Ljava/lang/String; = "https://syn-dir.sn.eamobile.com"
.field private static final SYNERGY_STAGE_SERVER_URL:Ljava/lang/String; = "https://director-stage.sn.eamobile.com"
.field public static final SYNERGY_UPDATE_RATE_LIMIT_PERIOD_IN_SECONDS:D = 60.0
.field public static final SYNERGY_UPDATE_REFRESH_PERIOD_IN_SECONDS:D = 300.0
# instance fields
.field private m_core:Lcom/ea/nimble/BaseCore;
.field private m_dataLoadedOnComponentSetup:Z
.field private m_environmentDataContainer:Lcom/ea/nimble/EnvironmentDataContainer;
.field private m_networkStatusChangeReceiver:Landroid/content/BroadcastReceiver;
.field private m_pendingStartupFinishedNotification:Z
.field private m_previousValidEnvironmentDataContainer:Lcom/ea/nimble/EnvironmentDataContainer;
.field private m_synergyEnvironmentUpdateRateLimitTriggerTimestamp:Ljava/lang/Long;
.field private m_synergyStartupObject:Lcom/ea/nimble/SynergyEnvironmentUpdater;
# direct methods
.method public constructor <init>(Lcom/ea/nimble/BaseCore;)V
.locals 0
.line 60
invoke-direct {p0}, Lcom/ea/nimble/Component;-><init>()V
iput-object p1, p0, Lcom/ea/nimble/SynergyEnvironmentImpl;->m_core:Lcom/ea/nimble/BaseCore;
const/4 p1, 0x0
iput-object p1, p0, Lcom/ea/nimble/SynergyEnvironmentImpl;->m_networkStatusChangeReceiver:Landroid/content/BroadcastReceiver;
const/4 p1, 0x0
iput-boolean p1, p0, Lcom/ea/nimble/SynergyEnvironmentImpl;->m_dataLoadedOnComponentSetup:Z
iput-boolean p1, p0, Lcom/ea/nimble/SynergyEnvironmentImpl;->m_pendingStartupFinishedNotification:Z
return-void
.end method
.method public static synthetic access$000(Lcom/ea/nimble/SynergyEnvironmentImpl;)Landroid/content/BroadcastReceiver;
.locals 0
.line 26
iget-object p0, p0, Lcom/ea/nimble/SynergyEnvironmentImpl;->m_networkStatusChangeReceiver:Landroid/content/BroadcastReceiver;
return-object p0
.end method
.method public static synthetic access$002(Lcom/ea/nimble/SynergyEnvironmentImpl;Landroid/content/BroadcastReceiver;)Landroid/content/BroadcastReceiver;
.locals 0
.line 26
iput-object p1, p0, Lcom/ea/nimble/SynergyEnvironmentImpl;->m_networkStatusChangeReceiver:Landroid/content/BroadcastReceiver;
return-object p1
.end method
.method public static synthetic access$100(Lcom/ea/nimble/SynergyEnvironmentImpl;)Lcom/ea/nimble/SynergyEnvironmentUpdater;
.locals 0
.line 26
iget-object p0, p0, Lcom/ea/nimble/SynergyEnvironmentImpl;->m_synergyStartupObject:Lcom/ea/nimble/SynergyEnvironmentUpdater;
return-object p0
.end method
.method public static synthetic access$102(Lcom/ea/nimble/SynergyEnvironmentImpl;Lcom/ea/nimble/SynergyEnvironmentUpdater;)Lcom/ea/nimble/SynergyEnvironmentUpdater;
.locals 0
.line 26
iput-object p1, p0, Lcom/ea/nimble/SynergyEnvironmentImpl;->m_synergyStartupObject:Lcom/ea/nimble/SynergyEnvironmentUpdater;
return-object p1
.end method
.method public static synthetic access$200(Lcom/ea/nimble/SynergyEnvironmentImpl;Lcom/ea/nimble/SynergyEnvironmentUpdater;)V
.locals 0
.line 26
invoke-direct {p0, p1}, Lcom/ea/nimble/SynergyEnvironmentImpl;->startSynergyEnvironmentUpdateImpl(Lcom/ea/nimble/SynergyEnvironmentUpdater;)V
return-void
.end method
.method public static synthetic access$300(Lcom/ea/nimble/SynergyEnvironmentImpl;)Lcom/ea/nimble/EnvironmentDataContainer;
.locals 0
.line 26
iget-object p0, p0, Lcom/ea/nimble/SynergyEnvironmentImpl;->m_environmentDataContainer:Lcom/ea/nimble/EnvironmentDataContainer;
return-object p0
.end method
.method public static synthetic access$302(Lcom/ea/nimble/SynergyEnvironmentImpl;Lcom/ea/nimble/EnvironmentDataContainer;)Lcom/ea/nimble/EnvironmentDataContainer;
.locals 0
.line 26
iput-object p1, p0, Lcom/ea/nimble/SynergyEnvironmentImpl;->m_environmentDataContainer:Lcom/ea/nimble/EnvironmentDataContainer;
return-object p1
.end method
.method public static synthetic access$400(Lcom/ea/nimble/SynergyEnvironmentImpl;)V
.locals 0
.line 26
invoke-direct {p0}, Lcom/ea/nimble/SynergyEnvironmentImpl;->saveEnvironmentDataToPersistent()V
return-void
.end method
.method public static synthetic access$500(Lcom/ea/nimble/SynergyEnvironmentImpl;)Lcom/ea/nimble/EnvironmentDataContainer;
.locals 0
.line 26
iget-object p0, p0, Lcom/ea/nimble/SynergyEnvironmentImpl;->m_previousValidEnvironmentDataContainer:Lcom/ea/nimble/EnvironmentDataContainer;
return-object p0
.end method
.method public static synthetic access$602(Lcom/ea/nimble/SynergyEnvironmentImpl;Z)Z
.locals 0
.line 26
iput-boolean p1, p0, Lcom/ea/nimble/SynergyEnvironmentImpl;->m_pendingStartupFinishedNotification:Z
return p1
.end method
.method public static synthetic access$700(Lcom/ea/nimble/SynergyEnvironmentImpl;)V
.locals 0
.line 26
invoke-direct {p0}, Lcom/ea/nimble/SynergyEnvironmentImpl;->startSynergyEnvironmentUpdateRateLimiting()V
return-void
.end method
.method private clearSynergyEnvironmentUpdateRateLimiting()V
.locals 1
.line 676
invoke-static {p0}, Lcom/ea/nimble/Log$Helper;->LOGFUNC(Ljava/lang/Object;)V
const/4 v0, 0x0
iput-object v0, p0, Lcom/ea/nimble/SynergyEnvironmentImpl;->m_synergyEnvironmentUpdateRateLimitTriggerTimestamp:Ljava/lang/Long;
return-void
.end method
.method private isInSynergyEnvironmentUpdateRateLimitingPeriod()Z
.locals 4
.line 669
invoke-static {p0}, Lcom/ea/nimble/Log$Helper;->LOGFUNC(Ljava/lang/Object;)V
iget-object v0, p0, Lcom/ea/nimble/SynergyEnvironmentImpl;->m_synergyEnvironmentUpdateRateLimitTriggerTimestamp:Ljava/lang/Long;
if-eqz v0, :cond_0
.line 671
invoke-static {}, Ljava/lang/System;->currentTimeMillis()J
move-result-wide v0
iget-object v2, p0, Lcom/ea/nimble/SynergyEnvironmentImpl;->m_synergyEnvironmentUpdateRateLimitTriggerTimestamp:Ljava/lang/Long;
invoke-virtual {v2}, Ljava/lang/Long;->longValue()J
move-result-wide v2
sub-long/2addr v0, v2
long-to-double v0, v0
const-wide v2, 0x40ed4c0000000000L # 60000.0
cmpg-double v0, v0, v2
if-gtz v0, :cond_0
const/4 v0, 0x1
goto :goto_0
:cond_0
const/4 v0, 0x0
:goto_0
return v0
.end method
.method private restoreEnvironmentDataFromPersistent(Z)Z
.locals 5
.line 682
invoke-static {p0}, Lcom/ea/nimble/Log$Helper;->LOGFUNC(Ljava/lang/Object;)V
const-string v0, "com.ea.nimble.synergyEnvironment"
.line 683
sget-object v1, Lcom/ea/nimble/Persistence$Storage;->CACHE:Lcom/ea/nimble/Persistence$Storage;
invoke-static {v0, v1}, Lcom/ea/nimble/PersistenceService;->getPersistenceForNimbleComponent(Ljava/lang/String;Lcom/ea/nimble/Persistence$Storage;)Lcom/ea/nimble/Persistence;
move-result-object v0
const/4 v1, 0x0
if-eqz v0, :cond_2
const-string v2, "environmentData"
.line 689
invoke-virtual {v0, v2}, Lcom/ea/nimble/Persistence;->getValue(Ljava/lang/String;)Ljava/io/Serializable;
move-result-object v0
if-nez v0, :cond_0
const-string p1, "Environment persistence data value not found in persistence object. Probably first install."
new-array v0, v1, [Ljava/lang/Object;
.line 693
invoke-static {p0, p1, v0}, Lcom/ea/nimble/Log$Helper;->LOGD(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V
goto :goto_0
.line 699
:cond_0
:try_start_0
check-cast v0, Lcom/ea/nimble/EnvironmentDataContainer;
iput-object v0, p0, Lcom/ea/nimble/SynergyEnvironmentImpl;->m_environmentDataContainer:Lcom/ea/nimble/EnvironmentDataContainer;
const-string v2, "Restored environment data from persistent. Restored data timestamp, %s"
const/4 v3, 0x1
new-array v4, v3, [Ljava/lang/Object;
.line 703
invoke-virtual {v0}, Lcom/ea/nimble/EnvironmentDataContainer;->getMostRecentDirectorResponseTimestamp()Ljava/lang/Long;
move-result-object v0
aput-object v0, v4, v1
.line 702
invoke-static {p0, v2, v4}, Lcom/ea/nimble/Log$Helper;->LOGD(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V
if-nez p1, :cond_1
const-string p1, "nimble.environment.notification.restored_from_persistent"
.line 707
invoke-static {p1}, Lcom/ea/nimble/Utility;->sendBroadcast(Ljava/lang/String;)V
:try_end_0
.catch Ljava/lang/ClassCastException; {:try_start_0 .. :try_end_0} :catch_0
:cond_1
return v3
:catch_0
const-string p1, "Environment persistence data value is not the expected type."
new-array v0, v1, [Ljava/lang/Object;
.line 715
invoke-static {p0, p1, v0}, Lcom/ea/nimble/Log$Helper;->LOGE(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V
goto :goto_0
:cond_2
const-string p1, "Could not get environment persistence object to restore from"
new-array v0, v1, [Ljava/lang/Object;
.line 721
invoke-static {p0, p1, v0}, Lcom/ea/nimble/Log$Helper;->LOGE(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V
:goto_0
const/4 p1, 0x0
iput-object p1, p0, Lcom/ea/nimble/SynergyEnvironmentImpl;->m_environmentDataContainer:Lcom/ea/nimble/EnvironmentDataContainer;
return v1
.end method
.method private saveEnvironmentDataToPersistent()V
.locals 3
.line 732
invoke-static {p0}, Lcom/ea/nimble/Log$Helper;->LOGFUNC(Ljava/lang/Object;)V
const-string v0, "com.ea.nimble.synergyEnvironment"
.line 733
sget-object v1, Lcom/ea/nimble/Persistence$Storage;->CACHE:Lcom/ea/nimble/Persistence$Storage;
invoke-static {v0, v1}, Lcom/ea/nimble/PersistenceService;->getPersistenceForNimbleComponent(Ljava/lang/String;Lcom/ea/nimble/Persistence$Storage;)Lcom/ea/nimble/Persistence;
move-result-object v0
const/4 v1, 0x0
if-eqz v0, :cond_0
const-string v2, "Saving environment data to persistent."
new-array v1, v1, [Ljava/lang/Object;
.line 737
invoke-static {p0, v2, v1}, Lcom/ea/nimble/Log$Helper;->LOGD(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V
const-string v1, "environmentData"
iget-object v2, p0, Lcom/ea/nimble/SynergyEnvironmentImpl;->m_environmentDataContainer:Lcom/ea/nimble/EnvironmentDataContainer;
.line 738
invoke-virtual {v0, v1, v2}, Lcom/ea/nimble/Persistence;->setValue(Ljava/lang/String;Ljava/io/Serializable;)V
.line 741
invoke-virtual {v0}, Lcom/ea/nimble/Persistence;->synchronize()V
goto :goto_0
:cond_0
const-string v0, "Could not get environment persistence object to save to."
new-array v1, v1, [Ljava/lang/Object;
.line 745
invoke-static {p0, v0, v1}, Lcom/ea/nimble/Log$Helper;->LOGE(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V
:goto_0
return-void
.end method
.method private startSynergyEnvironmentUpdate()V
.locals 4
.line 478
invoke-static {p0}, Lcom/ea/nimble/Log$Helper;->LOGFUNC(Ljava/lang/Object;)V
.line 480
monitor-enter p0
:try_start_0
iget-object v0, p0, Lcom/ea/nimble/SynergyEnvironmentImpl;->m_synergyStartupObject:Lcom/ea/nimble/SynergyEnvironmentUpdater;
if-nez v0, :cond_0
.line 484
new-instance v0, Lcom/ea/nimble/SynergyEnvironmentUpdater;
iget-object v1, p0, Lcom/ea/nimble/SynergyEnvironmentImpl;->m_core:Lcom/ea/nimble/BaseCore;
invoke-direct {v0, v1}, Lcom/ea/nimble/SynergyEnvironmentUpdater;-><init>(Lcom/ea/nimble/BaseCore;)V
iput-object v0, p0, Lcom/ea/nimble/SynergyEnvironmentImpl;->m_synergyStartupObject:Lcom/ea/nimble/SynergyEnvironmentUpdater;
goto :goto_0
:catchall_0
move-exception v0
goto :goto_1
:cond_0
const/4 v0, 0x0
.line 487
:goto_0
monitor-exit p0
:try_end_0
.catchall {:try_start_0 .. :try_end_0} :catchall_0
const/4 v1, 0x0
if-nez v0, :cond_1
const-string v0, "Attempt made to start Synergy environment update while a previous one is active. Exiting."
new-array v1, v1, [Ljava/lang/Object;
.line 490
invoke-static {p0, v0, v1}, Lcom/ea/nimble/Log$Helper;->LOGD(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V
return-void
.line 495
:cond_1
invoke-static {}, Lcom/ea/nimble/Network;->getComponent()Lcom/ea/nimble/INetwork;
move-result-object v2
invoke-interface {v2}, Lcom/ea/nimble/INetwork;->getStatus()Lcom/ea/nimble/Network$Status;
move-result-object v2
sget-object v3, Lcom/ea/nimble/Network$Status;->OK:Lcom/ea/nimble/Network$Status;
if-eq v2, v3, :cond_3
iget-object v0, p0, Lcom/ea/nimble/SynergyEnvironmentImpl;->m_networkStatusChangeReceiver:Landroid/content/BroadcastReceiver;
if-nez v0, :cond_2
.line 499
new-instance v0, Lcom/ea/nimble/SynergyEnvironmentImpl$1;
invoke-direct {v0, p0}, Lcom/ea/nimble/SynergyEnvironmentImpl$1;-><init>(Lcom/ea/nimble/SynergyEnvironmentImpl;)V
iput-object v0, p0, Lcom/ea/nimble/SynergyEnvironmentImpl;->m_networkStatusChangeReceiver:Landroid/content/BroadcastReceiver;
const-string v0, "Network not available to perform environment update. Setting receiver to listen for network status change."
new-array v1, v1, [Ljava/lang/Object;
.line 518
invoke-static {p0, v0, v1}, Lcom/ea/nimble/Log$Helper;->LOGD(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V
const-string v0, "nimble.notification.networkStatusChange"
iget-object v1, p0, Lcom/ea/nimble/SynergyEnvironmentImpl;->m_networkStatusChangeReceiver:Landroid/content/BroadcastReceiver;
.line 520
invoke-static {v0, v1}, Lcom/ea/nimble/Utility;->registerReceiver(Ljava/lang/String;Landroid/content/BroadcastReceiver;)V
:cond_2
return-void
.line 530
:cond_3
invoke-direct {p0, v0}, Lcom/ea/nimble/SynergyEnvironmentImpl;->startSynergyEnvironmentUpdateImpl(Lcom/ea/nimble/SynergyEnvironmentUpdater;)V
return-void
.line 487
:goto_1
:try_start_1
monitor-exit p0
:try_end_1
.catchall {:try_start_1 .. :try_end_1} :catchall_0
throw v0
.end method
.method private startSynergyEnvironmentUpdateImpl(Lcom/ea/nimble/SynergyEnvironmentUpdater;)V
.locals 3
.line 535
invoke-static {p0}, Lcom/ea/nimble/Log$Helper;->LOGFUNC(Ljava/lang/Object;)V
if-nez p1, :cond_0
const/4 p1, 0x0
new-array p1, p1, [Ljava/lang/Object;
const-string v0, "Synergy Environment Update canceled before it could start"
.line 538
invoke-static {p0, v0, p1}, Lcom/ea/nimble/Log$Helper;->LOGD(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V
return-void
:cond_0
iget-object v0, p0, Lcom/ea/nimble/SynergyEnvironmentImpl;->m_environmentDataContainer:Lcom/ea/nimble/EnvironmentDataContainer;
iput-object v0, p0, Lcom/ea/nimble/SynergyEnvironmentImpl;->m_previousValidEnvironmentDataContainer:Lcom/ea/nimble/EnvironmentDataContainer;
.line 547
new-instance v0, Ljava/util/HashMap;
invoke-direct {v0}, Ljava/util/HashMap;-><init>()V
const-string v1, "result"
const-string v2, "1"
.line 548
invoke-interface {v0, v1, v2}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
const-string v1, "nimble.environment.notification.startup_requests_started"
.line 549
invoke-static {v1, v0}, Lcom/ea/nimble/Utility;->sendBroadcast(Ljava/lang/String;Ljava/util/Map;)V
iget-object v0, p0, Lcom/ea/nimble/SynergyEnvironmentImpl;->m_previousValidEnvironmentDataContainer:Lcom/ea/nimble/EnvironmentDataContainer;
.line 551
new-instance v1, Lcom/ea/nimble/SynergyEnvironmentImpl$2;
invoke-direct {v1, p0, p1}, Lcom/ea/nimble/SynergyEnvironmentImpl$2;-><init>(Lcom/ea/nimble/SynergyEnvironmentImpl;Lcom/ea/nimble/SynergyEnvironmentUpdater;)V
invoke-virtual {p1, v0, v1}, Lcom/ea/nimble/SynergyEnvironmentUpdater;->startSynergyStartupSequence(Lcom/ea/nimble/EnvironmentDataContainer;Lcom/ea/nimble/SynergyEnvironmentUpdater$CompletionCallback;)V
return-void
.end method
.method private startSynergyEnvironmentUpdateRateLimiting()V
.locals 2
.line 663
invoke-static {p0}, Lcom/ea/nimble/Log$Helper;->LOGFUNC(Ljava/lang/Object;)V
.line 664
invoke-static {}, Ljava/lang/System;->currentTimeMillis()J
move-result-wide v0
invoke-static {v0, v1}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;
move-result-object v0
iput-object v0, p0, Lcom/ea/nimble/SynergyEnvironmentImpl;->m_synergyEnvironmentUpdateRateLimitTriggerTimestamp:Ljava/lang/Long;
return-void
.end method
# virtual methods
.method public checkAndInitiateSynergyEnvironmentUpdate()Lcom/ea/nimble/Error;
.locals 4
.line 287
invoke-static {p0}, Lcom/ea/nimble/Log$Helper;->LOGPUBLICFUNC(Ljava/lang/Object;)V
.line 289
invoke-virtual {p0}, Lcom/ea/nimble/SynergyEnvironmentImpl;->isUpdateInProgress()Z
move-result v0
if-eqz v0, :cond_0
.line 292
new-instance v0, Lcom/ea/nimble/Error;
sget-object v1, Lcom/ea/nimble/Error$Code;->SYNERGY_ENVIRONMENT_UPDATE_FAILURE:Lcom/ea/nimble/Error$Code;
const-string v2, "Update in progress."
invoke-direct {v0, v1, v2}, Lcom/ea/nimble/Error;-><init>(Lcom/ea/nimble/Error$Code;Ljava/lang/String;)V
return-object v0
:cond_0
iget-object v0, p0, Lcom/ea/nimble/SynergyEnvironmentImpl;->m_environmentDataContainer:Lcom/ea/nimble/EnvironmentDataContainer;
if-eqz v0, :cond_1
.line 297
invoke-virtual {v0}, Lcom/ea/nimble/EnvironmentDataContainer;->getMostRecentDirectorResponseTimestamp()Ljava/lang/Long;
move-result-object v0
if-eqz v0, :cond_1
.line 300
new-instance v0, Lcom/ea/nimble/Error;
sget-object v1, Lcom/ea/nimble/Error$Code;->SYNERGY_ENVIRONMENT_UPDATE_FAILURE:Lcom/ea/nimble/Error$Code;
const-string v2, "Environment data already cached."
invoke-direct {v0, v1, v2}, Lcom/ea/nimble/Error;-><init>(Lcom/ea/nimble/Error$Code;Ljava/lang/String;)V
return-object v0
.line 315
:cond_1
invoke-direct {p0}, Lcom/ea/nimble/SynergyEnvironmentImpl;->isInSynergyEnvironmentUpdateRateLimitingPeriod()Z
move-result v0
if-eqz v0, :cond_2
.line 319
invoke-static {}, Ljava/lang/System;->currentTimeMillis()J
move-result-wide v0
iget-object v2, p0, Lcom/ea/nimble/SynergyEnvironmentImpl;->m_synergyEnvironmentUpdateRateLimitTriggerTimestamp:Ljava/lang/Long;
invoke-virtual {v2}, Ljava/lang/Long;->longValue()J
move-result-wide v2
sub-long/2addr v0, v2
long-to-double v0, v0
const-wide v2, 0x408f400000000000L # 1000.0
div-double/2addr v0, v2
const-wide/high16 v2, 0x404e000000000000L # 60.0
sub-double/2addr v2, v0
invoke-static {v2, v3}, Ljava/lang/Double;->valueOf(D)Ljava/lang/Double;
move-result-object v0
filled-new-array {v0}, [Ljava/lang/Object;
move-result-object v0
const-string v1, "Attempt to re-initiate Synergy environment update blocked by rate limiting. %.2f seconds of rate limiting left"
.line 318
invoke-static {p0, v1, v0}, Lcom/ea/nimble/Log$Helper;->LOGD(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V
.line 323
new-instance v0, Lcom/ea/nimble/Error;
sget-object v1, Lcom/ea/nimble/Error$Code;->SYNERGY_ENVIRONMENT_UPDATE_FAILURE:Lcom/ea/nimble/Error$Code;
const-string v2, "Synergy environment update rate limit in effect."
invoke-direct {v0, v1, v2}, Lcom/ea/nimble/Error;-><init>(Lcom/ea/nimble/Error$Code;Ljava/lang/String;)V
return-object v0
.line 327
:cond_2
invoke-direct {p0}, Lcom/ea/nimble/SynergyEnvironmentImpl;->startSynergyEnvironmentUpdate()V
const/4 v0, 0x0
return-object v0
.end method
.method public cleanup()V
.locals 2
.line 446
invoke-static {p0}, Lcom/ea/nimble/Log$Helper;->LOGFUNC(Ljava/lang/Object;)V
iget-object v0, p0, Lcom/ea/nimble/SynergyEnvironmentImpl;->m_synergyStartupObject:Lcom/ea/nimble/SynergyEnvironmentUpdater;
const/4 v1, 0x0
if-eqz v0, :cond_0
.line 454
invoke-virtual {v0}, Lcom/ea/nimble/SynergyEnvironmentUpdater;->cancel()V
iput-object v1, p0, Lcom/ea/nimble/SynergyEnvironmentImpl;->m_synergyStartupObject:Lcom/ea/nimble/SynergyEnvironmentUpdater;
:cond_0
iget-object v0, p0, Lcom/ea/nimble/SynergyEnvironmentImpl;->m_networkStatusChangeReceiver:Landroid/content/BroadcastReceiver;
if-eqz v0, :cond_1
.line 460
invoke-static {v0}, Lcom/ea/nimble/Utility;->unregisterReceiver(Landroid/content/BroadcastReceiver;)V
iput-object v1, p0, Lcom/ea/nimble/SynergyEnvironmentImpl;->m_networkStatusChangeReceiver:Landroid/content/BroadcastReceiver;
.line 464
:cond_1
invoke-direct {p0}, Lcom/ea/nimble/SynergyEnvironmentImpl;->saveEnvironmentDataToPersistent()V
iput-object v1, p0, Lcom/ea/nimble/SynergyEnvironmentImpl;->m_environmentDataContainer:Lcom/ea/nimble/EnvironmentDataContainer;
return-void
.end method
.method public getComponentId()Ljava/lang/String;
.locals 1
const-string v0, "com.ea.nimble.synergyEnvironment"
return-object v0
.end method
.method public getEADeviceId()Ljava/lang/String;
.locals 1
.line 87
invoke-static {p0}, Lcom/ea/nimble/Log$Helper;->LOGPUBLICFUNC(Ljava/lang/Object;)V
.line 92
invoke-virtual {p0}, Lcom/ea/nimble/SynergyEnvironmentImpl;->checkAndInitiateSynergyEnvironmentUpdate()Lcom/ea/nimble/Error;
iget-object v0, p0, Lcom/ea/nimble/SynergyEnvironmentImpl;->m_environmentDataContainer:Lcom/ea/nimble/EnvironmentDataContainer;
if-nez v0, :cond_0
const/4 v0, 0x0
return-object v0
.line 98
:cond_0
invoke-virtual {v0}, Lcom/ea/nimble/EnvironmentDataContainer;->getEADeviceId()Ljava/lang/String;
move-result-object v0
return-object v0
.end method
.method public getEAHardwareId()Ljava/lang/String;
.locals 1
.line 173
invoke-static {p0}, Lcom/ea/nimble/Log$Helper;->LOGPUBLICFUNC(Ljava/lang/Object;)V
.line 174
invoke-virtual {p0}, Lcom/ea/nimble/SynergyEnvironmentImpl;->checkAndInitiateSynergyEnvironmentUpdate()Lcom/ea/nimble/Error;
iget-object v0, p0, Lcom/ea/nimble/SynergyEnvironmentImpl;->m_environmentDataContainer:Lcom/ea/nimble/EnvironmentDataContainer;
if-nez v0, :cond_0
const/4 v0, 0x0
return-object v0
.line 180
:cond_0
invoke-virtual {v0}, Lcom/ea/nimble/EnvironmentDataContainer;->getEAHardwareId()Ljava/lang/String;
move-result-object v0
return-object v0
.end method
.method public getGosMdmAppKey()Ljava/lang/String;
.locals 1
.line 781
invoke-static {p0}, Lcom/ea/nimble/Log$Helper;->LOGPUBLICFUNC(Ljava/lang/Object;)V
.line 782
invoke-virtual {p0}, Lcom/ea/nimble/SynergyEnvironmentImpl;->checkAndInitiateSynergyEnvironmentUpdate()Lcom/ea/nimble/Error;
iget-object v0, p0, Lcom/ea/nimble/SynergyEnvironmentImpl;->m_environmentDataContainer:Lcom/ea/nimble/EnvironmentDataContainer;
if-nez v0, :cond_0
const/4 v0, 0x0
return-object v0
.line 789
:cond_0
invoke-virtual {v0}, Lcom/ea/nimble/EnvironmentDataContainer;->getGosMdmAppKey()Ljava/lang/String;
move-result-object v0
return-object v0
.end method
.method public getLatestAppVersionCheckResult()I
.locals 1
.line 213
invoke-static {p0}, Lcom/ea/nimble/Log$Helper;->LOGPUBLICFUNC(Ljava/lang/Object;)V
iget-object v0, p0, Lcom/ea/nimble/SynergyEnvironmentImpl;->m_environmentDataContainer:Lcom/ea/nimble/EnvironmentDataContainer;
if-nez v0, :cond_0
const/4 v0, 0x0
goto :goto_0
.line 214
:cond_0
invoke-virtual {v0}, Lcom/ea/nimble/EnvironmentDataContainer;->getLatestAppVersionCheckResult()I
move-result v0
:goto_0
return v0
.end method
.method public getLogSourceTitle()Ljava/lang/String;
.locals 1
const-string v0, "SynergyEnv"
return-object v0
.end method
.method public getNexusClientId()Ljava/lang/String;
.locals 1
.line 752
invoke-static {p0}, Lcom/ea/nimble/Log$Helper;->LOGPUBLICFUNC(Ljava/lang/Object;)V
.line 753
invoke-virtual {p0}, Lcom/ea/nimble/SynergyEnvironmentImpl;->checkAndInitiateSynergyEnvironmentUpdate()Lcom/ea/nimble/Error;
iget-object v0, p0, Lcom/ea/nimble/SynergyEnvironmentImpl;->m_environmentDataContainer:Lcom/ea/nimble/EnvironmentDataContainer;
if-nez v0, :cond_0
const/4 v0, 0x0
return-object v0
.line 760
:cond_0
invoke-virtual {v0}, Lcom/ea/nimble/EnvironmentDataContainer;->getNexusClientId()Ljava/lang/String;
move-result-object v0
return-object v0
.end method
.method public getNexusClientSecret()Ljava/lang/String;
.locals 1
.line 767
invoke-static {p0}, Lcom/ea/nimble/Log$Helper;->LOGPUBLICFUNC(Ljava/lang/Object;)V
.line 768
invoke-virtual {p0}, Lcom/ea/nimble/SynergyEnvironmentImpl;->checkAndInitiateSynergyEnvironmentUpdate()Lcom/ea/nimble/Error;
iget-object v0, p0, Lcom/ea/nimble/SynergyEnvironmentImpl;->m_environmentDataContainer:Lcom/ea/nimble/EnvironmentDataContainer;
if-nez v0, :cond_0
const/4 v0, 0x0
return-object v0
.line 775
:cond_0
invoke-virtual {v0}, Lcom/ea/nimble/EnvironmentDataContainer;->getNexusClientSecret()Ljava/lang/String;
move-result-object v0
return-object v0
.end method
.method public getProductId()Ljava/lang/String;
.locals 1
.line 152
invoke-static {p0}, Lcom/ea/nimble/Log$Helper;->LOGPUBLICFUNC(Ljava/lang/Object;)V
.line 153
invoke-virtual {p0}, Lcom/ea/nimble/SynergyEnvironmentImpl;->checkAndInitiateSynergyEnvironmentUpdate()Lcom/ea/nimble/Error;
iget-object v0, p0, Lcom/ea/nimble/SynergyEnvironmentImpl;->m_environmentDataContainer:Lcom/ea/nimble/EnvironmentDataContainer;
if-nez v0, :cond_0
const/4 v0, 0x0
return-object v0
.line 159
:cond_0
invoke-virtual {v0}, Lcom/ea/nimble/EnvironmentDataContainer;->getProductId()Ljava/lang/String;
move-result-object v0
return-object v0
.end method
.method public getSellId()Ljava/lang/String;
.locals 1
.line 132
invoke-static {p0}, Lcom/ea/nimble/Log$Helper;->LOGPUBLICFUNC(Ljava/lang/Object;)V
.line 133
invoke-virtual {p0}, Lcom/ea/nimble/SynergyEnvironmentImpl;->checkAndInitiateSynergyEnvironmentUpdate()Lcom/ea/nimble/Error;
iget-object v0, p0, Lcom/ea/nimble/SynergyEnvironmentImpl;->m_environmentDataContainer:Lcom/ea/nimble/EnvironmentDataContainer;
if-nez v0, :cond_0
const/4 v0, 0x0
return-object v0
.line 139
:cond_0
invoke-virtual {v0}, Lcom/ea/nimble/EnvironmentDataContainer;->getSellId()Ljava/lang/String;
move-result-object v0
return-object v0
.end method
.method public getServerUrlWithKey(Ljava/lang/String;)Ljava/lang/String;
.locals 1
.line 204
invoke-static {p0}, Lcom/ea/nimble/Log$Helper;->LOGPUBLICFUNC(Ljava/lang/Object;)V
.line 205
invoke-virtual {p0}, Lcom/ea/nimble/SynergyEnvironmentImpl;->checkAndInitiateSynergyEnvironmentUpdate()Lcom/ea/nimble/Error;
iget-object v0, p0, Lcom/ea/nimble/SynergyEnvironmentImpl;->m_environmentDataContainer:Lcom/ea/nimble/EnvironmentDataContainer;
if-nez v0, :cond_0
const/4 p1, 0x0
goto :goto_0
.line 207
:cond_0
invoke-virtual {v0, p1}, Lcom/ea/nimble/EnvironmentDataContainer;->getServerUrlWithKey(Ljava/lang/String;)Ljava/lang/String;
move-result-object p1
:goto_0
return-object p1
.end method
.method public getSynergyDirectorServerUrl(Lcom/ea/nimble/NimbleConfiguration;)Ljava/lang/String;
.locals 3
.line 227
invoke-static {p0}, Lcom/ea/nimble/Log$Helper;->LOGPUBLICFUNC(Ljava/lang/Object;)V
# 🆕 COMMUNITY PATCH: Check SharedPreferences first (PRIORITY #1)
.line 228
invoke-static {}, Lcom/ea/nimble/ApplicationEnvironment;->getCurrentApplication()Landroid/app/Application;
move-result-object v0
invoke-static {v0}, Lcom/firemint/realracing/CommunityServerManager;->getServerUrl(Landroid/content/Context;)Ljava/lang/String;
move-result-object v0
if-eqz v0, :check_manifest
.line 229
invoke-virtual {v0}, Ljava/lang/String;->isEmpty()Z
move-result v1
if-nez v1, :check_manifest
# User has configured a custom server URL via setup dialog
const-string v1, "🎯 Using community server from SharedPreferences"
const-string v2, "SynergyEnvironmentImpl"
invoke-static {v2, v1}, Landroid/util/Log;->i(Ljava/lang/String;Ljava/lang/String;)I
return-object v0
# Continue with normal logic (AndroidManifest.xml or defaults)
:check_manifest
.line 228
sget-object v0, Lcom/ea/nimble/SynergyEnvironmentImpl$3;->$SwitchMap$com$ea$nimble$NimbleConfiguration:[I
invoke-virtual {p1}, Ljava/lang/Enum;->ordinal()I
move-result v1
aget v0, v0, v1
const/4 v1, 0x1
if-eq v0, v1, :cond_3
const/4 v1, 0x2
if-eq v0, v1, :cond_2
const/4 v1, 0x3
const-string v2, "https://syn-dir.sn.eamobile.com"
if-eq v0, v1, :cond_1
const/4 v1, 0x4
if-eq v0, v1, :cond_0
const-string v0, "Request for Synergy Director server URL with unknown NimbleConfiguration, %d."
filled-new-array {p1}, [Ljava/lang/Object;
move-result-object p1
.line 248
invoke-static {p0, v0, p1}, Lcom/ea/nimble/Log$Helper;->LOGF(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V
return-object v2
:cond_0
const-string p1, "NimbleCustomizedSynergyServerEndpointUrl"
.line 244
invoke-static {p1, v2}, Lcom/ea/nimble/NimbleApplicationConfiguration;->getConfigValueAsString(Ljava/lang/String;Ljava/lang/String;)Ljava/lang/String;
move-result-object p1
return-object p1
:cond_1
return-object v2
:cond_2
const-string p1, "https://director-stage.sn.eamobile.com"
return-object p1
:cond_3
const-string p1, "https://director-int.sn.eamobile.com"
return-object p1
.end method
.method public getSynergyId()Ljava/lang/String;
.locals 1
.line 112
invoke-static {p0}, Lcom/ea/nimble/Log$Helper;->LOGPUBLICFUNC(Ljava/lang/Object;)V
.line 113
invoke-virtual {p0}, Lcom/ea/nimble/SynergyEnvironmentImpl;->checkAndInitiateSynergyEnvironmentUpdate()Lcom/ea/nimble/Error;
iget-object v0, p0, Lcom/ea/nimble/SynergyEnvironmentImpl;->m_environmentDataContainer:Lcom/ea/nimble/EnvironmentDataContainer;
if-nez v0, :cond_0
const/4 v0, 0x0
return-object v0
.line 119
:cond_0
invoke-virtual {v0}, Lcom/ea/nimble/EnvironmentDataContainer;->getSynergyId()Ljava/lang/String;
move-result-object v0
return-object v0
.end method
.method public getTrackingPostInterval()I
.locals 1
.line 220
invoke-static {p0}, Lcom/ea/nimble/Log$Helper;->LOGPUBLICFUNC(Ljava/lang/Object;)V
iget-object v0, p0, Lcom/ea/nimble/SynergyEnvironmentImpl;->m_environmentDataContainer:Lcom/ea/nimble/EnvironmentDataContainer;
if-nez v0, :cond_0
const/4 v0, -0x1
goto :goto_0
.line 221
:cond_0
invoke-virtual {v0}, Lcom/ea/nimble/EnvironmentDataContainer;->getTrackingPostInterval()I
move-result v0
:goto_0
return v0
.end method
.method public isDataAvailable()Z
.locals 1
.line 262
invoke-static {p0}, Lcom/ea/nimble/Log$Helper;->LOGPUBLICFUNC(Ljava/lang/Object;)V
iget-object v0, p0, Lcom/ea/nimble/SynergyEnvironmentImpl;->m_environmentDataContainer:Lcom/ea/nimble/EnvironmentDataContainer;
if-eqz v0, :cond_0
const/4 v0, 0x1
goto :goto_0
:cond_0
const/4 v0, 0x0
:goto_0
return v0
.end method
.method public isFeatureDisabled(Ljava/lang/String;)Z
.locals 1
.line 335
invoke-static {p0}, Lcom/ea/nimble/Log$Helper;->LOGPUBLICFUNC(Ljava/lang/Object;)V
.line 336
invoke-virtual {p0}, Lcom/ea/nimble/SynergyEnvironmentImpl;->checkAndInitiateSynergyEnvironmentUpdate()Lcom/ea/nimble/Error;
iget-object v0, p0, Lcom/ea/nimble/SynergyEnvironmentImpl;->m_environmentDataContainer:Lcom/ea/nimble/EnvironmentDataContainer;
if-eqz v0, :cond_0
.line 338
invoke-virtual {v0, p1}, Lcom/ea/nimble/EnvironmentDataContainer;->isFeatureDisabled(Ljava/lang/String;)Z
move-result p1
if-eqz p1, :cond_0
const/4 p1, 0x1
goto :goto_0
:cond_0
const/4 p1, 0x0
:goto_0
return p1
.end method
.method public isUpdateInProgress()Z
.locals 1
.line 273
invoke-static {p0}, Lcom/ea/nimble/Log$Helper;->LOGPUBLICFUNC(Ljava/lang/Object;)V
iget-object v0, p0, Lcom/ea/nimble/SynergyEnvironmentImpl;->m_synergyStartupObject:Lcom/ea/nimble/SynergyEnvironmentUpdater;
if-eqz v0, :cond_0
const/4 v0, 0x1
goto :goto_0
:cond_0
const/4 v0, 0x0
:goto_0
return v0
.end method
.method public restore()V
.locals 4
.line 361
invoke-static {p0}, Lcom/ea/nimble/Log$Helper;->LOGFUNC(Ljava/lang/Object;)V
iget-boolean v0, p0, Lcom/ea/nimble/SynergyEnvironmentImpl;->m_dataLoadedOnComponentSetup:Z
const/4 v1, 0x0
if-eqz v0, :cond_0
iput-boolean v1, p0, Lcom/ea/nimble/SynergyEnvironmentImpl;->m_dataLoadedOnComponentSetup:Z
const-string v0, "nimble.environment.notification.restored_from_persistent"
.line 371
invoke-static {v0}, Lcom/ea/nimble/Utility;->sendBroadcast(Ljava/lang/String;)V
goto :goto_0
.line 376
:cond_0
invoke-direct {p0, v1}, Lcom/ea/nimble/SynergyEnvironmentImpl;->restoreEnvironmentDataFromPersistent(Z)Z
:goto_0
iget-object v0, p0, Lcom/ea/nimble/SynergyEnvironmentImpl;->m_environmentDataContainer:Lcom/ea/nimble/EnvironmentDataContainer;
if-eqz v0, :cond_2
.line 380
invoke-virtual {v0}, Lcom/ea/nimble/EnvironmentDataContainer;->getMostRecentDirectorResponseTimestamp()Ljava/lang/Long;
move-result-object v0
if-eqz v0, :cond_2
.line 381
invoke-static {}, Ljava/lang/System;->currentTimeMillis()J
move-result-wide v0
iget-object v2, p0, Lcom/ea/nimble/SynergyEnvironmentImpl;->m_environmentDataContainer:Lcom/ea/nimble/EnvironmentDataContainer;
invoke-virtual {v2}, Lcom/ea/nimble/EnvironmentDataContainer;->getMostRecentDirectorResponseTimestamp()Ljava/lang/Long;
move-result-object v2
invoke-virtual {v2}, Ljava/lang/Long;->longValue()J
move-result-wide v2
sub-long/2addr v0, v2
long-to-double v0, v0
const-wide v2, 0x408f400000000000L # 1000.0
div-double/2addr v0, v2
const-wide v2, 0x4072c00000000000L # 300.0
cmpl-double v0, v0, v2
if-lez v0, :cond_1
goto :goto_1
.line 387
:cond_1
invoke-virtual {p0}, Lcom/ea/nimble/SynergyEnvironmentImpl;->checkAndInitiateSynergyEnvironmentUpdate()Lcom/ea/nimble/Error;
goto :goto_2
.line 383
:cond_2
:goto_1
invoke-direct {p0}, Lcom/ea/nimble/SynergyEnvironmentImpl;->startSynergyEnvironmentUpdate()V
:goto_2
return-void
.end method
.method public resume()V
.locals 4
.line 417
invoke-static {p0}, Lcom/ea/nimble/Log$Helper;->LOGFUNC(Ljava/lang/Object;)V
.line 420
invoke-direct {p0}, Lcom/ea/nimble/SynergyEnvironmentImpl;->clearSynergyEnvironmentUpdateRateLimiting()V
iget-object v0, p0, Lcom/ea/nimble/SynergyEnvironmentImpl;->m_environmentDataContainer:Lcom/ea/nimble/EnvironmentDataContainer;
if-eqz v0, :cond_0
.line 425
invoke-virtual {v0}, Lcom/ea/nimble/EnvironmentDataContainer;->getMostRecentDirectorResponseTimestamp()Ljava/lang/Long;
move-result-object v0
if-eqz v0, :cond_0
.line 426
invoke-static {}, Ljava/lang/System;->currentTimeMillis()J
move-result-wide v0
iget-object v2, p0, Lcom/ea/nimble/SynergyEnvironmentImpl;->m_environmentDataContainer:Lcom/ea/nimble/EnvironmentDataContainer;
invoke-virtual {v2}, Lcom/ea/nimble/EnvironmentDataContainer;->getMostRecentDirectorResponseTimestamp()Ljava/lang/Long;
move-result-object v2
invoke-virtual {v2}, Ljava/lang/Long;->longValue()J
move-result-wide v2
sub-long/2addr v0, v2
long-to-double v0, v0
const-wide v2, 0x408f400000000000L # 1000.0
div-double/2addr v0, v2
const-wide v2, 0x4072c00000000000L # 300.0
cmpl-double v0, v0, v2
if-lez v0, :cond_1
.line 428
:cond_0
invoke-direct {p0}, Lcom/ea/nimble/SynergyEnvironmentImpl;->startSynergyEnvironmentUpdate()V
:cond_1
iget-boolean v0, p0, Lcom/ea/nimble/SynergyEnvironmentImpl;->m_pendingStartupFinishedNotification:Z
if-eqz v0, :cond_2
const/4 v0, 0x0
iput-boolean v0, p0, Lcom/ea/nimble/SynergyEnvironmentImpl;->m_pendingStartupFinishedNotification:Z
.line 434
new-instance v1, Ljava/util/HashMap;
invoke-direct {v1}, Ljava/util/HashMap;-><init>()V
const-string v2, "result"
const-string v3, "1"
.line 435
invoke-interface {v1, v2, v3}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
const-string v2, "App is running in forground, sending delayed the NOTIFICATION_STARTUP_REQUESTS_FINISHED notification"
new-array v0, v0, [Ljava/lang/Object;
.line 438
invoke-static {p0, v2, v0}, Lcom/ea/nimble/Log$Helper;->LOGD(Ljava/lang/Object;Ljava/lang/String;[Ljava/lang/Object;)V
const-string v0, "nimble.environment.notification.startup_requests_finished"
.line 439
invoke-static {v0, v1}, Lcom/ea/nimble/Utility;->sendBroadcast(Ljava/lang/String;Ljava/util/Map;)V
:cond_2
return-void
.end method
.method public setServerUrl(Ljava/lang/String;Ljava/lang/String;)Lcom/ea/nimble/Error;
.locals 1
iget-object v0, p0, Lcom/ea/nimble/SynergyEnvironmentImpl;->m_environmentDataContainer:Lcom/ea/nimble/EnvironmentDataContainer;
.line 192
invoke-virtual {v0, p1, p2}, Lcom/ea/nimble/EnvironmentDataContainer;->setServerUrl(Ljava/lang/String;Ljava/lang/String;)Lcom/ea/nimble/Error;
move-result-object p1
return-object p1
.end method
.method public setup()V
.locals 1
.line 350
invoke-static {p0}, Lcom/ea/nimble/Log$Helper;->LOGFUNC(Ljava/lang/Object;)V
const/4 v0, 0x1
.line 355
invoke-direct {p0, v0}, Lcom/ea/nimble/SynergyEnvironmentImpl;->restoreEnvironmentDataFromPersistent(Z)Z
move-result v0
iput-boolean v0, p0, Lcom/ea/nimble/SynergyEnvironmentImpl;->m_dataLoadedOnComponentSetup:Z
return-void
.end method
.method public suspend()V
.locals 2
.line 394
invoke-static {p0}, Lcom/ea/nimble/Log$Helper;->LOGFUNC(Ljava/lang/Object;)V
iget-object v0, p0, Lcom/ea/nimble/SynergyEnvironmentImpl;->m_synergyStartupObject:Lcom/ea/nimble/SynergyEnvironmentUpdater;
const/4 v1, 0x0
if-eqz v0, :cond_0
.line 401
invoke-virtual {v0}, Lcom/ea/nimble/SynergyEnvironmentUpdater;->cancel()V
iput-object v1, p0, Lcom/ea/nimble/SynergyEnvironmentImpl;->m_synergyStartupObject:Lcom/ea/nimble/SynergyEnvironmentUpdater;
:cond_0
iget-object v0, p0, Lcom/ea/nimble/SynergyEnvironmentImpl;->m_networkStatusChangeReceiver:Landroid/content/BroadcastReceiver;
if-eqz v0, :cond_1
.line 407
invoke-static {v0}, Lcom/ea/nimble/Utility;->unregisterReceiver(Landroid/content/BroadcastReceiver;)V
iput-object v1, p0, Lcom/ea/nimble/SynergyEnvironmentImpl;->m_networkStatusChangeReceiver:Landroid/content/BroadcastReceiver;
.line 411
:cond_1
invoke-direct {p0}, Lcom/ea/nimble/SynergyEnvironmentImpl;->saveEnvironmentDataToPersistent()V
return-void
.end method
.method public teardown()V
.locals 1
.line 472
invoke-static {p0}, Lcom/ea/nimble/Log$Helper;->LOGFUNC(Ljava/lang/Object;)V
const/4 v0, 0x0
iput-object v0, p0, Lcom/ea/nimble/SynergyEnvironmentImpl;->m_environmentDataContainer:Lcom/ea/nimble/EnvironmentDataContainer;
return-void
.end method