123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145 |
- package com.fdkankan.fusion.service.impl;
- import cn.hutool.core.io.FileUtil;
- import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
- import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
- import com.fdkankan.common.constant.ErrorCode;
- import com.fdkankan.fusion.common.FilePath;
- import com.fdkankan.fusion.common.ResultCode;
- import com.fdkankan.fusion.common.util.VideoUtil;
- import com.fdkankan.fusion.entity.CaseEntity;
- import com.fdkankan.fusion.entity.CaseVideoFolder;
- import com.fdkankan.fusion.exception.BusinessException;
- import com.fdkankan.fusion.entity.CaseVideo;
- import com.fdkankan.fusion.mapper.ICaseVideoMapper;
- import com.fdkankan.fusion.request.CaseParam;
- import com.fdkankan.fusion.request.CaseVideoParam;
- import com.fdkankan.fusion.service.ICaseService;
- import com.fdkankan.fusion.service.ICaseVideoFolderService;
- import com.fdkankan.fusion.service.ICaseVideoService;
- import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
- import com.fdkankan.fyun.oss.UploadToOssUtil;
- import org.apache.commons.lang3.StringUtils;
- import org.springframework.beans.factory.annotation.Autowired;
- import org.springframework.beans.factory.annotation.Value;
- import org.springframework.stereotype.Service;
- import org.springframework.web.multipart.MultipartFile;
- import java.io.File;
- import java.io.IOException;
- import java.lang.reflect.Field;
- import java.util.ArrayList;
- import java.util.LinkedHashSet;
- import java.util.List;
- /**
- * <p>
- * 服务实现类
- * </p>
- *
- * @author
- * @since 2022-07-29
- */
- @Service
- public class CaseVideoServiceImpl extends ServiceImpl<ICaseVideoMapper, CaseVideo> implements ICaseVideoService {
- @Autowired
- UploadToOssUtil uploadToOssUtil;
- @Autowired
- ICaseVideoFolderService videoFolderService;
- @Autowired
- ICaseService caseService;
- @Autowired
- UploadService uploadService;
- @Value("${upload.query-path}")
- private String queryPath;
- @Override
- public List<CaseVideo> getAllList(Integer folderId) {
- if(folderId == null){
- throw new BusinessException(ErrorCode.MISSING_REQUIRED_PARAMETERS);
- }
- QueryWrapper<CaseVideo> wrapper = new QueryWrapper<>();
- wrapper.lambda().eq(CaseVideo::getFolderId,folderId);
- wrapper.lambda().orderByAsc(CaseVideo::getSort);
- wrapper.lambda().orderByAsc(CaseVideo::getCreateTime);
- return this.list(wrapper);
- }
- @Override
- public void uploadAddVideo(MultipartFile[] files, Integer folderId,Integer caseId) throws IOException {
- if(files.length <=0 || caseId == null){
- throw new BusinessException(ErrorCode.MISSING_REQUIRED_PARAMETERS);
- }
- CaseEntity caseEntity = caseService.getById(caseId);
- if(caseEntity == null){
- throw new BusinessException(ResultCode.CASE_NOT_EXIST);
- }
- CaseVideoFolder videoFolder = videoFolderService.getByIdIfNotNew(folderId,caseId);
- if(videoFolder == null){
- throw new BusinessException(ResultCode.FOLDER_NOT_EXIST);
- }
- videoFolderService.deleteMergeUrl(videoFolder.getVideoMergeUrl());
- this.deleteByFolderId(folderId);
- //替换文件夹中文件
- List<CaseVideo> videoList = new ArrayList<>();
- Integer sort = 1;
- LinkedHashSet<String> filePathSet = new LinkedHashSet<>();
- for (MultipartFile file : files) {
- String ossPath = uploadService.uploadFile(file, true, String.format(FilePath.VIDEO_OSS_PATH,videoFolder.getVideoFolderId())+"/",filePathSet);
- CaseVideo caseVideo = new CaseVideo();
- caseVideo.setFolderId(videoFolder.getVideoFolderId());
- caseVideo.setVideoPath(ossPath);
- caseVideo.setVideoName(file.getName());
- caseVideo.setSort(sort);
- videoList.add(caseVideo);
- sort ++;
- }
- this.saveBatch(videoList);
- String mergeLocalName = VideoUtil.mergeVideo(filePathSet, FilePath.VIDEO_LOCAL_PATH);
- if(mergeLocalName == null){
- throw new BusinessException(ResultCode.MERGER_VIDEO_ERROR);
- }
- String mergeLocalPath = FilePath.VIDEO_LOCAL_PATH +"/"+mergeLocalName;
- String ossKey = String.format(FilePath.VIDEO_OSS_PATH,videoFolder.getVideoFolderId()) +"/"+mergeLocalName;
- uploadToOssUtil.upload(mergeLocalPath,ossKey);
- uploadToOssUtil.upload(mergeLocalPath.replace(".mp4",".jpg"),ossKey.replace(".mp4",".jpg"));
- videoFolder.setVideoMergeUrl(queryPath + ossKey);
- videoFolder.setVideoFolderCover(null);
- videoFolderService.updateById(videoFolder);
- FileUtil.del(mergeLocalPath);
- FileUtil.del(mergeLocalPath.replace(".mp4",".jpg"));
- }
- @Override
- public void deleteByFolderId(Integer videoFolderId) {
- LambdaQueryWrapper<CaseVideo> wrapper = new LambdaQueryWrapper<>();
- wrapper.eq(CaseVideo::getFolderId,videoFolderId);
- List<CaseVideo> list = this.list(wrapper);
- if(list.size() <=0){
- return;
- }
- for (CaseVideo caseVideo : list) {
- this.delete(caseVideo.getVideoId());
- }
- }
- @Override
- public void delete(Integer videoId) {
- CaseVideo caseVideo = this.getById(videoId);
- this.removeById(videoId);
- try {
- String replace = caseVideo.getVideoPath().replace(queryPath, "");
- uploadToOssUtil.delete(replace);
- }catch (Exception e){
- e.printStackTrace();
- }
- }
- }
|