Method returns sessions which were modified since specified date and time.
Method can be used to sync sessions results between StartExam and external system by schedule:
modifiedSince
that makes sense, for example: 2025-01-01T00:00:00ZmodifiedUntil
.and use it in the next request as modifiedSince
parameter.modifiedSince
parameter to avoid data loss and 400 errors.modifiedUntil
.Method returns maximum 500 sessions in one response and supports paging with continuation token:
continuationToken
is returned by server instead of modifiedUntil
, it means that server has more pages to return.continuationToken
as a parameter.continuationToken
, so use it only once to avoid endless loops.modifiedUntil
instead of continuationToken
. Save it as usual. Paging finished.
GET https://api.startexam.com/v2/sessions?center={center}&modifiedSince={modifiedSince}&continuationToken={continuationToken}
center
- center unique name. The value can be retrieved from the center details page.
modifiedSince
- date and time since which all new and modified sessions should be retrieved, UTC, ISO 8601.
continuationToken
- ask next 500 sessions from the server using token from previous response, string.
None.
GET https://api.startexam.com/v2/sessions?center=mycenter&modifiedSince=2025-01-16T00:00:00Z HTTP/1.1
Host: api.startexam.com
Accept: application/json; charset=utf-8
Authorization: SharedKey 99:f52JP7GQd0xqrBzMO1NWTNVGzLENymgdUXu/Ie++NX4=
Content-Type: application/json; charset=utf-8
Date: Thu, 16 Jan 2025 05:09:11 GMT
GET https://api.startexam.com/v2/sessions?center=mycenter&modifiedSince=2025-01-16T00:00:00Z&continuationToken=se02331582210410564987 HTTP/1.1
Host: api.startexam.com
Accept: application/json; charset=utf-8
Authorization: SharedKey 99:f52JP7GQd0xqrBzMO1NWTNVGzLENymgdUXu/Ie++NX4=
Content-Type: application/json; charset=utf-8
Date: Thu, 16 Jan 2025 05:09:11 GMT
Date and Authorization headers are constructed in the standard way.
200 OK, 400 Bad Request, etc. according the response processing guide.
Json.
modifiedUntil
- last successful sync time, UTC, ISO 8601. Should be saved and used as modifiedSince
in the next request. NULL
.
continuationToken
- token to request next page of data, string.NULL
.
results
- array of test sessions, can be empty if there is nothing new.
participantId
- participant id, guid.
testId
- test id, guid.
testTitle
- test title, string.
started
- session started date-time in UTC, ISO 8601.
isFinished
- session finished flag, true/false.
autoClosed
- participant has left system and session was closed automatically by timeout, true/false.
elapsedTime
- testing time, HH:MM:SS, nullable.
score
- participant score, double, nullable.
maxScore
- maximum possible score, double, nullable.
percent
- percent, double with 2 decimals, nullable.
scaleLevel
- participant level from Test settings, nullable.
manualScoring
- manual scoring status. Supported values:
unknown
,
notRequired
,
required
,
completed
.
modified
- participant modified date-time in UTC, ISO 8601.
participantData
- personal data of a participant.
If a participant hasn't finished a session, some fields (elapsedTime, score, maxScore, percent, scaleLevel, outcomes) will be not returned as nullable.
modifiedUntil
which means there are no more sessions, everything synced. Client must save modifiedUntil
.continuationToken
which means there are more sessions. Client must request a new page with this continuationToken
.modifiedUntil
which means there are no new sessions, everything synced. Client must save modifiedUntil
.HTTP/1.1 200 OK
Content-Type: application/json; charset=utf-8
Content-Length: 1790
{
"modifiedUntil": "2025-01-16T05:08:41Z",
"continuationToken": null,
"results": [
{
"participantId": "d6c914b5-6b4f-418d-bb3d-ea848002760a",
"testId": "a347d3c8-ff22-4c33-a32d-a60228367120",
"testTitle": "MBA Preparation",
"started": "2025-01-15T19:08:41Z",
"isFinished": true,
"autoClosed": true,
"elapsedTime": "00:33:00",
"score": 17.0,
"maxScore": 20.0,
"percent": 85.0,
"scaleLevel": "Average Knowledge",
"manualScoring": "notRequired",
"modified": "2025-01-15T20:08:41Z",
"participantData": [
{
"name": "First Name",
"value": "John"
},
{
"name": "Last Name",
"value": "Lennon"
},
{
"name": "Email",
"value": "lennon@gmail.com"
},
{
"name": "My Custom Field Name",
"value": "000000001"
}
]
},
{
"participantId": "16affd90-147f-4489-ac5c-fc5bf8e67cc9",
"testId": "7bddb4da-3207-483a-a7df-21a4b455c71e",
"testTitle": "MBA Examination",
"started": "2025-01-15T20:08:41Z",
"isFinished": false,
"autoClosed": false,
"elapsedTime": null,
"score": null,
"maxScore": null,
"percent": null,
"scaleLevel": null,
"manualScoring": "required",
"modified": "2025-01-15T20:08:41Z",
"participantData": [
{
"name": "First Name",
"value": "Frank"
},
{
"name": "Last Name",
"value": "Sinatra"
},
{
"name": "Email",
"value": "frank@sinatra.com"
},
{
"name": "My Custom Field Name",
"value": "000000002"
}
]
}
]
}
HTTP/1.1 200 OK
Content-Type: application/json; charset=utf-8
Content-Length: 1792
{
"modifiedUntil": null,
"continuationToken": "se02331582210410564987",
"results": [
{
"participantId": "ff4779e3-b848-4eaa-ad2b-8192dec57706",
"testId": "4c3dd8b3-3b29-46b3-bb7c-514cc51a2cb7",
"testTitle": "MBA Preparation",
"started": "2025-01-15T19:08:41Z",
"isFinished": true,
"autoClosed": true,
"elapsedTime": "00:33:00",
"score": 17.0,
"maxScore": 20.0,
"percent": 85.0,
"scaleLevel": "Average Knowledge",
"manualScoring": "notRequired",
"modified": "2025-01-15T20:08:41Z",
"participantData": [
{
"name": "First Name",
"value": "John"
},
{
"name": "Last Name",
"value": "Lennon"
},
{
"name": "Email",
"value": "lennon@gmail.com"
},
{
"name": "My Custom Field Name",
"value": "000000001"
}
]
},
{
"participantId": "041fc9b8-00b4-4c68-a5d7-c4b39f269595",
"testId": "f2d23994-d989-4c6b-8e47-ca4e364d9703",
"testTitle": "MBA Examination",
"started": "2025-01-15T20:08:41Z",
"isFinished": false,
"autoClosed": false,
"elapsedTime": null,
"score": null,
"maxScore": null,
"percent": null,
"scaleLevel": null,
"manualScoring": "required",
"modified": "2025-01-15T20:08:41Z",
"participantData": [
{
"name": "First Name",
"value": "Frank"
},
{
"name": "Last Name",
"value": "Sinatra"
},
{
"name": "Email",
"value": "frank@sinatra.com"
},
{
"name": "My Custom Field Name",
"value": "000000002"
}
]
}
]
}
HTTP/1.1 200 OK
Content-Type: application/json; charset=utf-8
Content-Length: 91
{
"modifiedUntil": "2025-01-16T05:08:41Z",
"continuationToken": null,
"results": []
}