mirror of
https://github.com/continew-org/continew-admin.git
synced 2025-09-20 19:00:53 +08:00
feat: 新增个人消息接口,调整个人信息接口地址
This commit is contained in:
@@ -16,8 +16,12 @@
|
|||||||
|
|
||||||
package top.continew.admin.system.mapper;
|
package top.continew.admin.system.mapper;
|
||||||
|
|
||||||
|
import com.baomidou.mybatisplus.core.metadata.IPage;
|
||||||
|
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
|
||||||
import org.apache.ibatis.annotations.Param;
|
import org.apache.ibatis.annotations.Param;
|
||||||
import top.continew.admin.system.model.entity.NoticeDO;
|
import top.continew.admin.system.model.entity.NoticeDO;
|
||||||
|
import top.continew.admin.system.model.query.NoticeQuery;
|
||||||
|
import top.continew.admin.system.model.resp.NoticeDetailResp;
|
||||||
import top.continew.admin.system.model.resp.dashboard.DashboardNoticeResp;
|
import top.continew.admin.system.model.resp.dashboard.DashboardNoticeResp;
|
||||||
import top.continew.starter.data.mp.base.BaseMapper;
|
import top.continew.starter.data.mp.base.BaseMapper;
|
||||||
|
|
||||||
@@ -38,4 +42,13 @@ public interface NoticeMapper extends BaseMapper<NoticeDO> {
|
|||||||
* @return 仪表盘公告列表
|
* @return 仪表盘公告列表
|
||||||
*/
|
*/
|
||||||
List<DashboardNoticeResp> selectDashboardList(@Param("userId") Long userId);
|
List<DashboardNoticeResp> selectDashboardList(@Param("userId") Long userId);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 分页查询公告列表
|
||||||
|
*
|
||||||
|
* @param page 分页条件
|
||||||
|
* @param query 查询条件
|
||||||
|
* @return 公告列表
|
||||||
|
*/
|
||||||
|
IPage<NoticeDetailResp> selectNoticePage(@Param("page") Page<NoticeDO> page, @Param("query") NoticeQuery query);
|
||||||
}
|
}
|
@@ -16,6 +16,7 @@
|
|||||||
|
|
||||||
package top.continew.admin.system.model.query;
|
package top.continew.admin.system.model.query;
|
||||||
|
|
||||||
|
import com.fasterxml.jackson.annotation.JsonIgnore;
|
||||||
import io.swagger.v3.oas.annotations.media.Schema;
|
import io.swagger.v3.oas.annotations.media.Schema;
|
||||||
import lombok.Data;
|
import lombok.Data;
|
||||||
import top.continew.starter.data.core.annotation.Query;
|
import top.continew.starter.data.core.annotation.Query;
|
||||||
@@ -49,4 +50,10 @@ public class NoticeQuery implements Serializable {
|
|||||||
*/
|
*/
|
||||||
@Schema(description = "类型", example = "1")
|
@Schema(description = "类型", example = "1")
|
||||||
private String type;
|
private String type;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 用户 ID
|
||||||
|
*/
|
||||||
|
@JsonIgnore
|
||||||
|
private Long userId;
|
||||||
}
|
}
|
@@ -16,6 +16,8 @@
|
|||||||
|
|
||||||
package top.continew.admin.system.service.impl;
|
package top.continew.admin.system.service.impl;
|
||||||
|
|
||||||
|
import com.baomidou.mybatisplus.core.metadata.IPage;
|
||||||
|
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
|
||||||
import lombok.RequiredArgsConstructor;
|
import lombok.RequiredArgsConstructor;
|
||||||
import org.springframework.stereotype.Service;
|
import org.springframework.stereotype.Service;
|
||||||
import top.continew.admin.common.context.UserContextHolder;
|
import top.continew.admin.common.context.UserContextHolder;
|
||||||
@@ -27,6 +29,8 @@ import top.continew.admin.system.model.resp.NoticeDetailResp;
|
|||||||
import top.continew.admin.system.model.resp.NoticeResp;
|
import top.continew.admin.system.model.resp.NoticeResp;
|
||||||
import top.continew.admin.system.model.resp.dashboard.DashboardNoticeResp;
|
import top.continew.admin.system.model.resp.dashboard.DashboardNoticeResp;
|
||||||
import top.continew.admin.system.service.NoticeService;
|
import top.continew.admin.system.service.NoticeService;
|
||||||
|
import top.continew.starter.extension.crud.model.query.PageQuery;
|
||||||
|
import top.continew.starter.extension.crud.model.resp.PageResp;
|
||||||
import top.continew.starter.extension.crud.service.BaseServiceImpl;
|
import top.continew.starter.extension.crud.service.BaseServiceImpl;
|
||||||
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
@@ -41,9 +45,18 @@ import java.util.List;
|
|||||||
@RequiredArgsConstructor
|
@RequiredArgsConstructor
|
||||||
public class NoticeServiceImpl extends BaseServiceImpl<NoticeMapper, NoticeDO, NoticeResp, NoticeDetailResp, NoticeQuery, NoticeReq> implements NoticeService {
|
public class NoticeServiceImpl extends BaseServiceImpl<NoticeMapper, NoticeDO, NoticeResp, NoticeDetailResp, NoticeQuery, NoticeReq> implements NoticeService {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public PageResp<NoticeResp> page(NoticeQuery query, PageQuery pageQuery) {
|
||||||
|
IPage<NoticeDetailResp> page = baseMapper.selectNoticePage(new Page<>(pageQuery.getPage(), pageQuery
|
||||||
|
.getSize()), query);
|
||||||
|
PageResp<NoticeResp> pageResp = PageResp.build(page, super.getListClass());
|
||||||
|
pageResp.getList().forEach(this::fill);
|
||||||
|
return pageResp;
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public List<DashboardNoticeResp> listDashboard() {
|
public List<DashboardNoticeResp> listDashboard() {
|
||||||
Long userId = UserContextHolder.isAdmin() ? null : UserContextHolder.getUserId();
|
Long userId = UserContextHolder.getUserId();
|
||||||
return baseMapper.selectDashboardList(userId);
|
return baseMapper.selectDashboardList(userId);
|
||||||
}
|
}
|
||||||
}
|
}
|
@@ -15,4 +15,28 @@
|
|||||||
ORDER BY sort ASC, effective_time DESC
|
ORDER BY sort ASC, effective_time DESC
|
||||||
LIMIT 5
|
LIMIT 5
|
||||||
</select>
|
</select>
|
||||||
|
|
||||||
|
<select id="selectNoticePage" resultType="top.continew.admin.system.model.resp.NoticeDetailResp">
|
||||||
|
SELECT *
|
||||||
|
FROM sys_notice AS t1
|
||||||
|
<where>
|
||||||
|
<if test="query.userId != null">
|
||||||
|
t1.notice_scope = 1 OR (t1.notice_scope = 2 AND JSON_EXTRACT(t1.notice_users, "$[0]") = CAST(#{query.userId} AS CHAR))
|
||||||
|
AND (t1.effective_time IS NULL OR NOW() > t1.effective_time)
|
||||||
|
AND (t1.terminate_time IS NULL OR t1.terminate_time > NOW())
|
||||||
|
</if>
|
||||||
|
<if test="query.title != null and query.title != ''">
|
||||||
|
AND t1.title LIKE CONCAT('%', #{query.title}, '%')
|
||||||
|
</if>
|
||||||
|
<if test="query.type != null and query.type != ''">
|
||||||
|
AND t1.type = #{query.type}
|
||||||
|
</if>
|
||||||
|
</where>
|
||||||
|
<if test="query.userId != null">
|
||||||
|
ORDER BY t1.sort ASC, t1.effective_time DESC
|
||||||
|
</if>
|
||||||
|
<if test="query.userId == null">
|
||||||
|
ORDER BY t1.create_time DESC
|
||||||
|
</if>
|
||||||
|
</select>
|
||||||
</mapper>
|
</mapper>
|
@@ -0,0 +1,71 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 2022-present Charles7c Authors. All Rights Reserved.
|
||||||
|
*
|
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
* you may not use this file except in compliance with the License.
|
||||||
|
* You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package top.continew.admin.controller.system;
|
||||||
|
|
||||||
|
import io.swagger.v3.oas.annotations.Operation;
|
||||||
|
import io.swagger.v3.oas.annotations.Parameter;
|
||||||
|
import io.swagger.v3.oas.annotations.enums.ParameterIn;
|
||||||
|
import io.swagger.v3.oas.annotations.tags.Tag;
|
||||||
|
import lombok.RequiredArgsConstructor;
|
||||||
|
import org.springframework.validation.annotation.Validated;
|
||||||
|
import org.springframework.web.bind.annotation.GetMapping;
|
||||||
|
import org.springframework.web.bind.annotation.PathVariable;
|
||||||
|
import org.springframework.web.bind.annotation.RequestMapping;
|
||||||
|
import org.springframework.web.bind.annotation.RestController;
|
||||||
|
import top.continew.admin.common.context.UserContextHolder;
|
||||||
|
import top.continew.admin.system.enums.NoticeScopeEnum;
|
||||||
|
import top.continew.admin.system.model.query.NoticeQuery;
|
||||||
|
import top.continew.admin.system.model.resp.NoticeDetailResp;
|
||||||
|
import top.continew.admin.system.model.resp.NoticeResp;
|
||||||
|
import top.continew.admin.system.service.NoticeService;
|
||||||
|
import top.continew.starter.core.validation.CheckUtils;
|
||||||
|
import top.continew.starter.extension.crud.model.query.PageQuery;
|
||||||
|
import top.continew.starter.extension.crud.model.resp.BasePageResp;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 个人消息 API
|
||||||
|
*
|
||||||
|
* @author Charles7c
|
||||||
|
* @since 2025/4/5 21:30
|
||||||
|
*/
|
||||||
|
@Tag(name = "个人消息 API")
|
||||||
|
@Validated
|
||||||
|
@RestController
|
||||||
|
@RequiredArgsConstructor
|
||||||
|
@RequestMapping("/user/message")
|
||||||
|
public class UserMessageController {
|
||||||
|
|
||||||
|
private final NoticeService noticeService;
|
||||||
|
|
||||||
|
@Operation(summary = "分页查询公告列表", description = "分页查询公告列表")
|
||||||
|
@GetMapping("/notice")
|
||||||
|
public BasePageResp<NoticeResp> pageNotice(@Validated NoticeQuery query, @Validated PageQuery pageQuery) {
|
||||||
|
query.setUserId(UserContextHolder.getUserId());
|
||||||
|
return noticeService.page(query, pageQuery);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Operation(summary = "查询公告详情", description = "查询公告")
|
||||||
|
@Parameter(name = "id", description = "ID", example = "1", in = ParameterIn.PATH)
|
||||||
|
@GetMapping("/notice/{id}")
|
||||||
|
public NoticeDetailResp getNotice(@PathVariable Long id) {
|
||||||
|
NoticeDetailResp detail = noticeService.get(id);
|
||||||
|
CheckUtils.throwIf(detail == null || (NoticeScopeEnum.USER.equals(detail.getNoticeScope()) && !detail
|
||||||
|
.getNoticeUsers()
|
||||||
|
.contains(UserContextHolder.getUserId().toString())), "公告不存在或无权限访问");
|
||||||
|
return detail;
|
||||||
|
}
|
||||||
|
}
|
@@ -41,6 +41,7 @@ import top.continew.admin.system.model.req.user.UserPasswordUpdateReq;
|
|||||||
import top.continew.admin.system.model.req.user.UserPhoneUpdateReq;
|
import top.continew.admin.system.model.req.user.UserPhoneUpdateReq;
|
||||||
import top.continew.admin.system.model.resp.AvatarResp;
|
import top.continew.admin.system.model.resp.AvatarResp;
|
||||||
import top.continew.admin.system.model.resp.user.UserSocialBindResp;
|
import top.continew.admin.system.model.resp.user.UserSocialBindResp;
|
||||||
|
import top.continew.admin.system.service.NoticeService;
|
||||||
import top.continew.admin.system.service.UserService;
|
import top.continew.admin.system.service.UserService;
|
||||||
import top.continew.admin.system.service.UserSocialService;
|
import top.continew.admin.system.service.UserSocialService;
|
||||||
import top.continew.starter.cache.redisson.util.RedisUtils;
|
import top.continew.starter.cache.redisson.util.RedisUtils;
|
||||||
@@ -51,22 +52,23 @@ import java.io.IOException;
|
|||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 个人中心 API
|
* 个人信息 API
|
||||||
*
|
*
|
||||||
* @author Charles7c
|
* @author Charles7c
|
||||||
* @since 2023/1/2 11:41
|
* @since 2023/1/2 11:41
|
||||||
*/
|
*/
|
||||||
@Tag(name = "个人中心 API")
|
@Tag(name = "个人信息 API")
|
||||||
@Validated
|
@Validated
|
||||||
@RestController
|
@RestController
|
||||||
@RequiredArgsConstructor
|
@RequiredArgsConstructor
|
||||||
@RequestMapping("/system/user")
|
@RequestMapping("/user/profile")
|
||||||
public class UserCenterController {
|
public class UserProfileController {
|
||||||
|
|
||||||
private static final String DECRYPT_FAILED = "当前密码解密失败";
|
private static final String DECRYPT_FAILED = "当前密码解密失败";
|
||||||
private static final String CAPTCHA_EXPIRED = "验证码已失效";
|
private static final String CAPTCHA_EXPIRED = "验证码已失效";
|
||||||
private final UserService userService;
|
private final UserService userService;
|
||||||
private final UserSocialService userSocialService;
|
private final UserSocialService userSocialService;
|
||||||
|
private final NoticeService noticeService;
|
||||||
private final AuthRequestFactory authRequestFactory;
|
private final AuthRequestFactory authRequestFactory;
|
||||||
|
|
||||||
@Operation(summary = "修改头像", description = "用户修改个人头像")
|
@Operation(summary = "修改头像", description = "用户修改个人头像")
|
Reference in New Issue
Block a user