规范化api, 进行中。。。

pull/80/head
panlinlin 2021-04-07 18:35:13 +08:00
parent c7b2004e43
commit 2310087e03
14 changed files with 321 additions and 76 deletions

13
pom.xml
View File

@ -102,18 +102,15 @@
<!-- <version>3.11</version>--> <!-- <version>3.11</version>-->
<!-- </dependency>--> <!-- </dependency>-->
<!--Swagger2 --> <!--Swagger3 -->
<!--在线文档 --> <!--在线文档 -->
<dependency> <dependency>
<groupId>io.springfox</groupId> <groupId>io.springfox</groupId>
<artifactId>springfox-swagger2</artifactId> <artifactId>springfox-boot-starter</artifactId>
<version>2.9.2</version> <version>3.0.0</version>
</dependency>
<dependency>
<groupId>io.springfox</groupId>
<artifactId>springfox-swagger-ui</artifactId>
<version>2.6.1</version>
</dependency> </dependency>
<!--参数校验 -->
<dependency> <dependency>
<groupId>javax.validation</groupId> <groupId>javax.validation</groupId>
<artifactId>validation-api</artifactId> <artifactId>validation-api</artifactId>

View File

@ -5,8 +5,10 @@ import java.util.logging.LogManager;
import org.springframework.boot.SpringApplication; import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication; import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.context.ConfigurableApplicationContext; import org.springframework.context.ConfigurableApplicationContext;
import springfox.documentation.oas.annotations.EnableOpenApi;
@SpringBootApplication @SpringBootApplication
@EnableOpenApi
public class VManageBootstrap extends LogManager { public class VManageBootstrap extends LogManager {
private static String[] args; private static String[] args;
private static ConfigurableApplicationContext context; private static ConfigurableApplicationContext context;

View File

@ -0,0 +1,41 @@
package com.genersoft.iot.vmp.conf;
import io.swagger.annotations.ApiOperation;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import springfox.documentation.builders.ApiInfoBuilder;
import springfox.documentation.builders.PathSelectors;
import springfox.documentation.builders.RequestHandlerSelectors;
import springfox.documentation.builders.RequestParameterBuilder;
import springfox.documentation.schema.ScalarType;
import springfox.documentation.service.ApiInfo;
import springfox.documentation.service.Contact;
import springfox.documentation.spi.DocumentationType;
import springfox.documentation.spring.web.plugins.Docket;
import java.util.ArrayList;
import java.util.List;
@Configuration
public class Swagger3Config {
@Bean
public Docket createRestApi() {
return new Docket(DocumentationType.OAS_30)
.apiInfo(apiInfo())
.select()
.apis(RequestHandlerSelectors.basePackage("com.genersoft.iot.vmp.vmanager"))
.paths(PathSelectors.any())
.build()
.pathMapping("/");
}
private ApiInfo apiInfo() {
return new ApiInfoBuilder()
.title("WVP-PRO 接口文档")
.description("更多请咨询服务开发者(18010473990@@163.com)。")
.contact(new Contact("Ray。", "http://www.ruiyeclub.cn", "ruiyeclub@foxmail.com"))
.version("1.0")
.build();
}
}

View File

@ -341,7 +341,7 @@ public class SIPCommander implements ISIPCommander {
@Override @Override
public void playStreamCmd(Device device, String channelId, ZLMHttpHookSubscribe.Event event, SipSubscribe.Event errorEvent) { public void playStreamCmd(Device device, String channelId, ZLMHttpHookSubscribe.Event event, SipSubscribe.Event errorEvent) {
try { try {
if (device == null) return;
String ssrc = streamSession.createPlaySsrc(); String ssrc = streamSession.createPlaySsrc();
String streamId = null; String streamId = null;
if (rtpEnable) { if (rtpEnable) {

View File

@ -17,16 +17,22 @@ import com.genersoft.iot.vmp.gb28181.transmit.cmd.impl.SIPCommander;
import com.genersoft.iot.vmp.gb28181.utils.XmlUtil; import com.genersoft.iot.vmp.gb28181.utils.XmlUtil;
import com.genersoft.iot.vmp.storager.IVideoManagerStorager; import com.genersoft.iot.vmp.storager.IVideoManagerStorager;
import io.swagger.annotations.Api;
import io.swagger.annotations.ApiImplicitParam;
import io.swagger.annotations.ApiImplicitParams;
import io.swagger.annotations.ApiOperation;
import org.slf4j.Logger; 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.HttpRequest;
import org.springframework.http.ResponseEntity; import org.springframework.http.ResponseEntity;
import org.springframework.web.bind.annotation.*; import org.springframework.web.bind.annotation.*;
import org.springframework.web.context.request.async.DeferredResult; import org.springframework.web.context.request.async.DeferredResult;
@Api(tags = "国标设备配置")
@CrossOrigin @CrossOrigin
@RestController @RestController
@RequestMapping("/api") @RequestMapping("/api/device/config")
public class DeviceConfig { public class DeviceConfig {
private final static Logger logger = LoggerFactory.getLogger(DeviceQuery.class); private final static Logger logger = LoggerFactory.getLogger(DeviceQuery.class);
@ -42,14 +48,24 @@ public class DeviceConfig {
/** /**
* API * API
* * @param deviceId ID
* @param deviceId * @param channelId ID
* @param enabled 使1:,0: * @param name
* @param resetTime * @param expiration
* @param presetIndex * @param heartBeatInterval
* @param channelId * @param heartBeatCount
* @return
*/ */
@GetMapping("/config/{deviceId}/basicParam") @ApiOperation("看守位控制命令")
@GetMapping("/basicParam/{deviceId}")
@ApiImplicitParams({
@ApiImplicitParam(name = "deviceId", value ="设备ID" ),
@ApiImplicitParam(name = "channelId", value ="通道ID" ),
@ApiImplicitParam(name = "name", value ="名称" ),
@ApiImplicitParam(name = "expiration", value ="到期时间" ),
@ApiImplicitParam(name = "heartBeatInterval", value ="心跳间隔" ),
@ApiImplicitParam(name = "heartBeatCount", value ="心跳计数" ),
})
public DeferredResult<ResponseEntity<String>> homePositionApi(@PathVariable String deviceId, public DeferredResult<ResponseEntity<String>> homePositionApi(@PathVariable String deviceId,
@RequestParam(required = false) String channelId, @RequestParam(required = false) String channelId,
@RequestParam(required = false) String name, @RequestParam(required = false) String name,
@ -86,10 +102,18 @@ public class DeviceConfig {
/** /**
* API * API
* * @param deviceId ID
* @param deviceId * @param configType
* @param channelId ID
* @return
*/ */
@GetMapping("/config/{deviceId}/query/{configType}") @ApiOperation("设备配置查询请求")
@ApiImplicitParams({
@ApiImplicitParam(name = "deviceId", value ="设备ID" ),
@ApiImplicitParam(name = "channelId", value ="通道ID" ),
@ApiImplicitParam(name = "configType", value ="配置类型" ),
})
@GetMapping("/query/{deviceId}/{configType}")
public DeferredResult<ResponseEntity<String>> configDownloadApi(@PathVariable String deviceId, public DeferredResult<ResponseEntity<String>> configDownloadApi(@PathVariable String deviceId,
@PathVariable String configType, @PathVariable String configType,
@RequestParam(required = false) String channelId) { @RequestParam(required = false) String channelId) {

View File

@ -17,6 +17,10 @@ import com.genersoft.iot.vmp.gb28181.transmit.cmd.impl.SIPCommander;
import com.genersoft.iot.vmp.gb28181.utils.XmlUtil; import com.genersoft.iot.vmp.gb28181.utils.XmlUtil;
import com.genersoft.iot.vmp.storager.IVideoManagerStorager; import com.genersoft.iot.vmp.storager.IVideoManagerStorager;
import io.swagger.annotations.Api;
import io.swagger.annotations.ApiImplicitParam;
import io.swagger.annotations.ApiImplicitParams;
import io.swagger.annotations.ApiOperation;
import org.slf4j.Logger; 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;
@ -25,9 +29,10 @@ import org.springframework.http.ResponseEntity;
import org.springframework.web.bind.annotation.*; import org.springframework.web.bind.annotation.*;
import org.springframework.web.context.request.async.DeferredResult; import org.springframework.web.context.request.async.DeferredResult;
@Api(tags = "国标设备控制")
@CrossOrigin @CrossOrigin
@RestController @RestController
@RequestMapping("/api") @RequestMapping("/api/device/control")
public class DeviceControl { public class DeviceControl {
private final static Logger logger = LoggerFactory.getLogger(DeviceQuery.class); private final static Logger logger = LoggerFactory.getLogger(DeviceQuery.class);
@ -44,10 +49,13 @@ public class DeviceControl {
/** /**
* API * API
* *
* @param deviceId * @param deviceId ID
*/ */
@GetMapping("/control/{deviceId}/teleboot") @ApiOperation("远程启动控制命令")
@PostMapping("/control/{deviceId}/teleboot") @ApiImplicitParams({
@ApiImplicitParam(name = "deviceId", value ="设备ID", required = true),
})
@GetMapping("/teleboot/{deviceId}")
public ResponseEntity<String> teleBootApi(@PathVariable String deviceId) { public ResponseEntity<String> teleBootApi(@PathVariable String deviceId) {
if (logger.isDebugEnabled()) { if (logger.isDebugEnabled()) {
logger.debug("设备远程启动API调用"); logger.debug("设备远程启动API调用");
@ -68,11 +76,18 @@ public class DeviceControl {
/** /**
* API * API
* *
* @param deviceId * @param deviceId ID
* @param recordCmdStr RecordStopRecord * @param recordCmdStr RecordStopRecord
* @param channelId * @param channelId
*/ */
@GetMapping("/control/{deviceId}/record/{recordCmdStr}") @ApiOperation("录像控制命令")
@ApiImplicitParams({
@ApiImplicitParam(name = "deviceId", value ="设备ID", required = true),
@ApiImplicitParam(name = "channelId", value ="通道编码"),
@ApiImplicitParam(name = "recordCmdStr", value ="命令, 可选值Record手动录像StopRecord停止手动录像",
required = true),
})
@GetMapping("/record/{deviceId}/{recordCmdStr}")
public DeferredResult<ResponseEntity<String>> recordApi(@PathVariable String deviceId, public DeferredResult<ResponseEntity<String>> recordApi(@PathVariable String deviceId,
@PathVariable String recordCmdStr, @RequestParam(required = false) String channelId) { @PathVariable String recordCmdStr, @RequestParam(required = false) String channelId) {
if (logger.isDebugEnabled()) { if (logger.isDebugEnabled()) {
@ -102,10 +117,15 @@ public class DeviceControl {
/** /**
* /API * /API
* *
* @param deviceId * @param deviceId ID
* @param guardCmdStr SetGuardResetGuard * @param guardCmdStr SetGuardResetGuard
*/ */
@GetMapping("/control/{deviceId}/guard/{guardCmdStr}") @ApiOperation("录像控制命令")
@ApiImplicitParams({
@ApiImplicitParam(name = "deviceId", value = "设备ID", required = true),
@ApiImplicitParam(name = "guardCmdStr", value ="命令, 可选值SetGuard布防ResetGuard撤防", required = true)
})
@GetMapping("/guard/{deviceId}/{guardCmdStr}")
public DeferredResult<ResponseEntity<String>> guardApi(@PathVariable String deviceId, @PathVariable String guardCmdStr) { public DeferredResult<ResponseEntity<String>> guardApi(@PathVariable String deviceId, @PathVariable String guardCmdStr) {
if (logger.isDebugEnabled()) { if (logger.isDebugEnabled()) {
logger.debug("布防/撤防API调用"); logger.debug("布防/撤防API调用");
@ -134,11 +154,17 @@ public class DeviceControl {
/** /**
* API * API
* *
* @param deviceId * @param deviceId ID
* @param alarmMethod * @param alarmMethod
* @param alarmType * @param alarmType
*/ */
@GetMapping("/control/{deviceId}/resetAlarm") @ApiOperation("报警复位")
@ApiImplicitParams({
@ApiImplicitParam(name = "deviceId", value = "设备ID", required = true),
@ApiImplicitParam(name = "alarmMethod", value ="报警方式"),
@ApiImplicitParam(name = "alarmType", value ="报警类型"),
})
@GetMapping("/reset_alarm/{deviceId}")
public DeferredResult<ResponseEntity<String>> resetAlarmApi(@PathVariable String deviceId, public DeferredResult<ResponseEntity<String>> resetAlarmApi(@PathVariable String deviceId,
@RequestParam(required = false) String alarmMethod, @RequestParam(required = false) String alarmMethod,
@RequestParam(required = false) String alarmType) { @RequestParam(required = false) String alarmType) {
@ -169,11 +195,15 @@ public class DeviceControl {
/** /**
* API * API
* *
* @param deviceId * @param deviceId ID
* @param channelId * @param channelId ID
*/ */
@GetMapping("/control/{deviceId}/iFrame") @ApiOperation("强制关键帧")
@PostMapping("/control/{deviceId}/iFrame") @ApiImplicitParams({
@ApiImplicitParam(name = "deviceId", value = "设备ID", required = true),
@ApiImplicitParam(name = "channelId", value ="通道ID", required = true),
})
@GetMapping("/i_frame/{deviceId}")
public ResponseEntity<String> iFrame(@PathVariable String deviceId, public ResponseEntity<String> iFrame(@PathVariable String deviceId,
@RequestParam(required = false) String channelId) { @RequestParam(required = false) String channelId) {
if (logger.isDebugEnabled()) { if (logger.isDebugEnabled()) {
@ -196,13 +226,21 @@ public class DeviceControl {
/** /**
* API * API
* *
* @param deviceId * @param deviceId ID
* @param enabled 使1:,0: * @param enabled 使1:,0:
* @param resetTime * @param resetTime
* @param presetIndex * @param presetIndex
* @param channelId * @param channelId
*/ */
@GetMapping("/control/{deviceId}/homePosition/{enabled}") @ApiOperation("看守位控制")
@ApiImplicitParams({
@ApiImplicitParam(name = "deviceId", value = "设备ID", required = true),
@ApiImplicitParam(name = "enabled", value = "是否开启看守位 1:开启,0:关闭", required = true),
@ApiImplicitParam(name = "resetTime", value = "自动归位时间间隔"),
@ApiImplicitParam(name = "presetIndex", value = "调用预置位编号"),
@ApiImplicitParam(name = "channelId", value ="通道ID"),
})
@GetMapping("/home_position/{deviceId}/{enabled}")
public DeferredResult<ResponseEntity<String>> homePositionApi(@PathVariable String deviceId, public DeferredResult<ResponseEntity<String>> homePositionApi(@PathVariable String deviceId,
@PathVariable String enabled, @PathVariable String enabled,
@RequestParam(required = false) String resetTime, @RequestParam(required = false) String resetTime,

View File

@ -3,6 +3,7 @@ package com.genersoft.iot.vmp.vmanager.device;
import com.genersoft.iot.vmp.gb28181.bean.DeviceChannel; import com.genersoft.iot.vmp.gb28181.bean.DeviceChannel;
import com.genersoft.iot.vmp.gb28181.transmit.callback.RequestMessage; import com.genersoft.iot.vmp.gb28181.transmit.callback.RequestMessage;
import com.github.pagehelper.PageInfo; import com.github.pagehelper.PageInfo;
import io.swagger.annotations.*;
import org.slf4j.Logger; 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;
@ -21,10 +22,11 @@ import com.genersoft.iot.vmp.storager.IVideoManagerStorager;
import javax.sip.message.Response; import javax.sip.message.Response;
@Api(tags = "国标设备查询1", value = "国标设备查询")
@SuppressWarnings("rawtypes") @SuppressWarnings("rawtypes")
@CrossOrigin @CrossOrigin
@RestController @RestController
@RequestMapping("/api") @RequestMapping("/api/device/query")
public class DeviceQuery { public class DeviceQuery {
private final static Logger logger = LoggerFactory.getLogger(DeviceQuery.class); private final static Logger logger = LoggerFactory.getLogger(DeviceQuery.class);
@ -40,7 +42,16 @@ public class DeviceQuery {
@Autowired @Autowired
private DeviceOffLineDetector offLineDetector; private DeviceOffLineDetector offLineDetector;
/**
* 使ID
* @param deviceId ID
* @return
*/
@ApiOperation("使用ID查询国标设备")
@ApiImplicitParams({
@ApiImplicitParam(name = "deviceId", value = "设备ID", required = true),
})
@GetMapping("/devices/{deviceId}") @GetMapping("/devices/{deviceId}")
public ResponseEntity<Device> devices(@PathVariable String deviceId){ public ResponseEntity<Device> devices(@PathVariable String deviceId){
@ -51,7 +62,18 @@ public class DeviceQuery {
Device device = storager.queryVideoDevice(deviceId); Device device = storager.queryVideoDevice(deviceId);
return new ResponseEntity<>(device,HttpStatus.OK); return new ResponseEntity<>(device,HttpStatus.OK);
} }
/**
*
* @param page
* @param count
* @return
*/
@ApiOperation("分页查询国标设备")
@ApiImplicitParams({
@ApiImplicitParam(name = "page", value = "当前页", required = true),
@ApiImplicitParam(name = "count", value = "每页查询数量", required = true),
})
@GetMapping("/devices") @GetMapping("/devices")
public PageInfo<Device> devices(int page, int count){ public PageInfo<Device> devices(int page, int count){
@ -73,7 +95,16 @@ public class DeviceQuery {
* @param channelType false/ true * @param channelType false/ true
* @return * @return
*/ */
@ApiOperation("分页查询通道")
@GetMapping("/devices/{deviceId}/channels") @GetMapping("/devices/{deviceId}/channels")
@ApiImplicitParams({
@ApiImplicitParam(name="deviceId", value = "设备id", required = true),
@ApiImplicitParam(name="page", value = "当前页", required = true),
@ApiImplicitParam(name="count", value = "每页查询数量", required = true),
@ApiImplicitParam(name="query", value = "查询内容"),
@ApiImplicitParam(name="online", value = "是否在线"),
@ApiImplicitParam(name="channelType", value = "设备/子目录-> false/true"),
})
public ResponseEntity<PageInfo> channels(@PathVariable String deviceId, public ResponseEntity<PageInfo> channels(@PathVariable String deviceId,
int page, int count, int page, int count,
@RequestParam(required = false) String query, @RequestParam(required = false) String query,
@ -89,7 +120,16 @@ public class DeviceQuery {
PageInfo pageResult = storager.queryChannelsByDeviceId(deviceId, query, channelType, online, page, count); PageInfo pageResult = storager.queryChannelsByDeviceId(deviceId, query, channelType, online, page, count);
return new ResponseEntity<>(pageResult,HttpStatus.OK); return new ResponseEntity<>(pageResult,HttpStatus.OK);
} }
/**
*
* @param deviceId id
* @return
*/
@ApiOperation("同步设备通道")
@ApiImplicitParams({
@ApiImplicitParam(name="deviceId", value = "设备id", required = true),
})
@PostMapping("/devices/{deviceId}/sync") @PostMapping("/devices/{deviceId}/sync")
public DeferredResult<ResponseEntity<Device>> devicesSync(@PathVariable String deviceId){ public DeferredResult<ResponseEntity<Device>> devicesSync(@PathVariable String deviceId){
@ -117,8 +157,17 @@ public class DeviceQuery {
resultHolder.put(DeferredResultHolder.CALLBACK_CMD_CATALOG+deviceId, result); resultHolder.put(DeferredResultHolder.CALLBACK_CMD_CATALOG+deviceId, result);
return result; return result;
} }
@PostMapping("/devices/{deviceId}/delete") /**
*
* @param deviceId id
* @return
*/
@ApiOperation("移除设备")
@ApiImplicitParams({
@ApiImplicitParam(name="deviceId", value = "设备id", required = true),
})
@DeleteMapping("/devices/{deviceId}/delete")
public ResponseEntity<String> delete(@PathVariable String deviceId){ public ResponseEntity<String> delete(@PathVariable String deviceId){
if (logger.isDebugEnabled()) { if (logger.isDebugEnabled()) {
@ -140,13 +189,27 @@ public class DeviceQuery {
} }
/** /**
* *
* @param deviceId id
* @param channelId id * @param channelId id
* @param page * @param page
* @param count * @param count
* @param query
* @param online 线
* @param channelType
* @return * @return
*/ */
@GetMapping("/subChannels/{deviceId}/{channelId}/channels") @ApiOperation("分页查询子目录通道")
@ApiImplicitParams({
@ApiImplicitParam(name="deviceId", value = "设备id", required = true),
@ApiImplicitParam(name="channelId", value = "通道id", required = true),
@ApiImplicitParam(name="page", value = "当前页", required = true),
@ApiImplicitParam(name="count", value = "每页条数", required = true),
@ApiImplicitParam(name="query", value = "查询内容"),
@ApiImplicitParam(name="online", value = "是否在线"),
@ApiImplicitParam(name="channelType", value = "通道类型, 子目录"),
})
@GetMapping("/sub_channels/{deviceId}/{channelId}/channels")
public ResponseEntity<PageInfo> subChannels(@PathVariable String deviceId, public ResponseEntity<PageInfo> subChannels(@PathVariable String deviceId,
@PathVariable String channelId, @PathVariable String channelId,
int page, int page,
@ -168,14 +231,36 @@ public class DeviceQuery {
return new ResponseEntity<>(pageResult,HttpStatus.OK); return new ResponseEntity<>(pageResult,HttpStatus.OK);
} }
/**
*
* @param deviceId id
* @param channel
* @return
*/
@ApiOperation("更新通道信息")
@ApiImplicitParams({
@ApiImplicitParam(name="deviceId", value = "设备id", required = true),
@ApiImplicitParam(name="channel", value = "通道", required = true),
})
@PostMapping("/channel/update/{deviceId}") @PostMapping("/channel/update/{deviceId}")
public ResponseEntity<PageInfo> updateChannel(@PathVariable String deviceId,DeviceChannel channel){ public ResponseEntity<PageInfo> updateChannel(@PathVariable String deviceId,DeviceChannel channel){
storager.updateChannel(deviceId, channel); storager.updateChannel(deviceId, channel);
return new ResponseEntity<>(null,HttpStatus.OK); return new ResponseEntity<>(null,HttpStatus.OK);
} }
@GetMapping("/devices/{deviceId}/transport/{streamMode}") /**
@PostMapping("/devices/{deviceId}/transport/{streamMode}") *
* @param deviceId id
* @param streamMode
* @return
*/
@ApiOperation("修改数据流传输模式")
@ApiImplicitParams({
@ApiImplicitParam(name = "deviceId", value = "设备id", required = true),
@ApiImplicitParam(name = "streamMode", value = "数据流传输模式, 取值:" +
"UDPudp传输TCP-ACTIVEtcp主动模式,暂不支持TCP-PASSIVEtcp被动模式"),
})
@PostMapping("/transport/{deviceId}/{streamMode}")
public ResponseEntity<PageInfo> updateTransport(@PathVariable String deviceId, @PathVariable String streamMode){ public ResponseEntity<PageInfo> updateTransport(@PathVariable String deviceId, @PathVariable String streamMode){
Device device = storager.queryVideoDevice(deviceId); Device device = storager.queryVideoDevice(deviceId);
device.setStreamMode(streamMode); device.setStreamMode(streamMode);
@ -186,8 +271,12 @@ public class DeviceQuery {
/** /**
* API * API
* *
* @param deviceId * @param deviceId id
*/ */
@ApiOperation("设备状态查询")
@ApiImplicitParams({
@ApiImplicitParam(name = "deviceId", value = "设备id", required = true),
})
@GetMapping("/devices/{deviceId}/status") @GetMapping("/devices/{deviceId}/status")
public DeferredResult<ResponseEntity<String>> deviceStatusApi(@PathVariable String deviceId) { public DeferredResult<ResponseEntity<String>> deviceStatusApi(@PathVariable String deviceId) {
if (logger.isDebugEnabled()) { if (logger.isDebugEnabled()) {
@ -216,9 +305,25 @@ public class DeviceQuery {
/** /**
* API * API
* * @param deviceId id
* @param deviceId * @param startPriority
* @param endPriority
* @param alarmMethod
* @param alarmType
* @param startTime
* @param endTime
* @return true =
*/ */
@ApiOperation("设备报警查询")
@ApiImplicitParams({
@ApiImplicitParam(name = "deviceId", value = "设备id", required = true),
@ApiImplicitParam(name = "startPriority", value = "报警起始级别"),
@ApiImplicitParam(name = "endPriority", value = "报警终止级别"),
@ApiImplicitParam(name = "alarmMethod", value = "报警方式条件"),
@ApiImplicitParam(name = "alarmType", value = "报警类型"),
@ApiImplicitParam(name = "startTime", value = "报警发生起始时间"),
@ApiImplicitParam(name = "endTime", value = "报警发生终止时间"),
})
@GetMapping("/alarm/{deviceId}") @GetMapping("/alarm/{deviceId}")
public DeferredResult<ResponseEntity<String>> alarmApi(@PathVariable String deviceId, public DeferredResult<ResponseEntity<String>> alarmApi(@PathVariable String deviceId,
@RequestParam(required = false) String startPriority, @RequestParam(required = false) String startPriority,

View File

@ -5,11 +5,16 @@ import com.genersoft.iot.vmp.storager.IVideoManagerStorager;
import com.genersoft.iot.vmp.vmanager.gbStream.bean.GbStreamParam; import com.genersoft.iot.vmp.vmanager.gbStream.bean.GbStreamParam;
import com.genersoft.iot.vmp.service.IGbStreamService; import com.genersoft.iot.vmp.service.IGbStreamService;
import com.github.pagehelper.PageInfo; import com.github.pagehelper.PageInfo;
import io.swagger.annotations.Api;
import io.swagger.annotations.ApiImplicitParam;
import io.swagger.annotations.ApiImplicitParams;
import io.swagger.annotations.ApiOperation;
import org.slf4j.Logger; 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.web.bind.annotation.*; import org.springframework.web.bind.annotation.*;
@Api(tags = "视频流关联到级联平台")
@CrossOrigin @CrossOrigin
@RestController @RestController
@RequestMapping("/api/gbStream") @RequestMapping("/api/gbStream")
@ -24,7 +29,18 @@ public class GbStreamController {
private IVideoManagerStorager storager; private IVideoManagerStorager storager;
@RequestMapping(value = "/list") /**
*
* @param page
* @param count
* @return
*/
@ApiOperation("查询国标通道")
@ApiImplicitParams({
@ApiImplicitParam(name = "page", value = "当前页", required = true ),
@ApiImplicitParam(name = "count", value = "每页条数", required = true ),
})
@GetMapping(value = "/list")
@ResponseBody @ResponseBody
public PageInfo<GbStream> list(@RequestParam(required = false)Integer page, public PageInfo<GbStream> list(@RequestParam(required = false)Integer page,
@RequestParam(required = false)Integer count){ @RequestParam(required = false)Integer count){
@ -33,11 +49,18 @@ public class GbStreamController {
} }
@RequestMapping(value = "/del") /**
*
* @param gbStreamParam
* @return
*/
@ApiOperation("移除国标关联")
@ApiImplicitParams({
@ApiImplicitParam(name = "gbStreamParam", value = "GbStreamParam", required = true ),
})
@DeleteMapping(value = "/del")
@ResponseBody @ResponseBody
public Object del(@RequestBody GbStreamParam gbStreamParam){ public Object del(@RequestBody GbStreamParam gbStreamParam){
System.out.println(2222);
System.out.println(gbStreamParam.getGbStreams().size());
if (gbStreamService.delPlatformInfo(gbStreamParam.getGbStreams())) { if (gbStreamService.delPlatformInfo(gbStreamParam.getGbStreams())) {
return "success"; return "success";
}else { }else {
@ -46,7 +69,17 @@ public class GbStreamController {
} }
@RequestMapping(value = "/add") /**
*
* @param gbStreamParam
* @return
*/
@ApiOperation("保存国标关联")
// @ApiImplicitParams({
// @ApiImplicitParam(name = "app", value = "视频流应用名", required = true ),
// @ApiImplicitParam(name = "gbId", value = "国标ID", required = true ),
// })
@PostMapping(value = "/add")
@ResponseBody @ResponseBody
public Object add(@RequestBody GbStreamParam gbStreamParam){ public Object add(@RequestBody GbStreamParam gbStreamParam){
System.out.println(3333); System.out.println(3333);

View File

@ -33,7 +33,7 @@ import javax.sip.message.Response;
@CrossOrigin @CrossOrigin
@RestController @RestController
@RequestMapping("/api") @RequestMapping("/api/play")
public class PlayController { public class PlayController {
private final static Logger logger = LoggerFactory.getLogger(PlayController.class); private final static Logger logger = LoggerFactory.getLogger(PlayController.class);
@ -59,7 +59,7 @@ public class PlayController {
@Autowired @Autowired
private IMediaService mediaService; private IMediaService mediaService;
@GetMapping("/play/{deviceId}/{channelId}") @GetMapping("/start/{deviceId}/{channelId}")
public DeferredResult<ResponseEntity<String>> play(@PathVariable String deviceId, public DeferredResult<ResponseEntity<String>> play(@PathVariable String deviceId,
@PathVariable String channelId) { @PathVariable String channelId) {
@ -79,7 +79,7 @@ public class PlayController {
return playResult.getResult(); return playResult.getResult();
} }
@PostMapping("/play/{streamId}/stop") @PostMapping("/stop/{streamId}")
public DeferredResult<ResponseEntity<String>> playStop(@PathVariable String streamId) { public DeferredResult<ResponseEntity<String>> playStop(@PathVariable String streamId) {
logger.debug(String.format("设备预览/回放停止API调用streamId%s", streamId)); logger.debug(String.format("设备预览/回放停止API调用streamId%s", streamId));
@ -139,7 +139,7 @@ public class PlayController {
* @param streamId ID * @param streamId ID
* @return * @return
*/ */
@PostMapping("/play/{streamId}/convert") @PostMapping("/convert/{streamId}")
public ResponseEntity<String> playConvert(@PathVariable String streamId) { public ResponseEntity<String> playConvert(@PathVariable String streamId) {
StreamInfo streamInfo = redisCatchStorage.queryPlayByStreamId(streamId); StreamInfo streamInfo = redisCatchStorage.queryPlayByStreamId(streamId);
if (streamInfo == null) { if (streamInfo == null) {
@ -179,7 +179,7 @@ public class PlayController {
* @param key * @param key
* @return * @return
*/ */
@PostMapping("/play/convert/stop/{key}") @PostMapping("/convertStop/{key}")
public ResponseEntity<String> playConvertStop(@PathVariable String key) { public ResponseEntity<String> playConvertStop(@PathVariable String key) {
JSONObject jsonObject = zlmresTfulUtils.delFFmpegSource(key); JSONObject jsonObject = zlmresTfulUtils.delFFmpegSource(key);

View File

@ -28,7 +28,7 @@ import java.util.UUID;
@CrossOrigin @CrossOrigin
@RestController @RestController
@RequestMapping("/api") @RequestMapping("/api/playback")
public class PlaybackController { public class PlaybackController {
private final static Logger logger = LoggerFactory.getLogger(PlaybackController.class); private final static Logger logger = LoggerFactory.getLogger(PlaybackController.class);
@ -51,7 +51,7 @@ public class PlaybackController {
@Autowired @Autowired
private DeferredResultHolder resultHolder; private DeferredResultHolder resultHolder;
@GetMapping("/playback/{deviceId}/{channelId}") @GetMapping("/start/{deviceId}/{channelId}")
public DeferredResult<ResponseEntity<String>> play(@PathVariable String deviceId, @PathVariable String channelId, String startTime, public DeferredResult<ResponseEntity<String>> play(@PathVariable String deviceId, @PathVariable String channelId, String startTime,
String endTime) { String endTime) {
@ -89,7 +89,7 @@ public class PlaybackController {
return result; return result;
} }
@RequestMapping("/playback/{ssrc}/stop") @RequestMapping("/stop/{ssrc}")
public ResponseEntity<String> playStop(@PathVariable String ssrc) { public ResponseEntity<String> playStop(@PathVariable String ssrc) {
cmder.streamByeCmd(ssrc); cmder.streamByeCmd(ssrc);

View File

@ -96,4 +96,10 @@ logging:
# [根据业务需求配置] # [根据业务需求配置]
userSettings: userSettings:
# 保存移动位置历史轨迹true:保留历史数据false:仅保留最后的位置(默认) # 保存移动位置历史轨迹true:保留历史数据false:仅保留最后的位置(默认)
savePositionHistory: false savePositionHistory: false
# 在线文档: swagger-ui生产环境建议关闭
springfox:
documentation:
swagger-ui:
enabled: true

View File

@ -136,7 +136,7 @@
getDeviceList: function() { getDeviceList: function() {
let that = this; let that = this;
this.getDeviceListLoading = true; this.getDeviceListLoading = true;
this.$axios.get(`/api/devices`,{ this.$axios.get(`/api/device/query/devices`,{
params: { params: {
page: that.currentPage, page: that.currentPage,
count: that.count count: that.count
@ -167,13 +167,12 @@
//gb28181 //gb28181
// //
refDevice: function(itemData) { refDevice: function(itemData) {
///api/devices/{deviceId}/sync
console.log("刷新对应设备:" + itemData.deviceId); console.log("刷新对应设备:" + itemData.deviceId);
var that = this; var that = this;
that.$refs[itemData.deviceId + 'refbtn' ].loading = true; that.$refs[itemData.deviceId + 'refbtn' ].loading = true;
this.$axios({ this.$axios({
method: 'post', method: 'post',
url: '/api/devices/' + itemData.deviceId + '/sync' url: '/api/device/query/devices/' + itemData.deviceId + '/sync'
}).then(function(res) { }).then(function(res) {
console.log("刷新设备结果:"+JSON.stringify(res)); console.log("刷新设备结果:"+JSON.stringify(res));
if (!res.data.deviceId) { if (!res.data.deviceId) {
@ -217,7 +216,7 @@
let that = this; let that = this;
this.$axios({ this.$axios({
method: 'get', method: 'get',
url: '/api/devices/' + row.deviceId + '/transport/' + row.streamMode url: '/api/device/query/transport' + row.deviceId + '/' + row.streamMode
}).then(function(res) { }).then(function(res) {
}).catch(function(e) { }).catch(function(e) {

View File

@ -154,7 +154,7 @@ export default {
getDeviceChannelList: function () { getDeviceChannelList: function () {
let that = this; let that = this;
this.$axios.get(`/api/devices/${this.$route.params.deviceId}/channels`, { this.$axios.get(`/api/device/query/devices/${this.$route.params.deviceId}/channels`, {
params: { params: {
page: that.currentPage, page: that.currentPage,
count: that.count, count: that.count,
@ -188,7 +188,7 @@ export default {
let that = this; let that = this;
this.$axios({ this.$axios({
method: 'get', method: 'get',
url: '/api/play/' + deviceId + '/' + channelId url: '/api/play/start/' + deviceId + '/' + channelId
}).then(function (res) { }).then(function (res) {
console.log(res.data) console.log(res.data)
let streamId = res.data.streamId; let streamId = res.data.streamId;
@ -216,7 +216,7 @@ export default {
var that = this; var that = this;
this.$axios({ this.$axios({
method: 'post', method: 'post',
url: '/api/play/' + itemData.streamId + '/stop' url: '/api/play/stop/' + itemData.streamId
}).then(function (res) { }).then(function (res) {
console.log(JSON.stringify(res)); console.log(JSON.stringify(res));
that.initData(); that.initData();
@ -251,7 +251,7 @@ export default {
showSubchannels: function (channelId) { showSubchannels: function (channelId) {
let that = this; let that = this;
this.$axios.get(`/api/subChannels/${this.deviceId}/${this.parentChannelId}/channels`, { this.$axios.get(`/api/device/query/sub_channels/${this.deviceId}/${this.parentChannelId}/channels`, {
params: { params: {
page: that.currentPage, page: that.currentPage,
count: that.count, count: that.count,
@ -282,7 +282,7 @@ export default {
console.log(row) console.log(row)
this.$axios({ this.$axios({
method: 'post', method: 'post',
url: `/api/channel/update/${this.deviceId}`, url: `/api/device/query/channel/update/${this.deviceId}`,
params: row params: row
}).then(function (res) { }).then(function (res) {
console.log(JSON.stringify(res)); console.log(JSON.stringify(res));

View File

@ -261,7 +261,7 @@ export default {
this.$refs.videoPlayer.pause() this.$refs.videoPlayer.pause()
that.$axios({ that.$axios({
method: 'post', method: 'post',
url: '/api/play/' + that.streamId + '/convert' url: '/api/play/convert/' + that.streamId
}).then(function (res) { }).then(function (res) {
if (res.data.code == 0) { if (res.data.code == 0) {
that.convertKey = res.data.key; that.convertKey = res.data.key;
@ -298,7 +298,7 @@ export default {
that.$refs.videoPlayer.pause() that.$refs.videoPlayer.pause()
this.$axios({ this.$axios({
method: 'post', method: 'post',
url: '/api/play/convert/stop/' + this.convertKey url: '/api/play/convertStop/' + this.convertKey
}).then(function (res) { }).then(function (res) {
if (res.data.code == 0) { if (res.data.code == 0) {
console.log(res.data.msg) console.log(res.data.msg)
@ -393,7 +393,7 @@ export default {
} else { } else {
this.$axios({ this.$axios({
method: 'get', method: 'get',
url: '/api/playback/' + this.deviceId + '/' + this.channelId + '?startTime=' + row.startTime + '&endTime=' + url: '/api/playback/start/' + this.deviceId + '/' + this.channelId + '?startTime=' + row.startTime + '&endTime=' +
row.endTime row.endTime
}).then(function (res) { }).then(function (res) {
var streamInfo = res.data; var streamInfo = res.data;
@ -408,7 +408,7 @@ export default {
this.videoUrl = ''; this.videoUrl = '';
this.$axios({ this.$axios({
method: 'get', method: 'get',
url: '/api/playback/' + this.streamId + '/stop' url: '/api/playback/stop/' + this.streamId
}).then(function (res) { }).then(function (res) {
if (callback) callback() if (callback) callback()
}); });