package com.genersoft.iot.vmp.vmanager.streamPush; import com.alibaba.excel.EasyExcel; import com.alibaba.excel.ExcelReader; import com.alibaba.excel.read.metadata.ReadSheet; import com.genersoft.iot.vmp.gb28181.bean.GbStream; import com.genersoft.iot.vmp.media.zlm.dto.StreamPushItem; import com.genersoft.iot.vmp.service.IMediaServerService; import com.genersoft.iot.vmp.service.IStreamPushService; import com.genersoft.iot.vmp.service.impl.StreamPushUploadFileHandler; import com.genersoft.iot.vmp.vmanager.bean.StreamPushExcelDto; import com.github.pagehelper.PageInfo; import io.swagger.annotations.Api; import io.swagger.annotations.ApiImplicitParam; import io.swagger.annotations.ApiImplicitParams; import io.swagger.annotations.ApiOperation; import org.apache.poi.sl.usermodel.Sheet; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Controller; import org.springframework.web.bind.annotation.*; import org.springframework.web.multipart.MultipartFile; import java.io.IOException; import java.io.InputStream; @Api(tags = "推流信息管理") @Controller @CrossOrigin @RequestMapping(value = "/api/push") public class StreamPushController { private final static Logger logger = LoggerFactory.getLogger(StreamPushController.class); @Autowired private IStreamPushService streamPushService; @Autowired private IMediaServerService mediaServerService; @ApiOperation("推流列表查询") @ApiImplicitParams({ @ApiImplicitParam(name="page", value = "当前页", required = true, dataTypeClass = Integer.class), @ApiImplicitParam(name="count", value = "每页查询数量", required = true, dataTypeClass = Integer.class), @ApiImplicitParam(name="query", value = "查询内容", dataTypeClass = String.class), @ApiImplicitParam(name="online", value = "是否在线", dataTypeClass = Boolean.class), }) @GetMapping(value = "/list") @ResponseBody public PageInfo list(@RequestParam(required = false)Integer page, @RequestParam(required = false)Integer count, @RequestParam(required = false)String query, @RequestParam(required = false)Boolean online ){ PageInfo pushList = streamPushService.getPushList(page, count); return pushList; } @ApiOperation("将推流添加到国标") @ApiImplicitParams({ @ApiImplicitParam(name = "stream", value = "直播流关联国标平台", dataTypeClass = GbStream.class), }) @PostMapping(value = "/save_to_gb") @ResponseBody public Object saveToGB(@RequestBody GbStream stream){ if (streamPushService.saveToGB(stream)){ return "success"; }else { return "fail"; } } @ApiOperation("将推流移出到国标") @ApiImplicitParams({ @ApiImplicitParam(name = "stream", value = "直播流关联国标平台", dataTypeClass = GbStream.class), }) @DeleteMapping(value = "/remove_form_gb") @ResponseBody public Object removeFormGB(@RequestBody GbStream stream){ if (streamPushService.removeFromGB(stream)){ return "success"; }else { return "fail"; } } @ApiOperation("中止一个推流") @ApiImplicitParams({ @ApiImplicitParam(name = "app", value = "应用名", required = true, dataTypeClass = String.class), @ApiImplicitParam(name = "streamId", value = "流ID", required = true, dataTypeClass = String.class), }) @PostMapping(value = "/stop") @ResponseBody public Object removeFormGB(@RequestParam(required = true)String app, @RequestParam(required = true)String streamId){ if (streamPushService.stop(app, streamId)){ return "success"; }else { return "fail"; } } @PostMapping(value = "upload") @ResponseBody public String uploadChannelFile(@RequestParam(value = "file") MultipartFile file){ if (file.isEmpty()) { return "fail"; } //获取文件流 InputStream inputStream = null; try { String name = file.getName(); inputStream = file.getInputStream(); } catch (IOException e) { e.printStackTrace(); } //传入参数 ExcelReader excelReader = EasyExcel.read(inputStream, StreamPushExcelDto.class, new StreamPushUploadFileHandler(streamPushService, mediaServerService.getDefaultMediaServer().getId())).build(); ReadSheet readSheet = EasyExcel.readSheet(0).build(); excelReader.read(readSheet); excelReader.finish(); return "success"; } }