Merge branch 'master' into dev/数据库统合
# Conflicts: # src/main/java/com/genersoft/iot/vmp/gb28181/service/IDeviceChannelService.java # web_src/src/components/DeviceList.vuedev/数据库统合
commit
317f771fa2
|
@ -489,4 +489,21 @@ public class DeviceQuery {
|
||||||
public DeviceChannel getRawChannel(int id) {
|
public DeviceChannel getRawChannel(int id) {
|
||||||
return deviceChannelService.getRawChannel(id);
|
return deviceChannelService.getRawChannel(id);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@GetMapping("/subscribe/catalog")
|
||||||
|
@Operation(summary = "开启/关闭目录订阅")
|
||||||
|
@Parameter(name = "id", description = "通道的Id", required = true)
|
||||||
|
@Parameter(name = "cycle", description = "订阅周期", required = true)
|
||||||
|
public void subscribeCatalog(int id, int cycle) {
|
||||||
|
deviceService.subscribeCatalog(id, cycle);
|
||||||
|
}
|
||||||
|
|
||||||
|
@GetMapping("/subscribe/mobile-position")
|
||||||
|
@Operation(summary = "开启/关闭移动位置订阅")
|
||||||
|
@Parameter(name = "id", description = "通道的Id", required = true)
|
||||||
|
@Parameter(name = "cycle", description = "订阅周期", required = true)
|
||||||
|
@Parameter(name = "interval", description = "报送间隔", required = true)
|
||||||
|
public void subscribeMobilePosition(int id, int cycle, int interval) {
|
||||||
|
deviceService.subscribeMobilePosition(id, cycle, interval);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -284,9 +284,8 @@ public interface DeviceMapper {
|
||||||
@Update(value = {" <script>" +
|
@Update(value = {" <script>" +
|
||||||
"UPDATE wvp_device " +
|
"UPDATE wvp_device " +
|
||||||
"SET update_time=#{updateTime}, custom_name=#{name} , password=#{password}, stream_mode=#{streamMode}" +
|
"SET update_time=#{updateTime}, custom_name=#{name} , password=#{password}, stream_mode=#{streamMode}" +
|
||||||
", ip=#{ip}, sdp_ip=#{sdpIp}, port=#{port}, charset=#{charset}, subscribe_cycle_for_catalog=#{subscribeCycleForCatalog}" +
|
", ip=#{ip}, sdp_ip=#{sdpIp}, port=#{port}, charset=#{charset}" +
|
||||||
", subscribe_cycle_for_mobile_position=#{subscribeCycleForMobilePosition}, mobile_position_submission_interval=#{mobilePositionSubmissionInterval}" +
|
", ssrc_check=#{ssrcCheck}, as_message_channel=#{asMessageChannel}" +
|
||||||
", subscribe_cycle_for_alarm=#{subscribeCycleForAlarm}, ssrc_check=#{ssrcCheck}, as_message_channel=#{asMessageChannel}" +
|
|
||||||
", broadcast_push_after_ack=#{broadcastPushAfterAck}, geo_coord_sys=#{geoCoordSys}, media_server_id=#{mediaServerId}" +
|
", broadcast_push_after_ack=#{broadcastPushAfterAck}, geo_coord_sys=#{geoCoordSys}, media_server_id=#{mediaServerId}" +
|
||||||
" WHERE id=#{id}"+
|
" WHERE id=#{id}"+
|
||||||
" </script>"})
|
" </script>"})
|
||||||
|
@ -391,4 +390,17 @@ public interface DeviceMapper {
|
||||||
@Select("select wd.* from wvp_device wd left join wvp_device_channel wdc on wdc.data_type = #{dataType} and wd.id = wdc.data_device_id where wdc.device_id = #{channelDeviceId}")
|
@Select("select wd.* from wvp_device wd left join wvp_device_channel wdc on wdc.data_type = #{dataType} and wd.id = wdc.data_device_id where wdc.device_id = #{channelDeviceId}")
|
||||||
Device getDeviceBySourceChannelDeviceId(@Param("dataType") Integer dataType, @Param("channelDeviceId") String channelDeviceId);
|
Device getDeviceBySourceChannelDeviceId(@Param("dataType") Integer dataType, @Param("channelDeviceId") String channelDeviceId);
|
||||||
|
|
||||||
|
@Update(value = {" <script>" +
|
||||||
|
" UPDATE wvp_device " +
|
||||||
|
" SET subscribe_cycle_for_catalog=#{subscribeCycleForCatalog}" +
|
||||||
|
" WHERE id=#{id}"+
|
||||||
|
" </script>"})
|
||||||
|
void updateSubscribeCatalog(Device device);
|
||||||
|
|
||||||
|
@Update(value = {" <script>" +
|
||||||
|
"UPDATE wvp_device " +
|
||||||
|
"SET subscribe_cycle_for_mobile_position=#{subscribeCycleForMobilePosition}, mobile_position_submission_interval=#{mobilePositionSubmissionInterval}" +
|
||||||
|
" WHERE id=#{id}"+
|
||||||
|
" </script>"})
|
||||||
|
void updateSubscribeMobilePosition(Device device);
|
||||||
}
|
}
|
||||||
|
|
|
@ -128,4 +128,5 @@ public interface IDeviceChannelService {
|
||||||
void queryRecordInfo(Device device, DeviceChannel channel, String startTime, String endTime, ErrorCallback<RecordInfo> object);
|
void queryRecordInfo(Device device, DeviceChannel channel, String startTime, String endTime, ErrorCallback<RecordInfo> object);
|
||||||
|
|
||||||
void queryRecordInfo(CommonGBChannel channel, String startTime, String endTime, ErrorCallback<RecordInfo> object);
|
void queryRecordInfo(CommonGBChannel channel, String startTime, String endTime, ErrorCallback<RecordInfo> object);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -160,4 +160,9 @@ public interface IDeviceService {
|
||||||
Device getDeviceByChannelId(Integer channelId);
|
Device getDeviceByChannelId(Integer channelId);
|
||||||
|
|
||||||
Device getDeviceBySourceChannelDeviceId(String requesterId);
|
Device getDeviceBySourceChannelDeviceId(String requesterId);
|
||||||
|
|
||||||
|
void subscribeCatalog(int id, int cycle);
|
||||||
|
|
||||||
|
void subscribeMobilePosition(int id, int cycle, int interval);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -12,7 +12,6 @@ import com.genersoft.iot.vmp.gb28181.bean.*;
|
||||||
import com.genersoft.iot.vmp.gb28181.dao.DeviceChannelMapper;
|
import com.genersoft.iot.vmp.gb28181.dao.DeviceChannelMapper;
|
||||||
import com.genersoft.iot.vmp.gb28181.dao.DeviceMapper;
|
import com.genersoft.iot.vmp.gb28181.dao.DeviceMapper;
|
||||||
import com.genersoft.iot.vmp.gb28181.dao.PlatformChannelMapper;
|
import com.genersoft.iot.vmp.gb28181.dao.PlatformChannelMapper;
|
||||||
import com.genersoft.iot.vmp.gb28181.service.IDeviceChannelService;
|
|
||||||
import com.genersoft.iot.vmp.gb28181.service.IDeviceService;
|
import com.genersoft.iot.vmp.gb28181.service.IDeviceService;
|
||||||
import com.genersoft.iot.vmp.gb28181.service.IInviteStreamService;
|
import com.genersoft.iot.vmp.gb28181.service.IInviteStreamService;
|
||||||
import com.genersoft.iot.vmp.gb28181.session.AudioBroadcastManager;
|
import com.genersoft.iot.vmp.gb28181.session.AudioBroadcastManager;
|
||||||
|
@ -38,6 +37,7 @@ import lombok.extern.slf4j.Slf4j;
|
||||||
import org.springframework.beans.factory.annotation.Autowired;
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
import org.springframework.stereotype.Service;
|
import org.springframework.stereotype.Service;
|
||||||
import org.springframework.transaction.annotation.Transactional;
|
import org.springframework.transaction.annotation.Transactional;
|
||||||
|
import org.springframework.util.Assert;
|
||||||
|
|
||||||
import javax.sip.InvalidArgumentException;
|
import javax.sip.InvalidArgumentException;
|
||||||
import javax.sip.SipException;
|
import javax.sip.SipException;
|
||||||
|
@ -269,6 +269,9 @@ public class DeviceServiceImpl implements IDeviceService {
|
||||||
@Override
|
@Override
|
||||||
public boolean removeCatalogSubscribe(Device device, CommonCallback<Boolean> callback) {
|
public boolean removeCatalogSubscribe(Device device, CommonCallback<Boolean> callback) {
|
||||||
if (device == null || device.getSubscribeCycleForCatalog() < 0) {
|
if (device == null || device.getSubscribeCycleForCatalog() < 0) {
|
||||||
|
if (callback != null) {
|
||||||
|
callback.run(false);
|
||||||
|
}
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
log.info("[移除目录订阅]: {}", device.getDeviceId());
|
log.info("[移除目录订阅]: {}", device.getDeviceId());
|
||||||
|
@ -278,6 +281,16 @@ public class DeviceServiceImpl implements IDeviceService {
|
||||||
if (runnable instanceof ISubscribeTask) {
|
if (runnable instanceof ISubscribeTask) {
|
||||||
ISubscribeTask subscribeTask = (ISubscribeTask) runnable;
|
ISubscribeTask subscribeTask = (ISubscribeTask) runnable;
|
||||||
subscribeTask.stop(callback);
|
subscribeTask.stop(callback);
|
||||||
|
}else {
|
||||||
|
log.info("[移除目录订阅]失败,未找到订阅任务 : {}", device.getDeviceId());
|
||||||
|
if (callback != null) {
|
||||||
|
callback.run(false);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}else {
|
||||||
|
log.info("[移除移动位置订阅]失败,设备已经离线 : {}", device.getDeviceId());
|
||||||
|
if (callback != null) {
|
||||||
|
callback.run(false);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
dynamicTask.stop(taskKey);
|
dynamicTask.stop(taskKey);
|
||||||
|
@ -303,6 +316,9 @@ public class DeviceServiceImpl implements IDeviceService {
|
||||||
@Override
|
@Override
|
||||||
public boolean removeMobilePositionSubscribe(Device device, CommonCallback<Boolean> callback) {
|
public boolean removeMobilePositionSubscribe(Device device, CommonCallback<Boolean> callback) {
|
||||||
if (device == null || device.getSubscribeCycleForCatalog() < 0) {
|
if (device == null || device.getSubscribeCycleForCatalog() < 0) {
|
||||||
|
if (callback != null) {
|
||||||
|
callback.run(false);
|
||||||
|
}
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
log.info("[移除移动位置订阅]: {}", device.getDeviceId());
|
log.info("[移除移动位置订阅]: {}", device.getDeviceId());
|
||||||
|
@ -312,6 +328,16 @@ public class DeviceServiceImpl implements IDeviceService {
|
||||||
if (runnable instanceof ISubscribeTask) {
|
if (runnable instanceof ISubscribeTask) {
|
||||||
ISubscribeTask subscribeTask = (ISubscribeTask) runnable;
|
ISubscribeTask subscribeTask = (ISubscribeTask) runnable;
|
||||||
subscribeTask.stop(callback);
|
subscribeTask.stop(callback);
|
||||||
|
}else {
|
||||||
|
log.info("[移除移动位置订阅]失败,未找到订阅任务 : {}", device.getDeviceId());
|
||||||
|
if (callback != null) {
|
||||||
|
callback.run(false);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}else {
|
||||||
|
log.info("[移除移动位置订阅]失败,设备已经离线 : {}", device.getDeviceId());
|
||||||
|
if (callback != null) {
|
||||||
|
callback.run(false);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
dynamicTask.stop(taskKey);
|
dynamicTask.stop(taskKey);
|
||||||
|
@ -427,64 +453,12 @@ public class DeviceServiceImpl implements IDeviceService {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void updateCustomDevice(Device device) {
|
public void updateCustomDevice(Device device) {
|
||||||
|
// 订阅状态的修改使用一个单独方法控制,此处不再进行状态修改
|
||||||
Device deviceInStore = deviceMapper.query(device.getId());
|
Device deviceInStore = deviceMapper.query(device.getId());
|
||||||
if (deviceInStore == null) {
|
if (deviceInStore == null) {
|
||||||
log.warn("更新设备时未找到设备信息");
|
log.warn("更新设备时未找到设备信息");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
// 目录订阅相关的信息
|
|
||||||
if (deviceInStore.getSubscribeCycleForCatalog() != device.getSubscribeCycleForCatalog()) {
|
|
||||||
if (device.getSubscribeCycleForCatalog() > 0) {
|
|
||||||
// 若已开启订阅,但订阅周期不同,则先取消
|
|
||||||
if (deviceInStore.getSubscribeCycleForCatalog() != 0) {
|
|
||||||
removeCatalogSubscribe(deviceInStore, result->{
|
|
||||||
// 开启订阅
|
|
||||||
deviceInStore.setSubscribeCycleForCatalog(device.getSubscribeCycleForCatalog());
|
|
||||||
addCatalogSubscribe(deviceInStore);
|
|
||||||
// 因为是异步执行,需要在这里更新下数据
|
|
||||||
deviceMapper.updateCustom(deviceInStore);
|
|
||||||
redisCatchStorage.updateDevice(deviceInStore);
|
|
||||||
});
|
|
||||||
}else {
|
|
||||||
// 开启订阅
|
|
||||||
deviceInStore.setSubscribeCycleForCatalog(device.getSubscribeCycleForCatalog());
|
|
||||||
addCatalogSubscribe(deviceInStore);
|
|
||||||
}
|
|
||||||
|
|
||||||
}else if (device.getSubscribeCycleForCatalog() == 0) {
|
|
||||||
// 取消订阅
|
|
||||||
deviceInStore.setSubscribeCycleForCatalog(0);
|
|
||||||
removeCatalogSubscribe(deviceInStore, null);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
// 移动位置订阅相关的信息
|
|
||||||
if (deviceInStore.getSubscribeCycleForMobilePosition() != device.getSubscribeCycleForMobilePosition()) {
|
|
||||||
if (device.getSubscribeCycleForMobilePosition() > 0) {
|
|
||||||
// 若已开启订阅,但订阅周期不同,则先取消
|
|
||||||
if (deviceInStore.getSubscribeCycleForMobilePosition() != 0) {
|
|
||||||
removeMobilePositionSubscribe(deviceInStore, result->{
|
|
||||||
// 开启订阅
|
|
||||||
deviceInStore.setSubscribeCycleForMobilePosition(device.getSubscribeCycleForMobilePosition());
|
|
||||||
deviceInStore.setMobilePositionSubmissionInterval(device.getMobilePositionSubmissionInterval());
|
|
||||||
addMobilePositionSubscribe(deviceInStore);
|
|
||||||
// 因为是异步执行,需要在这里更新下数据
|
|
||||||
deviceMapper.updateCustom(deviceInStore);
|
|
||||||
redisCatchStorage.updateDevice(deviceInStore);
|
|
||||||
});
|
|
||||||
}else {
|
|
||||||
// 开启订阅
|
|
||||||
deviceInStore.setSubscribeCycleForMobilePosition(device.getSubscribeCycleForMobilePosition());
|
|
||||||
deviceInStore.setMobilePositionSubmissionInterval(device.getMobilePositionSubmissionInterval());
|
|
||||||
addMobilePositionSubscribe(deviceInStore);
|
|
||||||
}
|
|
||||||
|
|
||||||
}else if (device.getSubscribeCycleForMobilePosition() == 0) {
|
|
||||||
// 取消订阅
|
|
||||||
deviceInStore.setSubscribeCycleForMobilePosition(0);
|
|
||||||
deviceInStore.setMobilePositionSubmissionInterval(0);
|
|
||||||
removeMobilePositionSubscribe(deviceInStore, null);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (deviceInStore.getGeoCoordSys() != null) {
|
if (deviceInStore.getGeoCoordSys() != null) {
|
||||||
// 坐标系变化,需要重新计算GCJ02坐标和WGS84坐标
|
// 坐标系变化,需要重新计算GCJ02坐标和WGS84坐标
|
||||||
if (!deviceInStore.getGeoCoordSys().equals(device.getGeoCoordSys())) {
|
if (!deviceInStore.getGeoCoordSys().equals(device.getGeoCoordSys())) {
|
||||||
|
@ -553,4 +527,68 @@ public class DeviceServiceImpl implements IDeviceService {
|
||||||
public Device getDeviceBySourceChannelDeviceId(String channelId) {
|
public Device getDeviceBySourceChannelDeviceId(String channelId) {
|
||||||
return deviceMapper.getDeviceBySourceChannelDeviceId(ChannelDataType.GB28181.value,channelId);
|
return deviceMapper.getDeviceBySourceChannelDeviceId(ChannelDataType.GB28181.value,channelId);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void subscribeCatalog(int id, int cycle) {
|
||||||
|
Device device = deviceMapper.query(id);
|
||||||
|
Assert.notNull(device, "未找到设备");
|
||||||
|
if (device.getSubscribeCycleForCatalog() == cycle) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
// 目录订阅相关的信息
|
||||||
|
if (device.getSubscribeCycleForCatalog() > 0) {
|
||||||
|
// 订阅周期不同,则先取消
|
||||||
|
removeCatalogSubscribe(device, result->{
|
||||||
|
device.setSubscribeCycleForCatalog(cycle);
|
||||||
|
if (cycle > 0) {
|
||||||
|
// 开启订阅
|
||||||
|
addCatalogSubscribe(device);
|
||||||
|
}
|
||||||
|
// 因为是异步执行,需要在这里更新下数据
|
||||||
|
deviceMapper.updateSubscribeCatalog(device);
|
||||||
|
redisCatchStorage.updateDevice(device);
|
||||||
|
});
|
||||||
|
}else {
|
||||||
|
// 开启订阅
|
||||||
|
device.setSubscribeCycleForCatalog(cycle);
|
||||||
|
addCatalogSubscribe(device);
|
||||||
|
deviceMapper.updateSubscribeCatalog(device);
|
||||||
|
redisCatchStorage.updateDevice(device);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void subscribeMobilePosition(int id, int cycle, int interval) {
|
||||||
|
Device device = deviceMapper.query(id);
|
||||||
|
Assert.notNull(device, "未找到设备");
|
||||||
|
if (device.getSubscribeCycleForMobilePosition() == cycle) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
// 目录订阅相关的信息
|
||||||
|
if (device.getSubscribeCycleForMobilePosition() > 0) {
|
||||||
|
// 订阅周期已经开启,则先取消
|
||||||
|
removeMobilePositionSubscribe(device, result->{
|
||||||
|
// 开启订阅
|
||||||
|
device.setSubscribeCycleForMobilePosition(cycle);
|
||||||
|
device.setMobilePositionSubmissionInterval(interval);
|
||||||
|
if (cycle > 0) {
|
||||||
|
addMobilePositionSubscribe(device);
|
||||||
|
}
|
||||||
|
// 因为是异步执行,需要在这里更新下数据
|
||||||
|
deviceMapper.updateSubscribeMobilePosition(device);
|
||||||
|
redisCatchStorage.updateDevice(device);
|
||||||
|
});
|
||||||
|
}else {
|
||||||
|
// 订阅未开启
|
||||||
|
device.setSubscribeCycleForMobilePosition(cycle);
|
||||||
|
device.setMobilePositionSubmissionInterval(interval);
|
||||||
|
// 开启订阅
|
||||||
|
addMobilePositionSubscribe(device);
|
||||||
|
// 因为是异步执行,需要在这里更新下数据
|
||||||
|
deviceMapper.updateSubscribeMobilePosition(device);
|
||||||
|
redisCatchStorage.updateDevice(device);
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -4,10 +4,10 @@
|
||||||
<div class="page-title">设备列表</div>
|
<div class="page-title">设备列表</div>
|
||||||
<div class="page-header-btn">
|
<div class="page-header-btn">
|
||||||
搜索:
|
搜索:
|
||||||
<el-input @input="getDeviceList" style="margin-right: 1rem; width: auto;" size="mini" placeholder="关键字"
|
<el-input @input="initData" style="margin-right: 1rem; width: auto;" size="mini" placeholder="关键字"
|
||||||
prefix-icon="el-icon-search" v-model="searchSrt" clearable></el-input>
|
prefix-icon="el-icon-search" v-model="searchSrt" clearable></el-input>
|
||||||
在线状态:
|
在线状态:
|
||||||
<el-select size="mini" style="width: 8rem; margin-right: 1rem;" @change="getDeviceList" v-model="online" placeholder="请选择"
|
<el-select size="mini" style="width: 8rem; margin-right: 1rem;" @change="initData" v-model="online" placeholder="请选择"
|
||||||
default-first-option>
|
default-first-option>
|
||||||
<el-option label="全部" value=""></el-option>
|
<el-option label="全部" value=""></el-option>
|
||||||
<el-option label="在线" value="true"></el-option>
|
<el-option label="在线" value="true"></el-option>
|
||||||
|
@ -22,10 +22,10 @@
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<!--设备列表-->
|
<!--设备列表-->
|
||||||
<el-table size="medium" :data="deviceList" style="width: 100%;font-size: 12px;" :height="winHeight" header-row-class-name="table-header">
|
<el-table size="medium" :data="deviceList" style="width: 100%;font-size: 12px;" :height="winHeight" header-row-class-name="table-header">
|
||||||
<el-table-column prop="name" label="名称" min-width="160">
|
<el-table-column prop="name" label="名称" min-width="160">
|
||||||
</el-table-column>
|
</el-table-column>
|
||||||
<el-table-column prop="deviceId" label="设备编号" min-width="200" >
|
<el-table-column prop="deviceId" label="设备编号" min-width="160" >
|
||||||
</el-table-column>
|
</el-table-column>
|
||||||
<el-table-column label="地址" min-width="160" >
|
<el-table-column label="地址" min-width="160" >
|
||||||
<template v-slot:default="scope">
|
<template v-slot:default="scope">
|
||||||
|
@ -35,9 +35,9 @@
|
||||||
</div>
|
</div>
|
||||||
</template>
|
</template>
|
||||||
</el-table-column>
|
</el-table-column>
|
||||||
<el-table-column prop="manufacturer" label="厂家" min-width="120" >
|
<el-table-column prop="manufacturer" label="厂家" min-width="100" >
|
||||||
</el-table-column>
|
</el-table-column>
|
||||||
<el-table-column prop="transport" label="信令传输模式" min-width="120" >
|
<el-table-column prop="transport" label="信令传输模式" min-width="100" >
|
||||||
</el-table-column>
|
</el-table-column>
|
||||||
<el-table-column label="流传输模式" min-width="160" >
|
<el-table-column label="流传输模式" min-width="160" >
|
||||||
<template v-slot:default="scope">
|
<template v-slot:default="scope">
|
||||||
|
@ -48,9 +48,12 @@
|
||||||
</el-select>
|
</el-select>
|
||||||
</template>
|
</template>
|
||||||
</el-table-column>
|
</el-table-column>
|
||||||
<el-table-column prop="channelCount" label="通道数" min-width="120" >
|
<el-table-column label="通道数" min-width="100" >
|
||||||
|
<template v-slot:default="scope">
|
||||||
|
<span style="font-size: 1rem">{{scope.row.channelCount}}</span>
|
||||||
|
</template>
|
||||||
</el-table-column>
|
</el-table-column>
|
||||||
<el-table-column label="状态" min-width="120">
|
<el-table-column label="状态" min-width="100">
|
||||||
<template v-slot:default="scope">
|
<template v-slot:default="scope">
|
||||||
<div slot="reference" class="name-wrapper">
|
<div slot="reference" class="name-wrapper">
|
||||||
<el-tag size="medium" v-if="scope.row.onLine && serverId !== scope.row.serverId" style="border-color: #ecf1af">在线</el-tag>
|
<el-tag size="medium" v-if="scope.row.onLine && serverId !== scope.row.serverId" style="border-color: #ecf1af">在线</el-tag>
|
||||||
|
@ -59,13 +62,20 @@
|
||||||
</div>
|
</div>
|
||||||
</template>
|
</template>
|
||||||
</el-table-column>
|
</el-table-column>
|
||||||
<el-table-column prop="keepaliveTime" label="最近心跳" min-width="160" >
|
<el-table-column label="订阅" min-width="260" >
|
||||||
</el-table-column>
|
|
||||||
<el-table-column prop="registerTime" label="最近注册" min-width="160">
|
|
||||||
</el-table-column>
|
|
||||||
<el-table-column label="操作" min-width="380" fixed="right">
|
|
||||||
<template v-slot:default="scope">
|
<template v-slot:default="scope">
|
||||||
<el-button type="text" size="medium" v-bind:disabled="scope.row.online==0" icon="el-icon-refresh" @click="refDevice(scope.row)"
|
<el-checkbox label="目录" :checked="scope.row.subscribeCycleForCatalog > 0" @change="(e)=>subscribeForCatalog(scope.row.id, e)"></el-checkbox>
|
||||||
|
<el-checkbox label="位置" :checked="scope.row.subscribeCycleForMobilePosition > 0" @change="(e)=>subscribeForMobilePosition(scope.row.id, e)"></el-checkbox>
|
||||||
|
<el-checkbox label="报警" disabled :checked="scope.row.subscribeCycleForAlarm > 0"></el-checkbox>
|
||||||
|
</template>
|
||||||
|
</el-table-column>
|
||||||
|
<el-table-column prop="keepaliveTime" label="最近心跳" min-width="140" >
|
||||||
|
</el-table-column>
|
||||||
|
<el-table-column prop="registerTime" label="最近注册" min-width="140">
|
||||||
|
</el-table-column>
|
||||||
|
<el-table-column label="操作" min-width="300" fixed="right">
|
||||||
|
<template v-slot:default="scope">
|
||||||
|
<el-button type="text" size="medium" v-bind:disabled="scope.row.online===0" icon="el-icon-refresh" @click="refDevice(scope.row)"
|
||||||
@mouseover="getTooltipContent(scope.row.deviceId)">刷新
|
@mouseover="getTooltipContent(scope.row.deviceId)">刷新
|
||||||
</el-button>
|
</el-button>
|
||||||
<el-divider direction="vertical"></el-divider>
|
<el-divider direction="vertical"></el-divider>
|
||||||
|
@ -75,13 +85,13 @@
|
||||||
<el-divider direction="vertical"></el-divider>
|
<el-divider direction="vertical"></el-divider>
|
||||||
<el-button size="medium" icon="el-icon-edit" type="text" @click="edit(scope.row)">编辑</el-button>
|
<el-button size="medium" icon="el-icon-edit" type="text" @click="edit(scope.row)">编辑</el-button>
|
||||||
<el-divider direction="vertical"></el-divider>
|
<el-divider direction="vertical"></el-divider>
|
||||||
<el-button size="medium" icon="el-icon-delete" type="text" @click="deleteDevice(scope.row)" style="color: #f56c6c">删除</el-button>
|
|
||||||
<el-divider direction="vertical"></el-divider>
|
|
||||||
<el-dropdown @command="(command)=>{moreClick(command, scope.row)}">
|
<el-dropdown @command="(command)=>{moreClick(command, scope.row)}">
|
||||||
<el-button size="medium" type="text" >
|
<el-button size="medium" type="text" >
|
||||||
操作<i class="el-icon-arrow-down el-icon--right"></i>
|
操作<i class="el-icon-arrow-down el-icon--right"></i>
|
||||||
</el-button>
|
</el-button>
|
||||||
<el-dropdown-menu slot="dropdown">
|
<el-dropdown-menu>
|
||||||
|
<el-dropdown-item command="delete" style="color: #f56c6c">
|
||||||
|
删除</el-dropdown-item>
|
||||||
<el-dropdown-item command="setGuard" v-bind:disabled="!scope.row.onLine">
|
<el-dropdown-item command="setGuard" v-bind:disabled="!scope.row.onLine">
|
||||||
布防</el-dropdown-item>
|
布防</el-dropdown-item>
|
||||||
<el-dropdown-item command="resetGuard" v-bind:disabled="!scope.row.onLine">
|
<el-dropdown-item command="resetGuard" v-bind:disabled="!scope.row.onLine">
|
||||||
|
@ -161,6 +171,8 @@ export default {
|
||||||
},
|
},
|
||||||
methods: {
|
methods: {
|
||||||
initData: function () {
|
initData: function () {
|
||||||
|
this.currentPage = 1;
|
||||||
|
this.total= 0;
|
||||||
// 获取平台信息
|
// 获取平台信息
|
||||||
this.showInfo(false)
|
this.showInfo(false)
|
||||||
this.getDeviceList();
|
this.getDeviceList();
|
||||||
|
@ -346,6 +358,8 @@ export default {
|
||||||
this.setGuard(itemData)
|
this.setGuard(itemData)
|
||||||
}else if (command === "resetGuard") {
|
}else if (command === "resetGuard") {
|
||||||
this.resetGuard(itemData)
|
this.resetGuard(itemData)
|
||||||
|
}else if (command === "delete") {
|
||||||
|
this.deleteDevice(itemData)
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
setGuard: function (itemData) {
|
setGuard: function (itemData) {
|
||||||
|
@ -394,6 +408,67 @@ export default {
|
||||||
})
|
})
|
||||||
});
|
});
|
||||||
},
|
},
|
||||||
|
subscribeForCatalog: function (data, value) {
|
||||||
|
console.log(data)
|
||||||
|
console.log(value)
|
||||||
|
this.$axios({
|
||||||
|
method: 'get',
|
||||||
|
url: `/api/device/query/subscribe/catalog`,
|
||||||
|
params: {
|
||||||
|
id: data,
|
||||||
|
cycle: value?60:0
|
||||||
|
}
|
||||||
|
}).then( (res)=> {
|
||||||
|
if (res.data.code === 0) {
|
||||||
|
this.$message.success({
|
||||||
|
showClose: true,
|
||||||
|
message: value?"订阅成功":"取消订阅成功"
|
||||||
|
})
|
||||||
|
}else {
|
||||||
|
this.$message.error({
|
||||||
|
showClose: true,
|
||||||
|
message: res.data.msg
|
||||||
|
})
|
||||||
|
}
|
||||||
|
}).catch( (error)=> {
|
||||||
|
this.$message.error({
|
||||||
|
showClose: true,
|
||||||
|
message: error.message
|
||||||
|
})
|
||||||
|
});
|
||||||
|
|
||||||
|
},
|
||||||
|
subscribeForMobilePosition: function (data, value) {
|
||||||
|
console.log(data)
|
||||||
|
console.log(value)
|
||||||
|
this.$axios({
|
||||||
|
method: 'get',
|
||||||
|
url: `/api/device/query/subscribe/mobile-position`,
|
||||||
|
params: {
|
||||||
|
id: data,
|
||||||
|
cycle: value?60:0,
|
||||||
|
interval: value?5:0
|
||||||
|
}
|
||||||
|
}).then( (res)=> {
|
||||||
|
if (res.data.code === 0) {
|
||||||
|
this.$message.success({
|
||||||
|
showClose: true,
|
||||||
|
message: value?"订阅成功":"取消订阅成功"
|
||||||
|
})
|
||||||
|
}else {
|
||||||
|
this.$message.error({
|
||||||
|
showClose: true,
|
||||||
|
message: res.data.msg
|
||||||
|
})
|
||||||
|
}
|
||||||
|
}).catch( (error)=> {
|
||||||
|
this.$message.error({
|
||||||
|
showClose: true,
|
||||||
|
message: error.message
|
||||||
|
})
|
||||||
|
});
|
||||||
|
|
||||||
|
},
|
||||||
|
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
|
@ -64,7 +64,7 @@
|
||||||
<el-button size="mini">
|
<el-button size="mini">
|
||||||
倍速 <i class="el-icon-arrow-down el-icon--right"></i>
|
倍速 <i class="el-icon-arrow-down el-icon--right"></i>
|
||||||
</el-button>
|
</el-button>
|
||||||
<el-dropdown-menu slot="dropdown">
|
<el-dropdown-menu>
|
||||||
<el-dropdown-item command="0.25">0.25倍速</el-dropdown-item>
|
<el-dropdown-item command="0.25">0.25倍速</el-dropdown-item>
|
||||||
<el-dropdown-item command="0.5">0.5倍速</el-dropdown-item>
|
<el-dropdown-item command="0.5">0.5倍速</el-dropdown-item>
|
||||||
<el-dropdown-item command="1.0">1倍速</el-dropdown-item>
|
<el-dropdown-item command="1.0">1倍速</el-dropdown-item>
|
||||||
|
|
|
@ -141,7 +141,7 @@
|
||||||
<el-button size="medium" type="text" >
|
<el-button size="medium" type="text" >
|
||||||
更多<i class="el-icon-arrow-down el-icon--right"></i>
|
更多<i class="el-icon-arrow-down el-icon--right"></i>
|
||||||
</el-button>
|
</el-button>
|
||||||
<el-dropdown-menu slot="dropdown">
|
<el-dropdown-menu>
|
||||||
<el-dropdown-item command="records" v-bind:disabled="device == null || device.online === 0">
|
<el-dropdown-item command="records" v-bind:disabled="device == null || device.online === 0">
|
||||||
设备录像</el-dropdown-item>
|
设备录像</el-dropdown-item>
|
||||||
<el-dropdown-item command="cloudRecords" v-bind:disabled="device == null || device.online === 0" >
|
<el-dropdown-item command="cloudRecords" v-bind:disabled="device == null || device.online === 0" >
|
||||||
|
|
|
@ -43,21 +43,6 @@
|
||||||
<el-option key="UTF-8" label="UTF-8" value="utf-8"></el-option>
|
<el-option key="UTF-8" label="UTF-8" value="utf-8"></el-option>
|
||||||
</el-select>
|
</el-select>
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
<!-- <el-form-item label="地理坐标系" prop="geoCoordSys" >-->
|
|
||||||
<!-- <el-select v-model="form.geoCoordSys" style="float: left; width: 100%" >-->
|
|
||||||
<!-- <el-option key="WGS84" label="WGS84" value="WGS84"></el-option>-->
|
|
||||||
<!-- <el-option key="GCJ02" label="GCJ02" value="GCJ02"></el-option>-->
|
|
||||||
<!-- </el-select>-->
|
|
||||||
<!-- </el-form-item>-->
|
|
||||||
<el-form-item v-if="this.isEdit" label="目录订阅" title="0为取消订阅" prop="subscribeCycleForCatalog" >
|
|
||||||
<el-input v-model="form.subscribeCycleForCatalog" clearable ></el-input>
|
|
||||||
</el-form-item>
|
|
||||||
<el-form-item v-if="this.isEdit" label="移动位置订阅" title="0为取消订阅" prop="subscribeCycleForCatalog" >
|
|
||||||
<el-input v-model="form.subscribeCycleForMobilePosition" clearable ></el-input>
|
|
||||||
</el-form-item>
|
|
||||||
<el-form-item v-if="form.subscribeCycleForMobilePosition > 0" label="移动位置报送间隔" prop="subscribeCycleForCatalog" >
|
|
||||||
<el-input v-model="form.mobilePositionSubmissionInterval" clearable ></el-input>
|
|
||||||
</el-form-item>
|
|
||||||
<el-form-item label="其他选项">
|
<el-form-item label="其他选项">
|
||||||
<el-checkbox label="SSRC校验" v-model="form.ssrcCheck" style="float: left"></el-checkbox>
|
<el-checkbox label="SSRC校验" v-model="form.ssrcCheck" style="float: left"></el-checkbox>
|
||||||
<el-checkbox label="作为消息通道" v-model="form.asMessageChannel" style="float: left"></el-checkbox>
|
<el-checkbox label="作为消息通道" v-model="form.asMessageChannel" style="float: left"></el-checkbox>
|
||||||
|
@ -122,12 +107,6 @@ export default {
|
||||||
onSubmit: function () {
|
onSubmit: function () {
|
||||||
console.log("onSubmit");
|
console.log("onSubmit");
|
||||||
console.log(this.form);
|
console.log(this.form);
|
||||||
this.form.subscribeCycleForCatalog = this.form.subscribeCycleForCatalog||0
|
|
||||||
this.form.subscribeCycleForMobilePosition = this.form.subscribeCycleForMobilePosition||0
|
|
||||||
this.form.mobilePositionSubmissionInterval = this.form.mobilePositionSubmissionInterval||0
|
|
||||||
if (this.form.mobilePositionSubmissionInterval === 0) {
|
|
||||||
this.form.mobilePositionSubmissionInterval = 5
|
|
||||||
}
|
|
||||||
this.$axios({
|
this.$axios({
|
||||||
method: 'post',
|
method: 'post',
|
||||||
url:`/api/device/query/device/${this.isEdit?'update':'add'}/`,
|
url:`/api/device/query/device/${this.isEdit?'update':'add'}/`,
|
||||||
|
|
|
@ -57,7 +57,7 @@
|
||||||
<el-button>
|
<el-button>
|
||||||
更多地址<i class="el-icon-arrow-down el-icon--right"></i>
|
更多地址<i class="el-icon-arrow-down el-icon--right"></i>
|
||||||
</el-button>
|
</el-button>
|
||||||
<el-dropdown-menu slot="dropdown">
|
<el-dropdown-menu>
|
||||||
<el-dropdown-item v-if="streamInfo.flv" :command="streamInfo.flv">
|
<el-dropdown-item v-if="streamInfo.flv" :command="streamInfo.flv">
|
||||||
<el-tag>FLV:</el-tag>
|
<el-tag>FLV:</el-tag>
|
||||||
<span>{{ streamInfo.flv }}</span>
|
<span>{{ streamInfo.flv }}</span>
|
||||||
|
|
Loading…
Reference in New Issue