mirror of https://github.com/beemdevelopment/Aegis
Abstract away the SQLite database reading logic into a separate class
parent
cd42b0dc65
commit
ef536a0c07
@ -0,0 +1,89 @@
|
|||||||
|
package com.beemdevelopment.aegis.importers;
|
||||||
|
|
||||||
|
import android.content.Context;
|
||||||
|
import android.database.Cursor;
|
||||||
|
import android.database.sqlite.SQLiteDatabase;
|
||||||
|
import android.database.sqlite.SQLiteException;
|
||||||
|
|
||||||
|
import com.topjohnwu.superuser.ShellUtils;
|
||||||
|
|
||||||
|
import java.io.File;
|
||||||
|
import java.io.FileOutputStream;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.io.InputStream;
|
||||||
|
import java.lang.reflect.InvocationTargetException;
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
import static android.database.sqlite.SQLiteDatabase.OPEN_READONLY;
|
||||||
|
|
||||||
|
public class SqlImporterHelper {
|
||||||
|
private Context _context;
|
||||||
|
|
||||||
|
public SqlImporterHelper(Context context) {
|
||||||
|
_context = context;
|
||||||
|
}
|
||||||
|
|
||||||
|
public <T extends Entry> List<T> read(Class<T> type, InputStream inStream, String table) throws DatabaseImporterException {
|
||||||
|
File file;
|
||||||
|
|
||||||
|
try {
|
||||||
|
// create a temporary copy of the database so that SQLiteDatabase can open it
|
||||||
|
file = File.createTempFile("db-import-", "", _context.getCacheDir());
|
||||||
|
try (FileOutputStream out = new FileOutputStream(file)) {
|
||||||
|
ShellUtils.pump(inStream, out);
|
||||||
|
}
|
||||||
|
} catch (IOException e) {
|
||||||
|
throw new DatabaseImporterException(e);
|
||||||
|
}
|
||||||
|
|
||||||
|
try (SQLiteDatabase db = SQLiteDatabase.openDatabase(file.getAbsolutePath(), null, OPEN_READONLY, null)) {
|
||||||
|
try (Cursor cursor = db.rawQuery(String.format("SELECT * FROM %s", table), null)) {
|
||||||
|
List<T> entries = new ArrayList<>();
|
||||||
|
|
||||||
|
if (cursor.moveToFirst()) {
|
||||||
|
do {
|
||||||
|
T entry = type.getDeclaredConstructor(Cursor.class).newInstance(cursor);
|
||||||
|
entries.add(entry);
|
||||||
|
} while (cursor.moveToNext());
|
||||||
|
}
|
||||||
|
|
||||||
|
return entries;
|
||||||
|
} catch (InstantiationException | IllegalAccessException
|
||||||
|
| NoSuchMethodException | InvocationTargetException e) {
|
||||||
|
throw new RuntimeException(e);
|
||||||
|
}
|
||||||
|
} catch (SQLiteException e) {
|
||||||
|
throw new DatabaseImporterException(e);
|
||||||
|
} finally {
|
||||||
|
// always delete the temporary file
|
||||||
|
file.delete();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static String getString(Cursor cursor, String columnName) {
|
||||||
|
return cursor.getString(cursor.getColumnIndex(columnName));
|
||||||
|
}
|
||||||
|
|
||||||
|
public static String getString(Cursor cursor, String columnName, String def) {
|
||||||
|
String res = cursor.getString(cursor.getColumnIndex(columnName));
|
||||||
|
if (res == null) {
|
||||||
|
return def;
|
||||||
|
}
|
||||||
|
return res;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static int getInt(Cursor cursor, String columnName) {
|
||||||
|
return cursor.getInt(cursor.getColumnIndex(columnName));
|
||||||
|
}
|
||||||
|
|
||||||
|
public static long getLong(Cursor cursor, String columnName) {
|
||||||
|
return cursor.getLong(cursor.getColumnIndex(columnName));
|
||||||
|
}
|
||||||
|
|
||||||
|
public static abstract class Entry {
|
||||||
|
public Entry (Cursor cursor) {
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in New Issue