|
@@ -1,9 +1,11 @@
|
|
|
package com.zd.alg.iot.vmp.vmanager.gb28181.record;
|
|
package com.zd.alg.iot.vmp.vmanager.gb28181.record;
|
|
|
|
|
|
|
|
-import com.zd.alg.iot.vmp.gb28181.transmit.callback.RequestMessage;
|
|
|
|
|
-import com.zd.alg.iot.vmp.gb28181.bean.RecordInfo;
|
|
|
|
|
|
|
+import com.zd.alg.iot.vmp.gb28181.bean.Device;
|
|
|
|
|
+import com.zd.alg.iot.vmp.gb28181.bean.RecordInfo2;
|
|
|
import com.zd.alg.iot.vmp.gb28181.transmit.callback.DeferredResultHolder;
|
|
import com.zd.alg.iot.vmp.gb28181.transmit.callback.DeferredResultHolder;
|
|
|
|
|
+import com.zd.alg.iot.vmp.gb28181.transmit.callback.RequestMessage;
|
|
|
import com.zd.alg.iot.vmp.gb28181.transmit.cmd.impl.SIPCommander;
|
|
import com.zd.alg.iot.vmp.gb28181.transmit.cmd.impl.SIPCommander;
|
|
|
|
|
+import com.zd.alg.iot.vmp.storager.IVideoManagerStorager;
|
|
|
import io.swagger.annotations.Api;
|
|
import io.swagger.annotations.Api;
|
|
|
import io.swagger.annotations.ApiImplicitParam;
|
|
import io.swagger.annotations.ApiImplicitParam;
|
|
|
import io.swagger.annotations.ApiImplicitParams;
|
|
import io.swagger.annotations.ApiImplicitParams;
|
|
@@ -12,16 +14,9 @@ import org.slf4j.Logger;
|
|
|
import org.slf4j.LoggerFactory;
|
|
import org.slf4j.LoggerFactory;
|
|
|
import org.springframework.beans.factory.annotation.Autowired;
|
|
import org.springframework.beans.factory.annotation.Autowired;
|
|
|
import org.springframework.http.ResponseEntity;
|
|
import org.springframework.http.ResponseEntity;
|
|
|
-import org.springframework.web.bind.annotation.CrossOrigin;
|
|
|
|
|
-import org.springframework.web.bind.annotation.GetMapping;
|
|
|
|
|
-import org.springframework.web.bind.annotation.PathVariable;
|
|
|
|
|
-import org.springframework.web.bind.annotation.RequestMapping;
|
|
|
|
|
-import org.springframework.web.bind.annotation.RestController;
|
|
|
|
|
|
|
+import org.springframework.web.bind.annotation.*;
|
|
|
import org.springframework.web.context.request.async.DeferredResult;
|
|
import org.springframework.web.context.request.async.DeferredResult;
|
|
|
|
|
|
|
|
-import com.zd.alg.iot.vmp.gb28181.bean.Device;
|
|
|
|
|
-import com.zd.alg.iot.vmp.storager.IVideoManagerStorager;
|
|
|
|
|
-
|
|
|
|
|
@Api(tags = "国标录像")
|
|
@Api(tags = "国标录像")
|
|
|
@CrossOrigin
|
|
@CrossOrigin
|
|
|
@RestController
|
|
@RestController
|
|
@@ -47,7 +42,7 @@ public class GBRecordController {
|
|
|
@ApiImplicitParam(name = "endTime", value = "结束时间", dataTypeClass = String.class),
|
|
@ApiImplicitParam(name = "endTime", value = "结束时间", dataTypeClass = String.class),
|
|
|
})
|
|
})
|
|
|
@GetMapping("/query/{deviceId}/{channelId}")
|
|
@GetMapping("/query/{deviceId}/{channelId}")
|
|
|
- public DeferredResult<ResponseEntity<RecordInfo>> recordinfo(@PathVariable String deviceId, @PathVariable String channelId, String startTime, String endTime){
|
|
|
|
|
|
|
+ public DeferredResult<ResponseEntity<RecordInfo2>> recordinfo(@PathVariable String deviceId, @PathVariable String channelId, String startTime, String endTime){
|
|
|
|
|
|
|
|
if (logger.isDebugEnabled()) {
|
|
if (logger.isDebugEnabled()) {
|
|
|
logger.debug(String.format("录像信息查询 API调用,deviceId:%s ,startTime:%s, startTime:%s",deviceId, startTime, endTime));
|
|
logger.debug(String.format("录像信息查询 API调用,deviceId:%s ,startTime:%s, startTime:%s",deviceId, startTime, endTime));
|
|
@@ -56,7 +51,7 @@ public class GBRecordController {
|
|
|
Device device = storager.queryVideoDevice(deviceId);
|
|
Device device = storager.queryVideoDevice(deviceId);
|
|
|
cmder.recordInfoQuery(device, channelId, startTime, endTime);
|
|
cmder.recordInfoQuery(device, channelId, startTime, endTime);
|
|
|
// 指定超时时间 1分钟30秒
|
|
// 指定超时时间 1分钟30秒
|
|
|
- DeferredResult<ResponseEntity<RecordInfo>> result = new DeferredResult<ResponseEntity<RecordInfo>>(90*1000L);
|
|
|
|
|
|
|
+ DeferredResult<ResponseEntity<RecordInfo2>> result = new DeferredResult<>(90*1000L);
|
|
|
// 录像查询以channelId作为deviceId查询
|
|
// 录像查询以channelId作为deviceId查询
|
|
|
resultHolder.put(DeferredResultHolder.CALLBACK_CMD_RECORDINFO+channelId, result);
|
|
resultHolder.put(DeferredResultHolder.CALLBACK_CMD_RECORDINFO+channelId, result);
|
|
|
result.onTimeout(()->{
|
|
result.onTimeout(()->{
|