123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269 |
- package com.ym.controller;
- import com.alibaba.fastjson.JSONObject;
- import com.ym.common.ApiException;
- import com.ym.common.BaseResponse;
- import com.ym.common.ErrorEnum;
- import com.ym.mec.auth.api.client.SysUserFeignService;
- import com.ym.pojo.*;
- import com.ym.service.MessageService;
- import com.ym.service.RoomService;
- import lombok.extern.slf4j.Slf4j;
- import org.springframework.beans.factory.annotation.Autowired;
- import org.springframework.web.bind.annotation.*;
- import java.util.List;
- /**
- * Created by weiqinxiao on 2019/2/25.
- */
- @RestController
- @RequestMapping("/room")
- @Slf4j
- public class RoomController{
- @Autowired
- RoomService roomService;
- @Autowired
- MessageService messageService;
- @Autowired
- SysUserFeignService sysUserFeignService;
- @RequestMapping(value = "/join", method = RequestMethod.POST)
- public Object joinRoom(@RequestBody ReqUserData data)
- throws ApiException, Exception {
- RoomResult roomResult = roomService.joinRoom(data.getUserName(), data.getRoomId(), data.isAudience(), data.isDisableCamera(),data.isMusicMode());
- return new BaseResponse<>(roomResult);
- }
- @RequestMapping(value = "/queryNoJoinStu", method = RequestMethod.GET)
- public Object queryNoJoinStu(String roomId){
- return new BaseResponse<>(roomService.queryNoJoinStu(roomId));
- }
- @RequestMapping(value = "/signIn", method = RequestMethod.POST)
- public Object signIn(Long roomId){
- roomService.signIn(roomId);
- return new BaseResponse<>();
- }
- @RequestMapping(value = "/leave", method = RequestMethod.POST)
- public Object leaveRoom(@RequestBody ReqUserData data)
- throws ApiException, Exception {
- boolean result = roomService.leaveRoom(data.getRoomId());
- return new BaseResponse<>(result);
- }
- @RequestMapping(value = "/sendImPlayMidiMessage", method = RequestMethod.POST)
- public Object sendImPlayMidiMessage(@RequestBody PlayMidiMessageData playMidiMessageData) throws Exception {
- roomService.sendImPlayMidiMessage(playMidiMessageData);
- return new BaseResponse<>();
- }
- @RequestMapping(value = "/statusSync")
- public Object statusSync(@RequestBody String body) throws Exception {
- ChannelStateNotify notify = JSONObject.parseObject(body, ChannelStateNotify.class);
- log.info("statusSyncParam: {}",JSONObject.toJSON(notify));
- boolean result = false;
- if(notify.getEvent() == 12 || notify.getEvent() == 3){
- result = roomService.statusSync(notify.getChannelId(), notify.getUserId());
- }else if(notify.getEvent() == 11){
- // Teacher teacher = teacherDao.get(Integer.parseInt(notify.getUserId()));
- // Long roomId = Long.parseLong(notify.getChannelId().substring(1));
- // CourseSchedule courseSchedule = courseScheduleDao.get(roomId);
- // if(teacher != null && teacher.getId().equals(courseSchedule.getActualTeacherId())){
- // roomService.joinRoom(teacher.getRealName(),roomId.toString(),false,false);
- // }else {
- // roomService.joinRoom(teacher.getUsername(),roomId.toString(),false,false);
- // }
- }
- return new BaseResponse<>(result);
- }
- @RequestMapping(value = "/statusImMsg")
- public void statusImMsg(@RequestBody String body) throws Exception {
- System.out.println("");
- }
- @RequestMapping(value = "/downgrade", method = RequestMethod.POST)
- public Object downRole(@RequestBody ReqChangeUserRoleData data)
- throws ApiException, Exception {
- boolean result = roomService.downgrade(data.getRoomId(), data.getUsers());
- return new BaseResponse<>(result);
- }
- @RequestMapping(value = "/kick", method = RequestMethod.POST)
- public Object kickMember(@RequestBody ReqUserData data)
- throws ApiException, Exception {
- boolean result = roomService.kickMember(data.getRoomId());
- return new BaseResponse<>(result);
- }
- //only teacher
- @RequestMapping(value = "/display", method = RequestMethod.POST)
- public Object display(@RequestBody ReqDisplayData data)
- throws ApiException, Exception {
- boolean result = roomService.display(data.getRoomId(), data.getType(), data.getUri(),data.getUserId());
- return new BaseResponse<>(result);
- }
- @RequestMapping(value = "/whiteboard/create", method = RequestMethod.POST)
- public Object createWhiteBoard(@RequestBody ReqWhiteboardData data)
- throws ApiException, Exception {
- String result = roomService.createWhiteBoard(data.getRoomId());
- return new BaseResponse<>(result);
- }
- @RequestMapping(value = "/whiteboard/delete", method = RequestMethod.POST)
- public Object destroyWhiteBoard(@RequestBody ReqWhiteboardData data)
- throws ApiException, Exception {
- boolean result = roomService.deleteWhiteboard(data.getRoomId(), data.getWhiteboardId());
- return new BaseResponse<>(result);
- }
- @RequestMapping(value = "/whiteboard/list", method = RequestMethod.GET)
- public Object getWhiteBoard(@RequestParam String roomId)
- throws ApiException, Exception {
- List<RoomResult.WhiteboardResult> whiteboards = roomService.getWhiteboard(roomId);
- return new BaseResponse<>(whiteboards);
- }
- @RequestMapping(value = "/device/approve", method = RequestMethod.POST)
- public Object approveControlDevice(@RequestBody ReqDeviceControlData data)
- throws ApiException, Exception {
- boolean result;
- result = roomService.approveControlDevice(data.getRoomId(), data.getTicket());
- return new BaseResponse<>(result);
- }
- @RequestMapping(value = "/device/reject", method = RequestMethod.POST)
- public Object rejectControlDevice(@RequestBody ReqDeviceControlData data)
- throws ApiException, Exception {
- boolean result;
- result = roomService.rejectControlDevice(data.getRoomId(), data.getTicket());
- return new BaseResponse<>(result);
- }
- @RequestMapping(value = "/device/control", method = RequestMethod.POST)
- public Object controlDevice(@RequestBody ReqDeviceControlData data)
- throws ApiException, Exception {
- boolean result;
- if (data.getCameraOn() != null) {
- result = roomService.controlDevice(data.getRoomId(), data.getUserId(), DeviceTypeEnum.Camera, data.getCameraOn());
- } else if (data.getMicrophoneOn() != null) {
- result = roomService.controlDevice(data.getRoomId(), data.getUserId(), DeviceTypeEnum.Microphone, data.getMicrophoneOn());
- } else if (data.getMusicModeOn() != null) {
- result = roomService.controlDevice(data.getRoomId(), data.getUserId(), DeviceTypeEnum.MusicMode, data.getMusicModeOn());
- } else if (data.getHandUpOn() != null) {
- result = roomService.controlDevice(data.getRoomId(), data.getUserId(), DeviceTypeEnum.HandUp, data.getHandUpOn());
- } else {
- throw new ApiException(ErrorEnum.ERR_REQUEST_PARA_ERR);
- }
- return new BaseResponse<>(result);
- }
- @RequestMapping(value = "/device/batchControl", method = RequestMethod.POST)
- public Object batchControlDevice(@RequestBody ReqDeviceControlData data)throws Exception {
- log.info("batchControl: {}",JSONObject.toJSON(data));
- boolean result = roomService.batchControlDevice(data);
- return new BaseResponse<>(result);
- }
- @RequestMapping(value = "/device/sync", method = RequestMethod.POST)
- public Object syncDeviceState(@RequestBody ReqDeviceControlData data)
- throws ApiException, Exception {
- boolean result;
- if (data.getCameraOn() != null) {
- result = roomService.syncDeviceState(data.getRoomId(), DeviceTypeEnum.Camera, data.getCameraOn());
- } else if (data.getMicrophoneOn() != null) {
- result = roomService.syncDeviceState(data.getRoomId(), DeviceTypeEnum.Microphone, data.getMicrophoneOn());
- } else if (data.getMusicModeOn() != null) {
- result = roomService.syncDeviceState(data.getRoomId(), DeviceTypeEnum.MusicMode, data.getMusicModeOn());
- } else if (data.getHandUpOn() != null) {
- result = roomService.syncDeviceState(data.getRoomId(), DeviceTypeEnum.HandUp, data.getHandUpOn());
- } else {
- throw new ApiException(ErrorEnum.ERR_REQUEST_PARA_ERR);
- }
- return new BaseResponse<>(result);
- }
- @RequestMapping(value = "/whiteboard/turn-page", method = RequestMethod.POST)
- public Object turnPage(@RequestBody ReqWhiteboardData data)
- throws ApiException, Exception {
- boolean result = roomService.turnWhiteBoardPage(data.getRoomId(), data.getWhiteboardId(), data.getPage());
- return new BaseResponse<>(result);
- }
- @RequestMapping(value = "/members", method = RequestMethod.GET)
- public Object getMembers(@RequestParam String roomId)
- throws ApiException, Exception {
- List<RoomResult.MemberResult> whiteboards = roomService.getMembers(roomId);
- return new BaseResponse<>(whiteboards);
- }
- @RequestMapping(value = "/speech/apply", method = RequestMethod.POST)
- public Object apply(@RequestBody ReqSpeechData data)
- throws ApiException, Exception {
- Boolean result = roomService.applySpeech(data.getRoomId());
- return new BaseResponse<>(result);
- }
- @RequestMapping(value = "/speech/approve", method = RequestMethod.POST)
- public Object approval(@RequestBody ReqSpeechData data)
- throws ApiException, Exception {
- Boolean result = roomService.approveSpeech(data.getRoomId(), data.getTicket());
- return new BaseResponse<>(result);
- }
- @RequestMapping(value = "/speech/reject", method = RequestMethod.POST)
- public Object reject(@RequestBody ReqSpeechData data)
- throws ApiException, Exception {
- Boolean result = roomService.rejectSpeech(data.getRoomId(), data.getTicket());
- return new BaseResponse<>(result);
- }
- @RequestMapping(value = "/transfer", method = RequestMethod.POST)
- public Object transfer(@RequestBody ReqUpgradeRoleData data)
- throws ApiException, Exception {
- Boolean result = roomService.transfer(data.getRoomId(), data.getUserId());
- return new BaseResponse<>(result);
- }
- @RequestMapping(value = "/upgrade/invite", method = RequestMethod.POST)
- public Object inviteUpgradeRole(@RequestBody ReqUpgradeRoleData data)
- throws ApiException, Exception {
- Boolean result = roomService.inviteUpgradeRole(data.getRoomId(), data.getUserId(), data.getRole());
- return new BaseResponse<>(result);
- }
- @RequestMapping(value = "/upgrade/approve", method = RequestMethod.POST)
- public Object approveUpgradeRole(@RequestBody ReqUpgradeRoleData data)
- throws ApiException, Exception {
- Boolean result = roomService.approveUpgradeRole(data.getRoomId(), data.getTicket());
- return new BaseResponse<>(result);
- }
- @RequestMapping(value = "/upgrade/reject", method = RequestMethod.POST)
- public Object rejectUpgradeRole(@RequestBody ReqUpgradeRoleData data)
- throws ApiException, Exception {
- Boolean result = roomService.rejectUpgradeRole(data.getRoomId(), data.getTicket());
- return new BaseResponse<>(result);
- }
- @RequestMapping(value = "/change-role", method = RequestMethod.POST)
- public Object changeRole(@RequestBody ReqChangeRole data)
- throws ApiException, Exception {
- Boolean result = roomService.changeRole(data.getRoomId(), data.getUserId(), data.getRole());
- return new BaseResponse<>(result);
- }
- @RequestMapping(value = "/members/online-status", method = RequestMethod.POST)
- public Object memberOnlineStatus(@RequestBody List<ReqMemberOnlineStatus> statusList,
- @RequestParam(value = "timestamp", required = false) String timestamp,
- @RequestParam(value = "nonce", required = false) String nonce,
- @RequestParam(value = "signature", required = false) String signature)
- throws ApiException, Exception {
- Boolean result = roomService.memberOnlineStatus(statusList, nonce, timestamp, signature);
- return new BaseResponse<>(result);
- }
- }
|