Creates a subject. There is a limit on the number of subjects per project.
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... |
Content-Type | The content type for this request. | application/json |
Name | Type | Description |
---|---|---|
* projectId | uuid | The project ID under which the subject should be created. |
* name | string | The name for the subject. |
firstName | string | |
middleName | string | |
lastName | string | |
prefix | string | |
suffix | string | |
alias | string | |
dateOfBirth | string | |
string | ||
phoneNumber | string |
A successful response
Field Name | Type | Description |
---|---|---|
id | uuid | The ID of the subject. |
curl \
-X POST "https://rest.eus.canaryspeech.com/v3/api/create-subject" \
-H "Authorization: Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJzdWIiOiIxMjM0NTY3ODkwIiwibmFtZSI6IkpvaG4gRG9lIiwiaWF0IjoxNTE2MjM5MDIyfQ.SflKxwRJSMeKKF2QT4fwpMeJf36POk6yJV_adQssw5c" \
-H "Content-Type: application/json" \
-d "{ \"projectId\": \"12345678-1234-abcd-5678-12345678\", \"name\": \"abc123\" }"
function postV3ApiCreateSubject() {
const url = 'https://rest.eus.canaryspeech.com/v3/api/create-subject';
const headers = {
Authorization: 'Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJzdWIiOiIxMjM0NTY3ODkwIiwibmFtZSI6IkpvaG4gRG9lIiwiaWF0IjoxNTE2MjM5MDIyfQ.SflKxwRJSMeKKF2QT4fwpMeJf36POk6yJV_adQssw5c',
'Content-Type': 'application/json'
};
const body = { projectId: '12345678-1234-abcd-5678-12345678', name: 'abc123' };
fetch(url, {
method: 'POST',
headers: headers,
body: JSON.stringify(body)
}).then((response) => {
if (!response.ok) throw new Error(response.status);
return response.json()
}).then((json) => {
const { id } = json;
// ...
});
}
const https = require('https');
function postV3ApiCreateSubject() {
const headers = {
Authorization: 'Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJzdWIiOiIxMjM0NTY3ODkwIiwibmFtZSI6IkpvaG4gRG9lIiwiaWF0IjoxNTE2MjM5MDIyfQ.SflKxwRJSMeKKF2QT4fwpMeJf36POk6yJV_adQssw5c',
'Content-Type': 'application/json'
};
const body = { projectId: '12345678-1234-abcd-5678-12345678', name: 'abc123' };
const options = {
hostname: 'rest.eus.canaryspeech.com',
port: 443,
path: '/v3/api/create-subject',
method: 'POST',
headers: headers
};
const request = https.request(options, (response) => {
if (response.statusCode !== 200) throw new Error(response.statusCode);
response.on('data', (d) => {
const { id } = JSON.parse(d);
// ...
});
});
request.on('error', (err) => {
throw new Error(err);
});
request.write(JSON.stringify(body));
request.end();
}
const axios = require('axios').default;
async function postV3ApiCreateSubject() {
const url = 'https://rest.eus.canaryspeech.com/v3/api/create-subject';
const headers = {
Authorization: 'Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJzdWIiOiIxMjM0NTY3ODkwIiwibmFtZSI6IkpvaG4gRG9lIiwiaWF0IjoxNTE2MjM5MDIyfQ.SflKxwRJSMeKKF2QT4fwpMeJf36POk6yJV_adQssw5c',
'Content-Type': 'application/json'
};
const body = { projectId: '12345678-1234-abcd-5678-12345678', name: 'abc123' };
const response = await axios.post(url, body, { headers });
if (response.status !== 200) throw new Error(response.status);
const { id } = response.data;
// ...
}
import * as https from 'https';
function postV3ApiCreateSubject(): void {
const headers = {
Authorization: 'Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJzdWIiOiIxMjM0NTY3ODkwIiwibmFtZSI6IkpvaG4gRG9lIiwiaWF0IjoxNTE2MjM5MDIyfQ.SflKxwRJSMeKKF2QT4fwpMeJf36POk6yJV_adQssw5c',
'Content-Type': 'application/json'
};
const body = { projectId: '12345678-1234-abcd-5678-12345678', name: 'abc123' };
const options = {
hostname: 'rest.eus.canaryspeech.com',
port: 443,
path: '/v3/api/create-subject',
method: 'POST',
headers: headers
};
const request = https.request(options, (response) => {
if (response.statusCode !== 200) throw new Error(response.statusCode);
response.on('data', (d) => {
const { id } = JSON.parse(d) as Record<string, unknown>;
// ...
});
});
request.on('error', (err) => {
throw new Error(err);
});
request.write(JSON.stringify(body));
request.end();
}
import axios from 'axios';
async function postV3ApiCreateSubject(): Promise<void> {
const url = 'https://rest.eus.canaryspeech.com/v3/api/create-subject';
const headers = {
Authorization: 'Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJzdWIiOiIxMjM0NTY3ODkwIiwibmFtZSI6IkpvaG4gRG9lIiwiaWF0IjoxNTE2MjM5MDIyfQ.SflKxwRJSMeKKF2QT4fwpMeJf36POk6yJV_adQssw5c',
'Content-Type': 'application/json'
};
const body = { projectId: '12345678-1234-abcd-5678-12345678', name: 'abc123' };
const response = await axios.post(url, body, { headers });
if (response.status !== 200) throw new Error(response.status);
const { id } = response.data;
// ...
}
import requests
def post_v3_api_create_subject():
url = 'https://rest.eus.canaryspeech.com/v3/api/create-subject'
headers = {
'Authorization': 'Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJzdWIiOiIxMjM0NTY3ODkwIiwibmFtZSI6IkpvaG4gRG9lIiwiaWF0IjoxNTE2MjM5MDIyfQ.SflKxwRJSMeKKF2QT4fwpMeJf36POk6yJV_adQssw5c',
'Content-Type': 'application/json'
}
body = {
'projectId': '12345678-1234-abcd-5678-12345678',
'name': 'abc123'
}
response = requests.post(
url,
headers=headers,
data=body,
)
if response.status_code !== 200:
raise Exception(response.status_code)
response_obj = response.json()
id = response_obj['id']
# ...
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 postV3ApiCreateSubject() {
URI uri = new URI("https://rest.eus.canaryspeech.com/v3/api/create-subject");
JSONObject body = new JSONObject();
body.put("projectId", "12345678-1234-abcd-5678-12345678");
body.put("name", "abc123");
byte[] bodyBytes = JSONValue.toJSONString(body).getBytes(StandardCharsets.UTF_8);
HttpRequest request = HttpRequest.newBuilder()
.uri(uri)
.version(HttpClient.Version.HTTP_2)
.header("Authorization", "Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJzdWIiOiIxMjM0NTY3ODkwIiwibmFtZSI6IkpvaG4gRG9lIiwiaWF0IjoxNTE2MjM5MDIyfQ.SflKxwRJSMeKKF2QT4fwpMeJf36POk6yJV_adQssw5c")
.header("Content-Type", "application/json")
.POST(BodyPublishers.ofByteArray(bodyBytes))
.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());
String id = (String) responseBody.get("id");
// ...
}
}
import org.json.JSONObject
import java.lang.StringBuilder
import java.net.URL
import javax.net.ssl.HttpsURLConnection
suspend fun postV3ApiCreateSubject() = runCatching {
val url = URL.create("https://rest.eus.canaryspeech.com/v3/api/create-subject")
with(url.openConnection() as HttpsURLConnection) {
requestMethod = "POST"
instanceFollowRedirects = true
setRequestProperty("Authorization", "Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJzdWIiOiIxMjM0NTY3ODkwIiwibmFtZSI6IkpvaG4gRG9lIiwiaWF0IjoxNTE2MjM5MDIyfQ.SflKxwRJSMeKKF2QT4fwpMeJf36POk6yJV_adQssw5c")
setRequestProperty("Content-Type", "application/json")
doInput = true
setChunkedStreamingMode(0)
val body = JSONObject()
body.put("projectId", String("12345678-1234-abcd-5678-12345678"))
body.put("name", String("abc123"))
outputStream.bufferedWriter(Charsets.UTF_8).use {
it.write(body.toString())
it.flush()
}
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 id = responseBody.get("id") as String
// ...
}
}
import UIKit
func postV3ApiCreateSubject() -> void {
let url = URL("https://rest.eus.canaryspeech.com/v3/api/create-subject")
let headers: [String: String] = [
"Authorization": "Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJzdWIiOiIxMjM0NTY3ODkwIiwibmFtZSI6IkpvaG4gRG9lIiwiaWF0IjoxNTE2MjM5MDIyfQ.SflKxwRJSMeKKF2QT4fwpMeJf36POk6yJV_adQssw5c",
"Content-Type": "application/json"
]
let body: [String: Any] = [ "projectId": "12345678-1234-abcd-5678-12345678", "name": "abc123" ]
var request = URLRequest(url: url)
request.httpMethod = "POST"
request.allHTTPHeaderFields = headers
request.httpBody = JSONEncoder().encode(body)
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(PostV3ApiCreateSubjectResponse.self, data)
// ...
} catch {
print(error)
}
}
}
}
struct PostV3ApiCreateSubjectResponse: Decodable {
let id: String
}
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 postV3ApiCreateSubject()
{
var url = "https://rest.eus.canaryspeech.com/v3/api/create-subject\"";
var body = new Dictionary<string, dynamic> {
{ "projectId": "12345678-1234-abcd-5678-12345678" },
{ "name": "abc123"
};
var bodyString = JsonConvert.Serialize(body);
var request = new HttpRequestMessage(HttpMethod.Post, url);
request.Headers.Add("Authorization", "Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJzdWIiOiIxMjM0NTY3ODkwIiwibmFtZSI6IkpvaG4gRG9lIiwiaWF0IjoxNTE2MjM5MDIyfQ.SflKxwRJSMeKKF2QT4fwpMeJf36POk6yJV_adQssw5c");
request.Headers.Add("Content-Type", "application/json");
request.Content = new ByteArrayContent(Encoding.UTF8.GetBytes(bodyString));
var response = await client.SendAsync(request);
response.EnsureSuccessStatusCode();
var responseBody = await response.Content.ReadAsStringAsync();
var responseJson = JsonConvert.DeserializeObject<Dictionary<string, dynamic>>(responseBody);
var id = (String)responseJson["id"];
// ...
}
}
import 'dart:convert';
import 'package:http/http.dart' as http;
Future<void> function postV3ApiCreateSubject() async {
final uri = Uri.https('rest.eus.canaryspeech.com', 'v3/api/create-subject', queryParams);
final headers = {
'Authorization': 'Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJzdWIiOiIxMjM0NTY3ODkwIiwibmFtZSI6IkpvaG4gRG9lIiwiaWF0IjoxNTE2MjM5MDIyfQ.SflKxwRJSMeKKF2QT4fwpMeJf36POk6yJV_adQssw5c',
'Content-Type': 'application/json'
};
final body = { 'projectId': '12345678-1234-abcd-5678-12345678', 'name': 'abc123' };
final request = http.Request('POST', uri);
request.headers.addAll(headers)
request.body = json.encode(body);
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 id = response['id'] as String;
// ...
} catch (e) {
print(e);
}
}