/******************************************************************************* * Copyright (c) 2011 Jordan Thoms. * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program 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 biz.shadowservices.DegreesToolbox; import android.content.Context; import android.database.sqlite.SQLiteDatabase; import android.database.sqlite.SQLiteOpenHelper; import android.util.Log; public class DBOpenHelper extends SQLiteOpenHelper { // This handles the opening, creation, and upgrading of the DB. private static final String DATABASE_NAME = "PhoneBalance"; private static final int DATABASE_VERSION = 4; @SuppressWarnings("unused") private static final String CACHE_TABLE_NAME = "cache"; private static final String CACHE_TABLE_CREATE = "CREATE TABLE \"cache\" " + "(\"id\" INTEGER PRIMARY KEY AUTOINCREMENT NOT NULL , " + "\"name\" TEXT NOT NULL , \"value\" NUMERIC NULL ," + " \"units\" TEXT, \"expires_value\" NUMERIC," + " \"expires_date\" DATETIME, " + "\"plan_startamount\" NUMERIC NULL, \"plan_name\" VARCHAR(10) NULL)"; private static final String LOG_TABLE_NAME = "log"; private static final String LOG_TABLE_CREATE = "CREATE TABLE \"log\" (\"id\" INTEGER PRIMARY KEY AUTOINCREMENT NOT NULL, " + "\"date_time\" DATETIME NOT NULL," + "\"severity\" VARCHAR(1)," + "\"tag\" VARCHAR(40) NOT NULL," + "\"message\" TEXT NOT NULL)"; private static final String USAGE_TABLE_NAME = "usage"; private static final String USAGE_TABLE_CREATE = "CREATE TABLE \"usage\" (date_time DATETIME NOT NULL, " + "charge_group VARCHAR(10) NOT NULL, charge_type VARCHAR(40) NOT NULL, " + "other_number VARCHAR(15) NULL, amount DECIMAL NULL, " + "charge DECIMAL NOT NULL)"; DBOpenHelper(Context context) { super(context, DATABASE_NAME, null, DATABASE_VERSION); } @Override public void onCreate(SQLiteDatabase db) { db.execSQL(CACHE_TABLE_CREATE); db.execSQL(LOG_TABLE_CREATE); db.execSQL(USAGE_TABLE_CREATE); } @Override public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) { switch(oldVersion) { case 1: Log.v("2DegreesDBOpenHelper", "Exec: " + LOG_TABLE_CREATE); db.execSQL(LOG_TABLE_CREATE); Log.v("2DegreesDBOpenHelper", "Exec: " + USAGE_TABLE_CREATE); db.execSQL(USAGE_TABLE_CREATE); case 2: db.execSQL("DROP TABLE cache"); db.execSQL(CACHE_TABLE_CREATE); case 3: db.execSQL("DROP TABLE cache"); Log.v("2DegreesDBOpenHelper", "Exec: " + CACHE_TABLE_CREATE); db.execSQL(CACHE_TABLE_CREATE); } } }