Partner API V3 Reference
Introduction
The Partner API V3 Documentation provides details of the APIs used to manage user profile, user workout presets, user workout results, equipment and facility data.
API Endpoints (Base URLs)
- DEV - https://api.developers.lifefitness.com/partnerapi/dev
- STAGING - https://api.developers.lifefitness.com/partnerapi/staging
- PRODUCTION - https://api.developers.lifefitness.com/partnerapi/production
Authentication
To access the Partner API V3 resources, the client needs to get an access token by providing the client credentials to the Authentication endpoint. The success response includes an access token which should be used as the Bearer token in the Authorization header for accessing Partner API v3 APIs.
Client Credentials
Client credentials are used to obtain an access token during Authentication they consist of a clientId
and a clientSecret
. Client credentials are unique to the client and the environment and distributed only to authorized parties. Please refer to Halo Fitness Developer Portal for more details on getting started.
Authentication Token
Authenticates the client's credentials and returns an oauth-access-token that can be used to make requests to the resources described in this documentation.
Endpoint
POST /api/v3/oauth/token
POST /api/v3/oauth/token HTTP/1.1
Host: {{BASE_URL}}
Content-Type: application/json
Accept: application/json
Content-Length: 108
{
"grantType": "client_credentials",
"clientId": "0c4b64...",
"clientSecret": "TUv17HH..."
}
curl --location '{{BASE_URL}}/api/v3/oauth/token' \
--header 'Content-Type: application/json' \
--header 'Accept: application/json' \
--data '{
"grantType": "client_credentials",
"clientId": "0c4b64...",
"clientSecret": "TUv17HH..."
}'
Headers
Header | Value |
---|---|
Accept | application/json |
Content-Type | application/json |
Body
Parameter | Type | Required |
---|---|---|
clientId | string | Y |
clientSecret | string | Y |
grantType | string ("client_credentials") | Y |
Response
Success
A successful response returns a HTTP Status Code: 200 - OK. This indicates that client authorization succeeded and the access token required to make requests to endpoints in this documentation has been returned in the body.
{
"status": "SUCCESSFUL",
"data": {
"accessToken": "eyAbc...",
"tokenType": "Bearer",
"expiresInSeconds": 3600
},
"error": null,
"meta": null
}
Parameter | Type | Description |
---|---|---|
status | string | Indicates status of response |
data.accessToken | string | oauth access token used as the Bearer token to access Partner APIs |
data.tokenType | string | oauth access token type - "Bearer" |
data.expiresInSeconds | number | oauth access token expiry time in seconds (1 hour) |
error | object | null in case of success response |
meta | object | meta object will be populated if any relevant metadata is available |
Error
Errors returned from this endpoint can be one of the following
- HTTP Status Code: 400 (Bad Request) Occurs when an invalid request was made, usually as the result of an invalid grant type
- HTTP Status Code: 401 (Authorization) Occurs when the credentials provided are not valid
- HTTP Status Code: 500 (Fault) Occurs when a server error has occurred
400
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 1001,
"errorMsg": "Missing parameter/s: Please provide a valid clientId and clientSecret"
},
"meta": null
}
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 1006,
"errorMsg": "Invalid grantType. Supported grant type is client_credentials"
},
"meta": null
}
401
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 1002,
"errorMsg": "Invalid clientId and/or clientSecret."
},
"meta": null
}
Parameter | Type | Description |
---|---|---|
status | string | Indicates the status of the request - SUCCESSFUL or FAILURE |
data | object | null in case of error |
error.errorCode | number | numeric value corresponding to the error message |
error.errorMsg | string | error message string |
meta | object | meta object will be populated if any relevant metadata is available |
OAuth
Verify OAuth Code
Third party developer application can request an access token for an existing user account from the PartnerAPI oauthAuthorize web page. This API takes the Authorization Code retrieved from the oauthAuthorize web page and returns user access token and refresh tokens in successful response. The Authorization code is usable only once.
Endpoint
POST /api/v3/oauth/verify-code
POST /api/v3/oauth/verify-code HTTP/1.1
Host: {{BASE_URL}}
Authorization: Bearer eyAbc...
Accept: application/json
Content-Type: application/json
Content-Length: 59
{
"code": "b1d67c0d65e61449b94ba33280e43e37|574934"
}
curl --location '{{BASE_URL}}/api/v3/oauth/verify-code' \
--header 'Authorization: Bearer eyAbc...' \
--header 'Accept: application/json' \
--header 'Content-Type: application/json' \
--data '{
"code": "b1d67c0d65e61449b94ba33280e43e37|574934"
}'
Headers
Header | Value |
---|---|
Accept | application/json |
Authorization | Bearer {oauth-access-token} |
Body
Parameter | Type | Required |
---|---|---|
code | string | Y |
Response
Success
A successful response returns a HTTP Status Code: 200 - OK. This indicates the code was valid and user's access and refresh tokens are returned in the success response.
{
"status": "SUCCESSFUL",
"data": {
"expiresIn": 31536000,
"accessToken": "9574cd575d7473405b846560c4d79d86|92733cdd75e7ba5e276479748e996180",
"tokenType": "Bearer",
"refreshToken": "92733cdd75e7ba5e276479748e996180|703919a789c6b8e50d87da89572008f0|328905"
},
"error": null,
"meta": null
}
Parameter | Type |
---|---|
status | string |
data | Object |
data.expiresIn | numeric |
data.accessToken | string |
data.tokenType | string |
data.refreshToken | string |
meta | Object / NULL |
error | Object / NULL |
Error
Errors returned from this endpoint can be one of the following
- HTTP Status Code: 401 (Authorization) Occurs when the Authorization header isn't set or is expired
- HTTP Status Code: 422 (Validation) Occurs when the code is invalid
- HTTP Status Code: 500 (Fault) Occurs when a server error has occurred
401
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 401,
"errorMsg": "user-access-token Header is missing"
},
"meta": null
}
422
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 1004,
"errorMsg": "Incorrect or expired Authorization Code"
},
"meta": null
}
500
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 500,
"errorMsg": "Internal Error"
},
"meta": null
}
Parameter | Type | Description |
---|---|---|
status | string | Indicates the status of the request - SUCCESSFUL or FAILURE |
data | object | null in case of error |
error.errorCode | number | numeric value corresponding to the error message |
error.errorMsg | string | error message string |
meta | object | meta object will be populated if any relevant metadata is available |
Refresh OAuth Tokens
This API can be used to regenerate the access and refresh tokens from a valid refresh token of a user.
Endpoint
POST /api/v3/oauth/refresh-tokens
POST /api/v3/oauth/refresh-tokens HTTP/1.1
Host: {{BASE_URL}}
Authorization: Bearer eyAbc...
Accept: application/json
Content-Type: application/json
Content-Length: 59
{
"refreshToken": "92733cdd75e7ba5e276479748e996180|9e382d69eae2c1acbb62c6d6c58885ad|921977"
}
curl --location '{{BASE_URL}}/api/v3/oauth/refresh-tokens' \
--header 'Authorization: Bearer eyAbc...' \
--header 'Accept: application/json' \
--header 'Content-Type: application/json' \
--data '{
"refreshToken": "92733cdd75e7ba5e276479748e996180|9e382d69eae2c1acbb62c6d6c58885ad|921977"
}'
Headers
Header | Value |
---|---|
Accept | application/json |
Authorization | Bearer {oauth-access-token} |
Body
Parameter | Type | Required |
---|---|---|
refreshToken | string | Y |
Response
Success
A successful response returns a HTTP Status Code: 200 - OK. This indicates the code was valid and user's access and refresh tokens are returned in the success response.
{
"status": "SUCCESSFUL",
"data": {
"expiresIn": 31536000,
"accessToken": "9574cd575d7473405b846560c4d79d86|92733cdd75e7ba5e276479748e996180",
"tokenType": "Bearer",
"refreshToken": "92733cdd75e7ba5e276479748e996180|703919a789c6b8e50d87da89572008f0|328905"
},
"error": null,
"meta": null
}
Parameter | Type |
---|---|
status | string |
data | Object |
data.expiresIn | numeric |
data.accessToken | string |
data.tokenType | string |
data.refreshToken | string |
meta | Object / NULL |
error | Object / NULL |
Error
Errors returned from this endpoint can be one of the following
- HTTP Status Code: 401 (Authorization) Occurs when the Authorization header isn't set or is expired
- HTTP Status Code: 422 (Validation) Occurs when the code is invalid
- HTTP Status Code: 500 (Fault) Occurs when a server error has occurred
401
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 401,
"errorMsg": "user-access-token Header is missing"
},
"meta": null
}
422
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 1005,
"errorMsg": "Invalid token. Please provide a valid refreshToken"
},
"meta": null
}
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 1005,
"errorMsg": "Invalid token. refreshToken not found"
},
"meta": null
}
500
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 500,
"errorMsg": "Internal Error"
},
"meta": null
}
Parameter | Type | Description |
---|---|---|
status | string | Indicates the status of the request - SUCCESSFUL or FAILURE |
data | object | null in case of error |
error.errorCode | number | numeric value corresponding to the error message |
error.errorMsg | string | error message string |
meta | object | meta object will be populated if any relevant metadata is available |
User Profile
This section contains APIs which manage a user's profile.
Create User
Creates a new user account.
Endpoint
POST /api/v3/users
POST /api/v3/users HTTP/1.1
Host: {{BASE_URL}}
Accept: application/json
Authorization: Bearer eyAbc...
Content-Type: application/json
{
"emailAddress": "jane.doe@nowhere.com",
"xid": "JN10001",
"dob": "1990-01-30",
"weight": 150.80,
"weightUnit": "M",
"password": "Test123!",
"height": 170.50,
"heightUnit": "M",
"firstName": "Jane",
"lastName": "Doe",
"gender": "f",
"preferredLanguageCode": "en",
"preferredUnit": "M",
"facilityIdList": [20]
}
curl --location '{{BASE_URL}}/api/v3/users' \
--header 'Accept: application/json' \
--header 'Authorization: Bearer eyAbc...' \
--header 'Content-Type: application/json' \
--data-raw '{
"emailAddress": "jane.doe@nowhere.com",
"xid": "JN10001",
"dob": "1990-01-30",
"weight": 150.80,
"weightUnit": "M",
"password": "Test123!",
"height": 170.50,
"heightUnit": "M",
"firstName": "Jane",
"lastName": "Doe",
"gender": "f",
"preferredLanguageCode": "en",
"preferredUnit": "M",
"facilityIdList": [20]
}'
Headers
Header | Value |
---|---|
Accept | application/json |
Content-Type | application/json |
Authorization | Bearer {oauth-access-token} |
Body
Parameter | Type | Required |
---|---|---|
emailAddress | string (Email of the user. Maximum characters allowed is 200) | Y |
xid | string (External account id of the user. Maximum characters allowed is 50) | Y |
dob | string (Date of birth of the user in the 'yyyy-MM-dd' format. Supported age range is from 13 to 100 years) | Y |
weight | numeric (If weightUnit is provided as 'M' then minimum value is 34 and maximum value is 181. If weightUnit is provided as 'I' then minimum value is 75 and maximum value is 400) | Y |
weightUnit | string (Unit code of the value used in 'weight' property, else defaults to the 'preferredUnit' property. Supported values are either "I" or "M") | N |
height | numeric (If heightUnit is provided as 'M' then minimum value is 60 and maximum value is 310. If heightUnit is provided as 'I' then minimum value is 23.64 and maximum value is 122.04) | N |
heightUnit | string (Unit code of the value used in 'height' property, else defaults to the 'preferredUnit' property. . Supported values are either "I" or "M") | N |
password | string (Password of the user. If not specified, a random autogenerated password is set for the user. The password policy is: minimum 8 characters, at least one number is required, at least one upper case or lower case letter is required, at least one special character (!@#$%^&*) is required) | N |
firstName | string (First name of the user. Maximum characters allowed is 200) | N |
lastName | string (Last name of the user. Maximum characters allowed is 200) | N |
gender | string (Gender of the user. Supported values are "m" or "f" ) | N |
preferredLanguageCode | string (Language code of the user's preferred language. If not specified, the default value is "en". Supported values: [ en_US = US English, en = British English, fr = Français, de = Deutsch, nl = Nederlands, it = Italiano, es = Español, ja = 日本語, zh = 简体中文, pt = Português, ru = Pусский, tr = Türkçe, ca = Català, eu = Euskara, fi = Suomi, hu = Magyar, ko = 한국어, pl = Polski, zhl = 繁體中文, cy = Cymraeg, ar = العربية, he = עִברִית ] | N |
preferredUnit | string (User's preferred Unit code. If not specified, Default value "I" will be set. Supported values are either "I" or "M") | N |
facilityIdList | integer array (List of facilities associated with the user) | N |
Response
Success
A successful response returns a HTTP Status Code: 201 - Created. This indicates the user was created successfully.
{
"data":{
"userAccessToken": "xyz123...",
"userAccessTokenExpiry": 1677689984915,
"emailAddress": "jane.doe@nowhere.com",
"xid": "JN10001",
"dob": "1990-01-30",
"weight": 150.80,
"weightUnit": "M",
"height": 170.50,
"heightUnit": "M",
"firstName": "Jane",
"lastName": "Doe",
"gender": "f",
"preferredLanguageCode": "en",
"preferredUnit": "M",
"facilityIdList": [20],
"age": 23,
"enabled": true,
"createdAt": "2023-02-16T18:48:37Z",
"updatedAt": "2023-02-16T18:48:37Z",
},
"meta": {
}
}
Parameter | Type |
---|---|
data | Object |
data.userAccessToken | string |
data.userAccessTokenExpiry | integer (Epoch time in millis indicating the expiry of the "userAccessToken" property) |
data.emailAddress | string |
data.xid | string |
data.dob | string (yyyy-MM-dd) |
data.weight | numeric |
data.weightUnit | string ("I"/"M") / NULL |
data.height | numeric / NULL |
data.heightUnit | string ("I"/"M") / NULL |
data.firstName | string / NULL |
data.lastName | string / NULL |
data.gender | string ("m"/"f") / NULL |
data.preferredLanguageCode | string |
data.preferredUnit | string ("I"/"M") |
data.facilityIdList | integer[] / NULL |
data.age | integer |
data.enabled | boolean |
data.createdAt | string (ISO 8601) |
data.updatedAt | string (ISO 8601) |
meta | Object / NULL |
Error
Errors returned from this endpoint can be one of the following
- HTTP Status Code: 401 (Authorization) Occurs when the Authorization header isn't set or an invalid access token is being used
- HTTP Status Code: 409 (Conflict) Occurs when the email address or xid is already in use by another account
- HTTP Status Code: 422 (Validation) Occurs when a property/properties doesn't meet the required type as documented here
- HTTP Status Code: 500 (Fault) Occurs when a server error has occurred
401
{
"errorCode": "Authorization",
"errorMessage": "Not authorized for resource.",
"innerErrors": [
{
"errorCode": "ClientAccessTokenInvalid",
"errorTarget": {
"source": "Header",
"key": "Authorization",
}
}
]
}
409
{
"errorCode": "Conflict",
"errorMessage": "Unable to fulfill request due to conflict.",
"innerErrors": [
{
"errorCode": "EmailAddressInUse",
"errorTarget": {
"source": "Body",
"key": "emailAddress",
},
"message": "This emailAddress is already in use."
},
{
"errorCode": "XIDInUse",
"errorTarget": {
"source": "Body",
"key": "xid",
},
"message": "This xid is already in use."
}
]
}
422
{
"errorCode": "Validation",
"errorMessage": "The given data failed to pass validation.",
"innerErrors": [
{
"errorCode": "RequiredValidation",
"errorTarget": {
"source": "Body",
"key": "emailAddress",
},
"message":"The 'emailAddress' property is required."
},
{
"errorCode": "RequiredValidation",
"errorTarget": {
"source": "Body",
"key": "xid",
},
"message":"The 'xid' property is required."
},
{
"errorCode": "RequiredValidation",
"errorTarget": {
"source": "Body",
"key": "weight",
},
"message":"The 'weight' property is required."
},
{
"errorCode": "RequiredValidation",
"errorTarget": {
"source": "Body",
"key": "dob",
},
"message":"The 'dob' property is required."
},
{
"errorCode": "StringValidation",
"errorTarget": {
"source": "Body",
"key": "emailAddress",
},
"message":"The 'emailAddress' property must be a string."
},
{
"errorCode": "EmailValidation",
"errorTarget": {
"source": "Body",
"key": "emailAddress",
},
"message":"The 'emailAddress' property must be an email."
},
{
"errorCode": "StringValidation",
"errorTarget": {
"source": "Body",
"key": "xid",
},
"message":"The 'xid' property must be a string."
},
{
"errorCode": "StringValidation",
"errorTarget": {
"source": "Body",
"key": "dob",
},
"message":"The 'dob' property must be a string."
},
{
"errorCode": "EmailValidation",
"errorTarget": {
"source": "Body",
"key": "email",
},
"message":"The 'email' property must be an email."
},
{
"errorCode": "DateValidation",
"errorTarget": {
"source": "Body",
"key": "dob",
},
"message":"The 'dob' property must be a date in format 'yyyy-MM-dd'."
},
{
"errorCode": "AgeValidation",
"errorTarget": {
"source": "Body",
"key": "dob",
},
"message":"The 'dob' property should have the year corresponding to age between 13 and 100 years."
},
{
"errorCode": "ISO639Validation",
"errorTarget": {
"source": "Body",
"key": "preferredLanguageCode"
},
"message": "The 'preferredLanguageCode' property is not valid."
},
{
"errorCode": "UnitValidation",
"errorTarget": {
"source": "Body",
"key": "heightUnit"
},
"message": "The 'heightUnit' property must be one of the following strings 'M' or 'I'."
},
{
"errorCode": "UnitValidation",
"errorTarget": {
"source": "Body",
"key": "weightUnit"
},
"message": "The 'weightUnit' property must be one of the following strings 'M' or 'I'."
},
{
"errorCode": "UnitValidation",
"errorTarget": {
"source": "Body",
"key": "preferredUnit"
},
"message": "The 'preferredUnit' property must be one of the following strings 'M' or 'I'."
},
{
"errorCode": "InvalidStringValidation",
"errorTarget": {
"source": "Body",
"key": "gender"
},
"message": "The 'gender' property must be one of the following values: [\"m\",\"f\"]"
},
{
"errorCode": "PasswordPolicyNotMet",
"errorTarget": {
"source": "Body",
"key": "password"
},
"message": "The 'password' property must be the password policy."
},
{
"errorCode": "NumericValidation",
"errorTarget": {
"source": "Body",
"key": "height"
},
"message": "The 'height' property must be a numeric value with or without decimals."
},
{
"errorCode": "NumericValidation",
"errorTarget": {
"source": "Body",
"key": "weight"
},
"message": "The 'weight' property must be a numeric value with or without decimals."
},
{
"errorCode": "HeightValidation",
"errorTarget": {
"source": "Body",
"key": "height"
},
"message": "The 'height' property must be within supported range."
},
{
"errorCode": "WeightValidation",
"errorTarget": {
"source": "Body",
"key": "weight"
},
"message": "The 'weight' property must be within supported range."
},
{
"errorCode": "FacilityIdsValidation",
"errorTarget": {
"source": "Body",
"key": "facilityIds"
},
"message": "The 'facilityIds' property must be an array of unique integers."
},
{
"errorCode": "FacilityIdsValidation",
"errorTarget": {
"source": "Body",
"key": "facilityIds"
},
"message": "Invalid facilityIds: {invalidFacilityIds}"
},
{
"errorCode": "MaximumCharactersLimitValidation",
"errorTarget": {
"source": "Body",
"key": "{property}"
},
"message": "The {property} exceeded the maximum allowed character limit"
}
]
}
500
{
"errorCode": "Fault",
"errorMessage": "A server error occurred.",
"innerErrors": []
}
Parameter | Type | Description |
---|---|---|
status | string | Indicates the status of the request - SUCCESSFUL or FAILURE |
data | object | null in case of error |
error.errorCode | number | numeric value corresponding to the error message |
error.errorMsg | string | error message string |
meta | object | meta object will be populated if any relevant metadata is available |
Get User information
Retrieves an existing user using the user-access-token in the user-access-token header.
Endpoint
GET /api/v3/users
GET /api/v3/users HTTP/1.1
Host: {{BASE_URL}}
Accept: application/json
Authorization: Bearer eyAbc...
user-access-token: xyz123...
curl --location '{{BASE_URL}}/api/v3/users' \
--header 'Accept: application/json' \
--header 'Authorization: Bearer eyAbc...' \
--header 'user-access-token: xyz123...'
Headers
Header | Value |
---|---|
Accept | application/json |
Authorization | Bearer {oauth-access-token} |
user-access-token | {user-access-token} |
Response
Success
A successful response returns a HTTP Status Code: 200 - OK. This indicates the user was successfully retrieved and their data is available in the body.
{
"data":{
"userAccessToken": "xyz123...",
"userAccessTokenExpiry": 1677689984915,
"emailAddress": "jane.doe@nowhere.com",
"xid": "JN10001",
"dob": "1990-01-30",
"weight": 150.80,
"weightUnit": "M",
"height": 170.50,
"heightUnit": "M",
"firstName": "Jane",
"lastName": "Doe",
"gender": "f",
"preferredLanguageCode": "en",
"preferredUnit": "M",
"age": 23,
"enabled": true,
"createdAt": "2023-02-16T18:48:37Z",
"updatedAt": "2023-02-16T18:48:37Z",
},
"meta": {
}
}
Parameter | Type |
---|---|
data | Object |
data.userAccessToken | string |
data.userAccessTokenExpiry | integer (Epoch time in millis indicating the expiry of the "userAccessToken" property) |
data.emailAddress | string |
data.xid | string |
data.dob | string (yyyy-MM-dd) |
data.weight | numeric |
data.weightUnit | string ("I"/"M") / NULL |
data.height | numeric / NULL |
data.heightUnit | string ("I"/"M") / NULL |
data.firstName | string / NULL |
data.lastName | string / NULL |
data.gender | string ("m"/"f") / NULL |
data.preferredLanguageCode | string |
data.preferredUnit | string ("I"/"M") |
data.age | integer |
data.enabled | boolean |
data.createdAt | string (ISO 8601) |
data.updatedAt | string (ISO 8601) |
meta | Object / NULL |
Error
Errors returned from this endpoint can be one of the following
- HTTP Status Code: 401 (Authorization) Occurs when the Authorization header isn't set or an invalid access token is being used
- HTTP Status Code: 404 (Not Found) Occurs when the user could not be retrieved by the specified Header user-access-token
- HTTP Status Code: 500 (Fault) Occurs when a server error has occurred
401
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 401,
"errorMsg": "user-access-token Header is missing"
},
"meta": null
}
404
{
"errorCode": "NotFound",
"errorMessage": "The requested resource was not found.",
"innerErrors": [
{
"errorCode": "UserNotFound",
"errorTarget": {
"source": "Header",
"key": "user-access-token",
}
}
]
}
500
{
"errorCode": "Fault",
"errorMessage": "A server error occurred.",
"innerErrors": []
}
Parameter | Type | Description |
---|---|---|
status | string | Indicates the status of the request - SUCCESSFUL or FAILURE |
data | object | null in case of error |
error.errorCode | number | numeric value corresponding to the error message |
error.errorMsg | string | error message string |
meta | object | meta object will be populated if any relevant metadata is available |
Update User
Update an existing user account corresponding to the user-access-token header. This API can be used to change the user's email, password, xid and also to enable/disable the user.
Endpoint
PUT /api/v3/users
PUT /api/v3/users HTTP/1.1
Host: {{BASE_URL}}
Accept: application/json
Authorization: Bearer eyAbc...
user-access-token: xyz123...
Content-Type: application/json
Content-Length: 353
{
"emailAddress": "jane.doe@nowhere.com",
"xid": "JN10001",
"dob": "1990-01-30",
"weight": 150.80,
"weightUnit": "M",
"password": "Test123!",
"height": 170.50,
"heightUnit": "M",
"firstName": "Jane",
"lastName": "Doe",
"gender": "f",
"preferredLanguageCode": "en",
"preferredUnit": "M",
"enabled": true,
}
curl --location --request PUT '{{BASE_URL}}/api/v3/users' \
--header 'Accept: application/json' \
--header 'Authorization: Bearer eyAbc...' \
--header 'user-access-token: xyz123...' \
--header 'Content-Type: application/json' \
--data-raw '{
"emailAddress": "jane.doe@nowhere.com",
"xid": "JN10001",
"dob": "1990-01-30",
"weight": 150.80,
"weightUnit": "M",
"password": "Test123!",
"height": 170.50,
"heightUnit": "M",
"firstName": "Jane",
"lastName": "Doe",
"gender": "f",
"preferredLanguageCode": "en",
"preferredUnit": "M",
"enabled": true
}'
Headers
Header | Value |
---|---|
Accept | application/json |
Authorization | Bearer {oauth-access-token} |
user-access-token | {user-access-token} |
Body
Parameter | Type | Required |
---|---|---|
emailAddress | string (Email of the user. Maximum characters allowed is 200) | Y |
xid | string (External account id of the user. Maximum characters allowed is 50) | Y |
dob | string (Date of birth of the user in the 'yyyy-MM-dd' format. Supported age range is from 13 to 100 years) | Y |
weight | numeric (If weightUnit is provided as 'M' then minimum value is 34 and maximum value is 181. If weightUnit is provided as 'I' then minimum value is 75 and maximum value is 400) | Y |
weightUnit | string (Unit code of the value used in 'weight' property, else defaults to the 'preferredUnit' property. Supported values are either "I" or "M") | N |
height | numeric (If heightUnit is provided as 'M' then minimum value is 60 and maximum value is 310. If heightUnit is provided as 'I' then minimum value is 23.64 and maximum value is 122.04) | N |
heightUnit | string (Unit code of the value used in 'height' property, else defaults to the 'preferredUnit' property. . Supported values are either "I" or "M") | N |
password | string (Password of the user. If not specified, a random autogenerated password is set for the user. The password policy is: minimum 8 characters, at least one number is required, at least one upper case or lower case letter is required, at least one special character (!@#$%^&*) is required) | N |
firstName | string (First name of the user. Maximum characters allowed is 200) | N |
lastName | string (Last name of the user. Maximum characters allowed is 200) | N |
gender | string (Gender of the user. Supported values are "m" or "f" ) | N |
preferredLanguageCode | string (Language code of the user's preferred language. If not specified, the default value is "en". Supported values: [ en_US = US English, en = British English, fr = Français, de = Deutsch, nl = Nederlands, it = Italiano, es = Español, ja = 日本語, zh = 简体中文, pt = Português, ru = Pусский, tr = Türkçe, ca = Català, eu = Euskara, fi = Suomi, hu = Magyar, ko = 한국어, pl = Polski, zhl = 繁體中文, cy = Cymraeg, ar = العربية, he = עִברִית ] | N |
preferredUnit | string (User's preferred Unit code. If not specified, Default value "I" will be set. Supported values are either "I" or "M") | N |
enabled | boolean (User's enabled status. Supported values: true or false) | N |
Response
Success
A successful response returns a HTTP Status Code: 200 - OK. This indicates the user was successfully updated and their data is available in the body.
{
"data":{
"userAccessToken": "xyz123...",
"userAccessTokenExpiry": 1677689984915,
"emailAddress": "jane.doe@nowhere.com",
"xid": "JN10001",
"dob": "1990-01-30",
"weight": 150.80,
"weightUnit": "M",
"height": 170.50,
"heightUnit": "M",
"firstName": "Jane",
"lastName": "Doe",
"gender": "f",
"preferredLanguageCode": "en",
"preferredUnit": "M",
"facilityIdList": [20],
"age": 23,
"enabled": true,
"createdAt": "2023-02-16T18:48:37Z",
"updatedAt": "2023-02-16T18:48:37Z",
},
"meta": {
}
}
Parameter | Type |
---|---|
data | Object |
data.userAccessToken | string |
data.userAccessTokenExpiry | integer (Epoch time in millis indicating the expiry of the "userAccessToken" property) |
data.emailAddress | string |
data.xid | string |
data.dob | string (yyyy-MM-dd) |
data.weight | numeric |
data.weightUnit | string ("I"/"M") / NULL |
data.height | numeric / NULL |
data.heightUnit | string ("I"/"M") / NULL |
data.firstName | string / NULL |
data.lastName | string / NULL |
data.gender | string ("m"/"f") / NULL |
data.preferredLanguageCode | string |
data.preferredUnit | string ("I"/"M") |
data.facilityIdList | integer[] / NULL |
data.age | integer |
data.enabled | boolean |
data.createdAt | string (ISO 8601) |
data.updatedAt | string (ISO 8601) |
meta | Object / NULL |
Error
Errors returned from this endpoint can be one of the following
- HTTP Status Code: 401 (Authorization) Occurs when the Authorization header isn't set or an invalid access token is being used
- HTTP Status Code: 404 (Not Found) Occurs when the user could not be retrieved by the specified Header user-access-token
- HTTP Status Code: 500 (Fault) Occurs when a server error has occurred
401
{
"errorCode": "Authorization",
"errorMessage": "Not authorized for resource.",
"innerErrors": [
{
"errorCode": "ClientAccessTokenInvalid",
"errorTarget": {
"source": "Header",
"key": "Authorization",
}
}
]
}
404
{
"errorCode": "NotFound",
"errorMessage": "The requested resource was not found.",
"innerErrors": [
{
"errorCode": "UserNotFound",
"errorTarget": {
"source": "Header",
"key": "user-access-token",
}
}
]
}
500
{
"errorCode": "Fault",
"errorMessage": "A server error occurred.",
"innerErrors": []
}
Parameter | Type | Description |
---|---|---|
status | string | Indicates the status of the request - SUCCESSFUL or FAILURE |
data | object | null in case of error |
error.errorCode | number | numeric value corresponding to the error message |
error.errorMsg | string | error message string |
meta | object | meta object will be populated if any relevant metadata is available |
Delete User
Deletes a user corresponding to the provided user-access-token request header.
Endpoint
DELETE /api/v3/users
DELETE /api/v3/users HTTP/1.1
Host: {{BASE_URL}}
Accept: application/json
Authorization: Bearer eyAbc...
user-access-token: xyz123...
curl --location --request DELETE '{{BASE_URL}}/api/v3/users' \
--header 'Accept: application/json' \
--header 'Authorization: Bearer eyAbc...' \
--header 'user-access-token: xyz123...'
Headers
Header | Value |
---|---|
Accept | application/json |
Authorization | Bearer {oauth-access-token} |
user-access-token | {user-access-token} |
Response
Success
A successful response returns a HTTP Status Code: 204 - No Content. This indicates the user was successfully deleted.
Error
Errors returned from this endpoint can be one of the following
- HTTP Status Code: 401 (Authorization) Occurs when the Authorization header isn't set or an invalid access token is being used
- HTTP Status Code: 404 (Not Found) Occurs when the user could not be retrieved by the specified Header user-access-token
- HTTP Status Code: 500 (Fault) Occurs when a server error has occurred
401
{
"errorCode": "Authorization",
"errorMessage": "Not authorized for resource.",
"innerErrors": [
{
"errorCode": "ClientAccessTokenInvalid",
"errorTarget": {
"source": "Header",
"key": "Authorization",
}
}
]
}
404
{
"errorCode": "NotFound",
"errorMessage": "The requested resource was not found.",
"innerErrors": [
{
"errorCode": "UserNotFound",
"errorTarget": {
"source": "Header",
"key": "user-access-token",
}
}
]
}
500
{
"errorCode": "Fault",
"errorMessage": "A server error occurred.",
"innerErrors": []
}
Parameter | Type | Description |
---|---|---|
status | string | Indicates the status of the request - SUCCESSFUL or FAILURE |
data | object | null in case of error |
error.errorCode | number | numeric value corresponding to the error message |
error.errorMsg | string | error message string |
meta | object | meta object will be populated if any relevant metadata is available |
Get user profile image
Get the user profile image URLs.
Endpoint
GET /api/v3/users/photo
GET /api/v3/users/photo HTTP/1.1
Host: {{BASE_URL}}
user-access-token: xyz123
Authorization: Bearer eyAbc...
curl --location '{{BASE_URL}}/api/v3/users/photo' \
--header 'user-access-token: xyz123...'
--header 'Authorization: Bearer eyAbc...' \
Headers
Header | Value |
---|---|
Accept | application/json |
Content-Type | application/json |
Authorization | Bearer {oauth-access-token} |
Response
Success
A successful response returns a HTTP Status Code: 200
{
"status": "SUCCESSFUL",
"data": {
"profileImage": {
"image": "https://storage....",
"thumbnail": "https://storage...."
}
},
"error": null,
"meta": null
}
Parameter | Type |
---|---|
data | Object |
data.status | string |
data.profileImage | Object |
data.profileImage.image | string |
data.profileImage.thumbnail | string |
meta | Object / NULL |
Error
Errors returned from this endpoint can be one of the following
- HTTP Status Code: 401 (Authorization) Occurs when the Authorization header isn't set or an invalid access token is being used
- HTTP Status Code: 409 (Conflict) Occurs when the email address or xid is already in use by another account
- HTTP Status Code: 422 (Validation) Occurs when a property/properties doesn't meet the required type as documented here
- HTTP Status Code: 500 (Fault) Occurs when a server error has occurred
401
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 401,
"errorMsg": "Invalid Bearer token in Authorization header"
},
"meta": null
}
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 401,
"errorMsg": "user-access-token Header is missing"
},
"meta": null
}
500
{
"errorCode": "Fault",
"errorMessage": "A server error occurred.",
"innerErrors": []
}
Parameter | Type | Description |
---|---|---|
status | string | Indicates the status of the request - SUCCESSFUL or FAILURE |
data | object | null in case of error |
error.errorCode | number | numeric value corresponding to the error message |
error.errorMsg | string | error message string |
meta | object | meta object will be populated if any relevant metadata is available |
User Cardio Equipment Login
This section contains APIs which lets a user login remotely onto a connected cardio console.
- This API Supports login with Workout Preset Id (workoutPresetId)
- This API Supports login with workout name (workoutType)
- At a time, user can login and start either the workout preset or the workout type. The API cannot handle both requests simultaneously.
- This API allows user to set the auto logout period in seconds due to inactivity once logged into the console. The 'loginTimeout' field can be used with either workoutPresetId or workoutType or without any both of them.
User Cardio Login
This API lets a user login remotely into the cardio connected console with or without duration in seconds. The duration is used to auto log out the user in case of inactivity after successful cardio console login.
Endpoint
POST /api/v3/users/cardio-login
POST /api/v3/users/cardio-login HTTP/1.1
Host: {{BASE_URL}}
Accept: application/json
Authorization: Bearer eyAbc...
user-access-token: xyz123...
Content-Type: application/json
Content-Length: 399
{
"bodySerial": "XYZ123456",
"loginTimeout" : 8
}
curl --location '{{BASE_URL}}/api/v3/users/cardio-login' \
--header 'Accept: application/json' \
--header 'Authorization: Bearer eyAbc...' \
--header 'user-access-token: xyz123...' \
--header 'Content-Type: application/json' \
--data-raw '{
"bodySerial": "XYZ123456",
"loginTimeout" : 8
}'
Headers
Header | Value |
---|---|
Accept | application/json |
Content-Type | application/json |
Authorization | Bearer {oauth-access-token} |
user-access-token | {user-access-token} |
Body
Parameter | Type | Required |
---|---|---|
bodySerial | string (Body serial of the equipment) | Y |
loginTimeout | number (time in seconds for which user remains logged on the console due to inactivity) | N |
Response
Success
A successful response returns a HTTP Status Code: 201 - Created. This indicates the user was created successfully.
{
"status": "SUCCESSFUL",
"data": null,
"error": null,
"meta": null
}
Parameter | Type |
---|---|
data | Object |
data.status | string |
Error
Errors returned from this endpoint can be one of the following
- HTTP Status Code: 401 (Authorization) Occurs when the Authorization header isn't set or an invalid access token is being used
- HTTP Status Code: 422 (Validation) Occurs when a property/properties doesn't meet the required type as documented here
- HTTP Status Code: 500 (Fault) Occurs when a server error has occurred
401
{
"errorCode": "Authorization",
"errorMessage": "Not authorized for resource.",
"innerErrors": [
{
"errorCode": "ClientAccessTokenInvalid",
"errorTarget": {
"source": "Header",
"key": "Authorization",
}
}
]
}
422
{
"errorCode": "Validation",
"errorMessage": "The given data failed to pass validation.",
"innerErrors": [
{
"errorCode": "RequiredValidation",
"errorTarget": {
"source": "Body",
"key": "bodySerial",
},
"message":"The 'bodySerial' property is required."
},
{
"errorCode": "StringValidation",
"errorTarget": {
"source": "Body",
"key": "bodySerial",
},
"message":"The 'bodySerial' property must be a string."
},
]
}
500
{
"errorCode": "Fault",
"errorMessage": "A server error occurred.",
"innerErrors": []
}
Parameter | Type | Description |
---|---|---|
status | string | Indicates the status of the request - SUCCESSFUL or FAILURE |
data | object | null in case of error |
error.errorCode | number | numeric value corresponding to the error message |
error.errorMsg | string | error message string |
meta | object | meta object will be populated if any relevant metadata is available |
User Cardio Login with Workout Preset
This API lets a user login remotely into the cardio connected console and start the workout preset with or without duration in seconds. The duration is used to auto log out the user in case of inactivity after successful cardio console login.
Endpoint
POST /api/v3/users/cardio-login
POST /api/v3/users/sso-login HTTP/1.1
Host: {{BASE_URL}}
Accept: application/json
Authorization: Bearer eyAbc...
user-access-token: xyz123...
Content-Type: application/json
Content-Length: 399
{
"bodySerial": "XYZ123456",
"loginTimeout" : 8,
"workoutPresetId" : 32323
}
curl --location '{{BASE_URL}}/api/v3/users/sso-login' \
--header 'Accept: application/json' \
--header 'Authorization: Bearer eyAbc...' \
--header 'user-access-token: xyz123...' \
--header 'Content-Type: application/json' \
--data-raw '{
"bodySerial": "XYZ123456",
"loginTimeout" : 8,
"workoutPresetId" : 32323
}'
Headers
Header | Value |
---|---|
Accept | application/json |
Content-Type | application/json |
Authorization | Bearer {oauth-access-token} |
user-access-token | {user-access-token} |
Body
Parameter | Type | Required |
---|---|---|
bodySerial | string (Body serial of the equipment) | Y |
loginTimeout | number (time in seconds for which user remains logged on the console due to inactivity) | N |
workoutPresetId | number (workout preset id) | Y |
Response
Success
A successful response returns a HTTP Status Code: 201 - Created. This indicates the user was created successfully.
{
"status": "SUCCESSFUL",
"data": null,
"error": null,
"meta": null
}
Parameter | Type |
---|---|
data | Object |
data.status | string |
Error
Errors returned from this endpoint can be one of the following
- HTTP Status Code: 401 (Authorization) Occurs when the Authorization header isn't set or an invalid access token is being used
- HTTP Status Code: 422 (Validation) Occurs when a property/properties doesn't meet the required type as documented here
- HTTP Status Code: 500 (Fault) Occurs when a server error has occurred
401
{
"errorCode": "Authorization",
"errorMessage": "Not authorized for resource.",
"innerErrors": [
{
"errorCode": "ClientAccessTokenInvalid",
"errorTarget": {
"source": "Header",
"key": "Authorization",
}
}
]
}
422
{
"errorCode": "Validation",
"errorMessage": "The given data failed to pass validation.",
"innerErrors": [
{
"errorCode": "RequiredValidation",
"errorTarget": {
"source": "Body",
"key": "bodySerial",
},
"message":"The 'bodySerial' property is required."
},
{
"errorCode": "StringValidation",
"errorTarget": {
"source": "Body",
"key": "bodySerial",
},
"message":"The 'bodySerial' property must be a string."
},
]
}
500
{
"errorCode": "Fault",
"errorMessage": "A server error occurred.",
"innerErrors": []
}
Parameter | Type | Description |
---|---|---|
status | string | Indicates the status of the request - SUCCESSFUL or FAILURE |
data | object | null in case of error |
error.errorCode | number | numeric value corresponding to the error message |
error.errorMsg | string | error message string |
meta | object | meta object will be populated if any relevant metadata is available |
User Cardio Login with Workout Type
This API lets a user login remotely into the cardio connected console and start the workout type with or without duration in seconds. The duration is used to auto log out the user in case of inactivity after successful cardio console login.
Endpoint
POST /api/v3/users/cardio-login
POST /api/v3/users/sso-login HTTP/1.1
Host: {{BASE_URL}}
Accept: application/json
Authorization: Bearer eyAbc...
user-access-token: xyz123...
Content-Type: application/json
Content-Length: 399
{
"bodySerial": "XYZ123456",
"loginTimeout" : 8,
"workoutType": "PERFORMANCE_RUN"
}
curl --location '{{BASE_URL}}/api/v3/users/sso-login' \
--header 'Accept: application/json' \
--header 'Authorization: Bearer eyAbc...' \
--header 'user-access-token: xyz123...' \
--header 'Content-Type: application/json' \
--data-raw '{
"bodySerial": "XYZ123456",
"loginTimeout" : 8,
"workoutType": "PERFORMANCE_RUN"
}'
Headers
Header | Value |
---|---|
Accept | application/json |
Content-Type | application/json |
Authorization | Bearer {oauth-access-token} |
user-access-token | {user-access-token} |
Body
Parameter | Type | Required |
---|---|---|
bodySerial | string (Body serial of the equipment) | Y |
loginTimeout | number (time in seconds for which user remains logged on the console due to inactivity) | N |
workoutType | number (workout type. Supported values - PERFORMANCE_RUN) | Y |
Response
Success
A successful response returns a HTTP Status Code: 201 - Created. This indicates the user was created successfully.
{
"status": "SUCCESSFUL",
"data": null,
"error": null,
"meta": null
}
Parameter | Type |
---|---|
data | Object |
data.status | string |
Error
Errors returned from this endpoint can be one of the following
- HTTP Status Code: 401 (Authorization) Occurs when the Authorization header isn't set or an invalid access token is being used
- HTTP Status Code: 422 (Validation) Occurs when a property/properties doesn't meet the required type as documented here
- HTTP Status Code: 500 (Fault) Occurs when a server error has occurred
401
{
"errorCode": "Authorization",
"errorMessage": "Not authorized for resource.",
"innerErrors": [
{
"errorCode": "ClientAccessTokenInvalid",
"errorTarget": {
"source": "Header",
"key": "Authorization",
}
}
]
}
422
{
"errorCode": "Validation",
"errorMessage": "The given data failed to pass validation.",
"innerErrors": [
{
"errorCode": "RequiredValidation",
"errorTarget": {
"source": "Body",
"key": "bodySerial",
},
"message":"The 'bodySerial' property is required."
},
{
"errorCode": "StringValidation",
"errorTarget": {
"source": "Body",
"key": "bodySerial",
},
"message":"The 'bodySerial' property must be a string."
},
]
}
500
{
"errorCode": "Fault",
"errorMessage": "A server error occurred.",
"innerErrors": []
}
Parameter | Type | Description |
---|---|---|
status | string | Indicates the status of the request - SUCCESSFUL or FAILURE |
data | object | null in case of error |
error.errorCode | number | numeric value corresponding to the error message |
error.errorMsg | string | error message string |
meta | object | meta object will be populated if any relevant metadata is available |
User Cardio Speeds
This section contains APIs which manage user speed settings.
Get User Cardio Speeds
Retrieve the cardio speeds of a user using the user-access-token in the user-access-token header.
Endpoint
GET /api/v3/users/cardio-speeds
GET /api/v3/users/cardio-speeds HTTP/1.1
Host: {{BASE_URL}}
Accept: application/json
Authorization: Bearer eyAbc...
user-access-token: xyz123...
curl --location '{{BASE_URL}}/api/v3/users/cardio-speeds' \
--header 'Accept: application/json' \
--header 'Authorization: Bearer eyAbc...' \
--header 'user-access-token: xyz123...'
Headers
Header | Value |
---|---|
Accept | application/json |
Authorization | Bearer {oauth-access-token} |
user-access-token | {user-access-token} |
Response
Success
A successful response returns a HTTP Status Code: 200 - OK. This indicates the user speeds were successfully retrieved and their data is available in the body.
{
"data":{
"walkSpeed": 2,
"jogSpeed": 5,
"runSpeed": 8,
"speedUnit": "I",
},
"meta": {
}
}
Parameter | Type |
---|---|
data | Object |
data.walkSpeed | numeric |
data.jogSpeed | numeric |
data.runSpeed | numeric |
data.speedUnit | string ("I"/"M") / NULL |
meta | Object / NULL |
Error
Errors returned from this endpoint can be one of the following
- HTTP Status Code: 401 (Authorization) Occurs when the Authorization header isn't set or an invalid access token is being used
- HTTP Status Code: 404 (Not Found) Occurs when the user could not be retrieved by the specified Header user-access-token
- HTTP Status Code: 500 (Fault) Occurs when a server error has occurred
401
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 401,
"errorMsg": "user-access-token Header is missing"
},
"meta": null
}
404
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 4063,
"errorMsg": "Failed to retrieve user speeds of the user"
},
"meta": null
}
500
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 4048,
"errorMsg": "Failed to retrieve user speeds of the user"
},
"meta": null
}
Parameter | Type | Description |
---|---|---|
status | string | Indicates the status of the request - SUCCESSFUL or FAILURE |
data | object | null in case of error |
error.errorCode | number | numeric value corresponding to the error message |
error.errorMsg | string | error message string |
meta | object | meta object will be populated if any relevant metadata is available |
Update User Cardio Speeds
Set the cardio speeds for a user.
Endpoint
PUT /api/v3/users/user-speeds
PUT /api/v3/users/user-speeds HTTP/1.1
Host: {{BASE_URL}}
Accept: application/json
Authorization: Bearer eyAbc..
user-access-token: xyz123...
Content-Type: application/json
Content-Length: 399
{
"walkSpeed": 2,
"jogSpeed": 5,
"runSpeed": 8,
"speedUnit": "I"
}
curl --location '{{BASE_URL}}/api/v3/users/user-speeds' \
--header 'Accept: application/json' \
--header 'Authorization: Bearer eyAbc...' \
--header 'Content-Type: application/json' \
--header 'user-access-token: xyz123...'
--data-raw '
{
"walkSpeed": 2,
"jogSpeed": 5,
"runSpeed": 8,
"speedUnit": "I"
}'
Headers
Header | Value |
---|---|
Accept | application/json |
Content-Type | application/json |
Authorization | Bearer {oauth-access-token} |
user-access-token | {user-access-token} |
Body
Parameter | Type | Required |
---|---|---|
walkSpeed | numeric (If speedUnit is provided as 'M' then minimum value is 0.5 and maximum value is 23.0. If weightUnit is provided as 'I' then minimum value is 0.3 and maximum value is 14.0. Walkspeed is always less than jogSpeed and runSpeed values) | Y |
jogSpeed | numeric (If speedUnit is provided as 'M' then minimum value is 0.5 and maximum value is 23.0. If weightUnit is provided as 'I' then minimum value is 0.3 and maximum value is 14.0. jogSpeed is always greater than walkSpeed and less than runSpeed values) | Y |
runSpeed | numeric (If speedUnit is provided as 'M' then minimum value is 0.5 and maximum value is 23.0. If weightUnit is provided as 'I' then minimum value is 0.3 and maximum value is 14.0. runSpeed is always greater than jogSpeed and runSpeed values) | Y |
speedUnit | string (Unit code of the value used for speeds. Supported values are either "I" or "M") | Y |
Response
Success
A successful response returns a HTTP Status Code: 204 - Success. This indicates the user speeds were set successfully.
Error
Errors returned from this endpoint can be one of the following
- HTTP Status Code: 401 (Authorization) Occurs when the Authorization header isn't set or an invalid access token is being used
- HTTP Status Code: 422 (Validation) Occurs when a property/properties doesn't meet the required type as documented here
- HTTP Status Code: 500 (Fault) Occurs when a server error has occurred
401
{
"errorCode": "Authorization",
"errorMessage": "Not authorized for resource.",
"innerErrors": [
{
"errorCode": "ClientAccessTokenInvalid",
"errorTarget": {
"source": "Header",
"key": "Authorization",
}
}
]
}
422
{
"errorCode": "Validation",
"errorMessage": "The given data failed to pass validation.",
"innerErrors": [
{
"errorCode": "RequiredValidation",
"errorTarget": {
"source": "Body",
"key": "walkSpeed",
},
"message":"The 'walkSpeed' property is required."
},
{
"errorCode": "RequiredValidation",
"errorTarget": {
"source": "Body",
"key": "jogSpeed",
},
"message":"The 'jogSpeed' property is required."
},
{
"errorCode": "RequiredValidation",
"errorTarget": {
"source": "Body",
"key": "runSpeed",
},
"message":"The 'runSpeed' property is required."
},
{
"errorCode": "UnitValidation",
"errorTarget": {
"source": "Body",
"key": "speedUnit"
},
"message": "The 'speedUnit' property must be one of the following strings 'M' or 'I'."
},
{
"errorCode": "NumericValidation",
"errorTarget": {
"source": "Body",
"key": "walkSpeed"
},
"message": "The 'walkSpeed' property must be a numeric value with or without decimals."
},
{
"errorCode": "NumericValidation",
"errorTarget": {
"source": "Body",
"key": "jogSpeed"
},
"message": "The 'jogSpeed' property must be a numeric value with or without decimals."
},
{
"errorCode": "NumericValidation",
"errorTarget": {
"source": "Body",
"key": "runSpeed"
},
"message": "The 'runSpeed' property must be a numeric value with or without decimals."
},
{
"errorCode": "RangeValidation",
"errorTarget": {
"source": "Body",
"key": "walkSpeed, jogSpeed, runSpeed"
},
"message": "The 'walkSpeed, jogSpeed, runSpeed' properties must be within supported range."
},
]
}
500
{
"errorCode": "Fault",
"errorMessage": "A server error occurred.",
"innerErrors": []
}
Parameter | Type | Description |
---|---|---|
status | string | Indicates the status of the request - SUCCESSFUL or FAILURE |
data | object | null in case of error |
error.errorCode | number | numeric value corresponding to the error message |
error.errorMsg | string | error message string |
meta | object | meta object will be populated if any relevant metadata is available |
Delete User Cardio Speeds
Deletes a user's cardio speeds using the user-access-token in the user-access-token header.
Endpoint
DELETE /api/v3/users/cardio-speeds
DELETE /api/v3/users/cardio-speeds HTTP/1.1
Host: {{BASE_URL}}
Accept: application/json
Authorization: Bearer eyAbc...
user-access-token: xyz123...
curl --location --request DELETE '{{BASE_URL}}/api/v3/users/cardio-speeds' \
--header 'Accept: application/json' \
--header 'Authorization: Bearer eyAbc...' \
--header 'user-access-token: xyz123...'
Headers
Header | Value |
---|---|
Accept | application/json |
Authorization | Bearer {oauth-access-token} |
user-access-token | {user-access-token} |
Response
Success
A successful response returns a HTTP Status Code: 204 - No Content. This indicates the user's cardio speeds were successfully deleted.
Error
Errors returned from this endpoint can be one of the following
- HTTP Status Code: 401 (Authorization) Occurs when the Authorization header isn't set or an invalid access token is being used
- HTTP Status Code: 404 (Not Found) Occurs when the user could not be retrieved by the specified Header user-access-token
- HTTP Status Code: 500 (Fault) Occurs when a server error has occurred
401
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 401,
"errorMsg": "user-access-token Header is missing"
},
"meta": null
}
404
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 4048,
"errorMsg": "Cannot delete user cardio speeds"
},
"meta": null
}
500
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 4048,
"errorMsg": "Cannot delete user cardio speeds"
},
"meta": null
}
Parameter | Type | Description |
---|---|---|
status | string | Indicates the status of the request - SUCCESSFUL or FAILURE |
data | object | null in case of error |
error.errorCode | number | numeric value corresponding to the error message |
error.errorMsg | string | error message string |
meta | object | meta object will be populated if any relevant metadata is available |
Get User Cardio Quick Speeds
Retrieve the quick speeds of a user using the user-access-token in the user-access-token header.
Endpoint
GET /api/v3/users/cardio-quick-speeds
GET /api/v3/users/user-speeds HTTP/1.1
Host: {{BASE_URL}}
Accept: application/json
Authorization: Bearer eyAbc...
user-access-token: xyz123...
curl --location '{{BASE_URL}}/api/v3/users/user-speeds' \
--header 'Accept: application/json' \
--header 'Authorization: Bearer eyAbc...' \
--header 'user-access-token: xyz123...'
Headers
Header | Value |
---|---|
Accept | application/json |
Authorization | Bearer {oauth-access-token} |
user-access-token | {user-access-token} |
Response
Success
A successful response returns a HTTP Status Code: 200 - OK. This indicates the user speeds were successfully retrieved and their data is available in the body.
{
"data":{
"quickSpeeds" : "2,4,6,8,10",
"quickSpeedsUnit": "I"
},
"meta": {
}
}
Parameter | Type |
---|---|
data | Object |
data.quickSpeeds | string |
data.quickSpeedsUnit | string ("I"/"M") / NULL |
meta | Object / NULL |
Error
Errors returned from this endpoint can be one of the following
- HTTP Status Code: 401 (Authorization) Occurs when the Authorization header isn't set or an invalid access token is being used
- HTTP Status Code: 404 (Not Found) Occurs when the user could not be retrieved by the specified Header user-access-token
- HTTP Status Code: 500 (Fault) Occurs when a server error has occurred
401
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 401,
"errorMsg": "user-access-token Header is missing"
},
"meta": null
}
404
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 4063,
"errorMsg": "Failed to retrieve user speeds of the user"
},
"meta": null
}
500
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 4048,
"errorMsg": "Failed to retrieve user speeds of the user"
},
"meta": null
}
Parameter | Type | Description |
---|---|---|
status | string | Indicates the status of the request - SUCCESSFUL or FAILURE |
data | object | null in case of error |
error.errorCode | number | numeric value corresponding to the error message |
error.errorMsg | string | error message string |
meta | object | meta object will be populated if any relevant metadata is available |
Set User Cardio Quick Speeds
Set the quick speeds for a user.
Endpoint
PUT /api/v3/users/cardio-quick-speeds
PUT /api/v3/users/cardio-quick-speeds HTTP/1.1
Host: {{BASE_URL}}
Accept: application/json
Authorization: Bearer eyAbc...
Content-Type: application/json
Content-Length: 399
{
"quickSpeeds" : "2,4,6,8,10",
"quickSpeedsUnit": "I"
}
curl --location '{{BASE_URL}}/api/v3/users/cardio-quick-speeds' \
--header 'Accept: application/json' \
--header 'Authorization: Bearer eyAbc...' \
--header 'Content-Type: application/json' \
--data-raw '
{
"quickSpeeds" : "2,4,6,8,10",
"quickSpeedsUnit": "I"
}'
Headers
Header | Value |
---|---|
Accept | application/json |
Content-Type | application/json |
Authorization | Bearer {oauth-access-token} |
user-access-token | {user-access-token} |
Body
Parameter | Type | Required |
---|---|---|
quickSpeeds | string (Comma-separated string of five quick speed numeric values in ascending order. If quickSpeedsUnit is provided as 'M' then minimum value is 0.5 and maximum value is 23.0. If weightUnit is provided as 'I' then minimum value is 0.3 and maximum value is 14.0) | Y |
quickSpeedsUnit | string (Unit code of the value used for speeds. Supported values are either "I" or "M") | Y |
Response
Success
A successful response returns a HTTP Status Code: 204 - Success. This indicates the user quick speeds were set successfully.
Error
Errors returned from this endpoint can be one of the following
- HTTP Status Code: 401 (Authorization) Occurs when the Authorization header isn't set or an invalid access token is being used
- HTTP Status Code: 422 (Validation) Occurs when a property/properties doesn't meet the required type as documented here
- HTTP Status Code: 500 (Fault) Occurs when a server error has occurred
401
{
"errorCode": "Authorization",
"errorMessage": "Not authorized for resource.",
"innerErrors": [
{
"errorCode": "ClientAccessTokenInvalid",
"errorTarget": {
"source": "Header",
"key": "Authorization",
}
}
]
}
422
{
"errorCode": "Validation",
"errorMessage": "The given data failed to pass validation.",
"innerErrors": [
{
"errorCode": "RequiredValidation",
"errorTarget": {
"source": "Body",
"key": "quickSpeeds",
},
"message":"The 'quickSpeeds' property is required."
},
{
"errorCode": "RequiredValidation",
"errorTarget": {
"source": "Body",
"key": "quickSpeedsUnit",
},
"message":"The 'quickSpeedsUnit' property is required."
},
{
"errorCode": "UnitValidation",
"errorTarget": {
"source": "Body",
"key": "quickSpeedsUnit"
},
"message": "The 'quickSpeedsUnit' property must be one of the following strings 'M' or 'I'."
},
{
"errorCode": "StringValidation",
"errorTarget": {
"source": "Body",
"key": "quickSpeeds"
},
"message": "The 'quickSpeeds' property must be a string with five comma-separated numeric values"
},
{
"errorCode": "RangeValidation",
"errorTarget": {
"source": "Body",
"key": "quickSpeeds"
},
"message": "The 'quickSpeeds' property must be within supported range."
},
]
}
500
{
"errorCode": "Fault",
"errorMessage": "A server error occurred.",
"innerErrors": []
}
Parameter | Type | Description |
---|---|---|
status | string | Indicates the status of the request - SUCCESSFUL or FAILURE |
data | object | null in case of error |
error.errorCode | number | numeric value corresponding to the error message |
error.errorMsg | string | error message string |
meta | object | meta object will be populated if any relevant metadata is available |
Delete User Cardio Quick Speeds
Deletes a user's quick speeds using the user-access-token in the user-access-token header.
Endpoint
DELETE /api/v3/users/cardio-quick-speeds
DELETE /api/v3/users/cardio-quick-speeds HTTP/1.1
Host: {{BASE_URL}}
Accept: application/json
Authorization: Bearer eyAbc...
user-access-token: xyz123...
curl --location --request DELETE '{{BASE_URL}}/api/v3/users/cardio-quick-speeds' \
--header 'Accept: application/json' \
--header 'Authorization: Bearer eyAbc...' \
--header 'user-access-token: xyz123...'
Headers
Header | Value |
---|---|
Accept | application/json |
Authorization | Bearer {oauth-access-token} |
user-access-token | {user-access-token} |
Response
Success
A successful response returns a HTTP Status Code: 204 - No Content. This indicates the user's quick speeds were successfully deleted.
Error
Errors returned from this endpoint can be one of the following
- HTTP Status Code: 401 (Authorization) Occurs when the Authorization header isn't set or an invalid access token is being used
- HTTP Status Code: 404 (Not Found) Occurs when the user could not be retrieved by the specified Header user-access-token
- HTTP Status Code: 500 (Fault) Occurs when a server error has occurred
401
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 401,
"errorMsg": "user-access-token Header is missing"
},
"meta": null
}
404
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 4048,
"errorMsg": "Cannot delete user quick speeds"
},
"meta": null
}
500
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 4048,
"errorMsg": "Cannot delete user quick speeds"
},
"meta": null
}
Parameter | Type | Description |
---|---|---|
status | string | Indicates the status of the request - SUCCESSFUL or FAILURE |
data | object | null in case of error |
error.errorCode | number | numeric value corresponding to the error message |
error.errorMsg | string | error message string |
meta | object | meta object will be populated if any relevant metadata is available |
User RFID
This section contains the APIs corresponding to user RFID management
Assign User RFID
Assign an RFID to the user account corresponding to the user-access-token header.
Endpoint
POST /api/v3/users/rfid
POST /api/v3/users/rfid HTTP/1.1
Host: {{BASE_URL}}
Accept: application/json
Authorization: Bearer eyAbc...
user-access-token: xyz123...
{
"rfid" : "RFID1"
}
curl --location '{{BASE_URL}}/api/v3/users/rfid' \
--header 'Accept: application/json' \
--header 'Authorization: Bearer eyAbc...' \
--header 'user-access-token: xyz123...'
--data '{
"rfid" : "RFID1"
}'
Headers
Header | Value |
---|---|
Accept | application/json |
Authorization | Bearer {oauth-access-token} |
user-access-token | {user-access-token} |
Body
Parameter | Type | Required |
---|---|---|
rfid | string | Y |
Response
Success
A successful response returns a HTTP Status Code: 204 - OK. This indicates the rfids has been successfully assigned to the user
Error
Errors returned from this endpoint can be one of the following
- HTTP Status Code: 401 (Authorization) Occurs when the Authorization header isn't set or an invalid access token is being used
- HTTP Status Code: 404 (Not Found) Occurs when the user could not be retrieved by the specified Header user-access-token
- HTTP Status Code: 422 (Validation) Occurs when a property/properties doesn't meet the required type as documented here
- HTTP Status Code: 500 (Fault) Occurs when a server error has occurred
401
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 401,
"errorMsg": "user-access-token Header is missing"
},
"meta": null
}
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 401,
"errorMsg": "Invalid user-access-token header"
},
"meta": null
}
422
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 1007,
"errorMsg": "Missing parameter/s: Missing mandatory parameter - rfid"
},
"meta": null
}
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 1007,
"errorMsg": "rfid: (Maximum characters allowed is 50)"
},
"meta": null
}
500
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 500,
"errorMsg": "Error occurred while assigning RFID: "
},
"meta": null
}
Parameter | Type | Description |
---|---|---|
status | string | Indicates the status of the request - SUCCESSFUL or FAILURE |
data | object | null in case of error |
error.errorCode | number | numeric value corresponding to the error message |
error.errorMsg | string | error message string |
meta | object | meta object will be populated if any relevant metadata is available |
Get User Assigned RFID
Retrieve the list of RFIDs assigned to the user account corresponding to the user-access-token header.
Endpoint
GET /api/v3/users/rfid
GET /api/v3/users/rfid HTTP/1.1
Host: {{BASE_URL}}
Accept: application/json
Authorization: Bearer eyAbc...
user-access-token: xyz123...
curl --location '{{BASE_URL}}/api/v3/users/rfid' \
--header 'Accept: application/json' \
--header 'Authorization: Bearer eyAbc...' \
--header 'user-access-token: xyz123...'
Headers
Header | Value |
---|---|
Accept | application/json |
Authorization | Bearer {oauth-access-token} |
user-access-token | {user-access-token} |
Response
Success
A successful response returns a HTTP Status Code: 200 - OK. This indicates the rfids pertaining to the user were successfully retrieved and their data is available in the body.
{
"status": "SUCCESSFUL",
"data": {
"rfidList": [
"RFID1",
"RFID2",
"RFID3"
]
},
"error": null,
"meta": null
}
Parameter | Type |
---|---|
data | Object |
data.rfidList | Object[] |
meta | Object / NULL |
Error
Errors returned from this endpoint can be one of the following
- HTTP Status Code: 401 (Authorization) Occurs when the Authorization header isn't set or an invalid access token is being used
- HTTP Status Code: 404 (Not Found) Occurs when the user could not be retrieved by the specified Header user-access-token
- HTTP Status Code: 500 (Fault) Occurs when a server error has occurred
401
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 401,
"errorMsg": "user-access-token Header is missing"
},
"meta": null
}
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 401,
"errorMsg": "Invalid user-access-token header"
},
"meta": null
}
500
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 4048,
"errorMsg": "Error occurred while retrieving RFID of current user"
},
"meta": null
}
Parameter | Type | Description |
---|---|---|
status | string | Indicates the status of the request - SUCCESSFUL or FAILURE |
data | object | null in case of error |
error.errorCode | number | numeric value corresponding to the error message |
error.errorMsg | string | error message string |
meta | object | meta object will be populated if any relevant metadata is available |
Update User existing RFID
Update an existing RFID assigned to the user account corresponding to the user-access-token header.
Endpoint
PUT /api/v3/users/rfid/{old-rfid}
PUT /api/v3/users/rfid/{old-rfid} HTTP/1.1
Host: {{BASE_URL}}
Accept: application/json
Authorization: Bearer eyAbc...
user-access-token: xyz123...
{
"rfid" : "New-RFID"
}
curl --location '{{BASE_URL}}/api/v3/users/rfid/{old-rfid}' \
--header 'Accept: application/json' \
--header 'Authorization: Bearer eyAbc...' \
--header 'user-access-token: xyz123...'
--data '{
"rfid" : "New-RFID"
}'
Headers
Header | Value |
---|---|
Accept | application/json |
Authorization | Bearer {oauth-access-token} |
user-access-token | {user-access-token} |
Body
Parameter | Type | Required |
---|---|---|
rfid | string | Y |
Response
Success
A successful response returns a HTTP Status Code: 204 - OK. This indicates the rfids has been successfully updated
Error
Errors returned from this endpoint can be one of the following
- HTTP Status Code: 401 (Authorization) Occurs when the Authorization header isn't set or an invalid access token is being used
- HTTP Status Code: 404 (Not Found) Occurs when the user could not be retrieved by the specified Header user-access-token
- HTTP Status Code: 422 (Validation) Occurs when a property/properties doesn't meet the required type as documented here
- HTTP Status Code: 500 (Fault) Occurs when a server error has occurred
401
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 401,
"errorMsg": "user-access-token Header is missing"
},
"meta": null
}
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 401,
"errorMsg": "Invalid user-access-token header"
},
"meta": null
}
422
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 1007,
"errorMsg": "Missing parameter/s: Missing mandatory parameter - rfid (New RFID to be updated)"
},
"meta": null
}
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 1007,
"errorMsg": "Missing path parameter - rfid (Old RFID to be updated)"
},
"meta": null
}
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 1007,
"errorMsg": "rfid: (Maximum characters allowed is 50)"
},
"meta": null
}
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 1071,
"errorMsg": "Missing parameter/s: Missing mandatory parameter - rfid (New RFID to be updated)"
},
"meta": null
}
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 422,
"errorMsg": "Old RFID is not assigned to the current user"
},
"meta": null
}
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 422,
"errorMsg": "New RFID: is already assigned to the current user."
},
"meta": null
}
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 422,
"errorMsg": "New RFID: is already assigned to another user"
},
"meta": null
}
500
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 4048,
"errorMsg": "Error occurred while retrieving RFID of current user"
},
"meta": null
}
Parameter | Type | Description |
---|---|---|
status | string | Indicates the status of the request - SUCCESSFUL or FAILURE |
data | object | null in case of error |
error.errorCode | number | numeric value corresponding to the error message |
error.errorMsg | string | error message string |
meta | object | meta object will be populated if any relevant metadata is available |
Delete User RFID
Delete an RFID assigned to the user account corresponding to the user-access-token header.
Endpoint
DELETE /api/v3/users/rfid/{rfid}
DELETE /api/v3/users/rfid/{rfid} HTTP/1.1
Host: {{BASE_URL}}
Accept: application/json
Authorization: Bearer eyAbc...
user-access-token: xyz123...
curl --location '{{BASE_URL}}/api/v3/users/rfid/{rfid}' \
--header 'Accept: application/json' \
--header 'Authorization: Bearer eyAbc...' \
--header 'user-access-token: xyz123...'
Headers
Header | Value |
---|---|
Accept | application/json |
Authorization | Bearer {oauth-access-token} |
user-access-token | {user-access-token} |
Response
Success
A successful response returns a HTTP Status Code: 204 - OK. This indicates the rfid assigned to the user has been successfully deleted
Error
Errors returned from this endpoint can be one of the following
-
HTTP Status Code: 401 (Authorization) Occurs when the Authorization header isn't set or an invalid access token is being used
-
HTTP Status Code: 404 (Not Found) Occurs when the user could not be retrieved by the specified Header user-access-token
-
HTTP Status Code: 422 (Validation) Occurs when a property/properties doesn't meet the required type as documented here
-
HTTP Status Code: 500 (Fault) Occurs when a server error has occurred
401
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 401,
"errorMsg": "user-access-token Header is missing"
},
"meta": null
}
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 401,
"errorMsg": "Invalid user-access-token header"
},
"meta": null
}
404
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 1001,
"errorMsg": "User not found"
},
"meta": null
}
422
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 1007,
"errorMsg": "Missing parameters rfid"
},
"meta": null
}
500
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 500,
"errorMsg": "Error occurred while deleting RFID: "
},
"meta": null
}
Parameter | Type | Description |
---|---|---|
status | string | Indicates the status of the request - SUCCESSFUL or FAILURE |
data | object | null in case of error |
error.errorCode | number | numeric value corresponding to the error message |
error.errorMsg | string | error message string |
meta | object | meta object will be populated if any relevant metadata is available |
Strength Videos
This section contains the APIs corresponding to strength video links.
Get Strength Videos
Retrieves the Strength Videos by the given qrCodeURL
Endpoint
GET /api/v3/strength-videos
GET /api/v3/activities?qrCodeURL={{qrCodeURL}}&preferredUnit={{preferredUnit}}&userHeight={{userHeight}} HTTP/1.1
Host: {{BASE_URL}}
Authorization: Bearer eyAbc...
Accept: application/json
curl --location '{{BASE_URL}}/api/v3/activities?qrCodeURL={{qrCodeURL}}&preferredUnit={{preferredUnit}}&userHeight={{userHeight}}' \
--header 'Authorization: Bearer eyAbc...' \
--header 'Accept: application/json'
Headers
Header | Value |
---|---|
Accept | application/json |
Authorization | Bearer {oauth-access-token} |
Query Parameters
Parameter | Type | Required |
---|---|---|
qrCodeURL | string (QRcode URL of the Strength equipment) | Y |
userHeight | numeric (If preferredUnit is provided as 'M' then minimum value is 149 cm and maximum value is 195 cm. If preferredUnit is provided as 'I' then minimum value is 59 inch and maximum value is 77 inch) | N |
preferredUnit | string (User's preferred Unit code. If not specified, Default value "I" will be set. Supported values are either "I" or "M") | N |
Response
Success
A successful response returns a HTTP Status Code: 200 - OK. This indicates the strength videos for the qrCodeURL are retrieved successfully.
{
"status": "SUCCESSFUL",
"data": {
"strengthEquipment": {
"name": "fzpd",
"officialTitle": "Pulldown",
"video": [
"http://youtube.com/embed/X-_nZ3oTFW8"
],
"targetMuscles": "Biceps,Latissimus Dorsi",
"workoutName": [
"Pulldown"
],
"totalWeight": 259,
"weightStack": 145,
"qrCodeURL": "https://lfconnect.com/q?t=s&m=fzpd",
"preferredUnit": "M",
"userHeight": 60,
"label": "Seat Position",
"labelValue": "1"
}
},
"error": null,
"meta": null
}
Parameter | Type |
---|---|
data | Object |
data.name | string |
data.officialTitle | string |
data.video | string[] |
data.targetMuscles | string |
data.workoutName | string[] |
data.totalWeight | numeric / 0 |
data.weightStack | numeric / 0 |
data.qrCodeURL | string |
data.preferredUnit | string ("I"/"M") |
data.userHeight | numeric / 0 |
data.label | string |
data.labelValue | string |
Error
Errors returned from this endpoint can be one of the following
- HTTP Status Code: 401 (Authorization) _Occurs when the Authorization header isn't set
- HTTP Status Code: 422 (Validation) Occurs when a property/properties doesn't meet the required type as documented here
- HTTP Status Code: 500 (Fault) Occurs when a server error has occurred
422
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 400,
"errorMsg": "Missing Parameters: qrCodeURL"
},
"meta": null
}
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 400,
"errorMsg": "Missing Parameters: preferredUnit"
},
"meta": null
}
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 1213,
"errorMsg": "qrCodeURL is not valid: ds"
},
"meta": null
}
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 1075,
"errorMsg": "User height is not in the range for providing config information"
},
"meta": null
}
500
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 1074,
"errorMsg": "Cannot retrieve the Strength equipment video links"
},
"meta": null
}
Parameter | Type | Description |
---|---|---|
status | string | Indicates the status of the request - SUCCESSFUL or FAILURE |
data | object | null in case of error |
error.errorCode | number | numeric value corresponding to the error message |
error.errorMsg | string | error message string |
meta | object | meta object will be populated if any relevant metadata is available |
Equipment
This section contains the APIs corresponding to equipment data.
Get Equipment Info
Retrieves the Equipment details.
Endpoint
GET /api/v3/facilities/{facilityId}/equipments/{bodySerial}
GET /api/v3/facilities/{facilityId}/equipments/{bodySerial} HTTP/1.1
Host: {{BASE_URL}}
Accept: application/json
Authorization: Bearer eyAbc...
curl --location 'https://{{BASE_URL}}/api/v3/facilities/{facilityId}/equipments/{bodySerial}' \
--header 'Accept: application/json' \
--header 'Authorization: Bearer eyAbc...' \
Headers
Header | Value |
---|---|
Accept | application/json |
Authorization | Bearer {oauth-access-token} |
Response
Success
A successful response returns a HTTP Status Code: 200 - OK. This indicates the facility information was successfully retrieved and their data is available in the body.
{
"status": "SUCCESSFUL",
"data": {
"equipment": {
"id": 1,
"facilityId": 1,
"bodySerial": "XYZ123",
"bodySerialOnboarding": "XYZ123",
"consoleSerial": "ConsoleSerial1",
"baseSerial": "",
"motorSerial": "",
"modelId": 50,
"createdAt": "2017-07-28T06:05:18.293+00:00",
"updatedAt": "2021-11-22T16:15:16.882+00:00",
"tunerId": 218,
"name": null,
"displayName": "Equipment1",
"ipAddress": "00.00.00.00",
"bluetoothMacAddress": null,
"attachToFacilityDate": null,
"lastHeardAt": "2017-09-06T06:41:37.555+00:00",
"onlineStatus": false,
"activityId": 4,
"activityName": "CROSSTRAINER_DISCOVER_ENGAGE_DEVICE_TYPE",
"pushServerId": 1,
"softwareVersion": "0201003"
}
},
"error": null,
"meta": null
}
Parameter | Type |
---|---|
data | Object |
data.equipment | Object |
data.equipment.id | numeric |
data.equipment.facilityId | numeric |
data.equipment.bodySerial | string |
data.equipment.bodySerialOnBoarding | string |
data.equipment.consoleSerial | string |
data.equipment.baseSerial | string |
data.equipment.motorSerial | string |
data.equipment.modelId | numeric |
data.equipment.createdAt | string |
data.equipment.updatedAt | string |
data.equipment.tunerId | numeric |
data.equipment.name | string |
data.equipment.displayName | string |
data.equipment.ipAddress | string |
data.equipment.bluetoothMacAddress | string |
data.equipment.attachToFacilityDate | string |
data.equipment.lastHeardAt | string |
data.equipment.onlineStatus | boolean |
data.equipment.activityId | numeric |
data.equipment.activityName | string |
data.equipment.pushServerId | numeric |
data.equipment.softwareVersion | string |
Error
Errors returned from this endpoint can be one of the following
- HTTP Status Code: 401 (Authorization) Occurs when the Authorization header isn't set
- HTTP Status Code: 404 (Not Found) Occurs when the equipment is not found
- HTTP Status Code: 500 (Fault) Occurs when a server error has occurred
401
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 401,
"errorMsg": "UnAuthorized"
},
"meta": null
}
404
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 404,
"errorMsg": "Not found: - bodySerial: XYZ123"
},
"meta": null
}
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 3048,
"errorMsg": "Equipment doesn't belong to the facility - bodySerial: XYZ123"
},
"meta": null
}
422
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 2001,
"errorMsg": "Missing parameter/s: facilityId path parameter is required"
},
"meta": null
}
422
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 2001,
"errorMsg": "Missing parameter/s: bodySerial path parameter is required"
},
"meta": null
}
500
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 2005,
"errorMsg": "Error retrieving equipemnt details. bodySerial: XYZ123"
},
"meta": null
}
Parameter | Type | Description |
---|---|---|
status | string | Indicates the status of the request - SUCCESSFUL or FAILURE |
data | object | null in case of error |
error.errorCode | number | numeric value corresponding to the error message |
error.errorMsg | string | error message string |
meta | object | meta object will be populated if any relevant metadata is available |
Get Equipment Usage Statistics
Retrieves the Equipment usage statistics.
Endpoint
GET /api/v3/facilities/{facilityId}/equipments/{bodySerial}/stats
GET /api/v3/facilities/{facilityId}/equipments/{bodySerial}/stats HTTP/1.1
Host: {{BASE_URL}}
Accept: application/json
Authorization: Bearer eyAbc...
curl --location 'https://{{BASE_URL}}/api/v3/facilities/{facilityId}/equipments/{bodySerial}/stats' \
--header 'Accept: application/json' \
--header 'Authorization: Bearer eyAbc...' \
Headers
Header | Value |
---|---|
Accept | application/json |
Authorization | Bearer {oauth-access-token} |
Response
Success
A successful response returns a HTTP Status Code: 200 - OK. This indicates the facility information was successfully retrieved and their data is available in the body.
{
"status": "SUCCESSFUL",
"data": {
"equipment": {
"bodySerial": "XYZ123",
"stats": {
"totalDistance": 190945,
"totalTime": 9709,
"totalWorkoutCount": 335,
"totalBeltTime": 9694,
"totalBeltDistance": 190720,
"totalLiftTime": 0
}
}
},
"error": null,
"meta": null
}
Parameter | Type |
---|---|
data | Object |
data.equipment | Object |
data.equipment.bodySerial | string |
data.equipment.stats | Object |
data.equipment.stats.totalDistance | numeric |
data.equipment.stats.totalTime | numeric |
data.equipment.stats.totalWorkoutCount | numeric |
data.equipment.stats.totalBeltTime | numeric |
data.equipment.stats.totalBeltDistance | numeric |
data.equipment.stats.totalLiftTime | numeric |
Error
Errors returned from this endpoint can be one of the following
- HTTP Status Code: 401 (Authorization) Occurs when the Authorization header isn't set
- HTTP Status Code: 404 (Not Found) Occurs when the equipment is not found
- HTTP Status Code: 500 (Fault) Occurs when a server error has occurred
401
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 401,
"errorMsg": "UnAuthorized"
},
"meta": null
}
404
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 404,
"errorMsg": "Not found: - bodySerial: XYZ123"
},
"meta": null
}
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 3048,
"errorMsg": "Equipment doesn't belong to the facility - bodySerial: XYZ123"
},
"meta": null
}
422
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 2001,
"errorMsg": "Missing parameter/s: facilityId"
},
"meta": null
}
422
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 2001,
"errorMsg": "Missing parameter/s: equipment serial"
},
"meta": null
}
500
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 2005,
"errorMsg": "Error while fetching equipment stats bodySerial: XYZ123"
},
"meta": null
}
Parameter | Type | Description |
---|---|---|
status | string | Indicates the status of the request - SUCCESSFUL or FAILURE |
data | object | null in case of error |
error.errorCode | number | numeric value corresponding to the error message |
error.errorMsg | string | error message string |
meta | object | meta object will be populated if any relevant metadata is available |
Get Equipment Online Status
Retrieves the Equipment online status at the given timestamp.
Endpoint
GET /api/v3/facilities/{facilityId}/equipments/{bodySerial}/online-at/{timestamp}
GET /api/v3/facilities/{facilityId}/equipments/{bodySerial}/online-at/{timestamp} HTTP/1.1
Host: {{BASE_URL}}
Accept: application/json
Authorization: Bearer eyAbc...
curl --location 'https://{{BASE_URL}}/api/v3/facilities/{facilityId}/equipments/{bodySerial}/online-at/{timestamp}' \
--header 'Accept: application/json' \
--header 'Authorization: Bearer eyAbc...' \
Headers
Header | Value |
---|---|
Accept | application/json |
Authorization | Bearer {oauth-access-token} |
Response
Success
A successful response returns a HTTP Status Code: 200 - OK. This indicates the facility information was successfully retrieved and their data is available in the body.
{
"status": "SUCCESSFUL",
"data": {
"equipment": {
"bodySerial": "XYZ123",
"online": true
}
},
"error": null,
"meta": null
}
Parameter | Type |
---|---|
data | Object |
data.equipment | Object |
data.equipment.bodySerial | string |
data.equipment.online | boolean |
Error
Errors returned from this endpoint can be one of the following
- HTTP Status Code: 401 (Authorization) Occurs when the Authorization header isn't set
- HTTP Status Code: 404 (Not Found) Occurs when the equipment is not found
- HTTP Status Code: 500 (Fault) Occurs when a server error has occurred
401
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 401,
"errorMsg": "UnAuthorized"
},
"meta": null
}
404
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 404,
"errorMsg": "Not found: - bodySerial: XYZ123"
},
"meta": null
}
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 3048,
"errorMsg": "Equipment doesn't belong to the facility - bodySerial: XYZ123"
},
"meta": null
}
422
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 2001,
"errorMsg": "Missing parameter/s: facilityId"
},
"meta": null
}
422
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 2001,
"errorMsg": "Missing parameter/s: equipment serial"
},
"meta": null
}
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 3042,
"errorMsg": "Not a valid Timestamp: timestamp not in correct format: 2024-04-29"
},
"meta": null
}
500
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 3043,
"errorMsg": "Asset Online status not found"
},
"meta": null
}
Parameter | Type | Description |
---|---|---|
status | string | Indicates the status of the request - SUCCESSFUL or FAILURE |
data | object | null in case of error |
error.errorCode | number | numeric value corresponding to the error message |
error.errorMsg | string | error message string |
meta | object | meta object will be populated if any relevant metadata is available |
Load Web Page on Cardio Equipment
View a web page on a compatible cardio console with an max optional duration in seconds not to exceed 180 seconds.
Endpoint
POST /api/v3/equipments/{bodySerial}/load-web-page
GET /api/v3/equipments/{bodySerial}/load-web-page HTTP/1.1
Host: {{BASE_URL}}
Accept: application/json
Authorization: Bearer eyAbc...
curl --location 'https://{{BASE_URL}}/api/v3/equipments/{bodySerial}/load-web-page' \
--header 'Authorization: eyAbc...' \
--data '{
"url": "https://www.google.com",
"duration": 5
}'
Headers
Header | Value |
---|---|
Authorization | Bearer {oauth-access-token} |
Response
Success
A successful response returns a HTTP Status Code: 200 - OK. This indicates the facility information was successfully retrieved and their data is available in the body.
{
"status": "SUCCESSFUL",
"data": {
"duration": 5,
"bodySerial": "SMT-UKMDNO",
"url": "https://www.google.com"
},
"error": null,
"meta": null
}
Parameter | Type |
---|---|
data | Object |
data.bodySerial | string |
data.url | string |
data.duration | number |
Error
Errors returned from this endpoint can be one of the following
- HTTP Status Code: 401 (Authorization) Occurs when the Authorization header isn't set
- HTTP Status Code: 404 (Not Found) Occurs when the equipment is not found
- HTTP Status Code: 422 (Not Found) Occurs during validation errors
- HTTP Status Code: 500 (Fault) Occurs when a server error has occurred
401
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 401,
"errorMsg": "UnAuthorized"
},
"meta": null
}
404
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 3001,
"errorMsg": "Missing parameter/s: url"
},
"meta": null
}
422
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 3044,
"errorMsg": "Invalid duration - duration: -5"
},
"meta": null
}
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 3041,
"errorMsg": "Not a valid URL"
},
"meta": null
}
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 3049,
"errorMsg": "Max duration (180) exceeded - duration: 589599"
},
"meta": null
}
500
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 3043,
"errorMsg": "Asset Online status not found"
},
"meta": null
}
Parameter | Type | Description |
---|---|---|
status | string | Indicates the status of the request - SUCCESSFUL or FAILURE |
data | object | null in case of error |
error | object | Includes the error details |
error.errorCode | number | numeric value corresponding to the error message |
error.errorMsg | string | error message string |
meta | object | meta object will be populated if any relevant metadata is available |
Facility
This section contains the APIs corresponding to facility data.
Get Facility info
Retrieves the facility information for given Facility Id
Endpoint
GET /api/v3/facilities/{facilityId}
GET /api/v3/facilities/{facilityId} HTTP/1.1
Host: {{BASE_URL}}
Accept: application/json
Authorization: Bearer eyAbc...
curl --location 'https://{{BASE_URL}}/api/v3/facilities/{facilityId}' \
--header 'Accept: application/json' \
--header 'Authorization: Bearer eyAbc...' \
Headers
Header | Value |
---|---|
Accept | application/json |
Authorization | Bearer {oauth-access-token} |
Response
Success
A successful response returns a HTTP Status Code: 200 - OK. This indicates the facility information was successfully retrieved and their data is available in the body.
{
"status": "SUCCESSFUL",
"data": {
"country": "US",
"facilityId": 1,
"address": "Street No.1",
"city": "Chicago",
"phone": "123-123-1234",
"timezone": "America/Chicago",
"postalCode": "600007",
"ipAddress": "10.10.10.10",
"facilityName": "Facility 1",
"state": "IL"
},
"error": null,
"meta": null
}
Parameter | Type |
---|---|
data | Object |
data.country | string |
data.facilityId | numeric |
data.address | string |
data.city | string |
data.phone | string |
data.timezone | string |
data.postalCode | string |
data.ipAddress | string |
data.facilityName | string |
data.state | string |
Error
Errors returned from this endpoint can be one of the following
- HTTP Status Code: 401 (Authorization) Occurs when the Authorization header isn't set
- HTTP Status Code: 422 (Not Found) Occurs when the facility could not be found
401
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 401,
"errorMsg": "Invalid Bearer token in Authorization header"
},
"meta": null
}
422
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 2005,
"errorMsg": "Facility not found Invalid facilityId"
},
"meta": null
}
Parameter | Type | Description |
---|---|---|
status | string | Indicates the status of the request - SUCCESSFUL or FAILURE |
data | object | null in case of error |
error.errorCode | number | numeric value corresponding to the error message |
error.errorMsg | string | error message string |
meta | object | meta object will be populated if any relevant metadata is available |
Get Facility Equipments
Retrieves the list of equipments with details for the given facility id.
Endpoint
GET /api/v3/facilities/{facilityId}/equipments
GET /api/v3/facilities/{facilityId}/equipments HTTP/1.1
Host: {{BASE_URL}}
Accept: application/json
Authorization: Bearer eyAbc...
curl --location 'https://{{BASE_URL}}/api/v3/facilities/{facilityId}/equipments' \
--header 'Accept: application/json' \
--header 'Authorization: Bearer eyAbc...' \
Headers
Header | Value |
---|---|
Accept | application/json |
Authorization | Bearer {oauth-access-token} |
Response
Success
A successful response returns a HTTP Status Code: 200 - OK. This indicates the facility equipment list was successfully retrieved and their data is available in the body.
{
"status": "SUCCESSFUL",
"data": [
{
"bodySerial": "BODYSERIAL1",
"modelId": 68,
"name": "EQUIPMENTNAME1",
"activityId": 1,
"activityName": "ACTIVITYNAME1",
"facilityId": 1,
"onlineStatus": true,
"secondaryEquipmentSerial": "SECONDARYSERIAL1",
"baseSerialNumber": "BASESERIAL1",
"consoleSerial": "CONSOLESERIAL1",
"softwareVersion": "123"
},
{
"bodySerial": "BODYSERIAL2",
"modelId": 68,
"name": "EQUIPMENTNAME2",
"activityId": 1,
"activityName": "ACTIVITYNAME2",
"facilityId": 1,
"onlineStatus": true,
"secondaryEquipmentSerial": "SECONDARYSERIAL2",
"baseSerialNumber": "BASESERIAL2",
"consoleSerial": "CONSOLESERIAL2",
"softwareVersion": "123"
}
],
"error": null,
"meta": null
}
Parameter | Type |
---|---|
data | Object[] |
data.bodySerial | string ( Format: 'SMT-902170' OR '00:11:22:33:44:55' OR '3bd07ceb-e842-4a14-b6c5-ff3270e195c') |
data.modelId | numeric |
data.name | string |
data.activityId | numeric ( Type of Equipment - 1/2/3 ... ) |
data.activityName | string ( Name of the Type of Equipment - Treadmill/ Cross-Trainer / Upright Bike ...) |
data.facilityId | numeric |
data.onlineStatus | boolean ( true/ false) |
data.secondaryEquipmentSerial | string ( Format: 'SMT-902170' - Only available when bodySerial is of the format - '00:11:22:33:44:55'/ '3bd07ceb-e842-4a14-b6c5-ff3270e195c') |
data.baseSerialNumber | string ( Serial number of the Base when relevant) |
data.consoleSerial | string (Serial number of the console when relevant) |
data.softwareVersion | string |
Error
Errors returned from this endpoint can be one of the following
- HTTP Status Code: 401 (Authorization) Occurs when the Authorization header isn't set
- HTTP Status Code: 404 (Not Found) Occurs when the facility could not be found
- HTTP Status Code: 500 (Fault) Occurs when a server error has occurred
401
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 401,
"errorMsg": "Invalid Bearer token in Authorization header"
},
"meta": null
}
422
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 2005,
"errorMsg": "Facility not found Invalid facilityId "
},
"meta": null
}
Parameter | Type | Description |
---|---|---|
status | string | Indicates the status of the request - SUCCESSFUL or FAILURE |
data | object | null in case of error |
error.errorCode | number | numeric value corresponding to the error message |
error.errorMsg | string | error message string |
meta | object | meta object will be populated if any relevant metadata is available |
Initiate Facility SSO
Initiate SSO Login for a facility. Please save the ssoKey returned upon a succesful request. This SSOKey is required for subsequent SSO related API calls for the facility.
Endpoint
POST /api/v3/facilities/{facilityId}/sso
POST /api/v3/facilities/{facilityId}/sso HTTP/1.1
Host: {{BASE_URL}}
Accept: application/json
Authorization: Bearer eyAbc...
{
"facilityId": {facilityId}
}
curl --location '{{BASE_URL}}/api/v3/facilities/{facilityId}/sso' \
--header 'Accept: application/json' \
--header 'Authorization: Bearer eyAbc...' \
--data-raw '{
"facilityId": 20892389
}'
Headers
Header | Value |
---|---|
Accept | application/json |
Content-Type | application/json |
Authorization | Bearer {oauth-access-token} |
Body
Parameter | Type | Required |
---|---|---|
facilityId | integer (Id of the Facility) | Y |
Response
Success
A successful response returns a HTTP Status Code: 200 - OK. This indicates the facility sso information was successfully retrieved and the data is available in the body.
{
"status": "SUCCESSFUL",
"data": {
"facilitySSO": {
"facilityId": 20892389,
"ssoEnabled": false,
"ssoKey": "SSOKeyAssignedToTheFacility",
"webURL": null
}
},
"error": null,
"meta": null
}
Parameter | Type |
---|---|
data | Object |
data.facilitySSO.facilityId | integer |
data.facilitySSO.ssoKey | string |
data.facilitySSO.ssoEnabled | boolean |
data.facilitySSO.webURL | string |
meta | Object / NULL |
Error
Errors returned from this endpoint can be one of the following
- HTTP Status Code: 400 (Not Found) Occurs when facility is already SSO Enabled
- HTTP Status Code: 401 (Authorization) Occurs when the Authorization header isn't set or an invalid Authorization header is being used
- HTTP Status Code: 404 (Not Found) Occurs when facility Id sent is not correct
- HTTP Status Code: 500 (Fault) Occurs when a server error has occurred
400
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 2027,
"errorMsg": "Facility SSO cannot be initialized - facilityId: {facilityId}"
},
"meta": null
}
404
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 2005,
"errorMsg": "Facility not found - facilityId: {facilityId}"
},
"meta": null
}
Parameter | Type | Description |
---|---|---|
status | string | Indicates the status of the request - SUCCESSFUL or FAILURE |
data | object | null in case of error |
error.errorCode | number | numeric value corresponding to the error message |
error.errorMsg | string | error message string |
meta | object | meta object will be populated if any relevant metadata is available |
Get Facility SSO Information
Retrieves the SSO information of a facility.
Endpoint
GET /api/v3/facilities/{facilityId}/sso
GET /api/v3/facilities/{facilityId}/sso HTTP/1.1
Host: {{BASE_URL}}
Accept: application/json
Authorization: Bearer eyAbc...
curl --location '{{BASE_URL}}/api/v3/facilities/{facilityId}/sso' \
--header 'Accept: application/json' \
--header 'Authorization: Bearer eyAbc...' \
Headers
Header | Value |
---|---|
Accept | application/json |
Authorization | Bearer {oauth-access-token} |
Response
Success
A successful response returns a HTTP Status Code: 200 - OK. This indicates the facility sso information was successfully retrieved and the data is available in the body.
{
"status": "SUCCESSFUL",
"data": {
"facilitySSO": {
"facilityId": 20892389,
"ssoEnabled": true,
"ssoKey": "XXXX-MaskedSSOKeyAssignedToTheFacility",
"webURL": "https://test.com/login.html"
}
},
"error": null,
"meta": null
}
Parameter | Type |
---|---|
data | Object |
data.facilitySSO.facilityId | integer |
data.facilitySSO.ssoKey | string |
data.facilitySSO.ssoEnabled | boolean |
data.facilitySSO.webURL | string |
meta | Object / NULL |
Error
Errors returned from this endpoint can be one of the following
- HTTP Status Code: 401 (Authorization) Occurs when the Authorization header isn't set or an invalid Authorization header is being used
- HTTP Status Code: 404 (Not Found) Occurs when SSO is not initiated for the facility
- HTTP Status Code: 500 (Fault) Occurs when a server error has occurred
404
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 2028,
"errorMsg": "Facility SSO not found - facilityId: {facilityId}"
},
"meta": null
}
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 2005,
"errorMsg": "Facility not found - facilityId: {facilityId}"
},
"meta": null
}
Parameter | Type | Description |
---|---|---|
status | string | Indicates the status of the request - SUCCESSFUL or FAILURE |
data | object | null in case of error |
error.errorCode | number | numeric value corresponding to the error message |
error.errorMsg | string | error message string |
meta | object | meta object will be populated if any relevant metadata is available |
Update Facility SSO
Updates facility SSO information using the ssoKey. This API can enable or disable the facility SSO and can also update the login webURL.
Endpoint
PUT /api/v3/facilities/{facilityId}/sso
PUT /api/v3/facilities/{facilityId}/sso HTTP/1.1
Host: {{BASE_URL}}
Accept: application/json
Authorization: Bearer eyAbc...
{
"webURL": "https://test.com/login.html?bodySerial123",
"ssoKey" : "SSOKeyAssignedToTheFacility",
"ssoEnabled" : true
}
curl --location '{{BASE_URL}}/api/v3/facilities/{facilityId}/sso' \
--header 'Accept: application/json' \
--header 'Authorization: Bearer eyAbc...' \
--data-raw '{
"webURL": "https://test.com/login.html"
"ssoKey" : "SSOKeyAssignedToTheFacility",
"ssoEnabled" : true
}'
Headers
Header | Value |
---|---|
Accept | application/json |
Content-Type | application/json |
Authorization | Bearer {oauth-access-token} |
Body
Parameter | Type | Required |
---|---|---|
webURL | string (URL to the page the user has to be redirected to for Single Sign on. Required if SSO Enabled is set to true for the facility) | Y |
ssoKey | string (SSO Key assigned to the facility and returned in the SSO Initiation API response) | Y |
ssoEnabled | boolean (true/false) | Y |
Response
Success
A successful response returns a HTTP Status Code: 204 - No content.
Error
Errors returned from this endpoint can be one of the following
- HTTP Status Code: 400 (Bad Request) Occurs when all the required parameters are not sent
- HTTP Status Code: 401 (Authorization) Occurs when the Authorization header isn't set or an invalid Authorization header is being used
- HTTP Status Code: 404 (Not Found) Occurs when facility Id sent is not correct
- HTTP Status Code: 422 (Conflict) Occurs when SSO key sent is not valid for the facility
- HTTP Status Code: 500 (Fault) Occurs when a server error has occurred
400
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 2001,
"errorMsg": "Missing parameter/s: - ssoKey "
},
"meta": null
}
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 2001,
"errorMsg": "Missing parameter/s: - ssoEnabled: "
},
"meta": null
}
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 2001,
"errorMsg": "Missing parameter/s: - webURL"
},
"meta": null
}
404
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 2005,
"errorMsg": "Facility not found - facilityId: {facilityId}"
},
"meta": null
}
422
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 2018,
"errorMsg": "Facility SSO Key check failed - facilityId: {facilityId}"
},
"meta": null
}
Parameter | Type | Description |
---|---|---|
status | string | Indicates the status of the request - SUCCESSFUL or FAILURE |
data | object | null in case of error |
error.errorCode | number | numeric value corresponding to the error message |
error.errorMsg | string | error message string |
meta | object | meta object will be populated if any relevant metadata is available |
Delete Facility SSO
Delete facility SSO information using the ssoKey.
Endpoint
DELETE /api/v3/facilities/{facilityId}/sso
DELETE /api/v3/facilities/10/sso HTTP/1.1
Host: {{BASE_URL}}
Authorization: Bearer eyAbc...
Content-Type: application/json
{
"ssoKey": "SSOKeyAssignedToTheFacility"
}
curl --location --request DELETE '{{BASE_URL}}/api/v3/facilities/10/sso' \
--header 'Authorization: Bearer eyAbc...' \
--header 'Content-Type: application/json' \
--data '{
"ssoKey": "SSOKeyAssignedToTheFacility"
}'
Headers
Header | Value |
---|---|
Accept | application/json |
Content-Type | application/json |
Authorization | Bearer {oauth-access-token} |
Body
Parameter | Type | Required |
---|---|---|
ssoKey | string (SSO Key assigned to the facility and returned in the SSO Initiation API response) | Y |
Response
Success
A successful response returns a HTTP Status Code: 204 - No content.
Error
Errors returned from this endpoint can be one of the following
- HTTP Status Code: 400 (Bad Request) Occurs when all the required parameters are not sent
- HTTP Status Code: 401 (Authorization) Occurs when the Authorization header isn't set or an invalid Authorization header is being used
- HTTP Status Code: 404 (Not Found) Occurs when facility Id sent is not correct
- HTTP Status Code: 422 (Conflict) Occurs when SSO key sent is not valid for the facility
- HTTP Status Code: 500 (Fault) Occurs when a server error has occurred
400
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 2001,
"errorMsg": "Missing parameter/s: - ssoKey "
},
"meta": null
}
404
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 2005,
"errorMsg": "Facility not found - facilityId: {facilityId}"
},
"meta": null
}
422
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 2018,
"errorMsg": "Facility SSO Key check failed - facilityId: {facilityId}"
},
"meta": null
}
Parameter | Type | Description |
---|---|---|
status | string | Indicates the status of the request - SUCCESSFUL or FAILURE |
data | object | null in case of error |
error.errorCode | number | numeric value corresponding to the error message |
error.errorMsg | string | error message string |
meta | object | meta object will be populated if any relevant metadata is available |
QR
The QR API can be used for multiple use cases. Please refer to this documentation for detailed information on the different use cases supported by this API - https://haloapisupport.zendesk.com/hc/en-us/articles/360053705793
QR API - User Cardio Login
The API is used to log in a user any Life Fitness cardio equipment
Endpoint
POST /api/v3/qr
POST /api/v3/qr HTTP/1.1
Host: {{BASE_URL}}
Accept: application/json
Authorization: Bearer eyAbc...
user-access-token: xyz123...
Content-Type: application/json
Content-Length: 399
{
"qrCodeURL": "https://lfconnect.com/q?t=c&l=XYZ123456",
"workoutId": 30367
}
curl --location '{{BASE_URL}}/api/v3/qr' \
--header 'Accept: application/json' \
--header 'Authorization: Bearer eyAbc...' \
--header 'user-access-token: xyz123...'
--header 'Content-Type: application/json' \
--data-raw '{
"qrCodeURL": "https://lfconnect.com/q?t=c&l=XYZ123456",
"workoutId": 30367
}'
Headers
Header | Value |
---|---|
Accept | application/json |
Content-Type | application/json |
Authorization | Bearer {oauth-access-token} |
user-access-token | {user-access-token} |
Body
Parameter | Type | Required |
---|---|---|
qrcodeURL | string | Y |
workoutId | numeric | N |
QRcode formats possible for this use case:
https://lfconnect.com/q?t=c&l={{bodySerial}}
https://lfconnect.com/q?t=c&s={{qrcode}}
https://lfconnect.com/q?t=c&l={{bodySerial}}&x=821&c=0&a=001C7BD763CA
Response
Success
A successful response returns a HTTP Status Code: 200 - Success. This indicates the workout result is succesffuly saved to the user.
{
"status": "SUCCESSFUL",
"data": {
"type": "cardioLogin"
},
"error": null,
"meta": null
}
Parameter | Type |
---|---|
data | Object |
data.type | string |
meta | Object / NULL |
Error
Errors returned from this endpoint can be one of the following
- HTTP Status Code: 401 (Authorization) Occurs when the Authorization header isn't set or an invalid access token is being used
- HTTP Status Code: 422 (Validation) Occurs when a property/properties doesn't meet the required type as documented here
- HTTP Status Code: 500 (Fault) Occurs when a server error has occurred
401
{
"error": "invalid_token",
"message": "Authorization failed : Missing or Invalid Bearer Token"
}
401
{
"errorCode": 401,
"errorMessage": "`user-access-token` header is either missing or invalid"
}
404
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 3003,
"errorMsg": "Asset not found - bodySerial: "
},
"meta": null
}
422
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 400,
"errorMsg": "Missing Parameters: - qrcodeURL"
},
"meta": null
}
500
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 4043,
"errorMsg": "User cannot be logged in"
},
"meta": null
}
Parameter | Type | Description |
---|---|---|
status | string | Indicates the status of the request - SUCCESSFUL or FAILURE |
data | object | null in case of error |
error.errorCode | number | numeric value corresponding to the error message |
error.errorMsg | string | error message string |
meta | object | meta object will be populated if any relevant metadata is available |
QR API - Get Strength Videos
The API can be used to receive strength equipment workout videos when the QR code on the equipment is scanned by the user.
Endpoint
POST /api/v3/qr
POST /api/v3/qr HTTP/1.1
Host: {{BASE_URL}}
Accept: application/json
Authorization: Bearer eyAbc...
Content-Type: application/json
Content-Length: 399
{
"qrCodeURL” : "https://lfconnect.com/q?t=s&m=sbsdip",
"preferredUnit": "M",
"userHeight": 68
}
curl --location '{{BASE_URL}}/api/v3/qr' \
--header 'Accept: application/json' \
--header 'Authorization: Bearer eyAbc...' \
--header 'Content-Type: application/json' \
--data-raw '{
"qrCodeURL” : "https://lfconnect.com/q?t=s&m=sbsdip",
"preferredUnit": "M",
"userHeight": 68
} '
Headers
Header | Value |
---|---|
Accept | application/json |
Content-Type | application/json |
Authorization | Bearer {oauth-access-token} |
Body
Parameter | Type | Required |
---|---|---|
qrcodeURL | string (sample QRcode for strength equipment - https://lfconnect.com/q?t=s&m={{modelId}} ) |
Y |
userHeight | numeric (If preferredUnit is provided as 'M' then minimum value is 60 and maximum value is 310. If preferredUnit is provided as 'I' then minimum value is 23.64 and maximum value is 122.04) | N |
preferredUnit | string (User's preferred Unit code. If not specified, Default value "I" will be set. Supported values are either "I" or "M") | N |
Response
Success
A successful response returns a HTTP Status Code: 200 - Success. This indicates the strength video details are retrieved successfully.
{
"status": "SUCCESSFUL",
"data": {
"type": "strengthvideos",
"video": {
"name": "fzab",
"officialTitle": "Abdominal",
"video": [
"http://youtube.com/embed/sqW1om6uCfE"
],
"videos3": null,
"targetMuscles": "Abdominals",
"workoutName": [
"Abdominal"
],
"totalWeight": 216,
"weightStack": 95,
"qrCodeURL": null,
"preferredUnit": null,
"userHeight": 0,
"label": "Seat Position",
"labelValue": "1"
}
},
"error": null,
"meta": null
}
Parameter | Type |
---|---|
data | Object |
data.type | string |
data.video | Object |
data.video.name | string |
data.video.video | string[] |
data.video.videos3 | string[] |
data.video.targetMuscles | string |
data.video.weightStack | numeric / NULL |
data.video.qrcodeURL | string / NULL |
data.video.preferredUnit | string ("I"/"M") / NULL |
data.video.userHeight | numeric |
data.video.label | string / NULL |
data.video.labelValue | string / NULL |
meta | Object / NULL |
Error
Errors returned from this endpoint can be one of the following
- HTTP Status Code: 401 (Authorization) Occurs when the Authorization header isn't set or an invalid access token is being used
- HTTP Status Code: 422 (Validation) Occurs when a property/properties doesn't meet the required type as documented here
- HTTP Status Code: 500 (Fault) Occurs when a server error has occurred
401
{
"errorCode": "Authorization",
"errorMessage": "Not authorized for resource.",
"innerErrors": [
{
"errorCode": "ClientAccessTokenInvalid",
"errorTarget": {
"source": "Header",
"key": "Authorization",
}
}
]
}
422
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 400,
"errorMsg": "Missing Parameters: - qrcodeURL"
},
"meta": null
}
500
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 1074,
"errorMsg": "Cannot retrieve the Strength equipment video links"
},
"meta": null
}
Parameter | Type | Description |
---|---|---|
status | string | Indicates the status of the request - SUCCESSFUL or FAILURE |
data | object | null in case of error |
error.errorCode | number | numeric value corresponding to the error message |
error.errorMsg | string | error message string |
meta | object | meta object will be populated if any relevant metadata is available |
QR API - Save User Cardio results
The API is used to save a workout result to a user profile.
Endpoint
POST /api/v3/qr
POST /api/v3/qr HTTP/1.1
Host: {{BASE_URL}}
Accept: application/json
Authorization: Bearer eyAbc...
user-access-token: xyz123...
Content-Type: application/json
Content-Length: 399
{
"qrCodeURL" : "https://halo.fitness/q?t=c&r=eyJpZCI6IjFmN2FiY2RhLXRjMGUtNGI2Zi04NzczLTIzYjIwMTIwMjQyYiIsImJzIjoiU01ULVVLTUROTyIsInQiOiI2OCIsImR0IjoiMjAxOS0xMi0xNlQxNTo1NDozNy0wNjowMCIsImV0IjoiNjMiLCJjIjoiMyIsImQiOnsidSI6IjAiLCJ2IjoiMC4xNzM5In0sImRjIjp7InUiOiIwIiwidiI6IjI3MzAuMDAwMCJ9LCJhcyI6eyJ1IjoiMCIsInYiOiI5LjkzNjUifSwiYXAiOnsidSI6IjAiLCJ2IjoiNjowMiJ9LCJhaSI6IjUuMDAwMCIsImFsIjoiMC4wMDAwIiwiYWhyIjoiMCIsImFtIjoiMCIsImF3IjoiMCIsImFyIjoiMC4wIiwiYXNwbSI6IjAuMCIsImFzbCI6IjAuMCJ9"
}
curl --location '{{BASE_URL}}/api/v3/qr' \
--header 'Accept: application/json' \
--header 'Authorization: Bearer eyAbc...' \
--header 'user-access-token: xyz123...' \
--header 'Content-Type: application/json' \
--data-raw '{ "qrCodeURL" : "https://halo.fitness/q?t=c&r=eyJpZCI6IjFmN2FiY2RhLXRjMGUtNGI2Zi04NzczLTIzYjIwMTIwMjQyYiIsImJzIjoiU01ULVVLTUROTyIsInQiOiI2OCIsImR0IjoiMjAxOS0xMi0xNlQxNTo1NDozNy0wNjowMCIsImV0IjoiNjMiLCJjIjoiMyIsImQiOnsidSI6IjAiLCJ2IjoiMC4xNzM5In0sImRjIjp7InUiOiIwIiwidiI6IjI3MzAuMDAwMCJ9LCJhcyI6eyJ1IjoiMCIsInYiOiI5LjkzNjUifSwiYXAiOnsidSI6IjAiLCJ2IjoiNjowMiJ9LCJhaSI6IjUuMDAwMCIsImFsIjoiMC4wMDAwIiwiYWhyIjoiMCIsImFtIjoiMCIsImF3IjoiMCIsImFyIjoiMC4wIiwiYXNwbSI6IjAuMCIsImFzbCI6IjAuMCJ9"
} '
Headers
Header | Value |
---|---|
Accept | application/json |
Content-Type | application/json |
Authorization | Bearer {oauth-access-token} |
user-access-token | {user-access-token} |
Body
Parameter | Type | Required |
---|---|---|
qrcodeURL | string (sample: https://lfconnect.com/q?t=c&r={{Base64 encoded workout result}} ) |
Y |
Response
Success
A successful response returns a HTTP Status Code: 200 - Success. This indicates the workout result is succesffuly saved to the user.
{
"status": "SUCCESSFUL",
"data": {
"type": "cardioWorkoutData",
"workoutId": 1234
},
"error": null,
"meta": null
}
Parameter | Type |
---|---|
data | Object |
data.type | string |
data.workoutId | numeric |
meta | Object / NULL |
Error
Errors returned from this endpoint can be one of the following
- HTTP Status Code: 401 (Authorization) Occurs when the Authorization header isn't set or an invalid access token is being used
- HTTP Status Code: 422 (Validation) Occurs when a property/properties doesn't meet the required type as documented here
- HTTP Status Code: 500 (Fault) Occurs when a server error has occurred
401
{
"errorCode": "Authorization",
"errorMessage": "Not authorized for resource.",
"innerErrors": [
{
"errorCode": "ClientAccessTokenInvalid",
"errorTarget": {
"source": "Header",
"key": "Authorization",
}
}
]
}
422
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 400,
"errorMsg": "Missing Parameters: - qrcodeURL"
},
"meta": null
}
500
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 4043,
"errorMsg": "Workout cannot be saved"
},
"meta": null
}
Parameter | Type | Description |
---|---|---|
status | string | Indicates the status of the request - SUCCESSFUL or FAILURE |
data | object | null in case of error |
error.errorCode | number | numeric value corresponding to the error message |
error.errorMsg | string | error message string |
meta | object | meta object will be populated if any relevant metadata is available |
Cardio Workout Results
This section contains APIs which manage a user's cardio workout results
Get Daily Workout Results
Retrieves daily Workout results posted by User between the specified dates. This service returns all the individual workout results aggregated by date.
Endpoint
GET /api/v3/workout-results/daily?fromDate={fromDate}&toDate={toDate}&timezone={timeZone}
GET /api/v3/workout-results/daily?fromDate={fromDate}&toDate={toDate}&timezone={timeZone} HTTP/1.1
Host: {{BASE_URL}}
Accept: application/json
Authorization: Bearer eyAbc...
user-access-token: xyz123...
curl --location '{{BASE_URL}}/api/v3/workout-results/daily?fromDate=01/01/2024&toDate=01/01/2025&timezone=GMT' \
--header 'Accept: application/json' \
--header 'Authorization: Bearer eyAbc...' \
--header 'user-access-token: xyz123...'
Headers
Header | Value |
---|---|
Accept | application/json |
Authorization | Bearer {oauth-access-token} |
user-access-token | {user-access-token} |
Query Parameters
Key | Value |
---|---|
fromDate | Date (mm/DD/yyyy) |
toDate | Date (mm/DD/yyyy) |
timezone | timezone (formats allowed - GMT/ GMT+0010 / 'America/Chicago') |
Response
Success
A successful response returns a HTTP Status Code: 200 - OK. This indicates the workout results are successfully retrieved and data is available in the body.
{
"status": "SUCCESSFUL",
"data": {
"workoutResults": [
{
"date": "2024-03-07T06:00:00.000+00:00",
"distance": 0.5797000000000001,
"duration": 29.6,
"calorie": 41.0,
"cardioData": [
{
"equipmentId": 1,
"equipmentName": "Treadmill",
"workoutName": "Manual Goals",
"distance": 0.536,
"duration": 26.8,
"calorie": 38.0,
"date": "2024-03-07T16:59:13.000+00:00",
"guid": "GUID2",
"workoutPresetId": null,
"workoutPresetName": null
},
{
"equipmentId": 16,
"equipmentName": "PowerMill Climber",
"workoutName": "Manual Goals",
"distance": 0.0,
"duration": 0.26666666666666666,
"calorie": 0.0,
"date": "2024-03-07T17:31:03.000+00:00",
"guid": "GUID2",
"workoutPresetId": null,
"workoutPresetName": null
}
],
"unit": "I"
}
]
},
"error": null,
"meta": null
}
Parameter | Type |
---|---|
data | Object |
data.workoutResults | Object[] |
workoutResults[].date | string (ISO 8601) |
workoutResults[].duration | numeric |
workoutResults[].distance | numeric |
workoutResults[].cardioData | Object[] |
workoutResults[].cardioData[].equipmentId | numeric |
workoutResults[].cardioData[].equipmentName | string |
workoutResults[].cardioData[].workoutName | string |
workoutResults[].cardioData[].distance | numeric |
workoutResults[].cardioData[].duration | numeric |
workoutResults[].cardioData[].calorie | numeric |
workoutResults[].cardioData[].date | string (ISO 8601) |
workoutResults[].cardioData[].guid | string |
workoutResults[].cardioData[].workoutPresetId | numeric |
workoutResults[].cardioData[].workoutPresetName | string |
meta | Object / NULL |
Error
Errors returned from this endpoint can be one of the following
- HTTP Status Code: 401 (Authorization) Occurs when the Authorization header isn't set or an invalid access token is being used
- HTTP Status Code: 404 (Not Found) Occurs when the workout could not be retrieved by the given GUID
- HTTP Status Code: 500 (Fault) Occurs when a server error has occurred
401
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 401,
"errorMsg": "user-access-token Header is missing"
},
"meta": null
}
404
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 4063,
"errorMsg": "Workout queue cannot be retrieved"
},
"meta": null
}
500
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 4063,
"errorMsg": "Workout queue cannot be retrieved"
},
"meta": null
}
Parameter | Type | Description |
---|---|---|
status | string | Indicates the status of the request - SUCCESSFUL or FAILURE |
data | object | null in case of error |
error.errorCode | number | numeric value corresponding to the error message |
error.errorMsg | string | error message string |
meta | object | meta object will be populated if any relevant metadata is available |
Get Workout Results by Date Range
Retrieves the workout details of the user between the provided date range
Endpoint
GET /api/v3/workout-results/lifefitness?fromDate={fromDate}&toDate={toDate}&timezone={timeZone}
GET /api/v3/workout-results/lifefitness?fromDate={fromDate}&toDate={toDate}&timezone={timeZone} HTTP/1.1
Host: {{BASE_URL}}
Accept: application/json
Authorization: Bearer eyAbc...
user-access-token: xyz123...
curl --location '{{BASE_URL}}/api/v3/workout-results/lifefitness?fromDate=01/01/2024&toDate=01/01/2025&timezone=GMT' \
--header 'Accept: application/json' \
--header 'Authorization: Bearer eyAbc...' \
--header 'user-access-token: xyz123...'
Headers
Header | Value |
---|---|
Accept | application/json |
Authorization | Bearer {oauth-access-token} |
user-access-token | {user-access-token} |
Query Parameters
Key | Value |
---|---|
fromDate | Date (mm/DD/yyyy) |
toDate | Date (mm/DD/yyyy) |
timezone | timezone (formats allowed - GMT/ GMT+0010 / 'America/Chicago') |
Response
Success
A successful response returns a HTTP Status Code: 200 - OK. This indicates the workout results are successfully retrieved and data is available in the body.
{
"status": "SUCCESSFUL",
"data": {
"workoutResults": [
{
"date": "2025-01-14T17:44:43.000+00:00",
"distance": 0.2005,
"duration": 0.8833333333333333,
"calories": 4.0,
"equipmentModelId": 204,
"activityId": 2,
"activityName": "Upright Bike",
"equipmentBodySerial": null,
"score": null,
"workoutName": "Quick Start",
"level": 9.4615,
"pace": null,
"incline": 0.0,
"averageSpeed": 14.1654,
"averageHeartRate": 105.0,
"distanceClimbed": 0.0,
"paceTime": null,
"paceSpeed": 4.15,
"floorsClimbed": null,
"watts": 36.0,
"mets": 3.1,
"rank": null,
"runTime": null,
"strideLength": 0.0,
"steps": 56.0,
"floors": null,
"rpm": 63.0,
"unit": "M",
"workoutPresetId": null,
"guid": "GUID1",
"workoutPresetName": null,
"rowersPace": null,
"averageStrokesPerMin": null,
"stridesPerMin": 126.0,
"stepsPerMin": null,
"leftBalance": null,
"rightBalance": null,
"averageGroundContactTime": null,
"averageResistanceLevel": 9.461538461538463,
"averageFlightTime": null,
"forwardPercentage": 73.0,
"forwardDuration": 38.0,
"reversePercentage": 27.0,
"reverseDuration": 14.0,
"heartRateZone1Percentage": 100.0,
"heartRateZone1Duration": 6.0,
"heartRateZone2Percentage": 0.0,
"heartRateZone2Duration": 0.0,
"heartRateZone3Percentage": 0.0,
"heartRateZone3Duration": 0.0,
"heartRateZone4Percentage": 0.0,
"heartRateZone4Duration": 0.0,
"heartRateZone5Percentage": 0.0,
"heartRateZone5Duration": 0.0,
"muscleUsageQuadGood": null,
"muscleUsageQuadBetter": null,
"muscleUsageQuadBest": null,
"muscleUsageGlutesGood": null,
"muscleUsageGlutesBetter": null,
"muscleUsageGlutesBest": null,
"muscleUsageCalvesGood": null,
"muscleUsageCalvesBetter": null,
"muscleUsageCalvesBest": null,
"muscleUsageHamstringsGood": null,
"muscleUsageHamstringsBetter": null,
"muscleUsageHamstringsBest": null
}
{
"date": "2025-01-14T17:14:05.000+00:00",
"distance": 0.1563,
"duration": 2.3833333333333333,
"calories": 14.0,
"equipmentModelId": 202,
"activityId": 4,
"activityName": "Cross-Trainer",
"equipmentBodySerial": null,
"score": null,
"workoutName": "Quick Start",
"level": 2.169,
"pace": null,
"incline": 7.8521,
"averageSpeed": 4.666,
"averageHeartRate": 116.0,
"distanceClimbed": 8.1635,
"paceTime": null,
"paceSpeed": 12.52,
"floorsClimbed": null,
"watts": 27.0,
"mets": 3.8,
"rank": null,
"runTime": null,
"strideLength": 0.0,
"steps": 129.0,
"floors": null,
"rpm": 27.0,
"unit": "M",
"workoutPresetId": null,
"guid": "GUID2",
"workoutPresetName": null,
"rowersPace": null,
"averageStrokesPerMin": null,
"stridesPerMin": 54.0,
"stepsPerMin": null,
"leftBalance": null,
"rightBalance": null,
"averageGroundContactTime": null,
"averageResistanceLevel": 2.169014084507043,
"averageFlightTime": null,
"forwardPercentage": 34.0,
"forwardDuration": 39.0,
"reversePercentage": 66.0,
"reverseDuration": 76.0,
"heartRateZone1Percentage": 0.0,
"heartRateZone1Duration": 0.0,
"heartRateZone2Percentage": 100.0,
"heartRateZone2Duration": 1.0,
"heartRateZone3Percentage": 0.0,
"heartRateZone3Duration": 0.0,
"heartRateZone4Percentage": 0.0,
"heartRateZone4Duration": 0.0,
"heartRateZone5Percentage": 0.0,
"heartRateZone5Duration": 0.0,
"muscleUsageQuadGood": 37.06294,
"muscleUsageQuadBetter": 25.874126,
"muscleUsageQuadBest": 37.06294,
"muscleUsageGlutesGood": 37.06294,
"muscleUsageGlutesBetter": 62.93706,
"muscleUsageGlutesBest": 0.0,
"muscleUsageCalvesGood": 0.0,
"muscleUsageCalvesBetter": 100.0,
"muscleUsageCalvesBest": 0.0,
"muscleUsageHamstringsGood": 23.076923,
"muscleUsageHamstringsBetter": 13.986013,
"muscleUsageHamstringsBest": 62.93706
}
]
},
"error": null,
"meta": null
}
Parameter | Type | Description |
---|---|---|
data | Object | |
data.workoutResults | Object[] | Array of workout results |
data.workoutResults[].distance | numeric | The accumulated distance traveled or distance climbed during a workout. Value in Miles or Km based on unit |
data.workoutResults[].workoutName | string | Name of the workout |
data.workoutResults[].distanceClimbed | numeric | Feet or Meters based on unit |
data.workoutResults[].equipmentId | numeric | Activity Id of the Equipment |
data.workoutResults[].duration | numeric | Duration of the workout in Minutes |
data.workoutResults[].score | numeric | Score |
data.workoutResults[].watts | numeric | Watts. Value in Watts |
data.workoutResults[].floors | numeric | Number of floors climbed |
data.workoutResults[].workoutPresetId | numeric | Id corresponding to the workout preset |
data.workoutResults[].workoutPresetName | string | Name of the workout preset |
data.workoutResults[].rank | numeric | Rank |
data.workoutResults[].equipmentName | string | Name of the Equipment |
data.workoutResults[].incline | numeric | Range of incline percentages. Value in % |
data.workoutResults[].averageHeartRate | numeric | Average heart rate in beats per minute (bpm) |
data.workoutResults[].runTime | numeric | Run Time |
data.workoutResults[].rowersPace | numeric | Rowers pace |
data.workoutResults[].paceSpeed | numeric | Pace Speed |
data.workoutResults[].mets | numeric | Metabolic equivalents. Value in METs |
data.workoutResults[].level | numeric | Selection of 20 intensity levels (1 to 20). Each level represents a range of incline percentages |
data.workoutResults[].paceTime | numeric | Time/Mile or Time/Km based on unit |
data.workoutResults[].pace | numeric | Min/Mile or Min/Km based on unit |
data.workoutResults[].averageSpeed | numeric | Average speed for the workout |
data.workoutResults[].strideLength | numeric | Stride Length |
data.workoutResults[].steps | numeric | Steps climbed |
data.workoutResults[].avgStrokesPerMin | numeric | Strokes per minute (SPM) |
data.workoutResults[].rpm | numeric | Rotations per minute (RPM) |
data.workoutResults[].calorie | numeric | The accumulated calories burned. Value in Cal |
data.workoutResults[].guid | string | Unique identifier of the workout result |
data.workoutResults[].floorsClimbed | numeric | FLoors climbed |
data.workoutResults[].unit | string ("I"/"M") / NULL | M (for Metric) or I (for Imperial) |
data.workoutResults[].date | string (ISO 8601) | Completion date-time of the workout |
data.workoutResults[].averageStrokesPerMin | numeric | Average strokes per min |
data.workoutResults[].stridesPerMin | numeric | Strides per min |
data.workoutResults[].stepsPerMin | numeric | Steps per min |
data.workoutResults[].leftBalance | numeric | Percentage value of left balance |
data.workoutResults[].rightBalance | numeric | Percentage value of right balance |
data.workoutResults[].averageGroundContactTime | numeric | Average ground contact time in milliseconds |
data.workoutResults[].averageResistanceLevel | numeric | Average resistance level |
data.workoutResults[].averageFlightTime | numeric | Average flight time in milliseconds |
data.workoutResults[].forwardPercentage | numeric | Percentage of workout in forward mode |
data.workoutResults[].forwardDuration | numeric | Duration of workout in forward mode in seconds |
data.workoutResults[].reversePercentage | numeric | Percentage of workout in reverse mode |
data.workoutResults[].reverseDuration | numeric | Duration of workout in reverse mode in seconds |
data.workoutResults[].heartRateZone1Percentage | numeric | Percentage in Heart Rate Zone 1 |
data.workoutResults[].heartRateZone1Duration | numeric | Time in Heart Rate Zone 1 in seconds |
data.workoutResults[].heartRateZone2Percentage | numeric | Percentage in Heart Rate Zone 2 |
data.workoutResults[].heartRateZone2Duration | numeric | Time in Heart Rate Zone 2 in seconds |
data.workoutResults[].heartRateZone3Percentage | numeric | Percentage in Heart Rate Zone 3 |
data.workoutResults[].heartRateZone3Duration | numeric | Time in Heart Rate Zone 3 in seconds |
data.workoutResults[].heartRateZone4Percentage | numeric | Percentage in Heart Rate Zone 4 |
data.workoutResults[].heartRateZone4Duration | numeric | Time in Heart Rate Zone 4 in seconds |
data.workoutResults[].heartRateZone5Percentage | numeric | Percentage in Heart Rate Zone 5 |
data.workoutResults[].heartRateZone5Duration | numeric | Time in Heart Rate Zone 5 in seconds |
data.workoutResults[].muscleUsageQuadGood | numeric | Percentage of workout using Good Quad Muscle Usage |
data.workoutResults[].muscleUsageQuadBetter | numeric | Percentage of workout using Better Quad Muscle Usage |
data.workoutResults[].muscleUsageQuadBest | numeric | Percentage of workout using Best Quad Muscle Usage |
data.workoutResults[].muscleUsageGlutesGood | numeric | Percentage of workout using Good Glutes Muscle Usage |
data.workoutResults[].muscleUsageGlutesBetter | numeric | Percentage of workout using Better Glutes Muscle Usage |
data.workoutResults[].muscleUsageGlutesBest | numeric | Percentage of workout using Best Glutes Muscle Usage |
data.workoutResults[].muscleUsageCalvesGood | numeric | Percentage of workout using Good Calves Muscle Usage |
data.workoutResults[].muscleUsageCalvesBetter | numeric | Percentage of workout using Better Calves Muscle Usage |
data.workoutResults[].muscleUsageCalvesBest | numeric | Percentage of workout using Best Calves Muscle Usage |
data.workoutResults[].muscleUsageHamstringsGood | numeric | Percentage of workout using Good Hamstrings Muscle Usage |
data.workoutResults[].muscleUsageHamstringsBetter | numeric | Percentage of workout using Better Hamstrings Muscle Usage |
data.workoutResults[].muscleUsageHamstringsBest | numeric | Percentage of workout using Best Hamstrings Muscle Usage |
meta | Object / NULL | - |
Error
Errors returned from this endpoint can be one of the following
- HTTP Status Code: 401 (Authorization) Occurs when the Authorization header isn't set or an invalid access token is being used
- HTTP Status Code: 404 (Not Found) Occurs when the workout could not be retrieved by the given GUID
- HTTP Status Code: 500 (Fault) Occurs when a server error has occurred
401
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 401,
"errorMsg": "user-access-token Header is missing"
},
"meta": null
}
404
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 4063,
"errorMsg": "Workout queue cannot be retrieved"
},
"meta": null
}
500
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 4063,
"errorMsg": "Workout queue cannot be retrieved"
},
"meta": null
}
Parameter | Type | Description |
---|---|---|
status | string | Indicates the status of the request - SUCCESSFUL or FAILURE |
data | object | null in case of error |
error.errorCode | number | numeric value corresponding to the error message |
error.errorMsg | string | error message string |
meta | object | meta object will be populated if any relevant metadata is available |
Get Workout Results by Date-Time Range
Retrieves the workout details of the user between the provided date-time range
Endpoint
GET /api/v3/workout-results/lifefitness/time-range?fromDateTime={fromDateTime}&toDateTime={toDateTime}&timezone={timeZone}
GET /api/v3/workout-results/lifefitness/time-range?fromDateTime={fromDateTime}&toDateTime={toDateTime}&timezone={timeZone} HTTP/1.1
Host: {{BASE_URL}}
Accept: application/json
Authorization: Bearer eyAbc...
user-access-token: xyz123...
curl --location '{{BASE_URL}}/api/v3/workout-results/lifefitness/time-range?fromDateTime=01/01/2024&toDateTime=01/01/2025&timezone=GMT' \
--header 'Accept: application/json' \
--header 'Authorization: Bearer eyAbc...' \
--header 'user-access-token: xyz123...'
Headers
Header | Value |
---|---|
Accept | application/json |
Authorization | Bearer {oauth-access-token} |
user-access-token | {user-access-token} |
Query Parameters
Key | Value | Example |
---|---|---|
fromDateTime | Date Time (yyyy-mm-DDTHH:MM:ss) | 2024-06-25T15:00:37 |
toDateTime | Date Time (yyyy-mm-DDTHH:MM:ss) | 2024-06-25T15:05:37 |
timezone | timezone (formats allowed - GMT/ GMT+0010 / 'America/Chicago') | GMT-5 |
Response
Success
A successful response returns a HTTP Status Code: 200 - OK. This indicates the workout results are successfully retrieved and data is available in the body.
{
"status": "SUCCESSFUL",
"data": {
"workoutResults": [
{
"date": "2025-01-14T17:44:43.000+00:00",
"distance": 0.2005,
"duration": 0.8833333333333333,
"calories": 4.0,
"equipmentModelId": 204,
"activityId": 2,
"activityName": "Upright Bike",
"equipmentBodySerial": null,
"score": null,
"workoutName": "Quick Start",
"level": 9.4615,
"pace": null,
"incline": 0.0,
"averageSpeed": 14.1654,
"averageHeartRate": 105.0,
"distanceClimbed": 0.0,
"paceTime": null,
"paceSpeed": 4.15,
"floorsClimbed": null,
"watts": 36.0,
"mets": 3.1,
"rank": null,
"runTime": null,
"strideLength": 0.0,
"steps": 56.0,
"floors": null,
"rpm": 63.0,
"unit": "M",
"workoutPresetId": null,
"guid": "GUID1",
"workoutPresetName": null,
"rowersPace": null,
"averageStrokesPerMin": null,
"stridesPerMin": 126.0,
"stepsPerMin": null,
"leftBalance": null,
"rightBalance": null,
"averageGroundContactTime": null,
"averageResistanceLevel": 9.461538461538463,
"averageFlightTime": null,
"forwardPercentage": 73.0,
"forwardDuration": 38.0,
"reversePercentage": 27.0,
"reverseDuration": 14.0,
"heartRateZone1Percentage": 100.0,
"heartRateZone1Duration": 6.0,
"heartRateZone2Percentage": 0.0,
"heartRateZone2Duration": 0.0,
"heartRateZone3Percentage": 0.0,
"heartRateZone3Duration": 0.0,
"heartRateZone4Percentage": 0.0,
"heartRateZone4Duration": 0.0,
"heartRateZone5Percentage": 0.0,
"heartRateZone5Duration": 0.0,
"muscleUsageQuadGood": null,
"muscleUsageQuadBetter": null,
"muscleUsageQuadBest": null,
"muscleUsageGlutesGood": null,
"muscleUsageGlutesBetter": null,
"muscleUsageGlutesBest": null,
"muscleUsageCalvesGood": null,
"muscleUsageCalvesBetter": null,
"muscleUsageCalvesBest": null,
"muscleUsageHamstringsGood": null,
"muscleUsageHamstringsBetter": null,
"muscleUsageHamstringsBest": null
}
{
"date": "2025-01-14T17:14:05.000+00:00",
"distance": 0.1563,
"duration": 2.3833333333333333,
"calories": 14.0,
"equipmentModelId": 202,
"activityId": 4,
"activityName": "Cross-Trainer",
"equipmentBodySerial": null,
"score": null,
"workoutName": "Quick Start",
"level": 2.169,
"pace": null,
"incline": 7.8521,
"averageSpeed": 4.666,
"averageHeartRate": 116.0,
"distanceClimbed": 8.1635,
"paceTime": null,
"paceSpeed": 12.52,
"floorsClimbed": null,
"watts": 27.0,
"mets": 3.8,
"rank": null,
"runTime": null,
"strideLength": 0.0,
"steps": 129.0,
"floors": null,
"rpm": 27.0,
"unit": "M",
"workoutPresetId": null,
"guid": "GUID2",
"workoutPresetName": null,
"rowersPace": null,
"averageStrokesPerMin": null,
"stridesPerMin": 54.0,
"stepsPerMin": null,
"leftBalance": null,
"rightBalance": null,
"averageGroundContactTime": null,
"averageResistanceLevel": 2.169014084507043,
"averageFlightTime": null,
"forwardPercentage": 34.0,
"forwardDuration": 39.0,
"reversePercentage": 66.0,
"reverseDuration": 76.0,
"heartRateZone1Percentage": 0.0,
"heartRateZone1Duration": 0.0,
"heartRateZone2Percentage": 100.0,
"heartRateZone2Duration": 1.0,
"heartRateZone3Percentage": 0.0,
"heartRateZone3Duration": 0.0,
"heartRateZone4Percentage": 0.0,
"heartRateZone4Duration": 0.0,
"heartRateZone5Percentage": 0.0,
"heartRateZone5Duration": 0.0,
"muscleUsageQuadGood": 37.06294,
"muscleUsageQuadBetter": 25.874126,
"muscleUsageQuadBest": 37.06294,
"muscleUsageGlutesGood": 37.06294,
"muscleUsageGlutesBetter": 62.93706,
"muscleUsageGlutesBest": 0.0,
"muscleUsageCalvesGood": 0.0,
"muscleUsageCalvesBetter": 100.0,
"muscleUsageCalvesBest": 0.0,
"muscleUsageHamstringsGood": 23.076923,
"muscleUsageHamstringsBetter": 13.986013,
"muscleUsageHamstringsBest": 62.93706
}
]
},
"error": null,
"meta": null
}
Parameter | Type | Description |
---|---|---|
data | Object | |
data.workoutResults | Object[] | Array of workout results |
data.workoutResults[].distance | numeric | The accumulated distance traveled or distance climbed during a workout. Value in Miles or Km based on unit |
data.workoutResults[].workoutName | string | Name of the workout |
data.workoutResults[].distanceClimbed | numeric | Feet or Meters based on unit |
data.workoutResults[].equipmentId | numeric | Activity Id of the Equipment |
data.workoutResults[].duration | numeric | Duration of the workout in Minutes |
data.workoutResults[].score | numeric | Score |
data.workoutResults[].watts | numeric | Watts. Value in Watts |
data.workoutResults[].floors | numeric | Number of floors climbed during the workout |
data.workoutResults[].workoutPresetId | numeric | Id corresponding to the workout preset |
data.workoutResults[].workoutPresetName | string | Name of the workout preset |
data.workoutResults[].rank | numeric | Rank |
data.workoutResults[].equipmentName | string | Name of the Equipment |
data.workoutResults[].incline | numeric | Range of incline percentages. Value in % |
data.workoutResults[].averageHeartRate | numeric | Average heart rate in beats per minute (bpm) |
data.workoutResults[].runTime | numeric | Run Time |
data.workoutResults[].rowersPace | numeric | Rowers pace |
data.workoutResults[].paceSpeed | numeric | Pace Speed |
data.workoutResults[].mets | numeric | Metabolic equivalents. Value in METs |
data.workoutResults[].level | numeric | Selection of 20 intensity levels (1 to 20). Each level represents a range of incline percentages |
data.workoutResults[].paceTime | numeric | Time/Mile or Time/Km based on unit |
data.workoutResults[].pace | numeric | Min/Mile or Min/Km based on unit |
data.workoutResults[].averageSpeed | numeric | Average speed for the workout |
data.workoutResults[].strideLength | numeric | Stride Length |
data.workoutResults[].steps | numeric | Steps climbed during the workout |
data.workoutResults[].avgStrokesPerMin | numeric | Strokes per minute (SPM) |
data.workoutResults[].rpm | numeric | Rotations per minute (RPM) |
data.workoutResults[].calorie | numeric | The accumulated calories burned during the workout. Value in Cal |
data.workoutResults[].guid | string | Unique identifier of the workout result |
data.workoutResults[].floorsClimbed | numeric | FLoors climbed during the workout |
data.workoutResults[].unit | string ("I"/"M") / NULL | M (for Metric) or I (for Imperial) |
data.workoutResults[].date | string (ISO 8601) | Completion date-time of the workout |
data.workoutResults[].averageStrokesPerMin | numeric | Average strokes per min |
data.workoutResults[].stridesPerMin | numeric | Strides per min |
data.workoutResults[].stepsPerMin | numeric | Steps per min |
data.workoutResults[].leftBalance | numeric | Percentage value of left balance |
data.workoutResults[].rightBalance | numeric | Percentage value of right balance |
data.workoutResults[].averageGroundContactTime | numeric | Average ground contact time in milliseconds |
data.workoutResults[].averageResistanceLevel | numeric | Average resistance level |
data.workoutResults[].averageFlightTime | numeric | Average flight time in milliseconds |
data.workoutResults[].forwardPercentage | numeric | Percentage of workout in forward mode |
data.workoutResults[].forwardDuration | numeric | Duration of workout in forward mode in seconds |
data.workoutResults[].reversePercentage | numeric | Percentage of workout in reverse mode |
data.workoutResults[].reverseDuration | numeric | Duration of workout in reverse mode in seconds |
data.workoutResults[].heartRateZone1Percentage | numeric | Percentage in Heart Rate Zone 1 |
data.workoutResults[].heartRateZone1Duration | numeric | Time in Heart Rate Zone 1 in seconds |
data.workoutResults[].heartRateZone2Percentage | numeric | Percentage in Heart Rate Zone 2 |
data.workoutResults[].heartRateZone2Duration | numeric | Time in Heart Rate Zone 2 in seconds |
data.workoutResults[].heartRateZone3Percentage | numeric | Percentage in Heart Rate Zone 3 |
data.workoutResults[].heartRateZone3Duration | numeric | Time in Heart Rate Zone 3 in seconds |
data.workoutResults[].heartRateZone4Percentage | numeric | Percentage in Heart Rate Zone 4 |
data.workoutResults[].heartRateZone4Duration | numeric | Time in Heart Rate Zone 4 in seconds |
data.workoutResults[].heartRateZone5Percentage | numeric | Percentage in Heart Rate Zone 5 |
data.workoutResults[].heartRateZone5Duration | numeric | Time in Heart Rate Zone 5 in seconds |
data.workoutResults[].muscleUsageQuadGood | numeric | Percentage of workout using Good Quad Muscle Usage |
data.workoutResults[].muscleUsageQuadBetter | numeric | Percentage of workout using Better Quad Muscle Usage |
data.workoutResults[].muscleUsageQuadBest | numeric | Percentage of workout using Best Quad Muscle Usage |
data.workoutResults[].muscleUsageGlutesGood | numeric | Percentage of workout using Good Glutes Muscle Usage |
data.workoutResults[].muscleUsageGlutesBetter | numeric | Percentage of workout using Better Glutes Muscle Usage |
data.workoutResults[].muscleUsageGlutesBest | numeric | Percentage of workout using Best Glutes Muscle Usage |
data.workoutResults[].muscleUsageCalvesGood | numeric | Percentage of workout using Good Calves Muscle Usage |
data.workoutResults[].muscleUsageCalvesBetter | numeric | Percentage of workout using Better Calves Muscle Usage |
data.workoutResults[].muscleUsageCalvesBest | numeric | Percentage of workout using Best Calves Muscle Usage |
data.workoutResults[].muscleUsageHamstringsGood | numeric | Percentage of workout using Good Hamstrings Muscle Usage |
data.workoutResults[].muscleUsageHamstringsBetter | numeric | Percentage of workout using Better Hamstrings Muscle Usage |
data.workoutResults[].muscleUsageHamstringsBest | numeric | Percentage of workout using Best Hamstrings Muscle Usage |
meta | Object / NULL | - |
Error
Errors returned from this endpoint can be one of the following
- HTTP Status Code: 401 (Authorization) Occurs when the Authorization header isn't set or an invalid access token is being used
- HTTP Status Code: 404 (Not Found) Occurs when the workout could not be retrieved by the given GUID
- HTTP Status Code: 500 (Fault) Occurs when a server error has occurred
401
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 401,
"errorMsg": "user-access-token Header is missing"
},
"meta": null
}
404
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 4063,
"errorMsg": "Workout queue cannot be retrieved"
},
"meta": null
}
500
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 4063,
"errorMsg": "Workout queue cannot be retrieved"
},
"meta": null
}
Parameter | Type | Description |
---|---|---|
status | string | Indicates the status of the request - SUCCESSFUL or FAILURE |
data | object | null in case of error |
error.errorCode | number | numeric value corresponding to the error message |
error.errorMsg | string | error message string |
meta | object | meta object will be populated if any relevant metadata is available |
Get Cardio Workout Result by GUID
Retrieves the Workout Result Details by the Life Fitness Workout Result GUID
Endpoint
GET /api/v3/workout-results/lifefitness/{guid}
GET /api/v3/workout-results/lifefitness/{guid} HTTP/1.1
Host: {{BASE_URL}}
Accept: application/json
Authorization: Bearer eyAbc...
user-access-token: xyz123...
curl --location '{{BASE_URL}}/api/v3/workout-results/lifefitness/GUID123' \
--header 'Accept: application/json' \
--header 'Authorization: Bearer eyAbc...' \
--header 'user-access-token: xyz123...'
Headers
Header | Value |
---|---|
Accept | application/json |
Authorization | Bearer {oauth-access-token} |
user-access-token | {user-access-token} |
Response
Success
A successful response returns a HTTP Status Code: 200 - OK. This indicates the workout result was successfully retrieved and data is available in the body.
{
"status": "SUCCESSFUL",
"data": {
"date": "2025-01-14T17:14:05.000+00:00",
"distance": 0.1563,
"duration": 2.3833333333333333,
"calories": 14.0,
"equipmentModelId": 202,
"activityId": 4,
"activityName": "Cross-Trainer",
"equipmentBodySerial": null,
"score": null,
"workoutName": "Quick Start",
"level": 2.169,
"pace": null,
"incline": 7.8521,
"averageSpeed": 4.666,
"averageHeartRate": 116.0,
"distanceClimbed": 8.1635,
"paceTime": null,
"paceSpeed": 12.52,
"floorsClimbed": null,
"watts": 27.0,
"mets": 3.8,
"rank": null,
"runTime": null,
"strideLength": 0.0,
"steps": 129.0,
"floors": null,
"rpm": 27.0,
"unit": "M",
"workoutPresetId": null,
"guid": "GUID1",
"workoutPresetName": null,
"rowersPace": null,
"averageStrokesPerMin": null,
"stridesPerMin": 54.0,
"stepsPerMin": null,
"leftBalance": null,
"rightBalance": null,
"averageGroundContactTime": null,
"averageResistanceLevel": 2.169014084507043,
"averageFlightTime": null,
"forwardPercentage": 34.0,
"forwardDuration": 39.0,
"reversePercentage": 66.0,
"reverseDuration": 76.0,
"heartRateZone1Percentage": 0.0,
"heartRateZone1Duration": 0.0,
"heartRateZone2Percentage": 100.0,
"heartRateZone2Duration": 1.0,
"heartRateZone3Percentage": 0.0,
"heartRateZone3Duration": 0.0,
"heartRateZone4Percentage": 0.0,
"heartRateZone4Duration": 0.0,
"heartRateZone5Percentage": 0.0,
"heartRateZone5Duration": 0.0,
"muscleUsageQuadGood": 37.06294,
"muscleUsageQuadBetter": 25.874126,
"muscleUsageQuadBest": 37.06294,
"muscleUsageGlutesGood": 37.06294,
"muscleUsageGlutesBetter": 62.93706,
"muscleUsageGlutesBest": 0.0,
"muscleUsageCalvesGood": 0.0,
"muscleUsageCalvesBetter": 100.0,
"muscleUsageCalvesBest": 0.0,
"muscleUsageHamstringsGood": 23.076923,
"muscleUsageHamstringsBetter": 13.986013,
"muscleUsageHamstringsBest": 62.93706
},
"error": null,
"meta": null
}
Parameter | Type | Description |
---|---|---|
data | Object | - |
data.distance | numeric | The accumulated distance traveled or distance climbed during a workout. Value in Miles or Km based on unit |
data.workoutName | string | Name of the workout |
data.distanceClimbed | numeric | Feet or Meters based on unit |
data.equipmentId | numeric | Activity Id of the Equipment |
data.duration | numeric | Duration of the workout in Minutes |
data.score | numeric | Score |
data.watts | numeric | Watts. Value in Watts |
data.floors | numeric | Number of floors climbed during the workout |
data.workoutPresetId | numeric | Id corresponding to the workout preset |
data.workoutPresetName | string | Name of the workout preset |
data.rank | numeric | Rank |
data.equipmentName | string | Name of the Equipment |
data.incline | numeric | Range of incline percentages. Value in % |
data.averageHeartRate | numeric | Average heart rate in beats per minute (bpm) |
data.runTime | numeric | Run Time |
data.rowersPace | numeric | Rowers pace |
data.paceSpeed | numeric | Pace Speed |
data.mets | numeric | Metabolic equivalents. Value in METs |
data.level | numeric | Selection of 20 intensity levels (1 to 20). Each level represents a range of incline percentages |
data.paceTime | numeric | Time/Mile or Time/Km based on unit |
data.pace | numeric | Min/Mile or Min/Km based on unit |
data.averageSpeed | numeric | Average speed for the workout |
data.strideLength | numeric | Stride Length |
data.steps | numeric | Steps climbed during the workout |
data.avgStrokesPerMin | numeric | Strokes per minute (SPM) |
data.rpm | numeric | Rotations per minute (RPM) |
data.calorie | numeric | The accumulated calories burned during the workout. Value in Cal |
data.guid | string | Unique identifier of the workout result |
data.floorsClimbed | numeric | FLoors climbed during the workout |
data.unit | string ("I"/"M") / NULL | M (for Metric) or I (for Imperial) |
data.date | string (ISO 8601) | Completion date-time of the workout |
data.averageStrokesPerMin | numeric | Average strokes per min |
data.stridesPerMin | numeric | Strides per min |
data.stepsPerMin | numeric | Steps per min |
data.leftBalance | numeric | Percentage value of left balance |
data.rightBalance | numeric | Percentage value of right balance |
data.averageGroundContactTime | numeric | Average ground contact time in milliseconds |
data.averageResistanceLevel | numeric | Average resistance level |
data.averageFlightTime | numeric | Average flight time in milliseconds |
data.forwardPercentage | numeric | Percentage of workout in forward mode |
data.forwardDuration | numeric | Duration of workout in forward mode in seconds |
data.reversePercentage | numeric | Percentage of workout in reverse mode |
data.reverseDuration | numeric | Duration of workout in reverse mode in seconds |
data.heartRateZone1Percentage | numeric | Percentage in Heart Rate Zone 1 |
data.heartRateZone1Duration | numeric | Time in Heart Rate Zone 1 in seconds |
data.heartRateZone2Percentage | numeric | Percentage in Heart Rate Zone 2 |
data.heartRateZone2Duration | numeric | Time in Heart Rate Zone 2 in seconds |
data.heartRateZone3Percentage | numeric | Percentage in Heart Rate Zone 3 |
data.heartRateZone3Duration | numeric | Time in Heart Rate Zone 3 in seconds |
data.heartRateZone4Percentage | numeric | Percentage in Heart Rate Zone 4 |
data.heartRateZone4Duration | numeric | Time in Heart Rate Zone 4 in seconds |
data.heartRateZone5Percentage | numeric | Percentage in Heart Rate Zone 5 |
data.heartRateZone5Duration | numeric | Time in Heart Rate Zone 5 in seconds |
data.muscleUsageQuadGood | numeric | Percentage of workout using Good Quad Muscle Usage |
data.muscleUsageQuadBetter | numeric | Percentage of workout using Better Quad Muscle Usage |
data.muscleUsageQuadBest | numeric | Percentage of workout using Best Quad Muscle Usage |
data.muscleUsageGlutesGood | numeric | Percentage of workout using Good Glutes Muscle Usage |
data.muscleUsageGlutesBetter | numeric | Percentage of workout using Better Glutes Muscle Usage |
data.muscleUsageGlutesBest | numeric | Percentage of workout using Best Glutes Muscle Usage |
data.muscleUsageCalvesGood | numeric | Percentage of workout using Good Calves Muscle Usage |
data.muscleUsageCalvesBetter | numeric | Percentage of workout using Better Calves Muscle Usage |
data.muscleUsageCalvesBest | numeric | Percentage of workout using Best Calves Muscle Usage |
data.muscleUsageHamstringsGood | numeric | Percentage of workout using Good Hamstrings Muscle Usage |
data.muscleUsageHamstringsBetter | numeric | Percentage of workout using Better Hamstrings Muscle Usage |
data.muscleUsageHamstringsBest | numeric | Percentage of workout using Best Hamstrings Muscle Usage |
meta | Object / NULL | - |
Error
Errors returned from this endpoint can be one of the following
- HTTP Status Code: 401 (Authorization) Occurs when the Authorization header isn't set or an invalid access token is being used
- HTTP Status Code: 404 (Not Found) Occurs when the workout could not be retrieved by the given GUID
- HTTP Status Code: 500 (Fault) Occurs when a server error has occurred
401
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 401,
"errorMsg": "user-access-token Header is missing"
},
"meta": null
}
404
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 4063,
"errorMsg": "Workout result not found with guid: GUID123"
},
"meta": null
}
500
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 4048,
"errorMsg": "Failed to retrieve workout with guid: GUID123"
},
"meta": null
}
Parameter | Type | Description |
---|---|---|
status | string | Indicates the status of the request - SUCCESSFUL or FAILURE |
data | object | null in case of error |
error.errorCode | number | numeric value corresponding to the error message |
error.errorMsg | string | error message string |
meta | object | meta object will be populated if any relevant metadata is available |
Cardio Workout Preset
This section contains APIs regarding a user's workout presets
Get All Workout Presets
Retrieve the list of Workout Presets details of the user account corresponding to the user-access-token header.
Endpoint
GET /api/v3/workout-presets
GET /api/v3/workout-presets HTTP/1.1
Host: {{BASE_URL}}
Accept: application/json
Authorization: Bearer eyAbc...
user-access-token: xyz123...
curl --location '{{BASE_URL}}/api/v3/workout-presets' \
--header 'Accept: application/json' \
--header 'Authorization: Bearer eyAbc...' \
--header 'user-access-token: xyz123...'
Headers
Header | Value |
---|---|
Accept | application/json |
Authorization | Bearer {oauth-access-token} |
user-access-token | {user-access-token} |
Response
Success
A successful response returns a HTTP Status Code: 200 - OK. This indicates the workout result was successfully retrieved and data is available in the body.
{
"status": "SUCCESSFUL",
"data": {
"workoutPresets": [
{
"id": 1,
"workoutName": "preset1",
"activityId": 1,
"workoutId": 1001,
"userId": 1234,
"paramList": [
{
"paramId": 7,
"paramValue": 45.0,
"intervalValues": null
},
{
"paramId": 14,
"paramValue": 5.0,
"intervalValues": null
}
],
"createdAt": "2024-04-18T16:23:33.000+00:00",
"updatedAt": "2024-04-18T16:46:04.000+00:00",
"unit": "I",
"uuid": null
},
{
"id": 2,
"workoutName": "preset2",
"activityId": 1,
"workoutId": 1001,
"userId": 1234,
"paramList": [
{
"paramId": 7,
"paramValue": 15.0,
"intervalValues": null
},
{
"paramId": 14,
"paramValue": 2.0,
"intervalValues": null
}
],
"createdAt": "2024-04-18T16:48:09.000+00:00",
"updatedAt": null,
"unit": "I",
"uuid": null
}
]
},
"error": null,
"meta": null
}
Parameter | Type |
---|---|
data | Object |
data.workoutPresets | Object[] |
data.workoutPresets.id | numeric |
data.workoutPresets.workoutName | numeric |
data.workoutPresets.activityId | numeric |
data.workoutPresets.workoutId | numeric |
data.workoutPresets.userId | numeric |
data.workoutPresets.createdAt | string |
data.workoutPresets.updatedAt | string |
data.workoutPresets.unit | string ("I"/"M") |
data.workoutPresets.uuid | string |
data.workoutPresets.paramList | Object[] |
data.workoutPresets.paramList.paramId | numeric |
data.workoutPresets.paramList.paramValue | numeric |
data.workoutPresets.paramList.intervalvalues | numeric[] |
meta | Object / NULL |
status | string |
Error
Errors returned from this endpoint can be one of the following
- HTTP Status Code: 401 (Authorization) Occurs when the Authorization header isn't set or an invalid access token is being used
- HTTP Status Code: 500 (Fault) Occurs when a server error has occurred
401
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 401,
"errorMsg": "user-access-token Header is missing"
},
"meta": null
}
500
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 500,
"errorMsg": "Internal Error"
},
"meta": null
}
Parameter | Type | Description |
---|---|---|
status | string | Indicates the status of the request - SUCCESSFUL or FAILURE |
data | object | null in case of error |
error.errorCode | number | numeric value corresponding to the error message |
error.errorMsg | string | error message string |
meta | object | meta object will be populated if any relevant metadata is available |
Get Workout Preset by Id
Retrieve a Workout Preset details by the workout-preset-id assigned to the user account corresponding to the user-access-token header.
Endpoint
GET /api/v3/workout-presets/{workout-preset-id}
GET /api/v3/workout-presets/{workout-preset-id} HTTP/1.1
Host: {{BASE_URL}}
Accept: application/json
Authorization: Bearer eyAbc...
user-access-token: xyz123...
curl --location '{{BASE_URL}}/api/v3/workout-presets/{workout-preset-id}' \
--header 'Accept: application/json' \
--header 'Authorization: Bearer eyAbc...' \
--header 'user-access-token: xyz123...'
Headers
Header | Value |
---|---|
Accept | application/json |
Authorization | Bearer {oauth-access-token} |
user-access-token | {user-access-token} |
Response
Success
A successful response returns a HTTP Status Code: 200 - OK. This indicates the workout result was successfully retrieved and data is available in the body.
{
"status": "SUCCESSFUL",
"data": {
"workoutPreset":
{
"id": {workout-preset-id},
"workoutName": "preset1",
"activityId": 1,
"workoutId": 1001,
"userId": 1234,
"paramList": [
{
"paramId": 7,
"paramValue": 45.0,
"intervalValues": null
},
{
"paramId": 14,
"paramValue": 5.0,
"intervalValues": null
}
],
"createdAt": "2024-04-18T16:23:33.000+00:00",
"updatedAt": "2024-04-18T16:46:04.000+00:00",
"unit": "I",
"uuid": null
},
},
"error": null,
"meta": null
}
Parameter | Type |
---|---|
data | Object |
data.workoutPreset | Object |
data.workoutPreset.id | numeric |
data.workoutPreset.workoutName | numeric |
data.workoutPreset.activityId | numeric |
data.workoutPreset.workoutId | numeric |
data.workoutPreset.userId | numeric |
data.workoutPreset.createdAt | string |
data.workoutPreset.updatedAt | string |
data.workoutPreset.unit | string ("I"/"M") |
data.workoutPreset.uuid | string |
data.workoutPreset.paramList | Object[] |
data.workoutPreset.paramList.paramId | numeric |
data.workoutPreset.paramList.paramValue | numeric |
data.workoutPreset.paramList.intervalvalues | numeric[] |
meta | Object / NULL |
status | string |
Error
Errors returned from this endpoint can be one of the following
- HTTP Status Code: 401 (Authorization) Occurs when the Authorization header isn't set or an invalid access token is being used
- HTTP Status Code: 404 (Not Found) Occurs when the workout preset could not be retrieved by the given ID
- HTTP Status Code: 409 (Conflict) Occurs when the workout preset ID doesn't belong to the user
- HTTP Status Code: 500 (Fault) Occurs when a server error has occurred
401
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 401,
"errorMsg": "user-access-token Header is missing"
},
"meta": null
}
404
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 4009,
"errorMsg": "Workout not found workoutId: presetId1"
},
"meta": null
}
409
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 4008,
"errorMsg": "Matching workout does not belong to this user workoutId: presetId1"
},
"meta": null
}
500
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 500,
"errorMsg": "Internal Error"
},
"meta": null
}
Parameter | Type | Description |
---|---|---|
status | string | Indicates the status of the request - SUCCESSFUL or FAILURE |
data | object | null in case of error |
error.errorCode | number | numeric value corresponding to the error message |
error.errorMsg | string | error message string |
meta | object | meta object will be populated if any relevant metadata is available |
Create Workout Preset
Create a new Workout Preset for a user account corresponding to the user-access-token header.
Endpoint
POST /api/v3/workout-presets
POST /api/v3/workout-presets HTTP/1.1
Host: {{BASE_URL}}
Accept: application/json
Authorization: Bearer eyAbc...
user-access-token: xyz123...
{
"workoutName": "8_28_testC",
"unit": "I",
"activityId": 1,
"workoutId": 1001,
"paramList": [
{
"paramId": 7,
"paramValue": 45
},
{
"paramId": 14,
"paramValue": 5
}
]
}
curl --location '{{BASE_URL}}/api/v3/workout-presets' \
--header 'Accept: application/json' \
--header 'Authorization: Bearer eyAbc...' \
--header 'user-access-token: xyz123...'
--data '{
"workoutName": "preset1",
"unit": "I",
"activityId": 1,
"workoutId": 1001,
"paramList": [
{
"paramId": 7,
"paramValue": 45
},
{
"paramId": 14,
"paramValue": 5
}
]
}'
Headers
Header | Value |
---|---|
Accept | application/json |
Authorization | Bearer {oauth-access-token} |
user-access-token | {user-access-token} |
Body
Parameter | Type | Required |
---|---|---|
id | numeric | N (Only Required when updating an existing workout preset) |
workoutName | numeric | Y |
activityId | numeric | Y |
workoutId | numeric | Y |
unit | string ("I"/"M") | Y |
paramList | Object[] | Y |
paramList.paramId | numeric | Y |
paramList.paramValue | numeric | Y |
paramList.intervalvalues | numeric[] | N |
Response
Success
A successful response returns a HTTP Status Code: 200 - OK. This indicates the workout result was successfully retrieved and data is available in the body.
{
"status": "SUCCESSFUL",
"data": {
"workoutPreset":
{
"id": 1,
"workoutName": "preset1",
"activityId": 1,
"workoutId": 1001,
"userId": 1234,
"paramList": [
{
"paramId": 7,
"paramValue": 45.0,
"intervalValues": null
},
{
"paramId": 14,
"paramValue": 5.0,
"intervalValues": null
}
],
"createdAt": "2024-04-18T16:23:33.000+00:00",
"updatedAt": "2024-04-18T16:46:04.000+00:00",
"unit": "I",
"uuid": null
},
},
"error": null,
"meta": null
}
Parameter | Type |
---|---|
data | Object |
data.workoutPreset | Object |
data.workoutPreset.id | numeric |
data.workoutPreset.workoutName | numeric |
data.workoutPreset.activityId | numeric |
data.workoutPreset.workoutId | numeric |
data.workoutPreset.userId | numeric |
data.workoutPreset.createdAt | string |
data.workoutPreset.updatedAt | string |
data.workoutPreset.unit | string ("I"/"M") |
data.workoutPreset.uuid | string |
data.workoutPreset.paramList | Object[] |
data.workoutPreset.paramList.paramId | numeric |
data.workoutPreset.paramList.paramValue | numeric |
data.workoutPreset.paramList.intervalvalues | numeric[] |
meta | Object / NULL |
status | string |
Error
Errors returned from this endpoint can be one of the following
- HTTP Status Code: 401 (Authorization) Occurs when the Authorization header isn't set or an invalid access token is being used
- HTTP Status Code: 404 (Not Found) Occurs when the workout preset could not be retrieved by the given ID
- HTTP Status Code: 409 (Conflict) Occurs when the workout preset ID doesn't belong to the user
- HTTP Status Code: 500 (Fault) Occurs when a server error has occurred
401
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 401,
"errorMsg": "user-access-token Header is missing"
},
"meta": null
}
404
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 4009,
"errorMsg": "Workout not found workoutId: presetId1"
},
"meta": null
}
409
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 4008,
"errorMsg": "Matching workout does not belong to this user workoutId: presetId1"
},
"meta": null
}
500
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 4083,
"errorMsg": "Workout name already exists, please choose a new one"
},
"meta": null
}
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 500,
"errorMsg": "Internal Error"
},
"meta": null
}
Parameter | Type | Description |
---|---|---|
status | string | Indicates the status of the request - SUCCESSFUL or FAILURE |
data | object | null in case of error |
error.errorCode | number | numeric value corresponding to the error message |
error.errorMsg | string | error message string |
meta | object | meta object will be populated if any relevant metadata is available |
Update Workout Preset
Update an existing Workout Preset of a user account corresponding to the user-access-token header.
Endpoint
PUT /api/v3/workout-presets/{workout-preset-id}
PUT /api/v3/workout-presets/{workout-preset-id} HTTP/1.1
Host: {{BASE_URL}}
Accept: application/json
Authorization: Bearer eyAbc...
user-access-token: xyz123...
{
"workoutName": "8_28_testC",
"unit": "I",
"activityId": 1,
"workoutId": 1001,
"paramList": [
{
"paramId": 7,
"paramValue": 45
},
{
"paramId": 14,
"paramValue": 5
}
]
}
curl --location --request PUT '{{BASE_URL}}/api/v3/workout-presets/{workout-preset-id}' \
--header 'Accept: application/json' \
--header 'Authorization: Bearer eyAbc...' \
--header 'user-access-token: xyz123...'
--data '{
"workoutName": "preset1",
"unit": "I",
"activityId": 1,
"workoutId": 1001,
"paramList": [
{
"paramId": 7,
"paramValue": 45
},
{
"paramId": 14,
"paramValue": 5
}
]
}'
Headers
Header | Value |
---|---|
Accept | application/json |
Authorization | Bearer {oauth-access-token} |
user-access-token | {user-access-token} |
Body
Parameter | Type | Required |
---|---|---|
id | numeric | N (Only Required when updating an existing workout preset) |
workoutName | numeric | Y |
activityId | numeric | Y |
workoutId | numeric | Y |
unit | string ("I"/"M") | Y |
paramList | Object[] | Y |
paramList.paramId | numeric | Y |
paramList.paramValue | numeric | Y |
paramList.intervalvalues | numeric[] | N |
Response
Success
A successful response returns a HTTP Status Code: 200 - OK. This indicates the workout result was successfully retrieved and data is available in the body.
{
"status": "SUCCESSFUL",
"data": {
"workoutPreset":
{
"id": 1,
"workoutName": "preset1",
"activityId": 1,
"workoutId": 1001,
"userId": 1234,
"paramList": [
{
"paramId": 7,
"paramValue": 45.0,
"intervalValues": null
},
{
"paramId": 14,
"paramValue": 5.0,
"intervalValues": null
}
],
"createdAt": "2024-04-18T16:23:33.000+00:00",
"updatedAt": "2024-04-18T16:46:04.000+00:00",
"unit": "I",
"uuid": null
},
},
"error": null,
"meta": null
}
Parameter | Type |
---|---|
data | Object |
data.workoutPreset | Object |
data.workoutPreset.id | numeric |
data.workoutPreset.workoutName | numeric |
data.workoutPreset.activityId | numeric |
data.workoutPreset.workoutId | numeric |
data.workoutPreset.userId | numeric |
data.workoutPreset.createdAt | string |
data.workoutPreset.updatedAt | string |
data.workoutPreset.unit | string ("I"/"M") |
data.workoutPreset.uuid | string |
data.workoutPreset.paramList | Object[] |
data.workoutPreset.paramList.paramId | numeric |
data.workoutPreset.paramList.paramValue | numeric |
data.workoutPreset.paramList.intervalvalues | numeric[] |
meta | Object / NULL |
status | string |
Error
Errors returned from this endpoint can be one of the following
- HTTP Status Code: 401 (Authorization) Occurs when the Authorization header isn't set or an invalid access token is being used
- HTTP Status Code: 404 (Not Found) Occurs when the workout preset could not be retrieved by the given ID
- HTTP Status Code: 409 (Conflict) Occurs when the workout preset ID doesn't belong to the user
- HTTP Status Code: 500 (Fault) Occurs when a server error has occurred
401
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 401,
"errorMsg": "user-access-token Header is missing"
},
"meta": null
}
404
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 4009,
"errorMsg": "Workout not found workoutId: presetId1"
},
"meta": null
}
409
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 4008,
"errorMsg": "Matching workout does not belong to this user workoutId: presetId1"
},
"meta": null
}
500
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 4083,
"errorMsg": "Workout name already exists, please choose a new one"
},
"meta": null
}
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 500,
"errorMsg": "Internal Error"
},
"meta": null
}
Parameter | Type | Description |
---|---|---|
status | string | Indicates the status of the request - SUCCESSFUL or FAILURE |
data | object | null in case of error |
error.errorCode | number | numeric value corresponding to the error message |
error.errorMsg | string | error message string |
meta | object | meta object will be populated if any relevant metadata is available |
Delete Workout Preset
Delete the workout preset by the workout-preset-id assigned to the user account corresponding to the user-access-token header.
Endpoint
DELETE /api/v3/workout-presets/{workout-preset-id}
DELETE /api/v3/workout-presets/{workout-preset-id} HTTP/1.1
Host: api.developers.lifefitness.com
Authorization: Bearer eyAbc...
user-access-token: xyz123...
curl --location --request DELETE '{{BASE_URL}}/api/v3/workout-presets/{workout-preset-id}' \
--header 'user-access-token: da2a51c10bbdf0d042a7cd471451b439|0b88cfd07508610548d961760e0bcd29' \
--header 'Authorization: Bearer eyAbc...' \
Headers
Header | Value |
---|---|
Accept | application/json |
Authorization | Bearer {oauth-access-token} |
user-access-token | {user-access-token} |
Response
Success
A successful response returns a HTTP Status Code: 204 - OK. This indicates the workout presets were successfully deleted.
Error
Errors returned from this endpoint can be one of the following
- HTTP Status Code: 401 (Authorization) Occurs when the Authorization header isn't set or an invalid access token is being used
- HTTP Status Code: 404 (Not Found) Occurs when the workout preset could not be retrieved by the given ID
- HTTP Status Code: 409 (Conflict) Occurs when the workout preset ID doesn't belong to the user
- HTTP Status Code: 500 (Fault) Occurs when a server error has occurred
401
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 401,
"errorMsg": "user-access-token Header is missing"
},
"meta": null
}
404
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 4009,
"errorMsg": "Workout not found presetId1"
},
"meta": null
}
409
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 4008,
"errorMsg": "Matching workout does not belong to this user {workout-preset-id}"
},
"meta": null
}
500
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 500,
"errorMsg": "Internal Error"
},
"meta": null
}
Parameter | Type | Description |
---|---|---|
status | string | Indicates the status of the request - SUCCESSFUL or FAILURE |
data | object | null in case of error |
error.errorCode | number | numeric value corresponding to the error message |
error.errorMsg | string | error message string |
meta | object | meta object will be populated if any relevant metadata is available |
Get Workout Preset Image
Retrieve the Image URL of a Workout Preset by the workout-preset-id assigned to the user account corresponding to the user-access-token header.
Endpoint
GET /api/v3/workout-presets/{workout-preset-id}/image
GET /api/v3/workout-presets/{workout-preset-id}/image HTTP/1.1
Host: {{BASE_URL}}
Accept: application/json
Authorization: Bearer eyAbc...
user-access-token: xyz123...
curl --location '{{BASE_URL}}/api/v3/workout-presets/{workout-preset-id}/image' \
--header 'Accept: application/json' \
--header 'Authorization: Bearer eyAbc...' \
--header 'user-access-token: xyz123...'
Headers
Header | Value |
---|---|
Accept | application/json |
Authorization | Bearer {oauth-access-token} |
user-access-token | {user-access-token} |
Response
Success
A successful response returns a HTTP Status Code: 200 - OK. This indicates the workout result was successfully retrieved and data is available in the body.
{
"status": "SUCCESSFUL",
"data": {
"workoutPreset": {
"imageURL": "https://imageURL",
"id": {workout-preset-id}
}
},
"error": null,
"meta": null
}
Parameter | Type |
---|---|
data | Object |
data.workoutPreset | Object |
data.workoutPreset.id | numeric |
data.workoutPreset.imageURL | string |
meta | Object / NULL |
status | string |
Error
Errors returned from this endpoint can be one of the following
- HTTP Status Code: 401 (Authorization) Occurs when the Authorization header isn't set or an invalid access token is being used
- HTTP Status Code: 404 (Not Found) Occurs when the workout preset could not be retrieved by the given ID
- HTTP Status Code: 409 (Conflict) Occurs when the workout preset ID doesn't belong to the user
- HTTP Status Code: 500 (Fault) Occurs when a server error has occurred
401
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 401,
"errorMsg": "user-access-token Header is missing"
},
"meta": null
}
404
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 4009,
"errorMsg": "Workout not found: presetId1"
},
"meta": null
}
409
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 4008,
"errorMsg": "Matching workout does not belong to this user: presetId1"
},
"meta": null
}
500
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 500,
"errorMsg": "Internal Error"
},
"meta": null
}
Parameter | Type | Description |
---|---|---|
status | string | Indicates the status of the request - SUCCESSFUL or FAILURE |
data | object | null in case of error |
error.errorCode | number | numeric value corresponding to the error message |
error.errorMsg | string | error message string |
meta | object | meta object will be populated if any relevant metadata is available |
Update Workout Preset Image
Update the Image of the Workout Preset by the workout-preset-id assigned to the user account corresponding to the user-access-token header.
Endpoint
PUT /api/v3/workout-presets/{workout-preset-id}/image
PUT /api/v3/workout-presets/{workout-preset-id}/image HTTP/1.1
Host: {{BASE_URL}}
Authorization: Bearer eyAbc...
user-access-token: xyz123...
Content-Type: multipart/form-data; boundary=----WebKitFormBoundary7MA4YWxkTrZu0gW
Content-Length: 246
------WebKitFormBoundary7MA4YWxkTrZu0gW
Content-Disposition: form-data; name="file"; filename="/PresetImage.jpeg"
Content-Type: image/jpeg
(data)
------WebKitFormBoundary7MA4YWxkTrZu0gW--
curl --location --request PUT '{{BASE_URL}}/api/v3/workout-presets/{workout-preset-id}/image' \
--header 'Authorization: Bearer eyAbc...' \
--header 'user-access-token: xyz123...'
--header 'Content-Type: multipart/form-data' \
--form 'file=@"/PresetImage.jpeg"'
Headers
Header | Value |
---|---|
Accept | application/json |
Authorization | Bearer {oauth-access-token} |
user-access-token | {user-access-token} |
Response
Success
A successful response returns a HTTP Status Code: 200 - OK. This indicates the workout successfully saved to the preset.
{
"status": "SUCCESSFUL",
"data": {
"workoutPreset": {
"imageURL": "https://imageURL",
"id": {workout-preset-id}
}
},
"error": null,
"meta": null
}
Parameter | Type |
---|---|
data | Object |
data.workoutPreset | Object |
data.workoutPreset.id | numeric |
data.workoutPreset.imageURL | string |
meta | Object / NULL |
status | string |
Error
Errors returned from this endpoint can be one of the following
- HTTP Status Code: 401 (Authorization) Occurs when the Authorization header isn't set or an invalid access token is being used
- HTTP Status Code: 404 (Not Found) Occurs when the workout preset could not be retrieved by the given ID
- HTTP Status Code: 409 (Conflict) Occurs when the workout preset ID doesn't belong to the user
- HTTP Status Code: 500 (Fault) Occurs when a server error has occurred
401
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 401,
"errorMsg": "user-access-token Header is missing"
},
"meta": null
}
404
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 4009,
"errorMsg": "Workout not found: presetId1"
},
"meta": null
}
409
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 4008,
"errorMsg": "Matching workout does not belong to this user: presetId1"
},
"meta": null
}
500
{ "status": "FAILURE",
"data": null,
"error": {
"errorCode": 4069,
"errorMsg": "Invalid image file"
},
"meta": null
}
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 500,
"errorMsg": "Internal Error"
},
"meta": null
}
Parameter | Type | Description |
---|---|---|
status | string | Indicates the status of the request - SUCCESSFUL or FAILURE |
data | object | null in case of error |
error.errorCode | number | numeric value corresponding to the error message |
error.errorMsg | string | error message string |
meta | object | meta object will be populated if any relevant metadata is available |
Delete Workout Preset Image
Deletes the Image of the Workout Preset by the workout-preset-id assigned to the user account corresponding to the user-access-token header.
Endpoint
DELETE /api/v3/workout-presets/{workout-preset-id}/image
DELETE /api/v3/workout-presets/{workout-preset-id}/image HTTP/1.1
Host: {{BASE_URL}}
Authorization: Bearer eyAbc...
user-access-token: xyz123...
curl --location --request DELETE '{{BASE_URL}}/api/v3/workout-presets/{workout-preset-id}/image' \
--header 'Authorization: Bearer eyAbc...' \
--header 'user-access-token: xyz123...'
Headers
Header | Value |
---|---|
Accept | application/json |
Authorization | Bearer {oauth-access-token} |
user-access-token | {user-access-token} |
Response
Success
A successful response returns a HTTP Status Code: 204 - OK. This indicates the workout successfully saved to the preset.
Error
Errors returned from this endpoint can be one of the following
- HTTP Status Code: 401 (Authorization) Occurs when the Authorization header isn't set or an invalid access token is being used
- HTTP Status Code: 404 (Not Found) Occurs when the workout preset could not be retrieved by the given ID
- HTTP Status Code: 409 (Conflict) Occurs when the workout preset ID doesn't belong to the user
- HTTP Status Code: 500 (Fault) Occurs when a server error has occurred
401
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 401,
"errorMsg": "user-access-token Header is missing"
},
"meta": null
}
404
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 4009,
"errorMsg": "Workout not found: presetId1"
},
"meta": null
}
409
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 4008,
"errorMsg": "Matching workout does not belong to this user: presetId1"
},
"meta": null
}
500
{ "status": "FAILURE",
"data": null,
"error": {
"errorCode": 4069,
"errorMsg": "Invalid image file"
},
"meta": null
}
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 500,
"errorMsg": "Internal Error"
},
"meta": null
}
Parameter | Type | Description |
---|---|---|
status | string | Indicates the status of the request - SUCCESSFUL or FAILURE |
data | object | null in case of error |
error.errorCode | number | numeric value corresponding to the error message |
error.errorMsg | string | error message string |
meta | object | meta object will be populated if any relevant metadata is available |
Cardio Activities
This section contains APIs regarding supported activities
Get Cardio Activities
Retrieves the supported cardio activities
Endpoint
GET /api/v3/activities
GET /api/v3/activities HTTP/1.1
Host: {{BASE_URL}}
Accept: application/json
Authorization: Bearer eyAbc...
curl --location '{{BASE_URL}}/api/v3/activities' \
--header 'Accept: application/json' \
--header 'Authorization: Bearer eyAbc...'
Headers
Header | Value |
---|---|
Accept | application/json |
Authorization | Bearer {oauth-access-token} |
Response
Success
A successful response returns a HTTP Status Code: 200 - OK. This indicates the workout result was successfully retrieved and data is available in the body.
{
"status": "SUCCESSFUL",
"data": {
"activities": [
{
"activityId": 1,
"activityName": "Treadmill",
"activityDescription": "Treadmill",
"supportedModelIds": "1,4,..."
},
...
]
},
"error": null,
"meta": null
}
Parameter | Type |
---|---|
data | Object |
data.activities | Object[] |
activities.activityId | numeric |
activities.activityName | string |
activities.activityDescription | string |
activities.supportedModelIds | string |
meta | Object / NULL |
status | string |
Error
Errors returned from this endpoint can be one of the following
- HTTP Status Code: 401 (Authorization) Occurs when the Authorization header isn't set or an invalid access token is being used
- HTTP Status Code: 500 (Fault) Occurs when a server error has occurred
500
{
"status": "FAILURE",
"data": null,
"error": {
"errorCode": 500,
"errorMsg": "Internal Error"
},
"meta": null
}
Parameter | Type | Description |
---|---|---|
status | string | Indicates the status of the request - SUCCESSFUL or FAILURE |
data | object | null in case of error |
error.errorCode | number | numeric value corresponding to the error message |
error.errorMsg | string | error message string |
meta | object | meta object will be populated if any relevant metadata is available |