Session API endpoint

Table of contents

  1. Fields
  2. List view
  3. Add
  4. Detail
  5. Change
  6. Delete

Fields

FieldDescription
idUUID identificator formatted as a string
namestring [required] [max length: 100; must be unique]
descriptionstring
projectslist of related projects IDs formatted as strings [required]
date_timestring containing date (e.g. “2023-03-22”)
epochslist of related epoch IDs formatted as strings [read-only]
datastoragelist of related data storage IDs formatted as strings [read-only]
extra_fieldslist of JSON dictionaries. See structure below
download_linkslist of JSON dictionaries. See structure below
dataacquisitionlist of related data acquisition IDs formatted as strings [read-only]
behaviorslist of related behaviors IDs formatted as strings [read-only]
manipulationslist of related manipulations IDs formatted as strings [read-only]
name_used_in_storagestring [max length: 200]
tagslist of strings

extra_fields is a list of JSON dictionaries with two elements, name and value like the example below. The name must start with a letter and can only consist of letters, numbers and underscore. The value can be a string or a numeric value.

{
    "extra_property": "setting1", 
    "another_property: 22
}

extra_fields is a list of JSON dictionaries with two elements, Repository and URL, like the following example:

[
    {"Repository": "DANDI", "URL": "https://dandiarchive.org/dandiset/123456?pos=1"}, 
    {"Repository": "GitHub", "URL": "https://github.com/my_user/my_code"}
]

List view

  • Allowed portals: public, private, super
  • Request method: GET
  • URL: https://www.brainstem.org/api/private/stem/session
  • Data: None
  • Responses: 200 OK; 403 Not allowed; 404 Not found

Use example (using Python API)

resp = client.load_model('session')

Response example

{'sessions': [
    {
        'id': '1a827c68-19b4-4cec-8ae5-e13c8f1de900',
        'name': 'session1',
        'description': '',
        'epochs': [],
        'projects': ['c4b8a90b-2963-4d13-aa07-b6f497252dde'],
        'date_time': None,
        'datastorage': [],
        'extra_fields': [],
        'download_links': [],
        'dataacquisition': [],
        'behaviors': [],
        'manipulations': ['20387176-5f3c-433a-8bf9-34a0f2c431f7'],
        'tags': [],
        'links': {'projects': 'projects/', 'manipulations': 'manipulations/'}
    },
    {
        'id': 'd8e72f9d-eb25-4280-a241-3317d5914055',
        'name': 'session2',
        'description': '',
        'epochs': [],
        'projects': ['c4b8a90b-2963-4d13-aa07-b6f497252dde'],
        'date_time': None,
        'datastorage': [],
        'extra_fields': [],
        'download_links': [],
        'dataacquisition': ['1c77ae53-6f83-4398-bfe5-6eb95ff00610'],
        'behaviors': [],
        'manipulations': [],
        'tags': [],
        'links': {'projects': 'projects/', 'manipulations': 'manipulations/'}
    }
]}

Add

  • Allowed portals: private, super
  • Request method: POST
  • URL: https://www.brainstem.org/api/private/stem/session
  • 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("session",  data={
	"name": "NewSession", 
	"description": "some text",  
	"projects": ["c4b8a90b-2963-4d13-aa07-b6f497252dde"]
})

Response example

{'session': {'id': '13bdd793-86d4-428e-9708-167bbc26f6d2',
    'name': 'NewSession',
    'description': 'some text',
    'epochs': [],
    'projects': ['c4b8a90b-2963-4d13-aa07-b6f497252dde'],
    'date_time': None,
    'datastorage': [],
    'extra_fields': [],
    'download_links': [],
    'dataacquisition': [],
    'behaviors': [],
    'manipulations': [],
    'tags': [],
    'links': {'projects': 'projects/'}}
}

Detail

  • Allowed portals: public, private, super
  • Request method: GET
  • URL: https://www.brainstem.org/api/private/stem/session/<id>/
  • Data: None
  • Responses: 200 OK; 403 Not allowed; 404 Not found

Use example (using Python API)

resp = client.load_model('session', id='13bdd793-86d4-428e-9708-167bbc26f6d2')

Response example

{'session': {'id': '13bdd793-86d4-428e-9708-167bbc26f6d2',
    'name': 'NewSession',
    'description': 'some text',
    'epochs': [],
    'projects': ['c4b8a90b-2963-4d13-aa07-b6f497252dde'],
    'date_time': None,
    'datastorage': [],
    'extra_fields': {
        "extra_property": "setting1", 
        "another_property: 22
    },
    'download_links': [
        {"Repository": "DANDI", "URL": "https://dandiarchive.org/dandiset/123456?pos=1"}, 
        {"Repository": "GitHub", "URL": "https://github.com/my_user/my_code"}
    ],
    'dataacquisition': [],
    'behaviors': [],
    'manipulations': [],
    'tags': [],
    'links': {'projects': 'projects/'}}
}

Change

  • Allowed portals: private, super
  • Request method: PATCH
  • URL: https://www.brainstem.org/api/private/stem/session/<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("session", id="13bdd793-86d4-428e-9708-167bbc26f6d2", data={"description": "new text"})

Response example

{'session': {'id': '13bdd793-86d4-428e-9708-167bbc26f6d2',
    'name': 'NewSession',
    'description': 'new text',
    'epochs': [],
    'projects': ['c4b8a90b-2963-4d13-aa07-b6f497252dde'],
    'date_time': None,
    'datastorage': [],
    'extra_fields': [],
    'download_links': [],
    'dataacquisition': [],
    'behaviors': [],
    'manipulations': [],
    'tags': [],
    'links': {'projects': 'projects/'}}
}

Delete

  • Allowed portals: private, super
  • Request method: DELETE
  • URL: https://www.brainstem.org/api/private/stem/session/<id>/
  • Data: None
  • Responses: 204 OK; 403 Not allowed; 404 Not found

Use example (using Python API)

resp = client.delete_model("session", id="13bdd793-86d4-428e-9708-167bbc26f6d2")