mirror of
https://codeberg.org/Freeyourgadget/Gadgetbridge
synced 2024-12-27 02:55: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 android.content.Intent;
|
||||||
|
|
||||||
import org.apache.commons.lang3.time.DateUtils;
|
import org.apache.commons.lang3.time.DateUtils;
|
||||||
|
import org.slf4j.Logger;
|
||||||
|
import org.slf4j.LoggerFactory;
|
||||||
|
|
||||||
import java.util.Date;
|
import java.util.Date;
|
||||||
|
|
||||||
@ -29,14 +31,26 @@ import nodomain.freeyourgadget.gadgetbridge.model.RecordedDataTypes;
|
|||||||
|
|
||||||
|
|
||||||
public class GBAutoFetchReceiver extends BroadcastReceiver {
|
public class GBAutoFetchReceiver extends BroadcastReceiver {
|
||||||
|
private static final Logger LOG = LoggerFactory.getLogger(GBAutoFetchReceiver.class);
|
||||||
|
|
||||||
private Date lastSync = new Date();
|
private Date lastSync = new Date();
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onReceive(Context context, Intent intent) {
|
public void onReceive(final Context context, final Intent intent) {
|
||||||
Date nextSync = DateUtils.addMinutes(lastSync, GBApplication.getPrefs().getInt("auto_fetch_interval_limit", 0));
|
synchronized (this) {
|
||||||
if (nextSync.before(new Date())) {
|
final Date now = new Date();
|
||||||
GBApplication.deviceService().onFetchRecordedData(RecordedDataTypes.TYPE_SYNC);
|
final long timeSinceLast = now.getTime() - lastSync.getTime();
|
||||||
lastSync = new Date();
|
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