Prevent auto fetch activity data in quick succession (#4165)

This commit is contained in:
José Rebelo 2024-09-24 19:05:21 +01:00
parent 3c6f1191b5
commit 2ac7aed8d0

View File

@ -21,6 +21,8 @@ import android.content.Context;
import android.content.Intent;
import org.apache.commons.lang3.time.DateUtils;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import java.util.Date;
@ -29,14 +31,26 @@ import nodomain.freeyourgadget.gadgetbridge.model.RecordedDataTypes;
public class GBAutoFetchReceiver extends BroadcastReceiver {
private static final Logger LOG = LoggerFactory.getLogger(GBAutoFetchReceiver.class);
private Date lastSync = new Date();
@Override
public void onReceive(Context context, Intent intent) {
Date nextSync = DateUtils.addMinutes(lastSync, GBApplication.getPrefs().getInt("auto_fetch_interval_limit", 0));
if (nextSync.before(new Date())) {
GBApplication.deviceService().onFetchRecordedData(RecordedDataTypes.TYPE_SYNC);
lastSync = new Date();
public void onReceive(final Context context, final Intent intent) {
synchronized (this) {
final Date now = new Date();
final long timeSinceLast = now.getTime() - lastSync.getTime();
if (timeSinceLast < 2500L) {
// #4165 - prevent multiple syncs in very quick succession
LOG.warn("Throttling auto fetch by {}, last one was {}ms ago", intent.getAction(), timeSinceLast);
return;
}
final Date nextSync = DateUtils.addMinutes(lastSync, GBApplication.getPrefs().getInt("auto_fetch_interval_limit", 0));
if (nextSync.before(now)) {
LOG.info("Trigger auto fetch by {}", intent.getAction());
GBApplication.deviceService().onFetchRecordedData(RecordedDataTypes.TYPE_SYNC);
lastSync = now;
}
}
}
}