/**
* Copyright (c) 2013, Redsolution LTD. All rights reserved.
*
* This file is part of Xabber project; you can redistribute it and/or
* modify it under the terms of the GNU General Public License, Version 3.
*
* Xabber is distributed in the hope that it will be useful, but
* WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
* See the GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License,
* along with this program. If not, see http://www.gnu.org/licenses/.
*/
package com.xabber.android.data.database.sqlite;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteStatement;
import com.xabber.android.data.database.DatabaseManager;
import com.xabber.android.data.database.sqlite.AbstractEntityTable;
/**
* Table with custom values associated with chat.
*
* @author alexander.ivanov
*/
abstract class AbstractChatPropertyTable<T> extends AbstractEntityTable {
static final class Fields implements AbstractEntityTable.Fields {
private Fields() {
}
public static final String VALUE = "value";
}
private static final String[] PROJECTION = new String[]{Fields.ACCOUNT,
Fields.USER, Fields.VALUE};
private final DatabaseManager databaseManager;
private SQLiteStatement writeStatement;
private final Object writeLock;
AbstractChatPropertyTable(DatabaseManager databaseManager) {
this.databaseManager = databaseManager;
writeStatement = null;
writeLock = new Object();
}
/**
* @return SQL type of the value field.
*/
abstract String getValueType();
/**
* Hook to bind value as 3 argument to the statement.
*
* @param writeStatement
* @param value
*/
abstract void bindValue(SQLiteStatement writeStatement, T value);
@Override
protected String[] getProjection() {
return PROJECTION;
}
@Override
public void create(SQLiteDatabase db) {
String sql = "CREATE TABLE " + getTableName() + " (" + Fields.ACCOUNT
+ " TEXT," + Fields.USER + " TEXT," + Fields.VALUE + " "
+ getValueType() + ");";
DatabaseManager.execSQL(db, sql);
sql = "CREATE UNIQUE INDEX " + getTableName() + "_index ON "
+ getTableName() + " " + "(" + Fields.ACCOUNT + ", "
+ Fields.USER + ");";
DatabaseManager.execSQL(db, sql);
}
/**
* Initial migrate to create table.
*
* @param db
* @param toVersion
* @param tableName
* @param valueType
*/
void initialMigrate(SQLiteDatabase db, String tableName, String valueType) {
String sql;
sql = "CREATE TABLE " + tableName + " (" + "account TEXT,"
+ "user TEXT," + "value " + valueType + ");";
DatabaseManager.execSQL(db, sql);
sql = "CREATE UNIQUE INDEX " + tableName + "_index ON " + tableName
+ " (account, user);";
DatabaseManager.execSQL(db, sql);
}
public void write(String account, String user, T value) {
synchronized (writeLock) {
if (writeStatement == null) {
SQLiteDatabase db = databaseManager.getWritableDatabase();
writeStatement = db.compileStatement("INSERT OR REPLACE INTO "
+ getTableName() + " (" + Fields.ACCOUNT + ", "
+ Fields.USER + ", " + Fields.VALUE
+ ") VALUES (?, ?, ?);");
}
writeStatement.bindString(1, account);
writeStatement.bindString(2, user);
bindValue(writeStatement, value);
writeStatement.execute();
}
}
}