Skip to main content

Systemready API

The VAPIX® Systemready API makes it possible to find out, without authentication, if the Axis device is ready to handle external communication, configurations and video streaming on either the first or a consecutive boot up.

Overview

The API uses the systemready.cgi as its communication interface and supports the following methods:

MethodsDescription
systemreadyQuery to check if the system is ready.
getSupportedVersionsRetrieve a list of supported API versions.

Identification

  • API Discovery: id=systemready
  • Firmware: 9.50 and later

Obsoletes

This CGI replaces polling of APIs such as getBrandInfo, which were used determine when the system was ready.

Common examples

How to use Systemready

This example will show you how to test if your device is ready to receive and handle requests.

  1. Check if the system is ready with the following request:
http://<servername>/axis-cgi/systemready.cgi

JSON input parameters

{
"apiVersion": "1.1",
"context": "my context",
"method": "systemready",
"params": {
"timeout": 20
}
}

Please note that it will take up to 20 seconds before the system responds.

  1. The response will appear if the system is or becomes ready during the timeout. If needsetup is yes the system is lacking an initial admin user, which must first be created using pwdgrp.cgi. It is not possible to call an API that requires authentication otherwise. Additional fields include:
  • uptime shows how many seconds the device has been active since it was last booted.
  • bootid is a string used for the current boot up of the device.
  • previewmode will be included in the response if the device is in preview mode.

Successful response

{
"apiVersion": "1.4",
"context": "my context",
"method": "systemready",
"data": {
"systemready": "yes",
"needsetup": "no",
"uptime": "7800",
"bootid": "ebe1fa05-2ff7-4062-874c-68a466a9eaed"
}
}

Successful response with active preview mode

{
"apiVersion": "1.4",
"context": "my context",
"method": "systemready",
"data": {
"systemready": "yes",
"needsetup": "no",
"uptime": "120",
"bootid": "ebe1fa05-2ff7-4062-874c-68a466a9eaed",
"previewmode": "7200"
}
}

API specification

systemready

This method should be used to check if the system is ready for operation.

Request

  • Security level: Anonymous
  • Method: POST
http://<servername>/axis-cgi/systemready.cgi

Request body syntax

{
"apiVersion": "<Major>.<Minor>",
"context": "<string>",
"method": "systemready",
"params": {
"timeout": <timeout seconds>
}
}
ParameterDescription
apiVersionThe API version that should be used.
contextThe user sets this value and the application echoes it back in the response (optional).
methodThe method that should be used.
paramsMethod specific parameters. Optional for some methods.
timeoutThe maximum time systemready.cgi will take before returning a response. Valid responses are either yes or no.

Return value - Success

  • HTTP Code: 200 OK
  • Content-Type: application/json

Response body syntax

{
"apiVersion": "<Major>.<Minor>",
"context": "<string>",
"method": "systemready",
"data": {
"systemready": "yes/no",
"needsetup": "yes/no",
"uptime": "<seconds from when the device was started in seconds>",
"bootid": "<unique boot id string>",
"previewmode": "<previewmode duration in seconds>"
}
}
ParameterDescription
apiVersionThe API version that was used in the request.
contextThe context set by the user in the request (optional).
methodThe requested method.
dataResponse specific data.
systemreadyThe system ready status. Accepted values are yes and no.
needsetupSetup related parameter. If the returning value is yes an initial admin user must first be created using pwdgrp.cgi.
uptimeThe device boot uptime, presented in seconds.
bootidThe device boot id string.
previewmodeIncluded when preview mode is enabled.

Return value - Failure

  • HTTP Code: 200 OK
  • Content-Type: application/json

Response body syntax

{
"apiVersion": "<Major>.<Minor>",
"context": <string>
"method": "systemready",
"error": {
"code": <error code>,
"message": "<error message>"
}
}
ParameterDescription
apiVersionThe API version that was used in the request.
contextThe context set by the user in the request (optional).
methodThe requested method.
errorError specific data.
codeThe error code.
messageThe error message for the corresponding error code.

getSupportedVersions

This method should be used when you want to retrieve a list containing all API versions supported by your device.

Request

  • Security level: Anonymous
  • Method: POST
http://<servername>/axis-cgi/systemready.cgi

Request body syntax

{
"context": "<string>",
"method": "getSupportedVersions"
}
ParameterDescription
contextThe user sets this value and the application echoes it back in the response (optional).
methodThe method that should be used.

Return value - Success

  • HTTP Code: 200 OK
  • Content-Type: application/json

Response body syntax

{
"context": "<string>",
"method": "getSupportedVersions",
"data": {
"apiVersions": ["1.0", "<Major>.<Minor>"]
}
}
ParameterDescription
contextThe context set by the user in the request (optional).
methodThe requested method.
dataResponse specific data.
apiVersionsA list containing all supported major versions along with their highest minor version, e.g. ["1.0", "1.2"].

Return value - Failure

  • HTTP Code: 200 OK
  • Content-Type: application/json

Response body syntax

{
"apiVersion": "<Major>.<Minor>",
"context": "<string>",
"method": "getSupportedVersions",
"error": {
"code": <error code>,
"message": "<error message>"
}
}
ParameterDescription
apiVersionThe API version that was used in the request.
contextThe context set by the user in the request (optional).
methodThe requested method.
errorThe error specific data.
codeThe error code.
messageThe error message for the corresponding error code.

General error codes

The following table lists the general errors that can occur to any CGI method.

CodeDescription
1000Internal error. Refer to message field or logs.
9000Internal error.