LocalVpnService$VpnConnectTask.smali

.class Lcom/quickbird/mini/vpn/vpn/LocalVpnService$VpnConnectTask;
.super Ljava/lang/Thread;
.source "LocalVpnService.java"


# annotations
.annotation system Ldalvik/annotation/EnclosingClass;
    value = Lcom/quickbird/mini/vpn/vpn/LocalVpnService;
.end annotation

.annotation system Ldalvik/annotation/InnerClass;
    accessFlags = 0x0
    name = "VpnConnectTask"
.end annotation


# instance fields
.field private startTime:J

.field final synthetic this$0:Lcom/quickbird/mini/vpn/vpn/LocalVpnService;


# direct methods
.method private constructor <init>(Lcom/quickbird/mini/vpn/vpn/LocalVpnService;)V
    .registers 4

    .prologue
    .line 212
    iput-object p1, p0, Lcom/quickbird/mini/vpn/vpn/LocalVpnService$VpnConnectTask;->this$0:Lcom/quickbird/mini/vpn/vpn/LocalVpnService;

    invoke-direct {p0}, Ljava/lang/Thread;-><init>()V

    .line 214
    invoke-static {}, Ljava/lang/System;->currentTimeMillis()J

    move-result-wide v0

    iput-wide v0, p0, Lcom/quickbird/mini/vpn/vpn/LocalVpnService$VpnConnectTask;->startTime:J

    return-void
.end method

.method synthetic constructor <init>(Lcom/quickbird/mini/vpn/vpn/LocalVpnService;Lcom/quickbird/mini/vpn/vpn/LocalVpnService$1;)V
    .registers 3

    .prologue
    .line 212
    invoke-direct {p0, p1}, Lcom/quickbird/mini/vpn/vpn/LocalVpnService$VpnConnectTask;-><init>(Lcom/quickbird/mini/vpn/vpn/LocalVpnService;)V

    return-void
.end method


# virtual methods
.method public run()V
    .registers 8

    .prologue
    .line 220
    :try_start_0
    sget-boolean v0, Lcom/quickbird/sdk/QuickBird;->SDK_DEBUG:Z

    if-eqz v0, :cond_b

    const-string v0, "QbSdk"

    const-string v1, "Start vpn connect task."

    invoke-static {v0, v1}, Lcom/quickbird/sdk/utils/QBLogger;->d(Ljava/lang/String;Ljava/lang/String;)V

    .line 221
    :cond_b
    new-instance v1, Landroid/net/VpnService$Builder;

    iget-object v0, p0, Lcom/quickbird/mini/vpn/vpn/LocalVpnService$VpnConnectTask;->this$0:Lcom/quickbird/mini/vpn/vpn/LocalVpnService;

    invoke-direct {v1, v0}, Landroid/net/VpnService$Builder;-><init>(Landroid/net/VpnService;)V

    .line 222
    const-string v0, "192.168.19.19"

    const/16 v2, 0x20

    invoke-virtual {v1, v0, v2}, Landroid/net/VpnService$Builder;->addAddress(Ljava/lang/String;I)Landroid/net/VpnService$Builder;

    .line 223
    const-string v0, "0.0.0.0"

    const/4 v2, 0x0

    invoke-virtual {v1, v0, v2}, Landroid/net/VpnService$Builder;->addRoute(Ljava/lang/String;I)Landroid/net/VpnService$Builder;

    .line 224
    iget-object v0, p0, Lcom/quickbird/mini/vpn/vpn/LocalVpnService$VpnConnectTask;->this$0:Lcom/quickbird/mini/vpn/vpn/LocalVpnService;

    # getter for: Lcom/quickbird/mini/vpn/vpn/LocalVpnService;->mVpnMgr:Lcom/quickbird/mini/vpn/vpn/VpnServiceManager;
    invoke-static {v0}, Lcom/quickbird/mini/vpn/vpn/LocalVpnService;->access$200(Lcom/quickbird/mini/vpn/vpn/LocalVpnService;)Lcom/quickbird/mini/vpn/vpn/VpnServiceManager;

    move-result-object v0

    invoke-virtual {v0}, Lcom/quickbird/mini/vpn/vpn/VpnServiceManager;->getVpnServiceName()Ljava/lang/String;

    move-result-object v0

    .line 225
    invoke-virtual {v1, v0}, Landroid/net/VpnService$Builder;->setSession(Ljava/lang/String;)Landroid/net/VpnService$Builder;

    .line 228
    iget-object v0, p0, Lcom/quickbird/mini/vpn/vpn/LocalVpnService$VpnConnectTask;->this$0:Lcom/quickbird/mini/vpn/vpn/LocalVpnService;

    const-string v2, "audio"

    invoke-virtual {v0, v2}, Lcom/quickbird/mini/vpn/vpn/LocalVpnService;->getSystemService(Ljava/lang/String;)Ljava/lang/Object;

    move-result-object v0

    check-cast v0, Landroid/media/AudioManager;

    .line 229
    const/4 v2, 0x5

    invoke-virtual {v0, v2}, Landroid/media/AudioManager;->getStreamVolume(I)I

    move-result v2

    .line 230
    const/4 v3, 0x1

    invoke-virtual {v0, v3}, Landroid/media/AudioManager;->getVibrateSetting(I)I
    :try_end_3f
    .catch Ljava/lang/Exception; {:try_start_0 .. :try_end_3f} :catch_a7

    move-result v3

    .line 233
    const/4 v4, 0x5

    const/4 v5, 0x0

    const/4 v6, 0x0

    :try_start_43
    invoke-virtual {v0, v4, v5, v6}, Landroid/media/AudioManager;->setStreamVolume(III)V

    .line 234
    const/4 v4, 0x1

    const/4 v5, 0x0

    invoke-virtual {v0, v4, v5}, Landroid/media/AudioManager;->setVibrateSetting(II)V

    .line 235
    iget-object v4, p0, Lcom/quickbird/mini/vpn/vpn/LocalVpnService$VpnConnectTask;->this$0:Lcom/quickbird/mini/vpn/vpn/LocalVpnService;

    invoke-virtual {v1}, Landroid/net/VpnService$Builder;->establish()Landroid/os/ParcelFileDescriptor;

    move-result-object v1

    # setter for: Lcom/quickbird/mini/vpn/vpn/LocalVpnService;->mVpnFD:Landroid/os/ParcelFileDescriptor;
    invoke-static {v4, v1}, Lcom/quickbird/mini/vpn/vpn/LocalVpnService;->access$302(Lcom/quickbird/mini/vpn/vpn/LocalVpnService;Landroid/os/ParcelFileDescriptor;)Landroid/os/ParcelFileDescriptor;

    .line 236
    iget-object v1, p0, Lcom/quickbird/mini/vpn/vpn/LocalVpnService$VpnConnectTask;->this$0:Lcom/quickbird/mini/vpn/vpn/LocalVpnService;

    # invokes: Lcom/quickbird/mini/vpn/vpn/LocalVpnService;->waitForWatchdogStart()V
    invoke-static {v1}, Lcom/quickbird/mini/vpn/vpn/LocalVpnService;->access$400(Lcom/quickbird/mini/vpn/vpn/LocalVpnService;)V

    .line 237
    new-instance v1, Landroid/content/Intent;

    const-string v4, "com.dianxinos.optimizer.action.VPN_START"

    invoke-direct {v1, v4}, Landroid/content/Intent;-><init>(Ljava/lang/String;)V

    .line 238
    iget-object v4, p0, Lcom/quickbird/mini/vpn/vpn/LocalVpnService$VpnConnectTask;->this$0:Lcom/quickbird/mini/vpn/vpn/LocalVpnService;

    invoke-virtual {v4, v1}, Lcom/quickbird/mini/vpn/vpn/LocalVpnService;->sendBroadcast(Landroid/content/Intent;)V
    :try_end_65
    .catchall {:try_start_43 .. :try_end_65} :catchall_9c

    .line 240
    const/4 v1, 0x5

    const/4 v4, 0x0

    :try_start_67
    invoke-virtual {v0, v1, v2, v4}, Landroid/media/AudioManager;->setStreamVolume(III)V

    .line 241
    const/4 v1, 0x1

    invoke-virtual {v0, v1, v3}, Landroid/media/AudioManager;->setVibrateSetting(II)V

    .line 244
    sget-boolean v0, Lcom/quickbird/sdk/QuickBird;->SDK_DEBUG:Z

    if-eqz v0, :cond_91

    .line 245
    const-string v0, "QbSdk"

    new-instance v1, Ljava/lang/StringBuilder;

    invoke-direct {v1}, Ljava/lang/StringBuilder;-><init>()V

    const-string v2, "Vpn connect used time : "

    invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    move-result-object v1

    invoke-static {}, Ljava/lang/System;->currentTimeMillis()J

    move-result-wide v2

    iget-wide v4, p0, Lcom/quickbird/mini/vpn/vpn/LocalVpnService$VpnConnectTask;->startTime:J

    sub-long/2addr v2, v4

    invoke-virtual {v1, v2, v3}, Ljava/lang/StringBuilder;->append(J)Ljava/lang/StringBuilder;

    move-result-object v1

    invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;

    move-result-object v1

    invoke-static {v0, v1}, Lcom/quickbird/sdk/utils/QBLogger;->d(Ljava/lang/String;Ljava/lang/String;)V
    :try_end_91
    .catch Ljava/lang/Exception; {:try_start_67 .. :try_end_91} :catch_a7

    .line 253
    :cond_91
    :goto_91
    iget-object v1, p0, Lcom/quickbird/mini/vpn/vpn/LocalVpnService$VpnConnectTask;->this$0:Lcom/quickbird/mini/vpn/vpn/LocalVpnService;

    monitor-enter v1

    .line 254
    :try_start_94
    iget-object v0, p0, Lcom/quickbird/mini/vpn/vpn/LocalVpnService$VpnConnectTask;->this$0:Lcom/quickbird/mini/vpn/vpn/LocalVpnService;

    const/4 v2, 0x0

    # setter for: Lcom/quickbird/mini/vpn/vpn/LocalVpnService;->mVpnConnectTask:Lcom/quickbird/mini/vpn/vpn/LocalVpnService$VpnConnectTask;
    invoke-static {v0, v2}, Lcom/quickbird/mini/vpn/vpn/LocalVpnService;->access$502(Lcom/quickbird/mini/vpn/vpn/LocalVpnService;Lcom/quickbird/mini/vpn/vpn/LocalVpnService$VpnConnectTask;)Lcom/quickbird/mini/vpn/vpn/LocalVpnService$VpnConnectTask;

    .line 255
    monitor-exit v1
    :try_end_9b
    .catchall {:try_start_94 .. :try_end_9b} :catchall_b4

    .line 256
    return-void

    .line 240
    :catchall_9c
    move-exception v1

    const/4 v4, 0x5

    const/4 v5, 0x0

    :try_start_9f
    invoke-virtual {v0, v4, v2, v5}, Landroid/media/AudioManager;->setStreamVolume(III)V

    .line 241
    const/4 v2, 0x1

    invoke-virtual {v0, v2, v3}, Landroid/media/AudioManager;->setVibrateSetting(II)V

    .line 240
    throw v1
    :try_end_a7
    .catch Ljava/lang/Exception; {:try_start_9f .. :try_end_a7} :catch_a7

    .line 247
    :catch_a7
    move-exception v0

    .line 248
    sget-boolean v0, Lcom/quickbird/sdk/QuickBird;->SDK_DEBUG:Z

    if-eqz v0, :cond_91

    .line 249
    const-string v0, "QbSdk"

    const-string v1, "Vpn connect error!!!"

    invoke-static {v0, v1}, Lcom/quickbird/sdk/utils/QBLogger;->e(Ljava/lang/String;Ljava/lang/String;)V

    goto :goto_91

    .line 255
    :catchall_b4
    move-exception v0

    :try_start_b5
    monitor-exit v1
    :try_end_b6
    .catchall {:try_start_b5 .. :try_end_b6} :catchall_b4

    throw v0
.end method