| | |
| | | */
|
| | | @ResponseBody
|
| | | @PostMapping(value = "/on_server_keepalive", produces = "application/json;charset=UTF-8")
|
| | | public ResponseEntity<String> onServerKeepalive(@RequestBody JSONObject json){
|
| | | public JSONObject onServerKeepalive(@RequestBody JSONObject json){
|
| | |
|
| | | logger.info("[ ZLM HOOK ] on_server_keepalive API调用,参数:" + json.toString());
|
| | | String mediaServerId = json.getString("mediaServerId");
|
| | |
| | | JSONObject ret = new JSONObject();
|
| | | ret.put("code", 0);
|
| | | ret.put("msg", "success");
|
| | | return new ResponseEntity<String>(ret.toString(),HttpStatus.OK);
|
| | |
|
| | | return ret;
|
| | | }
|
| | |
|
| | | /**
|
| | |
| | | */
|
| | | @ResponseBody
|
| | | @PostMapping(value = "/on_flow_report", produces = "application/json;charset=UTF-8")
|
| | | public ResponseEntity<String> onFlowReport(@RequestBody JSONObject json){
|
| | | public JSONObject onFlowReport(@RequestBody JSONObject json){
|
| | |
|
| | | if (logger.isDebugEnabled()) {
|
| | | logger.debug("[ ZLM HOOK ]on_flow_report API调用,参数:" + json.toString());
|
| | | }
|
| | | String mediaServerId = json.getString("mediaServerId");
|
| | | JSONObject ret = new JSONObject();
|
| | | ret.put("code", 0);
|
| | | ret.put("msg", "success");
|
| | | return new ResponseEntity<String>(ret.toString(),HttpStatus.OK);
|
| | | return ret;
|
| | | }
|
| | |
|
| | | /**
|
| | |
| | | */
|
| | | @ResponseBody
|
| | | @PostMapping(value = "/on_http_access", produces = "application/json;charset=UTF-8")
|
| | | public ResponseEntity<String> onHttpAccess(@RequestBody JSONObject json){
|
| | | public JSONObject onHttpAccess(@RequestBody JSONObject json){
|
| | |
|
| | | if (logger.isDebugEnabled()) {
|
| | | logger.debug("[ ZLM HOOK ]on_http_access API 调用,参数:" + json.toString());
|
| | |
| | | ret.put("err", "");
|
| | | ret.put("path", "");
|
| | | ret.put("second", 600);
|
| | | return new ResponseEntity<String>(ret.toString(),HttpStatus.OK);
|
| | | return ret;
|
| | | }
|
| | |
|
| | | /**
|
| | |
| | | */
|
| | | @ResponseBody
|
| | | @PostMapping(value = "/on_play", produces = "application/json;charset=UTF-8")
|
| | | public ResponseEntity<String> onPlay(@RequestBody OnPlayHookParam param){
|
| | | public JSONObject onPlay(@RequestBody OnPlayHookParam param){
|
| | |
|
| | | JSONObject json = (JSONObject)JSON.toJSON(param);
|
| | |
|
| | |
| | | if (streamAuthorityInfo != null && streamAuthorityInfo.getCallId() != null && !streamAuthorityInfo.getCallId().equals(paramMap.get("callId"))) {
|
| | | ret.put("code", 401);
|
| | | ret.put("msg", "Unauthorized");
|
| | | return new ResponseEntity<>(ret.toString(),HttpStatus.OK);
|
| | | return ret;
|
| | | }
|
| | | }
|
| | |
|
| | | ret.put("code", 0);
|
| | | ret.put("msg", "success");
|
| | | return new ResponseEntity<>(ret.toString(),HttpStatus.OK);
|
| | | return ret;
|
| | | }
|
| | |
|
| | | /**
|
| | |
| | | */
|
| | | @ResponseBody
|
| | | @PostMapping(value = "/on_publish", produces = "application/json;charset=UTF-8")
|
| | | public ResponseEntity<String> onPublish(@RequestBody OnPublishHookParam param) {
|
| | | public JSONObject onPublish(@RequestBody OnPublishHookParam param) {
|
| | |
|
| | | JSONObject json = (JSONObject) JSON.toJSON(param);
|
| | |
|
| | |
| | | logger.info("推流鉴权失败: 缺少不要参数:sign=md5(user表的pushKey)");
|
| | | ret.put("code", 401);
|
| | | ret.put("msg", "Unauthorized");
|
| | | return new ResponseEntity<>(ret.toString(), HttpStatus.OK);
|
| | | return ret;
|
| | | }
|
| | | Map<String, String> paramMap = urlParamToMap(param.getParams());
|
| | | String sign = paramMap.get("sign");
|
| | |
| | | logger.info("推流鉴权失败: 缺少不要参数:sign=md5(user表的pushKey)");
|
| | | ret.put("code", 401);
|
| | | ret.put("msg", "Unauthorized");
|
| | | return new ResponseEntity<>(ret.toString(), HttpStatus.OK);
|
| | | return ret;
|
| | | }
|
| | | // 推流自定义播放鉴权码
|
| | | String callId = paramMap.get("callId");
|
| | |
| | | logger.info("推流鉴权失败: sign 无权限: callId={}. sign={}", callId, sign);
|
| | | ret.put("code", 401);
|
| | | ret.put("msg", "Unauthorized");
|
| | | return new ResponseEntity<>(ret.toString(), HttpStatus.OK);
|
| | | return ret;
|
| | | }
|
| | | StreamAuthorityInfo streamAuthorityInfo = StreamAuthorityInfo.getInstanceByHook(param);
|
| | | streamAuthorityInfo.setCallId(callId);
|
| | |
| | | // 鉴权通过
|
| | | redisCatchStorage.updateStreamAuthorityInfo(param.getApp(), param.getStream(), streamAuthorityInfo);
|
| | | // 通知assist新的callId
|
| | | taskExecutor.execute(()->{
|
| | | if (mediaInfo != null && mediaInfo.getRecordAssistPort() > 0) {
|
| | | if (mediaInfo != null && mediaInfo.getRecordAssistPort() > 0) {
|
| | | taskExecutor.execute(()->{
|
| | | assistRESTfulUtils.addStreamCallInfo(mediaInfo, param.getApp(), param.getStream(), callId, null);
|
| | | }
|
| | | });
|
| | |
|
| | | });
|
| | | }
|
| | | }else {
|
| | | zlmMediaListManager.sendStreamEvent(param.getApp(),param.getStream(), param.getMediaServerId());
|
| | | }
|
| | |
| | |
|
| | | }
|
| | | }
|
| | |
|
| | |
|
| | |
|
| | | return new ResponseEntity<String>(ret.toString(), HttpStatus.OK);
|
| | | return ret;
|
| | | }
|
| | |
|
| | |
|
| | |
| | | */
|
| | | @ResponseBody
|
| | | @PostMapping(value = "/on_record_mp4", produces = "application/json;charset=UTF-8")
|
| | | public ResponseEntity<String> onRecordMp4(@RequestBody JSONObject json){
|
| | | public JSONObject onRecordMp4(@RequestBody JSONObject json){
|
| | |
|
| | | if (logger.isDebugEnabled()) {
|
| | | logger.debug("[ ZLM HOOK ]on_record_mp4 API调用,参数:" + json.toString());
|
| | |
| | | JSONObject ret = new JSONObject();
|
| | | ret.put("code", 0);
|
| | | ret.put("msg", "success");
|
| | | return new ResponseEntity<String>(ret.toString(),HttpStatus.OK);
|
| | | return ret;
|
| | | }
|
| | | /**
|
| | | * 录制hls完成后通知事件;此事件对回复不敏感。
|
| | |
| | | */
|
| | | @ResponseBody
|
| | | @PostMapping(value = "/on_record_ts", produces = "application/json;charset=UTF-8")
|
| | | public ResponseEntity<String> onRecordTs(@RequestBody JSONObject json){
|
| | | public JSONObject onRecordTs(@RequestBody JSONObject json){
|
| | |
|
| | | if (logger.isDebugEnabled()) {
|
| | | logger.debug("[ ZLM HOOK ]on_record_ts API调用,参数:" + json.toString());
|
| | |
| | | JSONObject ret = new JSONObject();
|
| | | ret.put("code", 0);
|
| | | ret.put("msg", "success");
|
| | | return new ResponseEntity<String>(ret.toString(),HttpStatus.OK);
|
| | | return ret;
|
| | | }
|
| | |
|
| | | /**
|
| | |
| | | */
|
| | | @ResponseBody
|
| | | @PostMapping(value = "/on_rtsp_realm", produces = "application/json;charset=UTF-8")
|
| | | public ResponseEntity<String> onRtspRealm(@RequestBody JSONObject json){
|
| | | public JSONObject onRtspRealm(@RequestBody JSONObject json){
|
| | |
|
| | | if (logger.isDebugEnabled()) {
|
| | | logger.debug("[ ZLM HOOK ]on_rtsp_realm API调用,参数:" + json.toString());
|
| | |
| | | JSONObject ret = new JSONObject();
|
| | | ret.put("code", 0);
|
| | | ret.put("realm", "");
|
| | | return new ResponseEntity<String>(ret.toString(),HttpStatus.OK);
|
| | | return ret;
|
| | | }
|
| | |
|
| | |
|
| | |
| | | */
|
| | | @ResponseBody
|
| | | @PostMapping(value = "/on_rtsp_auth", produces = "application/json;charset=UTF-8")
|
| | | public ResponseEntity<String> onRtspAuth(@RequestBody JSONObject json){
|
| | | public JSONObject onRtspAuth(@RequestBody JSONObject json){
|
| | |
|
| | | if (logger.isDebugEnabled()) {
|
| | | logger.debug("[ ZLM HOOK ]on_rtsp_auth API调用,参数:" + json.toString());
|
| | |
| | | ret.put("code", 0);
|
| | | ret.put("encrypted", false);
|
| | | ret.put("passwd", "test");
|
| | | return new ResponseEntity<String>(ret.toString(),HttpStatus.OK);
|
| | | return ret;
|
| | | }
|
| | |
|
| | | /**
|
| | |
| | | */
|
| | | @ResponseBody
|
| | | @PostMapping(value = "/on_shell_login", produces = "application/json;charset=UTF-8")
|
| | | public ResponseEntity<String> onShellLogin(@RequestBody JSONObject json){
|
| | | public JSONObject onShellLogin(@RequestBody JSONObject json){
|
| | |
|
| | | if (logger.isDebugEnabled()) {
|
| | | logger.debug("[ ZLM HOOK ]on_shell_login API调用,参数:" + json.toString());
|
| | |
| | | JSONObject ret = new JSONObject();
|
| | | ret.put("code", 0);
|
| | | ret.put("msg", "success");
|
| | | return new ResponseEntity<String>(ret.toString(),HttpStatus.OK);
|
| | | return ret;
|
| | | }
|
| | |
|
| | | /**
|
| | |
| | | */
|
| | | @ResponseBody
|
| | | @PostMapping(value = "/on_stream_changed", produces = "application/json;charset=UTF-8")
|
| | | public ResponseEntity<String> onStreamChanged(@RequestBody MediaItem item){
|
| | | public JSONObject onStreamChanged(@RequestBody MediaItem item){
|
| | |
|
| | | logger.info("[ ZLM HOOK ]on_stream_changed API调用,参数:" + JSONObject.toJSONString(item));
|
| | | String mediaServerId = item.getMediaServerId();
|
| | |
| | | JSONObject ret = new JSONObject();
|
| | | ret.put("code", 0);
|
| | | ret.put("msg", "success");
|
| | | return new ResponseEntity<String>(ret.toString(),HttpStatus.OK);
|
| | | return ret;
|
| | | }
|
| | |
|
| | | /**
|
| | |
| | | */
|
| | | @ResponseBody
|
| | | @PostMapping(value = "/on_stream_none_reader", produces = "application/json;charset=UTF-8")
|
| | | public ResponseEntity<String> onStreamNoneReader(@RequestBody JSONObject json){
|
| | | public JSONObject onStreamNoneReader(@RequestBody JSONObject json){
|
| | |
|
| | | logger.info("[ ZLM HOOK ]on_stream_none_reader API调用,参数:" + json.toString());
|
| | | String mediaServerId = json.getString("mediaServerId");
|
| | |
| | | if (mediaServerItem != null && mediaServerItem.getStreamNoneReaderDelayMS() == -1) {
|
| | | ret.put("close", false);
|
| | | }
|
| | | return new ResponseEntity<String>(ret.toString(),HttpStatus.OK);
|
| | | return ret;
|
| | | }else {
|
| | | StreamProxyItem streamProxyItem = streamProxyService.getStreamProxyByAppAndStream(app, streamId);
|
| | | if (streamProxyItem != null && streamProxyItem.isEnable_remove_none_reader()) {
|
| | |
| | | }else {
|
| | | ret.put("close", false);
|
| | | }
|
| | | return new ResponseEntity<String>(ret.toString(),HttpStatus.OK);
|
| | | return ret;
|
| | | }
|
| | | }
|
| | |
|
| | |
| | | */
|
| | | @ResponseBody
|
| | | @PostMapping(value = "/on_stream_not_found", produces = "application/json;charset=UTF-8")
|
| | | public ResponseEntity<String> onStreamNotFound(@RequestBody JSONObject json){
|
| | | public JSONObject onStreamNotFound(@RequestBody JSONObject json){
|
| | | if (logger.isDebugEnabled()) {
|
| | | logger.debug("[ ZLM HOOK ]on_stream_not_found API调用,参数:" + json.toString());
|
| | | }
|
| | |
| | | JSONObject ret = new JSONObject();
|
| | | ret.put("code", 0);
|
| | | ret.put("msg", "success");
|
| | | return new ResponseEntity<>(ret.toString(),HttpStatus.OK);
|
| | | return ret;
|
| | | }
|
| | |
|
| | | /**
|
| | |
| | | */
|
| | | @ResponseBody
|
| | | @PostMapping(value = "/on_server_started", produces = "application/json;charset=UTF-8")
|
| | | public ResponseEntity<String> onServerStarted(HttpServletRequest request, @RequestBody JSONObject jsonObject){
|
| | | public JSONObject onServerStarted(HttpServletRequest request, @RequestBody JSONObject jsonObject){
|
| | |
|
| | | if (logger.isDebugEnabled()) {
|
| | | logger.debug("[ ZLM HOOK ]on_server_started API调用,参数:" + jsonObject.toString());
|
| | |
| | | JSONObject ret = new JSONObject();
|
| | | ret.put("code", 0);
|
| | | ret.put("msg", "success");
|
| | | return new ResponseEntity<>(ret.toString(),HttpStatus.OK);
|
| | | return ret;
|
| | | }
|
| | |
|
| | | private Map<String, String> urlParamToMap(String params) {
|