wvp-GB28181-pro/src/main/java/com/genersoft/iot/vmp/web/ApiStreamController.java

189 lines
7.7 KiB
Java
Raw Normal View History

2020-09-25 17:41:02 +08:00
package com.genersoft.iot.vmp.web;
import com.alibaba.fastjson.JSON;
2020-11-17 15:27:13 +08:00
import com.alibaba.fastjson.JSONArray;
2020-09-25 17:41:02 +08:00
import com.alibaba.fastjson.JSONObject;
import com.genersoft.iot.vmp.common.StreamInfo;
import com.genersoft.iot.vmp.gb28181.bean.Device;
import com.genersoft.iot.vmp.gb28181.bean.DeviceChannel;
import com.genersoft.iot.vmp.gb28181.transmit.cmd.impl.SIPCommander;
2020-11-17 15:27:13 +08:00
import com.genersoft.iot.vmp.media.zlm.ZLMRESTfulUtils;
2020-09-25 17:41:02 +08:00
import com.genersoft.iot.vmp.storager.IVideoManagerStorager;
import com.genersoft.iot.vmp.vmanager.play.PlayController;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
2020-11-17 15:27:13 +08:00
import org.springframework.beans.factory.annotation.Value;
2020-09-25 17:41:02 +08:00
import org.springframework.http.HttpStatus;
import org.springframework.http.ResponseEntity;
import org.springframework.web.bind.annotation.*;
2020-12-21 11:13:27 +08:00
import org.springframework.web.context.request.async.DeferredResult;
2020-09-25 17:41:02 +08:00
/**
* LiveGBSAPI
*/
@CrossOrigin
@RestController
@RequestMapping(value = "/api/v1/stream")
public class ApiStreamController {
private final static Logger logger = LoggerFactory.getLogger(ApiStreamController.class);
@Autowired
private SIPCommander cmder;
@Autowired
private IVideoManagerStorager storager;
private boolean closeWaitRTPInfo = false;
2020-11-17 15:27:13 +08:00
@Autowired
private ZLMRESTfulUtils zlmresTfulUtils;
2020-12-21 11:13:27 +08:00
@Autowired
private PlayController playController;
2020-09-25 17:41:02 +08:00
/**
* -
* @param serial
* @param channel : 1
* @param code , /api/v1/device/channellist ChannelList.ID, channel
* @param cdn TODO CDN , : [rtmp|rtsp]://xxx, encodeURIComponent
* @param audio TODO ,
* @param transport UDP
* @param checkchannelstatus TODO , false, 线
* @param transportmode TODO transport=TCP , ,
* @param timeout TODO (),
* @return
*/
@RequestMapping(value = "/start")
2020-12-21 11:13:27 +08:00
private DeferredResult<JSONObject> start(String serial ,
@RequestParam(required = false)Integer channel ,
@RequestParam(required = false)String code,
@RequestParam(required = false)String cdn,
@RequestParam(required = false)String audio,
@RequestParam(required = false)String transport,
@RequestParam(required = false)String checkchannelstatus ,
@RequestParam(required = false)String transportmode,
@RequestParam(required = false)String timeout
2020-09-25 17:41:02 +08:00
){
2020-12-21 11:13:27 +08:00
DeferredResult<JSONObject> resultDeferredResult = new DeferredResult<JSONObject>();
2020-09-25 17:41:02 +08:00
Device device = storager.queryVideoDevice(serial);
if (device == null ) {
JSONObject result = new JSONObject();
result.put("error","device[ " + serial + " ]未找到");
2020-12-21 11:13:27 +08:00
resultDeferredResult.setResult(result);
2020-11-17 15:27:13 +08:00
}else if (device.getOnline() == 0) {
JSONObject result = new JSONObject();
result.put("error","device[ " + code + " ]offline");
2020-12-21 11:13:27 +08:00
resultDeferredResult.setResult(result);
2020-09-25 17:41:02 +08:00
}
2020-12-21 11:13:27 +08:00
resultDeferredResult.onTimeout(()->{
logger.info("播放等待超时");
JSONObject result = new JSONObject();
result.put("error","timeout");
resultDeferredResult.setResult(result);
});
2020-11-17 15:27:13 +08:00
2020-09-25 17:41:02 +08:00
DeviceChannel deviceChannel = storager.queryChannel(serial, code);
if (deviceChannel == null) {
JSONObject result = new JSONObject();
result.put("error","channel[ " + code + " ]未找到");
2020-12-21 11:13:27 +08:00
resultDeferredResult.setResult(result);
2020-11-17 15:27:13 +08:00
}else if (deviceChannel.getStatus() == 0) {
JSONObject result = new JSONObject();
result.put("error","channel[ " + code + " ]offline");
2020-12-21 11:13:27 +08:00
resultDeferredResult.setResult(result);
2020-09-25 17:41:02 +08:00
}
2020-12-21 11:13:27 +08:00
DeferredResult<ResponseEntity<String>> play = playController.play(serial, code);
2020-11-17 15:27:13 +08:00
2020-12-21 11:13:27 +08:00
play.setResultHandler((Object o)->{
ResponseEntity<String> responseEntity = (ResponseEntity)o;
StreamInfo streamInfo = JSON.parseObject(responseEntity.getBody(), StreamInfo.class);
2020-09-25 17:41:02 +08:00
JSONObject result = new JSONObject();
result.put("StreamID", streamInfo.getStreamId());
2020-09-25 17:41:02 +08:00
result.put("DeviceID", device.getDeviceId());
result.put("ChannelID", code);
result.put("ChannelName", deviceChannel.getName());
2020-11-20 10:40:43 +08:00
result.put("ChannelCustomName", "");
result.put("FLV", streamInfo.getFlv());
result.put("WS_FLV", streamInfo.getWs_flv());
result.put("RTMP", streamInfo.getRtmp());
result.put("HLS", streamInfo.getHls());
result.put("RTSP", streamInfo.getRtsp());
2020-09-25 17:41:02 +08:00
result.put("CDN", "");
result.put("SnapURL", "");
result.put("Transport", device.getTransport());
result.put("StartAt", "");
result.put("Duration", "");
result.put("SourceVideoCodecName", "");
result.put("SourceVideoWidth", "");
result.put("SourceVideoHeight", "");
result.put("SourceVideoFrameRate", "");
result.put("SourceAudioCodecName", "");
result.put("SourceAudioSampleRate", "");
result.put("AudioEnable", "");
result.put("Ondemand", "");
result.put("InBytes", "");
result.put("InBitRate", "");
result.put("OutBytes", "");
result.put("NumOutputs", "");
result.put("CascadeSize", "");
result.put("RelaySize", "");
result.put("ChannelPTZType", 0);
2020-12-21 11:13:27 +08:00
resultDeferredResult.setResult(result);
});
return resultDeferredResult;
2020-09-25 17:41:02 +08:00
}
/**
* -
* @param serial
* @param channel
* @param code
* @param check_outputs
* @return
*/
@RequestMapping(value = "/stop")
@ResponseBody
private JSONObject stop(String serial ,
@RequestParam(required = false)Integer channel ,
@RequestParam(required = false)String code,
@RequestParam(required = false)String check_outputs
){
2020-12-21 11:13:27 +08:00
StreamInfo streamInfo = storager.queryPlayByDevice(serial, code);
2020-09-25 17:41:02 +08:00
if (streamInfo == null) {
JSONObject result = new JSONObject();
result.put("error","未找到流信息");
return result;
}
cmder.streamByeCmd(streamInfo.getStreamId());
storager.stopPlay(streamInfo);
2020-09-25 17:41:02 +08:00
return null;
}
/**
* -
* @param serial
* @param channel
* @param code
* @return
*/
@RequestMapping(value = "/touch")
@ResponseBody
private JSONObject touch(String serial ,String t,
@RequestParam(required = false)Integer channel ,
@RequestParam(required = false)String code,
@RequestParam(required = false)String autorestart,
@RequestParam(required = false)String audio,
@RequestParam(required = false)String cdn
){
return null;
}
}