mirror of https://github.com/M66B/FairEmail.git
parent
5b73a1a4e8
commit
6cdd2a36aa
File diff suppressed because it is too large
Load Diff
@ -0,0 +1,152 @@
|
||||
package eu.faircode.email;
|
||||
|
||||
/*
|
||||
This file is part of FairEmail.
|
||||
|
||||
FairEmail 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.
|
||||
|
||||
FairEmail 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 FairEmail. If not, see <http://www.gnu.org/licenses/>.
|
||||
|
||||
Copyright 2018-2022 by Marcel Bokhorst (M66B)
|
||||
*/
|
||||
|
||||
import static android.os.Process.THREAD_PRIORITY_BACKGROUND;
|
||||
|
||||
import android.content.Context;
|
||||
import android.content.SharedPreferences;
|
||||
|
||||
import androidx.annotation.NonNull;
|
||||
import androidx.preference.PreferenceManager;
|
||||
import androidx.work.Constraints;
|
||||
import androidx.work.ExistingPeriodicWorkPolicy;
|
||||
import androidx.work.NetworkType;
|
||||
import androidx.work.PeriodicWorkRequest;
|
||||
import androidx.work.WorkManager;
|
||||
import androidx.work.Worker;
|
||||
import androidx.work.WorkerParameters;
|
||||
|
||||
import java.util.Calendar;
|
||||
import java.util.Date;
|
||||
import java.util.List;
|
||||
import java.util.concurrent.TimeUnit;
|
||||
|
||||
import javax.mail.Header;
|
||||
|
||||
public class WorkerDailyRules extends Worker {
|
||||
public WorkerDailyRules(@NonNull Context context, @NonNull WorkerParameters workerParams) {
|
||||
super(context, workerParams);
|
||||
Log.i("Instance " + getName());
|
||||
}
|
||||
|
||||
@NonNull
|
||||
@Override
|
||||
public Result doWork() {
|
||||
Thread.currentThread().setPriority(THREAD_PRIORITY_BACKGROUND);
|
||||
|
||||
final Context context = getApplicationContext();
|
||||
try {
|
||||
EntityLog.log(context, EntityLog.Type.Rules, "Running daily rules");
|
||||
|
||||
DB db = DB.getInstance(context);
|
||||
List<EntityAccount> accounts = db.account().getSynchronizingAccounts(null);
|
||||
for (EntityAccount account : accounts) {
|
||||
List<EntityFolder> folders = db.folder().getFolders(account.id, false, false);
|
||||
for (EntityFolder folder : folders) {
|
||||
List<EntityRule> rules = db.rule().getEnabledRules(folder.id);
|
||||
|
||||
int daily = 0;
|
||||
for (EntityRule rule : rules)
|
||||
if (rule.daily)
|
||||
daily++;
|
||||
if (daily == 0)
|
||||
continue;
|
||||
|
||||
|
||||
int count = 0;
|
||||
List<Long> mids = db.message().getMessageIdsByFolder(folder.id);
|
||||
for (long mid : mids) {
|
||||
EntityMessage message = db.message().getMessage(mid);
|
||||
if (message == null)
|
||||
continue;
|
||||
count++;
|
||||
|
||||
boolean needsHeaders = EntityRule.needsHeaders(message, rules);
|
||||
boolean needsBody = EntityRule.needsBody(message, rules);
|
||||
|
||||
if (needsHeaders && message.headers == null) {
|
||||
EntityOperation.queue(context, message, EntityOperation.HEADERS);
|
||||
continue;
|
||||
}
|
||||
|
||||
if (needsBody && !message.content) {
|
||||
EntityOperation.queue(context, message, EntityOperation.BODY);
|
||||
continue;
|
||||
}
|
||||
|
||||
for (EntityRule rule : rules)
|
||||
if (rule.daily &&
|
||||
rule.matches(context, message, null, null)) {
|
||||
rule.execute(context, message);
|
||||
if (rule.stop)
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
EntityLog.log(context, EntityLog.Type.Rules, folder,
|
||||
"Executed " + count + " rules for " + account.name + "/" + folder.name);
|
||||
}
|
||||
}
|
||||
|
||||
EntityLog.log(context, EntityLog.Type.Rules, "Completed daily rules");
|
||||
return Result.success();
|
||||
} catch (Throwable ex) {
|
||||
Log.e(ex);
|
||||
return Result.failure();
|
||||
}
|
||||
}
|
||||
|
||||
static void init(Context context) {
|
||||
SharedPreferences prefs = PreferenceManager.getDefaultSharedPreferences(context);
|
||||
boolean enabled = prefs.getBoolean("enabled", true);
|
||||
try {
|
||||
if (enabled) {
|
||||
Calendar cal = Calendar.getInstance();
|
||||
long delay = 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;
|
||||
|
||||
Log.i("Queuing " + getName() + " delay=" + (delay / (60 * 1000L)) + "m");
|
||||
PeriodicWorkRequest.Builder builder =
|
||||
new PeriodicWorkRequest.Builder(WorkerAutoUpdate.class, 1, TimeUnit.DAYS)
|
||||
.setInitialDelay(delay, TimeUnit.MILLISECONDS);
|
||||
WorkManager.getInstance(context)
|
||||
.enqueueUniquePeriodicWork(getName(), ExistingPeriodicWorkPolicy.KEEP, builder.build());
|
||||
Log.i("Queued " + getName());
|
||||
} else {
|
||||
Log.i("Cancelling " + getName());
|
||||
WorkManager.getInstance(context).cancelUniqueWork(getName());
|
||||
Log.i("Cancelled " + getName());
|
||||
}
|
||||
} catch (IllegalStateException ex) {
|
||||
// https://issuetracker.google.com/issues/138465476
|
||||
Log.w(ex);
|
||||
}
|
||||
}
|
||||
|
||||
private static String getName() {
|
||||
return WorkerAutoUpdate.class.getSimpleName();
|
||||
}
|
||||
}
|
Loading…
Reference in new issue