Endpoint Wi-Fi Management REST API Reference
Use the Endpoint Wi-Fi Management REST API to define Wi-Fi network configurations and assign them to an endpoint. In Alexa Smart Properties (ASP), an endpoint represents an Alexa-connected device or component with which an ASP resident can interact, such as Amazon Echo devices or Alexa-connected lights. Often property owners set up a device on a default Wi-Fi network, and then use these operations to assign additional Wi-Fi networks to a device. For Wi-Fi Protected Access 2 (WPA2) Enterprise Wi-Fi, you must associate the WPA2 Extensible Authentication Protocol (EAP) network with a device after device setup.
To assign Wi-Fi network configurations to an endpoint, invoke these operations in the following order:
- Save Wi-Fi configurations to the Amazon Wi-Fi locker for your account.
- Assign one or more of the saved Wi-Fi configurations to an endpoint.
During this step, make sure that the endpoint is online. - (Optional) Get the status of the configuration assignment.
You use the Endpoint Wi-Fi Management API along with the Endpoints REST API to view and change settings on devices owned by your Amazon Business account.
API endpoints
Based on the country of your organization, set the Host
parameter in the request header to one of the following API endpoints.
Country | Endpoint |
---|---|
CA, US |
|
DE, ES, FR, IT, UK |
|
JP |
|
Authentication
Each API request must have an authorization header whose value is the access token retrieved from Login with Amazon (LWA). For details, see Manage API Access.
To use the Endpoint Wi-Fi Management API, request your LWA token with the following scopes:
credential_locker::wifi_management
alexa::enterprise:management
Operations
The Endpoint Features API includes the following operations.
Operation | HTTP method and URI |
---|---|
| |
| |
| |
| |
|
Forget Wi-Fi configuration
Delete the Wi-Fi configuration from the specified endpoint. To forget a Wi-Fi configuration, the device must be online and have at least two Wi-Fi network configurations assigned to the endpoint. If there is one Wi-Fi configuration associated with the an endpoint, you can't delete the specified Wi-Fi configuration from the endpoint.
This operation is available in the following countries.
Healthcare | Hospitality | Senior Living | Core |
---|---|---|---|
None |
US, CA, UK, DE, FR, IT, ES, JP |
US, CA, UK, DE, FR, IT, ES, JP |
None |
Request
To delete a configuration, you make a POST
request to the /v2/endpoints/{endpointId}/features/connectivity/forgetWifiConfigurations
resource.
Request path and header example
POST /v2/endpoints/{endpointId}/features/connectivity/forgetWifiConfigurations
Host: api.amazonalexa.com
Accept: application/json
Authorization: Bearer {access token}
Request path and header parameters
Parameter | Located in | Description | Type | Required |
---|---|---|---|---|
|
Path |
Unique ID for this endpoint that Amazon assigns to each customer device. |
String |
Yes |
|
Header |
Access token for the customer. |
String |
Yes |
Request body example
{
"payload": {
"wifiConfigurations": [{
"ssid": "wifi-name.1",
"keyManagement": "WPAPSK"
}]
}
}
Request body properties
Property | Description | Type | Required |
---|---|---|---|
|
Contains the Wi-Fi configurations to delete. |
Object |
Yes |
|
List of Wi-Fi configurations. |
Array of objects |
Yes |
|
Wi-Fi network name. Note: Delimiting the
ssid is a requirement for the Save Wi-Fi configurations and Set Wi-Fi configuration operations, but not for the Forget Wi-Fi configuration operation. |
String |
Yes |
|
Wi-Fi configuration security type.
|
String |
Yes |
Response
A successful response returns HTTP 200 OK
.
On error, the response returns the appropriate HTTP status code and includes a response body with an Error object.
Response body example
The response has no body.
Response body properties
The response has no body.
HTTP status codes
Status | Description |
---|---|
|
Specified Wi-Fi configuration deleted from the device successfully. |
|
Indicates that one or more properties in the request body aren't valid.
|
|
Request didn't include the authorization token, or the included token expired or isn't valid. Or, you don't have access to the resource. |
|
Indicates that the authorization token is valid, but the requested operation isn't allowed. |
|
Requested resource not found.
|
|
Permitted rate limit, specified as the number of requests per unit of time, exceeded. You can retry the request by using exponential back-off. |
|
Error occurred on the server. You can retry the request by using exponential back-off. |
|
Server is down for maintenance, overloaded, or otherwise unavailable to handle the incoming request. |
|
No response from the endpoint.
|
Get Wi-Fi installation status
Get the status of a previous Set Wi-Fi configuration
operation on the specified endpoint.
This operation is available in the following countries.
Healthcare | Hospitality | Senior Living | Core |
---|---|---|---|
US |
US, CA, UK, DE, FR, IT, ES, JP |
US, CA, UK, DE, FR, IT, ES, JP |
US |
Request
To get the status, you make a GET
request to the /v2/endpoints/{endpointId}/features/connectivity/addOrUpdateWifiConfigurations/submittedOperations
resource.
Request path and header example
GET /v2/endpoints/{endpointId}/features/connectivity/addOrUpdateWifiConfigurations/submittedOperations/{operationId}
Host: api.amazonalexa.com
Content-Type: application/json
Authorization: Bearer {access token}
Accept: application/json
Request path and header parameters
Parameter | Located in | Description | Type | Required |
---|---|---|---|---|
|
Path |
Unique ID for this endpoint that Amazon assigns to each customer device. |
String |
Yes |
|
Path |
Unique |
String |
Yes |
|
Header |
Access token for the customer. |
String |
Yes |
Request body example
The request has no body.
Request body properties
The request has no body.
Response
A successful response returns HTTP 200 OK
, along with the status of the Wi-Fi configuration installation.
On error, the response returns the appropriate HTTP status code and includes a response body with an Error object.
Response body example
{
"status": {
"value": "IN_PROGRESS"
}
}
Response body properties
Property | Description | Type |
---|---|---|
|
Identifies the status of the requested Wi-Fi configuration installation for the specified endpoint. |
Object |
|
Operation status value. |
String |
HTTP status codes
Status | Description |
---|---|
|
Response body contains the current status of the Wi-Fi configuration installation. |
|
The endpoint ID has changed, but the underlying resource is still the same. The response body contains a URI reference for the new endpoint ID, for example, |
|
The endpoint ID has changed, but the underlying resource is still the same. The response body contains a URI reference for the new endpoint ID, for example, |
|
The endpoint has been merged with another, causing the underlying resource to change. The response body contains a URI reference for the new endpoint ID, for example, |
|
Indicates that one or more properties in the request body aren't valid. |
|
Request didn't include the authorization token, or the included token expired or isn't valid. Or, you don't have access to the resource. |
|
Indicates that the authorization token is valid, but the requested operation isn't allowed. |
|
Requested resource not found.
|
|
Permitted rate limit, specified as the number of requests per unit of time, exceeded. You can retry the request by using exponential back-off. |
|
Error occurred on the server. You can retry the request by using exponential back-off. |
|
Server is down for maintenance, overloaded, or otherwise unavailable to handle the incoming request. |
|
No response from the endpoint.
|
List Wi-Fi configurations
Get the list of Wi-Fi configurations assigned to the specified endpoint. To list the Wi-Fi configurations, the device must be online.
Request
To list configurations, you make a GET
request to the /v2/endpoints/{endpointId}/features/connectivity/wifiConfigurations
resource.
Request path and header example
GET /v2/endpoints/{endpointId}/features/connectivity/wifiConfigurations
Host: api.amazonalexa.com
Accept: application/json
Authorization: Bearer {access token}
Request path and header parameters
Parameter | Located in | Description | Type | Required |
---|---|---|---|---|
|
Path |
Unique ID for this endpoint that Amazon assigns to each customer device. |
String |
Yes |
|
Header |
Access token for the customer. |
String |
Yes |
Request body example
The request has no body.
Request body properties
The request has no body.
Response
A successful response returns HTTP 200 OK
, along with a list of the Wi-Fi configurations.
On error, the response returns the appropriate HTTP status code and includes a response body with an Error object.
Response body example
{
"wifiConfigurations": [{
"connectivityStatus": "CONNECTED",
"keyManagement": "OPEN",
"ssid": "wifi-name.1"
},
{
"connectivityStatus": "NOT_CONNECTED",
"keyManagement": "WPA2_PSK",
"ssid": "wifi-name.2"
}
]
}
Response body properties
Property | Description | Type |
---|---|---|
|
List of Wi-Fi configurations saved to the endpoint. |
Array of objects |
|
Indicates the connection status of the endpoint to this Wi-Fi network. |
String |
|
Wi-Fi configuration security type.
|
String |
|
Wi-Fi network name. |
String |
HTTP status codes
Status | Description |
---|---|
|
Response body contains a list of the Wi-Fi configurations associated with the specified endpoint. |
|
Indicates that one or more properties in the request body aren't valid. |
|
Request didn't include the authorization token, or the included token expired or isn't valid. Or, you don't have access to the resource. |
|
Indicates that the authorization token is valid, but the requested operation isn't allowed. |
|
Requested resource not found.
|
|
Permitted rate limit, specified as the number of requests per unit of time, exceeded. You can retry the request by using exponential back-off. |
|
Error occurred on the server. You can retry the request by using exponential back-off. |
|
Server is down for maintenance, overloaded, or otherwise unavailable to handle the incoming request. |
|
No response from the endpoint.
|
Save Wi-Fi configurations
Save Wi-Fi configurations to the Amazon Wi-Fi locker for your account. Later, you assign one or more of these configurations to endpoints with the Set Wi-Fi configuration
operation.
To use a network with a hidden Service Set Identifier (SSID), configure the network with the hidden SSID before you save the Wi-Fi configuration.
This operation is available in the following countries.
Healthcare | Hospitality | Senior Living | Core |
---|---|---|---|
US |
US, CA, DE, ES, FR, IT, UK, JP |
US, CA, DE, ES, FR, IT, UK, JP |
US |
Request
To save Wi-Fi configurations, you make a POST
request to the /credentiallocker/v2/saveWifiConfigurations
resource.
API endpoints
Based on the country of your organization, set the Host
parameter in the request header to one of the following API endpoints.
Country | Endpoint |
---|---|
CA, US |
|
DE, ES, FR, IT, UK |
|
JP |
|
Request path and header example
POST /credentiallocker/v2/saveWifiConfigurations
Host: credential-locker-service.amazon.com
x-amz-access-token: {access token}
Content-Type: application/json
Authorization: Bearer {access token}
Request path and header parameters
Parameter | Located in | Description | Type | Required |
---|---|---|---|---|
|
Header |
Access token for the customer. |
String |
Yes |
Request body example
The follow example shows a Wi-Fi configuration that uses Wi-Fi Protected Access 2 (WPA2) with a shared key (WPAPSK) for network access.
The follow example shows a Wi-Fi configuration that uses WPA2_EAP with certificates for enterprise network access.
Request body properties
Field | Description | Type | Required |
---|---|---|---|
|
List of Wi-Fi configurations to save. |
Array of objects |
Yes |
|
Wi-Fi network name. |
String |
Yes |
|
Wi-Fi configuration security type.
|
String |
Yes |
|
Credential information for the Wi-Fi network. |
|
Yes |
Response
A successful response returns HTTP 200 OK
.
On error, the response returns the appropriate HTTP status code and includes a response body with an Error object.
Response body example
The response has no body.
Response body properties
The response has no body.
HTTP status codes
Status | Description |
---|---|
|
Wi-Fi configurations saved successfully. |
|
Indicates that one or more properties in the request body aren't valid.
|
|
Request didn't include the authorization token, or the included token expired or isn't valid. Or, you don't have access to the resource. |
|
Indicates that the authorization token is valid, but the requested operation isn't allowed. |
|
Requested resource not found.
|
|
Permitted rate limit, specified as the number of requests per unit of time, exceeded. You can retry the request by using exponential back-off. |
|
Error occurred on the server. You can retry the request by using exponential back-off. |
|
Server is down for maintenance, overloaded, or otherwise unavailable to handle the incoming request. |
|
No response from the endpoint.
|
Set Wi-Fi configuration
Associate a saved Wi-Fi configuration with the specified endpoint. To save the Wi-Fi configuration to the device, the endpoint must be online. You can associate up to 32 Wi-Fi configurations with a single endpoint, one configuration at a time.
During normal operation, the endpoint tries to connect to one of the Wi-Fi networks assigned to the device. If a Wi-Fi network becomes unavailable, the device might go offline, but eventually connects to an available Wi-Fi network.
Save Wi-Fi configuration
operation. After you save the configuration, you can associate the saved configuration with the endpoint.This operation is available in the following countries.
Healthcare | Hospitality | Senior Living | Core |
---|---|---|---|
None |
US, CA, UK, DE, FR, IT, ES, JP |
US, CA, UK, DE, FR, IT, ES, JP |
None |
Request
To set a Wi-Fi configuration, you make a POST
request to the /v2/endpoints/{endpointId}/features/connectivity/addOrUpdateWifiConfigurations
resource.
Request path and header example
POST /v2/endpoints/{endpointId}/features/connectivity/addOrUpdateWifiConfigurations
Host: api.amazonalexa.com
Content-Type: application/json
Authorization: Bearer {access token}
Request path and header parameters
Parameter | Located in | Description | Type | Required |
---|---|---|---|---|
|
Path |
Unique ID for this endpoint that Amazon assigns to each customer device. |
String |
Yes |
|
Header |
Access token for the customer. |
String |
Yes |
Request body example
{
"payload": {
"wifiConfigurations": [{
"ssid": "\"wifi-name.1\"",
"keyManagement": "WPAPSK"
}]
}
}
Request body properties
Field | Description | Type | Required |
---|---|---|---|
|
Contains the Wi-Fi configuration definition. |
Object |
Yes |
|
List of Wi-Fi configurations to add or update on the specified endpoint. |
Array of objects |
Yes |
|
Wi-Fi network name. |
String |
Yes |
|
Wi-Fi configuration security type.
|
String |
Yes |
Response
A successful response returns HTTP 200 OK
, along with the identifier to use to get the status of the Wi-Fi configuration installation.
On error, the response returns the appropriate HTTP status code and includes a response body with an Error object.
Response body example
{
"submittedOperationId": "operationId.1"
}
Response body properties
Property | Description | Type |
---|---|---|
|
Identifies the request to set the configuration for the endpoint. |
String |
HTTP status codes
Status | Description |
---|---|
|
Wi-Fi configurations added or updated on the specified endpoint successfully. |
|
Indicates that one or more properties in the request body aren't valid.
|
|
Request didn't include the authorization token, or the included token expired or isn't valid. Or, you don't have access to the resource. |
|
Indicates that the authorization token is valid, but the requested operation isn't allowed. |
|
Requested resource not found.
|
|
Permitted rate limit, specified as the number of requests per unit of time, exceeded. You can retry the request by using exponential back-off. |
|
Error occurred on the server. You can retry the request by using exponential back-off. |
|
Server is down for maintenance, overloaded, or otherwise unavailable to handle the incoming request. |
|
No response from the endpoint.
|
Object definitions
The Endpoint Wi-Fi Management API defines the following objects.
CertificateAuthority object
The CertificateAuthority
object identifies the certificate authority organization that creates and verifies digital certificates.
Property | Description | Type |
---|---|---|
|
Identifies the certificate authority organization. |
String |
|
Identifies the certificate authority resource within the provider system. |
String |
CredentialConfiguration object
The CredentialConfiguration
object defines the configuration of a Wi-Fi network.
Property | Description | Type |
---|---|---|
|
(Optional) Password for Wi-Fi network access, enclosed in double quotation marks. Required for |
String |
|
(Optional) Identifies the Extensible Authentication Protocol (EAP) for Wi-Fi network access. Required for |
String |
|
(Optional) Identifies the certificate authority. |
|
|
(Optional) List of certificates used to identify a trusted network. |
Array of strings |
Error object
The Error
object defines the error type and message included in the response when an error occurs.
The following example shows the response body with the error code and message.
{
"type": "BAD_REQUEST",
"message": "The request is malformed or is missing any required parameters."
}
Property | Description | Type |
---|---|---|
|
Type of error that occurred. |
String |
|
The error message appears only for debugging/logging purposes. You must not share it with the customer. No business logic should depend on the content of the error message. |
String |
Related topics
- Alexa Smart Properties REST API Reference
- Endpoints REST API Reference
- Endpoint Features REST API Reference
- Endpoint Settings REST API Reference
Last updated: Nov 25, 2024