Log2FileService.smali
.class public Lcom/banalytics/Log2FileService;
.super Lcom/banalytics/LoggerIntentService;
.source "Log2FileService.java"
# annotations
.annotation system Ldalvik/annotation/MemberClasses;
value = {
Lcom/banalytics/Log2FileService$a;
}
.end annotation
# static fields
.field private static final a:Ljava/lang/String; = "Log2FileService"
.field private static b:Ljava/lang/String;
.field private static c:Ljava/text/SimpleDateFormat;
.field private static d:Ljava/text/SimpleDateFormat;
.field public static e:Ljava/lang/String;
.field public static f:Ljava/lang/String;
# instance fields
.field private g:Ljava/util/HashMap;
.annotation system Ldalvik/annotation/Signature;
value = {
"Ljava/util/HashMap<",
"Ljava/lang/String;",
"Ljava/util/ArrayList<",
"Lcom/banalytics/Log2FileService$a;",
">;>;"
}
.end annotation
.end field
# direct methods
.method static constructor <clinit>()V
.registers 3
.line 1
new-instance v0, Ljava/text/SimpleDateFormat;
sget-object v1, Ljava/util/Locale;->ENGLISH:Ljava/util/Locale;
const-string/jumbo v2, "yyyy-MM-dd-HH"
invoke-direct {v0, v2, v1}, Ljava/text/SimpleDateFormat;-><init>(Ljava/lang/String;Ljava/util/Locale;)V
sput-object v0, Lcom/banalytics/Log2FileService;->c:Ljava/text/SimpleDateFormat;
.line 2
new-instance v0, Ljava/text/SimpleDateFormat;
sget-object v1, Ljava/util/Locale;->ENGLISH:Ljava/util/Locale;
const-string/jumbo v2, "yyyy-MM-dd HH:mm:ss.SSS"
invoke-direct {v0, v2, v1}, Ljava/text/SimpleDateFormat;-><init>(Ljava/lang/String;Ljava/util/Locale;)V
sput-object v0, Lcom/banalytics/Log2FileService;->d:Ljava/text/SimpleDateFormat;
const-string v0, "http://203.116.180.99/crash/logs/"
.line 3
sput-object v0, Lcom/banalytics/Log2FileService;->e:Ljava/lang/String;
const-string v0, "crashreporter.beetalkmobile.com"
.line 4
sput-object v0, Lcom/banalytics/Log2FileService;->f:Ljava/lang/String;
return-void
.end method
.method public constructor <init>()V
.registers 2
const-string v0, "log2file"
.line 1
invoke-direct {p0, v0}, Lcom/banalytics/LoggerIntentService;-><init>(Ljava/lang/String;)V
.line 2
new-instance v0, Ljava/util/HashMap;
invoke-direct {v0}, Ljava/util/HashMap;-><init>()V
iput-object v0, p0, Lcom/banalytics/Log2FileService;->g:Ljava/util/HashMap;
return-void
.end method
.method private static a(J)Ljava/lang/String;
.registers 10
const/16 v0, 0x3e8
int-to-long v1, v0
cmp-long v3, p0, v1
if-gez v3, :cond_19
.line 68
new-instance v0, Ljava/lang/StringBuilder;
invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V
invoke-virtual {v0, p0, p1}, Ljava/lang/StringBuilder;->append(J)Ljava/lang/StringBuilder;
const-string p0, " B"
invoke-virtual {v0, p0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p0
return-object p0
:cond_19
long-to-double p0, p0
.line 69
invoke-static {p0, p1}, Ljava/lang/Math;->log(D)D
move-result-wide v1
int-to-double v3, v0
invoke-static {v3, v4}, Ljava/lang/Math;->log(D)D
move-result-wide v5
div-double/2addr v1, v5
double-to-int v0, v1
.line 70
new-instance v1, Ljava/lang/StringBuilder;
invoke-direct {v1}, Ljava/lang/StringBuilder;-><init>()V
add-int/lit8 v2, v0, -0x1
const-string v5, "kMGTPE"
invoke-virtual {v5, v2}, Ljava/lang/String;->charAt(I)C
move-result v2
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(C)Ljava/lang/StringBuilder;
const-string 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
const/4 v2, 0x2
.line 71
new-array v2, v2, [Ljava/lang/Object;
const/4 v5, 0x0
int-to-double v6, v0
invoke-static {v3, v4, v6, v7}, Ljava/lang/Math;->pow(DD)D
move-result-wide v3
invoke-static {p0, p1}, Ljava/lang/Double;->isNaN(D)Z
div-double/2addr p0, v3
invoke-static {p0, p1}, Ljava/lang/Double;->valueOf(D)Ljava/lang/Double;
move-result-object p0
aput-object p0, v2, v5
const/4 p0, 0x1
aput-object v1, v2, p0
const-string p0, "%.1f %sB"
invoke-static {p0, v2}, Ljava/lang/String;->format(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
move-result-object p0
return-object p0
.end method
.method static synthetic a()Ljava/text/SimpleDateFormat;
.registers 1
.line 1
sget-object v0, Lcom/banalytics/Log2FileService;->c:Ljava/text/SimpleDateFormat;
return-object v0
.end method
.method public static a(Landroid/content/Context;Ljava/lang/String;ZLjava/lang/String;)V
.registers 8
.line 2
new-instance v0, Landroid/content/Intent;
const-class v1, Lcom/banalytics/Log2FileService;
invoke-direct {v0, p0, v1}, Landroid/content/Intent;-><init>(Landroid/content/Context;Ljava/lang/Class;)V
.line 3
invoke-static {}, Ljava/lang/System;->currentTimeMillis()J
move-result-wide v1
const-string v3, "time"
invoke-virtual {v0, v3, v1, v2}, Landroid/content/Intent;->putExtra(Ljava/lang/String;J)Landroid/content/Intent;
const-string v1, "log"
.line 4
invoke-virtual {v0, v1, p1}, Landroid/content/Intent;->putExtra(Ljava/lang/String;Ljava/lang/String;)Landroid/content/Intent;
const-string p1, "forceFlush"
.line 5
invoke-virtual {v0, p1, p2}, Landroid/content/Intent;->putExtra(Ljava/lang/String;Z)Landroid/content/Intent;
const-string p1, "dir_path"
.line 6
invoke-virtual {v0, p1, p3}, Landroid/content/Intent;->putExtra(Ljava/lang/String;Ljava/lang/String;)Landroid/content/Intent;
.line 7
sget p1, Landroid/os/Build$VERSION;->SDK_INT:I
const/16 p2, 0x1a
if-lt p1, p2, :cond_29
.line 8
invoke-virtual {p0, v0}, Landroid/content/Context;->startForegroundService(Landroid/content/Intent;)Landroid/content/ComponentName;
goto :goto_2c
.line 9
:cond_29
invoke-virtual {p0, v0}, Landroid/content/Context;->startService(Landroid/content/Intent;)Landroid/content/ComponentName;
:goto_2c
return-void
.end method
.method private a(Lcom/banalytics/Log2FileService$a;)V
.registers 11
.line 20
new-instance v0, Ljava/io/File;
iget-object v1, p1, Lcom/banalytics/Log2FileService$a;->a:Ljava/lang/String;
invoke-direct {p0, v1}, Lcom/banalytics/Log2FileService;->b(Ljava/lang/String;)Ljava/lang/String;
move-result-object v1
invoke-direct {v0, v1}, Ljava/io/File;-><init>(Ljava/lang/String;)V
.line 21
iget-wide v1, p1, Lcom/banalytics/Log2FileService$a;->b:J
const-wide/32 v3, 0x36ee80
sub-long/2addr v1, v3
.line 22
sget-object v3, Lcom/banalytics/Log2FileService;->c:Ljava/text/SimpleDateFormat;
new-instance v4, Ljava/util/Date;
invoke-direct {v4, v1, v2}, Ljava/util/Date;-><init>(J)V
invoke-virtual {v3, v4}, Ljava/text/SimpleDateFormat;->format(Ljava/util/Date;)Ljava/lang/String;
move-result-object v1
.line 23
new-instance v2, Ljava/io/File;
invoke-direct {p0, v1}, Lcom/banalytics/Log2FileService;->b(Ljava/lang/String;)Ljava/lang/String;
move-result-object v1
invoke-direct {v2, v1}, Ljava/io/File;-><init>(Ljava/lang/String;)V
.line 24
new-instance v1, Ljava/lang/StringBuffer;
invoke-direct {v1}, Ljava/lang/StringBuffer;-><init>()V
const/16 v3, 0xa
.line 25
invoke-virtual {v1, v3}, Ljava/lang/StringBuffer;->append(C)Ljava/lang/StringBuffer;
new-instance v4, Ljava/lang/StringBuilder;
invoke-direct {v4}, Ljava/lang/StringBuilder;-><init>()V
const-string v5, "curFile= "
invoke-virtual {v4, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
.line 26
invoke-virtual {v0}, Ljava/io/File;->getAbsolutePath()Ljava/lang/String;
move-result-object v5
invoke-virtual {v4, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string v5, " exist = "
invoke-virtual {v4, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v0}, Ljava/io/File;->exists()Z
move-result v6
invoke-virtual {v4, v6}, Ljava/lang/StringBuilder;->append(Z)Ljava/lang/StringBuilder;
const-string v6, " size = "
invoke-virtual {v4, v6}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
.line 27
invoke-virtual {v0}, Ljava/io/File;->length()J
move-result-wide v7
invoke-static {v7, v8}, Lcom/banalytics/Log2FileService;->a(J)Ljava/lang/String;
move-result-object v7
invoke-virtual {v4, v7}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v4}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v4
.line 28
invoke-virtual {v1, v4}, Ljava/lang/StringBuffer;->append(Ljava/lang/String;)Ljava/lang/StringBuffer;
.line 29
invoke-virtual {v1, v3}, Ljava/lang/StringBuffer;->append(C)Ljava/lang/StringBuffer;
new-instance v3, Ljava/lang/StringBuilder;
invoke-direct {v3}, Ljava/lang/StringBuilder;-><init>()V
const-string v4, "preFile= "
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
.line 30
invoke-virtual {v2}, Ljava/io/File;->getAbsolutePath()Ljava/lang/String;
move-result-object v4
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v3, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v2}, Ljava/io/File;->exists()Z
move-result v4
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Z)Ljava/lang/StringBuilder;
invoke-virtual {v3, v6}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
.line 31
invoke-virtual {v2}, Ljava/io/File;->length()J
move-result-wide v4
invoke-static {v4, v5}, Lcom/banalytics/Log2FileService;->a(J)Ljava/lang/String;
move-result-object v4
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v3
.line 32
invoke-virtual {v1, v3}, Ljava/lang/StringBuffer;->append(Ljava/lang/String;)Ljava/lang/StringBuffer;
.line 33
invoke-virtual {v1}, Ljava/lang/StringBuffer;->toString()Ljava/lang/String;
move-result-object v1
const-string v3, "reportToServer"
invoke-static {v3, v1}, Landroid/util/Log;->i(Ljava/lang/String;Ljava/lang/String;)I
.line 34
:try_start_9f
new-instance v1, Ljava/io/File;
new-instance v4, Ljava/lang/StringBuilder;
invoke-direct {v4}, Ljava/lang/StringBuilder;-><init>()V
sget-object v5, Lcom/banalytics/Log2FileService;->b:Ljava/lang/String;
invoke-virtual {v4, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
sget-object v5, Ljava/io/File;->separator:Ljava/lang/String;
invoke-virtual {v4, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string v5, "report.gz"
invoke-virtual {v4, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v4}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v4
invoke-direct {v1, v4}, Ljava/io/File;-><init>(Ljava/lang/String;)V
.line 35
invoke-virtual {v1}, Ljava/io/File;->createNewFile()Z
.line 36
new-instance v4, Ljava/util/zip/GZIPOutputStream;
new-instance v5, Ljava/io/FileOutputStream;
invoke-direct {v5, v1}, Ljava/io/FileOutputStream;-><init>(Ljava/io/File;)V
invoke-direct {v4, v5}, Ljava/util/zip/GZIPOutputStream;-><init>(Ljava/io/OutputStream;)V
const/16 v5, 0x400
.line 37
new-array v5, v5, [B
.line 38
invoke-virtual {v2}, Ljava/io/File;->exists()Z
move-result v6
const/4 v7, 0x0
if-eqz v6, :cond_e6
.line 39
new-instance v6, Ljava/io/FileInputStream;
invoke-direct {v6, v2}, Ljava/io/FileInputStream;-><init>(Ljava/io/File;)V
.line 40
:goto_d9
invoke-virtual {v6, v5}, Ljava/io/FileInputStream;->read([B)I
move-result v2
if-lez v2, :cond_e3
.line 41
invoke-virtual {v4, v5, v7, v2}, Ljava/util/zip/GZIPOutputStream;->write([BII)V
goto :goto_d9
.line 42
:cond_e3
invoke-virtual {v6}, Ljava/io/FileInputStream;->close()V
:cond_e6
const-string v2, "\n ---second_file--- \n"
.line 43
invoke-virtual {v2}, Ljava/lang/String;->getBytes()[B
move-result-object v2
invoke-virtual {v4, v2}, Ljava/util/zip/GZIPOutputStream;->write([B)V
.line 44
invoke-virtual {v0}, Ljava/io/File;->exists()Z
move-result v2
if-eqz v2, :cond_107
.line 45
new-instance v2, Ljava/io/FileInputStream;
invoke-direct {v2, v0}, Ljava/io/FileInputStream;-><init>(Ljava/io/File;)V
.line 46
:goto_fa
invoke-virtual {v2, v5}, Ljava/io/FileInputStream;->read([B)I
move-result v0
if-lez v0, :cond_104
.line 47
invoke-virtual {v4, v5, v7, v0}, Ljava/util/zip/GZIPOutputStream;->write([BII)V
goto :goto_fa
.line 48
:cond_104
invoke-virtual {v2}, Ljava/io/FileInputStream;->close()V
.line 49
:cond_107
invoke-virtual {v4}, Ljava/util/zip/GZIPOutputStream;->flush()V
.line 50
invoke-virtual {v4}, Ljava/util/zip/GZIPOutputStream;->finish()V
.line 51
invoke-virtual {v4}, Ljava/util/zip/GZIPOutputStream;->close()V
.line 52
iget-object v0, p1, Lcom/banalytics/Log2FileService$a;->f:Ljava/lang/String;
invoke-virtual {v1}, Ljava/io/File;->getAbsolutePath()Ljava/lang/String;
move-result-object v2
invoke-static {v0, v2}, Lcom/banalytics/Log2FileService;->a(Ljava/lang/String;Ljava/lang/String;)Z
move-result v0
if-eqz v0, :cond_165
.line 53
new-instance v0, Ljava/io/File;
iget-object p1, p1, Lcom/banalytics/Log2FileService$a;->f:Ljava/lang/String;
invoke-direct {v0, p1}, Ljava/io/File;-><init>(Ljava/lang/String;)V
.line 54
invoke-virtual {v0}, Ljava/io/File;->delete()Z
move-result p1
:try_end_127
.catch Ljava/io/IOException; {:try_start_9f .. :try_end_127} :catch_165
const-string v2, " deleted"
const-string v4, "file ="
if-eqz p1, :cond_146
.line 55
:try_start_12d
new-instance p1, Ljava/lang/StringBuilder;
invoke-direct {p1}, Ljava/lang/StringBuilder;-><init>()V
invoke-virtual {p1, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v0}, Ljava/io/File;->getAbsolutePath()Ljava/lang/String;
move-result-object v0
invoke-virtual {p1, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {p1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {p1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p1
invoke-static {v3, p1}, Landroid/util/Log;->i(Ljava/lang/String;Ljava/lang/String;)I
.line 56
:cond_146
invoke-virtual {v1}, Ljava/io/File;->delete()Z
move-result p1
if-eqz p1, :cond_165
.line 57
new-instance p1, Ljava/lang/StringBuilder;
invoke-direct {p1}, Ljava/lang/StringBuilder;-><init>()V
invoke-virtual {p1, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v1}, Ljava/io/File;->getAbsolutePath()Ljava/lang/String;
move-result-object v0
invoke-virtual {p1, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {p1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {p1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p1
invoke-static {v3, p1}, Landroid/util/Log;->i(Ljava/lang/String;Ljava/lang/String;)I
:try_end_165
.catch Ljava/io/IOException; {:try_start_12d .. :try_end_165} :catch_165
:catch_165
:cond_165
return-void
.end method
.method private a(Ljava/lang/String;)V
.registers 7
.line 10
invoke-static {p1}, Landroid/text/TextUtils;->isEmpty(Ljava/lang/CharSequence;)Z
move-result v0
if-eqz v0, :cond_43
.line 11
invoke-direct {p0}, Lcom/banalytics/Log2FileService;->d()Ljava/lang/String;
move-result-object p1
.line 12
sget-object v0, Ljava/util/Locale;->ENGLISH:Ljava/util/Locale;
new-instance v1, Ljava/lang/StringBuilder;
invoke-direct {v1}, Ljava/lang/StringBuilder;-><init>()V
invoke-static {}, Landroid/os/Environment;->getExternalStorageDirectory()Ljava/io/File;
move-result-object v2
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
sget-object v2, Ljava/io/File;->separator:Ljava/lang/String;
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string v2, "%s"
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
sget-object v2, Ljava/io/File;->separator:Ljava/lang/String;
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string v2, "logs"
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
const/4 v2, 0x1
new-array v2, v2, [Ljava/lang/Object;
const/4 v3, 0x0
sget-object v4, Ljava/util/Locale;->ENGLISH:Ljava/util/Locale;
.line 13
invoke-virtual {p1, v4}, Ljava/lang/String;->toLowerCase(Ljava/util/Locale;)Ljava/lang/String;
move-result-object p1
aput-object p1, v2, v3
.line 14
invoke-static {v0, v1, v2}, Ljava/lang/String;->format(Ljava/util/Locale;Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
move-result-object p1
sput-object p1, Lcom/banalytics/Log2FileService;->b:Ljava/lang/String;
goto :goto_45
.line 15
:cond_43
sput-object p1, Lcom/banalytics/Log2FileService;->b:Ljava/lang/String;
.line 16
:goto_45
new-instance p1, Ljava/io/File;
sget-object v0, Lcom/banalytics/Log2FileService;->b:Ljava/lang/String;
invoke-direct {p1, v0}, Ljava/io/File;-><init>(Ljava/lang/String;)V
.line 17
invoke-virtual {p1}, Ljava/io/File;->exists()Z
move-result v0
if-nez v0, :cond_70
.line 18
invoke-virtual {p1}, Ljava/io/File;->mkdirs()Z
move-result p1
if-eqz p1, :cond_70
.line 19
sget-object p1, Lcom/banalytics/Log2FileService;->a:Ljava/lang/String;
new-instance v0, Ljava/lang/StringBuilder;
invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V
const-string v1, "current dir "
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
sget-object v1, Lcom/banalytics/Log2FileService;->b:Ljava/lang/String;
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
invoke-static {p1, v0}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I
:cond_70
return-void
.end method
.method private static a(Ljava/lang/String;Ljava/lang/String;)Z
.registers 6
.line 58
invoke-static {p0}, Landroid/text/TextUtils;->isEmpty(Ljava/lang/CharSequence;)Z
move-result v0
const/4 v1, 0x0
if-nez v0, :cond_7f
invoke-static {p1}, Landroid/text/TextUtils;->isEmpty(Ljava/lang/CharSequence;)Z
move-result v0
if-eqz v0, :cond_e
goto :goto_7f
.line 59
:cond_e
:try_start_e
new-instance v0, Lcom/banalytics/i;
sget-object v2, Lcom/banalytics/Log2FileService;->e:Ljava/lang/String;
const-string v3, "UTF-8"
invoke-direct {v0, v2, v3}, Lcom/banalytics/i;-><init>(Ljava/lang/String;Ljava/lang/String;)V
const-string v2, "Host"
.line 60
sget-object v3, Lcom/banalytics/Log2FileService;->f:Ljava/lang/String;
invoke-virtual {v0, v2, v3}, Lcom/banalytics/i;->a(Ljava/lang/String;Ljava/lang/String;)V
const-string v2, "logfile"
.line 61
new-instance v3, Ljava/io/File;
invoke-direct {v3, p0}, Ljava/io/File;-><init>(Ljava/lang/String;)V
invoke-virtual {v0, v2, v3}, Lcom/banalytics/i;->a(Ljava/lang/String;Ljava/io/File;)V
const-string v2, "attachment"
.line 62
new-instance v3, Ljava/io/File;
invoke-direct {v3, p1}, Ljava/io/File;-><init>(Ljava/lang/String;)V
invoke-virtual {v0, v2, v3}, Lcom/banalytics/i;->a(Ljava/lang/String;Ljava/io/File;)V
.line 63
invoke-virtual {v0}, Lcom/banalytics/i;->a()Z
move-result v0
if-eqz v0, :cond_7f
.line 64
new-instance v0, Ljava/lang/StringBuffer;
invoke-direct {v0}, Ljava/lang/StringBuffer;-><init>()V
const-string v2, "====\n"
.line 65
invoke-virtual {v0, v2}, Ljava/lang/StringBuffer;->append(Ljava/lang/String;)Ljava/lang/StringBuffer;
new-instance v2, Ljava/lang/StringBuilder;
invoke-direct {v2}, Ljava/lang/StringBuilder;-><init>()V
const-string v3, "post LogFile = "
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v2, p0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p0
invoke-virtual {v0, p0}, Ljava/lang/StringBuffer;->append(Ljava/lang/String;)Ljava/lang/StringBuffer;
const/16 p0, 0xa
invoke-virtual {v0, p0}, Ljava/lang/StringBuffer;->append(C)Ljava/lang/StringBuffer;
new-instance p0, Ljava/lang/StringBuilder;
invoke-direct {p0}, Ljava/lang/StringBuilder;-><init>()V
const-string v2, "post AttachFile = "
invoke-virtual {p0, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {p0, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {p0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p0
invoke-virtual {v0, p0}, Ljava/lang/StringBuffer;->append(Ljava/lang/String;)Ljava/lang/StringBuffer;
const-string p0, "\n done!"
.line 66
invoke-virtual {v0, p0}, Ljava/lang/StringBuffer;->append(Ljava/lang/String;)Ljava/lang/StringBuffer;
const-string p0, "post"
.line 67
invoke-virtual {v0}, Ljava/lang/StringBuffer;->toString()Ljava/lang/String;
move-result-object p1
invoke-static {p0, p1}, Landroid/util/Log;->i(Ljava/lang/String;Ljava/lang/String;)I
:try_end_7d
.catch Ljava/io/IOException; {:try_start_e .. :try_end_7d} :catch_7f
const/4 p0, 0x1
return p0
:catch_7f
:cond_7f
:goto_7f
return v1
.end method
.method private b(Ljava/lang/String;)Ljava/lang/String;
.registers 4
.line 10
new-instance v0, Ljava/lang/StringBuilder;
invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V
sget-object v1, Lcom/banalytics/Log2FileService;->b:Ljava/lang/String;
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
sget-object v1, Ljava/io/File;->separator:Ljava/lang/String;
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v0, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string p1, ".txt"
invoke-virtual {v0, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p1
return-object p1
.end method
.method private b()V
.registers 5
.line 1
:try_start_0
new-instance v0, Ljava/io/File;
sget-object v1, Lcom/banalytics/Log2FileService;->b:Ljava/lang/String;
invoke-direct {v0, v1}, Ljava/io/File;-><init>(Ljava/lang/String;)V
.line 2
invoke-virtual {v0}, Ljava/io/File;->exists()Z
move-result v1
if-nez v1, :cond_e
return-void
.line 3
:cond_e
invoke-virtual {v0}, Ljava/io/File;->listFiles()[Ljava/io/File;
move-result-object v0
if-eqz v0, :cond_37
.line 4
array-length v1, v0
const/16 v2, 0xa8
if-gt v1, v2, :cond_1a
goto :goto_37
.line 5
:cond_1a
new-instance v1, Lcom/banalytics/g;
invoke-direct {v1, p0}, Lcom/banalytics/g;-><init>(Lcom/banalytics/Log2FileService;)V
invoke-static {v0, v1}, Ljava/util/Arrays;->sort([Ljava/lang/Object;Ljava/util/Comparator;)V
const/4 v1, 0x0
.line 6
:goto_23
array-length v3, v0
sub-int/2addr v3, v2
if-ge v1, v3, :cond_3c
.line 7
aget-object v3, v0, v1
invoke-virtual {v3}, Ljava/io/File;->exists()Z
move-result v3
if-eqz v3, :cond_34
.line 8
aget-object v3, v0, v1
invoke-virtual {v3}, Ljava/io/File;->delete()Z
:try_end_34
.catch Ljava/lang/Exception; {:try_start_0 .. :try_end_34} :catch_38
:cond_34
add-int/lit8 v1, v1, 0x1
goto :goto_23
:cond_37
:goto_37
return-void
:catch_38
move-exception v0
.line 9
invoke-virtual {v0}, Ljava/lang/Exception;->printStackTrace()V
:cond_3c
return-void
.end method
.method private c(Ljava/lang/String;)Ljava/io/FileWriter;
.registers 4
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/io/IOException;
}
.end annotation
.line 23
sget-object v0, Lcom/banalytics/Log2FileService;->b:Ljava/lang/String;
invoke-direct {p0, v0}, Lcom/banalytics/Log2FileService;->a(Ljava/lang/String;)V
.line 24
invoke-direct {p0, p1}, Lcom/banalytics/Log2FileService;->b(Ljava/lang/String;)Ljava/lang/String;
move-result-object p1
.line 25
new-instance v0, Ljava/io/File;
invoke-direct {v0, p1}, Ljava/io/File;-><init>(Ljava/lang/String;)V
.line 26
invoke-virtual {v0}, Ljava/io/File;->exists()Z
move-result p1
if-nez p1, :cond_17
.line 27
invoke-virtual {v0}, Ljava/io/File;->createNewFile()Z
.line 28
:cond_17
new-instance p1, Ljava/io/FileWriter;
const/4 v1, 0x1
invoke-direct {p1, v0, v1}, Ljava/io/FileWriter;-><init>(Ljava/io/File;Z)V
return-object p1
.end method
.method private c()V
.registers 13
.line 1
iget-object v0, p0, Lcom/banalytics/Log2FileService;->g:Ljava/util/HashMap;
monitor-enter v0
.line 2
:try_start_3
iget-object v1, p0, Lcom/banalytics/Log2FileService;->g:Ljava/util/HashMap;
invoke-virtual {v1}, Ljava/util/HashMap;->keySet()Ljava/util/Set;
move-result-object v1
.line 3
invoke-interface {v1}, Ljava/util/Set;->iterator()Ljava/util/Iterator;
move-result-object v1
:catch_d
:cond_d
:goto_d
invoke-interface {v1}, Ljava/util/Iterator;->hasNext()Z
move-result v2
if-eqz v2, :cond_8d
invoke-interface {v1}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v2
check-cast v2, Ljava/lang/String;
.line 4
new-instance v3, Ljava/lang/StringBuffer;
invoke-direct {v3}, Ljava/lang/StringBuffer;-><init>()V
.line 5
iget-object v4, p0, Lcom/banalytics/Log2FileService;->g:Ljava/util/HashMap;
invoke-virtual {v4, v2}, Ljava/util/HashMap;->get(Ljava/lang/Object;)Ljava/lang/Object;
move-result-object v4
check-cast v4, Ljava/util/ArrayList;
.line 6
new-instance v5, Lcom/banalytics/h;
invoke-direct {v5, p0}, Lcom/banalytics/h;-><init>(Lcom/banalytics/Log2FileService;)V
invoke-static {v4, v5}, Ljava/util/Collections;->sort(Ljava/util/List;Ljava/util/Comparator;)V
const/4 v5, 0x0
.line 7
new-array v6, v5, [Lcom/banalytics/Log2FileService$a;
invoke-virtual {v4, v6}, Ljava/util/ArrayList;->toArray([Ljava/lang/Object;)[Ljava/lang/Object;
move-result-object v6
check-cast v6, [Lcom/banalytics/Log2FileService$a;
.line 8
invoke-virtual {v4}, Ljava/util/ArrayList;->clear()V
.line 9
array-length v4, v6
:goto_3b
if-ge v5, v4, :cond_6b
aget-object v7, v6, v5
.line 10
sget-object v8, Lcom/banalytics/Log2FileService;->d:Ljava/text/SimpleDateFormat;
new-instance v9, Ljava/util/Date;
iget-wide v10, v7, Lcom/banalytics/Log2FileService$a;->b:J
invoke-direct {v9, v10, v11}, Ljava/util/Date;-><init>(J)V
invoke-virtual {v8, v9}, Ljava/text/SimpleDateFormat;->format(Ljava/util/Date;)Ljava/lang/String;
move-result-object v8
const/16 v9, 0x5b
.line 11
invoke-virtual {v3, v9}, Ljava/lang/StringBuffer;->append(C)Ljava/lang/StringBuffer;
.line 12
invoke-virtual {v3, v8}, Ljava/lang/StringBuffer;->append(Ljava/lang/String;)Ljava/lang/StringBuffer;
const/16 v8, 0x5d
.line 13
invoke-virtual {v3, v8}, Ljava/lang/StringBuffer;->append(C)Ljava/lang/StringBuffer;
const/16 v8, 0x9
.line 14
invoke-virtual {v3, v8}, Ljava/lang/StringBuffer;->append(C)Ljava/lang/StringBuffer;
.line 15
iget-object v7, v7, Lcom/banalytics/Log2FileService$a;->c:Ljava/lang/String;
invoke-virtual {v3, v7}, Ljava/lang/StringBuffer;->append(Ljava/lang/String;)Ljava/lang/StringBuffer;
const/16 v7, 0xa
.line 16
invoke-virtual {v3, v7}, Ljava/lang/StringBuffer;->append(C)Ljava/lang/StringBuffer;
:try_end_68
.catchall {:try_start_3 .. :try_end_68} :catchall_8f
add-int/lit8 v5, v5, 0x1
goto :goto_3b
:cond_6b
const/4 v4, 0x0
.line 17
:try_start_6c
invoke-direct {p0, v2}, Lcom/banalytics/Log2FileService;->c(Ljava/lang/String;)Ljava/io/FileWriter;
move-result-object v4
.line 18
invoke-virtual {v3}, Ljava/lang/StringBuffer;->toString()Ljava/lang/String;
move-result-object v2
invoke-virtual {v4, v2}, Ljava/io/FileWriter;->append(Ljava/lang/CharSequence;)Ljava/io/Writer;
const-wide/16 v2, 0xc8
.line 19
invoke-static {v2, v3}, Ljava/lang/Thread;->sleep(J)V
:try_end_7c
.catch Ljava/io/IOException; {:try_start_6c .. :try_end_7c} :catch_89
.catch Ljava/lang/InterruptedException; {:try_start_6c .. :try_end_7c} :catch_89
.catchall {:try_start_6c .. :try_end_7c} :catchall_82
if-eqz v4, :cond_d
.line 20
:goto_7e
:try_start_7e
invoke-virtual {v4}, Ljava/io/FileWriter;->close()V
:try_end_81
.catch Ljava/io/IOException; {:try_start_7e .. :try_end_81} :catch_d
.catchall {:try_start_7e .. :try_end_81} :catchall_8f
goto :goto_d
:catchall_82
move-exception v1
if-eqz v4, :cond_88
:try_start_85
invoke-virtual {v4}, Ljava/io/FileWriter;->close()V
:try_end_88
.catch Ljava/io/IOException; {:try_start_85 .. :try_end_88} :catch_88
.catchall {:try_start_85 .. :try_end_88} :catchall_8f
.line 21
:catch_88
:cond_88
:try_start_88
throw v1
:catch_89
nop
if-eqz v4, :cond_d
goto :goto_7e
.line 22
:cond_8d
monitor-exit v0
return-void
:catchall_8f
move-exception v1
monitor-exit v0
:try_end_91
.catchall {:try_start_88 .. :try_end_91} :catchall_8f
goto :goto_93
:goto_92
throw v1
:goto_93
goto :goto_92
.end method
.method private d()Ljava/lang/String;
.registers 5
.line 1
invoke-virtual {p0}, Landroid/app/IntentService;->getApplicationContext()Landroid/content/Context;
move-result-object v0
invoke-virtual {v0}, Landroid/content/Context;->getApplicationInfo()Landroid/content/pm/ApplicationInfo;
move-result-object v0
iget v0, v0, Landroid/content/pm/ApplicationInfo;->labelRes:I
const/4 v1, 0x1
.line 2
new-array v1, v1, [Ljava/lang/Object;
sget-object v2, Ljava/util/Locale;->ENGLISH:Ljava/util/Locale;
const/4 v3, 0x0
aput-object v2, v1, v3
invoke-virtual {p0, v0, v1}, Landroid/app/IntentService;->getString(I[Ljava/lang/Object;)Ljava/lang/String;
move-result-object v0
return-object v0
.end method
.method private e()I
.registers 5
.line 1
iget-object v0, p0, Lcom/banalytics/Log2FileService;->g:Ljava/util/HashMap;
invoke-virtual {v0}, Ljava/util/HashMap;->keySet()Ljava/util/Set;
move-result-object v0
.line 2
invoke-interface {v0}, Ljava/util/Set;->iterator()Ljava/util/Iterator;
move-result-object v0
const/4 v1, 0x0
:goto_b
invoke-interface {v0}, Ljava/util/Iterator;->hasNext()Z
move-result v2
if-eqz v2, :cond_25
invoke-interface {v0}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v2
check-cast v2, Ljava/lang/String;
.line 3
iget-object v3, p0, Lcom/banalytics/Log2FileService;->g:Ljava/util/HashMap;
invoke-virtual {v3, v2}, Ljava/util/HashMap;->get(Ljava/lang/Object;)Ljava/lang/Object;
move-result-object v2
check-cast v2, Ljava/util/ArrayList;
invoke-virtual {v2}, Ljava/util/ArrayList;->size()I
move-result v2
add-int/2addr v1, v2
goto :goto_b
:cond_25
return v1
.end method
# virtual methods
.method public onDestroy()V
.registers 1
.line 1
invoke-super {p0}, Landroid/app/IntentService;->onDestroy()V
.line 2
invoke-direct {p0}, Lcom/banalytics/Log2FileService;->c()V
return-void
.end method
.method protected onHandleIntent(Landroid/content/Intent;)V
.registers 5
if-nez p1, :cond_3
return-void
.line 1
:cond_3
new-instance v0, Lcom/banalytics/Log2FileService$a;
const/4 v1, 0x0
invoke-direct {v0, p1, v1}, Lcom/banalytics/Log2FileService$a;-><init>(Landroid/content/Intent;Lcom/banalytics/g;)V
.line 2
iget-object p1, v0, Lcom/banalytics/Log2FileService$a;->g:Ljava/lang/String;
invoke-direct {p0, p1}, Lcom/banalytics/Log2FileService;->a(Ljava/lang/String;)V
.line 3
invoke-direct {p0}, Lcom/banalytics/Log2FileService;->b()V
.line 4
iget-object p1, p0, Lcom/banalytics/Log2FileService;->g:Ljava/util/HashMap;
iget-object v1, v0, Lcom/banalytics/Log2FileService$a;->a:Ljava/lang/String;
invoke-virtual {p1, v1}, Ljava/util/HashMap;->get(Ljava/lang/Object;)Ljava/lang/Object;
move-result-object p1
if-nez p1, :cond_27
.line 5
iget-object p1, p0, Lcom/banalytics/Log2FileService;->g:Ljava/util/HashMap;
iget-object v1, v0, Lcom/banalytics/Log2FileService$a;->a:Ljava/lang/String;
new-instance v2, Ljava/util/ArrayList;
invoke-direct {v2}, Ljava/util/ArrayList;-><init>()V
invoke-virtual {p1, v1, v2}, Ljava/util/HashMap;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
.line 6
:cond_27
iget-object p1, p0, Lcom/banalytics/Log2FileService;->g:Ljava/util/HashMap;
iget-object v1, v0, Lcom/banalytics/Log2FileService$a;->a:Ljava/lang/String;
invoke-virtual {p1, v1}, Ljava/util/HashMap;->get(Ljava/lang/Object;)Ljava/lang/Object;
move-result-object p1
check-cast p1, Ljava/util/ArrayList;
invoke-virtual {p1, v0}, Ljava/util/ArrayList;->add(Ljava/lang/Object;)Z
.line 7
invoke-direct {p0}, Lcom/banalytics/Log2FileService;->e()I
move-result p1
const/16 v1, 0x10
if-gt p1, v1, :cond_44
iget-boolean p1, v0, Lcom/banalytics/Log2FileService$a;->d:Z
if-nez p1, :cond_44
iget-boolean p1, v0, Lcom/banalytics/Log2FileService$a;->e:Z
if-eqz p1, :cond_47
.line 8
:cond_44
invoke-direct {p0}, Lcom/banalytics/Log2FileService;->c()V
.line 9
:cond_47
iget-boolean p1, v0, Lcom/banalytics/Log2FileService$a;->d:Z
if-eqz p1, :cond_4e
.line 10
invoke-direct {p0, v0}, Lcom/banalytics/Log2FileService;->a(Lcom/banalytics/Log2FileService$a;)V
:cond_4e
return-void
.end method