api-video / php-sdk
PHP client for api.video web services.
Installs: 11 257
Dependents: 1
Suggesters: 0
Security: 0
Stars: 8
Watchers: 3
Forks: 0
Open Issues: 1
Requires
- php: >=5.3
- ext-json: *
- kriswallsmith/buzz: ^0.15
Requires (Dev)
- mikey179/vfsstream: ^1.6
- phpunit/phpunit: ^6.5
- dev-master
- 1.8.9
- 1.8.8
- 1.8.7
- 1.8.6
- 1.8.5
- 1.8.4
- 1.8.3
- 1.8.2
- 1.8.1
- 1.8.0
- 1.7.0
- 1.6.2
- 1.6.1
- 1.6.0
- 1.5.0
- 1.4.0
- 1.3.1
- 1.3.0
- 1.2.2
- 1.2.1
- 1.2.0
- 1.1.0
- 1.0.3
- 1.0.2
- 1.0.1
- 1.0.0
- 0.10.1
- 0.10
- 0.9.1
- 0.9
- 0.8
- 0.7
- 0.6
- 0.5
- 0.4
- 0.3
- 0.2
- 0.1
- dev-fix-get-status
- dev-add-livestream-public-attribute
- dev-add-user-agent-header
- dev-develop
This package is auto-updated.
Last update: 2022-05-22 13:54:28 UTC
README
api.video is an API that encodes on the go to facilitate immediate playback, enhancing viewer streaming experiences across multiple devices and platforms. You can stream live or on-demand online videos within minutes.
Deprecation warning
This project is deprecated. It won't be updated anymore, no support will be provided, and it may not be fully compatible with the API anymore. Please use https://github.com/apivideo/api.video-php-client instead.
api.video PHP SDK
The api.video web-service helps you put video on the web without the hassle. This documentation helps you use the corresponding PHP client.
Installation
composer require api-video/php-sdk
Quick start
<?php require_once __DIR__ . '/vendor/autoload.php'; // Authenticate in production environment $client = ApiVideo\Client\Client::create('yourProductionApiKey'); // Alternatively, authenticate in sandbox environment for testing $client = ApiVideo\Client\Client::createSandbox('yourSandboxApiKey'); // Create and upload a video resource from local drive $video = $client->videos->upload( '/path/to/video.mp4', array('title' => 'Course #4 - Part B') ); // Display embed code echo $video->assets['iframe']; // <iframe src="https://embed.api.video/vod/viXXX" width="100%" height="100%" frameborder="0" scrolling="no" allowfullscreen=""></iframe>
Advanced usage
<?php // Create and upload a video resource from online source (third party) $video = $client->videos->download( 'https://www.example.com/path/to/video.mp4', 'Course #4 - Part B' ); // Update video properties $client->videos->update( $video->videoId, array( 'tags' => array('course', 'economics', 'finance') ) ); // Search video by tags filter and paginate results $videos = $client->videos->search( array( 'currentPage' => 1, 'pageSize' => 25, 'tags' => array('finance') ) ); foreach ($videos as $video) { echo $video->title."\n"; } // Delete video resource $client->videos->delete($video->videoId); // Upload a video thumbnail $client->videos->uploadThumbnail('/path/to/thumbnail.jpg', $video->videoId); // Update video thumbnail by picking image with video timecode $client->videos->updateThumbnailWithTimeCode($video->videoId, '00:15:22.05'); // Create players with default values $player = $client->players->create(); // Get a player $player = $client->players->get($player->playerId); // Search a player with paginate results $players = $client->players->search(array('currentPage' => 1, 'pageSize' => 50)); $properties = array( 'shapeMargin' => 10, 'shapeRadius' => 3, 'shapeAspect' => 'flat', 'shapeBackgroundTop' => 'rgba(50, 50, 50, .7)', 'shapeBackgroundBottom' => 'rgba(50, 50, 50, .8)', 'text' => 'rgba(255, 255, 255, .95)', 'link' => 'rgba(255, 0, 0, .95)', 'linkHover' => 'rgba(255, 255, 255, .75)', 'linkActive' => 'rgba(255, 0, 0, .75)', 'trackPlayed' => 'rgba(255, 255, 255, .95)', 'trackUnplayed' => 'rgba(255, 255, 255, .1)', 'trackBackground' => 'rgba(0, 0, 0, 0)', 'backgroundTop' => 'rgba(72, 4, 45, 1)', 'backgroundBottom' => 'rgba(94, 95, 89, 1)', 'backgroundText' => 'rgba(255, 255, 255, .95)', 'enableApi' => false, 'enableControls' => true, 'forceAutoplay' => false, 'hideTitle' => false, 'forceLoop' => false ); // Update player properties $client->players->update($player->playerId, $properties); // Upload player logo $client->players->uploadLogo('/path/to/logo.png', $playerId, 'https://api.video'); // Delete a player $client->players->delete($player->playerId); // Upload video caption $client->captions->upload( 'path/to/caption.vtt', array( 'videoId' => $video->videoId, 'language' => 'en' ) ); // Get video caption by language $caption = $client->captions->get($video->videoId, 'en'); // Update the default caption language $client->captions->updateDefault($video->videoId, 'en', true); //Delete caption by language $client->captions->delete($video->videoId, 'en'); // Upload video chapter $client->chapters->upload( 'path/to/chapter.vtt', array( 'videoId' => $video->videoId, 'language' => 'en' ) ); // Get video chapter by language $chapter = $client->chapters->get($video->videoId, 'en'); //Delete chapter by language $client->chapters->delete($video->videoId, 'en'); // Create a live stream container $liveStream = $client->lives->create('Test live'); // Get the RTMP stream key $streamKey = $liveStream->streamKey; //// Raw statistics // List video player sessions $videoSessions = $client->analyticsVideo->search($video->videoId); // List video player sessions for the month of July 2018 with pagination $videoSessionsJuly2018 = $client->analyticsVideo->search($video->videoId, '2018-07', array(), array('currentPage' => 1, 'pageSize' => 100)); // Get video session events for a sessionId $videoSessionEvents = $client->analyticsSessionEvents->get($videoSessions[0]->session->sessionId); // List video player sessions $liveSessions = $client->analyticsLive->search($liveStream->liveStreamId); // List video player sessions for the month of July 2018 with pagination $liveSessionsJuly2018 = $client->analyticsLive->search($video->videoId, '2018-07', array(), array('currentPage' => 1, 'pageSize' => 100)); // Get video session events for a sessionId $liveSessionEvents = $client->analyticsSessionEvents->get($liveSessions[0]->session->sessionId); // Generate a token for delegated upload $token = $client->tokens->generate();
Full API
<?php /* ********************************* ********************************* * VIDEO * ********************************* ********************************* */ // Show a video $client->videos->get($videoId); // List or search videos $client->videos->search($parameters = array(), $callback = null); // Create video properties $client->videos->create($title, $properties = array()); // Upload a video media file // Create a video, if videoId is null $client->videos->upload($source, $properties = array(), $videoId = null); // Create a video by downloading it from a third party $client->videos->download($source, $title, $properties = array()); // Update video properties $client->videos->update($videoId, $properties = array()); // Set video public $client->videos->setPublic($videoId); // Set video private $client->videos->setPrivate($videoId); // Delete video (file and data) $client->videos->delete($videoId); // Get last video request Error $client->videos->getLastError(); // Delegated upload (generate a token for someone to upload a video into your account) $token = $client->tokens->generate(); // string(3): "xyz" // ...then upload from anywhere without authentication: // $ curl https://ws.api.video/upload?token=xyz -F file=@video.mp4 /* ********************************* * VIDEO THUMBNAIL * ********************************* */ // Upload a thumbnail for video $client->videos->uploadThumbnail($source, $videoId); // Update video's thumbnail by picking timecode $client->videos->updateThumbnailWithTimeCode($videoId, $timecode); // Get last video request Error $client->videos->getLastError(); /* ********************************* * VIDEO CAPTIONS * ********************************* */ // Get caption for a video $client->captions->get($videoId, $language); // Get all captions for a video $client->captions->getAll($videoId); // Upload a caption file for a video (.vtt) $client->captions->upload($source, $properties = array()); // Set default caption for a video $client->captions->updateDefault($videoId, $language, $isDefault); // Delete video's caption $client->captions->delete($videoId, $language); // Get last video captions request Error $client->captions->getLastError(); /* ********************************* * VIDEO CHAPTERS * ********************************* */ // Get chapter for a video $client->chapters->get($videoId, $language); // Get all chapters for a video $client->chapters->getAll($videoId); // Upload a chapter file for a video (.vtt) $client->chapters->upload($source, $properties = array()); // Delete video's chapter $client->chapters->delete($videoId, $language); // Get last video chapters request Error $client->chapters->getLastError(); /* ********************************* * PLAYERS * ********************************* */ // Get a player $client->players->get($playerId); // List players $client->players->search($parameters = array(), $callback = null); // Create a player $client->players->create($properties = array()); // Update player's properties $client->players->update($playerId, $properties); // Upload player logo $client->players->uploadLogo('/path/to/logo.png', $playerId, 'https://api.video'); // Delete a logo $client->players->deleteLogo($playerId); // Delete a player $client->players->delete($playerId); // Get last players request Error $client->players->getLastError(); /* ********************************* ********************************* * LIVE * ********************************* ********************************* */ // Show a live $client->lives->get($liveStreamId); // List or search lives $client->lives->search($parameters = array(), $callback = null); // Create live properties $client->lives->create($name, $properties = array()); // Update live properties $client->lives->update($liveStreamId, $properties = array()); // Set live public $client->lives->setPublic($liveStreamId); // Set live private $client->lives->setPrivate($liveStreamId); // Delete live (file and data) $client->lives->delete($liveStreamId); // Get last live request Error $client->lives->getLastError(); /* ********************************* * LIVE THUMBNAIL * ********************************* */ // Upload a thumbnail for live $client->lives->uploadThumbnail($source, $liveStreamId); /* ********************************* * ANALYTICS * ********************************* */ // Search videos analytics between period, filter with tags or metadata $client->analyticsVideo->search($videoId, $period, $metadata, $parameters); // Get last video analytics request Error $client->analyticsVideo->getLastError(); // Search live stream analytics between period, filter with tags or metadata $client->analyticsLive->search($liveStreamId, $period, $parameters); // Get last live analytics request Error $client->analyticsLive->getLastError(); // Get session events analytics $client->analyticsSessionEvents->search($sessionId, $parameters); // Get last sesion events analytics request Error $client->analyticsSessionEvents->getLastError();
Full API Details Implementation
Videos
Function | Parameters | Description | Required | Allowed Values |
---|---|---|---|---|
get | videoId(string) | Video identifier | ✔️ | - |
search | - | - | - | - |
- | parameters(array) | Search parameters | ❌ |
|
- | callback(function) | callback function | ❌ | - |
create | - | - | - | - |
- | title(string) | Video title | ✔️ | - |
- | properties(array) | Video properties | ❌ |
|
upload | - | - | - | - |
- | source(string) | Video media file | ✔️ | - |
- | properties(array) | Video properties | ❌ |
|
- | videoId(string) | Video identifier | ❌ | - |
download | - | - | - | - |
- | source(string) | Video media file | ✔️ | - |
- | title(string) | Video title | ✔️ | - |
- | properties(array) | Video properties | ❌ |
|
uploadThumbnail | - | - | - | - |
- | source(string) | Image media file | ✔️ | - |
- | videoId(string) | Video identifier | ✔️ | - |
updateThumbnailWithTimeCode | - | - | - | - |
- | videoId(string) | Video identifier | ✔️ | - |
- | timecode(string) | Video timecode | ✔️ | 00:00:00.00 (hours:minutes:seconds.frames) |
update | - | - | - | - |
- | videoId()string | Video identifier | ✔️ | - |
- | properties(array) | Video properties | ✔️ |
|
setPublic | videoId(string) | Video identifier | ✔️ | - |
setPrivate | videoId(string) | Video identifier | ✔️ | - |
delete | videoId(string) | Video identifier | ✔️ | - |
Players
Function | Parameters | Description | Required | Allowed Values |
---|---|---|---|---|
get | playerId(string) | Player identifier | ✔️ | - |
create | properties(array) | Player properties | ❌ |
|
update | - | - | - | - |
- | playerId(string) | Player identifier | ✔️ | - |
- | properties(array) | Player properties | ✔️ |
|
uploadLogo | - | - | - | - |
- | source(string) | Image media file | ✔️ | - |
- | playerId(string) | Player identifier | ✔️ | - |
- | link(string) | Link url | ❌ | - |
deleteLogo | playerId(string) | Player identifier | ✔️ | - |
delete | playerId(string) | Player identifier | ✔️ | - |
Captions
Function | Parameters | Description | Required | Allowed Values |
---|---|---|---|---|
get | - | - | - | - |
- | videoId(string) | Video identifier | ✔️ | - |
- | language(string) | Language identifier | ✔️ | 2 letters (ex: en, fr) |
getAll | videoId(string) | Video identifier | ✔️ | - |
upload | - | - | - | - |
- | source(string) | Caption file | ✔️ | - |
- | properties(string) | Caption properties | ✔️ |
|
updateDefault | - (array) | - | - | - |
- | videoId | Video identifier | ✔️ | - |
- | language (string) | Language identifier | ✔️ | 2 letters (ex: en, fr) |
- | isDefault (string) | Set default language | ✔️ | true/false |
delete | - (boolean) | - | - | - |
- | videoId | Video identifier | ✔️ | - |
- | language (string) | Language identifier | ✔️ | 2 letters (ex: en, fr) |
Chapters
Function | Parameters | Description | Required | Allowed Values |
---|---|---|---|---|
get | - | - | - | - |
- | videoId(string) | Video identifier | ✔️ | - |
- | language(string) | Language identifier | ✔️ | 2 letters (ex: en, fr) |
getAll | videoId(string) | Video identifier | ✔️ | - |
upload | - | - | - | - |
- | source(string) | Chapter file | ✔️ | - |
- | properties(string) | Chapter properties | ✔️ |
|
delete | - (boolean) | - | - | - |
- | videoId | Video identifier | ✔️ | - |
- | language (string) | Language identifier | ✔️ | 2 letters (ex: en, fr) |
Live streams
Function | Parameters | Description | Required | Allowed Values |
---|---|---|---|---|
get | liveStreamId(string) | Live identifier | ✔️ | - |
search | - | - | - | - |
- | parameters(array) | Search parameters | ❌ |
|
- | callback(function) | callback function | ❌ | - |
create | - | - | - | - |
- | name(string) | Live name | ✔️ | - |
- | properties(array) | Live properties | ❌ |
|
uploadThumbnail | - | - | - | - |
- | source(string) | Image media file | ✔️ | - |
- | liveStreamId(string) | Live identifier | ✔️ | - |
update | - | - | - | - |
- | liveStreamId(string) | Live identifier | ✔️ | - |
- | properties(array) | Live properties | ✔️ |
|
setPublic | liveStreamId(string) | Live identifier | ✔️ | - |
setPrivate | liveStreamId(string) | Live identifier | ✔️ | - |
delete | liveStreamId(string) | Live identifier | ✔️ | - |
AnalyticsVideo
Function | Parameters | Description | Required | Allowed Values/Format |
---|---|---|---|---|
search | parameters(array) | Search parameters | ❌ |
|
- | videoId(string) | Video identifier | ✔️ | - |
- | period (string) | Period research | ❌ |
|
- | metadata (array) | Metadata research | ❌ | - |
AnalyticsLive
Function | Parameters | Description | Required | Allowed Values/Format |
---|---|---|---|---|
search | parameters(array) | Search parameters | ❌ |
|
- | liveStreamId(string) | Live identifier | ✔️ | - |
- | period (string) | Period research | ❌ |
|
AnalyticsSessionEvents
Function | Parameters | Description | Required | Allowed Values/Format |
---|---|---|---|---|
search | - | - | - | - |
- | sessionId(string) | Session identifier | ✔️ | - |
- | parameters(array) | Search parameters | ❌ |
|
Tokens
Function | Parameters | Description | Required | Allowed Values |
---|---|---|---|---|
generate | - | Token for delegated upload | - | - |
Account
Function | Parameters | Description | Required | Allowed Values |
---|---|---|---|---|
get | - | Get account informations (quota, features) | - | - |
More on api.video
A full technical documentation is available on https://docs.api.video/