SqliteWrapper.smali
.class Lio/agora/utils/SqliteWrapper;
.super Ljava/lang/Object;
# annotations
.annotation system Ldalvik/annotation/MemberClasses;
value = {
Lio/agora/utils/SqliteWrapper$StorageItem;
}
.end annotation
# static fields
.field private static final TAG:Ljava/lang/String; = "SQLITE"
# instance fields
.field private db:Landroid/database/sqlite/SQLiteDatabase;
.field private final lock:Ljava/lang/Object;
# direct methods
.method public constructor <init>()V
.registers 2
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
new-instance v0, Ljava/lang/Object;
invoke-direct {v0}, Ljava/lang/Object;-><init>()V
iput-object v0, p0, Lio/agora/utils/SqliteWrapper;->lock:Ljava/lang/Object;
const/4 v0, 0x0
iput-object v0, p0, Lio/agora/utils/SqliteWrapper;->db:Landroid/database/sqlite/SQLiteDatabase;
return-void
.end method
.method private executeCommandOnPath(Ljava/lang/String;Ljava/lang/String;)Z
.registers 5
.annotation system Ldalvik/annotation/MethodParameters;
accessFlags = {
0x0,
0x0
}
names = {
"path",
"cmd"
}
.end annotation
invoke-direct {p0}, Lio/agora/utils/SqliteWrapper;->isDatabaseValid()Z
move-result v0
const/4 v1, 0x0
if-nez v0, :cond_8
return v1
:cond_8
invoke-direct {p0, p1}, Lio/agora/utils/SqliteWrapper;->isPathValid(Ljava/lang/String;)Z
move-result p1
if-nez p1, :cond_f
return v1
:cond_f
iget-object p1, p0, Lio/agora/utils/SqliteWrapper;->lock:Ljava/lang/Object;
monitor-enter p1
:try_start_12
iget-object v0, p0, Lio/agora/utils/SqliteWrapper;->db:Landroid/database/sqlite/SQLiteDatabase;
invoke-virtual {v0, p2}, Landroid/database/sqlite/SQLiteDatabase;->execSQL(Ljava/lang/String;)V
:try_end_17
.catch Ljava/lang/Exception; {:try_start_12 .. :try_end_17} :catch_1c
.catchall {:try_start_12 .. :try_end_17} :catchall_1a
const/4 p2, 0x1
:try_start_18
monitor-exit p1
return p2
:catchall_1a
move-exception p2
goto :goto_1e
:catch_1c
monitor-exit p1
return v1
:goto_1e
monitor-exit p1
:try_end_1f
.catchall {:try_start_18 .. :try_end_1f} :catchall_1a
throw p2
.end method
.method private isDatabaseValid()Z
.registers 2
iget-object v0, p0, Lio/agora/utils/SqliteWrapper;->db:Landroid/database/sqlite/SQLiteDatabase;
if-eqz v0, :cond_14
invoke-virtual {v0}, Landroid/database/sqlite/SQLiteDatabase;->isOpen()Z
move-result v0
if-eqz v0, :cond_14
iget-object v0, p0, Lio/agora/utils/SqliteWrapper;->db:Landroid/database/sqlite/SQLiteDatabase;
invoke-virtual {v0}, Landroid/database/sqlite/SQLiteDatabase;->isReadOnly()Z
move-result v0
if-nez v0, :cond_14
const/4 v0, 0x1
goto :goto_15
:cond_14
const/4 v0, 0x0
:goto_15
return v0
.end method
.method private isPathValid(Ljava/lang/String;)Z
.registers 6
.annotation system Ldalvik/annotation/MethodParameters;
accessFlags = {
0x0
}
names = {
"path"
}
.end annotation
invoke-static {p1}, Landroid/text/TextUtils;->isEmpty(Ljava/lang/CharSequence;)Z
move-result v0
const/4 v1, 0x0
if-eqz v0, :cond_8
return v1
:cond_8
move v0, v1
:goto_9
invoke-virtual {p1}, Ljava/lang/String;->length()I
move-result v2
if-ge v0, v2, :cond_2c
invoke-virtual {p1, v0}, Ljava/lang/String;->charAt(I)C
move-result v2
const/16 v3, 0x20
if-lt v2, v3, :cond_2b
const/16 v3, 0x7e
if-gt v2, v3, :cond_2b
const/16 v3, 0x22
if-eq v2, v3, :cond_2b
const/16 v3, 0x27
if-eq v2, v3, :cond_2b
const/16 v3, 0x3b
if-ne v2, v3, :cond_28
goto :goto_2b
:cond_28
add-int/lit8 v0, v0, 0x1
goto :goto_9
:cond_2b
:goto_2b
return v1
:cond_2c
invoke-virtual {p1}, Ljava/lang/String;->toLowerCase()Ljava/lang/String;
move-result-object p1
const-string v0, "sqlite_master"
invoke-virtual {p1, v0}, Ljava/lang/String;->contains(Ljava/lang/CharSequence;)Z
move-result p1
xor-int/lit8 p1, p1, 0x1
return p1
.end method
# virtual methods
.method public close()V
.registers 3
invoke-direct {p0}, Lio/agora/utils/SqliteWrapper;->isDatabaseValid()Z
move-result v0
if-nez v0, :cond_7
return-void
:cond_7
iget-object v0, p0, Lio/agora/utils/SqliteWrapper;->lock:Ljava/lang/Object;
monitor-enter v0
:try_start_a
iget-object v1, p0, Lio/agora/utils/SqliteWrapper;->db:Landroid/database/sqlite/SQLiteDatabase;
invoke-virtual {v1}, Landroid/database/sqlite/SQLiteDatabase;->close()V
const/4 v1, 0x0
iput-object v1, p0, Lio/agora/utils/SqliteWrapper;->db:Landroid/database/sqlite/SQLiteDatabase;
monitor-exit v0
return-void
:catchall_14
move-exception v1
monitor-exit v0
:try_end_16
.catchall {:try_start_a .. :try_end_16} :catchall_14
throw v1
.end method
.method delete(Ljava/lang/String;Ljava/lang/String;)Z
.registers 7
.annotation system Ldalvik/annotation/MethodParameters;
accessFlags = {
0x0,
0x0
}
names = {
"path",
"key"
}
.end annotation
invoke-direct {p0}, Lio/agora/utils/SqliteWrapper;->isDatabaseValid()Z
move-result v0
const/4 v1, 0x0
if-nez v0, :cond_8
return v1
:cond_8
invoke-direct {p0, p1}, Lio/agora/utils/SqliteWrapper;->isPathValid(Ljava/lang/String;)Z
move-result v0
if-nez v0, :cond_f
return v1
:cond_f
invoke-direct {p0, p2}, Lio/agora/utils/SqliteWrapper;->isPathValid(Ljava/lang/String;)Z
move-result v0
if-nez v0, :cond_16
return v1
:cond_16
iget-object v0, p0, Lio/agora/utils/SqliteWrapper;->lock:Ljava/lang/Object;
monitor-enter v0
:try_start_19
new-instance v2, Ljava/lang/StringBuilder;
invoke-direct {v2}, Ljava/lang/StringBuilder;-><init>()V
const-string v3, "delete from \""
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v2, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string p1, "\" where key = \""
invoke-virtual {v2, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v2, p2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string p1, "\";"
invoke-virtual {v2, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p1
:try_end_37
.catchall {:try_start_19 .. :try_end_37} :catchall_41
:try_start_37
iget-object p2, p0, Lio/agora/utils/SqliteWrapper;->db:Landroid/database/sqlite/SQLiteDatabase;
invoke-virtual {p2, p1}, Landroid/database/sqlite/SQLiteDatabase;->execSQL(Ljava/lang/String;)V
:try_end_3c
.catch Ljava/lang/Exception; {:try_start_37 .. :try_end_3c} :catch_3f
.catchall {:try_start_37 .. :try_end_3c} :catchall_41
const/4 p1, 0x1
:try_start_3d
monitor-exit v0
return p1
:catch_3f
monitor-exit v0
return v1
:catchall_41
move-exception p1
monitor-exit v0
:try_end_43
.catchall {:try_start_3d .. :try_end_43} :catchall_41
throw p1
.end method
.method public dispose()V
.registers 3
iget-object v0, p0, Lio/agora/utils/SqliteWrapper;->lock:Ljava/lang/Object;
monitor-enter v0
:try_start_3
iget-object v1, p0, Lio/agora/utils/SqliteWrapper;->db:Landroid/database/sqlite/SQLiteDatabase;
if-eqz v1, :cond_12
invoke-virtual {v1}, Landroid/database/sqlite/SQLiteDatabase;->isOpen()Z
move-result v1
if-eqz v1, :cond_12
iget-object v1, p0, Lio/agora/utils/SqliteWrapper;->db:Landroid/database/sqlite/SQLiteDatabase;
invoke-virtual {v1}, Landroid/database/sqlite/SQLiteDatabase;->close()V
:cond_12
const/4 v1, 0x0
iput-object v1, p0, Lio/agora/utils/SqliteWrapper;->db:Landroid/database/sqlite/SQLiteDatabase;
monitor-exit v0
return-void
:catchall_17
move-exception v1
monitor-exit v0
:try_end_19
.catchall {:try_start_3 .. :try_end_19} :catchall_17
throw v1
.end method
.method drop(Ljava/lang/String;)Z
.registers 4
.annotation system Ldalvik/annotation/MethodParameters;
accessFlags = {
0x0
}
names = {
"path"
}
.end annotation
new-instance v0, Ljava/lang/StringBuilder;
invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V
const-string v1, "drop table if exists \""
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 v1, "\";"
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-direct {p0, p1, v0}, Lio/agora/utils/SqliteWrapper;->executeCommandOnPath(Ljava/lang/String;Ljava/lang/String;)Z
move-result p1
return p1
.end method
.method load(Ljava/lang/String;Ljava/lang/String;Z)Lio/agora/utils/SqliteWrapper$StorageItem;
.registers 13
.annotation system Ldalvik/annotation/MethodParameters;
accessFlags = {
0x0,
0x0,
0x0
}
names = {
"query",
"cmd",
"testSize"
}
.end annotation
invoke-direct {p0}, Lio/agora/utils/SqliteWrapper;->isDatabaseValid()Z
move-result p3
if-nez p3, :cond_13
const-string p1, "SQLITE"
const-string p2, "database is invalid"
invoke-static {p1, p2}, Lio/agora/base/internal/Logging;->w(Ljava/lang/String;Ljava/lang/String;)V
new-instance p1, Lio/agora/utils/SqliteWrapper$StorageItem;
invoke-direct {p1}, Lio/agora/utils/SqliteWrapper$StorageItem;-><init>()V
return-object p1
:cond_13
invoke-static {p1}, Landroid/text/TextUtils;->isEmpty(Ljava/lang/CharSequence;)Z
move-result p3
if-eqz p3, :cond_26
const-string p1, "SQLITE"
const-string p2, "query is invalid"
invoke-static {p1, p2}, Lio/agora/base/internal/Logging;->w(Ljava/lang/String;Ljava/lang/String;)V
new-instance p1, Lio/agora/utils/SqliteWrapper$StorageItem;
invoke-direct {p1}, Lio/agora/utils/SqliteWrapper$StorageItem;-><init>()V
return-object p1
:cond_26
invoke-static {p2}, Landroid/text/TextUtils;->isEmpty(Ljava/lang/CharSequence;)Z
move-result p3
if-eqz p3, :cond_39
const-string p1, "SQLITE"
const-string p2, "cmd is invalid"
invoke-static {p1, p2}, Lio/agora/base/internal/Logging;->w(Ljava/lang/String;Ljava/lang/String;)V
new-instance p1, Lio/agora/utils/SqliteWrapper$StorageItem;
invoke-direct {p1}, Lio/agora/utils/SqliteWrapper$StorageItem;-><init>()V
return-object p1
:cond_39
iget-object p3, p0, Lio/agora/utils/SqliteWrapper;->lock:Ljava/lang/Object;
monitor-enter p3
const/4 v0, 0x0
const-wide/16 v1, 0x0
:try_start_3f
iget-object v3, p0, Lio/agora/utils/SqliteWrapper;->db:Landroid/database/sqlite/SQLiteDatabase;
const/4 v4, 0x0
new-array v5, v4, [Ljava/lang/String;
invoke-virtual {v3, p1, v5}, Landroid/database/sqlite/SQLiteDatabase;->rawQuery(Ljava/lang/String;[Ljava/lang/String;)Landroid/database/Cursor;
move-result-object p1
:try_end_48
.catch Ljava/lang/Exception; {:try_start_3f .. :try_end_48} :catch_98
.catchall {:try_start_3f .. :try_end_48} :catchall_96
const/4 v3, 0x1
if-eqz p1, :cond_59
:try_start_4b
invoke-interface {p1}, Landroid/database/Cursor;->getCount()I
move-result v5
if-lez v5, :cond_53
move v5, v3
goto :goto_54
:cond_53
move v5, v4
:goto_54
invoke-interface {p1}, Landroid/database/Cursor;->close()V
move-object p1, v0
goto :goto_5a
:cond_59
move v5, v4
:goto_5a
if-nez v5, :cond_64
const-string p2, "SQLITE"
const-string v3, "table is not exist"
invoke-static {p2, v3}, Lio/agora/base/internal/Logging;->w(Ljava/lang/String;Ljava/lang/String;)V
goto :goto_99
:cond_64
iget-object v5, p0, Lio/agora/utils/SqliteWrapper;->db:Landroid/database/sqlite/SQLiteDatabase;
new-array v4, v4, [Ljava/lang/String;
invoke-virtual {v5, p2, v4}, Landroid/database/sqlite/SQLiteDatabase;->rawQuery(Ljava/lang/String;[Ljava/lang/String;)Landroid/database/Cursor;
move-result-object p1
invoke-interface {p1}, Landroid/database/Cursor;->isClosed()Z
move-result p2
if-nez p2, :cond_99
invoke-interface {p1}, Landroid/database/Cursor;->moveToFirst()Z
move-result p2
if-eqz p2, :cond_99
invoke-interface {p1}, Landroid/database/Cursor;->getCount()I
move-result p2
if-eq p2, v3, :cond_7f
goto :goto_99
:cond_7f
invoke-interface {p1, v3}, Landroid/database/Cursor;->getBlob(I)[B
move-result-object v0
const/4 p2, 0x2
invoke-interface {p1, p2}, Landroid/database/Cursor;->getLong(I)J
move-result-wide v3
:try_end_88
.catch Ljava/lang/Exception; {:try_start_4b .. :try_end_88} :catch_99
.catchall {:try_start_4b .. :try_end_88} :catchall_96
:try_start_88
array-length p2, v0
const/high16 v5, 0x80000
if-le p2, v5, :cond_91
const-wide/32 v5, 0x80000
goto :goto_93
:cond_91
array-length p2, v0
:try_end_92
.catchall {:try_start_88 .. :try_end_92} :catchall_96
int-to-long v5, p2
:goto_93
move-wide v7, v3
move-object v4, v0
goto :goto_9c
:catchall_96
move-exception p1
goto :goto_c0
:catch_98
move-object p1, v0
:catch_99
:cond_99
:goto_99
move-object v4, v0
move-wide v5, v1
move-wide v7, v5
:goto_9c
if-eqz p1, :cond_a9
:try_start_9e
invoke-interface {p1}, Landroid/database/Cursor;->close()V
:try_end_a1
.catch Ljava/lang/Exception; {:try_start_9e .. :try_end_a1} :catch_a2
.catchall {:try_start_9e .. :try_end_a1} :catchall_96
goto :goto_a9
:catch_a2
:try_start_a2
const-string p1, "SQLITE"
const-string p2, "cursor close exception"
invoke-static {p1, p2}, Lio/agora/base/internal/Logging;->w(Ljava/lang/String;Ljava/lang/String;)V
:cond_a9
:goto_a9
cmp-long p1, v5, v1
if-eqz p1, :cond_b9
array-length p1, v4
if-nez p1, :cond_b1
goto :goto_b9
:cond_b1
new-instance p1, Lio/agora/utils/SqliteWrapper$StorageItem;
move-object v3, p1
invoke-direct/range {v3 .. v8}, Lio/agora/utils/SqliteWrapper$StorageItem;-><init>([BJJ)V
monitor-exit p3
return-object p1
:cond_b9
:goto_b9
new-instance p1, Lio/agora/utils/SqliteWrapper$StorageItem;
invoke-direct {p1}, Lio/agora/utils/SqliteWrapper$StorageItem;-><init>()V
monitor-exit p3
return-object p1
:goto_c0
monitor-exit p3
:try_end_c1
.catchall {:try_start_a2 .. :try_end_c1} :catchall_96
throw p1
.end method
.method public open(Ljava/lang/String;)Z
.registers 8
.annotation system Ldalvik/annotation/MethodParameters;
accessFlags = {
0x0
}
names = {
"path"
}
.end annotation
invoke-direct {p0, p1}, Lio/agora/utils/SqliteWrapper;->isPathValid(Ljava/lang/String;)Z
move-result v0
const/4 v1, 0x0
if-nez v0, :cond_8
return v1
:cond_8
iget-object v0, p0, Lio/agora/utils/SqliteWrapper;->lock:Ljava/lang/Object;
monitor-enter v0
const/4 v2, 0x0
:try_start_c
sget v3, Landroid/os/Build$VERSION;->SDK_INT:I
const/16 v4, 0x1c
const/high16 v5, 0x10000000
if-lt v3, v4, :cond_31
new-instance v3, Landroid/database/sqlite/SQLiteDatabase$OpenParams$Builder;
invoke-direct {v3}, Landroid/database/sqlite/SQLiteDatabase$OpenParams$Builder;-><init>()V
invoke-virtual {v3, v5}, Landroid/database/sqlite/SQLiteDatabase$OpenParams$Builder;->setOpenFlags(I)Landroid/database/sqlite/SQLiteDatabase$OpenParams$Builder;
const-string v4, "off"
invoke-virtual {v3, v4}, Landroid/database/sqlite/SQLiteDatabase$OpenParams$Builder;->setJournalMode(Ljava/lang/String;)Landroid/database/sqlite/SQLiteDatabase$OpenParams$Builder;
invoke-virtual {v3}, Landroid/database/sqlite/SQLiteDatabase$OpenParams$Builder;->build()Landroid/database/sqlite/SQLiteDatabase$OpenParams;
move-result-object v3
new-instance v4, Ljava/io/File;
invoke-direct {v4, p1}, Ljava/io/File;-><init>(Ljava/lang/String;)V
invoke-static {v4, v3}, Landroid/database/sqlite/SQLiteDatabase;->openDatabase(Ljava/io/File;Landroid/database/sqlite/SQLiteDatabase$OpenParams;)Landroid/database/sqlite/SQLiteDatabase;
move-result-object v3
:goto_2e
iput-object v3, p0, Lio/agora/utils/SqliteWrapper;->db:Landroid/database/sqlite/SQLiteDatabase;
goto :goto_36
:cond_31
invoke-static {p1, v2, v5}, Landroid/database/sqlite/SQLiteDatabase;->openDatabase(Ljava/lang/String;Landroid/database/sqlite/SQLiteDatabase$CursorFactory;I)Landroid/database/sqlite/SQLiteDatabase;
move-result-object v3
:try_end_35
.catch Ljava/lang/Exception; {:try_start_c .. :try_end_35} :catch_74
.catchall {:try_start_c .. :try_end_35} :catchall_72
goto :goto_2e
:goto_36
:try_start_36
iget-object v3, p0, Lio/agora/utils/SqliteWrapper;->db:Landroid/database/sqlite/SQLiteDatabase;
const-string v4, "PRAGMA TEMP_STORE = MEMORY;"
invoke-virtual {v3, v4}, Landroid/database/sqlite/SQLiteDatabase;->execSQL(Ljava/lang/String;)V
iget-object v3, p0, Lio/agora/utils/SqliteWrapper;->db:Landroid/database/sqlite/SQLiteDatabase;
const-string v4, "PRAGMA SYNCHRONOUS = OFF;"
invoke-virtual {v3, v4}, Landroid/database/sqlite/SQLiteDatabase;->execSQL(Ljava/lang/String;)V
:try_end_44
.catch Ljava/lang/Exception; {:try_start_36 .. :try_end_44} :catch_47
.catchall {:try_start_36 .. :try_end_44} :catchall_72
const/4 p1, 0x1
:try_start_45
monitor-exit v0
return p1
:catch_47
move-exception v3
invoke-virtual {v3}, Ljava/lang/Exception;->printStackTrace()V
iget-object v3, p0, Lio/agora/utils/SqliteWrapper;->db:Landroid/database/sqlite/SQLiteDatabase;
invoke-virtual {v3}, Landroid/database/sqlite/SQLiteDatabase;->isOpen()Z
move-result v3
if-eqz v3, :cond_58
iget-object v3, p0, Lio/agora/utils/SqliteWrapper;->db:Landroid/database/sqlite/SQLiteDatabase;
invoke-virtual {v3}, Landroid/database/sqlite/SQLiteDatabase;->close()V
:cond_58
iput-object v2, p0, Lio/agora/utils/SqliteWrapper;->db:Landroid/database/sqlite/SQLiteDatabase;
const-string v2, "SQLITE"
new-instance v3, Ljava/lang/StringBuilder;
invoke-direct {v3}, Ljava/lang/StringBuilder;-><init>()V
const-string v4, "Can not open database: "
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v3, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p1
invoke-static {v2, p1}, Lio/agora/base/internal/Logging;->d(Ljava/lang/String;Ljava/lang/String;)V
monitor-exit v0
return v1
:catchall_72
move-exception p1
goto :goto_9d
:catch_74
iget-object v3, p0, Lio/agora/utils/SqliteWrapper;->db:Landroid/database/sqlite/SQLiteDatabase;
if-eqz v3, :cond_83
invoke-virtual {v3}, Landroid/database/sqlite/SQLiteDatabase;->isOpen()Z
move-result v3
if-eqz v3, :cond_83
iget-object v3, p0, Lio/agora/utils/SqliteWrapper;->db:Landroid/database/sqlite/SQLiteDatabase;
invoke-virtual {v3}, Landroid/database/sqlite/SQLiteDatabase;->close()V
:cond_83
iput-object v2, p0, Lio/agora/utils/SqliteWrapper;->db:Landroid/database/sqlite/SQLiteDatabase;
const-string v2, "SQLITE"
new-instance v3, Ljava/lang/StringBuilder;
invoke-direct {v3}, Ljava/lang/StringBuilder;-><init>()V
const-string v4, "Can not open database: "
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v3, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p1
invoke-static {v2, p1}, Lio/agora/base/internal/Logging;->d(Ljava/lang/String;Ljava/lang/String;)V
monitor-exit v0
return v1
:goto_9d
monitor-exit v0
:try_end_9e
.catchall {:try_start_45 .. :try_end_9e} :catchall_72
throw p1
.end method
.method save(Ljava/lang/String;Ljava/lang/String;[BJ)J
.registers 11
.annotation system Ldalvik/annotation/MethodParameters;
accessFlags = {
0x0,
0x0,
0x0,
0x0
}
names = {
"path",
"key",
"buffer",
"expired"
}
.end annotation
invoke-direct {p0, p1}, Lio/agora/utils/SqliteWrapper;->isPathValid(Ljava/lang/String;)Z
move-result v0
const-wide/16 v1, 0x0
if-nez v0, :cond_9
return-wide v1
:cond_9
invoke-direct {p0, p2}, Lio/agora/utils/SqliteWrapper;->isPathValid(Ljava/lang/String;)Z
move-result v0
if-nez v0, :cond_10
return-wide v1
:cond_10
if-eqz p3, :cond_75
array-length v0, p3
if-nez v0, :cond_16
goto :goto_75
:cond_16
array-length v0, p3
const/high16 v3, 0x80000
if-lt v0, v3, :cond_1c
return-wide v1
:cond_1c
invoke-virtual {p0, p1}, Lio/agora/utils/SqliteWrapper;->touch(Ljava/lang/String;)Z
move-result v0
if-nez v0, :cond_23
return-wide v1
:cond_23
iget-object v0, p0, Lio/agora/utils/SqliteWrapper;->lock:Ljava/lang/Object;
monitor-enter v0
:try_start_26
new-instance v3, Ljava/lang/StringBuilder;
invoke-direct {v3}, Ljava/lang/StringBuilder;-><init>()V
const-string v4, "replace into \""
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v3, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string p1, "\" (key, value, expired) values (\""
invoke-virtual {v3, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v3, p2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string p1, "\", ?, "
invoke-virtual {v3, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v3, p4, p5}, Ljava/lang/StringBuilder;->append(J)Ljava/lang/StringBuilder;
const-string p1, ");"
invoke-virtual {v3, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p1
const/4 p2, 0x0
iget-object p4, p0, Lio/agora/utils/SqliteWrapper;->db:Landroid/database/sqlite/SQLiteDatabase;
invoke-virtual {p4}, Landroid/database/sqlite/SQLiteDatabase;->beginTransaction()V
:try_end_52
.catchall {:try_start_26 .. :try_end_52} :catchall_72
:try_start_52
iget-object p4, p0, Lio/agora/utils/SqliteWrapper;->db:Landroid/database/sqlite/SQLiteDatabase;
invoke-virtual {p4, p1}, Landroid/database/sqlite/SQLiteDatabase;->compileStatement(Ljava/lang/String;)Landroid/database/sqlite/SQLiteStatement;
move-result-object p2
const/4 p1, 0x1
invoke-virtual {p2, p1, p3}, Landroid/database/sqlite/SQLiteStatement;->bindBlob(I[B)V
invoke-virtual {p2}, Landroid/database/sqlite/SQLiteStatement;->execute()V
:try_end_5f
.catch Ljava/lang/Exception; {:try_start_52 .. :try_end_5f} :catch_61
.catchall {:try_start_52 .. :try_end_5f} :catchall_72
:try_start_5f
array-length p1, p3
int-to-long v1, p1
:catch_61
iget-object p1, p0, Lio/agora/utils/SqliteWrapper;->db:Landroid/database/sqlite/SQLiteDatabase;
invoke-virtual {p1}, Landroid/database/sqlite/SQLiteDatabase;->setTransactionSuccessful()V
iget-object p1, p0, Lio/agora/utils/SqliteWrapper;->db:Landroid/database/sqlite/SQLiteDatabase;
invoke-virtual {p1}, Landroid/database/sqlite/SQLiteDatabase;->endTransaction()V
if-eqz p2, :cond_70
invoke-virtual {p2}, Landroid/database/sqlite/SQLiteStatement;->close()V
:cond_70
monitor-exit v0
return-wide v1
:catchall_72
move-exception p1
monitor-exit v0
:try_end_74
.catchall {:try_start_5f .. :try_end_74} :catchall_72
throw p1
:cond_75
:goto_75
return-wide v1
.end method
.method touch(Ljava/lang/String;)Z
.registers 4
.annotation system Ldalvik/annotation/MethodParameters;
accessFlags = {
0x0
}
names = {
"path"
}
.end annotation
new-instance v0, Ljava/lang/StringBuilder;
invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V
const-string v1, "create table if not exists \""
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 v1, "\" (key text primary key, value text, expired INTEGER);"
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-direct {p0, p1, v0}, Lio/agora/utils/SqliteWrapper;->executeCommandOnPath(Ljava/lang/String;Ljava/lang/String;)Z
move-result p1
return p1
.end method