From 73ca1aebdc6b577b709a76706ead39e3bd63fc5d Mon Sep 17 00:00:00 2001
From: jiangping <jp@doumee.com>
Date: 星期五, 04 七月 2025 11:10:48 +0800
Subject: [PATCH] Merge remote-tracking branch 'origin/master'
---
server/src/main/java/com/doumee/service/business/impl/SeoServiceImpl.java | 169 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++
1 files changed, 169 insertions(+), 0 deletions(-)
diff --git a/server/src/main/java/com/doumee/service/business/impl/SeoServiceImpl.java b/server/src/main/java/com/doumee/service/business/impl/SeoServiceImpl.java
new file mode 100644
index 0000000..4a10c23
--- /dev/null
+++ b/server/src/main/java/com/doumee/service/business/impl/SeoServiceImpl.java
@@ -0,0 +1,169 @@
+package com.doumee.service.business.impl;
+
+import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
+import com.doumee.core.constants.Constants;
+import com.doumee.core.constants.ResponseStatus;
+import com.doumee.core.exception.BusinessException;
+import com.doumee.core.model.LoginUserInfo;
+import com.doumee.core.model.PageData;
+import com.doumee.core.model.PageWrap;
+import com.doumee.core.utils.Utils;
+import com.doumee.dao.business.SeoMapper;
+import com.doumee.dao.business.model.Carousel;
+import com.doumee.dao.business.model.Seo;
+import com.doumee.dao.system.model.SystemUser;
+import com.doumee.service.business.SeoService;
+import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
+import com.baomidou.mybatisplus.core.conditions.update.UpdateWrapper;
+import com.baomidou.mybatisplus.core.metadata.IPage;
+import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
+import com.github.yulichang.query.MPJQueryWrapper;
+import com.github.yulichang.wrapper.MPJLambdaWrapper;
+import org.apache.commons.lang3.StringUtils;
+import org.apache.shiro.SecurityUtils;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.stereotype.Service;
+import org.springframework.util.CollectionUtils;
+
+import java.util.Date;
+import java.util.List;
+import java.util.Objects;
+
+/**
+ * 缃戠珯SEO閰嶇疆Service瀹炵幇
+ * @author 姹熻箘韫�
+ * @since 2025/07/02 11:35
+ */
+@Service
+public class SeoServiceImpl implements SeoService {
+
+ @Autowired
+ private SeoMapper seoMapper;
+
+ @Override
+ public Integer create(Seo seo) {
+ LoginUserInfo user = (LoginUserInfo) SecurityUtils.getSubject().getPrincipal();
+ if(Objects.isNull(seo)
+ || Objects.isNull(seo.getPageAddr())
+ || Objects.isNull(seo.getName())
+ ){
+ throw new BusinessException(ResponseStatus.BAD_REQUEST);
+ }
+ if(seoMapper.selectCount(new LambdaQueryWrapper<Seo>().eq(Seo::getIsdeleted,Constants.ZERO)
+ .eq(Seo::getPageAddr,seo.getPageAddr())) >0 ){
+ throw new BusinessException(ResponseStatus.BAD_REQUEST.getCode(),"璇ラ〉闈㈠湴鍧�宸查厤缃紝璇峰嬁閲嶅閰嶇疆锛�");
+ }
+ seo.setIsdeleted(Constants.ZERO);
+ seo.setCreateDate(new Date());
+ seo.setCreator(user.getId());
+ seo.setEditDate(new Date());
+ seo.setEditor(user.getId());
+ seoMapper.insert(seo);
+ return seo.getId();
+ }
+
+ @Override
+ public void deleteById(Integer id) {
+ LoginUserInfo user = (LoginUserInfo) SecurityUtils.getSubject().getPrincipal();
+ seoMapper.update(new UpdateWrapper<Seo>().lambda()
+ .set(Seo::getEditDate,new Date())
+ .set(Seo::getEditor,user.getId())
+ .set(Seo::getIsdeleted,Constants.ONE)
+ .eq(Seo::getId,id));
+ }
+
+ @Override
+ public void delete(Seo seo) {
+ UpdateWrapper<Seo> deleteWrapper = new UpdateWrapper<>(seo);
+ seoMapper.delete(deleteWrapper);
+ }
+
+ @Override
+ public void deleteByIdInBatch(List<Integer> ids) {
+ if (CollectionUtils.isEmpty(ids)) {
+ return;
+ }
+ for(Integer id :ids){
+ this.deleteById(id);
+ }
+ }
+
+ @Override
+ public void updateById(Seo seo) {
+ LoginUserInfo user = (LoginUserInfo) SecurityUtils.getSubject().getPrincipal();
+ if(StringUtils.isNotBlank(seo.getPageAddr()) &&
+ seoMapper.selectCount(new LambdaQueryWrapper<Seo>().eq(Seo::getIsdeleted,Constants.ZERO)
+ .eq(Seo::getPageAddr,seo.getPageAddr()).ne(Seo::getId,seo.getId())) >0 ){
+ throw new BusinessException(ResponseStatus.BAD_REQUEST.getCode(),"璇ラ〉闈㈠湴鍧�宸查厤缃紝璇峰嬁閲嶅閰嶇疆锛�");
+ }
+ seo.setIsdeleted(Constants.ZERO);
+ seo.setEditDate(new Date());
+ seo.setEditor(user.getId());
+ seoMapper.updateById(seo);
+ }
+
+ @Override
+ public void updateByIdInBatch(List<Seo> seos) {
+ if (CollectionUtils.isEmpty(seos)) {
+ return;
+ }
+ for (Seo seo: seos) {
+ this.updateById(seo);
+ }
+ }
+
+ @Override
+ public Seo findById(Integer id) {
+ return seoMapper.selectById(id);
+ }
+
+ @Override
+ public Seo findOne(Seo seo) {
+ QueryWrapper<Seo> wrapper = new QueryWrapper<>(seo);
+ return seoMapper.selectOne(wrapper);
+ }
+
+ @Override
+ public List<Seo> findList(Seo seo) {
+ seo.setIsdeleted(Constants.ZERO);
+ QueryWrapper<Seo> wrapper = new QueryWrapper<>(seo);
+ return seoMapper.selectList(wrapper);
+ }
+
+ @Override
+ public PageData<Seo> findPage(PageWrap<Seo> pageWrap) {
+ IPage<Seo> page = new Page<>(pageWrap.getPage(), pageWrap.getCapacity());
+ MPJLambdaWrapper<Seo> queryWrapper = new MPJLambdaWrapper<Seo>();
+ Utils.MP.blankToNull(pageWrap.getModel());
+ pageWrap.getModel().setIsdeleted(Constants.ZERO);
+ queryWrapper.selectAll(Seo.class )
+ .selectAs(SystemUser::getUsername,Seo::getEditorName)
+ .leftJoin(SystemUser.class,SystemUser::getId,Seo::getEditor)
+ .eq(pageWrap.getModel().getId() != null, Seo::getId, pageWrap.getModel().getId())
+ .eq(pageWrap.getModel().getCreator() != null, Seo::getCreator, pageWrap.getModel().getCreator())
+ .ge(pageWrap.getModel().getCreateDate() != null, Seo::getCreateDate, Utils.Date.getStart(pageWrap.getModel().getCreateDate()))
+ .le(pageWrap.getModel().getCreateDate() != null, Seo::getCreateDate, Utils.Date.getEnd(pageWrap.getModel().getCreateDate()))
+ .eq(pageWrap.getModel().getEditor() != null, Seo::getEditor, pageWrap.getModel().getEditor())
+ .ge(pageWrap.getModel().getEditDate() != null, Seo::getEditDate, Utils.Date.getStart(pageWrap.getModel().getEditDate()))
+ .le(pageWrap.getModel().getEditDate() != null, Seo::getEditDate, Utils.Date.getEnd(pageWrap.getModel().getEditDate()))
+ .eq(pageWrap.getModel().getIsdeleted() != null, Seo::getIsdeleted, pageWrap.getModel().getIsdeleted())
+ .eq(pageWrap.getModel().getRemark() != null, Seo::getRemark, pageWrap.getModel().getRemark())
+ .like(pageWrap.getModel().getName() != null, Seo::getName, pageWrap.getModel().getName())
+ .like(pageWrap.getModel().getTitle() != null, Seo::getTitle, pageWrap.getModel().getTitle())
+ .like(pageWrap.getModel().getKeywords() != null, Seo::getKeywords, pageWrap.getModel().getKeywords())
+ .like(pageWrap.getModel().getAuthor() != null, Seo::getAuthor, pageWrap.getModel().getAuthor())
+ .eq(pageWrap.getModel().getIcon() != null, Seo::getIcon, pageWrap.getModel().getIcon())
+ .like(pageWrap.getModel().getImgalt() != null, Seo::getImgalt, pageWrap.getModel().getImgalt())
+ .like(pageWrap.getModel().getPageAddr() != null, Seo::getPageAddr, pageWrap.getModel().getPageAddr())
+ .eq(pageWrap.getModel().getSortnum() != null, Seo::getSortnum, pageWrap.getModel().getSortnum())
+ .orderByAsc(Seo::getSortnum);
+
+ return PageData.from(seoMapper.selectPage(page, queryWrapper));
+ }
+
+ @Override
+ public long count(Seo seo) {
+ QueryWrapper<Seo> wrapper = new QueryWrapper<>(seo);
+ return seoMapper.selectCount(wrapper);
+ }
+}
--
Gitblit v1.9.3