Also scrape stress data
This commit is contained in:
parent
4203bfeca5
commit
8dbe90f6de
1 changed files with 27 additions and 5 deletions
|
@ -26,10 +26,23 @@ def hr2point(time, val):
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
||||||
|
def stress2point(time, val):
|
||||||
|
return Point("health") \
|
||||||
|
.field("stress", max(val, 0)) \
|
||||||
|
.time(
|
||||||
|
datetime.fromtimestamp(time / 1000, timezone.utc),
|
||||||
|
WritePrecision.S
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
def hr_for_date(api, date_to_fetch):
|
def hr_for_date(api, date_to_fetch):
|
||||||
return api.get_heart_rates(date_to_fetch.isoformat())['heartRateValues']
|
return api.get_heart_rates(date_to_fetch.isoformat())['heartRateValues']
|
||||||
|
|
||||||
|
|
||||||
|
def stress_for_date(api, date_to_fetch):
|
||||||
|
return api.get_stress_data(date_to_fetch.isoformat())['stressValuesArray']
|
||||||
|
|
||||||
|
|
||||||
date_to_fetch = date.today().isoformat()
|
date_to_fetch = date.today().isoformat()
|
||||||
if len(sys.argv) > 1:
|
if len(sys.argv) > 1:
|
||||||
date_to_fetch = sys.argv[1]
|
date_to_fetch = sys.argv[1]
|
||||||
|
@ -39,21 +52,30 @@ date_to_fetch = date.fromisoformat(date_to_fetch)
|
||||||
try:
|
try:
|
||||||
api = Garmin(email, password)
|
api = Garmin(email, password)
|
||||||
api.login()
|
api.login()
|
||||||
points = list(map(
|
hr_points = list(map(
|
||||||
lambda p: hr2point(*p),
|
lambda p: hr2point(*p),
|
||||||
hr_for_date(api, date_to_fetch - timedelta(days=1))
|
hr_for_date(api, date_to_fetch - timedelta(days=1))
|
||||||
))
|
))
|
||||||
points += list(map(
|
stress_points = list(map(
|
||||||
|
lambda p: stress2point(*p),
|
||||||
|
stress_for_date(api, date_to_fetch - timedelta(days=1))
|
||||||
|
))
|
||||||
|
hr_points += list(map(
|
||||||
lambda p: hr2point(*p),
|
lambda p: hr2point(*p),
|
||||||
hr_for_date(api, date_to_fetch)
|
hr_for_date(api, date_to_fetch)
|
||||||
))
|
))
|
||||||
|
stress_points += list(map(
|
||||||
|
lambda p: stress2point(*p),
|
||||||
|
stress_for_date(api, date_to_fetch)
|
||||||
|
))
|
||||||
with InfluxDBClient(
|
with InfluxDBClient(
|
||||||
url="https://stats.chvp.be:8086",
|
url="https://stats.chvp.be:8086",
|
||||||
token=token,
|
token=token,
|
||||||
org=org
|
org=org
|
||||||
) as client:
|
) as client:
|
||||||
write_api = client.write_api(write_options=SYNCHRONOUS)
|
write_api = client.write_api(write_options=SYNCHRONOUS)
|
||||||
write_api.write(bucket, org, points)
|
write_api.write(bucket, org, hr_points)
|
||||||
|
write_api.write(bucket, org, stress_points)
|
||||||
except (
|
except (
|
||||||
GarminConnectConnectionError,
|
GarminConnectConnectionError,
|
||||||
GarminConnectAuthenticationError,
|
GarminConnectAuthenticationError,
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue