Playback API Reference (2.0.0)
Download OpenAPI specification:Download
Reference for the Brightcove Playback API, used for client-side access video and playlist information.
The raw API JSON response is not suitable for the player. Use the player.catalog.transformVideoResponse()
function to convert each video object in the response into a format compatible with the player. This includes duration times and https image compatibility. For details, see the Player Catalog document.
For additional in-depth guides to features of the API, see the Overview.
**NOTE: this is version 2 of the Playback API - almost all Brightcove accounts are on this version, but a very few are still on version 1. All version 1 functionality works with version 2. Version 2 offers some new functionality as noted below. The base url is the same for both versions - requests are directed to the correct version based on the account settings.
Get Related Videos by ID or Reference ID
Gets a page of video objects that are related to the specified video. Using the name and short description of the specified video, the Playback API searches for videos with any partial matches in the following fields: name
, short
description
, long_description
, tags
.
Notes: When performing a search (using the q
parameter), you must use a search-enabled Policy Key. For information on getting policy keys, see the Policy API Overview. You can also use this sample app to create a search-enabled key
In general, search-enabled Policy Keys should only be stored on a server and not in a browser player or mobile app, since they can be used to list all playable videos. For some accounts this may not be applicable if you do not care if all of your playable videos can be discovered.
The response results for this endpoint are subject to change as we improve the algorithm for finding related videos. If you do not want your results to change, or if you want precise control, then you should use the Get Videos endpoint with a search parameter.
Any geo-restricted videos that are denied for the particular requestor are omitted from the results. As long as some videos are allowed the request is considered successful. An errors field is added to the result with a summary explaining why videos were omitted.
path Parameters
account_id required | string Video Cloud account ID |
video_id required | string Video Cloud video ID |
query Parameters
limit | integer [ 1 .. 1000 ] Default: 20 The number of videos to return |
offset | integer >= 0 Default: 0 The number of videos to skip - used to page multiple sets of videos. Note that the maximum number of videos that can be returned by the Playback API is 1000. To return more than 1000 videos, you must use the CMS API. |
ad_config_id | string include server-side ad insertion |
config_id | string include and set equal to the delivery rules id in order to have the delivery rules applied |
header Parameters
Authorization required | string
|
BCOV-Policy required | string
|
Accept required | string
|
Responses
Response samples
- 200
[- {
- "thumbnail_sources": [
], - "description": null,
- "tags": [
- "public",
- "sample",
- "water"
], - "cue_points": [ ],
- "custom_fields": {
- "customfield1": "foo",
- "customfield2": "bar"
}, - "account_id": "1752604059001",
- "sources": [
- {
- "ext_x_version": "4",
- "type": "application/x-mpegURL"
}, - {
- "ext_x_version": "4",
- "type": "application/x-mpegURL"
}, - {
- "codecs": "avc1,mp4a",
- "ext_x_version": "7",
- "type": "application/x-mpegURL"
}, - {
- "codecs": "avc1,mp4a",
- "ext_x_version": "7",
- "type": "application/x-mpegURL"
}, - {
- "profiles": "urn:mpeg:dash:profile:isoff-live:2011",
- "type": "application/dash+xml"
}, - {
- "profiles": "urn:mpeg:dash:profile:isoff-live:2011",
- "type": "application/dash+xml"
}, - {
- "codecs": "avc1,mp4a",
- "profiles": "urn:mpeg:dash:profile:isoff-live:2011",
- "type": "application/dash+xml"
}, - {
- "codecs": "avc1,mp4a",
- "profiles": "urn:mpeg:dash:profile:isoff-live:2011",
- "type": "application/dash+xml"
}, - {
- "avg_bitrate": 2213000,
- "codec": "H264",
- "container": "MP4",
- "duration": 49690,
- "height": 1080,
- "size": 13753809,
- "width": 1920
}, - {
- "avg_bitrate": 2213000,
- "codec": "H264",
- "container": "MP4",
- "duration": 49690,
- "height": 1080,
- "size": 13753809,
- "width": 1920
}, - {
- "avg_bitrate": 613000,
- "codec": "H264",
- "container": "MP4",
- "duration": 49690,
- "height": 1080,
- "size": 3826436,
- "width": 1920
}, - {
- "avg_bitrate": 613000,
- "codec": "H264",
- "container": "MP4",
- "duration": 49690,
- "height": 1080,
- "size": 3826436,
- "width": 1920
}
], - "name": "Canada Geese and Goslings",
- "reference_id": null,
- "long_description": null,
- "duration": 49633,
- "economics": "AD_SUPPORTED",
- "text_tracks": [
- {
- "id": null,
- "account_id": "1752604059001",
- "srclang": null,
- "label": "thumbnails",
- "kind": "metadata",
- "mime_type": "text/webvtt",
- "asset_id": null,
- "sources": null,
- "default": false,
- "width": 192,
- "height": 108,
- "bandwidth": 360
}, - {
- "id": null,
- "account_id": "1752604059001",
- "srclang": null,
- "label": "thumbnails",
- "kind": "metadata",
- "mime_type": "text/webvtt",
- "asset_id": null,
- "sources": null,
- "default": false,
- "width": 192,
- "height": 108,
- "bandwidth": 360
}
], - "published_at": "2016-05-07T18:33:28.665Z",
- "created_at": "2016-05-07T18:33:28.665Z",
- "updated_at": "2020-04-25T19:50:54.934Z",
- "offline_enabled": false,
- "link": null,
- "id": "4883184247001",
- "ad_keys": null,
- "variants": [
- {
- "language": "de-DE",
- "name": "Basel: Der Rhein",
- "description": "Panoramablick auf den Rhein im Zentrum von Basel, Schweiz.",
- "long_description": "Panoramablick auf den Rhein im Zentrum von Basel, Schweiz.",
- "custom_fields": { }
}, - {
- "language": "ja-JA",
- "name": "バーゼル:ライン川",
- "description": "スイス、バーゼルの中心部にあるライン川のパノラマビュー。",
- "long_description": "スイス、バーゼルの中心部にあるライン川のパノラマビュー。",
- "custom_fields": {
- "language": "Japanese"
}
}
]
}
]
Get Video by ID or Reference ID
Gets a video object based on a video ID or reference ID. To get a video using the reference_id
, use: https://edge.api.brightcove.com/playback/v1/accounts/{account_id}/videos/ref:{reference_id}`
Note that you can specify multiple video ids in a comma-delimited list, but only one reference_id
.
path Parameters
account_id required | string Video Cloud account ID |
video_id required | string Video Cloud video ID |
query Parameters
ad_config_id | string include server-side ad insertion |
config_id | string include and set equal to the delivery rules id in order to have the delivery rules applied |
header Parameters
Authorization required | string
|
BCOV-Policy required | string
|
Accept required | string
|
Responses
Response samples
- 200
{- "thumbnail_sources": [
], - "description": null,
- "tags": [
- "public",
- "sample",
- "water"
], - "cue_points": [ ],
- "custom_fields": {
- "customfield1": "foo",
- "customfield2": "bar"
}, - "account_id": "1752604059001",
- "sources": [
- {
- "ext_x_version": "4",
- "type": "application/x-mpegURL"
}, - {
- "ext_x_version": "4",
- "type": "application/x-mpegURL"
}, - {
- "codecs": "avc1,mp4a",
- "ext_x_version": "7",
- "type": "application/x-mpegURL"
}, - {
- "codecs": "avc1,mp4a",
- "ext_x_version": "7",
- "type": "application/x-mpegURL"
}, - {
- "profiles": "urn:mpeg:dash:profile:isoff-live:2011",
- "type": "application/dash+xml"
}, - {
- "profiles": "urn:mpeg:dash:profile:isoff-live:2011",
- "type": "application/dash+xml"
}, - {
- "codecs": "avc1,mp4a",
- "profiles": "urn:mpeg:dash:profile:isoff-live:2011",
- "type": "application/dash+xml"
}, - {
- "codecs": "avc1,mp4a",
- "profiles": "urn:mpeg:dash:profile:isoff-live:2011",
- "type": "application/dash+xml"
}, - {
- "avg_bitrate": 2213000,
- "codec": "H264",
- "container": "MP4",
- "duration": 49690,
- "height": 1080,
- "size": 13753809,
- "width": 1920
}, - {
- "avg_bitrate": 2213000,
- "codec": "H264",
- "container": "MP4",
- "duration": 49690,
- "height": 1080,
- "size": 13753809,
- "width": 1920
}, - {
- "avg_bitrate": 613000,
- "codec": "H264",
- "container": "MP4",
- "duration": 49690,
- "height": 1080,
- "size": 3826436,
- "width": 1920
}, - {
- "avg_bitrate": 613000,
- "codec": "H264",
- "container": "MP4",
- "duration": 49690,
- "height": 1080,
- "size": 3826436,
- "width": 1920
}
], - "name": "Canada Geese and Goslings",
- "reference_id": null,
- "long_description": null,
- "duration": 49633,
- "economics": "AD_SUPPORTED",
- "text_tracks": [
- {
- "id": null,
- "account_id": "1752604059001",
- "srclang": null,
- "label": "thumbnails",
- "kind": "metadata",
- "mime_type": "text/webvtt",
- "asset_id": null,
- "sources": null,
- "default": false,
- "width": 192,
- "height": 108,
- "bandwidth": 360
}, - {
- "id": null,
- "account_id": "1752604059001",
- "srclang": null,
- "label": "thumbnails",
- "kind": "metadata",
- "mime_type": "text/webvtt",
- "asset_id": null,
- "sources": null,
- "default": false,
- "width": 192,
- "height": 108,
- "bandwidth": 360
}
], - "published_at": "2016-05-07T18:33:28.665Z",
- "created_at": "2016-05-07T18:33:28.665Z",
- "updated_at": "2020-04-25T19:50:54.934Z",
- "offline_enabled": false,
- "link": null,
- "id": "4883184247001",
- "ad_keys": null,
- "variants": [
- {
- "language": "de-DE",
- "name": "Basel: Der Rhein",
- "description": "Panoramablick auf den Rhein im Zentrum von Basel, Schweiz.",
- "long_description": "Panoramablick auf den Rhein im Zentrum von Basel, Schweiz.",
- "custom_fields": { }
}, - {
- "language": "ja-JA",
- "name": "バーゼル:ライン川",
- "description": "スイス、バーゼルの中心部にあるライン川のパノラマビュー。",
- "long_description": "スイス、バーゼルの中心部にあるライン川のパノラマビュー。",
- "custom_fields": {
- "language": "Japanese"
}
}
]
}
Get Videos
Gets a page of video objects. The Playback API allows you to programmatically search for videos in your Video Cloud library. For more information on the search syntax, see CMS/Playback API: Videos Search.
Notes:
When performing a search, you need to use a search-enabled Policy Key. For information on getting policy keys, see the Policy API Overview or the Policy Keys documents. In general, search-enabled Policy Keys should only be stored on a server and not in a browser player or mobile app, since they can be used to list all playable videos. For some accounts this may not be applicable if you do not care if all of your playable videos can be discovered.
The maximum number of videos (highest count value) returned is 1000, even if there are more matching videos in the account. The count value is an estimate and should not be relied on as the exact number to be returned. If all results are desired then keep paging until it no longer returns a full page, or use the CMS api.
Only currently playable videos are included in the results list. It is recommended to do a similar query with the CMS api to see why some videos are excluded. Any geo-restricted videos that are denied for the particular requestor are omitted from the results. As long as some videos are allowed the request is considered successful. An errors field is added to the result with a summary explaining why videos were omitted.
path Parameters
account_id required | string Video Cloud account ID |
video_id required | string Video Cloud video ID |
query Parameters
q | string search string - see search guide for details |
limit | integer [ 1 .. 1000 ] Default: 20 The number of videos to return |
offset | integer >= 0 Default: 0 The number of videos to skip - used to page multiple sets of videos. Note that the maximum number of videos that can be returned by the Playback API is 1000. To return more than 1000 videos, you must use the CMS API. |
sort | string Default: "-updated_at" Enum: "name" "reference_id" "created_at" "published_at" "updated_at" "schedule_starts_at" "schedule_ends_at" "state" "plays_total" "plays_trailing_week" Field to sort results by; if absent and there is a search string, results are sorted by relevance — note that |
ad_config_id | string include server-side ad insertion |
config_id | string include and set equal to the delivery rules id in order to have the delivery rules applied |
header Parameters
Authorization required | string
|
BCOV-Policy required | string
|
Accept required | string
|
Responses
Response samples
- 200
[- {
- "thumbnail_sources": [
], - "description": null,
- "tags": [
- "public",
- "sample",
- "water"
], - "cue_points": [ ],
- "custom_fields": {
- "customfield1": "foo",
- "customfield2": "bar"
}, - "account_id": "1752604059001",
- "sources": [
- {
- "ext_x_version": "4",
- "type": "application/x-mpegURL"
}, - {
- "ext_x_version": "4",
- "type": "application/x-mpegURL"
}, - {
- "codecs": "avc1,mp4a",
- "ext_x_version": "7",
- "type": "application/x-mpegURL"
}, - {
- "codecs": "avc1,mp4a",
- "ext_x_version": "7",
- "type": "application/x-mpegURL"
}, - {
- "profiles": "urn:mpeg:dash:profile:isoff-live:2011",
- "type": "application/dash+xml"
}, - {
- "profiles": "urn:mpeg:dash:profile:isoff-live:2011",
- "type": "application/dash+xml"
}, - {
- "codecs": "avc1,mp4a",
- "profiles": "urn:mpeg:dash:profile:isoff-live:2011",
- "type": "application/dash+xml"
}, - {
- "codecs": "avc1,mp4a",
- "profiles": "urn:mpeg:dash:profile:isoff-live:2011",
- "type": "application/dash+xml"
}, - {
- "avg_bitrate": 2213000,
- "codec": "H264",
- "container": "MP4",
- "duration": 49690,
- "height": 1080,
- "size": 13753809,
- "width": 1920
}, - {
- "avg_bitrate": 2213000,
- "codec": "H264",
- "container": "MP4",
- "duration": 49690,
- "height": 1080,
- "size": 13753809,
- "width": 1920
}, - {
- "avg_bitrate": 613000,
- "codec": "H264",
- "container": "MP4",
- "duration": 49690,
- "height": 1080,
- "size": 3826436,
- "width": 1920
}, - {
- "avg_bitrate": 613000,
- "codec": "H264",
- "container": "MP4",
- "duration": 49690,
- "height": 1080,
- "size": 3826436,
- "width": 1920
}
], - "name": "Canada Geese and Goslings",
- "reference_id": null,
- "long_description": null,
- "duration": 49633,
- "economics": "AD_SUPPORTED",
- "text_tracks": [
- {
- "id": null,
- "account_id": "1752604059001",
- "srclang": null,
- "label": "thumbnails",
- "kind": "metadata",
- "mime_type": "text/webvtt",
- "asset_id": null,
- "sources": null,
- "default": false,
- "width": 192,
- "height": 108,
- "bandwidth": 360
}, - {
- "id": null,
- "account_id": "1752604059001",
- "srclang": null,
- "label": "thumbnails",
- "kind": "metadata",
- "mime_type": "text/webvtt",
- "asset_id": null,
- "sources": null,
- "default": false,
- "width": 192,
- "height": 108,
- "bandwidth": 360
}
], - "published_at": "2016-05-07T18:33:28.665Z",
- "created_at": "2016-05-07T18:33:28.665Z",
- "updated_at": "2020-04-25T19:50:54.934Z",
- "offline_enabled": false,
- "link": null,
- "id": "4883184247001",
- "ad_keys": null,
- "variants": [
- {
- "language": "de-DE",
- "name": "Basel: Der Rhein",
- "description": "Panoramablick auf den Rhein im Zentrum von Basel, Schweiz.",
- "long_description": "Panoramablick auf den Rhein im Zentrum von Basel, Schweiz.",
- "custom_fields": { }
}, - {
- "language": "ja-JA",
- "name": "バーゼル:ライン川",
- "description": "スイス、バーゼルの中心部にあるライン川のパノラマビュー。",
- "long_description": "スイス、バーゼルの中心部にあるライン川のパノラマビュー。",
- "custom_fields": {
- "language": "Japanese"
}
}
]
}
]
Operations for retrieving static URLs for video manifests. This gives you the flexibility to manage your content in your own CMS, and deliver it using a custom security schema.
Static URL requests are for version 2 of the API only.
This is important for customers who have existing architecture that does not allow a Playback API call before needing the manifest url(s). The player can also use this feature, reducing playback start time by eliminating one call.
See Static URL Delivery for more information.
Get an HLS Manifest with static URLs
Gets an HLS manifest with static URLs for the renditions and other assets. Note that the URLs carry a token, and are good for the TTL of the token. Version 2 of the API only
path Parameters
account_id required | string Video Cloud account ID |
video_id required | string Video Cloud video ID |
query Parameters
bcov_auth required | string The value is a JWT (JSON Web Token) - see Static URL Delivery and Creating a JSON Web Token |
config_id | string include and set equal to the delivery rules id in order to have the delivery rules applied |
header Parameters
Authorization required | string
|
BCOV-Policy required | string
|
Accept required | string
|
Responses
Get a DASH Manifest with static URLs
Gets a DASH manifest with static URLs for the renditions and other assets. Note that the URLs carry a token, and are good for the TTL of the token. Version 2 of the API only
path Parameters
account_id required | string Video Cloud account ID |
video_id required | string Video Cloud video ID |
query Parameters
bcov_auth required | string The value is a JWT (JSON Web Token) - see Static URL Delivery and Creating a JSON Web Token |
config_id | string include and set equal to the delivery rules id in order to have the delivery rules applied |
header Parameters
Authorization required | string
|
BCOV-Policy required | string
|
Accept required | string
|
Responses
Get an HLS VMAP with static URLs
Gets an HLS VMAP with static URLs for the renditions and other assets. Note that the URLs carry a token, and are good for the TTL of the token. Also, VMAPS can only be retrieved if the JWT includes an ssai
claim - see Creating a JSON Web Token. Version 2 of the API only
path Parameters
account_id required | string Video Cloud account ID |
video_id required | string Video Cloud video ID |
query Parameters
bcov_auth required | string The value is a JWT (JSON Web Token) - see Static URL Delivery and Creating a JSON Web Token |
config_id | string include and set equal to the delivery rules id in order to have the delivery rules applied |
header Parameters
Authorization required | string
|
BCOV-Policy required | string
|
Accept required | string
|
Responses
Get an DASH VMAP with static URLs
Gets an DASH VMAP with static URLs for the renditions and other assets. Note that the URLs carry a token, and are good for the TTL of the token. Also, VMAPS can only be retrieved if the JWT includes an ssai
claim - see Creating a JSON Web Token. Version 2 of the API only
path Parameters
account_id required | string Video Cloud account ID |
video_id required | string Video Cloud video ID |
query Parameters
bcov_auth required | string The value is a JWT (JSON Web Token) - see Static URL Delivery and Creating a JSON Web Token |
config_id | string include and set equal to the delivery rules id in order to have the delivery rules applied |
header Parameters
Authorization required | string
|
BCOV-Policy required | string
|
Accept required | string
|
Responses
Get the highest bitrate MP4 rendition
Gets the MP4 rendition of the video that has the highest bitrate Version 2 of the API only
path Parameters
account_id required | string Video Cloud account ID |
video_id required | string Video Cloud video ID |
query Parameters
bcov_auth required | string The value is a JWT (JSON Web Token) - see Static URL Delivery and Creating a JSON Web Token |
config_id | string include and set equal to the delivery rules id in order to have the delivery rules applied |
header Parameters
Authorization required | string
|
BCOV-Policy required | string
|
Accept required | string
|
Responses
Get the lowest bitrate MP4 rendition
Gets the MP4 rendition of the video that has the lowest bitrate Version 2 of the API only
path Parameters
account_id required | string Video Cloud account ID |
video_id required | string Video Cloud video ID |
query Parameters
bcov_auth required | string The value is a JWT (JSON Web Token) - see Static URL Delivery and Creating a JSON Web Token |
config_id | string include and set equal to the delivery rules id in order to have the delivery rules applied |
header Parameters
Authorization required | string
|
BCOV-Policy required | string
|
Accept required | string
|
Responses
Get Playlist by ID or Reference ID
Gets a playlist object for an account, based on playlist ID or reference ID. Note that playlists may contain up to 1000 videos. By default, only the first 20 are returned. You can use the limit
and offset
parameters to control how many (up to 1000) and which videos are returned for a request
path Parameters
account_id required | string Video Cloud account ID |
playlist_id required | string Video Cloud playlist ID |
query Parameters
limit | integer [ 1 .. 1000 ] Default: 20 The number of videos to return |
offset | integer >= 0 Default: 0 The number of videos to skip - used to page multiple sets of videos. Note that the maximum number of videos that can be returned by the Playback API is 1000. To return more than 1000 videos, you must use the CMS API. |
ad_config_id | string include server-side ad insertion |
config_id | string include and set equal to the delivery rules id in order to have the delivery rules applied |
header Parameters
Authorization required | string
|
BCOV-Policy required | string
|
Accept required | string
|
Responses
Response samples
- 200
{- "videos": [
- {
- "description": "Bugs-Bee",
- "tags": [
- "bugs",
- "sample"
], - "cue_points": [ ],
- "custom_fields": { },
- "account_id": "1752604059001",
- "sources": [
- {
- "ext_x_version": "4",
- "type": "application/x-mpegURL",
}
], - "name": "Bugs-Bee",
- "reference_id": "1754261699001",
- "long_description": null,
- "duration": 30000,
- "economics": "AD_SUPPORTED",
- "published_at": "2012-07-25T20:34:13.393Z",
- "text_tracks": [ ],
- "updated_at": "2018-09-03T18:35:27.609Z",
- "offline_enabled": false,
- "link": null,
- "id": "1754261699001",
- "ad_keys": null,
- "created_at": "2012-07-25T20:34:13.393Z"
}
], - "updated_at": "2016-01-30T20:43:59.351Z",
- "type": "ACTIVATED_NEWEST_TO_OLDEST",
- "reference_id": "bugs1754200352001",
- "name": "Bugs",
- "id": "1754200352001",
- "description": null,
- "created_at": "2012-07-25T20:43:06.070Z",
- "account_id": "1752604059001"
}