Skip to content

API for network-DVR service management

Description

This API provides an interface to manage network-DVR (temporary stream recording on the receiving device).

The API allows to get information about DVR ranges (recorded periods in DVR archive) for the stream and to delete them.

API

General information

  • Required headers: CDN-AUTH-TOKEN (authorization token, refer. Authorization)
  • Data in request body is sent in JSON format (Content-Type: application/json)

In case of correct response API returns 2xx response code and response text in the following format:

{
  "status": "Completed",
  "data": <API response>,
  "<request parameter 1>": "value1",
  "<request parameter 2>": "value2"
}

In case of an error response, the API returns the corresponding response code and the response text in the following format:

{
  "status": "Forbidden",
  "description": "Token is expired"
}

The description field returns a text description of the error.

Get information for specific stream

URL: https://api-cdn.platformcraft.com/app/dvr-net/v1/<your_account_name>/streams/<stream_name>

  • Request type: GET
  • Headers: CDN-AUTH-TOKEN
  • Request parameters: no request parameters
  • Response data type: JSON Object
  • Response parameters:
Parameter Description
stream_name Stream name
host Server
is_alive is the stream alive
dvr DVR parameters block for the stream
dvr.enabled Is the DVR enabled for the stream
dvr.window DVR depth
dvr.duration Total duration of the recorded DVR excluding any breaks in recording
dvr.from UTC timestamp of the first DVR recording
dvr.ranges List of recorded DVR periods
dvr.ranges.duration DVR period duration
dvr.ranges.from UTC timestamp of the beginning of the DVR period

Request example

curl -H "CDN-AUTH-TOKEN: $TOKEN" 'https://api-cdn.platformcraft.com/app/dvr-net/v1/testaccount/streams/test/stream1'

Response example

{
  "status": "Completed",
  "stream_name": "test/stream1",
  "data": [
    {
      "stream_name": "test/stream1",
     "host": "ffce3977afe64227676096887231adba",
      "is_alive": false,
      "dvr": {
        "enabled": true,
        "window": 3600,
        "duration": 60,
        "from": 1668753181,
        "ranges": [
          {
            "duration": 27,
            "from": 1668753181
          },
          {
            "duration": 33,
            "from": 1668753302
          }
        ]
      }
    },
    {
      "stream_name": "test/stream1",
      "host": "7bd5e6ccea2e689d252eb4c183a1aaf6",
      "is_alive": false,
      "dvr": {
        "enabled": true,
        "window": 3600,
        "duration": 60,
        "from": 1668753181,
        "ranges": [
          {
            "duration": 27,
            "from": 1668753181
          },
          {
            "duration": 33,
            "from": 1668753302
          }
        ]
      }
    }
  ]
}

Delete DVR range for specific stream

Any part of DVR can be deleted to the accuracy of a second, i.e. it is possible to delete a piece of DVR in the middle of DVR range, left, right (and left and right borders may be specified outside existing ranges).

The active DVR can be deleted too, in which case the list becomes empty at first and then accumulates again.

If deletion fails on at least one of the list of nodes, a 500 error is returned. In this case, in addition to the status field, the failed_hosts field appears in the response with the list of nodes on which the removal failed.

URL: https://api-cdn.platformcraft.com/app/dvr-net/v1/<your_account_name>/streams/<stream_name>

  • Request type: DELETE
  • Headers: CDN-AUTH-TOKEN
  • Response data type: JSON Object
  • Request parameters:
Parameter Description
duration_sec Duration of the DVR chunk you are deleting
host Server
from_ts UTC timestamp from which the DVR chunk should be deleted
to_ts UTC timestamp to which the DVR chunk should be deleted

Required are host, from_ts and any one of (duration_sec, to_ts).

If it is necessary to remove the DVR on all nodes, an "asterisk" must be specified as the value of the host parameter.

Request example

curl -X DELETE -d '{"host": "7bd5e6ccea2e689d252eb4c183a1aaf6", "from_ts": 1668753181, "duration_sec": 15}' -H "cdn-auth-token: $TOKEN" -H "Content-Type: application/json" 'https://api-cdn.platformcraft.com/app/dvr-net/v1/testaccount/streams/test/stream1'

Response example

{
  "status": "Completed",
  "stream_name": "test/stream1",
  "duration_sec": 15,
  "from_ts": 1668753181,
  "host": "7bd5e6ccea2e689d252eb4c183a1aaf6"
}

Delete all accumulated DVR for specific stream

If the deletion fails on at least one of the list of nodes, a 500 error is returned. In this case, in addition to the status field, the failed_hosts field appears in the response with the list of nodes on which the deletion failed.

URL: https://api-cdn.platformcraft.com/app/dvr-net/v1/<your_account_name>/streams/<stream_name>

  • Request type: DELETE
  • Headers: CDN-AUTH-TOKEN
  • Response data type: JSON Object
  • Request parameters:
Parameter Description
all Flag of deletion of all accumulated DVR
host Server

Both parameters are required.

If it is necessary to remove the DVR on all nodes, an "asterisk" must be specified as the value of the host parameter.

Request example

curl -X DELETE -d '{"host": "*", "all": true}' -H "cdn-auth-token: $TOKEN" -H "Content-Type: application/json" 'https://api-cdn.platformcraft.com/app/dvr-net/v1/testaccount/streams/test/stream1'

Response example

{
  "status": "Completed",
  "stream_name": "test/stream1",
  "host": "*",
  "all": true
}