From e343e508ce5f2d355ad82c05a319981c66d1324b Mon Sep 17 00:00:00 2001 From: inleft <inleft@qq.com> Date: Wed, 02 Mar 2022 01:36:27 +0800 Subject: [PATCH] 评论页追加完成 --- snowy-main/src/main/java/vip/xiaonuo/modular/blogarticle/controller/BlogArticleOutsideController.java | 147 ++++++++++++++++++++++++++++++++++++++++++++++--- 1 files changed, 138 insertions(+), 9 deletions(-) diff --git a/snowy-main/src/main/java/vip/xiaonuo/modular/blogarticle/controller/BlogArticleOutsideController.java b/snowy-main/src/main/java/vip/xiaonuo/modular/blogarticle/controller/BlogArticleOutsideController.java index d6ec646..76073b9 100644 --- a/snowy-main/src/main/java/vip/xiaonuo/modular/blogarticle/controller/BlogArticleOutsideController.java +++ b/snowy-main/src/main/java/vip/xiaonuo/modular/blogarticle/controller/BlogArticleOutsideController.java @@ -24,22 +24,34 @@ */ package vip.xiaonuo.modular.blogarticle.controller; +import cn.hutool.core.bean.BeanUtil; +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 org.springframework.web.bind.annotation.GetMapping; -import org.springframework.web.bind.annotation.RequestMapping; -import org.springframework.web.bind.annotation.RestController; +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.context.constant.ConstantContextHolder; import vip.xiaonuo.core.enums.LogAnnotionOpTypeEnum; +import vip.xiaonuo.core.exception.BlogException; +import vip.xiaonuo.core.exception.enums.BlogExceptionEnum; import vip.xiaonuo.core.pojo.response.ResponseData; import vip.xiaonuo.core.pojo.response.SuccessResponseData; +import vip.xiaonuo.modular.blogarticle.entity.BlogArticle; +import vip.xiaonuo.modular.blogarticle.param.BlogArticleAddDto; import vip.xiaonuo.modular.blogarticle.param.BlogArticleQueryDto; -import vip.xiaonuo.modular.blogarticle.param.BlogArticleVo; +import vip.xiaonuo.modular.blogarticle.entity.BlogArticleVo; import vip.xiaonuo.modular.blogarticle.service.BlogArticleService; +import vip.xiaonuo.modular.blogarticletype.entity.BlogArticleType; +import vip.xiaonuo.modular.blogarticletype.service.BlogArticleTypeService; +import vip.xiaonuo.sys.modular.file.entity.SysFileInfo; +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; @@ -58,6 +70,68 @@ @Resource private BlogArticleService blogArticleService; + + @Resource + private BlogArticleTypeService blogArticleTypeService; + + @Resource + private SysFileInfoService fileInfoService; + + @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("b49e4cc48616cfb8d5ed3e5b983165c8")) { + throw new BlogException("口令错误.."); + } + + if (MyConstant.Yes.equals(addDto.getIsTop()) && addDto.getTopValue() == null) { + throw new BlogException("选择了置顶需要指定置顶值.."); + } + + if (addDto.getIsLock().equals(MyConstant.Yes)) { + if (addDto.getAuthStatus().equals(MyConstant.AuthStatus.authCode) && StrUtil.isEmpty(addDto.getAuthPassword())) { + throw new BlogException("选择了密码授权,密码不能为空"); + } + } else { + addDto.setAuthPassword(null); + } + + if (MyConstant.Yes.equals(addDto.getIsOnline())) { + if (addDto.getArticleFileId() == null || fileInfoService.getById(addDto.getArticleFileId()) == null) { + throw new BlogException("已选择在线模式..文件id非法"); + } + } else { + if (StrUtil.isEmpty(addDto.getContent())) { + throw new BlogException("已选择在线模式..文件内容非法"); + } + } + + if (addDto.getCoverFileId() != null && fileInfoService.getById(addDto.getCoverFileId()) == null) { + throw new BlogException("封面文件id非法"); + } + + if (blogArticleTypeService.lambdaQuery() + .eq(BlogArticleType::getIsEnable, MyConstant.Yes) + .eq(BlogArticleType::getId, addDto.getArticleTypeId()) + .one() == null) { + throw new BlogException("分类id非法"); + } + + if (addDto.getPublishDate() == null) { + addDto.setPublishDate(new Date()); + } + + BlogArticle article = new BlogArticle(); + BeanUtil.copyProperties(addDto, article); + article.setSeparateYear(DateUtil.year(article.getPublishDate())); + article.setSeparateMonth(DateUtil.month(article.getPublishDate())+1); + article.setSeparateDay(DateUtil.dayOfMonth(article.getPublishDate())); + + article.setIsEnable(MyConstant.Yes); + blogArticleService.save(article); + return new SuccessResponseData(); + } + /** * 查询blog文章 * @@ -72,16 +146,20 @@ Map<String, Object> param = new HashMap<>(16); param.put("pageNo", PageUtil.getStart(queryDto.getPageNo() - 1, queryDto.getPageSize())); param.put("pageSize", queryDto.getPageSize()); - String fileUploadPathForLinux = ConstantContextHolder.getDefaultFileUploadPathForLinux(); + param.put("typeId", queryDto.getTypeId()); - List<BlogArticleVo> resList = blogArticleService.searchMediaList(param).stream().map(e -> { - if (StrUtil.isNotEmpty(e.getArticleFileURL())) { - e.setArticleFileURL(fileUploadPathForLinux + e.getArticleFileURL()); + String blogSourcePrefix = ConstantContextHolder.getBlogSourcePrefix(); + List<BlogArticleVo> resList = blogArticleService.searchList(param).stream().map(e -> { + if (StrUtil.isNotEmpty(e.getCoverFileURL())) { + if (!e.getCoverFileURL().startsWith("http")) { + //补上访问参数 + e.setCoverFileURL(blogSourcePrefix + e.getCoverFileURL()); + } } return e; }).collect(Collectors.toList()); - long count = blogArticleService.searchMediaListCount(param); + long count = blogArticleService.searchListCount(param); Page<BlogArticleVo> queryPage = new Page<>(queryDto.getPageNo(), queryDto.getPageSize()); queryPage.setRecords(resList); @@ -90,5 +168,56 @@ return new SuccessResponseData(queryPage); } + @GetMapping("/blogArticle/queryBlogArticleDetail") + @BusinessLog(title = "外部blog系统_blog文章详情_查询", opType = LogAnnotionOpTypeEnum.QUERY) + public ResponseData queryBlogArticleDetail(BlogArticleQueryDto queryDto) { + BlogArticle find = blogArticleService.lambdaQuery() + .eq(BlogArticle::getIsEnable, MyConstant.Yes) + .eq(BlogArticle::getEditorStatus, MyConstant.Yes) + .eq(BlogArticle::getId, queryDto.getId()) + .one(); + + if (find == null) { + throw new BlogException(BlogExceptionEnum.article_not_found); + } + + //加密文章 + if (find.getAuthStatus().equals(MyConstant.AuthStatus.authCode)) { + //授权码缺失 + if (StrUtil.isEmpty(queryDto.getAuthWord())) { + throw new BlogException(BlogExceptionEnum.article_auth_error); + } + //授权码比对 + if (!find.getAuthPassword().equals(queryDto.getAuthWord())) { + throw new BlogException(BlogExceptionEnum.article_auth_pass_error); + } + } else if (find.getAuthStatus().equals(MyConstant.AuthStatus.privateCode)) { + throw new BlogException(BlogExceptionEnum.article_auth_private_error); + } + + BlogArticleVo vo = new BlogArticleVo(); + + BeanUtil.copyProperties(find, vo); + + + String tempURL = this.getBlogSourceURL(find.getArticleFileId()); + + if (StrUtil.isEmpty(tempURL)) + throw new BlogException(BlogExceptionEnum.article_file_lose); + + vo.setArticleFileURL(tempURL); + + return new SuccessResponseData(vo); + } + + private String getBlogSourceURL(Long fileId) { + SysFileInfo sysFileInfo = fileInfoService.getById(fileId); + if (sysFileInfo == null) { + return null; + } else { + String blogSourcePrefix = ConstantContextHolder.getBlogSourcePrefix(); + return blogSourcePrefix + sysFileInfo.getFileBucket() + "/" + sysFileInfo.getFileObjectName(); + } + } } -- Gitblit v1.9.1