mirror of
https://codeberg.org/Freeyourgadget/Gadgetbridge
synced 2024-12-26 10:35:50 +01:00
Prevent auto fetch activity data in quick succession (#4165)
This commit is contained in:
parent
3c6f1191b5
commit
2ac7aed8d0
@ -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;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user