1
0
mirror of https://codeberg.org/Freeyourgadget/Gadgetbridge synced 2025-01-16 12:47:32 +01:00

Bangle.js:actTrk: fix 'Reset fetch date' function

This commit is contained in:
Ganblejs 2024-03-09 03:56:02 +01:00 committed by José Rebelo
parent c2a4eed13a
commit 35021f28fa

View File

@ -1,9 +1,12 @@
package nodomain.freeyourgadget.gadgetbridge.service.devices.banglejs;
import static java.lang.Integer.parseInt;
import static java.lang.Long.parseLong;
import static java.lang.Math.cos;
import static java.lang.Math.sqrt;
import android.content.Context;
import android.content.SharedPreferences;
import android.widget.Toast;
import org.json.JSONArray;
@ -17,6 +20,7 @@ import java.io.File;
import java.io.FileReader;
import java.io.IOException;
import java.util.Arrays;
import java.util.Calendar;
import java.util.Date;
import java.util.Objects;
import java.util.Timer;
@ -49,7 +53,7 @@ class BangleJSActivityTrack extends BangleJSDeviceSupport {
signalFetchingStarted(device, context);
//GB.toast("TYPE_GPS_TRACKS says hi!", Toast.LENGTH_LONG, GB.INFO);
String lastSyncedID = getLatestFetchedRecorderLog();
String lastSyncedID = getLatestFetchedRecorderLog(device);
JSONObject o = new JSONObject();
try {
@ -124,7 +128,7 @@ class BangleJSActivityTrack extends BangleJSDeviceSupport {
}
if (!json.has("lines")) { // if no lines were sent with this json object, it signifies that the whole recorder log has been transmitted.
setLatestFetchedRecorderLog(dir, log);
setLatestFetchedRecorderLog(log, device);
parseFetchedRecorderCSV(dir, filename, log, device, context); // I tried refactoring to parse all fetched logs in one go at the end instead. But that only gave me more troubles. This seems like a more stable approach at least in the Bangle.js case.
if (tracksList.length()==0) {
signalFetchingEnded(device, context);
@ -382,8 +386,8 @@ class BangleJSActivityTrack extends BangleJSDeviceSupport {
//LOG.debug("check here 7");
BaseActivitySummary summary = null;
Date startTime = new Date(Long.parseLong(storedLogArray2[1][0].split("\\.\\d")[0])*1000L);
Date endTime = new Date(Long.parseLong(storedLogArray2[storedLogArray2.length-1][0].split("\\.\\d")[0])*1000L);
Date startTime = new Date(parseLong(storedLogArray2[1][0].split("\\.\\d")[0])*1000L);
Date endTime = new Date(parseLong(storedLogArray2[storedLogArray2.length-1][0].split("\\.\\d")[0])*1000L);
summary = new BaseActivitySummary();
summary.setName(log);
summary.setStartTime(startTime);
@ -689,38 +693,94 @@ class BangleJSActivityTrack extends BangleJSDeviceSupport {
startTimeout(device, context);
}
private static String getLatestFetchedRecorderLog() {
File dir;
try {
dir = FileUtils.getExternalFilesDir();
} catch (IOException e) {
return null;
}
String filename = "latestFetchedRecorderLog.txt";
File inputFile = new File(dir, filename);
String lastSyncedID = "";
try {
lastSyncedID = FileUtils.getStringFromFile(inputFile).replace("\n","");
} catch (IOException ignored) {
}
//lastSyncedID = "20230706x"; // DEBUGGING
private static String getLatestFetchedRecorderLog(GBDevice device) {
// "lastSportsActivityTimeMillis" is what
// `ActivitySummaryActivity.resetFetchTimestampToChosenDate()` uses, so we have to
// control if the user changed that value, and if so recompile a new sync id from that info.
LOG.info("Last Synced log ID: " + lastSyncedID);
//requestActivityTracksList(lastSyncedID);
String lastSyncedId = GBApplication.getDeviceSpecificSharedPrefs(device.getAddress()).
getString("lastSportsActivityIdBangleJS","19700101a");
LOG.debug("lastSyncedId: " + lastSyncedId);
return lastSyncedID;
long lastSportsActivityTimeMillis = GBApplication.getDeviceSpecificSharedPrefs(device.getAddress()).
getLong("lastSportsActivityTimeMillis",0);
LOG.debug("lastSportsActivityTimeMillis: " + lastSportsActivityTimeMillis);
Calendar dateFromId = parseCalendarFromBangleJSLogId(lastSyncedId);
Calendar dateFromMillis = parseCalendarFromMillis(lastSportsActivityTimeMillis);
LOG.debug("lastSyncedIdMillis: " + dateFromId.getTimeInMillis());
int intMillis = parseInt(compileDateStringFromCalendar(dateFromMillis));
int intBangle = parseInt(lastSyncedId.substring(0,lastSyncedId.length()-1));
LOG.debug("intMillis: " + intMillis);
LOG.debug("intBangle: " + intBangle);
//if (dateFromMillis.before(dateFromId)) { // This would not work b/c the millis didn't ever become the same in my testing, even if compiled from the same sync id string.
if (intMillis < intBangle) {
dateFromMillis.add(Calendar.DATE, -1); // We want the day before so we fetch from the day the user reset to.
int year = dateFromMillis.get(Calendar.YEAR);
int month = dateFromMillis.get(Calendar.MONTH);
int dayBefore = dateFromMillis.get(Calendar.DATE);
String yearString = String.valueOf(year);
String monthString = String.valueOf(month);
if (month<10) monthString = "0" + monthString;
String dayBeforeString = String.valueOf(dayBefore);
if (dayBefore<10) dayBeforeString = "0" + dayBeforeString;
String letter = "z";
return yearString + monthString + dayBeforeString + letter;
} else {
return lastSyncedId;
}
}
private static void setLatestFetchedRecorderLog(File dir, String log) {
private static void setLatestFetchedRecorderLog(String log, GBDevice device) {
Calendar date = parseCalendarFromBangleJSLogId(log);
String filenameLogID = "latestFetchedRecorderLog.txt";
File outputFileLogID = new File(dir, filenameLogID);
try {
FileUtils.copyStringToFile(log,outputFileLogID,"");
//GB.toast(context, "Log ID " + log + " written to " + filenameLogID, Toast.LENGTH_LONG, GB.INFO);
} catch (IOException e) {
LOG.error("Could not write to file", e);
}
SharedPreferences.Editor editor = GBApplication.getDeviceSpecificSharedPrefs(device.getAddress()).edit();
editor.remove("lastSportsActivityIdBangleJS"); //FIXME: key reconstruction is BAD (FIXME inherited from `ActivitySummaryActivity`.
editor.remove("lastSportsActivityTimeMillis"); //FIXME: key reconstruction is BAD
editor.putString("lastSportsActivityIdBangleJS", log);
editor.putLong("lastSportsActivityTimeMillis", date.getTimeInMillis());
editor.apply();
}
private static Calendar parseCalendarFromBangleJSLogId(String log) {
int year = parseInt(log.substring(0,4));
int month = parseInt(log.substring(4,6));
int day = parseInt(log.substring(6,8));
LOG.debug("DateFromId: " + year+ "|"+ month + "|" +day);
Calendar date = Calendar.getInstance();
date.set(year,month,day);
return date;
}
private static Calendar parseCalendarFromMillis(long millis) {
Calendar date = Calendar.getInstance();
date.setTimeInMillis(millis);
return date;
}
private static String compileDateStringFromCalendar(Calendar date) {
int year = date.get(Calendar.YEAR);
int month = date.get(Calendar.MONTH);
int day = date.get(Calendar.DATE);
String yearString = String.valueOf(year);
String monthString = String.valueOf(month);
if (month<10) monthString = "0" + monthString;
String dayString = String.valueOf(day);
if (day<10) dayString = "0" + dayString;
return yearString + monthString + dayString;
}
private static void writeToRecorderCSV(String lines, File dir, String filename) {