Procedure Log API endpoint
Table of contents
- Fields
- Types of procedure 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] |
procedure | related procedure ID formatted as a string [required] |
entries | list of log entries [read-only]. See entries format below |
Types of procedure logs
Impedances
: Impedances logLinearDisplacement
: Linear displacement logTetrodes4
: Tetrode log (4 tetrodes)Tetrodes8
: Tetrode log (8 tetrodes)
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/procedurelog
- Data: None
- Responses:
200
OK;403
Not allowed;404
Not found
Use example (using Python API)
resp = client.load_model('procedurelog')
Response example
{'procedure_logs': [
{
'id': '6a24ec67-59df-4da2-beae-c138102e69b1',
'type': 'Impedances',
'description': None,
'procedure': '6a7c4ef9-f633-4b60-aa21-21d274ebab17',
'entries': [
{'date_time': '2023-05-05T06:20:00Z',
'notes': None,
'details': {'impedances': 3.0, 'phases': None, 'channels': ''}},
{'date_time': '2023-04-05T07:10:00Z',
'notes': 'aa',
'details': {'impedances': 2.0, 'phases': None, 'channels': ''}},
{'date_time': '2023-03-26T13:20:00Z',
'notes': None,
'details': {'impedances': 1.0, 'phases': None, 'channels': ''}},
{'date_time': '2023-03-13T07:10:00Z',
'notes': None,
'details': {'impedances': 2.0, 'phases': None, 'channels': ''}}
],
'links': {'entries': 'entries/'}
},
{
'id': '88331276-e142-45ec-ae63-45a513881ed7',
'type': 'LinearDisplacement',
'description': None,
'procedure': '61da7e53-1066-42de-a1a2-3db96bb7cba2',
'entries': [
{'date_time': '2023-04-05T13:45:00Z',
'notes': None,
'details': {'displacement': 9.0}},
{'date_time': '2023-03-31T09:05:00Z',
'notes': None,
'details': {'displacement': 7.0}}
],
'links': {'entries': 'entries/'}
}
]}
Add
- Allowed portals: private, super
- Request method: POST
- URL: https://www.brainstem.org/api/private/modules/procedurelog
- 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("procedurelog", data={
"type": "LinearDisplacement",
"procedure": "61da7e53-1066-42de-a1a2-3db96bb7cba2"})
Response example
{'procedure_log': {
'id': '43d3d060-4606-4e95-bd7e-79dcb910cf27',
'type': 'LinearDisplacement',
'description': None,
'procedure': '61da7e53-1066-42de-a1a2-3db96bb7cba2',
'entries': []}
}
Detail
- Allowed portals: public, private, super
- Request method: GET
- URL: https://www.brainstem.org/api/private/modules/procedurelog/<id>/
- Data: None
- Responses:
200
OK;403
Not allowed;404
Not found
Use example (using Python API)
resp = client.load_model('procedurelog', id='43d3d060-4606-4e95-bd7e-79dcb910cf27')
Response example
{'procedure_log': {
'id': '43d3d060-4606-4e95-bd7e-79dcb910cf27',
'type': 'LinearDisplacement',
'description': None,
'procedure': '61da7e53-1066-42de-a1a2-3db96bb7cba2',
'entries': []}
}
Change
- Allowed portals: private, super
- Request method: PATCH
- URL: https://www.brainstem.org/api/private/modules/procedurelog/<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("procedurelog", id="43d3d060-4606-4e95-bd7e-79dcb910cf27", data={"description": "new text"})
Response example
{'procedure_log': {
'id': '43d3d060-4606-4e95-bd7e-79dcb910cf27',
'type': 'LinearDisplacement',
'description': "new text",
'procedure': '61da7e53-1066-42de-a1a2-3db96bb7cba2',
'entries': []}
}
Delete
- Allowed portals: private, super
- Request method: DELETE
- URL: https://www.brainstem.org/api/private/modules/procedurelog/<id>/
- Data: None
- Responses:
204
OK;403
Not allowed;404
Not found
Use example (using Python API)
resp = client.delete_model("procedurelog", id="43d3d060-4606-4e95-bd7e-79dcb910cf27")
Add entry
- Allowed portals: private, super
- Request method: PATCH
- URL: https://www.brainstem.org/api/private/modules/procedurelog/<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("procedurelog", id="43d3d060-4606-4e95-bd7e-79dcb910cf27", options="add_entry", data={
'date_time': '2023-04-05T13:45:00Z',
'notes': None,
'details': {'displacement': 9.0}
}
)
Response example
{'procedure_log': {
'id': '43d3d060-4606-4e95-bd7e-79dcb910cf27',
'type': 'LinearDisplacement',
'description': 'new text',
'procedure': '61da7e53-1066-42de-a1a2-3db96bb7cba2',
'entries': [
{'date_time': '2023-04-05T13:45:00Z',
'notes': None,
'details': {'displacement': 9.0}}
],
'links': {'entries': 'entries/'}
}
}
Change entry
- Allowed portals: private, super
- Request method: PATCH
- URL: https://www.brainstem.org/api/private/modules/procedurelog/<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("procedurelog", id="43d3d060-4606-4e95-bd7e-79dcb910cf27", options="change_entry", data={'date_time': '2023-04-05T13:45:00Z', 'notes': 'new text'})
Response example
{'procedure_log': {
'id': '43d3d060-4606-4e95-bd7e-79dcb910cf27',
'type': 'LinearDisplacement',
'description': 'new text',
'procedure': '61da7e53-1066-42de-a1a2-3db96bb7cba2',
'entries': [
{'date_time': '2023-04-05T13:45:00Z',
'notes': "new text",
'details': {'displacement': 9.0}}
],
'links': {'entries': 'entries/'}
}
}
Remove entry
- Allowed portals: private, super
- Request method: PATCH
- URL: https://www.brainstem.org/api/private/modules/procedurelog/<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("procedurelog", id="43d3d060-4606-4e95-bd7e-79dcb910cf27", options="remove_entry", data={'date_time': '2023-04-05T13:45:00Z'})
Response example
{'procedure_log': {
'id': '43d3d060-4606-4e95-bd7e-79dcb910cf27',
'type': 'LinearDisplacement',
'description': 'new text',
'procedure': '61da7e53-1066-42de-a1a2-3db96bb7cba2',
'entries': []
}
}