|
|
@ -9,8 +9,6 @@ import android.net.Uri;
|
|
|
|
import android.os.PowerManager;
|
|
|
|
import android.os.PowerManager;
|
|
|
|
import android.preference.PreferenceManager;
|
|
|
|
import android.preference.PreferenceManager;
|
|
|
|
|
|
|
|
|
|
|
|
import com.sun.mail.imap.IMAPFolder;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
import java.util.Date;
|
|
|
|
import java.util.Date;
|
|
|
|
import java.util.Properties;
|
|
|
|
import java.util.Properties;
|
|
|
|
|
|
|
|
|
|
|
@ -101,12 +99,16 @@ public class ServiceUI extends IntentService {
|
|
|
|
break;
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
|
|
case "snooze":
|
|
|
|
case "snooze":
|
|
|
|
|
|
|
|
// AlarmManager.RTC_WAKEUP
|
|
|
|
onSnooze(id);
|
|
|
|
onSnooze(id);
|
|
|
|
break;
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
|
|
case "synchronize":
|
|
|
|
case "process":
|
|
|
|
// AlarmManager.RTC_WAKEUP
|
|
|
|
onProcessOperation(id);
|
|
|
|
onSyncOndemand(id);
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
case "fsync":
|
|
|
|
|
|
|
|
onFolderSync(id);
|
|
|
|
break;
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
|
|
default:
|
|
|
|
default:
|
|
|
@ -239,10 +241,9 @@ public class ServiceUI extends IntentService {
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
private void onSyncOndemand(long fid) {
|
|
|
|
private void onProcessOperation(long fid) {
|
|
|
|
Log.i("Synchronize on demand folder=" + fid);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
DB db = DB.getInstance(this);
|
|
|
|
DB db = DB.getInstance(this);
|
|
|
|
|
|
|
|
|
|
|
|
EntityFolder folder = db.folder().getFolder(fid);
|
|
|
|
EntityFolder folder = db.folder().getFolder(fid);
|
|
|
|
if (folder == null)
|
|
|
|
if (folder == null)
|
|
|
|
return;
|
|
|
|
return;
|
|
|
@ -252,10 +253,13 @@ public class ServiceUI extends IntentService {
|
|
|
|
|
|
|
|
|
|
|
|
Store istore = null;
|
|
|
|
Store istore = null;
|
|
|
|
try {
|
|
|
|
try {
|
|
|
|
|
|
|
|
SharedPreferences prefs = PreferenceManager.getDefaultSharedPreferences(this);
|
|
|
|
|
|
|
|
boolean debug = (prefs.getBoolean("debug", false) || BuildConfig.BETA_RELEASE);
|
|
|
|
|
|
|
|
|
|
|
|
// Create session
|
|
|
|
// Create session
|
|
|
|
Properties props = MessageHelper.getSessionProperties(account.auth_type, account.realm, account.insecure);
|
|
|
|
Properties props = MessageHelper.getSessionProperties(account.auth_type, account.realm, account.insecure);
|
|
|
|
final Session isession = Session.getInstance(props, null);
|
|
|
|
final Session isession = Session.getInstance(props, null);
|
|
|
|
isession.setDebug(true);
|
|
|
|
isession.setDebug(debug);
|
|
|
|
|
|
|
|
|
|
|
|
// Connect account
|
|
|
|
// Connect account
|
|
|
|
Log.i(account.name + " connecting");
|
|
|
|
Log.i(account.name + " connecting");
|
|
|
@ -267,9 +271,6 @@ public class ServiceUI extends IntentService {
|
|
|
|
db.account().setAccountError(account.id, null);
|
|
|
|
db.account().setAccountError(account.id, null);
|
|
|
|
Log.i(account.name + " connected");
|
|
|
|
Log.i(account.name + " connected");
|
|
|
|
|
|
|
|
|
|
|
|
// Synchronize folders
|
|
|
|
|
|
|
|
Core.onSynchronizeFolders(this, account, istore, new Core.State());
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// Connect folder
|
|
|
|
// Connect folder
|
|
|
|
Log.i(folder.name + " connecting");
|
|
|
|
Log.i(folder.name + " connecting");
|
|
|
|
db.folder().setFolderState(folder.id, "connecting");
|
|
|
|
db.folder().setFolderState(folder.id, "connecting");
|
|
|
@ -282,9 +283,6 @@ public class ServiceUI extends IntentService {
|
|
|
|
// Process operations
|
|
|
|
// Process operations
|
|
|
|
Core.processOperations(this, account, folder, isession, istore, ifolder, new Core.State());
|
|
|
|
Core.processOperations(this, account, folder, isession, istore, ifolder, new Core.State());
|
|
|
|
|
|
|
|
|
|
|
|
// Synchronize messages
|
|
|
|
|
|
|
|
Core.onSynchronizeMessages(this, folder.getSyncArgs(), account, folder, (IMAPFolder) ifolder, new Core.State());
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
} catch (Throwable ex) {
|
|
|
|
} catch (Throwable ex) {
|
|
|
|
Log.w(ex);
|
|
|
|
Log.w(ex);
|
|
|
|
Core.reportError(this, account, folder, ex);
|
|
|
|
Core.reportError(this, account, folder, ex);
|
|
|
@ -311,13 +309,66 @@ public class ServiceUI extends IntentService {
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
public static void sync(Context context, long folder) {
|
|
|
|
private void onFolderSync(long aid) {
|
|
|
|
DB db = DB.getInstance(context);
|
|
|
|
DB db = DB.getInstance(this);
|
|
|
|
db.folder().setFolderState(folder, "waiting");
|
|
|
|
EntityAccount account = db.account().getAccount(aid);
|
|
|
|
db.folder().setFolderSyncState(folder, "manual");
|
|
|
|
if (account == null)
|
|
|
|
|
|
|
|
return;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
Store istore = null;
|
|
|
|
|
|
|
|
try {
|
|
|
|
|
|
|
|
SharedPreferences prefs = PreferenceManager.getDefaultSharedPreferences(this);
|
|
|
|
|
|
|
|
boolean debug = (prefs.getBoolean("debug", false) || BuildConfig.BETA_RELEASE);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// Create session
|
|
|
|
|
|
|
|
Properties props = MessageHelper.getSessionProperties(account.auth_type, account.realm, account.insecure);
|
|
|
|
|
|
|
|
final Session isession = Session.getInstance(props, null);
|
|
|
|
|
|
|
|
isession.setDebug(debug);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// Connect account
|
|
|
|
|
|
|
|
Log.i(account.name + " connecting");
|
|
|
|
|
|
|
|
db.account().setAccountState(account.id, "connecting");
|
|
|
|
|
|
|
|
istore = isession.getStore(account.getProtocol());
|
|
|
|
|
|
|
|
Helper.connect(this, istore, account);
|
|
|
|
|
|
|
|
db.account().setAccountState(account.id, "connected");
|
|
|
|
|
|
|
|
db.account().setAccountConnected(account.id, new Date().getTime());
|
|
|
|
|
|
|
|
db.account().setAccountError(account.id, null);
|
|
|
|
|
|
|
|
Log.i(account.name + " connected");
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// Synchronize folders
|
|
|
|
|
|
|
|
Core.onSynchronizeFolders(this, account, istore, new Core.State());
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
} catch (Throwable ex) {
|
|
|
|
|
|
|
|
Log.w(ex);
|
|
|
|
|
|
|
|
Core.reportError(this, account, null, ex);
|
|
|
|
|
|
|
|
db.account().setAccountError(account.id, Helper.formatThrowable(ex));
|
|
|
|
|
|
|
|
} finally {
|
|
|
|
|
|
|
|
if (istore != null) {
|
|
|
|
|
|
|
|
Log.i(account.name + " closing");
|
|
|
|
|
|
|
|
db.account().setAccountState(account.id, "closing");
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
try {
|
|
|
|
|
|
|
|
istore.close();
|
|
|
|
|
|
|
|
} catch (MessagingException ex) {
|
|
|
|
|
|
|
|
Log.e(ex);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
Log.i(account.name + " closed");
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
db.account().setAccountState(account.id, null);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
public static void process(Context context, long folder) {
|
|
|
|
|
|
|
|
context.startService(
|
|
|
|
|
|
|
|
new Intent(context, ServiceUI.class)
|
|
|
|
|
|
|
|
.setAction("process:" + folder));
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
public static void fsync(Context context, long account) {
|
|
|
|
context.startService(
|
|
|
|
context.startService(
|
|
|
|
new Intent(context, ServiceUI.class)
|
|
|
|
new Intent(context, ServiceUI.class)
|
|
|
|
.setAction("synchronize:" + folder));
|
|
|
|
.setAction("fsync:" + account));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|