# 查询频道回放设置

单独查询回放开关可使用旧版接口，接口地址[查询频道回放开关](https://git.polyv.net/help-center/document-center/-/blob/master/live/api/channel/playback/get_playback_enabled/README.md)

### 接口描述

```
1、查询频道回放设置
2、接口支持https协议
```

### 接口URL

```
https://api.polyv.net/live/v3/channel/playback/get-setting
```

[在线API调用](https://git.polyv.net/help-center/document-center/-/blob/master/req.html?api=http:/api.polyv.net/live/v3/channel/playback/get-setting/README.md)

### 请求方式

```
GET
```

### 接口约束

1、接口同时支持HTTP 、HTTPS ，建议使用HTTPS 确保接口安全，接口调用有频率限制，[详细请查看](https://git.polyv.net/help-center/document-center/-/blob/master/live/api/limit/README.md)

### 请求参数描述

| 参数名       | 必选   | 类型     | 说明                                                                                                                                                                                                        |
| --------- | ---- | ------ | --------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
| appId     | true | String | 账号appId【详见[获取密钥](https://git.polyv.net/help-center/document-center/-/blob/master/live/api/getSecretKey/README.md)】                                                                                        |
| timestamp | true | Long   | 当前13位毫秒级时间戳，3分钟内有效                                                                                                                                                                                        |
| sign      | true | String | 签名，为32位大写的MD5值,`生成签名的appSecret密钥作为通信数据安全的关键信息，严禁保存在客户端直接使用，所有API都必须通过客户自己服务器中转调用POLYV服务器获取响应数据`【详见[签名生成规则](https://git.polyv.net/help-center/document-center/-/blob/master/live/api/buildSign/README.md)】 |
| channelId | true | String | 频道号                                                                                                                                                                                                       |

### 示例

```requestUrl
http://api.polyv.net/live/v3/channel/playback/get-setting?appId=frlr1zazn3&sign=9DC1D9A3AAD34E0DD5C3B3154F1A6F5D&channelId=3187786&timestamp=1655964947987
```

### 响应参数描述

| 参数名     | 类型      | 说明                                                                                                                               |
| ------- | ------- | -------------------------------------------------------------------------------------------------------------------------------- |
| code    | Integer | 响应状态码，200为成功返回，非200为失败【详见[全局错误说明](https://git.polyv.net/help-center/document-center/-/blob/master/live/api/errorInfo/README.md)】 |
| status  | String  | 响应状态文本信息                                                                                                                         |
| message | String  | 响应描述信息，当code为400或者500的时候，辅助描述错误原因                                                                                                |
| data    | Object  | 请求成功返回频道回放设置【详见[data参数描述](#Data参数描述)】                                                                                            |

### Data参数描述

| 参数名                              | 类型     | 说明                                                                                   |
| -------------------------------- | ------ | ------------------------------------------------------------------------------------ |
| channelId                        | String | 频道号                                                                                  |
| type                             | String | <p>回放类型<br>single：单个视频回放<br>list：列表回放</p>                                            |
| playbackEnabled                  | String | <p>回放的开关<br>Y：开启<br>N：关闭</p>                                                         |
| origin                           | String | <p>回放的视频来源<br>record：录制文件<br>playback：回放列表<br>vod：点播列表</p>                           |
| videoId                          | String | 回放的视频ID                                                                              |
| videoName                        | String | 回放的视频名称                                                                              |
| sectionEnabled                   | String | <p>回放设置，章节开关<br>Y：开启<br>N：关闭</p>                                                     |
| globalSettingEnabled             | String | <p>是否应用通用设置<br>Y：是<br>N：否</p>                                                        |
| chatPlaybackEnabled              | String | <p>聊天重放<br>Y：开启<br>N：关闭</p>                                                          |
| crontabType                      | String | <p>定时回放类型<br>timedOpen：定时打开，timedClosed：定时关闭，period：时间段内打开,custom-自定义,disable：关闭</p> |
| startTime                        | Long   | 放开回放的时间,13位毫秒级时间                                                                     |
| endTime                          | Long   | 关闭回放的时间,13位毫秒级时间                                                                     |
| playbackMultiplierEnabled        | String | <p>倍数播放开关<br>Y：开启<br>N：关闭</p>                                                        |
| playbackProgressBarEnabled       | String | <p>进度条开关<br>Y：开启<br>N：关闭</p>                                                         |
| playbackProgressBarOperationType | String | <p>进度条操作方式<br>drag 拖动,prohibitDrag 禁止拖动,dragHistoryOnly 只能拖动已观看内容</p>                |
| showPlayButtonEnabled            | String | <p>显示播放按钮开关<br>Y：开启<br>N：关闭</p>                                                      |
| customOpenDuration               | Long   | 定时回放：自定义时间,crontType为custom自定义时生效                                                    |
| productPlaybackEnabled           | String | <p>商品库开关<br>Y：开启<br>N：关闭,开启后，回放时观众将看到商品列表和推送商品，将读取后台最新的商品数据。</p>                     |

### Java请求示例

快速接入基础代码请下载相关依赖源码， [点击下载源代码](https://git.polyv.net/help-center/document-center/-/blob/master/third_res/util.zip) ,下载后加入到自己的源码工程中即可。测试用例中的**HttpUtil.java 和 LiveSignUtil.java** 都包含在下载文件中。

> 强烈建议您使用[直播Java SDK](https://git.polyv.net/help-center/document-center/-/blob/master/live/java/README.md)完成API的功能对接，直播Java SDK 对API调用逻辑、异常处理、数据签名、HTTP请求线程池进行了统一封装和优化。

```java
private static final Logger log = LoggerFactory.getLogger(ChannelPlayBackTest.class);
/**
 * 查询频道回放设置
 * @throws IOException
 * @throws NoSuchAlgorithmException
 */
@Test
public void testGetPlaybackSetting() throws IOException, NoSuchAlgorithmException {
    //公共参数,填写自己的实际参数
    String appId = super.appId;
    String appSecret = super.appSecret;
    String userId = super.userId;
    String timestamp = String.valueOf(System.currentTimeMillis());
    //业务参数
    String url = "http://api.polyv.net/live/v3/channel/playback/get-setting";
    String channelId = "3187786";
    
    Map<String, String> requestMap = new HashMap<>();
    requestMap.put("appId", appId);
    requestMap.put("timestamp", timestamp);
    requestMap.put("channelId", channelId);
    requestMap.put("sign", LiveSignUtil.getSign(requestMap, appSecret));
    String response = HttpUtil.get(url, requestMap);
    log.info("测试查询频道回放设置，返回值：{}", response);
    //do somethings
    
}
```

### 响应示例

系统全局错误说明详见[全局错误说明](https://git.polyv.net/help-center/document-center/-/blob/master/live/api/errorInfo/README.md)

成功示例

```json
{
    "code": 200,
    "status": "success",
    "message": "",
    "data": {
        "channelId": 3187786,
        "type": "single",
        "origin": "record",
        "videoId": null,
        "playbackEnabled": "Y",
        "videoName": null,
        "sectionEnabled": "Y",
        "globalSettingEnabled": "N",
        "chatPlaybackEnabled": "N",
        "crontabType":"period",
        "startTime": 1694102400000,
        "endTime": 1695398400000,
        "productPlaybackEnabled": null,
        "customOpenDuration": 18,
        "playbackMultiplierEnabled": "Y",
        "playbackProgressBarEnabled": "Y",
        "playbackProgressBarOperationType": "drag",
        "showPlayButtonEnabled": "Y"
    }
}
```

异常示例

参数错误

```json
{
    "code": 400,
    "status": "error",
    "message": "param validate error",
    "data": 400
}
```

未输入appId

```json
{
    "code": 400,
    "status": "error",
    "message": "appId is required.",
    "data": ""
}
```

appId不正确

```json
{
    "code": 400,
    "status": "error",
    "message": "application not found.",
    "data": ""
}
```

时间戳错误

```json
{
    "code": 400,
    "status": "error",
    "message": "invalid timestamp.",
    "data": ""
}
```

签名错误

```json
{
    "code": 403,
    "status": "error",
    "message": "invalid signature.",
    "data": ""
}
```
