Get all of an assessment's scores
Header Key | Description | Example |
---|---|---|
Authorization | The Authorization header for this endpoint. The value must be the token from the /v3/auth/tokens/get endpoint and given using the Bearer pattern. | Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJzdW... |
Name | Type | Description |
---|---|---|
assessmentId | string | The UUID of the assessment |
A successful response
Field Name | Type | Description |
---|---|---|
scores | array<object> | The scores in the assessment. |
curl \
-X GET "https://rest.eus.canaryspeech.com/v2/org/assessment/${ASSESSMENT_ID}/get-scores" \
-H "Authorization: Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJzdWIiOiIxMjM0NTY3ODkwIiwibmFtZSI6IkpvaG4gRG9lIiwiaWF0IjoxNTE2MjM5MDIyfQ.SflKxwRJSMeKKF2QT4fwpMeJf36POk6yJV_adQssw5c"
function getV2OrgAssessmentGetScores() {
const assessmentId = 'abc123';
const url = `https://rest.eus.canaryspeech.com/v2/org/assessment/${assessmentId}/get-scores`;
const headers = {
Authorization: 'Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJzdWIiOiIxMjM0NTY3ODkwIiwibmFtZSI6IkpvaG4gRG9lIiwiaWF0IjoxNTE2MjM5MDIyfQ.SflKxwRJSMeKKF2QT4fwpMeJf36POk6yJV_adQssw5c'
};
fetch(url, {
method: 'GET',
headers: headers
}).then((response) => {
if (!response.ok) throw new Error(response.status);
return response.json()
}).then((json) => {
const { scores } = json;
// ...
});
}
const https = require('https');
function getV2OrgAssessmentGetScores() {
const assessmentId = 'abc123';
const headers = {
Authorization: 'Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJzdWIiOiIxMjM0NTY3ODkwIiwibmFtZSI6IkpvaG4gRG9lIiwiaWF0IjoxNTE2MjM5MDIyfQ.SflKxwRJSMeKKF2QT4fwpMeJf36POk6yJV_adQssw5c'
};
const options = {
hostname: 'rest.eus.canaryspeech.com',
port: 443,
path: `/v2/org/assessment/${assessmentId}/get-scores`,
method: 'GET',
headers: headers
};
const request = https.request(options, (response) => {
if (response.statusCode !== 200) throw new Error(response.statusCode);
response.on('data', (d) => {
const { scores } = JSON.parse(d);
// ...
});
});
request.on('error', (err) => {
throw new Error(err);
});
request.end();
}
const axios = require('axios').default;
async function getV2OrgAssessmentGetScores() {
const assessmentId = 'abc123';
const url = `https://rest.eus.canaryspeech.com/v2/org/assessment/${assessmentId}/get-scores`;
const headers = {
Authorization: 'Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJzdWIiOiIxMjM0NTY3ODkwIiwibmFtZSI6IkpvaG4gRG9lIiwiaWF0IjoxNTE2MjM5MDIyfQ.SflKxwRJSMeKKF2QT4fwpMeJf36POk6yJV_adQssw5c'
};
const response = await axios.get(url, { headers });
if (response.status !== 200) throw new Error(response.status);
const { scores } = response.data;
// ...
}
import * as https from 'https';
function getV2OrgAssessmentGetScores(): void {
const assessmentId = 'abc123';
const headers = {
Authorization: 'Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJzdWIiOiIxMjM0NTY3ODkwIiwibmFtZSI6IkpvaG4gRG9lIiwiaWF0IjoxNTE2MjM5MDIyfQ.SflKxwRJSMeKKF2QT4fwpMeJf36POk6yJV_adQssw5c'
};
const options = {
hostname: 'rest.eus.canaryspeech.com',
port: 443,
path: `/v2/org/assessment/${assessmentId}/get-scores`,
method: 'GET',
headers: headers
};
const request = https.request(options, (response) => {
if (response.statusCode !== 200) throw new Error(response.statusCode);
response.on('data', (d) => {
const { scores } = JSON.parse(d) as Record<string, unknown>;
// ...
});
});
request.on('error', (err) => {
throw new Error(err);
});
request.end();
}
import axios from 'axios';
async function getV2OrgAssessmentGetScores(): Promise<void> {
const assessmentId = 'abc123';
const url = `https://rest.eus.canaryspeech.com/v2/org/assessment/${assessmentId}/get-scores`;
const headers = {
Authorization: 'Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJzdWIiOiIxMjM0NTY3ODkwIiwibmFtZSI6IkpvaG4gRG9lIiwiaWF0IjoxNTE2MjM5MDIyfQ.SflKxwRJSMeKKF2QT4fwpMeJf36POk6yJV_adQssw5c'
};
const response = await axios.get(url, { headers });
if (response.status !== 200) throw new Error(response.status);
const { scores } = response.data;
// ...
}
import requests
def get_v2_org_assessment_get_scores():
assessment_id = 'abc123'
url = f'https://rest.eus.canaryspeech.com/v2/org/assessment/{assessment_id}/get-scores'
headers = {
'Authorization': 'Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJzdWIiOiIxMjM0NTY3ODkwIiwibmFtZSI6IkpvaG4gRG9lIiwiaWF0IjoxNTE2MjM5MDIyfQ.SflKxwRJSMeKKF2QT4fwpMeJf36POk6yJV_adQssw5c'
}
response = requests.get(
url,
headers=headers,
)
if response.status_code !== 200:
raise Exception(response.status_code)
response_obj = response.json()
scores = response_obj['scores']
# ...
import org.json.simple.JSONObject;
import org.json.simple.JSONArray;
import org.json.simple.JSONParser;
import org.json.simple.JSONValue;
import java.net.http.HttpClient;
import java.net.http.HttpRequest;
import java.net.http.HttpRequest.BodyPublishers;
import java.net.http.HttpResponse;
import java.net.http.HttpResponse.BodyHandlers;
import java.nio.charset.StandardCharsets;
import java.util.List;
import java.util.Map;
public class CanarySpeechApi {
public void getV2OrgAssessmentGetScores() {
final String assessmentId = "abc123"
URI uri = new URI("https://rest.eus.canaryspeech.com/v2/org/assessment/" + assessmentId + "/get-scores");
HttpRequest request = HttpRequest.newBuilder()
.uri(uri)
.version(HttpClient.Version.HTTP_2)
.header("Authorization", "Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJzdWIiOiIxMjM0NTY3ODkwIiwibmFtZSI6IkpvaG4gRG9lIiwiaWF0IjoxNTE2MjM5MDIyfQ.SflKxwRJSMeKKF2QT4fwpMeJf36POk6yJV_adQssw5c")
.GET()
.build();
HttpClient client = HttpClient.newBuilder()
.version(HttpClient.Version.HTTP_1_1)
.build();
HttpResponse<String> response = client.send(request, BodyHandlers.ofString());
if (client.status != 200) {
throw new Exception(client.status.toString());
}
JSONParser parser = new JSONParser();
JSONObject responseBody = (JSONObject) parser.parse(client.body());
List<Object> scores = (List<Object>) responseBody.get("scores");
// ...
}
}
import org.json.JSONObject
import java.lang.StringBuilder
import java.net.URL
import javax.net.ssl.HttpsURLConnection
suspend fun getV2OrgAssessmentGetScores() = runCatching {
val assessmentId = "abc123"
val url = URL.create("https://rest.eus.canaryspeech.com/v2/org/assessment/"${assessmentId}"/get-scores")
with(url.openConnection() as HttpsURLConnection) {
requestMethod = "GET"
instanceFollowRedirects = true
setRequestProperty("Authorization", "Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJzdWIiOiIxMjM0NTY3ODkwIiwibmFtZSI6IkpvaG4gRG9lIiwiaWF0IjoxNTE2MjM5MDIyfQ.SflKxwRJSMeKKF2QT4fwpMeJf36POk6yJV_adQssw5c")
doOutput = true
if (responseCode != 200) throw Error(responseMessage)
val buffer = StringBuilder()
var line: String?
inputStream.bufferedReader(Charsets.UTF-8).use {
do {
line = it.readLine()
if (line != null) buffer.appendLine(line)
} while (line != null)
}
val responseBody = JSONObject(buffer.toString())
val scores = responseBody.get("scores") as Array<Object>
// ...
}
}
import UIKit
func getV2OrgAssessmentGetScores() -> void {
let assessmentId = "abc123"
let url = URL("https://rest.eus.canaryspeech.com/v2/org/assessment/\(assessmentId)/get-scores")
let headers: [String: String] = [
"Authorization": "Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJzdWIiOiIxMjM0NTY3ODkwIiwibmFtZSI6IkpvaG4gRG9lIiwiaWF0IjoxNTE2MjM5MDIyfQ.SflKxwRJSMeKKF2QT4fwpMeJf36POk6yJV_adQssw5c"
]
var request = URLRequest(url: url)
request.httpMethod = "GET"
request.allHTTPHeaderFields = headers
let task = URLSession.shared.dataTask(with: request) { data, response, error in
guard
let data = data,
let response = response as? HTTPURLResponse,
error == nil
else {
print("error", error ?? URLError(.badServerResponse)
return
}
guard (200 ... 299) ~= response.statusCode else {
print("statusCode = \(response.statusCode)")
print("response = \(response)")
return
}
do {
let responseObj = try JSONDecoder().decode(GetV2OrgAssessmentGetScoresResponse.self, data)
// ...
} catch {
print(error)
}
}
}
}
struct GetV2OrgAssessmentGetScoresResponse: Decodable {
let scores: [undefined]
}
using System.Collections.Generic;
using System.Net.Http;
using System.Text.Encoding;
using System.Text.Json;
using System.Text.Json.Serialization;
public static class CanarySpeechAPI
{
public static readonly HttpClient client = new HttpClient();
public static async Task getV2OrgAssessmentGetScores()
{
var assessmentId = "abc123";
var url = "https://rest.eus.canaryspeech.com/v2/org/assessment/${assessmentId}/get-scores\"";
var request = new HttpRequestMessage(HttpMethod.Get, url);
request.Headers.Add("Authorization", "Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJzdWIiOiIxMjM0NTY3ODkwIiwibmFtZSI6IkpvaG4gRG9lIiwiaWF0IjoxNTE2MjM5MDIyfQ.SflKxwRJSMeKKF2QT4fwpMeJf36POk6yJV_adQssw5c");
var response = await client.SendAsync(request);
response.EnsureSuccessStatusCode();
var responseBody = await response.Content.ReadAsStringAsync();
var responseJson = JsonConvert.DeserializeObject<Dictionary<string, dynamic>>(responseBody);
var scores = (List<undefined>)responseJson["scores"];
// ...
}
}
import 'dart:convert';
import 'package:http/http.dart' as http;
Future<void> function getV2OrgAssessmentGetScores() async {
final assessmentId = 'abc123';
final uri = Uri.https('rest.eus.canaryspeech.com', 'v2/org/assessment/$assessmentId/get-scores', queryParams);
final headers = {
'Authorization': 'Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJzdWIiOiIxMjM0NTY3ODkwIiwibmFtZSI6IkpvaG4gRG9lIiwiaWF0IjoxNTE2MjM5MDIyfQ.SflKxwRJSMeKKF2QT4fwpMeJf36POk6yJV_adQssw5c'
};
final request = http.Request('GET', uri);
request.headers.addAll(headers)
final client = http.Client();
try {
final responseStream = await client.send(request);
final statusCode = responseStream.statusCode;
if (statusCode < 200 || statusCode >= 300) {
throw Error(statusCode.toString());
}
final responseBytes = await responseStream.stream.toBytes();
final responseString = utf8.decode(responseBytes);
final response = json.decode(responseString);
final scores = response['scores'] as List<dynamic>;
// ...
} catch (e) {
print(e);
}
}
Name | Type | Description |
---|---|---|
uuid | uuid | The uuid of the score. |
assessmentUUIDs | array<string> | The list of parent assessments associated with this score. |
dateRecorded | date-time | The ISO-8601 timestamp of when the child score was recorded. |
scoreId | string | The ID of the question as defined in the survey JSON that corresponds to this score. |
scoreType | string | The type of the question as defined in the survey JSON. |
scoreData | object | The data of the score. If the scoreType starts with "OVERSEER", this object will have a "data" field. Otherwise, it will have a "value" field. |
extraData | object | Any additional optional metadata of the child score. |