Commit cefdce5e0a34743e6d9784f858265120e75179a1
1 parent
c5ff8113
优化兼容接口
Showing
5 changed files
with
126 additions
and
102 deletions
src/main/java/com/genersoft/iot/vmp/storager/IVideoManagerStorage.java
| @@ -5,6 +5,7 @@ import com.genersoft.iot.vmp.media.zlm.dto.StreamProxyItem; | @@ -5,6 +5,7 @@ import com.genersoft.iot.vmp.media.zlm.dto.StreamProxyItem; | ||
| 5 | import com.genersoft.iot.vmp.service.bean.GPSMsgInfo; | 5 | import com.genersoft.iot.vmp.service.bean.GPSMsgInfo; |
| 6 | import com.genersoft.iot.vmp.storager.dao.dto.ChannelSourceInfo; | 6 | import com.genersoft.iot.vmp.storager.dao.dto.ChannelSourceInfo; |
| 7 | import com.genersoft.iot.vmp.vmanager.gb28181.platform.bean.ChannelReduce; | 7 | import com.genersoft.iot.vmp.vmanager.gb28181.platform.bean.ChannelReduce; |
| 8 | +import com.genersoft.iot.vmp.web.gb28181.dto.DeviceChannelExtend; | ||
| 8 | import com.github.pagehelper.PageInfo; | 9 | import com.github.pagehelper.PageInfo; |
| 9 | 10 | ||
| 10 | import java.util.List; | 11 | import java.util.List; |
| @@ -58,7 +59,7 @@ public interface IVideoManagerStorage { | @@ -58,7 +59,7 @@ public interface IVideoManagerStorage { | ||
| 58 | */ | 59 | */ |
| 59 | public PageInfo<DeviceChannel> queryChannelsByDeviceId(String deviceId, String query, Boolean hasSubChannel, Boolean online, Boolean catalogUnderDevice, int page, int count); | 60 | public PageInfo<DeviceChannel> queryChannelsByDeviceId(String deviceId, String query, Boolean hasSubChannel, Boolean online, Boolean catalogUnderDevice, int page, int count); |
| 60 | 61 | ||
| 61 | - public List<DeviceChannel> queryChannelsByDeviceIdWithStartAndLimit(String deviceId, String query, Boolean hasSubChannel, Boolean online, int start, int limit,List<String> channelIds); | 62 | + public List<DeviceChannelExtend> queryChannelsByDeviceIdWithStartAndLimit(String deviceId, List<String> channelIds, String query, Boolean hasSubChannel, Boolean online, int start, int limit); |
| 62 | 63 | ||
| 63 | 64 | ||
| 64 | /** | 65 | /** |
| @@ -374,4 +375,7 @@ public interface IVideoManagerStorage { | @@ -374,4 +375,7 @@ public interface IVideoManagerStorage { | ||
| 374 | void cleanContentForPlatform(String serverGBId); | 375 | void cleanContentForPlatform(String serverGBId); |
| 375 | 376 | ||
| 376 | List<DeviceChannel> queryChannelWithCatalog(String serverGBId); | 377 | List<DeviceChannel> queryChannelWithCatalog(String serverGBId); |
| 378 | + | ||
| 379 | + List<DeviceChannelExtend> queryChannelsByDeviceId(String serial, List<String> channelIds, Boolean online); | ||
| 380 | + | ||
| 377 | } | 381 | } |
src/main/java/com/genersoft/iot/vmp/storager/dao/DeviceChannelMapper.java
| @@ -5,6 +5,7 @@ import com.genersoft.iot.vmp.gb28181.bean.DeviceChannel; | @@ -5,6 +5,7 @@ import com.genersoft.iot.vmp.gb28181.bean.DeviceChannel; | ||
| 5 | import com.genersoft.iot.vmp.gb28181.bean.DeviceChannelInPlatform; | 5 | import com.genersoft.iot.vmp.gb28181.bean.DeviceChannelInPlatform; |
| 6 | import com.genersoft.iot.vmp.vmanager.bean.ResourceBaceInfo; | 6 | import com.genersoft.iot.vmp.vmanager.bean.ResourceBaceInfo; |
| 7 | import com.genersoft.iot.vmp.vmanager.gb28181.platform.bean.ChannelReduce; | 7 | import com.genersoft.iot.vmp.vmanager.gb28181.platform.bean.ChannelReduce; |
| 8 | +import com.genersoft.iot.vmp.web.gb28181.dto.DeviceChannelExtend; | ||
| 8 | import org.apache.ibatis.annotations.*; | 9 | import org.apache.ibatis.annotations.*; |
| 9 | import org.springframework.stereotype.Repository; | 10 | import org.springframework.stereotype.Repository; |
| 10 | 11 | ||
| @@ -82,7 +83,56 @@ public interface DeviceChannelMapper { | @@ -82,7 +83,56 @@ public interface DeviceChannelMapper { | ||
| 82 | "</foreach> </if>" + | 83 | "</foreach> </if>" + |
| 83 | "ORDER BY dc.channelId " + | 84 | "ORDER BY dc.channelId " + |
| 84 | " </script>"}) | 85 | " </script>"}) |
| 85 | - List<DeviceChannel> queryChannels(String deviceId, String parentChannelId, String query, Boolean hasSubChannel, Boolean online,List<String> channelIds); | 86 | + List<DeviceChannel> queryChannels(String deviceId, String parentChannelId, String query, Boolean hasSubChannel, Boolean online, List<String> channelIds); |
| 87 | + | ||
| 88 | + @Select(value = {" <script>" + | ||
| 89 | + "SELECT " + | ||
| 90 | + "dc.*, " + | ||
| 91 | + "de.name as deviceName, " + | ||
| 92 | + "de.online as deviceOnline " + | ||
| 93 | + "from " + | ||
| 94 | + "device_channel dc " + | ||
| 95 | + "LEFT JOIN device de ON dc.deviceId = de.deviceId " + | ||
| 96 | + "WHERE 1=1" + | ||
| 97 | + " <if test='deviceId != null'> AND dc.deviceId = #{deviceId} </if> " + | ||
| 98 | + " <if test='query != null'> AND (dc.channelId LIKE '%${query}%' OR dc.name LIKE '%${query}%' OR dc.name LIKE '%${query}%')</if> " + | ||
| 99 | + " <if test='parentChannelId != null'> AND dc.parentId=#{parentChannelId} </if> " + | ||
| 100 | + " <if test='online == true' > AND dc.status=1</if>" + | ||
| 101 | + " <if test='online == false' > AND dc.status=0</if>" + | ||
| 102 | + " <if test='hasSubChannel == true' > AND dc.subCount > 0 </if>" + | ||
| 103 | + " <if test='hasSubChannel == false' > AND dc.subCount = 0 </if>" + | ||
| 104 | + "<if test='channelIds != null'> AND dc.channelId in <foreach item='item' index='index' collection='channelIds' open='(' separator=',' close=')'>" + | ||
| 105 | + "#{item} " + | ||
| 106 | + "</foreach> </if>" + | ||
| 107 | + "ORDER BY dc.channelId ASC" + | ||
| 108 | + " </script>"}) | ||
| 109 | + List<DeviceChannelExtend> queryChannelsWithDeviceInfo(String deviceId, String parentChannelId, String query, Boolean hasSubChannel, Boolean online, List<String> channelIds); | ||
| 110 | + | ||
| 111 | + | ||
| 112 | + @Select(value = {" <script>" + | ||
| 113 | + "SELECT " + | ||
| 114 | + "dc.*, " + | ||
| 115 | + "de.name as deviceName, " + | ||
| 116 | + "de.online as deviceOnline " + | ||
| 117 | + "from " + | ||
| 118 | + "device_channel dc " + | ||
| 119 | + "LEFT JOIN device de ON dc.deviceId = de.deviceId " + | ||
| 120 | + "WHERE 1=1" + | ||
| 121 | + " <if test='deviceId != null'> AND dc.deviceId = #{deviceId} </if> " + | ||
| 122 | + " <if test='query != null'> AND (dc.channelId LIKE '%${query}%' OR dc.name LIKE '%${query}%' OR dc.name LIKE '%${query}%')</if> " + | ||
| 123 | + " <if test='parentChannelId != null'> AND dc.parentId=#{parentChannelId} </if> " + | ||
| 124 | + " <if test='online == true' > AND dc.status=1</if>" + | ||
| 125 | + " <if test='online == false' > AND dc.status=0</if>" + | ||
| 126 | + " <if test='hasSubChannel == true' > AND dc.subCount > 0 </if>" + | ||
| 127 | + " <if test='hasSubChannel == false' > AND dc.subCount = 0 </if>" + | ||
| 128 | + "<if test='channelIds != null'> AND dc.channelId in <foreach item='item' index='index' collection='channelIds' open='(' separator=',' close=')'>" + | ||
| 129 | + "#{item} " + | ||
| 130 | + "</foreach> </if>" + | ||
| 131 | + "ORDER BY dc.channelId ASC " + | ||
| 132 | + "Limit #{limit} OFFSET #{start}" + | ||
| 133 | + " </script>"}) | ||
| 134 | + List<DeviceChannelExtend> queryChannelsByDeviceIdWithStartAndLimit(String deviceId,List<String> channelIds, String parentChannelId, String query, | ||
| 135 | + Boolean hasSubChannel, Boolean online, int start, int limit); | ||
| 86 | 136 | ||
| 87 | @Select("SELECT * FROM device_channel WHERE deviceId=#{deviceId} AND channelId=#{channelId}") | 137 | @Select("SELECT * FROM device_channel WHERE deviceId=#{deviceId} AND channelId=#{channelId}") |
| 88 | DeviceChannel queryChannel(String deviceId, String channelId); | 138 | DeviceChannel queryChannel(String deviceId, String channelId); |
| @@ -245,28 +295,6 @@ public interface DeviceChannelMapper { | @@ -245,28 +295,6 @@ public interface DeviceChannelMapper { | ||
| 245 | int batchUpdate(List<DeviceChannel> updateChannels); | 295 | int batchUpdate(List<DeviceChannel> updateChannels); |
| 246 | 296 | ||
| 247 | 297 | ||
| 248 | - @Select(value = {" <script>" + | ||
| 249 | - "SELECT " + | ||
| 250 | - "dc1.* " + | ||
| 251 | - "from " + | ||
| 252 | - "device_channel dc1 " + | ||
| 253 | - "WHERE " + | ||
| 254 | - "dc1.deviceId = #{deviceId} " + | ||
| 255 | - " <if test='query != null'> AND (dc1.channelId LIKE concat('%',#{query},'%') OR dc1.name LIKE concat('%',#{query},'%') OR dc1.name LIKE concat('%',#{query},'%'))</if> " + | ||
| 256 | - " <if test='parentChannelId != null'> AND dc1.parentId=#{parentChannelId} </if> " + | ||
| 257 | - " <if test='online == true' > AND dc1.status=1</if>" + | ||
| 258 | - " <if test='online == false' > AND dc1.status=0</if>" + | ||
| 259 | - " <if test='hasSubChannel == true' > AND dc1.subCount >0</if>" + | ||
| 260 | - " <if test='hasSubChannel == false' > AND dc1.subCount=0</if>" + | ||
| 261 | - "<if test='channelIds != null'> AND dc1.channelId in <foreach item='item' index='index' collection='channelIds' open='(' separator=',' close=')'>" + | ||
| 262 | - "#{item} " + | ||
| 263 | - "</foreach> </if>" + | ||
| 264 | - "ORDER BY dc1.channelId ASC " + | ||
| 265 | - "Limit #{limit} OFFSET #{start}" + | ||
| 266 | - " </script>"}) | ||
| 267 | - List<DeviceChannel> queryChannelsByDeviceIdWithStartAndLimit(String deviceId, String parentChannelId, String query, | ||
| 268 | - Boolean hasSubChannel, Boolean online, int start, int limit,List<String> channelIds); | ||
| 269 | - | ||
| 270 | @Select("SELECT * FROM device_channel WHERE deviceId=#{deviceId} AND status=1") | 298 | @Select("SELECT * FROM device_channel WHERE deviceId=#{deviceId} AND status=1") |
| 271 | List<DeviceChannel> queryOnlineChannelsByDeviceId(String deviceId); | 299 | List<DeviceChannel> queryOnlineChannelsByDeviceId(String deviceId); |
| 272 | 300 |
src/main/java/com/genersoft/iot/vmp/storager/impl/VideoManagerStorageImpl.java
| @@ -14,6 +14,7 @@ import com.genersoft.iot.vmp.storager.dao.*; | @@ -14,6 +14,7 @@ import com.genersoft.iot.vmp.storager.dao.*; | ||
| 14 | import com.genersoft.iot.vmp.storager.dao.dto.ChannelSourceInfo; | 14 | import com.genersoft.iot.vmp.storager.dao.dto.ChannelSourceInfo; |
| 15 | import com.genersoft.iot.vmp.utils.DateUtil; | 15 | import com.genersoft.iot.vmp.utils.DateUtil; |
| 16 | import com.genersoft.iot.vmp.vmanager.gb28181.platform.bean.ChannelReduce; | 16 | import com.genersoft.iot.vmp.vmanager.gb28181.platform.bean.ChannelReduce; |
| 17 | +import com.genersoft.iot.vmp.web.gb28181.dto.DeviceChannelExtend; | ||
| 17 | import com.github.pagehelper.PageHelper; | 18 | import com.github.pagehelper.PageHelper; |
| 18 | import com.github.pagehelper.PageInfo; | 19 | import com.github.pagehelper.PageInfo; |
| 19 | import org.slf4j.Logger; | 20 | import org.slf4j.Logger; |
| @@ -366,8 +367,8 @@ public class VideoManagerStorageImpl implements IVideoManagerStorage { | @@ -366,8 +367,8 @@ public class VideoManagerStorageImpl implements IVideoManagerStorage { | ||
| 366 | } | 367 | } |
| 367 | 368 | ||
| 368 | @Override | 369 | @Override |
| 369 | - public List<DeviceChannel> queryChannelsByDeviceIdWithStartAndLimit(String deviceId, String query, Boolean hasSubChannel, Boolean online, int start, int limit,List<String> channelIds) { | ||
| 370 | - return deviceChannelMapper.queryChannelsByDeviceIdWithStartAndLimit(deviceId, null, query, hasSubChannel, online, start, limit,channelIds); | 370 | + public List<DeviceChannelExtend> queryChannelsByDeviceIdWithStartAndLimit(String deviceId, List<String> channelIds, String query, Boolean hasSubChannel, Boolean online, int start, int limit) { |
| 371 | + return deviceChannelMapper.queryChannelsByDeviceIdWithStartAndLimit(deviceId, channelIds, null, query, hasSubChannel, online, start, limit); | ||
| 371 | } | 372 | } |
| 372 | 373 | ||
| 373 | 374 | ||
| @@ -377,6 +378,11 @@ public class VideoManagerStorageImpl implements IVideoManagerStorage { | @@ -377,6 +378,11 @@ public class VideoManagerStorageImpl implements IVideoManagerStorage { | ||
| 377 | } | 378 | } |
| 378 | 379 | ||
| 379 | @Override | 380 | @Override |
| 381 | + public List<DeviceChannelExtend> queryChannelsByDeviceId(String deviceId, List<String> channelIds, Boolean online) { | ||
| 382 | + return deviceChannelMapper.queryChannelsWithDeviceInfo(deviceId, null,null, null, online,channelIds); | ||
| 383 | + } | ||
| 384 | + | ||
| 385 | + @Override | ||
| 380 | public PageInfo<DeviceChannel> querySubChannels(String deviceId, String parentChannelId, String query, Boolean hasSubChannel, Boolean online, int page, int count) { | 386 | public PageInfo<DeviceChannel> querySubChannels(String deviceId, String parentChannelId, String query, Boolean hasSubChannel, Boolean online, int page, int count) { |
| 381 | PageHelper.startPage(page, count); | 387 | PageHelper.startPage(page, count); |
| 382 | List<DeviceChannel> all = deviceChannelMapper.queryChannels(deviceId, parentChannelId, query, hasSubChannel, online,null); | 388 | List<DeviceChannel> all = deviceChannelMapper.queryChannels(deviceId, parentChannelId, query, hasSubChannel, online,null); |
src/main/java/com/genersoft/iot/vmp/web/gb28181/ApiDeviceController.java
| @@ -3,15 +3,17 @@ package com.genersoft.iot.vmp.web.gb28181; | @@ -3,15 +3,17 @@ package com.genersoft.iot.vmp.web.gb28181; | ||
| 3 | import com.alibaba.fastjson2.JSONArray; | 3 | import com.alibaba.fastjson2.JSONArray; |
| 4 | import com.alibaba.fastjson2.JSONObject; | 4 | import com.alibaba.fastjson2.JSONObject; |
| 5 | import com.genersoft.iot.vmp.gb28181.bean.Device; | 5 | import com.genersoft.iot.vmp.gb28181.bean.Device; |
| 6 | -import com.genersoft.iot.vmp.gb28181.bean.DeviceChannel; | ||
| 7 | import com.genersoft.iot.vmp.service.IDeviceService; | 6 | import com.genersoft.iot.vmp.service.IDeviceService; |
| 8 | import com.genersoft.iot.vmp.storager.IVideoManagerStorage; | 7 | import com.genersoft.iot.vmp.storager.IVideoManagerStorage; |
| 8 | +import com.genersoft.iot.vmp.web.gb28181.dto.DeviceChannelExtend; | ||
| 9 | import com.github.pagehelper.PageInfo; | 9 | import com.github.pagehelper.PageInfo; |
| 10 | import org.slf4j.Logger; | 10 | import org.slf4j.Logger; |
| 11 | import org.slf4j.LoggerFactory; | 11 | import org.slf4j.LoggerFactory; |
| 12 | import org.springframework.beans.factory.annotation.Autowired; | 12 | import org.springframework.beans.factory.annotation.Autowired; |
| 13 | import org.springframework.util.StringUtils; | 13 | import org.springframework.util.StringUtils; |
| 14 | -import org.springframework.web.bind.annotation.*; | 14 | +import org.springframework.web.bind.annotation.RequestMapping; |
| 15 | +import org.springframework.web.bind.annotation.RequestParam; | ||
| 16 | +import org.springframework.web.bind.annotation.RestController; | ||
| 15 | 17 | ||
| 16 | import java.util.Arrays; | 18 | import java.util.Arrays; |
| 17 | import java.util.List; | 19 | import java.util.List; |
| @@ -96,8 +98,8 @@ public class ApiDeviceController { | @@ -96,8 +98,8 @@ public class ApiDeviceController { | ||
| 96 | 98 | ||
| 97 | @RequestMapping(value = "/channellist") | 99 | @RequestMapping(value = "/channellist") |
| 98 | public JSONObject channellist( String serial, | 100 | public JSONObject channellist( String serial, |
| 99 | - @RequestParam(required = false)String code, | ||
| 100 | @RequestParam(required = false)String channel_type, | 101 | @RequestParam(required = false)String channel_type, |
| 102 | + @RequestParam(required = false)String code , | ||
| 101 | @RequestParam(required = false)String dir_serial , | 103 | @RequestParam(required = false)String dir_serial , |
| 102 | @RequestParam(required = false)Integer start, | 104 | @RequestParam(required = false)Integer start, |
| 103 | @RequestParam(required = false)Integer limit, | 105 | @RequestParam(required = false)Integer limit, |
| @@ -109,54 +111,60 @@ public class ApiDeviceController { | @@ -109,54 +111,60 @@ public class ApiDeviceController { | ||
| 109 | // } | 111 | // } |
| 110 | JSONObject result = new JSONObject(); | 112 | JSONObject result = new JSONObject(); |
| 111 | // 查询设备是否存在 | 113 | // 查询设备是否存在 |
| 112 | - List<DeviceChannel> deviceChannels; | 114 | +// Device device = storager.queryVideoDevice(serial); |
| 115 | +// if (device == null) { | ||
| 116 | +// result.put("ChannelCount", 0); | ||
| 117 | +// result.put("ChannelList", "[]"); | ||
| 118 | +// return result; | ||
| 119 | +// } | ||
| 120 | + List<DeviceChannelExtend> deviceChannels; | ||
| 113 | List<String> channelIds = null; | 121 | List<String> channelIds = null; |
| 114 | if (!StringUtils.isEmpty(code)) { | 122 | if (!StringUtils.isEmpty(code)) { |
| 115 | String[] split = code.trim().split(","); | 123 | String[] split = code.trim().split(","); |
| 116 | channelIds = Arrays.asList(split); | 124 | channelIds = Arrays.asList(split); |
| 117 | } | 125 | } |
| 118 | - List<DeviceChannel> allDeviceChannelList = storager.queryChannelsByDeviceId(serial,online,channelIds); | 126 | + List<DeviceChannelExtend> allDeviceChannelList = storager.queryChannelsByDeviceId(serial,channelIds,online); |
| 119 | if (start == null || limit ==null) { | 127 | if (start == null || limit ==null) { |
| 120 | deviceChannels = allDeviceChannelList; | 128 | deviceChannels = allDeviceChannelList; |
| 121 | result.put("ChannelCount", deviceChannels.size()); | 129 | result.put("ChannelCount", deviceChannels.size()); |
| 122 | }else { | 130 | }else { |
| 123 | - deviceChannels = storager.queryChannelsByDeviceIdWithStartAndLimit(serial, null, null, online,start, limit,channelIds); | 131 | + deviceChannels = storager.queryChannelsByDeviceIdWithStartAndLimit(serial,channelIds, null, null, online,start, limit); |
| 124 | int total = allDeviceChannelList.size(); | 132 | int total = allDeviceChannelList.size(); |
| 125 | result.put("ChannelCount", total); | 133 | result.put("ChannelCount", total); |
| 126 | } | 134 | } |
| 127 | 135 | ||
| 128 | JSONArray channleJSONList = new JSONArray(); | 136 | JSONArray channleJSONList = new JSONArray(); |
| 129 | - for (DeviceChannel deviceChannel : deviceChannels) { | 137 | + for (DeviceChannelExtend deviceChannelExtend : deviceChannels) { |
| 130 | JSONObject deviceJOSNChannel = new JSONObject(); | 138 | JSONObject deviceJOSNChannel = new JSONObject(); |
| 131 | - deviceJOSNChannel.put("ID", deviceChannel.getChannelId()); | ||
| 132 | - deviceJOSNChannel.put("DeviceID", device.getDeviceId()); | ||
| 133 | - deviceJOSNChannel.put("DeviceName", device.getName()); | ||
| 134 | - deviceJOSNChannel.put("DeviceOnline", device.getOnline() == 1); | ||
| 135 | - deviceJOSNChannel.put("Channel", 0); // 自定义序号 | ||
| 136 | - deviceJOSNChannel.put("Name", deviceChannel.getName()); | 139 | + deviceJOSNChannel.put("ID", deviceChannelExtend.getChannelId()); |
| 140 | + deviceJOSNChannel.put("DeviceID", deviceChannelExtend.getDeviceId()); | ||
| 141 | + deviceJOSNChannel.put("DeviceName", deviceChannelExtend.getDeviceName()); | ||
| 142 | + deviceJOSNChannel.put("DeviceOnline", deviceChannelExtend.getDeviceOnline() == 1); | ||
| 143 | + deviceJOSNChannel.put("Channel", 0); // TODO 自定义序号 | ||
| 144 | + deviceJOSNChannel.put("Name", deviceChannelExtend.getName()); | ||
| 137 | deviceJOSNChannel.put("Custom", false); | 145 | deviceJOSNChannel.put("Custom", false); |
| 138 | deviceJOSNChannel.put("CustomName", ""); | 146 | deviceJOSNChannel.put("CustomName", ""); |
| 139 | - deviceJOSNChannel.put("SubCount", deviceChannel.getSubCount()); // 子节点数, SubCount > 0 表示该通道为子目录 | 147 | + deviceJOSNChannel.put("SubCount", deviceChannelExtend.getSubCount()); // TODO ? 子节点数, SubCount > 0 表示该通道为子目录 |
| 140 | deviceJOSNChannel.put("SnapURL", ""); | 148 | deviceJOSNChannel.put("SnapURL", ""); |
| 141 | - deviceJOSNChannel.put("Manufacturer ", deviceChannel.getManufacture()); | ||
| 142 | - deviceJOSNChannel.put("Model", deviceChannel.getModel()); | ||
| 143 | - deviceJOSNChannel.put("Owner", deviceChannel.getOwner()); | ||
| 144 | - deviceJOSNChannel.put("CivilCode", deviceChannel.getCivilCode()); | ||
| 145 | - deviceJOSNChannel.put("Address", deviceChannel.getAddress()); | ||
| 146 | - deviceJOSNChannel.put("Parental", deviceChannel.getParental()); // 当为通道设备时, 是否有通道子设备, 1-有,0-没有 | ||
| 147 | - deviceJOSNChannel.put("ParentID", deviceChannel.getParentId()); // 直接上级编号 | ||
| 148 | - deviceJOSNChannel.put("Secrecy", deviceChannel.getSecrecy()); | 149 | + deviceJOSNChannel.put("Manufacturer ", deviceChannelExtend.getManufacture()); |
| 150 | + deviceJOSNChannel.put("Model", deviceChannelExtend.getModel()); | ||
| 151 | + deviceJOSNChannel.put("Owner", deviceChannelExtend.getOwner()); | ||
| 152 | + deviceJOSNChannel.put("CivilCode", deviceChannelExtend.getCivilCode()); | ||
| 153 | + deviceJOSNChannel.put("Address", deviceChannelExtend.getAddress()); | ||
| 154 | + deviceJOSNChannel.put("Parental", deviceChannelExtend.getParental()); // 当为通道设备时, 是否有通道子设备, 1-有,0-没有 | ||
| 155 | + deviceJOSNChannel.put("ParentID", deviceChannelExtend.getParentId()); // 直接上级编号 | ||
| 156 | + deviceJOSNChannel.put("Secrecy", deviceChannelExtend.getSecrecy()); | ||
| 149 | deviceJOSNChannel.put("RegisterWay", 1); // 注册方式, 缺省为1, 允许值: 1, 2, 3 | 157 | deviceJOSNChannel.put("RegisterWay", 1); // 注册方式, 缺省为1, 允许值: 1, 2, 3 |
| 150 | - // 1-IETF RFC3261, | ||
| 151 | - // 2-基于口令的双向认证, | ||
| 152 | - // 3-基于数字证书的双向认证 | ||
| 153 | - deviceJOSNChannel.put("Status", deviceChannel.getStatus() == 1 ? "ON":"OFF"); | ||
| 154 | - deviceJOSNChannel.put("Longitude", deviceChannel.getLongitude()); | ||
| 155 | - deviceJOSNChannel.put("Latitude", deviceChannel.getLatitude()); | ||
| 156 | - deviceJOSNChannel.put("PTZType ", deviceChannel.getPTZType()); // 云台类型, 0 - 未知, 1 - 球机, 2 - 半球, | ||
| 157 | - // 3 - 固定枪机, 4 - 遥控枪机 | 158 | + // 1-IETF RFC3261, |
| 159 | + // 2-基于口令的双向认证, | ||
| 160 | + // 3-基于数字证书的双向认证 | ||
| 161 | + deviceJOSNChannel.put("Status", deviceChannelExtend.getStatus() == 1 ? "ON":"OFF"); | ||
| 162 | + deviceJOSNChannel.put("Longitude", deviceChannelExtend.getLongitude()); | ||
| 163 | + deviceJOSNChannel.put("Latitude", deviceChannelExtend.getLatitude()); | ||
| 164 | + deviceJOSNChannel.put("PTZType ", deviceChannelExtend.getPTZType()); // 云台类型, 0 - 未知, 1 - 球机, 2 - 半球, | ||
| 165 | + // 3 - 固定枪机, 4 - 遥控枪机 | ||
| 158 | deviceJOSNChannel.put("CustomPTZType", ""); | 166 | deviceJOSNChannel.put("CustomPTZType", ""); |
| 159 | - deviceJOSNChannel.put("StreamID", deviceChannel.getStreamId()); // StreamID 直播流ID, 有值表示正在直播 | 167 | + deviceJOSNChannel.put("StreamID", deviceChannelExtend.getStreamId()); // StreamID 直播流ID, 有值表示正在直播 |
| 160 | deviceJOSNChannel.put("NumOutputs ", -1); // 直播在线人数 | 168 | deviceJOSNChannel.put("NumOutputs ", -1); // 直播在线人数 |
| 161 | channleJSONList.add(deviceJOSNChannel); | 169 | channleJSONList.add(deviceJOSNChannel); |
| 162 | } | 170 | } |
src/main/java/com/genersoft/iot/vmp/web/gb28181/dto/DeviceChannelExtent.java renamed to src/main/java/com/genersoft/iot/vmp/web/gb28181/dto/DeviceChannelExtend.java
| 1 | package com.genersoft.iot.vmp.web.gb28181.dto; | 1 | package com.genersoft.iot.vmp.web.gb28181.dto; |
| 2 | 2 | ||
| 3 | -import io.swagger.v3.oas.annotations.media.Schema; | ||
| 4 | - | ||
| 5 | -@Schema(description = "通道信息") | ||
| 6 | -public class DeviceChannelExtent { | 3 | +public class DeviceChannelExtend { |
| 7 | 4 | ||
| 8 | 5 | ||
| 9 | /** | 6 | /** |
| 10 | * 数据库自增ID | 7 | * 数据库自增ID |
| 11 | */ | 8 | */ |
| 12 | - @Schema(description = "数据库自增ID") | ||
| 13 | private int id; | 9 | private int id; |
| 14 | 10 | ||
| 15 | /** | 11 | /** |
| 16 | - * 通道国标编号 | 12 | + * 通道id |
| 17 | */ | 13 | */ |
| 18 | - @Schema(description = "通道国标编号") | ||
| 19 | private String channelId; | 14 | private String channelId; |
| 20 | 15 | ||
| 21 | /** | 16 | /** |
| 22 | - * 设备国标编号 | 17 | + * 设备id |
| 23 | */ | 18 | */ |
| 24 | - @Schema(description = "设备国标编号") | ||
| 25 | private String deviceId; | 19 | private String deviceId; |
| 26 | 20 | ||
| 27 | /** | 21 | /** |
| 28 | * 通道名 | 22 | * 通道名 |
| 29 | */ | 23 | */ |
| 30 | - @Schema(description = "名称") | ||
| 31 | private String name; | 24 | private String name; |
| 25 | + | ||
| 26 | + private String deviceName; | ||
| 27 | + | ||
| 28 | + private int deviceOnline; | ||
| 32 | 29 | ||
| 33 | /** | 30 | /** |
| 34 | * 生产厂商 | 31 | * 生产厂商 |
| 35 | */ | 32 | */ |
| 36 | - @Schema(description = "生产厂商") | ||
| 37 | private String manufacture; | 33 | private String manufacture; |
| 38 | 34 | ||
| 39 | /** | 35 | /** |
| 40 | * 型号 | 36 | * 型号 |
| 41 | */ | 37 | */ |
| 42 | - @Schema(description = "型号") | ||
| 43 | private String model; | 38 | private String model; |
| 44 | 39 | ||
| 45 | /** | 40 | /** |
| 46 | * 设备归属 | 41 | * 设备归属 |
| 47 | */ | 42 | */ |
| 48 | - @Schema(description = "设备归属") | ||
| 49 | private String owner; | 43 | private String owner; |
| 50 | 44 | ||
| 51 | /** | 45 | /** |
| 52 | * 行政区域 | 46 | * 行政区域 |
| 53 | */ | 47 | */ |
| 54 | - @Schema(description = "行政区域") | ||
| 55 | private String civilCode; | 48 | private String civilCode; |
| 56 | 49 | ||
| 57 | /** | 50 | /** |
| 58 | * 警区 | 51 | * 警区 |
| 59 | */ | 52 | */ |
| 60 | - @Schema(description = "警区") | ||
| 61 | private String block; | 53 | private String block; |
| 62 | 54 | ||
| 63 | /** | 55 | /** |
| 64 | * 安装地址 | 56 | * 安装地址 |
| 65 | */ | 57 | */ |
| 66 | - @Schema(description = "安装地址") | ||
| 67 | private String address; | 58 | private String address; |
| 68 | 59 | ||
| 69 | /** | 60 | /** |
| 70 | * 是否有子设备 1有, 0没有 | 61 | * 是否有子设备 1有, 0没有 |
| 71 | */ | 62 | */ |
| 72 | - @Schema(description = "是否有子设备 1有, 0没有") | ||
| 73 | private int parental; | 63 | private int parental; |
| 74 | 64 | ||
| 75 | /** | 65 | /** |
| 76 | * 父级id | 66 | * 父级id |
| 77 | */ | 67 | */ |
| 78 | - @Schema(description = "父级id") | ||
| 79 | private String parentId; | 68 | private String parentId; |
| 80 | 69 | ||
| 81 | /** | 70 | /** |
| 82 | * 信令安全模式 缺省为0; 0:不采用; 2: S/MIME签名方式; 3: S/ MIME加密签名同时采用方式; 4:数字摘要方式 | 71 | * 信令安全模式 缺省为0; 0:不采用; 2: S/MIME签名方式; 3: S/ MIME加密签名同时采用方式; 4:数字摘要方式 |
| 83 | */ | 72 | */ |
| 84 | - @Schema(description = "信令安全模式 缺省为0; 0:不采用; 2: S/MIME签名方式; 3: S/ MIME加密签名同时采用方式; 4:数字摘要方式") | ||
| 85 | private int safetyWay; | 73 | private int safetyWay; |
| 86 | 74 | ||
| 87 | /** | 75 | /** |
| 88 | * 注册方式 缺省为1;1:符合IETFRFC3261标准的认证注册模 式; 2:基于口令的双向认证注册模式; 3:基于数字证书的双向认证注册模式 | 76 | * 注册方式 缺省为1;1:符合IETFRFC3261标准的认证注册模 式; 2:基于口令的双向认证注册模式; 3:基于数字证书的双向认证注册模式 |
| 89 | */ | 77 | */ |
| 90 | - @Schema(description = "注册方式 缺省为1;1:符合IETFRFC3261标准的认证注册模 式; 2:基于口令的双向认证注册模式; 3:基于数字证书的双向认证注册模式") | ||
| 91 | private int registerWay; | 78 | private int registerWay; |
| 92 | 79 | ||
| 93 | /** | 80 | /** |
| 94 | * 证书序列号 | 81 | * 证书序列号 |
| 95 | */ | 82 | */ |
| 96 | - @Schema(description = "证书序列号") | ||
| 97 | private String certNum; | 83 | private String certNum; |
| 98 | 84 | ||
| 99 | /** | 85 | /** |
| 100 | * 证书有效标识 缺省为0;证书有效标识:0:无效1: 有效 | 86 | * 证书有效标识 缺省为0;证书有效标识:0:无效1: 有效 |
| 101 | */ | 87 | */ |
| 102 | - @Schema(description = "证书有效标识 缺省为0;证书有效标识:0:无效1: 有效") | ||
| 103 | private int certifiable; | 88 | private int certifiable; |
| 104 | 89 | ||
| 105 | /** | 90 | /** |
| 106 | * 证书无效原因码 | 91 | * 证书无效原因码 |
| 107 | */ | 92 | */ |
| 108 | - @Schema(description = "证书无效原因码") | ||
| 109 | private int errCode; | 93 | private int errCode; |
| 110 | 94 | ||
| 111 | /** | 95 | /** |
| 112 | * 证书终止有效期 | 96 | * 证书终止有效期 |
| 113 | */ | 97 | */ |
| 114 | - @Schema(description = "证书终止有效期") | ||
| 115 | private String endTime; | 98 | private String endTime; |
| 116 | 99 | ||
| 117 | /** | 100 | /** |
| 118 | * 保密属性 缺省为0; 0:不涉密, 1:涉密 | 101 | * 保密属性 缺省为0; 0:不涉密, 1:涉密 |
| 119 | */ | 102 | */ |
| 120 | - @Schema(description = "保密属性 缺省为0; 0:不涉密, 1:涉密") | ||
| 121 | private String secrecy; | 103 | private String secrecy; |
| 122 | 104 | ||
| 123 | /** | 105 | /** |
| 124 | * IP地址 | 106 | * IP地址 |
| 125 | */ | 107 | */ |
| 126 | - @Schema(description = "IP地址") | ||
| 127 | private String ipAddress; | 108 | private String ipAddress; |
| 128 | 109 | ||
| 129 | /** | 110 | /** |
| 130 | * 端口号 | 111 | * 端口号 |
| 131 | */ | 112 | */ |
| 132 | - @Schema(description = "端口号") | ||
| 133 | private int port; | 113 | private int port; |
| 134 | 114 | ||
| 135 | /** | 115 | /** |
| 136 | * 密码 | 116 | * 密码 |
| 137 | */ | 117 | */ |
| 138 | - @Schema(description = "密码") | ||
| 139 | private String password; | 118 | private String password; |
| 140 | 119 | ||
| 141 | /** | 120 | /** |
| 142 | * 云台类型 | 121 | * 云台类型 |
| 143 | */ | 122 | */ |
| 144 | - @Schema(description = "云台类型") | ||
| 145 | private int PTZType; | 123 | private int PTZType; |
| 146 | 124 | ||
| 147 | /** | 125 | /** |
| 148 | * 云台类型描述字符串 | 126 | * 云台类型描述字符串 |
| 149 | */ | 127 | */ |
| 150 | - @Schema(description = "云台类型描述字符串") | ||
| 151 | private String PTZTypeText; | 128 | private String PTZTypeText; |
| 152 | 129 | ||
| 153 | /** | 130 | /** |
| 154 | * 创建时间 | 131 | * 创建时间 |
| 155 | */ | 132 | */ |
| 156 | - @Schema(description = "创建时间") | ||
| 157 | private String createTime; | 133 | private String createTime; |
| 158 | 134 | ||
| 159 | /** | 135 | /** |
| 160 | * 更新时间 | 136 | * 更新时间 |
| 161 | */ | 137 | */ |
| 162 | - @Schema(description = "更新时间") | ||
| 163 | private String updateTime; | 138 | private String updateTime; |
| 164 | 139 | ||
| 165 | /** | 140 | /** |
| @@ -171,79 +146,66 @@ public class DeviceChannelExtent { | @@ -171,79 +146,66 @@ public class DeviceChannelExtent { | ||
| 171 | * <Status>OFF</Status> | 146 | * <Status>OFF</Status> |
| 172 | * 遇到过NVR下的IPC下发信令可以推流, 但是 Status 响应 OFF | 147 | * 遇到过NVR下的IPC下发信令可以推流, 但是 Status 响应 OFF |
| 173 | */ | 148 | */ |
| 174 | - @Schema(description = "在线/离线, 1在线,0离线") | ||
| 175 | private int status; | 149 | private int status; |
| 176 | 150 | ||
| 177 | /** | 151 | /** |
| 178 | * 经度 | 152 | * 经度 |
| 179 | */ | 153 | */ |
| 180 | - @Schema(description = "经度") | ||
| 181 | private double longitude; | 154 | private double longitude; |
| 182 | 155 | ||
| 183 | /** | 156 | /** |
| 184 | * 纬度 | 157 | * 纬度 |
| 185 | */ | 158 | */ |
| 186 | - @Schema(description = "纬度") | ||
| 187 | private double latitude; | 159 | private double latitude; |
| 188 | 160 | ||
| 189 | /** | 161 | /** |
| 190 | * 经度 GCJ02 | 162 | * 经度 GCJ02 |
| 191 | */ | 163 | */ |
| 192 | - @Schema(description = "GCJ02坐标系经度") | ||
| 193 | private double longitudeGcj02; | 164 | private double longitudeGcj02; |
| 194 | 165 | ||
| 195 | /** | 166 | /** |
| 196 | * 纬度 GCJ02 | 167 | * 纬度 GCJ02 |
| 197 | */ | 168 | */ |
| 198 | - @Schema(description = "GCJ02坐标系纬度") | ||
| 199 | private double latitudeGcj02; | 169 | private double latitudeGcj02; |
| 200 | 170 | ||
| 201 | /** | 171 | /** |
| 202 | * 经度 WGS84 | 172 | * 经度 WGS84 |
| 203 | */ | 173 | */ |
| 204 | - @Schema(description = "WGS84坐标系经度") | ||
| 205 | private double longitudeWgs84; | 174 | private double longitudeWgs84; |
| 206 | 175 | ||
| 207 | /** | 176 | /** |
| 208 | * 纬度 WGS84 | 177 | * 纬度 WGS84 |
| 209 | */ | 178 | */ |
| 210 | - @Schema(description = "WGS84坐标系纬度") | ||
| 211 | private double latitudeWgs84; | 179 | private double latitudeWgs84; |
| 212 | 180 | ||
| 213 | /** | 181 | /** |
| 214 | * 子设备数 | 182 | * 子设备数 |
| 215 | */ | 183 | */ |
| 216 | - @Schema(description = "子设备数") | ||
| 217 | private int subCount; | 184 | private int subCount; |
| 218 | 185 | ||
| 219 | /** | 186 | /** |
| 220 | * 流唯一编号,存在表示正在直播 | 187 | * 流唯一编号,存在表示正在直播 |
| 221 | */ | 188 | */ |
| 222 | - @Schema(description = "流唯一编号,存在表示正在直播") | ||
| 223 | private String streamId; | 189 | private String streamId; |
| 224 | 190 | ||
| 225 | /** | 191 | /** |
| 226 | * 是否含有音频 | 192 | * 是否含有音频 |
| 227 | */ | 193 | */ |
| 228 | - @Schema(description = "是否含有音频") | ||
| 229 | private boolean hasAudio; | 194 | private boolean hasAudio; |
| 230 | 195 | ||
| 231 | /** | 196 | /** |
| 232 | * 标记通道的类型,0->国标通道 1->直播流通道 2->业务分组/虚拟组织/行政区划 | 197 | * 标记通道的类型,0->国标通道 1->直播流通道 2->业务分组/虚拟组织/行政区划 |
| 233 | */ | 198 | */ |
| 234 | - @Schema(description = "标记通道的类型,0->国标通道 1->直播流通道 2->业务分组/虚拟组织/行政区划") | ||
| 235 | private int channelType; | 199 | private int channelType; |
| 236 | 200 | ||
| 237 | /** | 201 | /** |
| 238 | * 业务分组 | 202 | * 业务分组 |
| 239 | */ | 203 | */ |
| 240 | - @Schema(description = "业务分组") | ||
| 241 | private String businessGroupId; | 204 | private String businessGroupId; |
| 242 | 205 | ||
| 243 | /** | 206 | /** |
| 244 | * GPS的更新时间 | 207 | * GPS的更新时间 |
| 245 | */ | 208 | */ |
| 246 | - @Schema(description = "GPS的更新时间") | ||
| 247 | private String gpsTime; | 209 | private String gpsTime; |
| 248 | 210 | ||
| 249 | public int getId() { | 211 | public int getId() { |
| @@ -574,4 +536,20 @@ public class DeviceChannelExtent { | @@ -574,4 +536,20 @@ public class DeviceChannelExtent { | ||
| 574 | public void setGpsTime(String gpsTime) { | 536 | public void setGpsTime(String gpsTime) { |
| 575 | this.gpsTime = gpsTime; | 537 | this.gpsTime = gpsTime; |
| 576 | } | 538 | } |
| 539 | + | ||
| 540 | + public String getDeviceName() { | ||
| 541 | + return deviceName; | ||
| 542 | + } | ||
| 543 | + | ||
| 544 | + public void setDeviceName(String deviceName) { | ||
| 545 | + this.deviceName = deviceName; | ||
| 546 | + } | ||
| 547 | + | ||
| 548 | + public int getDeviceOnline() { | ||
| 549 | + return deviceOnline; | ||
| 550 | + } | ||
| 551 | + | ||
| 552 | + public void setDeviceOnline(int deviceOnline) { | ||
| 553 | + this.deviceOnline = deviceOnline; | ||
| 554 | + } | ||
| 577 | } | 555 | } |