AppEventsLoggerImpl.smali
.class Lcom/facebook/appevents/AppEventsLoggerImpl;
.super Ljava/lang/Object;
.source "AppEventsLoggerImpl.java"
# static fields
.field private static final ACCOUNT_KIT_EVENT_NAME_PREFIX:Ljava/lang/String; = "fb_ak"
.field private static final APP_EVENTS_KILLSWITCH:Ljava/lang/String; = "app_events_killswitch"
.field private static final APP_EVENT_NAME_PUSH_OPENED:Ljava/lang/String; = "fb_mobile_push_opened"
.field private static final APP_EVENT_PREFERENCES:Ljava/lang/String; = "com.facebook.sdk.appEventPreferences"
.field private static final APP_EVENT_PUSH_PARAMETER_ACTION:Ljava/lang/String; = "fb_push_action"
.field private static final APP_EVENT_PUSH_PARAMETER_CAMPAIGN:Ljava/lang/String; = "fb_push_campaign"
.field private static final APP_SUPPORTS_ATTRIBUTION_ID_RECHECK_PERIOD_IN_SECONDS:I = 0x15180
.field private static final PUSH_PAYLOAD_CAMPAIGN_KEY:Ljava/lang/String; = "campaign"
.field private static final PUSH_PAYLOAD_KEY:Ljava/lang/String; = "fb_push_payload"
.field private static final TAG:Ljava/lang/String; = "com.facebook.appevents.AppEventsLoggerImpl"
.field private static anonymousAppDeviceGUID:Ljava/lang/String;
.field private static backgroundExecutor:Ljava/util/concurrent/ScheduledThreadPoolExecutor;
.field private static flushBehavior:Lcom/facebook/appevents/AppEventsLogger$FlushBehavior;
.field private static isActivateAppEventRequested:Z
.field private static pushNotificationsRegistrationId:Ljava/lang/String;
.field private static final staticLock:Ljava/lang/Object;
# instance fields
.field private final accessTokenAppId:Lcom/facebook/appevents/AccessTokenAppIdPair;
.field private final contextName:Ljava/lang/String;
# direct methods
.method static constructor <clinit>()V
.registers 1
.line 1
sget-object v0, Lcom/facebook/appevents/AppEventsLogger$FlushBehavior;->AUTO:Lcom/facebook/appevents/AppEventsLogger$FlushBehavior;
sput-object v0, Lcom/facebook/appevents/AppEventsLoggerImpl;->flushBehavior:Lcom/facebook/appevents/AppEventsLogger$FlushBehavior;
.line 2
new-instance v0, Ljava/lang/Object;
invoke-direct {v0}, Ljava/lang/Object;-><init>()V
sput-object v0, Lcom/facebook/appevents/AppEventsLoggerImpl;->staticLock:Ljava/lang/Object;
return-void
.end method
.method constructor <init>(Landroid/content/Context;Ljava/lang/String;Lcom/facebook/AccessToken;)V
.registers 4
.line 1
invoke-static {p1}, Lcom/facebook/internal/Utility;->getActivityName(Landroid/content/Context;)Ljava/lang/String;
move-result-object p1
.line 2
invoke-direct {p0, p1, p2, p3}, Lcom/facebook/appevents/AppEventsLoggerImpl;-><init>(Ljava/lang/String;Ljava/lang/String;Lcom/facebook/AccessToken;)V
return-void
.end method
.method constructor <init>(Ljava/lang/String;Ljava/lang/String;Lcom/facebook/AccessToken;)V
.registers 4
.line 3
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
.line 4
invoke-static {}, Lcom/facebook/internal/Validate;->sdkInitialized()V
.line 5
iput-object p1, p0, Lcom/facebook/appevents/AppEventsLoggerImpl;->contextName:Ljava/lang/String;
if-nez p3, :cond_e
.line 6
invoke-static {}, Lcom/facebook/AccessToken;->getCurrentAccessToken()Lcom/facebook/AccessToken;
move-result-object p3
:cond_e
if-eqz p3, :cond_2a
.line 7
invoke-virtual {p3}, Lcom/facebook/AccessToken;->isExpired()Z
move-result p1
if-nez p1, :cond_2a
if-eqz p2, :cond_22
.line 8
invoke-virtual {p3}, Lcom/facebook/AccessToken;->getApplicationId()Ljava/lang/String;
move-result-object p1
invoke-virtual {p2, p1}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z
move-result p1
if-eqz p1, :cond_2a
.line 9
:cond_22
new-instance p1, Lcom/facebook/appevents/AccessTokenAppIdPair;
invoke-direct {p1, p3}, Lcom/facebook/appevents/AccessTokenAppIdPair;-><init>(Lcom/facebook/AccessToken;)V
iput-object p1, p0, Lcom/facebook/appevents/AppEventsLoggerImpl;->accessTokenAppId:Lcom/facebook/appevents/AccessTokenAppIdPair;
goto :goto_3c
:cond_2a
if-nez p2, :cond_34
.line 10
invoke-static {}, Lcom/facebook/FacebookSdk;->getApplicationContext()Landroid/content/Context;
move-result-object p1
.line 11
invoke-static {p1}, Lcom/facebook/internal/Utility;->getMetadataApplicationId(Landroid/content/Context;)Ljava/lang/String;
move-result-object p2
.line 12
:cond_34
new-instance p1, Lcom/facebook/appevents/AccessTokenAppIdPair;
const/4 p3, 0x0
invoke-direct {p1, p3, p2}, Lcom/facebook/appevents/AccessTokenAppIdPair;-><init>(Ljava/lang/String;Ljava/lang/String;)V
iput-object p1, p0, Lcom/facebook/appevents/AppEventsLoggerImpl;->accessTokenAppId:Lcom/facebook/appevents/AccessTokenAppIdPair;
.line 13
:goto_3c
invoke-static {}, Lcom/facebook/appevents/AppEventsLoggerImpl;->initializeTimersIfNeeded()V
return-void
.end method
.method static synthetic access$000()Ljava/lang/String;
.registers 1
.line 1
sget-object v0, Lcom/facebook/appevents/AppEventsLoggerImpl;->TAG:Ljava/lang/String;
return-object v0
.end method
.method static activateApp(Landroid/app/Application;Ljava/lang/String;)V
.registers 3
.line 1
invoke-static {}, Lcom/facebook/FacebookSdk;->isInitialized()Z
move-result v0
if-eqz v0, :cond_19
.line 2
invoke-static {}, Lcom/facebook/appevents/AnalyticsUserIDStore;->initStore()V
.line 3
invoke-static {}, Lcom/facebook/appevents/UserDataStore;->initStore()V
if-nez p1, :cond_12
.line 4
invoke-static {}, Lcom/facebook/FacebookSdk;->getApplicationId()Ljava/lang/String;
move-result-object p1
.line 5
:cond_12
invoke-static {p0, p1}, Lcom/facebook/FacebookSdk;->publishInstallAsync(Landroid/content/Context;Ljava/lang/String;)V
.line 6
invoke-static {p0, p1}, Lcom/facebook/appevents/internal/ActivityLifecycleTracker;->startTracking(Landroid/app/Application;Ljava/lang/String;)V
return-void
.line 7
:cond_19
new-instance p0, Lcom/facebook/FacebookException;
const-string p1, "The Facebook sdk must be initialized before calling activateApp"
invoke-direct {p0, p1}, Lcom/facebook/FacebookException;-><init>(Ljava/lang/String;)V
throw p0
.end method
.method static augmentWebView(Landroid/webkit/WebView;Landroid/content/Context;)V
.registers 7
.line 1
sget-object v0, Landroid/os/Build$VERSION;->RELEASE:Ljava/lang/String;
const-string v1, "\\."
invoke-virtual {v0, v1}, Ljava/lang/String;->split(Ljava/lang/String;)[Ljava/lang/String;
move-result-object v0
.line 2
array-length v1, v0
const/4 v2, 0x0
if-lez v1, :cond_13
aget-object v1, v0, v2
invoke-static {v1}, Ljava/lang/Integer;->parseInt(Ljava/lang/String;)I
move-result v1
goto :goto_14
:cond_13
const/4 v1, 0x0
.line 3
:goto_14
array-length v3, v0
const/4 v4, 0x1
if-le v3, v4, :cond_1e
aget-object v0, v0, v4
invoke-static {v0}, Ljava/lang/Integer;->parseInt(Ljava/lang/String;)I
move-result v2
.line 4
:cond_1e
sget v0, Landroid/os/Build$VERSION;->SDK_INT:I
const/16 v3, 0x11
if-lt v0, v3, :cond_4a
const/4 v0, 0x4
if-lt v1, v0, :cond_4a
if-ne v1, v0, :cond_2c
if-gt v2, v4, :cond_2c
goto :goto_4a
.line 5
:cond_2c
new-instance v0, Lcom/facebook/appevents/FacebookSDKJSInterface;
invoke-direct {v0, p1}, Lcom/facebook/appevents/FacebookSDKJSInterface;-><init>(Landroid/content/Context;)V
new-instance p1, Ljava/lang/StringBuilder;
invoke-direct {p1}, Ljava/lang/StringBuilder;-><init>()V
const-string v1, "fbmq_"
invoke-virtual {p1, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
.line 6
invoke-static {}, Lcom/facebook/FacebookSdk;->getApplicationId()Ljava/lang/String;
move-result-object v1
invoke-virtual {p1, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {p1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p1
.line 7
invoke-virtual {p0, v0, p1}, Landroid/webkit/WebView;->addJavascriptInterface(Ljava/lang/Object;Ljava/lang/String;)V
return-void
.line 8
:cond_4a
:goto_4a
sget-object p0, Lcom/facebook/LoggingBehavior;->DEVELOPER_ERRORS:Lcom/facebook/LoggingBehavior;
sget-object p1, Lcom/facebook/appevents/AppEventsLoggerImpl;->TAG:Ljava/lang/String;
const-string v0, "augmentWebView is only available for Android SDK version >= 17 on devices running Android >= 4.2"
invoke-static {p0, p1, v0}, Lcom/facebook/internal/Logger;->log(Lcom/facebook/LoggingBehavior;Ljava/lang/String;Ljava/lang/String;)V
return-void
.end method
.method static eagerFlush()V
.registers 2
.line 1
invoke-static {}, Lcom/facebook/appevents/AppEventsLoggerImpl;->getFlushBehavior()Lcom/facebook/appevents/AppEventsLogger$FlushBehavior;
move-result-object v0
sget-object v1, Lcom/facebook/appevents/AppEventsLogger$FlushBehavior;->EXPLICIT_ONLY:Lcom/facebook/appevents/AppEventsLogger$FlushBehavior;
if-eq v0, v1, :cond_d
.line 2
sget-object v0, Lcom/facebook/appevents/FlushReason;->EAGER_FLUSHING_EVENT:Lcom/facebook/appevents/FlushReason;
invoke-static {v0}, Lcom/facebook/appevents/AppEventQueue;->flush(Lcom/facebook/appevents/FlushReason;)V
:cond_d
return-void
.end method
.method static functionDEPRECATED(Ljava/lang/String;)V
.registers 4
.line 1
sget-object v0, Lcom/facebook/appevents/AppEventsLoggerImpl;->TAG:Ljava/lang/String;
new-instance v1, Ljava/lang/StringBuilder;
invoke-direct {v1}, Ljava/lang/StringBuilder;-><init>()V
const-string v2, "This function is deprecated. "
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v1, p0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p0
invoke-static {v0, p0}, Landroid/util/Log;->w(Ljava/lang/String;Ljava/lang/String;)I
return-void
.end method
.method static getAnalyticsExecutor()Ljava/util/concurrent/Executor;
.registers 1
.line 1
sget-object v0, Lcom/facebook/appevents/AppEventsLoggerImpl;->backgroundExecutor:Ljava/util/concurrent/ScheduledThreadPoolExecutor;
if-nez v0, :cond_7
.line 2
invoke-static {}, Lcom/facebook/appevents/AppEventsLoggerImpl;->initializeTimersIfNeeded()V
.line 3
:cond_7
sget-object v0, Lcom/facebook/appevents/AppEventsLoggerImpl;->backgroundExecutor:Ljava/util/concurrent/ScheduledThreadPoolExecutor;
return-object v0
.end method
.method static getAnonymousAppDeviceGUID(Landroid/content/Context;)Ljava/lang/String;
.registers 6
.line 1
sget-object v0, Lcom/facebook/appevents/AppEventsLoggerImpl;->anonymousAppDeviceGUID:Ljava/lang/String;
if-nez v0, :cond_54
.line 2
sget-object v0, Lcom/facebook/appevents/AppEventsLoggerImpl;->staticLock:Ljava/lang/Object;
monitor-enter v0
.line 3
:try_start_7
sget-object v1, Lcom/facebook/appevents/AppEventsLoggerImpl;->anonymousAppDeviceGUID:Ljava/lang/String;
if-nez v1, :cond_4f
const-string v1, "com.facebook.sdk.appEventPreferences"
const/4 v2, 0x0
.line 4
invoke-virtual {p0, v1, v2}, Landroid/content/Context;->getSharedPreferences(Ljava/lang/String;I)Landroid/content/SharedPreferences;
move-result-object v1
const-string v3, "anonymousAppDeviceGUID"
const/4 v4, 0x0
.line 5
invoke-interface {v1, v3, v4}, Landroid/content/SharedPreferences;->getString(Ljava/lang/String;Ljava/lang/String;)Ljava/lang/String;
move-result-object v1
sput-object v1, Lcom/facebook/appevents/AppEventsLoggerImpl;->anonymousAppDeviceGUID:Ljava/lang/String;
.line 6
sget-object v1, Lcom/facebook/appevents/AppEventsLoggerImpl;->anonymousAppDeviceGUID:Ljava/lang/String;
if-nez v1, :cond_4f
.line 7
new-instance v1, Ljava/lang/StringBuilder;
invoke-direct {v1}, Ljava/lang/StringBuilder;-><init>()V
const-string v3, "XZ"
invoke-virtual {v1, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-static {}, Ljava/util/UUID;->randomUUID()Ljava/util/UUID;
move-result-object v3
invoke-virtual {v3}, Ljava/util/UUID;->toString()Ljava/lang/String;
move-result-object v3
invoke-virtual {v1, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v1
sput-object v1, Lcom/facebook/appevents/AppEventsLoggerImpl;->anonymousAppDeviceGUID:Ljava/lang/String;
const-string v1, "com.facebook.sdk.appEventPreferences"
.line 8
invoke-virtual {p0, v1, v2}, Landroid/content/Context;->getSharedPreferences(Ljava/lang/String;I)Landroid/content/SharedPreferences;
move-result-object p0
.line 9
invoke-interface {p0}, Landroid/content/SharedPreferences;->edit()Landroid/content/SharedPreferences$Editor;
move-result-object p0
const-string v1, "anonymousAppDeviceGUID"
sget-object v2, Lcom/facebook/appevents/AppEventsLoggerImpl;->anonymousAppDeviceGUID:Ljava/lang/String;
.line 10
invoke-interface {p0, v1, v2}, Landroid/content/SharedPreferences$Editor;->putString(Ljava/lang/String;Ljava/lang/String;)Landroid/content/SharedPreferences$Editor;
move-result-object p0
.line 11
invoke-interface {p0}, Landroid/content/SharedPreferences$Editor;->apply()V
.line 12
:cond_4f
monitor-exit v0
goto :goto_54
:catchall_51
move-exception p0
monitor-exit v0
:try_end_53
.catchall {:try_start_7 .. :try_end_53} :catchall_51
throw p0
.line 13
:cond_54
:goto_54
sget-object p0, Lcom/facebook/appevents/AppEventsLoggerImpl;->anonymousAppDeviceGUID:Ljava/lang/String;
return-object p0
.end method
.method static getFlushBehavior()Lcom/facebook/appevents/AppEventsLogger$FlushBehavior;
.registers 2
.line 1
sget-object v0, Lcom/facebook/appevents/AppEventsLoggerImpl;->staticLock:Ljava/lang/Object;
monitor-enter v0
.line 2
:try_start_3
sget-object v1, Lcom/facebook/appevents/AppEventsLoggerImpl;->flushBehavior:Lcom/facebook/appevents/AppEventsLogger$FlushBehavior;
monitor-exit v0
return-object v1
:catchall_7
move-exception v1
.line 3
monitor-exit v0
:try_end_9
.catchall {:try_start_3 .. :try_end_9} :catchall_7
throw v1
.end method
.method static getInstallReferrer()Ljava/lang/String;
.registers 3
.line 1
new-instance v0, Lcom/facebook/appevents/AppEventsLoggerImpl$2;
invoke-direct {v0}, Lcom/facebook/appevents/AppEventsLoggerImpl$2;-><init>()V
invoke-static {v0}, Lcom/facebook/internal/InstallReferrerUtil;->tryUpdateReferrerInfo(Lcom/facebook/internal/InstallReferrerUtil$Callback;)V
.line 2
invoke-static {}, Lcom/facebook/FacebookSdk;->getApplicationContext()Landroid/content/Context;
move-result-object v0
const-string v1, "com.facebook.sdk.appEventPreferences"
const/4 v2, 0x0
.line 3
invoke-virtual {v0, v1, v2}, Landroid/content/Context;->getSharedPreferences(Ljava/lang/String;I)Landroid/content/SharedPreferences;
move-result-object v0
const-string v1, "install_referrer"
const/4 v2, 0x0
.line 4
invoke-interface {v0, v1, v2}, Landroid/content/SharedPreferences;->getString(Ljava/lang/String;Ljava/lang/String;)Ljava/lang/String;
move-result-object v0
return-object v0
.end method
.method static getPushNotificationsRegistrationId()Ljava/lang/String;
.registers 2
.line 1
sget-object v0, Lcom/facebook/appevents/AppEventsLoggerImpl;->staticLock:Ljava/lang/Object;
monitor-enter v0
.line 2
:try_start_3
sget-object v1, Lcom/facebook/appevents/AppEventsLoggerImpl;->pushNotificationsRegistrationId:Ljava/lang/String;
monitor-exit v0
return-object v1
:catchall_7
move-exception v1
.line 3
monitor-exit v0
:try_end_9
.catchall {:try_start_3 .. :try_end_9} :catchall_7
throw v1
.end method
.method static initializeLib(Landroid/content/Context;Ljava/lang/String;)V
.registers 4
.line 1
invoke-static {}, Lcom/facebook/FacebookSdk;->getAutoLogAppEventsEnabled()Z
move-result v0
if-nez v0, :cond_7
return-void
.line 2
:cond_7
new-instance v0, Lcom/facebook/appevents/AppEventsLoggerImpl;
const/4 v1, 0x0
invoke-direct {v0, p0, p1, v1}, Lcom/facebook/appevents/AppEventsLoggerImpl;-><init>(Landroid/content/Context;Ljava/lang/String;Lcom/facebook/AccessToken;)V
.line 3
sget-object p1, Lcom/facebook/appevents/AppEventsLoggerImpl;->backgroundExecutor:Ljava/util/concurrent/ScheduledThreadPoolExecutor;
new-instance v1, Lcom/facebook/appevents/AppEventsLoggerImpl$1;
invoke-direct {v1, p0, v0}, Lcom/facebook/appevents/AppEventsLoggerImpl$1;-><init>(Landroid/content/Context;Lcom/facebook/appevents/AppEventsLoggerImpl;)V
invoke-virtual {p1, v1}, Ljava/util/concurrent/ScheduledThreadPoolExecutor;->execute(Ljava/lang/Runnable;)V
return-void
.end method
.method private static initializeTimersIfNeeded()V
.registers 10
.line 1
sget-object v0, Lcom/facebook/appevents/AppEventsLoggerImpl;->staticLock:Ljava/lang/Object;
monitor-enter v0
.line 2
:try_start_3
sget-object v1, Lcom/facebook/appevents/AppEventsLoggerImpl;->backgroundExecutor:Ljava/util/concurrent/ScheduledThreadPoolExecutor;
if-eqz v1, :cond_9
.line 3
monitor-exit v0
return-void
.line 4
:cond_9
new-instance v1, Ljava/util/concurrent/ScheduledThreadPoolExecutor;
const/4 v2, 0x1
invoke-direct {v1, v2}, Ljava/util/concurrent/ScheduledThreadPoolExecutor;-><init>(I)V
sput-object v1, Lcom/facebook/appevents/AppEventsLoggerImpl;->backgroundExecutor:Ljava/util/concurrent/ScheduledThreadPoolExecutor;
.line 5
monitor-exit v0
:try_end_12
.catchall {:try_start_3 .. :try_end_12} :catchall_24
.line 6
new-instance v4, Lcom/facebook/appevents/AppEventsLoggerImpl$4;
invoke-direct {v4}, Lcom/facebook/appevents/AppEventsLoggerImpl$4;-><init>()V
.line 7
sget-object v3, Lcom/facebook/appevents/AppEventsLoggerImpl;->backgroundExecutor:Ljava/util/concurrent/ScheduledThreadPoolExecutor;
const-wide/16 v5, 0x0
const-wide/32 v7, 0x15180
sget-object v9, Ljava/util/concurrent/TimeUnit;->SECONDS:Ljava/util/concurrent/TimeUnit;
invoke-virtual/range {v3 .. v9}, Ljava/util/concurrent/ScheduledThreadPoolExecutor;->scheduleAtFixedRate(Ljava/lang/Runnable;JJLjava/util/concurrent/TimeUnit;)Ljava/util/concurrent/ScheduledFuture;
return-void
:catchall_24
move-exception v1
.line 8
:try_start_25
monitor-exit v0
:try_end_26
.catchall {:try_start_25 .. :try_end_26} :catchall_24
throw v1
.end method
.method private static logEvent(Lcom/facebook/appevents/AppEvent;Lcom/facebook/appevents/AccessTokenAppIdPair;)V
.registers 3
.line 21
invoke-static {p1, p0}, Lcom/facebook/appevents/AppEventQueue;->add(Lcom/facebook/appevents/AccessTokenAppIdPair;Lcom/facebook/appevents/AppEvent;)V
.line 22
invoke-virtual {p0}, Lcom/facebook/appevents/AppEvent;->getIsImplicit()Z
move-result p1
if-nez p1, :cond_26
sget-boolean p1, Lcom/facebook/appevents/AppEventsLoggerImpl;->isActivateAppEventRequested:Z
if-nez p1, :cond_26
.line 23
invoke-virtual {p0}, Lcom/facebook/appevents/AppEvent;->getName()Ljava/lang/String;
move-result-object p0
const-string p1, "fb_mobile_activate_app"
invoke-virtual {p0, p1}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z
move-result p0
if-eqz p0, :cond_1d
const/4 p0, 0x1
.line 24
sput-boolean p0, Lcom/facebook/appevents/AppEventsLoggerImpl;->isActivateAppEventRequested:Z
goto :goto_26
.line 25
:cond_1d
sget-object p0, Lcom/facebook/LoggingBehavior;->APP_EVENTS:Lcom/facebook/LoggingBehavior;
const-string p1, "AppEvents"
const-string v0, "Warning: Please call AppEventsLogger.activateApp(...)from the long-lived activity\'s onResume() methodbefore logging other app events."
invoke-static {p0, p1, v0}, Lcom/facebook/internal/Logger;->log(Lcom/facebook/LoggingBehavior;Ljava/lang/String;Ljava/lang/String;)V
:cond_26
:goto_26
return-void
.end method
.method private static notifyDeveloperError(Ljava/lang/String;)V
.registers 3
.line 1
sget-object v0, Lcom/facebook/LoggingBehavior;->DEVELOPER_ERRORS:Lcom/facebook/LoggingBehavior;
const-string v1, "AppEvents"
invoke-static {v0, v1, p0}, Lcom/facebook/internal/Logger;->log(Lcom/facebook/LoggingBehavior;Ljava/lang/String;Ljava/lang/String;)V
return-void
.end method
.method static onContextStop()V
.registers 0
.line 1
invoke-static {}, Lcom/facebook/appevents/AppEventQueue;->persistToDisk()V
return-void
.end method
.method static setFlushBehavior(Lcom/facebook/appevents/AppEventsLogger$FlushBehavior;)V
.registers 2
.line 1
sget-object v0, Lcom/facebook/appevents/AppEventsLoggerImpl;->staticLock:Ljava/lang/Object;
monitor-enter v0
.line 2
:try_start_3
sput-object p0, Lcom/facebook/appevents/AppEventsLoggerImpl;->flushBehavior:Lcom/facebook/appevents/AppEventsLogger$FlushBehavior;
.line 3
monitor-exit v0
return-void
:catchall_7
move-exception p0
monitor-exit v0
:try_end_9
.catchall {:try_start_3 .. :try_end_9} :catchall_7
throw p0
.end method
.method static setInstallReferrer(Ljava/lang/String;)V
.registers 4
.line 1
invoke-static {}, Lcom/facebook/FacebookSdk;->getApplicationContext()Landroid/content/Context;
move-result-object v0
const-string v1, "com.facebook.sdk.appEventPreferences"
const/4 v2, 0x0
.line 2
invoke-virtual {v0, v1, v2}, Landroid/content/Context;->getSharedPreferences(Ljava/lang/String;I)Landroid/content/SharedPreferences;
move-result-object v0
if-eqz p0, :cond_1a
.line 3
invoke-interface {v0}, Landroid/content/SharedPreferences;->edit()Landroid/content/SharedPreferences$Editor;
move-result-object v0
const-string v1, "install_referrer"
invoke-interface {v0, v1, p0}, Landroid/content/SharedPreferences$Editor;->putString(Ljava/lang/String;Ljava/lang/String;)Landroid/content/SharedPreferences$Editor;
move-result-object p0
invoke-interface {p0}, Landroid/content/SharedPreferences$Editor;->apply()V
:cond_1a
return-void
.end method
.method static setPushNotificationsRegistrationId(Ljava/lang/String;)V
.registers 4
.line 1
sget-object v0, Lcom/facebook/appevents/AppEventsLoggerImpl;->staticLock:Ljava/lang/Object;
monitor-enter v0
.line 2
:try_start_3
sget-object v1, Lcom/facebook/appevents/AppEventsLoggerImpl;->pushNotificationsRegistrationId:Ljava/lang/String;
invoke-static {v1, p0}, Lcom/facebook/internal/Utility;->stringsEqualOrEmpty(Ljava/lang/String;Ljava/lang/String;)Z
move-result v1
if-nez v1, :cond_27
.line 3
sput-object p0, Lcom/facebook/appevents/AppEventsLoggerImpl;->pushNotificationsRegistrationId:Ljava/lang/String;
.line 4
new-instance p0, Lcom/facebook/appevents/AppEventsLoggerImpl;
.line 5
invoke-static {}, Lcom/facebook/FacebookSdk;->getApplicationContext()Landroid/content/Context;
move-result-object v1
const/4 v2, 0x0
invoke-direct {p0, v1, v2, v2}, Lcom/facebook/appevents/AppEventsLoggerImpl;-><init>(Landroid/content/Context;Ljava/lang/String;Lcom/facebook/AccessToken;)V
const-string v1, "fb_mobile_obtain_push_token"
.line 6
invoke-virtual {p0, v1}, Lcom/facebook/appevents/AppEventsLoggerImpl;->logEvent(Ljava/lang/String;)V
.line 7
invoke-static {}, Lcom/facebook/appevents/AppEventsLoggerImpl;->getFlushBehavior()Lcom/facebook/appevents/AppEventsLogger$FlushBehavior;
move-result-object v1
sget-object v2, Lcom/facebook/appevents/AppEventsLogger$FlushBehavior;->EXPLICIT_ONLY:Lcom/facebook/appevents/AppEventsLogger$FlushBehavior;
if-eq v1, v2, :cond_27
.line 8
invoke-virtual {p0}, Lcom/facebook/appevents/AppEventsLoggerImpl;->flush()V
.line 9
:cond_27
monitor-exit v0
return-void
:catchall_29
move-exception p0
monitor-exit v0
:try_end_2b
.catchall {:try_start_3 .. :try_end_2b} :catchall_29
throw p0
.end method
.method static updateUserProperties(Landroid/os/Bundle;Ljava/lang/String;Lcom/facebook/GraphRequest$Callback;)V
.registers 5
.line 1
invoke-static {}, Lcom/facebook/appevents/AppEventsLoggerImpl;->getAnalyticsExecutor()Ljava/util/concurrent/Executor;
move-result-object v0
new-instance v1, Lcom/facebook/appevents/AppEventsLoggerImpl$3;
invoke-direct {v1, p0, p1, p2}, Lcom/facebook/appevents/AppEventsLoggerImpl$3;-><init>(Landroid/os/Bundle;Ljava/lang/String;Lcom/facebook/GraphRequest$Callback;)V
invoke-interface {v0, v1}, Ljava/util/concurrent/Executor;->execute(Ljava/lang/Runnable;)V
return-void
.end method
# virtual methods
.method flush()V
.registers 2
.line 1
sget-object v0, Lcom/facebook/appevents/FlushReason;->EXPLICIT:Lcom/facebook/appevents/FlushReason;
invoke-static {v0}, Lcom/facebook/appevents/AppEventQueue;->flush(Lcom/facebook/appevents/FlushReason;)V
return-void
.end method
.method public getApplicationId()Ljava/lang/String;
.registers 2
.line 1
iget-object v0, p0, Lcom/facebook/appevents/AppEventsLoggerImpl;->accessTokenAppId:Lcom/facebook/appevents/AccessTokenAppIdPair;
invoke-virtual {v0}, Lcom/facebook/appevents/AccessTokenAppIdPair;->getApplicationId()Ljava/lang/String;
move-result-object v0
return-object v0
.end method
.method isValidForAccessToken(Lcom/facebook/AccessToken;)Z
.registers 3
.line 1
new-instance v0, Lcom/facebook/appevents/AccessTokenAppIdPair;
invoke-direct {v0, p1}, Lcom/facebook/appevents/AccessTokenAppIdPair;-><init>(Lcom/facebook/AccessToken;)V
.line 2
iget-object p1, p0, Lcom/facebook/appevents/AppEventsLoggerImpl;->accessTokenAppId:Lcom/facebook/appevents/AccessTokenAppIdPair;
invoke-virtual {p1, v0}, Lcom/facebook/appevents/AccessTokenAppIdPair;->equals(Ljava/lang/Object;)Z
move-result p1
return p1
.end method
.method logEvent(Ljava/lang/String;)V
.registers 3
const/4 v0, 0x0
.line 1
invoke-virtual {p0, p1, v0}, Lcom/facebook/appevents/AppEventsLoggerImpl;->logEvent(Ljava/lang/String;Landroid/os/Bundle;)V
return-void
.end method
.method logEvent(Ljava/lang/String;D)V
.registers 5
const/4 v0, 0x0
.line 2
invoke-virtual {p0, p1, p2, p3, v0}, Lcom/facebook/appevents/AppEventsLoggerImpl;->logEvent(Ljava/lang/String;DLandroid/os/Bundle;)V
return-void
.end method
.method logEvent(Ljava/lang/String;DLandroid/os/Bundle;)V
.registers 11
.line 5
invoke-static {p2, p3}, Ljava/lang/Double;->valueOf(D)Ljava/lang/Double;
move-result-object v2
.line 6
invoke-static {}, Lcom/facebook/appevents/internal/ActivityLifecycleTracker;->getCurrentSessionGuid()Ljava/util/UUID;
move-result-object v5
const/4 v4, 0x0
move-object v0, p0
move-object v1, p1
move-object v3, p4
.line 7
invoke-virtual/range {v0 .. v5}, Lcom/facebook/appevents/AppEventsLoggerImpl;->logEvent(Ljava/lang/String;Ljava/lang/Double;Landroid/os/Bundle;ZLjava/util/UUID;)V
return-void
.end method
.method logEvent(Ljava/lang/String;Landroid/os/Bundle;)V
.registers 9
.line 3
invoke-static {}, Lcom/facebook/appevents/internal/ActivityLifecycleTracker;->getCurrentSessionGuid()Ljava/util/UUID;
move-result-object v5
const/4 v2, 0x0
const/4 v4, 0x0
move-object v0, p0
move-object v1, p1
move-object v3, p2
.line 4
invoke-virtual/range {v0 .. v5}, Lcom/facebook/appevents/AppEventsLoggerImpl;->logEvent(Ljava/lang/String;Ljava/lang/Double;Landroid/os/Bundle;ZLjava/util/UUID;)V
return-void
.end method
.method logEvent(Ljava/lang/String;Ljava/lang/Double;Landroid/os/Bundle;ZLjava/util/UUID;)V
.registers 19
move-object v1, p0
if-eqz p1, :cond_61
.line 8
invoke-virtual {p1}, Ljava/lang/String;->isEmpty()Z
move-result v0
if-eqz v0, :cond_a
goto :goto_61
.line 9
:cond_a
invoke-static {}, Lcom/facebook/FacebookSdk;->getApplicationId()Ljava/lang/String;
move-result-object v0
const/4 v10, 0x0
const-string v2, "app_events_killswitch"
.line 10
invoke-static {v2, v0, v10}, Lcom/facebook/internal/FetchedAppGateKeepersManager;->getGateKeeperForKey(Ljava/lang/String;Ljava/lang/String;Z)Z
move-result v0
const/4 v11, 0x1
const-string v12, "AppEvents"
if-eqz v0, :cond_26
.line 11
sget-object v0, Lcom/facebook/LoggingBehavior;->APP_EVENTS:Lcom/facebook/LoggingBehavior;
new-array v2, v11, [Ljava/lang/Object;
aput-object p1, v2, v10
const-string v3, "KillSwitch is enabled and fail to log app event: %s"
invoke-static {v0, v12, v3, v2}, Lcom/facebook/internal/Logger;->log(Lcom/facebook/LoggingBehavior;Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
return-void
.line 12
:cond_26
:try_start_26
new-instance v0, Lcom/facebook/appevents/AppEvent;
iget-object v3, v1, Lcom/facebook/appevents/AppEventsLoggerImpl;->contextName:Ljava/lang/String;
.line 13
invoke-static {}, Lcom/facebook/appevents/internal/ActivityLifecycleTracker;->isInBackground()Z
move-result v8
move-object v2, v0
move-object v4, p1
move-object v5, p2
move-object/from16 v6, p3
move/from16 v7, p4
move-object/from16 v9, p5
invoke-direct/range {v2 .. v9}, Lcom/facebook/appevents/AppEvent;-><init>(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Double;Landroid/os/Bundle;ZZLjava/util/UUID;)V
.line 14
iget-object v2, v1, Lcom/facebook/appevents/AppEventsLoggerImpl;->accessTokenAppId:Lcom/facebook/appevents/AccessTokenAppIdPair;
invoke-static {v0, v2}, Lcom/facebook/appevents/AppEventsLoggerImpl;->logEvent(Lcom/facebook/appevents/AppEvent;Lcom/facebook/appevents/AccessTokenAppIdPair;)V
:try_end_3f
.catch Lorg/json/JSONException; {:try_start_26 .. :try_end_3f} :catch_51
.catch Lcom/facebook/FacebookException; {:try_start_26 .. :try_end_3f} :catch_40
goto :goto_61
:catch_40
move-exception v0
.line 15
sget-object v2, Lcom/facebook/LoggingBehavior;->APP_EVENTS:Lcom/facebook/LoggingBehavior;
new-array v3, v11, [Ljava/lang/Object;
.line 16
invoke-virtual {v0}, Lcom/facebook/FacebookException;->toString()Ljava/lang/String;
move-result-object v0
aput-object v0, v3, v10
const-string v0, "Invalid app event: %s"
.line 17
invoke-static {v2, v12, v0, v3}, Lcom/facebook/internal/Logger;->log(Lcom/facebook/LoggingBehavior;Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
goto :goto_61
:catch_51
move-exception v0
.line 18
sget-object v2, Lcom/facebook/LoggingBehavior;->APP_EVENTS:Lcom/facebook/LoggingBehavior;
new-array v3, v11, [Ljava/lang/Object;
.line 19
invoke-virtual {v0}, Lorg/json/JSONException;->toString()Ljava/lang/String;
move-result-object v0
aput-object v0, v3, v10
const-string v0, "JSON encoding for app event failed: \'%s\'"
.line 20
invoke-static {v2, v12, v0, v3}, Lcom/facebook/internal/Logger;->log(Lcom/facebook/LoggingBehavior;Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
:cond_61
:goto_61
return-void
.end method
.method logEventFromSE(Ljava/lang/String;Ljava/lang/String;)V
.registers 6
.line 1
new-instance v0, Landroid/os/Bundle;
invoke-direct {v0}, Landroid/os/Bundle;-><init>()V
const-string v1, "_is_suggested_event"
const-string v2, "1"
.line 2
invoke-virtual {v0, v1, v2}, Landroid/os/Bundle;->putString(Ljava/lang/String;Ljava/lang/String;)V
const-string v1, "_button_text"
.line 3
invoke-virtual {v0, v1, p2}, Landroid/os/Bundle;->putString(Ljava/lang/String;Ljava/lang/String;)V
.line 4
invoke-virtual {p0, p1, v0}, Lcom/facebook/appevents/AppEventsLoggerImpl;->logEvent(Ljava/lang/String;Landroid/os/Bundle;)V
return-void
.end method
.method logEventImplicitly(Ljava/lang/String;Ljava/lang/Double;Landroid/os/Bundle;)V
.registers 10
.line 1
invoke-static {}, Lcom/facebook/appevents/internal/ActivityLifecycleTracker;->getCurrentSessionGuid()Ljava/util/UUID;
move-result-object v5
const/4 v4, 0x1
move-object v0, p0
move-object v1, p1
move-object v2, p2
move-object v3, p3
.line 2
invoke-virtual/range {v0 .. v5}, Lcom/facebook/appevents/AppEventsLoggerImpl;->logEvent(Ljava/lang/String;Ljava/lang/Double;Landroid/os/Bundle;ZLjava/util/UUID;)V
return-void
.end method
.method logEventImplicitly(Ljava/lang/String;Ljava/math/BigDecimal;Ljava/util/Currency;Landroid/os/Bundle;)V
.registers 11
if-eqz p2, :cond_29
if-nez p3, :cond_5
goto :goto_29
:cond_5
if-nez p4, :cond_c
.line 3
new-instance p4, Landroid/os/Bundle;
invoke-direct {p4}, Landroid/os/Bundle;-><init>()V
:cond_c
move-object v3, p4
.line 4
invoke-virtual {p3}, Ljava/util/Currency;->getCurrencyCode()Ljava/lang/String;
move-result-object p3
const-string p4, "fb_currency"
invoke-virtual {v3, p4, p3}, Landroid/os/Bundle;->putString(Ljava/lang/String;Ljava/lang/String;)V
.line 5
invoke-virtual {p2}, Ljava/math/BigDecimal;->doubleValue()D
move-result-wide p2
invoke-static {p2, p3}, Ljava/lang/Double;->valueOf(D)Ljava/lang/Double;
move-result-object v2
const/4 v4, 0x1
.line 6
invoke-static {}, Lcom/facebook/appevents/internal/ActivityLifecycleTracker;->getCurrentSessionGuid()Ljava/util/UUID;
move-result-object v5
move-object v0, p0
move-object v1, p1
.line 7
invoke-virtual/range {v0 .. v5}, Lcom/facebook/appevents/AppEventsLoggerImpl;->logEvent(Ljava/lang/String;Ljava/lang/Double;Landroid/os/Bundle;ZLjava/util/UUID;)V
return-void
.line 8
:cond_29
:goto_29
sget-object p1, Lcom/facebook/appevents/AppEventsLoggerImpl;->TAG:Ljava/lang/String;
const-string p2, "purchaseAmount and currency cannot be null"
invoke-static {p1, p2}, Lcom/facebook/internal/Utility;->logd(Ljava/lang/String;Ljava/lang/String;)V
return-void
.end method
.method logProductItem(Ljava/lang/String;Lcom/facebook/appevents/AppEventsLogger$ProductAvailability;Lcom/facebook/appevents/AppEventsLogger$ProductCondition;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/math/BigDecimal;Ljava/util/Currency;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Landroid/os/Bundle;)V
.registers 15
if-nez p1, :cond_8
const-string p1, "itemID cannot be null"
.line 1
invoke-static {p1}, Lcom/facebook/appevents/AppEventsLoggerImpl;->notifyDeveloperError(Ljava/lang/String;)V
return-void
:cond_8
if-nez p2, :cond_10
const-string p1, "availability cannot be null"
.line 2
invoke-static {p1}, Lcom/facebook/appevents/AppEventsLoggerImpl;->notifyDeveloperError(Ljava/lang/String;)V
return-void
:cond_10
if-nez p3, :cond_18
const-string p1, "condition cannot be null"
.line 3
invoke-static {p1}, Lcom/facebook/appevents/AppEventsLoggerImpl;->notifyDeveloperError(Ljava/lang/String;)V
return-void
:cond_18
if-nez p4, :cond_20
const-string p1, "description cannot be null"
.line 4
invoke-static {p1}, Lcom/facebook/appevents/AppEventsLoggerImpl;->notifyDeveloperError(Ljava/lang/String;)V
return-void
:cond_20
if-nez p5, :cond_28
const-string p1, "imageLink cannot be null"
.line 5
invoke-static {p1}, Lcom/facebook/appevents/AppEventsLoggerImpl;->notifyDeveloperError(Ljava/lang/String;)V
return-void
:cond_28
if-nez p6, :cond_30
const-string p1, "link cannot be null"
.line 6
invoke-static {p1}, Lcom/facebook/appevents/AppEventsLoggerImpl;->notifyDeveloperError(Ljava/lang/String;)V
return-void
:cond_30
if-nez p7, :cond_38
const-string p1, "title cannot be null"
.line 7
invoke-static {p1}, Lcom/facebook/appevents/AppEventsLoggerImpl;->notifyDeveloperError(Ljava/lang/String;)V
return-void
:cond_38
if-nez p8, :cond_40
const-string p1, "priceAmount cannot be null"
.line 8
invoke-static {p1}, Lcom/facebook/appevents/AppEventsLoggerImpl;->notifyDeveloperError(Ljava/lang/String;)V
return-void
:cond_40
if-nez p9, :cond_48
const-string p1, "currency cannot be null"
.line 9
invoke-static {p1}, Lcom/facebook/appevents/AppEventsLoggerImpl;->notifyDeveloperError(Ljava/lang/String;)V
return-void
:cond_48
if-nez p10, :cond_54
if-nez p11, :cond_54
if-nez p12, :cond_54
const-string p1, "Either gtin, mpn or brand is required"
.line 10
invoke-static {p1}, Lcom/facebook/appevents/AppEventsLoggerImpl;->notifyDeveloperError(Ljava/lang/String;)V
return-void
:cond_54
if-nez p13, :cond_5b
.line 11
new-instance p13, Landroid/os/Bundle;
invoke-direct {p13}, Landroid/os/Bundle;-><init>()V
:cond_5b
const-string v0, "fb_product_item_id"
.line 12
invoke-virtual {p13, v0, p1}, Landroid/os/Bundle;->putString(Ljava/lang/String;Ljava/lang/String;)V
.line 13
invoke-virtual {p2}, Ljava/lang/Enum;->name()Ljava/lang/String;
move-result-object p1
const-string p2, "fb_product_availability"
invoke-virtual {p13, p2, p1}, Landroid/os/Bundle;->putString(Ljava/lang/String;Ljava/lang/String;)V
.line 14
invoke-virtual {p3}, Ljava/lang/Enum;->name()Ljava/lang/String;
move-result-object p1
const-string p2, "fb_product_condition"
invoke-virtual {p13, p2, p1}, Landroid/os/Bundle;->putString(Ljava/lang/String;Ljava/lang/String;)V
const-string p1, "fb_product_description"
.line 15
invoke-virtual {p13, p1, p4}, Landroid/os/Bundle;->putString(Ljava/lang/String;Ljava/lang/String;)V
const-string p1, "fb_product_image_link"
.line 16
invoke-virtual {p13, p1, p5}, Landroid/os/Bundle;->putString(Ljava/lang/String;Ljava/lang/String;)V
const-string p1, "fb_product_link"
.line 17
invoke-virtual {p13, p1, p6}, Landroid/os/Bundle;->putString(Ljava/lang/String;Ljava/lang/String;)V
const-string p1, "fb_product_title"
.line 18
invoke-virtual {p13, p1, p7}, Landroid/os/Bundle;->putString(Ljava/lang/String;Ljava/lang/String;)V
const/4 p1, 0x3
const/4 p2, 0x4
.line 19
invoke-virtual {p8, p1, p2}, Ljava/math/BigDecimal;->setScale(II)Ljava/math/BigDecimal;
move-result-object p1
invoke-virtual {p1}, Ljava/math/BigDecimal;->toString()Ljava/lang/String;
move-result-object p1
const-string p2, "fb_product_price_amount"
.line 20
invoke-virtual {p13, p2, p1}, Landroid/os/Bundle;->putString(Ljava/lang/String;Ljava/lang/String;)V
.line 21
invoke-virtual {p9}, Ljava/util/Currency;->getCurrencyCode()Ljava/lang/String;
move-result-object p1
const-string p2, "fb_product_price_currency"
.line 22
invoke-virtual {p13, p2, p1}, Landroid/os/Bundle;->putString(Ljava/lang/String;Ljava/lang/String;)V
if-eqz p10, :cond_a5
const-string p1, "fb_product_gtin"
.line 23
invoke-virtual {p13, p1, p10}, Landroid/os/Bundle;->putString(Ljava/lang/String;Ljava/lang/String;)V
:cond_a5
if-eqz p11, :cond_ac
const-string p1, "fb_product_mpn"
.line 24
invoke-virtual {p13, p1, p11}, Landroid/os/Bundle;->putString(Ljava/lang/String;Ljava/lang/String;)V
:cond_ac
if-eqz p12, :cond_b3
const-string p1, "fb_product_brand"
.line 25
invoke-virtual {p13, p1, p12}, Landroid/os/Bundle;->putString(Ljava/lang/String;Ljava/lang/String;)V
:cond_b3
const-string p1, "fb_mobile_catalog_update"
.line 26
invoke-virtual {p0, p1, p13}, Lcom/facebook/appevents/AppEventsLoggerImpl;->logEvent(Ljava/lang/String;Landroid/os/Bundle;)V
.line 27
invoke-static {}, Lcom/facebook/appevents/AppEventsLoggerImpl;->eagerFlush()V
return-void
.end method
.method logPurchase(Ljava/math/BigDecimal;Ljava/util/Currency;)V
.registers 4
const/4 v0, 0x0
.line 1
invoke-virtual {p0, p1, p2, v0}, Lcom/facebook/appevents/AppEventsLoggerImpl;->logPurchase(Ljava/math/BigDecimal;Ljava/util/Currency;Landroid/os/Bundle;)V
return-void
.end method
.method logPurchase(Ljava/math/BigDecimal;Ljava/util/Currency;Landroid/os/Bundle;)V
.registers 6
.line 2
invoke-static {}, Lcom/facebook/appevents/internal/AutomaticAnalyticsLogger;->isImplicitPurchaseLoggingEnabled()Z
move-result v0
if-eqz v0, :cond_d
.line 3
sget-object v0, Lcom/facebook/appevents/AppEventsLoggerImpl;->TAG:Ljava/lang/String;
const-string v1, "You are logging purchase events while auto-logging of in-app purchase is enabled in the SDK. Make sure you don\'t log duplicate events"
invoke-static {v0, v1}, Landroid/util/Log;->w(Ljava/lang/String;Ljava/lang/String;)I
:cond_d
const/4 v0, 0x0
.line 4
invoke-virtual {p0, p1, p2, p3, v0}, Lcom/facebook/appevents/AppEventsLoggerImpl;->logPurchase(Ljava/math/BigDecimal;Ljava/util/Currency;Landroid/os/Bundle;Z)V
return-void
.end method
.method logPurchase(Ljava/math/BigDecimal;Ljava/util/Currency;Landroid/os/Bundle;Z)V
.registers 11
if-nez p1, :cond_8
const-string p1, "purchaseAmount cannot be null"
.line 5
invoke-static {p1}, Lcom/facebook/appevents/AppEventsLoggerImpl;->notifyDeveloperError(Ljava/lang/String;)V
return-void
:cond_8
if-nez p2, :cond_10
const-string p1, "currency cannot be null"
.line 6
invoke-static {p1}, Lcom/facebook/appevents/AppEventsLoggerImpl;->notifyDeveloperError(Ljava/lang/String;)V
return-void
:cond_10
if-nez p3, :cond_17
.line 7
new-instance p3, Landroid/os/Bundle;
invoke-direct {p3}, Landroid/os/Bundle;-><init>()V
:cond_17
move-object v3, p3
.line 8
invoke-virtual {p2}, Ljava/util/Currency;->getCurrencyCode()Ljava/lang/String;
move-result-object p2
const-string p3, "fb_currency"
invoke-virtual {v3, p3, p2}, Landroid/os/Bundle;->putString(Ljava/lang/String;Ljava/lang/String;)V
.line 9
invoke-virtual {p1}, Ljava/math/BigDecimal;->doubleValue()D
move-result-wide p1
invoke-static {p1, p2}, Ljava/lang/Double;->valueOf(D)Ljava/lang/Double;
move-result-object v2
.line 10
invoke-static {}, Lcom/facebook/appevents/internal/ActivityLifecycleTracker;->getCurrentSessionGuid()Ljava/util/UUID;
move-result-object v5
const-string v1, "fb_mobile_purchase"
move-object v0, p0
move v4, p4
.line 11
invoke-virtual/range {v0 .. v5}, Lcom/facebook/appevents/AppEventsLoggerImpl;->logEvent(Ljava/lang/String;Ljava/lang/Double;Landroid/os/Bundle;ZLjava/util/UUID;)V
.line 12
invoke-static {}, Lcom/facebook/appevents/AppEventsLoggerImpl;->eagerFlush()V
return-void
.end method
.method logPurchaseImplicitly(Ljava/math/BigDecimal;Ljava/util/Currency;Landroid/os/Bundle;)V
.registers 5
const/4 v0, 0x1
.line 1
invoke-virtual {p0, p1, p2, p3, v0}, Lcom/facebook/appevents/AppEventsLoggerImpl;->logPurchase(Ljava/math/BigDecimal;Ljava/util/Currency;Landroid/os/Bundle;Z)V
return-void
.end method
.method logPushNotificationOpen(Landroid/os/Bundle;Ljava/lang/String;)V
.registers 5
:try_start_0
const-string v0, "fb_push_payload"
.line 1
invoke-virtual {p1, v0}, Landroid/os/Bundle;->getString(Ljava/lang/String;)Ljava/lang/String;
move-result-object p1
.line 2
invoke-static {p1}, Lcom/facebook/internal/Utility;->isNullOrEmpty(Ljava/lang/String;)Z
move-result v0
if-eqz v0, :cond_d
return-void
.line 3
:cond_d
new-instance v0, Lorg/json/JSONObject;
invoke-direct {v0, p1}, Lorg/json/JSONObject;-><init>(Ljava/lang/String;)V
const-string p1, "campaign"
.line 4
invoke-virtual {v0, p1}, Lorg/json/JSONObject;->getString(Ljava/lang/String;)Ljava/lang/String;
move-result-object p1
:try_end_18
.catch Lorg/json/JSONException; {:try_start_0 .. :try_end_18} :catch_19
goto :goto_1a
:catch_19
const/4 p1, 0x0
:goto_1a
if-nez p1, :cond_26
.line 5
sget-object p1, Lcom/facebook/LoggingBehavior;->DEVELOPER_ERRORS:Lcom/facebook/LoggingBehavior;
sget-object p2, Lcom/facebook/appevents/AppEventsLoggerImpl;->TAG:Ljava/lang/String;
const-string v0, "Malformed payload specified for logging a push notification open."
invoke-static {p1, p2, v0}, Lcom/facebook/internal/Logger;->log(Lcom/facebook/LoggingBehavior;Ljava/lang/String;Ljava/lang/String;)V
return-void
.line 6
:cond_26
new-instance v0, Landroid/os/Bundle;
invoke-direct {v0}, Landroid/os/Bundle;-><init>()V
const-string v1, "fb_push_campaign"
.line 7
invoke-virtual {v0, v1, p1}, Landroid/os/Bundle;->putString(Ljava/lang/String;Ljava/lang/String;)V
if-eqz p2, :cond_37
const-string p1, "fb_push_action"
.line 8
invoke-virtual {v0, p1, p2}, Landroid/os/Bundle;->putString(Ljava/lang/String;Ljava/lang/String;)V
:cond_37
const-string p1, "fb_mobile_push_opened"
.line 9
invoke-virtual {p0, p1, v0}, Lcom/facebook/appevents/AppEventsLoggerImpl;->logEvent(Ljava/lang/String;Landroid/os/Bundle;)V
return-void
.end method
.method logSdkEvent(Ljava/lang/String;Ljava/lang/Double;Landroid/os/Bundle;)V
.registers 11
const-string v0, "fb_ak"
.line 1
invoke-virtual {p1, v0}, Ljava/lang/String;->startsWith(Ljava/lang/String;)Z
move-result v0
if-nez v0, :cond_10
.line 2
sget-object p1, Lcom/facebook/appevents/AppEventsLoggerImpl;->TAG:Ljava/lang/String;
const-string p2, "logSdkEvent is deprecated and only supports account kit for legacy, please use logEvent instead"
invoke-static {p1, p2}, Landroid/util/Log;->e(Ljava/lang/String;Ljava/lang/String;)I
return-void
.line 3
:cond_10
invoke-static {}, Lcom/facebook/FacebookSdk;->getAutoLogAppEventsEnabled()Z
move-result v0
if-eqz v0, :cond_22
const/4 v5, 0x1
.line 4
invoke-static {}, Lcom/facebook/appevents/internal/ActivityLifecycleTracker;->getCurrentSessionGuid()Ljava/util/UUID;
move-result-object v6
move-object v1, p0
move-object v2, p1
move-object v3, p2
move-object v4, p3
.line 5
invoke-virtual/range {v1 .. v6}, Lcom/facebook/appevents/AppEventsLoggerImpl;->logEvent(Ljava/lang/String;Ljava/lang/Double;Landroid/os/Bundle;ZLjava/util/UUID;)V
:cond_22
return-void
.end method