From 552004d0902687de16cd50e3378d4d6671d7f015 Mon Sep 17 00:00:00 2001
From: inleft <inleft@qq.com>
Date: Mon, 21 Feb 2022 18:46:36 +0800
Subject: [PATCH] 文章添加

---
 snowy-main/src/main/java/vip/xiaonuo/modular/blogarticle/controller/BlogArticleOutsideController.java |   69 +++++++++++++++++++++-
 snowy-base/snowy-core/src/main/java/vip/xiaonuo/core/exception/enums/BlogExceptionEnum.java           |    2 
 snowy-main/src/main/java/vip/xiaonuo/modular/blogarticle/param/BlogArticleAddDto.java                 |   52 +++++++++++------
 3 files changed, 99 insertions(+), 24 deletions(-)

diff --git a/snowy-base/snowy-core/src/main/java/vip/xiaonuo/core/exception/enums/BlogExceptionEnum.java b/snowy-base/snowy-core/src/main/java/vip/xiaonuo/core/exception/enums/BlogExceptionEnum.java
index 5887c48..6713be1 100644
--- a/snowy-base/snowy-core/src/main/java/vip/xiaonuo/core/exception/enums/BlogExceptionEnum.java
+++ b/snowy-base/snowy-core/src/main/java/vip/xiaonuo/core/exception/enums/BlogExceptionEnum.java
@@ -48,6 +48,8 @@
     article_auth_private_error(3, "那属于他的自留地,以后再来探索吧.."),
     article_not_found(4, "这是黑洞..什么也没有"),
     article_file_lose(5, "啊噢,该文件已丢失.."),
+
+
  ;
 
     private final Integer code;
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 0889227..843e2d0 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
@@ -29,9 +29,8 @@
 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;
@@ -41,13 +40,17 @@
 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.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;
@@ -68,7 +71,62 @@
 
 
     @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("8616CFB8D5ED3E5B")) {
+            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);
+        System.out.println(article.toString());
+
+//        blogArticleService.add(blogArticleParam);
+        return new SuccessResponseData();
+    }
 
     /**
      * 查询blog文章
@@ -139,10 +197,11 @@
 
         if (queryDto.getId() % 2 == 0) {
             String tempURL = this.getBlogSourceURL(find.getArticleFileId());
-            if (StrUtil.isEmpty(tempURL))
-                throw new BlogException(BlogExceptionEnum.article_file_lose);
+//            if (StrUtil.isEmpty(tempURL))
+//                throw new BlogException(BlogExceptionEnum.article_file_lose);
 
             vo.setArticleFileURL(tempURL);
+            vo.setArticleFileURL("http://t.inleft.com/share/book/blog/a岛神灯.md");
         } else {
             vo.setArticleFileURL("http://t.inleft.com/share/book/blog/es-search.md");
         }
diff --git a/snowy-main/src/main/java/vip/xiaonuo/modular/blogarticle/param/BlogArticleAddDto.java b/snowy-main/src/main/java/vip/xiaonuo/modular/blogarticle/param/BlogArticleAddDto.java
index 23d0ca4..b52fcee 100644
--- a/snowy-main/src/main/java/vip/xiaonuo/modular/blogarticle/param/BlogArticleAddDto.java
+++ b/snowy-main/src/main/java/vip/xiaonuo/modular/blogarticle/param/BlogArticleAddDto.java
@@ -1,22 +1,28 @@
 
 package vip.xiaonuo.modular.blogarticle.param;
 
+import com.fasterxml.jackson.annotation.JsonFormat;
 import lombok.Data;
 import vip.xiaonuo.core.pojo.base.param.BaseParam;
 
 import javax.validation.constraints.NotBlank;
+import javax.validation.constraints.NotEmpty;
 import javax.validation.constraints.NotNull;
+import java.util.Date;
+import java.util.List;
 
 /**
-* blog文章参数类
+ * blog文章参数类
  *
  * @author inleft
  * @date 2022-02-09 18:21:14
-*/
+ */
 @Data
 public class BlogArticleAddDto extends BaseParam {
 
 
+    @NotEmpty(message = "需要口令", groups = {add.class, edit.class})
+    private String secret;
 
     /**
      * 文章标题
@@ -25,21 +31,29 @@
     private String title;
 
     /**
-     * 文章文件id
-     */
-    @NotNull(message = "文章文件id不能为空,请检查articleFileId参数", groups = {add.class, edit.class})
-    private Long articleFileId;
-
-    /**
-     * 文件类型
-     */
-    private Integer articleFileType;
-
-    /**
      * 文章分类
      */
     @NotNull(message = "文章分类不能为空,请检查articleTypeId参数", groups = {add.class, edit.class})
     private Long articleTypeId;
+
+    @NotNull
+    private Integer isOnline;
+
+    /**
+     * 文章文件id
+     */
+    private Long articleFileId;
+
+    /**
+     * 在线生成文件内容
+     */
+    private String content;
+
+    /**
+     * 文件类型
+     */
+    @NotNull(message = "文件类型不能为空,请检查articleFileType参数", groups = {add.class, edit.class})
+    private Integer articleFileType;
 
     /**
      * 文章引言
@@ -52,14 +66,10 @@
     private Long coverFileId;
 
     /**
-     * 上次编辑时间
-     */
-    private String lastEditorDate;
-
-    /**
      * 发布时间
      */
-    private String publishDate;
+    @JsonFormat(timezone = "GMT+8", pattern = "yyyy-MM-dd HH:mm:ss")
+    private Date publishDate;
 
     /**
      * 是否置顶
@@ -72,9 +82,11 @@
      */
     private Integer topValue;
 
+    private Integer isLock;
     /**
      * 公开状态
      */
+    @NotNull(message = "公开状态不能为空,请检查authStatus参数", groups = {add.class, edit.class})
     private Integer authStatus;
 
     /**
@@ -85,7 +97,9 @@
     /**
      * 编辑状态
      */
+    @NotNull(message = "编辑状态不能为空,请检查editorStatus参数", groups = {add.class, edit.class})
     private Integer editorStatus;
 
+    private List<String> tags;
 
 }

--
Gitblit v1.9.1