wzj-boot/ruoyi-admin/src/main/java/org/dromara/app/AppVlogController.java

196 lines
7.0 KiB
Java
Raw Normal View History

2025-08-15 16:51:03 +08:00
package org.dromara.app;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import com.fasterxml.jackson.databind.ObjectMapper;
2025-08-21 15:47:21 +08:00
import com.wzj.soopin.content.domain.bo.*;
import com.wzj.soopin.content.domain.po.MyLikedVlog;
2025-08-25 14:35:44 +08:00
import com.wzj.soopin.content.domain.po.Vlog;
2025-08-21 15:47:21 +08:00
import com.wzj.soopin.content.domain.vo.IndexVlogVO;
2025-08-28 15:43:21 +08:00
import com.wzj.soopin.content.service.IVlogPullService;
2025-08-15 16:51:03 +08:00
import com.wzj.soopin.content.service.VlogService;
import com.wzj.soopin.content.service.VlogUploadService;
import com.wzj.soopin.content.utils.PagedGridResult;
import com.wzj.soopin.content.utils.QcCloud;
import com.wzj.soopin.content.utils.RedisOperator;
import io.swagger.annotations.Api;
import io.swagger.v3.oas.annotations.tags.Tag;
2025-08-28 15:43:21 +08:00
import lombok.AllArgsConstructor;
2025-08-15 16:51:03 +08:00
import lombok.extern.slf4j.Slf4j;
import org.apache.commons.lang3.StringUtils;
import org.dromara.common.core.domain.R;
2025-08-16 11:15:40 +08:00
import org.dromara.common.core.domain.model.LoginUser;
import org.dromara.common.core.exception.ServiceException;
import org.dromara.common.mq.domain.MQMessage;
import org.dromara.common.mq.enums.MQMessageType;
import org.dromara.common.mq.enums.MessageActionEnum;
import org.dromara.common.mq.utils.MqUtil;
2025-08-28 15:43:21 +08:00
import org.dromara.common.redis.redis.RedisCache;
2025-08-16 11:15:40 +08:00
import org.dromara.common.satoken.utils.LoginHelper;
2025-08-15 16:51:03 +08:00
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.*;
import java.util.ArrayList;
import java.util.HashMap;
2025-08-15 16:51:03 +08:00
import java.util.List;
import java.util.Map;
import static com.wzj.soopin.content.domain.base.BaseInfoProperties.*;
2025-08-16 11:15:40 +08:00
2025-08-15 16:51:03 +08:00
@Slf4j
@Api(tags = "VlogController 短视频相关业务功能的接口")
@RequestMapping("/app/vlog")
@RestController
2025-08-28 15:43:21 +08:00
@AllArgsConstructor
2025-08-15 16:51:03 +08:00
public class AppVlogController {
2025-08-28 15:43:21 +08:00
private final VlogService vlogService;
private final QcCloud qcCloud;
private final VlogUploadService vlogUploadService;
public final RedisCache cache;
private final IVlogPullService pullService;
2025-08-15 16:51:03 +08:00
@Tag(name = "首页视频列表")
@PostMapping("/indexList")
2025-08-21 15:47:21 +08:00
public R<Page<IndexVlogVO>> indexList(@RequestBody IndexListBO bo, @RequestBody Page page) {
2025-08-25 14:35:44 +08:00
2025-08-28 15:43:21 +08:00
Page<IndexVlogVO> pages = pullService.page(page);
2025-08-15 16:51:03 +08:00
return R.ok(pages);
}
2025-08-28 15:43:21 +08:00
2025-08-21 15:47:21 +08:00
@GetMapping("/detail/{vlogId}")
2025-08-28 15:43:21 +08:00
public R<Object> detail(@PathVariable String vlogId) {
2025-08-21 15:47:21 +08:00
return R.ok(vlogService.getVlogDetailById(vlogId));
2025-08-15 16:51:03 +08:00
}
2025-08-21 15:47:21 +08:00
2025-08-15 16:51:03 +08:00
@Tag(name = "我的私密视频列表")
@PostMapping("/myPrivateList")
2025-08-21 15:47:21 +08:00
public R<Page<IndexVlogVO>> myPrivateList(@RequestBody MyListBO bo, @RequestBody Page page) {
2025-08-16 11:15:40 +08:00
LoginUser loginUser = LoginHelper.getLoginUser();
if (loginUser == null) {
throw new ServiceException("用户未登录");
}
bo.setUserId(String.valueOf(loginUser.getUserId()));
2025-08-21 15:47:21 +08:00
Page<IndexVlogVO> pages = vlogService.queryMyVlogList(bo, page);
2025-08-15 16:51:03 +08:00
return R.ok(pages);
}
@Tag(name = "我点赞的视频列表")
@PostMapping("/myLikedList")
2025-08-21 15:47:21 +08:00
public R<Page<IndexVlogVO>> myLikedList(@RequestBody MyLikedVlogBO bo, @RequestBody Page page) {
Page<IndexVlogVO> pages = vlogService.getMyLikedVlogList(page);
2025-08-15 16:51:03 +08:00
return R.ok(pages);
}
2025-08-21 15:47:21 +08:00
@Tag(name = "我关注的人的视频列表")
2025-08-15 16:51:03 +08:00
@PostMapping("/followList")
2025-08-21 15:47:21 +08:00
public R<Page<IndexVlogVO>> followList(@RequestBody SimpleListBO bo, @RequestBody Page page) {
2025-08-16 11:15:40 +08:00
LoginUser loginUser = LoginHelper.getLoginUser();
if (loginUser == null) {
throw new ServiceException("用户未登录");
}
bo.setMyId(String.valueOf(loginUser.getUserId()));
2025-08-28 15:43:21 +08:00
Page<IndexVlogVO> pages = vlogService.getMyFollowVlogList(page);
2025-08-15 16:51:03 +08:00
return R.ok(pages);
}
@Tag(name = "好友视频列表")
@PostMapping("/friendList")
2025-08-21 15:47:21 +08:00
public R<Page<IndexVlogVO>> friendList(@RequestBody SimpleListBO bo, @RequestBody Page page) {
2025-08-16 11:15:40 +08:00
LoginUser loginUser = LoginHelper.getLoginUser();
if (loginUser == null) {
throw new ServiceException("用户未登录");
}
bo.setMyId(String.valueOf(loginUser.getUserId()));
2025-08-28 15:43:21 +08:00
Page<IndexVlogVO> pages = vlogService.getMyFriendVlogList(page);
2025-08-15 16:51:03 +08:00
return R.ok(pages);
}
2025-08-28 15:43:21 +08:00
2025-08-15 16:51:03 +08:00
@PostMapping("publish")
public R<Void> publish(@RequestBody VlogBO vlogBO) throws Exception {
2025-08-25 14:35:44 +08:00
LoginUser loginUser = LoginHelper.getLoginUser();
if (loginUser == null) {
throw new ServiceException("用户未登录");
}
vlogBO.setVlogerId(String.valueOf(loginUser.getUserId()));
2025-08-15 16:51:03 +08:00
String url = vlogBO.getUrl();
2025-08-28 15:43:21 +08:00
log.info("未审核视频地址:" + url);
2025-08-15 16:51:03 +08:00
String fileName = url.substring(url.lastIndexOf("/") + 1);
2025-08-28 15:43:21 +08:00
log.info("视频文件名称:" + fileName);
log.info("开始上传腾讯云点播:" + fileName);
2025-08-15 16:51:03 +08:00
String fileId = qcCloud.uploadViaTempFile(fileName);
2025-08-28 15:43:21 +08:00
log.info("视频发布ID:" + fileId);
2025-08-15 16:51:03 +08:00
vlogBO.setFileId(fileId);
// 删除minio文件
// MinIOUtils.removeFile(minIOConfig.getBucketName(),fileName);
// log.info("删除minio文件"+fileName);
// FIXME 校验VlogBO
vlogService.createVlog(vlogBO);
return R.ok();
}
2025-08-28 15:43:21 +08:00
2025-08-15 16:51:03 +08:00
@Tag(name = "我的公开视频列表")
@PostMapping("/myPublicList")
2025-08-21 15:47:21 +08:00
public R<Page<IndexVlogVO>> myPublicList(@RequestBody MyListBO bo, @RequestBody Page page) {
Page<IndexVlogVO> pages = vlogService.queryMyVlogList(bo, page);
2025-08-15 16:51:03 +08:00
return R.ok(pages);
}
@PostMapping("/like")
public R<Void> like(@RequestBody VlogBO vlogBO) {
2025-08-16 11:15:40 +08:00
LoginUser loginUser = LoginHelper.getLoginUser();
if (loginUser == null) {
throw new ServiceException("用户未登录");
}
String userId = String.valueOf(loginUser.getUserId());
String vlogId = vlogBO.getId();
vlogService.userLikeVlog(userId,vlogId );
2025-08-15 16:51:03 +08:00
return R.ok();
}
@PostMapping("/unlike")
public R<Void> unlike(@RequestBody VlogBO vlogBO) {
2025-08-16 11:15:40 +08:00
LoginUser loginUser = LoginHelper.getLoginUser();
if (loginUser == null) {
throw new ServiceException("用户未登录");
}
String userId = String.valueOf(loginUser.getUserId());
String vlogId = vlogBO.getId();
2025-08-15 16:51:03 +08:00
vlogService.userUnLikeVlog(userId, vlogId);
return R.ok();
}
@GetMapping("/read")
public R<Void> read(@RequestBody VlogBO vlogBO) {
2025-08-28 15:43:21 +08:00
LoginUser loginUser = LoginHelper.getLoginUser();
if (loginUser == null) {
throw new ServiceException("用户未登录");
}
vlogService.readVlog(loginUser.getUserId(), vlogBO.getId());
2025-08-28 15:43:21 +08:00
return R.ok();
}
2025-08-15 16:51:03 +08:00
@Tag(name = "手动触发缓存点赞最多视频")
@PostMapping("/cacheTopLikedVlogs")
public R<Void> cacheTopLikedVlogs(@RequestParam(defaultValue = "100") int limit) {
try {
2025-08-28 15:43:21 +08:00
// vlogService.cacheTopLikedVlogs(limit);
2025-08-15 16:51:03 +08:00
return R.ok();
} catch (Exception e) {
log.error("手动触发缓存点赞最多视频失败", e);
return R.fail("缓存失败: " + e.getMessage());
}
}
}