临时提交
parent
15f44b0d23
commit
e46ad4e66a
|
@ -63,13 +63,7 @@ public class StreamProxy extends CommonGBChannel {
|
||||||
private String streamKey;
|
private String streamKey;
|
||||||
|
|
||||||
@Schema(description = "拉流状态")
|
@Schema(description = "拉流状态")
|
||||||
private Boolean status;
|
private Boolean pulling;
|
||||||
|
|
||||||
@Schema(description = "更新时间")
|
|
||||||
private String updateTime;
|
|
||||||
|
|
||||||
@Schema(description = "创建时间")
|
|
||||||
private String createTime;
|
|
||||||
|
|
||||||
public CommonGBChannel buildCommonGBChannel() {
|
public CommonGBChannel buildCommonGBChannel() {
|
||||||
if (ObjectUtils.isEmpty(this.getGbDeviceId())) {
|
if (ObjectUtils.isEmpty(this.getGbDeviceId())) {
|
||||||
|
|
|
@ -44,15 +44,18 @@ public class StreamProxyController {
|
||||||
@Parameter(name = "page", description = "当前页")
|
@Parameter(name = "page", description = "当前页")
|
||||||
@Parameter(name = "count", description = "每页查询数量")
|
@Parameter(name = "count", description = "每页查询数量")
|
||||||
@Parameter(name = "query", description = "查询内容")
|
@Parameter(name = "query", description = "查询内容")
|
||||||
@Parameter(name = "online", description = "是否在线")
|
@Parameter(name = "query", description = "查询内容")
|
||||||
|
@Parameter(name = "pulling", description = "是否正在拉流")
|
||||||
|
@Parameter(name = "mediaServerId", description = "流媒体ID")
|
||||||
@GetMapping(value = "/list")
|
@GetMapping(value = "/list")
|
||||||
@ResponseBody
|
@ResponseBody
|
||||||
public PageInfo<StreamProxy> list(@RequestParam(required = false)Integer page,
|
public PageInfo<StreamProxy> list(@RequestParam(required = false)Integer page,
|
||||||
@RequestParam(required = false)Integer count,
|
@RequestParam(required = false)Integer count,
|
||||||
@RequestParam(required = false)String query,
|
@RequestParam(required = false)String query,
|
||||||
@RequestParam(required = false)Boolean online ){
|
@RequestParam(required = false)Boolean pulling,
|
||||||
|
@RequestParam(required = false)String mediaServerId){
|
||||||
|
|
||||||
return streamProxyService.getAll(page, count);
|
return streamProxyService.getAll(page, count, query, pulling, mediaServerId);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Operation(summary = "查询流代理", security = @SecurityRequirement(name = JwtUtils.HEADER))
|
@Operation(summary = "查询流代理", security = @SecurityRequirement(name = JwtUtils.HEADER))
|
||||||
|
@ -65,7 +68,7 @@ public class StreamProxyController {
|
||||||
return streamProxyService.getStreamProxyByAppAndStream(app, stream);
|
return streamProxyService.getStreamProxyByAppAndStream(app, stream);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Operation(summary = "保存代理", security = @SecurityRequirement(name = JwtUtils.HEADER), parameters = {
|
@Operation(summary = "保存代理(已存在会覆盖)", security = @SecurityRequirement(name = JwtUtils.HEADER), parameters = {
|
||||||
@Parameter(name = "param", description = "代理参数", required = true),
|
@Parameter(name = "param", description = "代理参数", required = true),
|
||||||
})
|
})
|
||||||
@PostMapping(value = "/save")
|
@PostMapping(value = "/save")
|
||||||
|
@ -99,6 +102,40 @@ public class StreamProxyController {
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Operation(summary = "新增代理", security = @SecurityRequirement(name = JwtUtils.HEADER), parameters = {
|
||||||
|
@Parameter(name = "param", description = "代理参数", required = true),
|
||||||
|
})
|
||||||
|
@PostMapping(value = "/add")
|
||||||
|
@ResponseBody
|
||||||
|
public StreamContent add(@RequestBody StreamProxy param){
|
||||||
|
log.info("添加代理: " + JSONObject.toJSONString(param));
|
||||||
|
if (ObjectUtils.isEmpty(param.getMediaServerId())) {
|
||||||
|
param.setMediaServerId("auto");
|
||||||
|
}
|
||||||
|
if (ObjectUtils.isEmpty(param.getType())) {
|
||||||
|
param.setType("default");
|
||||||
|
}
|
||||||
|
if (ObjectUtils.isEmpty(param.getGbId())) {
|
||||||
|
param.setGbDeviceId(null);
|
||||||
|
}
|
||||||
|
StreamProxy streamProxyItem = streamProxyService.getStreamProxyByAppAndStream(param.getApp(), param.getStream());
|
||||||
|
if (streamProxyItem != null) {
|
||||||
|
streamProxyService.del(param.getApp(), param.getStream());
|
||||||
|
}
|
||||||
|
|
||||||
|
StreamInfo streamInfo = streamProxyService.add(param);
|
||||||
|
if (param.isEnable()) {
|
||||||
|
if (streamInfo == null) {
|
||||||
|
throw new ControllerException(ErrorCode.ERROR100.getCode(), ErrorCode.ERROR100.getMsg());
|
||||||
|
}else {
|
||||||
|
return new StreamContent(streamInfo);
|
||||||
|
}
|
||||||
|
}else {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
@GetMapping(value = "/ffmpeg_cmd/list")
|
@GetMapping(value = "/ffmpeg_cmd/list")
|
||||||
@ResponseBody
|
@ResponseBody
|
||||||
@Operation(summary = "获取ffmpeg.cmd模板", security = @SecurityRequirement(name = JwtUtils.HEADER))
|
@Operation(summary = "获取ffmpeg.cmd模板", security = @SecurityRequirement(name = JwtUtils.HEADER))
|
||||||
|
|
|
@ -11,81 +11,86 @@ import java.util.List;
|
||||||
@Repository
|
@Repository
|
||||||
public interface StreamProxyMapper {
|
public interface StreamProxyMapper {
|
||||||
|
|
||||||
@Insert("INSERT INTO wvp_stream_proxy (type, name, app, stream,media_server_id, url, src_url, dst_url, " +
|
@Insert("INSERT INTO wvp_stream_proxy (type, name, app, stream,media_server_id, src_url, " +
|
||||||
"timeout_ms, ffmpeg_cmd_key, rtp_type, enable_audio, enable_mp4, enable, status, stream_key, enable_remove_none_reader, enable_disable_none_reader, create_time) VALUES" +
|
"timeout, ffmpeg_cmd_key, rtsp_type, enable_audio, enable_mp4, enable, pulling, stream_key, " +
|
||||||
"(#{type}, #{name}, #{app}, #{stream}, #{mediaServerId}, #{url}, #{srcUrl}, #{dstUrl}, " +
|
"enable_remove_none_reader, enable_disable_none_reader, create_time) VALUES" +
|
||||||
"#{timeoutMs}, #{ffmpegCmdKey}, #{rtpType}, #{enableAudio}, #{enableMp4}, #{enable}, #{status}, #{streamKey}, " +
|
"(#{type}, #{name}, #{app}, #{stream}, #{mediaServerId}, #{srcUrl}, " +
|
||||||
|
"#{timeout}, #{ffmpegCmdKey}, #{rtspType}, #{enableAudio}, #{enableMp4}, #{enable}, #{pulling}, #{streamKey}, " +
|
||||||
"#{enableRemoveNoneReader}, #{enableDisableNoneReader}, #{createTime} )")
|
"#{enableRemoveNoneReader}, #{enableDisableNoneReader}, #{createTime} )")
|
||||||
|
@Options(useGeneratedKeys = true, keyProperty = "id", keyColumn = "id")
|
||||||
int add(StreamProxy streamProxyDto);
|
int add(StreamProxy streamProxyDto);
|
||||||
|
|
||||||
@Update("UPDATE wvp_stream_proxy " +
|
@Update("UPDATE wvp_stream_proxy " +
|
||||||
"SET type=#{type}, " +
|
"SET type=#{type}, " +
|
||||||
|
"app=#{app}," +
|
||||||
|
"stream=#{stream}," +
|
||||||
"name=#{name}," +
|
"name=#{name}," +
|
||||||
"app=#{app}," +
|
"app=#{app}," +
|
||||||
"stream=#{stream}," +
|
"stream=#{stream}," +
|
||||||
"url=#{url}, " +
|
"url=#{url}, " +
|
||||||
"media_server_id=#{mediaServerId}, " +
|
"media_server_id=#{mediaServerId}, " +
|
||||||
"src_url=#{srcUrl}," +
|
"src_url=#{srcUrl}," +
|
||||||
"dst_url=#{dstUrl}, " +
|
"timeout=#{timeout}, " +
|
||||||
"timeout_ms=#{timeoutMs}, " +
|
|
||||||
"ffmpeg_cmd_key=#{ffmpegCmdKey}, " +
|
"ffmpeg_cmd_key=#{ffmpegCmdKey}, " +
|
||||||
"rtp_type=#{rtpType}, " +
|
"rtsp_type=#{rtspType}, " +
|
||||||
"enable_audio=#{enableAudio}, " +
|
"enable_audio=#{enableAudio}, " +
|
||||||
"enable=#{enable}, " +
|
"enable=#{enable}, " +
|
||||||
"status=#{status}, " +
|
"pulling=#{pulling}, " +
|
||||||
"stream_key=#{streamKey}, " +
|
"stream_key=#{streamKey}, " +
|
||||||
"enable_remove_none_reader=#{enableRemoveNoneReader}, " +
|
"enable_remove_none_reader=#{enableRemoveNoneReader}, " +
|
||||||
"enable_disable_none_reader=#{enableDisableNoneReader}, " +
|
"enable_disable_none_reader=#{enableDisableNoneReader}, " +
|
||||||
"enable_mp4=#{enableMp4} " +
|
"enable_mp4=#{enableMp4} " +
|
||||||
"WHERE app=#{app} AND stream=#{stream}")
|
"WHERE id=#{id}")
|
||||||
int update(StreamProxy streamProxyDto);
|
int update(StreamProxy streamProxyDto);
|
||||||
|
|
||||||
@Delete("DELETE FROM wvp_stream_proxy WHERE app=#{app} AND stream=#{stream}")
|
@Delete("DELETE FROM wvp_stream_proxy WHERE app=#{app} AND stream=#{stream}")
|
||||||
int del(String app, String stream);
|
int delByAppAndStream(String app, String stream);
|
||||||
|
|
||||||
@Select("SELECT st.*, pgs.gb_id, pgs.name, pgs.longitude, pgs.latitude FROM wvp_stream_proxy st LEFT join wvp_gb_stream pgs on st.app = pgs.app AND st.stream = pgs.stream order by st.create_time desc")
|
@Select("SELECT " +
|
||||||
List<StreamProxy> selectAll();
|
" st.*, " +
|
||||||
|
" st.id as stream_proxy_id, " +
|
||||||
|
" wdc.*, " +
|
||||||
|
" wdc.id as gb_id" +
|
||||||
|
" FROM wvp_stream_proxy st " +
|
||||||
|
" LEFT join wvp_device_channel wdc " +
|
||||||
|
" on st.id = wdc.stream_proxy_id " +
|
||||||
|
" WHERE " +
|
||||||
|
" 1=1 " +
|
||||||
|
" <if test='query != null'> AND (st.app LIKE concat('%',#{query},'%') OR st.stream LIKE concat('%',#{query},'%') " +
|
||||||
|
" OR wdc.gb_device_id LIKE concat('%',#{query},'%') OR wdc.gb_name LIKE concat('%',#{query},'%'))</if> " +
|
||||||
|
" <if test='pulling == true' > AND st.pulling=1</if>" +
|
||||||
|
" <if test='pulling == false' > AND st.pulling=0 </if>" +
|
||||||
|
" <if test='mediaServerId != null' > AND st.media_server_id=#{mediaServerId} </if>" +
|
||||||
|
"order by st.create_time desc")
|
||||||
|
List<StreamProxy> selectAll(@Param("query") String query, @Param("pushing") Boolean pushing, @Param("mediaServerId") String mediaServerId);
|
||||||
|
|
||||||
@Select("SELECT st.*, pgs.gb_id, pgs.name, pgs.longitude, pgs.latitude, 'proxy' as streamType FROM wvp_stream_proxy st LEFT join wvp_gb_stream pgs on st.app = pgs.app AND st.stream = pgs.stream WHERE st.enable=#{enable} order by st.create_time desc")
|
@Select("SELECT " +
|
||||||
List<StreamProxy> selectForEnable(boolean enable);
|
" st.*, " +
|
||||||
|
" st.id as stream_proxy_id, " +
|
||||||
|
" wdc.*, " +
|
||||||
|
" wdc.id as gb_id" +
|
||||||
|
" FROM wvp_stream_proxy st " +
|
||||||
|
" LEFT join wvp_device_channel wdc " +
|
||||||
|
" on st.id = wdc.stream_proxy_id " +
|
||||||
|
" WHERE st.app=#{app} AND st.stream=#{stream} order by st.create_time desc")
|
||||||
|
StreamProxy selectOneByAppAndStream(@Param("app") String app, @Param("stream") String stream);
|
||||||
|
|
||||||
@Select("SELECT st.*, pgs.gb_id, pgs.name, pgs.longitude, pgs.latitude FROM wvp_stream_proxy st LEFT join wvp_gb_stream pgs on st.app = pgs.app AND st.stream = pgs.stream WHERE st.app=#{app} AND st.stream=#{stream} order by st.create_time desc")
|
@Select("SELECT " +
|
||||||
StreamProxy selectOne(@Param("app") String app, @Param("stream") String stream);
|
" st.*, " +
|
||||||
|
" st.id as stream_proxy_id, " +
|
||||||
@Select("SELECT st.*, pgs.gb_id, pgs.name, pgs.longitude, pgs.latitude FROM wvp_stream_proxy st " +
|
" wdc.*, " +
|
||||||
"LEFT join wvp_gb_stream pgs on st.app = pgs.app AND st.stream = pgs.stream " +
|
" wdc.id as gb_id" +
|
||||||
|
" FROM wvp_stream_proxy st " +
|
||||||
|
" LEFT join wvp_device_channel wdc " +
|
||||||
|
" on st.id = wdc.stream_proxy_id " +
|
||||||
"WHERE st.enable=#{enable} and st.media_server_id= #{id} order by st.create_time desc")
|
"WHERE st.enable=#{enable} and st.media_server_id= #{id} order by st.create_time desc")
|
||||||
List<StreamProxy> selectForEnableInMediaServer(@Param("id") String id, @Param("enable") boolean enable);
|
List<StreamProxy> selectForEnableInMediaServer(@Param("id") String id, @Param("enable") boolean enable);
|
||||||
|
|
||||||
@Select("SELECT st.*, pgs.gb_id, pgs.name, pgs.longitude, pgs.latitude FROM wvp_stream_proxy st " +
|
|
||||||
"LEFT join wvp_gb_stream pgs on st.app = pgs.app AND st.stream = pgs.stream " +
|
|
||||||
"WHERE st.media_server_id= #{id} order by st.create_time desc")
|
|
||||||
List<StreamProxy> selectInMediaServer(String id);
|
|
||||||
|
|
||||||
@Update("UPDATE wvp_stream_proxy " +
|
|
||||||
"SET status=#{status} " +
|
|
||||||
"WHERE media_server_id=#{mediaServerId}")
|
|
||||||
void updateStatusByMediaServerId(@Param("mediaServerId") String mediaServerId, @Param("status") boolean status);
|
|
||||||
|
|
||||||
@Update("UPDATE wvp_stream_proxy " +
|
|
||||||
"SET status=#{status} " +
|
|
||||||
"WHERE app=#{app} AND stream=#{stream}")
|
|
||||||
int updateStatus(@Param("app") String app, @Param("stream") String stream, @Param("status") boolean status);
|
|
||||||
|
|
||||||
@Delete("DELETE FROM wvp_stream_proxy WHERE enable_remove_none_reader=true AND media_server_id=#{mediaServerId}")
|
|
||||||
void deleteAutoRemoveItemByMediaServerId(String mediaServerId);
|
|
||||||
|
|
||||||
@Select("SELECT st.*, pgs.gb_id, pgs.name, pgs.longitude, pgs.latitude FROM wvp_stream_proxy st LEFT join wvp_gb_stream pgs on st.app = pgs.app AND st.stream = pgs.stream WHERE st.enable_remove_none_reader=true AND st.media_server_id=#{mediaServerId} order by st.create_time desc")
|
|
||||||
List<StreamProxy> selectAutoRemoveItemByMediaServerId(String mediaServerId);
|
|
||||||
|
|
||||||
@Select("select count(1) as total, sum(status) as online from wvp_stream_proxy")
|
|
||||||
ResourceBaseInfo getOverview();
|
|
||||||
|
|
||||||
@Select("select count(1) from wvp_stream_proxy")
|
@Select("select count(1) from wvp_stream_proxy")
|
||||||
|
|
||||||
int getAllCount();
|
int getAllCount();
|
||||||
|
|
||||||
@Select("select count(1) from wvp_stream_proxy where status = true")
|
@Select("select count(1) from wvp_stream_proxy where pulling = true")
|
||||||
int getOnline();
|
int getOnline();
|
||||||
|
|
||||||
@Delete("DELETE FROM wvp_stream_proxy WHERE id=#{id}")
|
@Delete("DELETE FROM wvp_stream_proxy WHERE id=#{id}")
|
||||||
|
@ -101,12 +106,12 @@ public interface StreamProxyMapper {
|
||||||
void deleteByList(List<StreamProxy> streamProxiesForRemove);
|
void deleteByList(List<StreamProxy> streamProxiesForRemove);
|
||||||
|
|
||||||
@Update("UPDATE wvp_stream_proxy " +
|
@Update("UPDATE wvp_stream_proxy " +
|
||||||
"SET status=true " +
|
"SET pulling=true " +
|
||||||
"WHERE id=#{id}")
|
"WHERE id=#{id}")
|
||||||
int online(@Param("id") int id);
|
int online(@Param("id") int id);
|
||||||
|
|
||||||
@Update("UPDATE wvp_stream_proxy " +
|
@Update("UPDATE wvp_stream_proxy " +
|
||||||
"SET status=false " +
|
"SET pulling=false " +
|
||||||
"WHERE id=#{id}")
|
"WHERE id=#{id}")
|
||||||
int offline(@Param("id") int id);
|
int offline(@Param("id") int id);
|
||||||
}
|
}
|
||||||
|
|
|
@ -22,7 +22,7 @@ public interface IStreamProxyService {
|
||||||
* @param count
|
* @param count
|
||||||
* @return
|
* @return
|
||||||
*/
|
*/
|
||||||
PageInfo<StreamProxy> getAll(Integer page, Integer count);
|
PageInfo<StreamProxy> getAll(Integer page, Integer count, String query, Boolean pulling,String mediaServerId);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 删除视频代理
|
* 删除视频代理
|
||||||
|
@ -96,4 +96,5 @@ public interface IStreamProxyService {
|
||||||
*/
|
*/
|
||||||
ResourceBaseInfo getOverview();
|
ResourceBaseInfo getOverview();
|
||||||
|
|
||||||
|
StreamInfo add(StreamProxy streamProxy);
|
||||||
}
|
}
|
||||||
|
|
|
@ -144,7 +144,7 @@ public class StreamProxyServiceImpl implements IStreamProxyService {
|
||||||
streamProxy.setMediaServerId(mediaServer.getId());
|
streamProxy.setMediaServerId(mediaServer.getId());
|
||||||
boolean saveResult;
|
boolean saveResult;
|
||||||
// 更新
|
// 更新
|
||||||
if (streamProxyMapper.selectOne(streamProxy.getApp(), streamProxy.getStream()) != null) {
|
if (streamProxyMapper.selectOneByAppAndStream(streamProxy.getApp(), streamProxy.getStream()) != null) {
|
||||||
saveResult = updateStreamProxy(streamProxy);
|
saveResult = updateStreamProxy(streamProxy);
|
||||||
}else { // 新增
|
}else { // 新增
|
||||||
saveResult = addStreamProxy(streamProxy);
|
saveResult = addStreamProxy(streamProxy);
|
||||||
|
@ -192,16 +192,16 @@ public class StreamProxyServiceImpl implements IStreamProxyService {
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public PageInfo<StreamProxy> getAll(Integer page, Integer count) {
|
public PageInfo<StreamProxy> getAll(Integer page, Integer count, String query, Boolean pulling,String mediaServerId) {
|
||||||
PageHelper.startPage(page, count);
|
PageHelper.startPage(page, count);
|
||||||
List<StreamProxy> all = streamProxyMapper.selectAll();
|
List<StreamProxy> all = streamProxyMapper.selectAll(query, pulling, mediaServerId);
|
||||||
return new PageInfo<>(all);
|
return new PageInfo<>(all);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@Transactional
|
@Transactional
|
||||||
public void del(String app, String stream) {
|
public void del(String app, String stream) {
|
||||||
StreamProxy streamProxy = streamProxyMapper.selectOne(app, stream);
|
StreamProxy streamProxy = streamProxyMapper.selectOneByAppAndStream(app, stream);
|
||||||
if (streamProxy == null) {
|
if (streamProxy == null) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -219,7 +219,7 @@ public class StreamProxyServiceImpl implements IStreamProxyService {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean start(String app, String stream) {
|
public boolean start(String app, String stream) {
|
||||||
StreamProxy streamProxy = streamProxyMapper.selectOne(app, stream);
|
StreamProxy streamProxy = streamProxyMapper.selectOneByAppAndStream(app, stream);
|
||||||
if (streamProxy == null) {
|
if (streamProxy == null) {
|
||||||
throw new ControllerException(ErrorCode.ERROR404.getCode(), "代理信息未找到");
|
throw new ControllerException(ErrorCode.ERROR404.getCode(), "代理信息未找到");
|
||||||
}
|
}
|
||||||
|
@ -246,7 +246,7 @@ public class StreamProxyServiceImpl implements IStreamProxyService {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void stop(String app, String stream) {
|
public void stop(String app, String stream) {
|
||||||
StreamProxy streamProxy = streamProxyMapper.selectOne(app, stream);
|
StreamProxy streamProxy = streamProxyMapper.selectOneByAppAndStream(app, stream);
|
||||||
if (streamProxy == null) {
|
if (streamProxy == null) {
|
||||||
throw new ControllerException(ErrorCode.ERROR404.getCode(), "代理信息未找到");
|
throw new ControllerException(ErrorCode.ERROR404.getCode(), "代理信息未找到");
|
||||||
}
|
}
|
||||||
|
@ -265,7 +265,7 @@ public class StreamProxyServiceImpl implements IStreamProxyService {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public StreamProxy getStreamProxyByAppAndStream(String app, String streamId) {
|
public StreamProxy getStreamProxyByAppAndStream(String app, String streamId) {
|
||||||
return streamProxyMapper.selectOne(app, streamId);
|
return streamProxyMapper.selectOneByAppAndStream(app, streamId);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -391,11 +391,11 @@ public class StreamProxyServiceImpl implements IStreamProxyService {
|
||||||
@Transactional
|
@Transactional
|
||||||
public int updateStatusByAppAndStream(String app, String stream, boolean status) {
|
public int updateStatusByAppAndStream(String app, String stream, boolean status) {
|
||||||
// 状态变化时推送到国标上级
|
// 状态变化时推送到国标上级
|
||||||
StreamProxy streamProxy = streamProxyMapper.selectOne(app, stream);
|
StreamProxy streamProxy = streamProxyMapper.selectOneByAppAndStream(app, stream);
|
||||||
if (streamProxy == null) {
|
if (streamProxy == null) {
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
streamProxy.setStatus(true);
|
streamProxy.setPulling(true);
|
||||||
streamProxyMapper.online(streamProxy.getId());
|
streamProxyMapper.online(streamProxy.getId());
|
||||||
streamProxy.setGbStatus(status?"ON":"OFF");
|
streamProxy.setGbStatus(status?"ON":"OFF");
|
||||||
if (streamProxy.getGbId() > 0) {
|
if (streamProxy.getGbId() > 0) {
|
||||||
|
@ -404,7 +404,6 @@ public class StreamProxyServiceImpl implements IStreamProxyService {
|
||||||
}else {
|
}else {
|
||||||
gbChannelService.offline(streamProxy.buildCommonGBChannel());
|
gbChannelService.offline(streamProxy.buildCommonGBChannel());
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
@ -418,6 +417,22 @@ public class StreamProxyServiceImpl implements IStreamProxyService {
|
||||||
return new ResourceBaseInfo(total, online);
|
return new ResourceBaseInfo(total, online);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
@Transactional
|
||||||
|
public StreamInfo add(StreamProxy streamProxy) {
|
||||||
|
StreamProxy streamProxyInDb = streamProxyMapper.selectOneByAppAndStream(streamProxy.getApp(), streamProxy.getStream());
|
||||||
|
if (streamProxyInDb != null) {
|
||||||
|
throw new ControllerException(ErrorCode.ERROR100.getCode(), "APP+STREAM已经存在");
|
||||||
|
}
|
||||||
|
if (streamProxy.getGbDeviceId() != null) {
|
||||||
|
gbChannelService.add(streamProxy.buildCommonGBChannel());
|
||||||
|
}
|
||||||
|
streamProxyMapper.add(streamProxy);
|
||||||
|
if (streamProxy.isEnable()) {
|
||||||
|
// start()
|
||||||
|
}
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
// @Scheduled(cron = "* 0/10 * * * ?")
|
// @Scheduled(cron = "* 0/10 * * * ?")
|
||||||
// public void asyncCheckStreamProxyStatus() {
|
// public void asyncCheckStreamProxyStatus() {
|
||||||
|
|
|
@ -68,7 +68,7 @@ public class StreamPush extends CommonGBChannel implements Comparable<StreamPush
|
||||||
* 是否正在推流
|
* 是否正在推流
|
||||||
*/
|
*/
|
||||||
@Schema(description = "是否正在推流")
|
@Schema(description = "是否正在推流")
|
||||||
private boolean pushIng;
|
private boolean pushing;
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public int compareTo(@NotNull StreamPush streamPushItem) {
|
public int compareTo(@NotNull StreamPush streamPushItem) {
|
||||||
|
|
|
@ -236,7 +236,7 @@ public class StreamPushController {
|
||||||
throw new ControllerException(ErrorCode.ERROR400.getCode(), "app或stream不可为空");
|
throw new ControllerException(ErrorCode.ERROR400.getCode(), "app或stream不可为空");
|
||||||
}
|
}
|
||||||
stream.setGbStatus("OFF");
|
stream.setGbStatus("OFF");
|
||||||
stream.setPushIng(false);
|
stream.setPushing(false);
|
||||||
if (!streamPushService.add(stream)) {
|
if (!streamPushService.add(stream)) {
|
||||||
throw new ControllerException(ErrorCode.ERROR100);
|
throw new ControllerException(ErrorCode.ERROR100);
|
||||||
}
|
}
|
||||||
|
|
|
@ -13,8 +13,8 @@ import java.util.Set;
|
||||||
@Repository
|
@Repository
|
||||||
public interface StreamPushMapper {
|
public interface StreamPushMapper {
|
||||||
|
|
||||||
@Insert("INSERT INTO wvp_stream_push (app, stream, media_server_id, server_id, push_time, update_time, create_time, push_ing) VALUES" +
|
@Insert("INSERT INTO wvp_stream_push (app, stream, media_server_id, server_id, push_time, update_time, create_time, pushing) VALUES" +
|
||||||
"(#{app}, #{stream}, #{mediaServerId} , #{serverId} , #{pushTime} ,#{updateTime}, #{createTime}, #{pushIng})")
|
"(#{app}, #{stream}, #{mediaServerId} , #{serverId} , #{pushTime} ,#{updateTime}, #{createTime}, #{pushing})")
|
||||||
@Options(useGeneratedKeys = true, keyProperty = "id", keyColumn = "id")
|
@Options(useGeneratedKeys = true, keyProperty = "id", keyColumn = "id")
|
||||||
int add(StreamPush streamPushItem);
|
int add(StreamPush streamPushItem);
|
||||||
|
|
||||||
|
@ -27,7 +27,7 @@ public interface StreamPushMapper {
|
||||||
"<if test=\"mediaServerId != null\">, media_server_id=#{mediaServerId}</if>" +
|
"<if test=\"mediaServerId != null\">, media_server_id=#{mediaServerId}</if>" +
|
||||||
"<if test=\"serverId != null\">, server_id=#{serverId}</if>" +
|
"<if test=\"serverId != null\">, server_id=#{serverId}</if>" +
|
||||||
"<if test=\"pushTime != null\">, push_time=#{pushTime}</if>" +
|
"<if test=\"pushTime != null\">, push_time=#{pushTime}</if>" +
|
||||||
"<if test=\"pushIng != null\">, push_ing=#{pushIng}</if>" +
|
"<if test=\"pushing != null\">, pushing=#{pushing}</if>" +
|
||||||
"WHERE id = #{id}"+
|
"WHERE id = #{id}"+
|
||||||
" </script>"})
|
" </script>"})
|
||||||
int update(StreamPush streamPushItem);
|
int update(StreamPush streamPushItem);
|
||||||
|
@ -49,21 +49,21 @@ public interface StreamPushMapper {
|
||||||
" 1=1 " +
|
" 1=1 " +
|
||||||
" <if test='query != null'> AND (st.app LIKE concat('%',#{query},'%') OR st.stream LIKE concat('%',#{query},'%') " +
|
" <if test='query != null'> AND (st.app LIKE concat('%',#{query},'%') OR st.stream LIKE concat('%',#{query},'%') " +
|
||||||
" OR wdc.gb_device_id LIKE concat('%',#{query},'%') OR wdc.gb_name LIKE concat('%',#{query},'%'))</if> " +
|
" OR wdc.gb_device_id LIKE concat('%',#{query},'%') OR wdc.gb_name LIKE concat('%',#{query},'%'))</if> " +
|
||||||
" <if test='pushing == true' > AND st.push_ing=1</if>" +
|
" <if test='pushing == true' > AND st.pushing=1</if>" +
|
||||||
" <if test='pushing == false' > AND st.push_ing=0 </if>" +
|
" <if test='pushing == false' > AND st.pushing=0 </if>" +
|
||||||
" <if test='mediaServerId != null' > AND st.media_server_id=#{mediaServerId} </if>" +
|
" <if test='mediaServerId != null' > AND st.media_server_id=#{mediaServerId} </if>" +
|
||||||
" order by st.create_time desc" +
|
" order by st.create_time desc" +
|
||||||
" </script>"})
|
" </script>"})
|
||||||
List<StreamPush> selectAllForList(@Param("query") String query, @Param("pushing") Boolean pushing, @Param("mediaServerId") String mediaServerId);
|
List<StreamPush> selectAll(@Param("query") String query, @Param("pushing") Boolean pushing, @Param("mediaServerId") String mediaServerId);
|
||||||
|
|
||||||
@Select("SELECT st.*, st.id as stream_push_id, wdc.*, wdc.id as gb_id FROM wvp_stream_push st LEFT join wvp_device_channel wdc on st.id = wdc.stream_push_id WHERE st.app=#{app} AND st.stream=#{stream}")
|
@Select("SELECT st.*, st.id as stream_push_id, wdc.*, wdc.id as gb_id FROM wvp_stream_push st LEFT join wvp_device_channel wdc on st.id = wdc.stream_push_id WHERE st.app=#{app} AND st.stream=#{stream}")
|
||||||
StreamPush selectByAppAndStream(@Param("app") String app, @Param("stream") String stream);
|
StreamPush selectByAppAndStream(@Param("app") String app, @Param("stream") String stream);
|
||||||
|
|
||||||
@Insert("<script>" +
|
@Insert("<script>" +
|
||||||
"Insert INTO wvp_stream_push ( " +
|
"Insert INTO wvp_stream_push ( " +
|
||||||
" app, stream, media_server_id, server_id, push_time, update_time, create_time, push_ing) " +
|
" app, stream, media_server_id, server_id, push_time, update_time, create_time, pushing) " +
|
||||||
" VALUES <foreach collection='streamPushItems' item='item' index='index' separator=','>" +
|
" VALUES <foreach collection='streamPushItems' item='item' index='index' separator=','>" +
|
||||||
" ( #{item.app}, #{item.stream}, #{item.mediaServerId},#{item.serverId} ,#{item.pushTime}, #{item.updateTime}, #{item.createTime}, #{item.pushIng} )" +
|
" ( #{item.app}, #{item.stream}, #{item.mediaServerId},#{item.serverId} ,#{item.pushTime}, #{item.updateTime}, #{item.createTime}, #{item.pushing} )" +
|
||||||
" </foreach>" +
|
" </foreach>" +
|
||||||
" </script>")
|
" </script>")
|
||||||
@Options(useGeneratedKeys = true, keyProperty = "id", keyColumn = "id")
|
@Options(useGeneratedKeys = true, keyProperty = "id", keyColumn = "id")
|
||||||
|
@ -76,9 +76,9 @@ public interface StreamPushMapper {
|
||||||
List<StreamPush> selectAllByMediaServerIdWithOutGbID(String mediaServerId);
|
List<StreamPush> selectAllByMediaServerIdWithOutGbID(String mediaServerId);
|
||||||
|
|
||||||
@Update("UPDATE wvp_stream_push " +
|
@Update("UPDATE wvp_stream_push " +
|
||||||
"SET push_ing=#{pushIng} " +
|
"SET pushing=#{pushing} " +
|
||||||
"WHERE id=#{id}")
|
"WHERE id=#{id}")
|
||||||
int updatePushStatus(@Param("id") int id, @Param("pushIng") boolean pushIng);
|
int updatePushStatus(@Param("id") int id, @Param("pushing") boolean pushing);
|
||||||
|
|
||||||
|
|
||||||
@Select("<script> "+
|
@Select("<script> "+
|
||||||
|
@ -98,7 +98,7 @@ public interface StreamPushMapper {
|
||||||
int getAllCount();
|
int getAllCount();
|
||||||
|
|
||||||
@Select(value = {" <script>" +
|
@Select(value = {" <script>" +
|
||||||
" select count(1) from wvp_stream_push where push_ing = true" +
|
" select count(1) from wvp_stream_push where pushing = true" +
|
||||||
" </script>"})
|
" </script>"})
|
||||||
int getAllPushing(Boolean usePushingAsStatus);
|
int getAllPushing(Boolean usePushingAsStatus);
|
||||||
|
|
||||||
|
|
|
@ -93,7 +93,7 @@ public class StreamPushServiceImpl implements IStreamPushService {
|
||||||
StreamPush streamPushInDb = getPush(event.getApp(), event.getStream());
|
StreamPush streamPushInDb = getPush(event.getApp(), event.getStream());
|
||||||
if (streamPushInDb == null) {
|
if (streamPushInDb == null) {
|
||||||
StreamPush streamPush = StreamPush.getInstance(event, userSetting.getServerId());
|
StreamPush streamPush = StreamPush.getInstance(event, userSetting.getServerId());
|
||||||
streamPush.setPushIng(true);
|
streamPush.setPushing(true);
|
||||||
streamPush.setUpdateTime(DateUtil.getNow());
|
streamPush.setUpdateTime(DateUtil.getNow());
|
||||||
streamPush.setPushTime(DateUtil.getNow());
|
streamPush.setPushTime(DateUtil.getNow());
|
||||||
add(streamPush);
|
add(streamPush);
|
||||||
|
@ -151,7 +151,7 @@ public class StreamPushServiceImpl implements IStreamPushService {
|
||||||
if (push == null) {
|
if (push == null) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
push.setPushIng(false);
|
push.setPushing(false);
|
||||||
if (push.getGbDeviceId() != null) {
|
if (push.getGbDeviceId() != null) {
|
||||||
if (userSetting.isUsePushingAsStatus()) {
|
if (userSetting.isUsePushingAsStatus()) {
|
||||||
push.setGbStatus("OFF");
|
push.setGbStatus("OFF");
|
||||||
|
@ -187,7 +187,7 @@ public class StreamPushServiceImpl implements IStreamPushService {
|
||||||
@Override
|
@Override
|
||||||
public PageInfo<StreamPush> getPushList(Integer page, Integer count, String query, Boolean pushing, String mediaServerId) {
|
public PageInfo<StreamPush> getPushList(Integer page, Integer count, String query, Boolean pushing, String mediaServerId) {
|
||||||
PageHelper.startPage(page, count);
|
PageHelper.startPage(page, count);
|
||||||
List<StreamPush> all = streamPushMapper.selectAllForList(query, pushing, mediaServerId);
|
List<StreamPush> all = streamPushMapper.selectAll(query, pushing, mediaServerId);
|
||||||
return new PageInfo<>(all);
|
return new PageInfo<>(all);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -236,7 +236,7 @@ public class StreamPushServiceImpl implements IStreamPushService {
|
||||||
log.info("[删除推流]失败, 不存在 app: {}, stream: {}, ", app, stream);
|
log.info("[删除推流]失败, 不存在 app: {}, stream: {}, ", app, stream);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
if (streamPush.isPushIng()) {
|
if (streamPush.isPushing()) {
|
||||||
stop(streamPush);
|
stop(streamPush);
|
||||||
}
|
}
|
||||||
if (streamPush.getGbId() > 0) {
|
if (streamPush.getGbId() > 0) {
|
||||||
|
@ -294,7 +294,7 @@ public class StreamPushServiceImpl implements IStreamPushService {
|
||||||
if (mediaServer != null) {
|
if (mediaServer != null) {
|
||||||
mediaServerService.closeStreams(mediaServer, streamPush.getApp(), streamPush.getStream());
|
mediaServerService.closeStreams(mediaServer, streamPush.getApp(), streamPush.getStream());
|
||||||
}
|
}
|
||||||
streamPush.setPushIng(false);
|
streamPush.setPushing(false);
|
||||||
if (userSetting.isUsePushingAsStatus()) {
|
if (userSetting.isUsePushingAsStatus()) {
|
||||||
gbChannelService.offline(streamPush.buildCommonGBChannel());
|
gbChannelService.offline(streamPush.buildCommonGBChannel());
|
||||||
}
|
}
|
||||||
|
@ -463,7 +463,7 @@ public class StreamPushServiceImpl implements IStreamPushService {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void allOffline() {
|
public void allOffline() {
|
||||||
List<StreamPush> streamPushList = streamPushMapper.selectAllForList(null, null, null);
|
List<StreamPush> streamPushList = streamPushMapper.selectAll(null, null, null);
|
||||||
if (streamPushList.isEmpty()) {
|
if (streamPushList.isEmpty()) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -537,7 +537,7 @@ public class StreamPushServiceImpl implements IStreamPushService {
|
||||||
@Override
|
@Override
|
||||||
public void updatePushStatus(Integer streamPushId, boolean pushIng) {
|
public void updatePushStatus(Integer streamPushId, boolean pushIng) {
|
||||||
StreamPush streamPushInDb = streamPushMapper.select(streamPushId);
|
StreamPush streamPushInDb = streamPushMapper.select(streamPushId);
|
||||||
streamPushInDb.setPushIng(pushIng);
|
streamPushInDb.setPushing(pushIng);
|
||||||
if (userSetting.isUsePushingAsStatus()) {
|
if (userSetting.isUsePushingAsStatus()) {
|
||||||
streamPushInDb.setGbStatus(pushIng?"ON":"OFF");
|
streamPushInDb.setGbStatus(pushIng?"ON":"OFF");
|
||||||
}
|
}
|
||||||
|
@ -578,7 +578,7 @@ public class StreamPushServiceImpl implements IStreamPushService {
|
||||||
if (streamPush == null) {
|
if (streamPush == null) {
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
if(streamPush.isPushIng()) {
|
if(streamPush.isPushing()) {
|
||||||
MediaServer mediaServer = mediaServerService.getOne(streamPush.getMediaServerId());
|
MediaServer mediaServer = mediaServerService.getOne(streamPush.getMediaServerId());
|
||||||
mediaServerService.closeStreams(mediaServer, streamPush.getApp(), streamPush.getStream());
|
mediaServerService.closeStreams(mediaServer, streamPush.getApp(), streamPush.getStream());
|
||||||
}
|
}
|
||||||
|
|
|
@ -25,23 +25,17 @@
|
||||||
<el-option label="FFmpeg" value="ffmpeg"></el-option>
|
<el-option label="FFmpeg" value="ffmpeg"></el-option>
|
||||||
</el-select>
|
</el-select>
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
<el-form-item label="名称" prop="name">
|
<el-form-item label="应用名" prop="app">
|
||||||
<el-input v-model="streamProxy.name" clearable></el-input>
|
|
||||||
</el-form-item>
|
|
||||||
<el-form-item label="流应用名" prop="app">
|
|
||||||
<el-input v-model="streamProxy.app" clearable></el-input>
|
<el-input v-model="streamProxy.app" clearable></el-input>
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
<el-form-item label="流ID" prop="stream">
|
<el-form-item label="流ID" prop="stream">
|
||||||
<el-input v-model="streamProxy.stream" clearable></el-input>
|
<el-input v-model="streamProxy.stream" clearable></el-input>
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
<el-form-item label="拉流地址" prop="url" v-if="streamProxy.type=='default'">
|
<el-form-item label="拉流地址" prop="url">
|
||||||
<el-input v-model="streamProxy.url" clearable></el-input>
|
|
||||||
</el-form-item>
|
|
||||||
<el-form-item label="拉流地址" prop="srcUrl" v-if="streamProxy.type=='ffmpeg'">
|
|
||||||
<el-input v-model="streamProxy.srcUrl" clearable></el-input>
|
<el-input v-model="streamProxy.srcUrl" clearable></el-input>
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
<el-form-item label="超时时间:毫秒" prop="timeoutMs" v-if="streamProxy.type=='ffmpeg'">
|
<el-form-item label="超时时间:毫秒" prop="timeoutMs" v-if="streamProxy.type=='ffmpeg'">
|
||||||
<el-input v-model="streamProxy.timeoutMs" clearable></el-input>
|
<el-input v-model="streamProxy.timeout" clearable></el-input>
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
<el-form-item label="节点选择" prop="rtpType">
|
<el-form-item label="节点选择" prop="rtpType">
|
||||||
<el-select
|
<el-select
|
||||||
|
@ -72,12 +66,9 @@
|
||||||
</el-option>
|
</el-option>
|
||||||
</el-select>
|
</el-select>
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
<el-form-item label="国标编码" prop="gbId">
|
<el-form-item label="拉流方式" prop="rtpType" v-if="streamProxy.type ==='default'">
|
||||||
<el-input v-model="streamProxy.gbId" placeholder="设置国标编码可推送到国标" clearable></el-input>
|
|
||||||
</el-form-item>
|
|
||||||
<el-form-item label="拉流方式" prop="rtpType" v-if="streamProxy.type=='default'">
|
|
||||||
<el-select
|
<el-select
|
||||||
v-model="streamProxy.rtpType"
|
v-model="streamProxy.rtspType"
|
||||||
style="width: 100%"
|
style="width: 100%"
|
||||||
placeholder="请选择拉流方式"
|
placeholder="请选择拉流方式"
|
||||||
>
|
>
|
||||||
|
|
|
@ -292,7 +292,7 @@ create table wvp_stream_proxy (
|
||||||
media_server_id character varying(50),
|
media_server_id character varying(50),
|
||||||
enable_audio bool default false,
|
enable_audio bool default false,
|
||||||
enable_mp4 bool default false,
|
enable_mp4 bool default false,
|
||||||
status bool default false,
|
pulling bool default false,
|
||||||
enable bool default false,
|
enable bool default false,
|
||||||
enable_remove_none_reader bool default false,
|
enable_remove_none_reader bool default false,
|
||||||
create_time character varying(50),
|
create_time character varying(50),
|
||||||
|
@ -313,7 +313,7 @@ create table wvp_stream_push (
|
||||||
push_time character varying(50),
|
push_time character varying(50),
|
||||||
status bool default false,
|
status bool default false,
|
||||||
update_time character varying(50),
|
update_time character varying(50),
|
||||||
push_ing bool default false,
|
pushing bool default false,
|
||||||
self bool default false,
|
self bool default false,
|
||||||
constraint uk_stream_push_app_stream unique (app, stream)
|
constraint uk_stream_push_app_stream unique (app, stream)
|
||||||
);
|
);
|
||||||
|
|
Loading…
Reference in New Issue