動画
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)); }