Subject Log API endpoint
Table of contents
- Fields
- Types of subject logs
- Log entries
- List view
- Add
- Detail
- Change
- Delete
- Add entry
- Change entry
- Remove entry
Fields
Field | Description |
---|---|
id | UUID identificator formatted as a string |
type | string [required]. See options below |
description | string [max length: 500] |
subject | related subject ID formatted as a string [required] |
entries | list of log entries [read-only]. See entries format below |
Types of subject logs
Diet and Consumption Logs
FoodConsumption
: Food consumption logWaterConsumption
: Water consumption log
Deprivation Logs, [
FoodDeprivation
: Food deprivation logWaterDeprivation
: Water deprivation log
Housing and Environment Logs
Housing
: Housing log
Physical and Health Logs
Weighing
: Weighing logWellness
: Wellness log
Log entries
Each entry in the entries
list is a dictionary with the following fields:
Field | Description |
---|---|
date_time | string containing date and time (e.g. ā2023-05-05T06:20:00Zā) [required] |
notes | string |
details | JSON object. See accepted schemas below |
A detailed list of the accepted schemas for the details
field, related to each type
, can be found in
List view
- Allowed portals: public, private, super
- Request method: GET
- URL: https://www.brainstem.org/api/private/modules/subjectlog
- Data: None
- Responses:
200
OK;403
Not allowed;404
Not found
Use example (using Python API)
resp = client.load_model('subjectlog')
Response example
{'subject_logs': [
{
'id': '36570c8f-707b-4ead-950a-f924acf14c37',
'type': 'Weighing',
'description': None,
'subject': '0f87c229-6769-4854-83a5-c71e154246b8',
'entries': [
{'date_time': '2023-03-26T04:05:00Z',
'notes': None,
'details': {'weight': 1254.0}},
{'date_time': '2023-03-03T17:05:00Z',
'notes': None,
'details': {'weight': 23.0}}
],
'links': {'entries': 'entries/'}
},
{
'id': '8d7f3c37-69f5-4069-aca7-406f09de50f8',
'type': 'FoodConsumption',
'description': None,
'subject': '0cdaf69d-63cf-429f-b549-fc0cc163d046',
'entries': [
{'date_time': '2023-03-09T07:10:00Z',
'notes': None,
'details': {'foodAmount': 1.0}},
{'date_time': '2023-03-01T13:45:00Z',
'notes': None,
'details': {'foodAmount': 2.0}}
],
'links': {'entries': 'entries/'}}
]}
Add
- Allowed portals: private, super
- Request method: POST
- URL: https://www.brainstem.org/api/private/modules/subjectlog
- Data: JSON dictionary containing at least the required fields.
- Responses:
201
OK;400
Bad request;403
Not allowed;404
Not found
Use example (using Python API)
resp = client.save_model("subjectlog", data={
"type": "WaterConsumption",
"subject": "0cdaf69d-63cf-429f-b549-fc0cc163d046"})
Response example
{'subject_log': {
'id': '9c3a8cc7-da48-4061-a118-d9c7dc3105c3',
'type': 'WaterConsumption',
'description': None,
'subject': '0cdaf69d-63cf-429f-b549-fc0cc163d046',
'entries': []}
}
Detail
- Allowed portals: public, private, super
- Request method: GET
- URL: https://www.brainstem.org/api/private/modules/subjectlog/<id>/
- Data: None
- Responses:
200
OK;403
Not allowed;404
Not found
Use example (using Python API)
resp = client.load_model('subjectlog', id='9c3a8cc7-da48-4061-a118-d9c7dc3105c3')
Response example
{'subject_log': {
'id': '9c3a8cc7-da48-4061-a118-d9c7dc3105c3',
'type': 'WaterConsumption',
'description': None,
'subject': '0cdaf69d-63cf-429f-b549-fc0cc163d046',
'entries': []}
}
Change
- Allowed portals: private, super
- Request method: PATCH
- URL: https://www.brainstem.org/api/private/modules/subjectlog/<id>/
- Data: dictionary containing the fields to be updated
- Responses:
200
OK;400
Bad request;403
Not allowed;404
Not found
Use example (using Python API)
resp = client.save_model("subjectlog", id="9c3a8cc7-da48-4061-a118-d9c7dc3105c3", data={"description": "new text"})
Response example
{'subject_log': {
'id': '9c3a8cc7-da48-4061-a118-d9c7dc3105c3',
'type': 'WaterConsumption',
'description': "new text",
'subject': '0cdaf69d-63cf-429f-b549-fc0cc163d046',
'entries': []}
}
Delete
- Allowed portals: private, super
- Request method: DELETE
- URL: https://www.brainstem.org/api/private/modules/subjectlog/<id>/
- Data: None
- Responses:
204
OK;403
Not allowed;404
Not found
Use example (using Python API)
resp = client.delete_model("subjectlog", id="9c3a8cc7-da48-4061-a118-d9c7dc3105c3")
Add entry
- Allowed portals: private, super
- Request method: PATCH
- URL: https://www.brainstem.org/api/private/modules/subjectlog/<id>/add_entry/
- Data: dictionary with the entry data
- Responses:
200
OK;400
Bad request;403
Not allowed;404
Not found
Use example (using Python API)
resp = client.save_model("subjectlog", id="9c3a8cc7-da48-4061-a118-d9c7dc3105c3", options="add_entry", data={
'date_time': '2023-04-05T13:45:00Z',
'notes': None,
'details': {'waterAmount': 9.0}
}
)
Response example
{'subject_log':
{
'id': '9c3a8cc7-da48-4061-a118-d9c7dc3105c3',
'type': 'WaterConsumption',
'description': 'new text',
'subject': '0cdaf69d-63cf-429f-b549-fc0cc163d046',
'entries': [
{'date_time': '2023-04-05T13:45:00Z',
'notes': None,
'details': {'waterAmount': 9.0}}
],
'links': {'entries': 'entries/'}
}
}
Change entry
- Allowed portals: private, super
- Request method: PATCH
- URL: https://www.brainstem.org/api/private/modules/subjectlog/<id>/change_entry/
- Data: dictionary with the entry data
- Responses:
200
OK;400
Bad request;403
Not allowed;404
Not found
Use example (using Python API)
resp = client.save_model("subjectlog", id="9c3a8cc7-da48-4061-a118-d9c7dc3105c3", options="change_entry", data={'date_time': '2023-04-05T13:45:00Z', 'notes': 'new text'})
Response example
{'subject_log':
{
'id': '9c3a8cc7-da48-4061-a118-d9c7dc3105c3',
'type': 'WaterConsumption',
'description': 'new text',
'subject': '0cdaf69d-63cf-429f-b549-fc0cc163d046',
'entries': [
{'date_time': '2023-04-05T13:45:00Z',
'notes': 'new text',
'details': {'waterAmount': 9.0}}
],
'links': {'entries': 'entries/'}
}
}
Remove entry
- Allowed portals: private, super
- Request method: PATCH
- URL: https://www.brainstem.org/api/private/modules/subjectlog/<id>/remove_entry/
- Data: dictionary with the entry data
- Responses:
200
OK;400
Bad request;403
Not allowed;404
Not found
Use example (using Python API)
resp = client.save_model("subjectlog", id="9c3a8cc7-da48-4061-a118-d9c7dc3105c3", options="remove_entry", data={'date_time': '2023-04-05T13:45:00Z'})
Response example
{'subject_log': {
'id': '9c3a8cc7-da48-4061-a118-d9c7dc3105c3',
'type': 'WaterConsumption',
'description': "new text",
'subject': '0cdaf69d-63cf-429f-b549-fc0cc163d046',
'entries': []}
}