123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189 |
- <?php
- namespace Qiniu\Pili;
- use \Qiniu\Pili\Utils;
- use \Qiniu\Pili\HttpRequest;
- class Stream
- {
- private $_transport;
- private $_hub;
- private $_key;
- private $_baseURL;
- public function __construct($transport, $hub, $key)
- {
- $this->_transport = $transport;
- $this->_hub = $hub;
- $this->_key = $key;
- $cfg = Config::getInstance();
- $protocal = $cfg->USE_HTTPS === true ? "https" : "http";
- $this->_baseURL = sprintf("%s://%s/%s/hubs/%s/streams/%s", $protocal, $cfg->API_HOST, $cfg->API_VERSION, $this->_hub, Utils::base64UrlEncode($this->_key));
- }
- //获得流信息.
- /*
- * RETURN
- * @hub: Hub名.
- * @key: 流名.
- * @disableTill: 禁用结束的时间, 0 表示不禁用, -1 表示永久禁用.
- * @converts: 实时转码规格.
- */
- public function info()
- {
- $resp=$this->_transport->send(HttpRequest::GET, $this->_baseURL);
- $ret = array();
- $ret["hub"] = $this->_hub;
- $ret["key"] = $this->_key;
- $ret["disabledTill"] = $resp["disabledTill"];
- $ret["converts"] = $resp["converts"];
- return $ret;
- }
- //在一定期限内禁止一个流.
- /*
- * PARAM
- * @till: Unix 时间戳, 在这之前流均不可用.
- */
- public function disable($till = null)
- {
- $url = $this->_baseURL . "/disabled";
- if (empty($till)) {
- $params['disabledTill'] = -1;
- } else {
- $params['disabledTill'] = $till;
- }
- $body = json_encode($params);
- return $this->_transport->send(HttpRequest::POST, $url, $body);
- }
- //启用一个流.
- public function enable()
- {
- $url = $this->_baseURL . "/disabled";
- $params['disabledTill'] = 0;
- $body = json_encode($params);
- return $this->_transport->send(HttpRequest::POST, $url, $body);
- }
- //查询直播状态.
- /*
- * RETURN
- * @startAt: 直播开始的 Unix 时间戳, 0 表示当前没在直播.
- * @clientIP: 直播的客户端 IP.
- * @bps: 直播的码率.
- * @fps: 直播的帧率.
- */
- public function liveStatus()
- {
- $url = $this->_baseURL . "/live";
- return $this->_transport->send(HttpRequest::GET, $url);
- }
- //查询直播历史.
- /*
- * PARAM
- * @start: Unix 时间戳, 限定了查询的时间范围, 0 值表示不限定, 系统会返回所有时间的直播历史.
- * @end: Unix 时间戳, 限定了查询的时间范围, 0 值表示不限定, 系统会返回所有时间的直播历史.
- * RETURN
- * @items: 数组. 每个item包含一次推流的开始及结束时间.
- * @start: Unix 时间戳, 直播开始时间.
- * @end: Unix 时间戳, 直播结束时间.
- */
- public function historyActivity($start = null, $end = null)
- {
- $url = $this->_baseURL . "/historyrecord";
- $flag = "?";
- if (!empty($start)) {
- $url = $url . $flag . "start=" . $start;
- $flag = "&";
- }
- if (!empty($end)) {
- $url = $url . $flag . "end=" . $end;
- }
- return $this->_transport->send(HttpRequest::GET, $url);
- }
- //保存直播回放.
- /*
- * PARAM
- * @start: Unix 时间戳, 起始时间, 0 值表示不指定, 则不限制起始时间.
- * @end: Unix 时间戳, 结束时间, 0 值表示当前时间.
- * RETURN
- * @fname: 保存到bucket里的文件名, 由系统生成.
- */
- public function save($start = null, $end = null)
- {
- $url = $this->_baseURL . "/saveas";
- if (!empty($start)) {
- $params['start'] = $start;
- }
- if (!empty($end)) {
- $params['end'] = $end;
- }
- $body = json_encode($params);
- return $this->_transport->send(HttpRequest::POST, $url, $body);
- }
- //灵活度更高的保存直播回放.
- /*
- * PARAM
- * @fname: 保存的文件名, 不指定会随机生成.
- * @start: Unix 时间戳, 起始时间, 0 值表示不指定, 则不限制起始时间.
- * @end: Unix 时间戳, 结束时间, 0 值表示当前时间.
- * @format: 保存的文件格式, 默认为m3u8.
- * @pipeline: dora 的私有队列, 不指定则用默认队列.
- * @notify: 保存成功后的回调地址.
- * @expireDays: 对应ts文件的过期时间.
- * -1 表示不修改ts文件的expire属性.
- * 0 表示修改ts文件生命周期为永久保存.
- * >0 表示修改ts文件的的生命周期为ExpireDays.
- * RETURN
- * @fname: 保存到bucket里的文件名.
- * @persistentID: 异步模式时,持久化异步处理任务ID,通常用不到该字段.
- */
- public function saveas($options = null)
- {
- $url = $this->_baseURL . "/saveas";
- if (!empty($options)) {
- $body = json_encode($options);
- } else {
- $body = null;
- }
- return $this->_transport->send(HttpRequest::POST, $url, $body);
- }
- //对流进行截图并保存.
- /*
- * PARAM
- * @fname: 保存的文件名, 不指定会随机生成.
- * @time: Unix 时间戳, 保存的时间点, 默认为当前时间.
- * @format: 保存的文件格式, 默认为jpg.
- * RETURN
- * @fname: 保存到bucket里的文件名.
- */
- public function snapshot($options = null)
- {
- $url = $this->_baseURL . "/snapshot";
- if (!empty($options)) {
- $body = json_encode($options);
- } else {
- $body = null;
- }
- return $this->_transport->send(HttpRequest::POST, $url, $body);
- }
- //更改流的实时转码规格
- /*
- * PARAM
- * @profiles: 实时转码规格. array("480p", "720p")
- */
- public function updateConverts($profiles)
- {
- $url = $this->_baseURL . "/converts";
- $params['converts'] = $profiles;
- $body = json_encode($params);
- return $this->_transport->send(HttpRequest::POST, $url, $body);
- }
- }
|