1
0
Fork 0
mirror of https://github.com/M66B/FairEmail.git synced 2025-01-01 04:35:57 +00:00

Fixed scheduling daily / sync workers

This commit is contained in:
M66B 2023-01-24 08:01:41 +01:00
parent 61554af6e9
commit c118b753cd
2 changed files with 12 additions and 7 deletions

View file

@ -129,13 +129,15 @@ public class WorkerDailyRules extends Worker {
try {
if (enabled) {
Calendar cal = Calendar.getInstance();
long delay = cal.getTimeInMillis();
long now = cal.getTimeInMillis();
cal.set(Calendar.MILLISECOND, 0);
cal.set(Calendar.SECOND, 0);
cal.set(Calendar.MINUTE, 0);
cal.set(Calendar.HOUR_OF_DAY, 1);
cal.add(Calendar.DAY_OF_MONTH, 1);
delay = cal.getTimeInMillis() - delay;
long delay = cal.getTimeInMillis() - now;
if (delay < 0)
cal.add(Calendar.DATE, 1);
delay = cal.getTimeInMillis() - now;
Log.i("Queuing " + getName() + " delay=" + (delay / (60 * 1000L)) + "m");
PeriodicWorkRequest.Builder builder =

View file

@ -72,16 +72,19 @@ public class WorkerSync extends Worker {
String user = prefs.getString("cloud_user", null);
String password = prefs.getString("cloud_password", null);
boolean enabled = !(TextUtils.isEmpty(user) || TextUtils.isEmpty(password));
Log.i("Cloud worker enabled=" + enabled);
try {
if (enabled) {
Calendar cal = Calendar.getInstance();
long delay = cal.getTimeInMillis();
long now = cal.getTimeInMillis();
cal.set(Calendar.MILLISECOND, 0);
cal.set(Calendar.SECOND, 0);
cal.set(Calendar.MINUTE, 30);
cal.set(Calendar.HOUR_OF_DAY, 1);
cal.add(Calendar.DAY_OF_MONTH, 1);
delay = cal.getTimeInMillis() - delay;
cal.set(Calendar.HOUR_OF_DAY, 8);
long delay = cal.getTimeInMillis() - now;
if (delay < 0)
cal.add(Calendar.DATE, 1);
delay = cal.getTimeInMillis() - now;
EntityLog.log(context, EntityLog.Type.Cloud,
"Queuing " + getName() + " delay=" + (delay / (60 * 1000L)) + "m");