From db57072dd3cd7d4297b1956cc9758d1f5108f6d5 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Jos=C3=A9=20Rebelo?= Date: Wed, 18 Oct 2023 11:14:08 +0100 Subject: [PATCH] Xiaomi: Make activity file ID types readable --- .../activity/XiaomiActivityFileFetcher.java | 2 +- .../xiaomi/activity/XiaomiActivityFileId.java | 109 +++++++++++++++--- .../xiaomi/activity/XiaomiActivityParser.java | 40 ++++--- 3 files changed, 118 insertions(+), 33 deletions(-) diff --git a/app/src/main/java/nodomain/freeyourgadget/gadgetbridge/service/devices/xiaomi/activity/XiaomiActivityFileFetcher.java b/app/src/main/java/nodomain/freeyourgadget/gadgetbridge/service/devices/xiaomi/activity/XiaomiActivityFileFetcher.java index 04205027b..1726450f0 100644 --- a/app/src/main/java/nodomain/freeyourgadget/gadgetbridge/service/devices/xiaomi/activity/XiaomiActivityFileFetcher.java +++ b/app/src/main/java/nodomain/freeyourgadget/gadgetbridge/service/devices/xiaomi/activity/XiaomiActivityFileFetcher.java @@ -116,7 +116,7 @@ public class XiaomiActivityFileFetcher { return; } - if (activityParser.parse(fileId, activityData)) { + if (activityParser.parse(mHealthService.getSupport(), fileId, activityData)) { if (!XiaomiPreferences.keepActivityDataOnDevice(mHealthService.getSupport().getDevice())) { LOG.debug("Acking recorded data {}", fileId); mHealthService.ackRecordedData(fileId); diff --git a/app/src/main/java/nodomain/freeyourgadget/gadgetbridge/service/devices/xiaomi/activity/XiaomiActivityFileId.java b/app/src/main/java/nodomain/freeyourgadget/gadgetbridge/service/devices/xiaomi/activity/XiaomiActivityFileId.java index ab327fef5..3d84f120f 100644 --- a/app/src/main/java/nodomain/freeyourgadget/gadgetbridge/service/devices/xiaomi/activity/XiaomiActivityFileId.java +++ b/app/src/main/java/nodomain/freeyourgadget/gadgetbridge/service/devices/xiaomi/activity/XiaomiActivityFileId.java @@ -25,12 +25,6 @@ import java.util.Date; import nodomain.freeyourgadget.gadgetbridge.util.DateTimeUtils; public class XiaomiActivityFileId { - public static final int TYPE_ACTIVITY = 0; - public static final int TYPE_SPORTS = 1; - - public static final int TYPE_DETAILS = 0; - public static final int TYPE_SUMMARY = 1; - private final Date timestamp; private final int timezone; private final int type; @@ -60,16 +54,16 @@ public class XiaomiActivityFileId { return timezone; } - public int getType() { - return type; + public Type getType() { + return Type.fromCode(type); } - public int getSubtype() { - return subtype; + public Subtype getSubtype() { + return Subtype.fromCode(getType(), subtype); } - public int getDetailType() { - return detailType; + public DetailType getDetailType() { + return DetailType.fromCode(detailType); } public int getVersion() { @@ -113,13 +107,98 @@ public class XiaomiActivityFileId { @NonNull @Override public String toString() { + final Type typeName = Type.fromCode(type); + final Subtype subtypeName = Subtype.fromCode(typeName, subtype); + final DetailType detailTypeName = DetailType.fromCode(detailType); + return getClass().getSimpleName() + "{" + "timestamp=" + DateTimeUtils.formatIso8601(timestamp) + ", timezone=" + timezone + - ", type=" + type + - ", subtype=" + subtype + - ", detailType=" + detailType + + ", type=" + (typeName != Type.UNKNOWN ? typeName : "UNKNOWN(" + type + ")") + + ", subtype=" + (subtypeName != Subtype.UNKNOWN ? subtypeName : "UNKNOWN(" + subtype + ")") + + ", detailType=" + (detailTypeName != DetailType.UNKNOWN ? detailTypeName : "UNKNOWN(" + detailType + ")") + ", version=" + version + "}"; } + + public enum Type { + UNKNOWN(-1), + ACTIVITY(0), + SPORTS(1), + ; + + private final int code; + + Type(final int code) { + this.code = code; + } + + public int getCode() { + return code; + } + + public static Type fromCode(final int code) { + for (final Type type : values()) { + if (type.getCode() == code) { + return type; + } + } + return UNKNOWN; + } + } + + public enum Subtype { + UNKNOWN(Type.UNKNOWN, -1), + ACTIVITY_DAILY(Type.ACTIVITY, 0), + ACTIVITY_SLEEP(Type.ACTIVITY,8), + SPORTS_FREESTYLE(Type.SPORTS, 8), + ; + + private final Type type; + private final int code; + + Subtype(final Type type, final int code) { + this.type = type; + this.code = code; + } + + public int getCode() { + return code; + } + + public static Subtype fromCode(final Type type, final int code) { + for (final Subtype subtype : values()) { + if (subtype.type == type && subtype.getCode() == code) { + return subtype; + } + } + return UNKNOWN; + } + } + + public enum DetailType { + UNKNOWN(-1), + DETAILS(0), + SUMMARY(1), + ; + + private final int code; + + DetailType(final int code) { + this.code = code; + } + + public int getCode() { + return code; + } + + public static DetailType fromCode(final int code) { + for (final DetailType detailType : values()) { + if (detailType.getCode() == code) { + return detailType; + } + } + return UNKNOWN; + } + } } diff --git a/app/src/main/java/nodomain/freeyourgadget/gadgetbridge/service/devices/xiaomi/activity/XiaomiActivityParser.java b/app/src/main/java/nodomain/freeyourgadget/gadgetbridge/service/devices/xiaomi/activity/XiaomiActivityParser.java index f1d5892d0..494135e34 100644 --- a/app/src/main/java/nodomain/freeyourgadget/gadgetbridge/service/devices/xiaomi/activity/XiaomiActivityParser.java +++ b/app/src/main/java/nodomain/freeyourgadget/gadgetbridge/service/devices/xiaomi/activity/XiaomiActivityParser.java @@ -26,24 +26,14 @@ import nodomain.freeyourgadget.gadgetbridge.service.devices.xiaomi.XiaomiSupport public abstract class XiaomiActivityParser { private static final Logger LOG = LoggerFactory.getLogger(XiaomiActivityParser.class); - private final XiaomiSupport mSupport; - - public XiaomiActivityParser(final XiaomiSupport support) { - this.mSupport = support; - } - - public abstract boolean parse(final XiaomiActivityFileId fileId, final byte[] bytes); - - public XiaomiSupport getSupport() { - return mSupport; - } + public abstract boolean parse(final XiaomiSupport support, final XiaomiActivityFileId fileId, final byte[] bytes); @Nullable public static XiaomiActivityParser create(final XiaomiActivityFileId fileId) { switch (fileId.getType()) { - case XiaomiActivityFileId.TYPE_ACTIVITY: + case ACTIVITY: return createForActivity(fileId); - case XiaomiActivityFileId.TYPE_SPORTS: + case SPORTS: return createForSports(fileId); } @@ -51,14 +41,30 @@ public abstract class XiaomiActivityParser { return null; } - public static XiaomiActivityParser createForActivity(final XiaomiActivityFileId fileId) { - assert fileId.getType() == XiaomiActivityFileId.TYPE_ACTIVITY; + private static XiaomiActivityParser createForActivity(final XiaomiActivityFileId fileId) { + assert fileId.getType() == XiaomiActivityFileId.Type.ACTIVITY; + + switch (fileId.getSubtype()) { + case ACTIVITY_DAILY: + switch (fileId.getDetailType()) { + case DETAILS: + return null; + case SUMMARY: + return null; + } + + break; + } + + LOG.warn("No parser for activity subtype in {}", fileId); return null; } - public static XiaomiActivityParser createForSports(final XiaomiActivityFileId fileId) { - assert fileId.getType() == XiaomiActivityFileId.TYPE_SPORTS; + private static XiaomiActivityParser createForSports(final XiaomiActivityFileId fileId) { + assert fileId.getType() == XiaomiActivityFileId.Type.SPORTS; + + LOG.warn("No parser for sports subtype in {}", fileId); return null; }