|  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | import com.alibaba.fastjson2.JSON; | 
|---|
|  |  |  | import com.alibaba.fastjson2.JSONObject; | 
|---|
|  |  |  | import com.genersoft.iot.vmp.media.zlm.dto.MediaServerItem; | 
|---|
|  |  |  | import com.genersoft.iot.vmp.media.zlm.dto.MediaServer; | 
|---|
|  |  |  | import com.genersoft.iot.vmp.utils.SSLSocketClientUtil; | 
|---|
|  |  |  | import okhttp3.*; | 
|---|
|  |  |  | import okhttp3.logging.HttpLoggingInterceptor; | 
|---|
|  |  |  | import org.jetbrains.annotations.NotNull; | 
|---|
|  |  |  | 
|---|
|  |  |  | import org.springframework.stereotype.Component; | 
|---|
|  |  |  | import org.springframework.util.ObjectUtils; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | import javax.net.ssl.X509TrustManager; | 
|---|
|  |  |  | import java.io.IOException; | 
|---|
|  |  |  | import java.net.ConnectException; | 
|---|
|  |  |  | import java.net.SocketTimeoutException; | 
|---|
|  |  |  | 
|---|
|  |  |  | private OkHttpClient getClient(){ | 
|---|
|  |  |  | return getClient(null); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | private OkHttpClient getClient(Integer readTimeOut){ | 
|---|
|  |  |  | if (client == null) { | 
|---|
|  |  |  | if (readTimeOut == null) { | 
|---|
|  |  |  | 
|---|
|  |  |  | // OkHttp進行添加攔截器loggingInterceptor | 
|---|
|  |  |  | httpClientBuilder.addInterceptor(logging); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | X509TrustManager manager = SSLSocketClientUtil.getX509TrustManager(); | 
|---|
|  |  |  | // 设置ssl | 
|---|
|  |  |  | httpClientBuilder.sslSocketFactory(SSLSocketClientUtil.getSocketFactory(manager), manager); | 
|---|
|  |  |  | httpClientBuilder.hostnameVerifier(SSLSocketClientUtil.getHostnameVerifier());//忽略校验 | 
|---|
|  |  |  | client = httpClientBuilder.build(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | return client; | 
|---|
|  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | public JSONObject sendGet(MediaServerItem mediaServerItem, String api, Map<String, Object> param, RequestCallback callback) { | 
|---|
|  |  |  | public JSONObject sendGet(MediaServer mediaServerItem, String api, Map<String, Object> param, RequestCallback callback) { | 
|---|
|  |  |  | OkHttpClient client = getClient(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if (mediaServerItem == null) { | 
|---|
|  |  |  | 
|---|
|  |  |  | logger.warn("未启用Assist服务"); | 
|---|
|  |  |  | return null; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | StringBuffer stringBuffer = new StringBuffer(); | 
|---|
|  |  |  | stringBuffer.append(String.format("http://%s:%s/%s",  mediaServerItem.getIp(), mediaServerItem.getRecordAssistPort(), api)); | 
|---|
|  |  |  | StringBuilder stringBuffer = new StringBuilder(); | 
|---|
|  |  |  | stringBuffer.append(api); | 
|---|
|  |  |  | JSONObject responseJSON = null; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if (param != null && param.keySet().size() > 0) { | 
|---|
|  |  |  | if (param != null && !param.keySet().isEmpty()) { | 
|---|
|  |  |  | stringBuffer.append("?"); | 
|---|
|  |  |  | int index = 1; | 
|---|
|  |  |  | for (String key : param.keySet()){ | 
|---|
|  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | String url = stringBuffer.toString(); | 
|---|
|  |  |  | logger.info("[访问assist]: {}", url); | 
|---|
|  |  |  | Request request = new Request.Builder() | 
|---|
|  |  |  | .get() | 
|---|
|  |  |  | .url(url) | 
|---|
|  |  |  | 
|---|
|  |  |  | return responseJSON; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | public JSONObject sendPost(MediaServerItem mediaServerItem, String api, JSONObject param, ZLMRESTfulUtils.RequestCallback callback, Integer readTimeOut) { | 
|---|
|  |  |  | public JSONObject sendPost(MediaServer mediaServerItem, String url, | 
|---|
|  |  |  | JSONObject param, ZLMRESTfulUtils.RequestCallback callback, | 
|---|
|  |  |  | Integer readTimeOut) { | 
|---|
|  |  |  | OkHttpClient client = getClient(readTimeOut); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if (mediaServerItem == null) { | 
|---|
|  |  |  | return null; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | String url = String.format("http://%s:%s/%s",  mediaServerItem.getIp(), mediaServerItem.getRecordAssistPort(), api); | 
|---|
|  |  |  | logger.info("[访问assist]: {}, 参数: {}", url, param); | 
|---|
|  |  |  | JSONObject responseJSON = new JSONObject(); | 
|---|
|  |  |  | //-2自定义流媒体 调用错误码 | 
|---|
|  |  |  | responseJSON.put("code",-2); | 
|---|
|  |  |  | 
|---|
|  |  |  | return responseJSON; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | public JSONObject getInfo(MediaServerItem mediaServerItem, RequestCallback callback){ | 
|---|
|  |  |  | public JSONObject getInfo(MediaServer mediaServerItem, RequestCallback callback){ | 
|---|
|  |  |  | Map<String, Object> param = new HashMap<>(); | 
|---|
|  |  |  | return sendGet(mediaServerItem, "api/record/info",param, callback); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | public JSONObject addTask(MediaServerItem mediaServerItem, String app, String stream, String startTime, | 
|---|
|  |  |  | public JSONObject addTask(MediaServer mediaServerItem, String app, String stream, String startTime, | 
|---|
|  |  |  | String endTime, String callId, List<String> filePathList, String remoteHost) { | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | JSONObject videoTaskInfoJSON = new JSONObject(); | 
|---|
|  |  |  | videoTaskInfoJSON.put("app", app); | 
|---|
|  |  |  | videoTaskInfoJSON.put("stream", stream); | 
|---|
|  |  |  | 
|---|
|  |  |  | if (!ObjectUtils.isEmpty(remoteHost)) { | 
|---|
|  |  |  | videoTaskInfoJSON.put("remoteHost", remoteHost); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | return sendPost(mediaServerItem, "api/record/file/download/task/add", videoTaskInfoJSON, null, 30); | 
|---|
|  |  |  | String urlStr = String.format("%s/api/record/file/download/task/add",  remoteHost);; | 
|---|
|  |  |  | return sendPost(mediaServerItem, urlStr, videoTaskInfoJSON, null, 30); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | public JSONObject queryTaskList(MediaServerItem mediaServerItem, String taskId, Boolean isEnd) { | 
|---|
|  |  |  | public JSONObject queryTaskList(MediaServer mediaServerItem, String app, String stream, String callId, | 
|---|
|  |  |  | String taskId, Boolean isEnd, String scheme) { | 
|---|
|  |  |  | Map<String, Object> param = new HashMap<>(); | 
|---|
|  |  |  | if (!ObjectUtils.isEmpty(app)) { | 
|---|
|  |  |  | param.put("app", app); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (!ObjectUtils.isEmpty(stream)) { | 
|---|
|  |  |  | param.put("stream", stream); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (!ObjectUtils.isEmpty(callId)) { | 
|---|
|  |  |  | param.put("callId", callId); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (!ObjectUtils.isEmpty(taskId)) { | 
|---|
|  |  |  | param.put("taskId", taskId); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (!ObjectUtils.isEmpty(isEnd)) { | 
|---|
|  |  |  | param.put("isEnd", isEnd); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | return sendGet(mediaServerItem, "api/record/file/download/task/list", param, null); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | public JSONObject addCollect(MediaServerItem mediaServerItem, JSONObject jsonObject) { | 
|---|
|  |  |  | return sendPost(mediaServerItem, "api/record/file/collection/add", jsonObject, null, 30); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | public JSONObject deleteFiles(MediaServerItem mediaServerItem, List<String> filePathList) { | 
|---|
|  |  |  | JSONObject jsonObject = new JSONObject(); | 
|---|
|  |  |  | jsonObject.put("filePathList", filePathList); | 
|---|
|  |  |  | return sendPost(mediaServerItem, "api/record/file/delete", jsonObject, null, 15*60); | 
|---|
|  |  |  | String urlStr = String.format("%s://%s:%s/api/record/file/download/task/list", | 
|---|
|  |  |  | scheme, mediaServerItem.getIp(), mediaServerItem.getRecordAssistPort());; | 
|---|
|  |  |  | return sendGet(mediaServerItem, urlStr, param, null); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|