The hypnogram
timeseries type
The removal will happen on or after 31 January 2025.
sleep_cycle
) which captures the detailed hypnogram of a sleep session.
It replaces the existing hypnogram
timeseries type. More details can be found here: Sleep Cycle Summary
Recommended Action
Start processing the new
historical.data.sleep_cycle.created
, daily.data.sleep_cycle.created
and daily.data.sleep_cycle.updated
events.
Stop processing the historical.timeseries.hypnogram.created
, daily.timeseries.hypnogram.created
and daily.timeseries.hypnogram.updated
events.Redefining Source and Provider
The stated removals in this section will happen on or after 31 July 2024.
The new definitions of Provider and Source
The new definitions of Provider and Source
Entity | Definition |
---|---|
Source | The source context of a specific summary or a specific timeseries value group. |
Provider | A wearable data provider (an app, a platform, a service, or Vital Mobile SDKs). |
- the Provider (slug only)
- the Source Type
- the App ID (optional)
name
, logo
and slug
trio you have been receiving in many data events.1
All Data Dvents (daily.data.*)
Inside the Source context located at As part of this redefinition, the Once the deprecation cycle ends, Vital will remove the deprecated fields:
$.data.source
, the name
, logo
, and slug
fields are
now deprecated.Vital no longer embeds these Provider object fields in every data event, except for the provider
slug.Using the Steps data event as an illustration, originally
the source
field describes the wearable data provider:daily.data.steps.created (Original)
source
field is redefined to mean the Source context of this steps timeseries
value group. So Vital has introduced a few new Source context fields:daily.data.steps.created (Current)
daily.data.steps.created (Future)
Recommended Action
Stop parsing
name
, logo
and slug
when processing the $.data.source
field in
all Data Events (daily.data.*).If you need the Provider information, you can obtain it through the Get Providers
endpoint.
2
Get Summary endpoints
This applies to:
- Get Activity:
GET /v2/summary/activity/*
- Get Body:
GET /v2/summary/body/*
- Get Meal:
GET /v2/summary/meal/*
- Get Profile:
GET /v2/summary/profile/*
- Get Sleep:
GET /v2/summary/sleep/*
- Get Workouts:
GET /v2/summary/workouts/*
name
, logo
, and slug
sub-fields under the source
field
in each and every summary are now deprecated.Vital no longer embeds these Provider object fields in every summary, except for the provider
slug.Using the Get Profile endpoint as an illustration, originally
the source
field describes the wearable data provider:Profile (Original)
source
field is redefined to mean the Source context of this Profile
summary. So Vital has introduced a few new Source context fields:Profile (Current)
Profile (Future)
Recommended Action
Stop parsing
name
, logo
and slug
fields in all Get Summary endpoint responses.If you need the Provider information, you can obtain it through the Get Providers
endpoint.
3
Provider Connection events
This applies to:
- Provider Connection Created:
provider.connection.created
.
source
field in this event to provider
, aligning with the redefinition of Source
and Provider.To illustrate the change, originally the source
field describes the wearable data provider:provider.connection.created (Original)
source
is no longer applicable here. Vital has introduced an identical
provider
field as its replacement.provider.connection.created (Current)
source
field:provider.connection.created (Future)
Recommended Action
Update your
provider.connection.created
event parsing logic to parse the provider
field,
and stop parsing the source
field.The is_final
flag in historical.data.*.created
events
The removal will happen on or after 31 June 2024.
is_final
flag from the Historical Pull Completed (historical.data.*.created
) events.
For each resource, Vital now signals one Historical Pull Completed event, only after we have finished fetching
all data chunks. This means is_final
no longer has a meaning, since the event itself is final.
Recommended Action
Stop parsing
is_final
as a required field when processing historical.data.*.created
events.