From a56380c00de70b79f7fd4f986139e1c342821bac Mon Sep 17 00:00:00 2001
From: Helius <wangdoubleone@gmail.com>
Date: Mon, 11 Jul 2022 22:21:23 +0800
Subject: [PATCH] fix
---
src/main/java/com/xcong/farmer/cms/modules/core/service/impl/CmsCoreServiceImpl.java | 9 +++++++++
src/main/java/com/xcong/farmer/cms/core/node/Template.java | 18 +++++++++++++++---
src/main/java/com/xcong/farmer/cms/modules/core/controller/CmsCoreController.java | 2 +-
src/main/java/com/xcong/farmer/cms/modules/system/service/IReleaseService.java | 3 ++-
src/main/java/com/xcong/farmer/cms/modules/system/service/Impl/ReleaseServiceImpl.java | 28 +++++++++++++++++++++-------
5 files changed, 48 insertions(+), 12 deletions(-)
diff --git a/src/main/java/com/xcong/farmer/cms/core/node/Template.java b/src/main/java/com/xcong/farmer/cms/core/node/Template.java
index 6a7a49c..ab9b54e 100644
--- a/src/main/java/com/xcong/farmer/cms/core/node/Template.java
+++ b/src/main/java/com/xcong/farmer/cms/core/node/Template.java
@@ -70,8 +70,20 @@
if (!new Integer(1).equals(page)) {
this.name = name + "_" + page;
}
- } else {
-
+ } else if ("search".equals(templateType)){
+ Object templateName = system.get("templateName");
+ if (templateName != null) {
+ this.name = String.valueOf(templateName);
+ } else {
+ this.name = "search";
+ }
+ } else if ("message".equals(templateType)) {
+ Object templateName = system.get("templateName");
+ if (templateName != null) {
+ this.name = String.valueOf(templateName);
+ } else {
+ this.name = "message";
+ }
}
}
@@ -107,7 +119,7 @@
file.mkdirs();
}
- FileOutputStream outputStream = new FileOutputStream(path +this.name + suffix);
+ FileOutputStream outputStream = new FileOutputStream(path + this.name + suffix);
outputStream.write(html.getBytes());
outputStream.close();
} catch (IOException e) {
diff --git a/src/main/java/com/xcong/farmer/cms/modules/core/controller/CmsCoreController.java b/src/main/java/com/xcong/farmer/cms/modules/core/controller/CmsCoreController.java
index 4aadc03..f65150f 100644
--- a/src/main/java/com/xcong/farmer/cms/modules/core/controller/CmsCoreController.java
+++ b/src/main/java/com/xcong/farmer/cms/modules/core/controller/CmsCoreController.java
@@ -45,7 +45,7 @@
@PostMapping(value = "/releaseIndex")
public Result releaseIndex() {
Long companyId = LoginUserUtil.getCompanyId();
- releaseService.releaseIndex(companyId);
+ releaseService.releaseIndex(companyId, true);
return Result.ok("success");
}
diff --git a/src/main/java/com/xcong/farmer/cms/modules/core/service/impl/CmsCoreServiceImpl.java b/src/main/java/com/xcong/farmer/cms/modules/core/service/impl/CmsCoreServiceImpl.java
index 7a2eb81..daf39db 100644
--- a/src/main/java/com/xcong/farmer/cms/modules/core/service/impl/CmsCoreServiceImpl.java
+++ b/src/main/java/com/xcong/farmer/cms/modules/core/service/impl/CmsCoreServiceImpl.java
@@ -112,6 +112,15 @@
public void process(Map<String, Object> data, String templateType, String templateName) {
data.put("templateType", templateType);
globalData(data);
+
+ if ("search".equals(templateType)) {
+ templateName = "search.html";
+ }
+
+ if ("message".equals(templateType)) {
+ templateName = "message.html";
+ }
+
try {
cfg.process(data, templateName);
} catch (Exception e) {
diff --git a/src/main/java/com/xcong/farmer/cms/modules/system/service/IReleaseService.java b/src/main/java/com/xcong/farmer/cms/modules/system/service/IReleaseService.java
index 31d3ed1..2af8ed0 100644
--- a/src/main/java/com/xcong/farmer/cms/modules/system/service/IReleaseService.java
+++ b/src/main/java/com/xcong/farmer/cms/modules/system/service/IReleaseService.java
@@ -9,7 +9,8 @@
void releaseColumns(int type, Long companyId);
- void releaseIndex(Long companyId);
+ void releaseIndex(Long companyId, boolean hasSearch);
void releaseAll(Long companyId);
+
}
diff --git a/src/main/java/com/xcong/farmer/cms/modules/system/service/Impl/ReleaseServiceImpl.java b/src/main/java/com/xcong/farmer/cms/modules/system/service/Impl/ReleaseServiceImpl.java
index ff8221c..b647660 100644
--- a/src/main/java/com/xcong/farmer/cms/modules/system/service/Impl/ReleaseServiceImpl.java
+++ b/src/main/java/com/xcong/farmer/cms/modules/system/service/Impl/ReleaseServiceImpl.java
@@ -4,8 +4,11 @@
import com.xcong.farmer.cms.modules.core.service.ICmsCoreService;
import com.xcong.farmer.cms.modules.system.entity.ArticleEntity;
import com.xcong.farmer.cms.modules.system.entity.ColumnEntity;
+import com.xcong.farmer.cms.modules.system.entity.WebSettingEntity;
import com.xcong.farmer.cms.modules.system.mapper.ArticleMapper;
import com.xcong.farmer.cms.modules.system.mapper.ColumnMapper;
+import com.xcong.farmer.cms.modules.system.mapper.CompanyMapper;
+import com.xcong.farmer.cms.modules.system.mapper.WebSetMapper;
import com.xcong.farmer.cms.modules.system.service.IReleaseService;
import com.xcong.farmer.cms.modules.system.util.LoginUserUtil;
import lombok.extern.slf4j.Slf4j;
@@ -22,8 +25,8 @@
import java.util.concurrent.TimeUnit;
/**
- * @TODO 发布时,index存在重复发布的情况,可优化。用线程notify唤醒。
* @author wzy
+ * @TODO 发布时,index存在重复发布的情况,可优化。用线程notify唤醒。
* @date 2022-07-05
**/
@Slf4j
@@ -38,6 +41,9 @@
@Autowired
private ICmsCoreService cmsCoreService;
+
+ @Autowired
+ private WebSetMapper webSetMapper;
private final Executor executor = new ThreadPoolExecutor(5, 20, 600, TimeUnit.SECONDS, new LinkedBlockingQueue<Runnable>());
@@ -54,7 +60,7 @@
data.put("id", article.getId());
data.put("companyId", companyId);
- executor.execute(()->{
+ executor.execute(() -> {
log.info("执行文章发布");
cmsCoreService.articleProcess(data, column.getArticleTemplate(), column.getPath());
this.releaseColumn(column.getId(), 1, companyId);
@@ -70,7 +76,7 @@
}
}
- this.releaseIndex(companyId);
+ this.releaseIndex(companyId, false);
});
}
@@ -104,7 +110,7 @@
cmsCoreService.columnProcess(parentMap, parentColumn.getListTemplate());
}
- releaseIndex(companyId);
+ releaseIndex(companyId, false);
});
if (type != 1) {
@@ -134,7 +140,7 @@
}
}
- releaseIndex(companyId);
+ releaseIndex(companyId, false);
});
}
@@ -170,11 +176,19 @@
}
@Override
- public void releaseIndex(Long companyId) {
+ public void releaseIndex(Long companyId, boolean hasSearch) {
Map<String, Object> map = new HashMap<>();
map.put("companyId", companyId);
- cmsCoreService.indexProcess(map, null);
+ WebSettingEntity webSetting = webSetMapper.selectByCompanyId(companyId);
+
+ cmsCoreService.indexProcess(map, webSetting.getIndexTemplate());
+ if (hasSearch) {
+ executor.execute(() -> {
+ cmsCoreService.process(map, "search", webSetting.getSearchTemplate());
+ cmsCoreService.process(map, "message", webSetting.getMsgTemplate());
+ });
+ }
}
@Override
--
Gitblit v1.9.1