UserController.java 6.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152
  1. package com.ym.controller;
  2. import com.alibaba.fastjson.JSON;
  3. import com.alibaba.fastjson.JSONObject;
  4. import com.ym.common.BaseResponse;
  5. import com.ym.mec.biz.dal.dto.TencentData;
  6. import com.ym.mec.biz.dal.dto.TencentImCallbackResult;
  7. import com.ym.mec.biz.dal.enums.ETencentImCallbackCommand;
  8. import com.ym.mec.biz.service.ImLiveBroadcastRoomService;
  9. import com.ym.mec.common.entity.ImUserState;
  10. import com.ym.service.LiveRoomService;
  11. import com.ym.service.UserService;
  12. import io.rong.models.user.UserModel;
  13. import io.swagger.annotations.ApiOperation;
  14. import org.apache.commons.lang3.StringUtils;
  15. import org.slf4j.Logger;
  16. import org.slf4j.LoggerFactory;
  17. import org.springframework.beans.factory.annotation.Autowired;
  18. import org.springframework.web.bind.annotation.*;
  19. import javax.servlet.http.HttpServletRequest;
  20. import java.util.List;
  21. @RestController
  22. @RequestMapping("/user")
  23. public class UserController {
  24. private static final Logger log = LoggerFactory.getLogger(UserController.class);
  25. @Autowired
  26. private UserService userService;
  27. @Autowired
  28. private ImLiveBroadcastRoomService imLiveBroadcastRoomService;
  29. @Autowired
  30. private LiveRoomService liveRoomService;
  31. @RequestMapping(value = "/register", method = RequestMethod.POST)
  32. public Object register(@RequestBody UserModel userModel) throws Exception {
  33. return userService.register(userModel);
  34. }
  35. @RequestMapping(value = "/update", method = RequestMethod.POST)
  36. public Object update(@RequestBody UserModel userModel) throws Exception {
  37. return userService.update(userModel);
  38. }
  39. /**
  40. * 监听融云用户状态变更
  41. *
  42. * @param userState List<ImUserState>
  43. */
  44. @PostMapping(value = "/statusImUser")
  45. public BaseResponse statusImUser(@RequestBody List<ImUserState> userState) {
  46. log.info("statusImUser >>>>> : {}", JSONObject.toJSONString(userState));
  47. imLiveBroadcastRoomService.opsRoom(userState);
  48. return new BaseResponse<>();
  49. }
  50. @ApiOperation("腾讯im 回调接口")
  51. @PostMapping(value = "/tencentImCallback")
  52. public TencentImCallbackResult tencentImCallback(@RequestBody String body, HttpServletRequest request) {
  53. log.info("tencentImCallback body:{}", body);
  54. log.info("tencentImCallback request param:{}", JSON.toJSONString(request.getParameterMap()));
  55. String clientIP = request.getParameter("ClientIP");
  56. String optPlatform = request.getParameter("OptPlatform");
  57. if(request.getParameter("CallbackCommand").equals(ETencentImCallbackCommand.GROUP_CALLBACKONMEMBERSTATECHANGE.name())) {
  58. TencentData.CallbackOnMemberStateChange callbackOnMemberStateChange = TencentData.CallbackOnMemberStateChange.toObject(
  59. body);
  60. log.debug("callbackOnMemberStateChange: {}", callbackOnMemberStateChange);
  61. callbackOnMemberStateChange.setClientIP(clientIP);
  62. callbackOnMemberStateChange.setOptPlatform(optPlatform);
  63. imLiveBroadcastRoomService.callbackOnMemberStateChange(callbackOnMemberStateChange);
  64. } else if(request.getParameter("CallbackCommand").equals(ETencentImCallbackCommand.GROUP_CALLBACKAFTERMEMBEREXIT.name())) {
  65. TencentData.CallbackAfterMemberExit callbackAfterMemberExit = TencentData.CallbackAfterMemberExit.toObject(
  66. body);
  67. log.debug("callbackAfterMemberExit: {}", callbackAfterMemberExit);
  68. callbackAfterMemberExit.setClientIP(clientIP);
  69. callbackAfterMemberExit.setOptPlatform(optPlatform);
  70. imLiveBroadcastRoomService.callbackAfterMemberExit(callbackAfterMemberExit);
  71. } else if(request.getParameter("CallbackCommand").equals(ETencentImCallbackCommand.GROUP_CALLBACKAFTERNEWMEMBERJOIN.name())) {
  72. TencentData.CallbackAfterNewMemberJoin callbackAfterNewMemberJoin = TencentData.CallbackAfterNewMemberJoin.toObject(
  73. body);
  74. log.debug("CallbackAfterNewMemberJoin: {}", callbackAfterNewMemberJoin);
  75. callbackAfterNewMemberJoin.setClientIP(clientIP);
  76. callbackAfterNewMemberJoin.setOptPlatform(optPlatform);
  77. imLiveBroadcastRoomService.callbackAfterNewMemberJoin(callbackAfterNewMemberJoin);
  78. }
  79. return new TencentImCallbackResult();
  80. }
  81. @ApiOperation("腾讯云直播-推流 回调接口")
  82. @PostMapping(value = "/tencentStreamEventCallback")
  83. public TencentData.StreamEventCallbackResult tencentStreamEventCallback(@RequestBody String body) {
  84. log.info("tencentStreamEventCallback body:{}", body);
  85. TencentData.CallbackStreamStateEvent event = TencentData.CallbackStreamStateEvent.from(body);
  86. // 断流事件通知
  87. if (event.getEventType() == 0) {
  88. // 自动关闭录制
  89. if (StringUtils.isNotBlank(event.getPushDuration()) && event.getPushDuration().matches("\\d+")) {
  90. // 更新直播推流时长
  91. imLiveBroadcastRoomService.updateLiveRoomPushStreamTime(event);
  92. }
  93. }
  94. // 推流事件通知
  95. if (event.getEventType() == 1) {
  96. // 自动开启录制
  97. }
  98. return TencentData.StreamEventCallbackResult.builder().code(0).build();
  99. }
  100. @ApiOperation("腾讯云直播-录制 回调接口")
  101. @PostMapping(value = "/tencentStreamRecordCallback")
  102. public TencentData.StreamEventCallbackResult tencentStreamRecordCallback(@RequestBody String body) {
  103. log.info("tencentStreamRecordCallback body:{}", body);
  104. TencentData.CallbackSteamRecordEvent event = TencentData.CallbackSteamRecordEvent.from(body);
  105. log.info("taskId={}, url={}", event.getTaskId(), event.getVideoUrl());
  106. // 生成直播录制信息
  107. liveRoomService.createLiveRoomVideoRecord(event);
  108. return TencentData.StreamEventCallbackResult.builder().code(0).build();
  109. }
  110. @ApiOperation("腾讯云直播-推流异常 回调接口")
  111. @PostMapping(value = "/tencentStreamExceptionCallback")
  112. public TencentData.StreamEventCallbackResult tencentStreamExceptionCallback(@RequestBody String body) {
  113. log.info("tencentStreamExceptionCallback body:{}", body);
  114. return TencentData.StreamEventCallbackResult.builder().code(0).build();
  115. }
  116. }