You would want to use this dataset so that you can access raw data from Learnosity to perform your own custom data analysis and reporting.
See Implementing and Creating Datasets for Download or Reporting for more information about datasets.
Usage
The format of requests to Data API use the following syntax:
https://data.learnosity.com/[LTS_VERSION]/reports/datasets
For example, to use the 2023.3.LTS version and the 'Initialize Dataset' endpoint, you would create a request like so:
https://data.learnosity.com/v2023.3.LTS/reports/datasets
Initialize dataset
Initialize a "sessions-summary-by-group"
dataset via the SET reports/datasets
endpoint. The following parameters are supported:
Endpoint | /[LTS_VERSION]/reports/datasets |
---|---|
HTTP Method | POST |
Action Type | set |
dataset_type string |
Specifies the type of dataset to initialize. Must be |
file_count int |
Number of group data files to accept during upload step. The response object will contain this many file URLs. Specify You would want to use this if your report is based on a large number of users and you prefer to split your user data into a number of smaller files. Maximum value is: |
filters object |
Specifies a set of filters for the report. You would want to use this to restrict the data returned based on a specific date and time range. See child attributes detailed below. |
filters.mintime string |
Filter to exclude sessions submitted before |
filters.maxtime string |
Filter to exclude sessions submitted after |
options object |
Object containing report configuration parameters, see attributes detailed below. |
options.default_sort_field string |
Define the default field used for sorting all group data in the dataset. Note: the named field must be present in fields. |
options.default_sort_order string |
Choose ascending or descending order for sorting group rows. Possible values:
Default: |
options.fields array |
List of fields to be calculated for all groups in the report. See the list of available fields. |
options.user_fields array |
List of data fields to show for each user in the report. See the list of available user fields. |
options.default_users_sort_field string |
Define the default field used for sorting all user data in the dataset. Note: the named field must be present in |
options.default_users_sort_order string |
Choose ascending or descending order for sorting users. Possible values:
Default: |
groups array[object] |
Define the group hierarchy that will format the presentation of report data. You must build an array of objects. Each object contains a |
Example
{
"dataset_type": "sessions-summary-by-group",
"file_count": 1,
"options": {
"default_sort_field": "mean_percent",
"default_sort_order": "desc",
"fields": [
"group_count",
"population",
"lowest_score",
"highest_score",
"mean_seen_activities",
"mean_attempted_percent",
"mean_score",
"median_score",
"p25_score",
"p75_score",
"p90_score",
"stddev_score",
"lowest_percent",
"highest_percent",
"mean_percent",
"median_percent",
"p25_percent",
"p75_percent",
"p90_percent",
"stddev_percent"
],
"default_users_sort_field": "score",
"default_users_sort_order": "desc",
"user_fields": [
"score",
"attempted_max_score",
"unscored_max_score",
"max_score",
"seen_activities"
]
},
"groups": [
{
"key": "district",
"label": "District"
},
{
"key": "school",
"label": "School"
},
{
"key": "class",
"label": "Class"
}
]
}
/* Example response:
{
"meta": {
"status": true,
"timestamp": 1483585276
},
"data": {
"dataset_id": "ce6c3842-5366-486d-a68f-ab9e6160e9de",
"input_files": [
"https://learnosity-reportdatasets-va.s3.amazonaws.com/reports/0034/sessions-summary-by-group/ce6c3842-5366-486d-a68f-ab9e6160e9de/infiles/0.ndjson?AWSAccessKeyId=AKIAJB5XQL2VQTD4KG6Q&Expires=1483588877&Signature=QUXjR0beW83bB7l1OpiTMOKRsKc%3D"
]
}
}
*/
Input file
For "sessions-summary-by-group"
datasets, upload one or more NDJSON input files containing user_id
, session_id
, and group_path
properties. The datasets implementation guide provides details on the upload process.
{"user_id": "ANONYMIZED_USER_001", "session_id": ["b867295a-174c-44ca-befa-de9f073575ca"], "group_path":["Simpson","Hogwarts School","7_slytherin"]}
{"user_id": "ANONYMIZED_USER_002", "session_id": ["4b1659d4-8a61-4edc-a233-c49732f365ce"], "group_path":["Simpson","Hogwarts School","7_slytherin"]}
{"user_id": "ANONYMIZED_USER_003", "session_id": ["f3dff73f-01c0-455c-918d-4d16fec0c171"], "group_path":["Simpson","Hogwarts School","7_slytherin"]}
{"user_id": "ANONYMIZED_USER_004", "session_id": ["8fc131b5-4fd8-4442-92f7-1226054b1776"], "group_path":["Simpson","Hogwarts School","7_gryffindor"]}
{"user_id": "ANONYMIZED_USER_005", "session_id": ["447909ec-624b-473c-8b2a-0dde5d76ba8b"], "group_path":["Simpson","Hogwarts School","7_gryffindor"]}
{"user_id": "ANONYMIZED_USER_006", "session_id": ["b8371baa-f490-481b-9de8-6ba69fac016c"], "group_path":["Simpson","Hogwarts School","7_gryffindor"]}
{"user_id": "ANONYMIZED_USER_007", "session_id": ["f3662052-5212-41fe-8588-ccb3a493d7bb"], "group_path":["Simpson","Hogwarts School","7_hufflepuff"]}
{"user_id": "ANONYMIZED_USER_008", "session_id": ["f1129577-f7b7-43e0-a23d-80c938bebe90"], "group_path":["Simpson","Hogwarts School","7_hufflepuff"]}
{"user_id": "ANONYMIZED_USER_009", "session_id": ["8f8960a7-49e4-49a5-a632-0c317dd3b6a3"], "group_path":["Simpson","Hogwarts School","7_hufflepuff"]}
{"user_id": "ANONYMIZED_USER_010", "session_id": ["1c66b0ed-2a95-48c2-b227-a5ae327772ab"], "group_path":["Simpson","Hogwarts School","7_ravenclaw"]}
{"user_id": "ANONYMIZED_USER_011", "session_id": ["5db92946-a16c-40af-a5ba-eac9b4d9189b"], "group_path":["Simpson","Hogwarts School","7_ravenclaw"]}
{"user_id": "ANONYMIZED_USER_012", "session_id": ["31689030-5fa1-44f2-8b6c-740d6e465ce5"], "group_path":["Walter","Shermer High School","7_vernon"]}
{"user_id": "ANONYMIZED_USER_013", "session_id": ["fe2eb5ac-b8c7-4464-bdae-a5c284066668"], "group_path":["Walter","Shermer High School","7_vernon"]}
{"user_id": "ANONYMIZED_USER_014", "session_id": ["d4ad04a5-e252-4d22-aba0-490319fd9d1a"], "group_path":["Walter","Padua High School","7_morgan"]}
{"user_id": "ANONYMIZED_USER_015", "session_id": ["95095fde-fdd7-44e9-ad0a-565ca285ab56"], "group_path":["Walter","Padua High School","7_morgan"]}
{"user_id": "ANONYMIZED_USER_016", "session_id": ["a4c8b47f-93d8-4602-a732-18cfa57de30c"], "group_path":["Walter","Padua High School","7_morgan"]}
Get dataset
Retrieves the URL of raw data files for a specified dataset. The endpoint returns pre-signed URLs for each group_path
listed in the request. Send an HTTP GET request to the pre-signed URL to retrieve a JSON file of raw aggregation data corresponding to that group_path
.
The ordering of the returned URLs corresponds to the ordering of the group_path
values passed in the request.
Note: the endpoint will return URLs for each of the given group_paths
even if the path does not exist within the dataset. However, accessing the URL for a non-existent path will return an HTTP status of 404.
Endpoint | /[LTS_VERSION]/reports/datasets |
---|---|
HTTP Method | POST |
Action Type | get |
dataset_id string |
The dataset to retrieve. |
dataset_type string |
The type of dataset identified by Must be |
group_paths array[array[object]] |
You must create an array to specify the group paths. The group paths controls the presentation of data at each level of the report. Each element of the array must be an array of strings containing See example structure below. |
Example
{
"dataset_type": "sessions-summary-by-group",
"dataset_id": "686b89d5-2911-4721-a6fc-7b43f57772aa",
"group_paths": [
[],
["Oregon"],
["Oregon", "Springfield Elementary"],
["Oregon", "Springfield Elementary", "Mrs Krabappel"],
["Oregon", "Springfield Elementary", "Ms Hoover"]
]
}
/* Example response:
{
"meta": {
"status": true,
"timestamp": 1474431536,
"records": 5
},
"data": [
"https://learnosity-reportdatasets-va.s3.amazonaws.com/reports/0034/sessions-summary-by-group/686b89d5-2911-4721-a6fc-7b43f57772aa/outfiles/d751713988987e9331980363e24189ce_1.json?AWSAccessKeyId=AKIAJUBLH5F2YDP6Z2QQ&Expires=1474435137&Signature=%2Bwgd77wOjBRFPQ41JohHb2hzLZU%3D",
"https://learnosity-reportdatasets-va.s3.amazonaws.com/reports/0034/sessions-summary-by-group/686b89d5-2911-4721-a6fc-7b43f57772aa/outfiles/8147ed71067cce9877dd043d5e98c1af_1.json?AWSAccessKeyId=AKIAJUBLH5F2YDP6Z2QQ&Expires=1474435137&Signature=l1GJ58bjT9yWWZIhFrKqRPYgoxI%3D",
"https://learnosity-reportdatasets-va.s3.amazonaws.com/reports/0034/sessions-summary-by-group/686b89d5-2911-4721-a6fc-7b43f57772aa/outfiles/8cea191c63343357ee28dcea89d80db2_1.json?AWSAccessKeyId=AKIAJUBLH5F2YDP6Z2QQ&Expires=1474435137&Signature=HeXt9M4ihps994zzc6L9C00Xg%2FI%3D",
"https://learnosity-reportdatasets-va.s3.amazonaws.com/reports/0034/sessions-summary-by-group/686b89d5-2911-4721-a6fc-7b43f57772aa/outfiles/25cebb8f9646cc5160decd7a04b57f68_1.json?AWSAccessKeyId=AKIAJUBLH5F2YDP6Z2QQ&Expires=1474435137&Signature=tTWr50j%2BlnDnNKrDFGkOZI3%2F7Ys%3D",
"https://learnosity-reportdatasets-va.s3.amazonaws.com/reports/0034/sessions-summary-by-group/686b89d5-2911-4721-a6fc-7b43f57772aa/outfiles/e065981af54ede481150c96e2ebfe79e_1.json?AWSAccessKeyId=AKIAJUBLH5F2YDP6Z2QQ&Expires=1474435137&Signature=q10lM9aSPYR%2B7q0GMz5q9f5MJFc%3D",
]
}
*/
Sample data file
Sending an HTTP GET request to a pre-signed URL from the response above will retrieve a JSON file with this structure:
{
"group_id": "c82cd9e95eddcb4f050257791cd73d97",
"group_name": "Springfield Elementary",
"group_path": [
"Oregon",
"Springfield Elementary"
],
"fields": [
"group_id",
"group_path",
"group_name",
"population",
"lowest_score",
"highest_score",
"mean_score",
"median_score",
"mean_percent",
"median_percent"
],
"sort_field": "population",
"sort_order": "desc",
"rows_per_page": 1000,
"rows_total": 2,
"self": [
"c82cd9e95eddcb4f050257791cd73d97",
[
"Oregon",
"Springfield Elementary"
],
"Springfield Elementary",
16,
2,
20,
11.37,
11,
56.875,
55
],
"rows": [
[
"d4130a365bfd812fcecdda69a1c81c2f",
[
"Oregon",
"Springfield Elementary",
"7_krabappel"
],
"7_krabappel",
9,
9,
20,
14.88,
14,
74.44444444444,
70
],
[
"84dea322f8946625a1b4e00fbfa10fb5",
[
"Oregon",
"Springfield Elementary",
"7_hoover"
],
"7_hoover",
7,
2,
17,
6.85,
6,
34.28571428571,
30
]
]
}
The contents of the JSON file are described below:
Attribute | Description |
---|---|
group_id string |
Autogenerated unique identifier for this group. |
group_name string |
User friendly name for the group. |
group_path array[string] |
An array of group names identifying the path of this group through the group hierarchy, starting with the top-level group name. |
fields array[string] |
Array of field names calculated for this group and for all groups in the dataset. |
self array[string] |
Summary row data for this group, containing an array of calculated aggregate values based on all users within this group. The values are ordered based on the fields array. |
rows array[array] |
Array of arrays. Each sub-array contains the calculated aggregate values for each child group of this group. The values in each sub-array are ordered to correspond to the order of fields specified within the fields array. |
rows_total int |
Total number of rows calculated for this group. Note: the actual size of |
rows_per_page int |
Maximum number of rows contained in this JSON file. Note: the actual size of |
sort_field string |
String denoting the field by which The field used to sort the data. The |
sort_order string |
String denoting the order by which rows is sorted; either The order of sorting that was applied to the data which can be either ascending ( The |
Reports API
Initialize Reports API with an sessions-summary-by-group
report object to explore the dataset via our interactive GUI, including drill down functionality. See the API documentation for the sessions-summary-by-group report type.
An example PHP implementation of Reports API using the Learnosity SDK:
<?php
include_once __DIR__ . "/vendor/autoload.php";
use LearnositySdk\Request\Init;
$domain = $_SERVER["SERVER_NAME"];
$security = [
"consumer_key" => CONSUMER_KEY,
"domain" => $domain,
"timestamp" => gmdate("Ymd-Hi"),
];
// build request
$request = [
"reports" => [
[
"id" => "report-01",
"type" => "sessions-summary-by-group",
"dataset_id" => "fb254347-23c3-40b4-b4e4-f79bda201109",
"group_path" => []
]
];
$Init = new Init("reports", $security, CONSUMER_SECRET, $request);
$signedRequest = $Init->generate();
?>
<html>
<head>
<title>Group Activity Reports</title>
</head>
<body>
<div id="report-01"></div>
<script src="//reports.learnosity.com"></script>
<script>
var initOptions = "<?php echo $signedRequest ?>";
var eventOptions = {};
var reportsApp = LearnosityReports.init(initOptions, eventOptions);
</script>
</body>
</html>