2 * ownCloud Android client application
4 * @author Bartek Przybylski
5 * Copyright (C) 2011-2012 Bartek Przybylski
6 * Copyright (C) 2015 ownCloud Inc.
8 * This program is free software: you can redistribute it and/or modify
9 * it under the terms of the GNU General Public License version 2,
10 * as published by the Free Software Foundation.
12 * This program is distributed in the hope that it will be useful,
13 * but WITHOUT ANY WARRANTY; without even the implied warranty of
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 * GNU General Public License for more details.
17 * You should have received a copy of the GNU General Public License
18 * along with this program. If not, see <http://www.gnu.org/licenses/>.
21 package com
.owncloud
.android
.db
;
23 import com
.owncloud
.android
.MainApp
;
24 import com
.owncloud
.android
.lib
.common
.utils
.Log_OC
;
26 import android
.content
.ContentValues
;
27 import android
.content
.Context
;
28 import android
.database
.Cursor
;
29 import android
.database
.sqlite
.SQLiteDatabase
;
30 import android
.database
.sqlite
.SQLiteOpenHelper
;
33 * Custom database helper for ownCloud
35 public class DbHandler
{
36 private SQLiteDatabase mDB
;
37 private OpenerHelper mHelper
;
38 private final String mDatabaseName
;
39 private final int mDatabaseVersion
= 3;
41 private final String TABLE_INSTANT_UPLOAD
= "instant_upload";
43 public static final int UPLOAD_STATUS_UPLOAD_LATER
= 0;
44 public static final int UPLOAD_STATUS_UPLOAD_FAILED
= 1;
46 public DbHandler(Context context
) {
47 mDatabaseName
= MainApp
.getDBName();
48 mHelper
= new OpenerHelper(context
);
49 mDB
= mHelper
.getWritableDatabase();
56 public boolean putFileForLater(String filepath
, String account
, String message
) {
57 ContentValues cv
= new ContentValues();
58 cv
.put("path", filepath
);
59 cv
.put("account", account
);
60 cv
.put("attempt", UPLOAD_STATUS_UPLOAD_LATER
);
61 cv
.put("message", message
);
62 long result
= mDB
.insert(TABLE_INSTANT_UPLOAD
, null
, cv
);
63 Log_OC
.d(TABLE_INSTANT_UPLOAD
, "putFileForLater returns with: " + result
+ " for file: " + filepath
);
67 public int updateFileState(String filepath
, Integer status
, String message
) {
68 ContentValues cv
= new ContentValues();
69 cv
.put("attempt", status
);
70 cv
.put("message", message
);
71 int result
= mDB
.update(TABLE_INSTANT_UPLOAD
, cv
, "path=?", new String
[] { filepath
});
72 Log_OC
.d(TABLE_INSTANT_UPLOAD
, "updateFileState returns with: " + result
+ " for file: " + filepath
);
76 public Cursor
getAwaitingFiles() {
77 return mDB
.query(TABLE_INSTANT_UPLOAD
, null
, "attempt=" + UPLOAD_STATUS_UPLOAD_LATER
, null
, null
, null
, null
);
80 public Cursor
getFailedFiles() {
81 return mDB
.query(TABLE_INSTANT_UPLOAD
, null
, "attempt>" + UPLOAD_STATUS_UPLOAD_LATER
, null
, null
, null
, null
);
84 public void clearFiles() {
85 mDB
.delete(TABLE_INSTANT_UPLOAD
, null
, null
);
91 * @return true when one or more pending files was removed
93 public boolean removeIUPendingFile(String localPath
) {
94 long result
= mDB
.delete(TABLE_INSTANT_UPLOAD
, "path = ?", new String
[] { localPath
});
95 Log_OC
.d(TABLE_INSTANT_UPLOAD
, "delete returns with: " + result
+ " for file: " + localPath
);
100 private class OpenerHelper
extends SQLiteOpenHelper
{
101 public OpenerHelper(Context context
) {
102 super(context
, mDatabaseName
, null
, mDatabaseVersion
);
106 public void onCreate(SQLiteDatabase db
) {
107 db
.execSQL("CREATE TABLE " + TABLE_INSTANT_UPLOAD
+ " (" + " _id INTEGER PRIMARY KEY, " + " path TEXT,"
108 + " account TEXT,attempt INTEGER,message TEXT);");
112 public void onUpgrade(SQLiteDatabase db
, int oldVersion
, int newVersion
) {
113 if (oldVersion
< 2) {
114 db
.execSQL("ALTER TABLE " + TABLE_INSTANT_UPLOAD
+ " ADD COLUMN attempt INTEGER;");
116 db
.execSQL("ALTER TABLE " + TABLE_INSTANT_UPLOAD
+ " ADD COLUMN message TEXT;");
120 public void onDowngrade(SQLiteDatabase db
, int oldVersion
, int newVersion
) {
121 //downgrading is the exception, so deleting and re-creating is acceptable.
122 //otherwise exception will be thrown (cannot downgrade) and oc app will crash.
123 db
.execSQL("DROP TABLE IF EXISTS " + TABLE_INSTANT_UPLOAD
+ ";");