動画
clips > get
動画或いは広告情報ををリクエストします。
ハッシュ付きリクエストを使用する場合、それはアプリケーションの責任になります。
1. 動画をユーザーに表示するかどうかを決定します(APIは制限の有無にかかわらず動画情報を返します)。アプリケーションは、はじめにAPIコールの"users > get_cvr"を用いてユーザーが動画にアクセスする権限があるかどうかを確認し、次に何をするかを決定する必要があります。
2. 動画がアクティブかどうかを確認します(APIはステータスに関係なく動画情報を返します)。
可能なステータス値:0 (非アクティブ), 1 (アクティブ), 2 (保留中のモデレーション)
3. メディア(動画ファイル)のURLには、[cfsig]および[xtok]というプレフィックスを含めることができます。
・[cfsig]プレフィックスが見つかった場合は、URLにCloudFrontの署名が必要です。
署名付きURLを再生時に取得するにはAPIコールの"clips > get_aws_signed_url"を使用します。
・[xtok]プレフィックスが見つかった場合は、URLに外部トークン化が必要です。
トークン化されたURLを再生時に取得するにはAPIコールの"clips > get_xtokenized_url"を使用します。
4. 「販売中(制限付き/ユーザーがアクセスを許可されておらず、かつ"on_sale=1")」の動画に「予告編」ファイルがある場合、アプリケーションは動画に対応する「予告編」ファイルを再生します。
5. "downloadable_condition"フィールドの値を確認した後、メディアファイルダウンロードオプションをユーザーに適用するかどうかを決定します。
"downloadable"と"downloadable_xfiles"
・downloadable_condition:ファイルダウンロードオプションを適用するための条件です。
0 = 常に"downloadable"設定を確認してください(下記参照)。
1 = 動画が「販売中」かつユーザーがアクセスを許可されている場合にのみ"downloadable"設定を確認します。
それ以外の場合は、ダウンロードオプションを適用しません。
・downloadable("downloadable_condition"の値による):ユーザーにダウンロードオプションを適用します。
0 =ダウンロードオプションを適用しません。
1 =動画メディアリストのファイルのダウンロードのみ許可します。
2 =動画メディアリストのファイルと"downloadable_xfiles"フィールドで指定されたファイルのダウンロードを許可します。
3 ="downloadable_xfiles"フィールドで指定されたファイルのダウンロードのみ許可します。
・downloadable_xfiles:他のダウンロード可能ファイルへのリンク。
形式:1行に1つのURL。各URLは単独で、またはラベルを付けて指定できます。
URLのみ:http://www.myserver.com/folder/myfile.mp4
ラベル付きURL(ラベル+ダッシュ3つ+URL):Label---http://www.myserver.com/folder/myfile.mp4
リクエストの構築
リクエストURLとGET変数
リクエスト固有のGET変数
| 変数 | 値 | 説明 |
|---|---|---|
| go | clips | APIセクション |
| do | get | APIアクション |
| iq | Clip ID | 動画もしくは広告のID |
リクエストURLは以下のようになります。必須情報(key, timestamp, salt, signature)を追加することを忘れないでください。
POST変数
以下のPOST変数はオプションです。
| 変数 | 値 | 説明 |
|---|---|---|
| generateEmbedCode | (int) 0|1 | "1"の場合、対応する埋め込みコードが生成されます。 |
| embedWidth | (int) width | 埋め込みコードの幅(px) |
| embedHeight | (int) height | 埋め込みコードの高さ(px) |
| embedURLVars | (string) "&var1=value1..." | 埋め込みコードの動画プレーヤーURL変数。 可能なURL変数はこちらでご確認ください。 |
応答例
リクエストが成功した場合は、以下の内容のレスポンスを受け取ります。
・data:動画情報
・media:動画に関連付けられているメディアファイルのリスト
・media_mbr:動画に関連付けられているマルチビットレートURL(Flash/F4M, HTML5/DASH)
・subtitles:字幕のリスト
・interactivities:インタラクティビティのリスト
・channels:クリップに関連付けられているチャンネルのリスト
・categories:クリップに関連付けられているカテゴリーのリスト
{
"data": {
"ad_is_channel_mid_roll": "0",
"ad_is_channel_pre_roll": "0",
"ad_is_clip_pre_roll": "0",
"ad_link": "",
"ad_policy": "0",
"admin_template": "",
"allow_comments": "1",
"aspect": "1.78",
"clicks": "0",
"date": "1381911153",
"date_formatted": "16\/10\/2013 10:12:33 AM",
"date_lastmod": "1423210557",
"date_lastmod_formatted": "06\/02\/2015 09:15:57 AM",
"description": "<p>Clip description<\/p>",
"description_seo": "Clip description",
"dislikes": "1",
"dislikes_formatted": "1",
"downloadable": "0",
"downloadable_condition": "0",
"downloadable_xfiles": "",
"duration": "8",
"duration_formatted": "00:08",
"id": "45",
"id_imdb": "",
"id_import": "",
"id_user": "1",
"img_icon": "http:\/\/......\/uploads\/images\/clip_45_1390047394_icon.jpg",
"img_poster": "http:\/\/......\/uploads\/images\/clip_45_1390047394_poster.jpg",
"img_social": "http:\/\/......\/uploads\/images\/clip_45_1390047394_social.jpg",
"img_thumbnail": "http:\/\/......\/uploads\/images\/clip_45_1390047394_thumb.jpg",
"interactivity_randomization": "0",
"interactivity_spacing": "1",
"interactivity_start_delay": "1",
"interactivity_timing": "0",
"is_3d": "0",
"is_360": "0",
"is_ad": "0",
"is_featured": "1",
"is_indexable": "1",
"is_searchable": "1",
"is_skippable": "1",
"is_skippable_after": "0",
"is_visitable": "1",
"likes": "1",
"likes_formatted": "1",
"privacy": "0",
"privacy_access_level": "99",
"socialize": "1",
"sprite_img": "http:\/\/......\/uploads\/images\/clip_45_1390926596_sprite.jpg",
"sprite_vtt": "http:\/\/......\/uploads\/images\/clip_45_1390926596_sprite.vtt",
"status": "1",
"status_moderation": "1",
"store_on_sale": "0",
"store_play_trailer": "1",
"tags": "tag1, tag2, tag3, tag4",
"title": "This is a sample Clip",
"title_url": "this-is-a-sample-clip",
"type": "1",
"type_name": "streamclip_vod",
"url": "http:\/\/......\/index.php\/video\/45\/ws-interstreamm\/",
"user_alias": "InterStream",
"user_url": "http:\/\/......\/index.php\/portal\/user\/1\/inter-stream\/",
"views": "346",
"views_complete": "42",
"views_complete_formatted": "42",
"views_embed": "7",
"views_embed_formatted": "7",
"views_formatted": "346",
"views_page": "206",
"views_page_formatted": "206"
},
"media": {
"0": {
"id": "4843",
"id_quality": "2",
"vod_flash": "http:\/\/......\/uploads\/movies\/myvideo-hq.mp4",
"vod_html5_h264": "http:\/\/......\/uploads\/movies\/myvideo-hq.mp4",
"vod_html5_webm": "",
"live_flash": "",
"live_ios": "",
"live_rtsp": "",
"live_ms": "",
"embed_flash": "",
"embed_html5": "",
"vod_flash_trailer": "",
"vod_html5_h264_trailer": "",
"vod_html5_webm_trailer": ""
},
"1": {
"id": "4844",
"id_quality": "3",
"vod_flash": "http:\/\/......\/uploads\/movies\/myvideo-normal.mp4",
"vod_html5_h264": "http:\/\/......\/uploads\/movies\/myvideo-normal.mp4",
"vod_html5_webm": "",
"live_flash": "",
"live_ios": "",
"live_rtsp": "",
"live_ms": "",
"embed_flash": "",
"embed_html5": "",
"vod_flash_trailer": "",
"vod_html5_h264_trailer": "",
"vod_html5_webm_trailer": ""
},
"2": {
"id": "4845",
"id_quality": "1",
"vod_flash": "",
"vod_html5_h264": "",
"vod_html5_webm": "",
"live_flash": "",
"live_ios": "",
"live_rtsp": "",
"live_ms": "",
"embed_flash": "",
"embed_html5": "",
"vod_flash_trailer": "http:\/\/......\/uploads\/movies\/myvideo-low.mp4",
"vod_html5_h264_trailer": "http:\/\/......\/uploads\/movies\/myvideo-low.mp4",
"vod_html5_webm_trailer": ""
}
},
"media_mbr": {
"flash": "http://../f4m_manifest.f4m",
"html5": "http://../dash_manifest.mpd"
},
"subtitles": [],
"interactivities": {
"settings": {
"timing": "absolute",
"start_delay": -1,
"spacing": -1,
"randomize": -1
},
"list": [
{
"clicks": "18",
"closable": "1",
"content": "http://pubads.g.doubleclick.net/....&LR_SCHEMA=vast2",
"contentType": "vast",
"duration": -1,
"end": "8",
"height": "0",
"id": "141",
"link": "",
"relative_position": -1,
"start": "5",
"views": "529",
"width": "0"
},
{
"clicks": "1",
"closable": "0",
"content": "Click for more info here!",
"contentType": "text",
"duration": -1,
"end": "4",
"height": "0",
"id": "142",
"link": "http://interactivity_link/",
"relative_position": -1,
"start": "1",
"views": "381",
"width": "0"
}
]
},
"channels": [{
"id": "1",
"title": "Video Channel 1"
}],
"categories": [{
"id": 7,
"title": "Animation",
"breadcrumb": [{
"id": "1",
"title": "Movies"
}, {
"id": 7,
"title": "Animation"
}]
}]
}
認証情報にGETの許可がない場合など、リクエストが失敗した場合のレスポンス
{
"error" : "REQUEST_ERROR",
"error_long" : "Permission error: GET"
}
このリクエストは以下のエラーを返す可能性があります。
・REQUEST_ERROR | Invalid Clip ID
動画IDが1未満かもしくは数値ではありません。
・REQUEST_ERROR | Clip not found, inactive or restricted
動画が見つからない、非アクティブ、もしくは公開制限されています。
その他のエラー内容に関しては一般的なエラーメッセージを確認してください。
PHPサンプルコード
GETおよびPOSTデータを準備します。
// GET変数 $GET_VARS = array( "go" => "clips", "do" => "get", "iq" => 45 ); // POST変数 $POST_VARS = array();
salt, timestamp, signatureを生成してリクエストを送信します。
// APIベースURLと認証情報の収集
$API_URL = "https://www.interstreamdomain.tv/api.php";
$API_KEY_ID = "1b323a1cb879fd4e66530fbad07a32ee";
$API_SHARED_SECRET = "MWIzMjNhMWNiODc5ZmQ0ZTY2NTMwZmJhZDA3YTMyZWViOTQ3MDJiOGM2ZTU2NjE3"; // 公開しないでください
// salt, timestamp, signatureの生成
$salt = md5(mt_rand());
$timestamp = time();
$signature = base64_encode(hash_hmac('sha256', $salt.$timestamp, $API_SHARED_SECRET, true));
// key, salt, timestamp, signatureをGET変数に追加
$GET_VARS["timestamp"] = $timestamp; // UTCタイムスタンプ
$GET_VARS["salt"] = $salt;
$GET_VARS["key"] = $API_KEY_ID ; // APIキーID:これは公開されており、アプリケーションを識別するためにAPIによって使用されます
$GET_VARS["signature"] = $signature;
// リクエストURLを作成します。HTTPクエリを作成するためにPHPの組み込み関数を使用しない場合は、値をURLエンコードすることを忘れないでください。
$REQUEST_URL = $API_URL."?".http_build_query($GET_VARS);
// ".../api.php?go=api_subject&do=api_action&etc..."のようにURLを構築
// 新しいcURLリソースを作成して適切なオプションを設定
$ch = curl_init();
curl_setopt($ch, CURLOPT_URL, $REQUEST_URL);
curl_setopt($ch, CURLOPT_POST, true);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
curl_setopt($ch, CURLOPT_HEADER, false);
curl_setopt($ch, CURLOPT_POSTFIELDS, $POST_VARS);
// PHPホストに有効なSSL証明書がない場合は、SSL証明書の検証を無効にする必要があります。これは危険であり、有効な証明書がインストールされるまで一時的に行われるべきです。
curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, false); // Turns off verification of the SSL certificate.
curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false); // Turns off verification of the SSL certificate.
// APIにリクエストを送信
$response = curl_exec($ch);
// レスポンス処理
if (!$response) {
echo 'API call failed';
}
else
{
print_r(json_decode($response,true));
}