| | |
| | | package vip.xiaonuo.modular.blogarticle.controller; |
| | | |
| | | import cn.hutool.core.bean.BeanUtil; |
| | | import cn.hutool.core.collection.CollUtil; |
| | | import cn.hutool.core.date.DateUnit; |
| | | import cn.hutool.core.date.DateUtil; |
| | | import cn.hutool.core.util.PageUtil; |
| | | import cn.hutool.core.util.StrUtil; |
| | | import cn.hutool.crypto.SecureUtil; |
| | | import com.baomidou.mybatisplus.extension.plugins.pagination.Page; |
| | | import lombok.extern.slf4j.Slf4j; |
| | | import org.springframework.validation.annotation.Validated; |
| | | import org.springframework.web.bind.annotation.*; |
| | | import vip.xiaonuo.core.annotion.BusinessLog; |
| | | import vip.xiaonuo.core.consts.MyConstant; |
| | | import vip.xiaonuo.core.consts.SymbolConstant; |
| | | import vip.xiaonuo.core.context.constant.ConstantContextHolder; |
| | | import vip.xiaonuo.core.enums.LogAnnotionOpTypeEnum; |
| | | import vip.xiaonuo.core.exception.BlogException; |
| | |
| | | import vip.xiaonuo.sys.modular.file.service.SysFileInfoService; |
| | | |
| | | import javax.annotation.Resource; |
| | | import java.util.Date; |
| | | import java.util.HashMap; |
| | | import java.util.List; |
| | | import java.util.Map; |
| | | import java.util.*; |
| | | import java.util.concurrent.Future; |
| | | import java.util.function.Function; |
| | | import java.util.stream.Collectors; |
| | | |
| | | /** |
| | |
| | | @PostMapping("/blogArticle/add") |
| | | @BusinessLog(title = "外部blog系统_blog文章_增加", opType = LogAnnotionOpTypeEnum.ADD) |
| | | public ResponseData add(@RequestBody @Validated(BlogArticleAddDto.add.class) BlogArticleAddDto addDto) { |
| | | if (!SecureUtil.md5(addDto.getSecret()).equals(ConstantContextHolder.getPushCode())) { |
| | | if (!addDto.getSecret().equals(ConstantContextHolder.getPushCode())) { |
| | | throw new BlogException("口令错误.."); |
| | | } |
| | | |
| | |
| | | param.put("pageSize", queryDto.getPageSize()); |
| | | param.put("typeId", queryDto.getTypeId()); |
| | | param.put("fileType", queryDto.getFileType()); |
| | | param.put("faceExcludeFile", MyConstant.faceExcludeFile); |
| | | |
| | | String blogSourcePrefix = ConstantContextHolder.getBlogSourcePrefix(); |
| | | |
| | |
| | | }).collect(Collectors.toList()); |
| | | |
| | | long count = blogArticleService.searchListCount(param); |
| | | |
| | | Page<BlogArticleVo> queryPage = new Page<>(queryDto.getPageNo(), queryDto.getPageSize()); |
| | | queryPage.setRecords(resList); |
| | | queryPage.setTotal(count); |
| | | |
| | | return new SuccessResponseData(queryPage); |
| | | } |
| | | |
| | | |
| | | /** |
| | | * 查询blog文章(月台专用列表) |
| | | * |
| | | * @author inleft |
| | | * @date 2022-02-09 18:20:22 |
| | | */ |
| | | @GetMapping("/blogArticle/platform") |
| | | @BusinessLog(title = "外部blog系统_blog月台_查询", opType = LogAnnotionOpTypeEnum.QUERY) |
| | | public ResponseData platform(BlogArticleQueryDto queryDto) { |
| | | |
| | | Map<String, Object> param = new HashMap<>(16); |
| | | param.put("pageNo", PageUtil.getStart(queryDto.getPageNo() - 1, queryDto.getPageSize())); |
| | | param.put("pageSize", queryDto.getPageSize()); |
| | | param.put("id", queryDto.getId()); |
| | | |
| | | if (queryDto.getActiveKey().equals(MyConstant.platformType.type_1)) { |
| | | param.put("typeIds", new Long[]{66L});//临时id |
| | | param.put("fileType", MyConstant.FileType.fileTypeVideo_3); |
| | | } else if (queryDto.getActiveKey().equals(MyConstant.platformType.type_2)) { |
| | | param.put("typeIds", new Long[]{55L});//临时id,后续需要修改(前方高能分类) |
| | | param.put("fileType", MyConstant.FileType.fileTypeVideo_3); |
| | | } else if (queryDto.getActiveKey().equals(MyConstant.platformType.type_3)) { |
| | | param.put("typeIds", new Long[]{99L});//临时id,后续需要修改(图组) |
| | | param.put("fileType", MyConstant.FileType.fileTypePictures_5); |
| | | } else { |
| | | param.put("typeIds", new Long[]{66L});//临时id,后续需要修改(音乐分类) |
| | | param.put("fileType", MyConstant.FileType.fileTypeVideo_3); |
| | | } |
| | | |
| | | String blogSourcePrefix = ConstantContextHolder.getBlogSourcePrefix(); |
| | | |
| | | //空类型查询条件,排除笔记系列,按更新时间倒序 |
| | | //含有类型查询,按发布时间倒序 |
| | | List<BlogArticleVo> resList = blogArticleService.searchPlatformList(param).stream().map(e -> { |
| | | if (StrUtil.isNotEmpty(e.getCoverFileURL())) { |
| | | if (!e.getCoverFileURL().startsWith("http")) { |
| | | //补上访问参数 |
| | | e.setCoverFileURL(blogSourcePrefix + e.getCoverFileURL()); |
| | | } |
| | | } |
| | | |
| | | //补充视频组,图片组的url |
| | | if (StrUtil.isNotEmpty(e.getPictureIds())) { |
| | | e.setPictureUrlList(this.getBlogSourceURLBatch(Arrays.stream(e.getPictureIds().split(SymbolConstant.COMMA)).collect(Collectors.toList()))); |
| | | } |
| | | |
| | | return e; |
| | | }).collect(Collectors.toList()); |
| | | |
| | | long count = blogArticleService.searchPlatformListCount(param); |
| | | |
| | | Page<BlogArticleVo> queryPage = new Page<>(queryDto.getPageNo(), queryDto.getPageSize()); |
| | | queryPage.setRecords(resList); |
| | |
| | | |
| | | BeanUtil.copyProperties(find, vo); |
| | | |
| | | //补充视频组,图片组的url |
| | | if (StrUtil.isNotEmpty(vo.getPictureIds())) { |
| | | vo.setPictureUrlList(this.getBlogSourceURLBatch(Arrays.stream(vo.getPictureIds().split(SymbolConstant.COMMA)).collect(Collectors.toList()))); |
| | | } |
| | | if (StrUtil.isNotEmpty(vo.getVideoIds())) { |
| | | vo.setVideoUrlList(this.getBlogSourceURLBatch(Arrays.stream(vo.getVideoIds().split(SymbolConstant.COMMA)).collect(Collectors.toList()))); |
| | | } |
| | | |
| | | |
| | | String tempURL = this.getBlogSourceURL(find.getArticleFileId()); |
| | | |
| | |
| | | } |
| | | } |
| | | |
| | | private List<String> getBlogSourceURLBatch(List<String> fileIds) { |
| | | Map<String, SysFileInfo> sysFileInfoMap = fileInfoService.listByIds(fileIds).stream().collect(Collectors.toMap(e -> e.getId().toString(), Function.identity(), (k1, k2) -> k1)); |
| | | if (CollUtil.isEmpty(sysFileInfoMap)) { |
| | | return null; |
| | | } else { |
| | | List<String> urlList = new ArrayList<>(fileIds.size()); |
| | | String blogSourcePrefix = ConstantContextHolder.getBlogSourcePrefix(); |
| | | |
| | | SysFileInfo sysFileInfo; |
| | | for (String fileId : fileIds) { |
| | | sysFileInfo = sysFileInfoMap.getOrDefault(fileId, null); |
| | | if (sysFileInfo == null) { |
| | | urlList.add(null); |
| | | } else { |
| | | urlList.add(blogSourcePrefix + sysFileInfo.getFileBucket() + "/" + sysFileInfo.getFileObjectName()); |
| | | } |
| | | } |
| | | return urlList; |
| | | } |
| | | } |
| | | |
| | | } |