mirror of
				https://gitee.com/hhyykk/ipms-sjy.git
				synced 2025-11-04 12:18:42 +08:00 
			
		
		
		
	新增两个APP端接口
1.获取用户个人签到信息 2.用户签到接接口
This commit is contained in:
		@@ -0,0 +1,55 @@
 | 
			
		||||
package cn.iocoder.yudao.module.member.controller.app.signin;
 | 
			
		||||
 | 
			
		||||
import cn.iocoder.yudao.framework.common.pojo.CommonResult;
 | 
			
		||||
import cn.iocoder.yudao.framework.security.core.util.SecurityFrameworkUtils;
 | 
			
		||||
import cn.iocoder.yudao.module.member.convert.signin.MemberSignInRecordConvert;
 | 
			
		||||
import cn.iocoder.yudao.module.member.dal.dataobject.signin.MemberSignInRecordDO;
 | 
			
		||||
import cn.iocoder.yudao.module.member.service.signin.MemberSignInRecordService;
 | 
			
		||||
import io.swagger.v3.oas.annotations.Operation;
 | 
			
		||||
import io.swagger.v3.oas.annotations.tags.Tag;
 | 
			
		||||
import org.springframework.web.bind.annotation.GetMapping;
 | 
			
		||||
import org.springframework.web.bind.annotation.PostMapping;
 | 
			
		||||
import org.springframework.web.bind.annotation.RequestMapping;
 | 
			
		||||
import org.springframework.web.bind.annotation.RestController;
 | 
			
		||||
 | 
			
		||||
import javax.annotation.Resource;
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * 描述    :用户签到相关信息接口
 | 
			
		||||
 * Author :xiaqing
 | 
			
		||||
 * Date   :2023-09-15 09:02
 | 
			
		||||
 */
 | 
			
		||||
@Tag(name = "签到APP - 签到")
 | 
			
		||||
@RestController
 | 
			
		||||
@RequestMapping("/member/signin")
 | 
			
		||||
public class AppMemberSignInController {
 | 
			
		||||
 | 
			
		||||
    @Resource
 | 
			
		||||
    MemberSignInRecordService signInRecordService;
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * 描述    :获取个人签到信息
 | 
			
		||||
     * Author :xiaqing
 | 
			
		||||
     * Date   :2023-09-15 12:56:47
 | 
			
		||||
     */
 | 
			
		||||
 | 
			
		||||
    @Operation(summary = "个人签到信息")
 | 
			
		||||
    @GetMapping("/get-summary")
 | 
			
		||||
    public CommonResult getUserSummary(){
 | 
			
		||||
        return CommonResult.success(signInRecordService.getUserSummary(SecurityFrameworkUtils.getLoginUserId()));
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * 描述    :用户签到
 | 
			
		||||
     * Author :xiaqing
 | 
			
		||||
     * Date   :2023-09-15 09:20:58
 | 
			
		||||
     */
 | 
			
		||||
    @Operation(summary = "会员签到")
 | 
			
		||||
    @PostMapping("/create")
 | 
			
		||||
    public CommonResult create(){
 | 
			
		||||
        MemberSignInRecordDO recordDO = signInRecordService.create(SecurityFrameworkUtils.getLoginUserId());
 | 
			
		||||
        return CommonResult.success(MemberSignInRecordConvert.INSTANCE.coverRecordToAppRecordVo(recordDO));
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
}
 | 
			
		||||
@@ -0,0 +1,21 @@
 | 
			
		||||
package cn.iocoder.yudao.module.member.controller.app.signin.vo;
 | 
			
		||||
 | 
			
		||||
import io.swagger.v3.oas.annotations.media.Schema;
 | 
			
		||||
import lombok.Data;
 | 
			
		||||
 | 
			
		||||
import java.time.LocalDateTime;
 | 
			
		||||
 | 
			
		||||
@Schema(description = "用户签到积分 Response VO")
 | 
			
		||||
@Data
 | 
			
		||||
public class AppMemberSignInRecordRespVO {
 | 
			
		||||
 | 
			
		||||
    @Schema(description = "第几天签到", requiredMode = Schema.RequiredMode.REQUIRED, example = "1")
 | 
			
		||||
    private Integer day;
 | 
			
		||||
 | 
			
		||||
    @Schema(description = "签到的分数", requiredMode = Schema.RequiredMode.REQUIRED, example = "10")
 | 
			
		||||
    private Integer point;
 | 
			
		||||
 | 
			
		||||
    @Schema(description = "签到时间", requiredMode = Schema.RequiredMode.REQUIRED)
 | 
			
		||||
    private LocalDateTime createTime;
 | 
			
		||||
 | 
			
		||||
}
 | 
			
		||||
@@ -0,0 +1,21 @@
 | 
			
		||||
package cn.iocoder.yudao.module.member.controller.app.signin.vo;
 | 
			
		||||
 | 
			
		||||
import io.swagger.v3.oas.annotations.media.Schema;
 | 
			
		||||
import lombok.Data;
 | 
			
		||||
 | 
			
		||||
import java.time.LocalDateTime;
 | 
			
		||||
 | 
			
		||||
@Schema(description = "用户签到统计信息 Response VO")
 | 
			
		||||
@Data
 | 
			
		||||
public class AppMemberSignInSummaryRespVO {
 | 
			
		||||
 | 
			
		||||
    @Schema(description = "持续签到天数", requiredMode = Schema.RequiredMode.REQUIRED, example = "5")
 | 
			
		||||
    private Integer continuousDay;
 | 
			
		||||
 | 
			
		||||
    @Schema(description = "总签到天数", requiredMode = Schema.RequiredMode.REQUIRED, example = "10")
 | 
			
		||||
    private Integer totalDay;
 | 
			
		||||
 | 
			
		||||
    @Schema(description = "当天是否签到", requiredMode = Schema.RequiredMode.REQUIRED,example = "true")
 | 
			
		||||
    private Boolean todaySignIn ;
 | 
			
		||||
 | 
			
		||||
}
 | 
			
		||||
@@ -4,6 +4,7 @@ import cn.iocoder.yudao.framework.common.pojo.PageResult;
 | 
			
		||||
import cn.iocoder.yudao.framework.common.util.collection.MapUtils;
 | 
			
		||||
import cn.iocoder.yudao.module.member.api.user.dto.MemberUserRespDTO;
 | 
			
		||||
import cn.iocoder.yudao.module.member.controller.admin.signin.vo.record.MemberSignInRecordRespVO;
 | 
			
		||||
import cn.iocoder.yudao.module.member.controller.app.signin.vo.AppMemberSignInRecordRespVO;
 | 
			
		||||
import cn.iocoder.yudao.module.member.dal.dataobject.signin.MemberSignInRecordDO;
 | 
			
		||||
import org.mapstruct.Mapper;
 | 
			
		||||
import org.mapstruct.factory.Mappers;
 | 
			
		||||
@@ -33,4 +34,6 @@ public interface MemberSignInRecordConvert {
 | 
			
		||||
    }
 | 
			
		||||
    PageResult<MemberSignInRecordRespVO> convertPage(PageResult<MemberSignInRecordDO> pageResult);
 | 
			
		||||
 | 
			
		||||
    AppMemberSignInRecordRespVO coverRecordToAppRecordVo(MemberSignInRecordDO memberSignInRecordDO);
 | 
			
		||||
 | 
			
		||||
}
 | 
			
		||||
 
 | 
			
		||||
@@ -1,13 +1,9 @@
 | 
			
		||||
package cn.iocoder.yudao.module.member.dal.mysql.signin;
 | 
			
		||||
 | 
			
		||||
import cn.iocoder.yudao.framework.mybatis.core.mapper.BaseMapperX;
 | 
			
		||||
import cn.iocoder.yudao.framework.mybatis.core.query.LambdaQueryWrapperX;
 | 
			
		||||
import cn.iocoder.yudao.module.member.dal.dataobject.signin.MemberSignInConfigDO;
 | 
			
		||||
import com.baomidou.mybatisplus.core.conditions.update.LambdaUpdateWrapper;
 | 
			
		||||
import org.apache.ibatis.annotations.Mapper;
 | 
			
		||||
 | 
			
		||||
import java.util.List;
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * 积分签到规则 Mapper
 | 
			
		||||
 *
 | 
			
		||||
 
 | 
			
		||||
@@ -7,6 +7,7 @@ import cn.iocoder.yudao.module.member.controller.admin.signin.vo.record.MemberSi
 | 
			
		||||
import cn.iocoder.yudao.module.member.dal.dataobject.signin.MemberSignInRecordDO;
 | 
			
		||||
import org.apache.ibatis.annotations.Mapper;
 | 
			
		||||
 | 
			
		||||
import java.util.List;
 | 
			
		||||
import java.util.Set;
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
@@ -25,4 +26,12 @@ public interface MemberSignInRecordMapper extends BaseMapperX<MemberSignInRecord
 | 
			
		||||
                .orderByDesc(MemberSignInRecordDO::getId));
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
    //获取用户的签到记录列表信息,根据签到时间倒序
 | 
			
		||||
    default List<MemberSignInRecordDO> selectListByUserId(Long userId){
 | 
			
		||||
        return selectList(new LambdaQueryWrapperX <MemberSignInRecordDO>()
 | 
			
		||||
                .eq(MemberSignInRecordDO::getUserId, userId)
 | 
			
		||||
                .orderByDesc(MemberSignInRecordDO::getCreateTime));
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
}
 | 
			
		||||
 
 | 
			
		||||
@@ -2,6 +2,8 @@ package cn.iocoder.yudao.module.member.service.signin;
 | 
			
		||||
 | 
			
		||||
import cn.iocoder.yudao.framework.common.pojo.PageResult;
 | 
			
		||||
import cn.iocoder.yudao.module.member.controller.admin.signin.vo.record.MemberSignInRecordPageReqVO;
 | 
			
		||||
import cn.iocoder.yudao.module.member.controller.app.signin.vo.AppMemberSignInRecordRespVO;
 | 
			
		||||
import cn.iocoder.yudao.module.member.controller.app.signin.vo.AppMemberSignInSummaryRespVO;
 | 
			
		||||
import cn.iocoder.yudao.module.member.dal.dataobject.signin.MemberSignInRecordDO;
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
@@ -19,4 +21,18 @@ public interface MemberSignInRecordService {
 | 
			
		||||
     */
 | 
			
		||||
    PageResult<MemberSignInRecordDO> getSignInRecordPage(MemberSignInRecordPageReqVO pageReqVO);
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
    MemberSignInRecordDO create(Long userId);
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     *
 | 
			
		||||
     *功能描述: 根据用户id获取个人签到信息
 | 
			
		||||
     * @param userId
 | 
			
		||||
     * @return
 | 
			
		||||
     * @author xiaqing
 | 
			
		||||
     * @date 2023-09-15 14:21:01
 | 
			
		||||
     */
 | 
			
		||||
    AppMemberSignInSummaryRespVO getUserSummary(Long userId);
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
}
 | 
			
		||||
 
 | 
			
		||||
@@ -1,20 +1,28 @@
 | 
			
		||||
package cn.iocoder.yudao.module.member.service.signin;
 | 
			
		||||
 | 
			
		||||
import cn.iocoder.yudao.framework.common.pojo.PageResult;
 | 
			
		||||
import cn.iocoder.yudao.framework.mybatis.core.query.LambdaQueryWrapperX;
 | 
			
		||||
import cn.iocoder.yudao.module.member.api.user.MemberUserApi;
 | 
			
		||||
import cn.iocoder.yudao.module.member.api.user.dto.MemberUserRespDTO;
 | 
			
		||||
import cn.iocoder.yudao.module.member.controller.admin.signin.vo.record.MemberSignInRecordPageReqVO;
 | 
			
		||||
import cn.iocoder.yudao.module.member.controller.app.signin.vo.AppMemberSignInSummaryRespVO;
 | 
			
		||||
import cn.iocoder.yudao.module.member.dal.dataobject.signin.MemberSignInConfigDO;
 | 
			
		||||
import cn.iocoder.yudao.module.member.dal.dataobject.signin.MemberSignInRecordDO;
 | 
			
		||||
import cn.iocoder.yudao.module.member.dal.mysql.signin.MemberSignInConfigMapper;
 | 
			
		||||
import cn.iocoder.yudao.module.member.dal.mysql.signin.MemberSignInRecordMapper;
 | 
			
		||||
import cn.iocoder.yudao.module.member.enums.ErrorCodeConstants;
 | 
			
		||||
import org.apache.commons.lang3.StringUtils;
 | 
			
		||||
import org.springframework.stereotype.Service;
 | 
			
		||||
import org.springframework.util.CollectionUtils;
 | 
			
		||||
import org.springframework.validation.annotation.Validated;
 | 
			
		||||
 | 
			
		||||
import javax.annotation.Resource;
 | 
			
		||||
import java.time.LocalDate;
 | 
			
		||||
import java.time.temporal.ChronoUnit;
 | 
			
		||||
import java.util.List;
 | 
			
		||||
import java.util.Set;
 | 
			
		||||
 | 
			
		||||
import static cn.iocoder.yudao.framework.common.exception.util.ServiceExceptionUtil.exception;
 | 
			
		||||
import static cn.iocoder.yudao.framework.common.util.collection.CollectionUtils.convertSet;
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
@@ -28,16 +36,62 @@ public class MemberSignInRecordServiceImpl implements MemberSignInRecordService
 | 
			
		||||
 | 
			
		||||
    @Resource
 | 
			
		||||
    private MemberSignInRecordMapper signInRecordMapper;
 | 
			
		||||
 | 
			
		||||
    @Resource
 | 
			
		||||
    private MemberSignInConfigMapper signInConfigMapper;
 | 
			
		||||
    @Resource
 | 
			
		||||
    private MemberUserApi memberUserApi;
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
    @Override
 | 
			
		||||
    public PageResult<MemberSignInRecordDO> getSignInRecordPage(MemberSignInRecordPageReqVO pageReqVO) {
 | 
			
		||||
    public AppMemberSignInSummaryRespVO getUserSummary(Long userId) {
 | 
			
		||||
        AppMemberSignInSummaryRespVO vo  = new AppMemberSignInSummaryRespVO();
 | 
			
		||||
        vo.setTotalDay(0);
 | 
			
		||||
        vo.setContinuousDay(0);
 | 
			
		||||
        vo.setTodaySignIn(false);
 | 
			
		||||
        //获取用户签到的记录,按照天数倒序获取
 | 
			
		||||
        List <MemberSignInRecordDO> signInRecordDOList = signInRecordMapper.selectListByUserId(userId);
 | 
			
		||||
        if(!CollectionUtils.isEmpty(signInRecordDOList)){
 | 
			
		||||
            //设置总签到天数
 | 
			
		||||
            vo.setTotalDay(signInRecordDOList.size());
 | 
			
		||||
            //判断当天是否有签到复用校验方法
 | 
			
		||||
            try {
 | 
			
		||||
                validSignDay(signInRecordDOList.get(0));
 | 
			
		||||
                vo.setTodaySignIn(false);
 | 
			
		||||
            }catch (Exception e){
 | 
			
		||||
                vo.setTodaySignIn(true);
 | 
			
		||||
            }
 | 
			
		||||
            //如果当天签到了则说明连续签到天数有意义,否则直接用默认值0
 | 
			
		||||
            if(vo.getTodaySignIn()){
 | 
			
		||||
                //下方计算连续签到从2天开始,此处直接设置一天连续签到
 | 
			
		||||
                vo.setContinuousDay(1);
 | 
			
		||||
                //判断连续签到天数
 | 
			
		||||
                for (int i = 1; i < signInRecordDOList.size(); i++) {
 | 
			
		||||
                    //前一天减1等于当前天数则说明连续,继续循环
 | 
			
		||||
                    LocalDate cur = signInRecordDOList.get(i).getCreateTime().toLocalDate();
 | 
			
		||||
                    LocalDate pre = signInRecordDOList.get(i-1).getCreateTime().toLocalDate();
 | 
			
		||||
                    if(1==daysBetween(cur,pre)){
 | 
			
		||||
                        vo.setContinuousDay(i+1);
 | 
			
		||||
                    }else{
 | 
			
		||||
                        break;
 | 
			
		||||
                    }
 | 
			
		||||
                }
 | 
			
		||||
            }
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
        }
 | 
			
		||||
        return vo;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    private long daysBetween(LocalDate date1,LocalDate date2){
 | 
			
		||||
        return ChronoUnit.DAYS.between(date1, date2);
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    @Override
 | 
			
		||||
    public PageResult <MemberSignInRecordDO> getSignInRecordPage(MemberSignInRecordPageReqVO pageReqVO) {
 | 
			
		||||
        // 根据用户昵称查询出用户ids
 | 
			
		||||
        Set<Long> userIds = null;
 | 
			
		||||
        Set <Long> userIds = null;
 | 
			
		||||
        if (StringUtils.isNotBlank(pageReqVO.getNickname())) {
 | 
			
		||||
            List<MemberUserRespDTO> users = memberUserApi.getUserListByNickname(pageReqVO.getNickname());
 | 
			
		||||
            List <MemberUserRespDTO> users = memberUserApi.getUserListByNickname(pageReqVO.getNickname());
 | 
			
		||||
            // 如果查询用户结果为空直接返回无需继续查询
 | 
			
		||||
            if (CollectionUtils.isEmpty(users)) {
 | 
			
		||||
                return PageResult.empty();
 | 
			
		||||
@@ -47,4 +101,58 @@ public class MemberSignInRecordServiceImpl implements MemberSignInRecordService
 | 
			
		||||
        return signInRecordMapper.selectPage(pageReqVO, userIds);
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    @Override
 | 
			
		||||
    public MemberSignInRecordDO create(Long userId) {
 | 
			
		||||
        //获取当前用户签到的最大天数
 | 
			
		||||
        MemberSignInRecordDO maxSignDay = signInRecordMapper.selectOne(new LambdaQueryWrapperX <MemberSignInRecordDO>()
 | 
			
		||||
                .eq(MemberSignInRecordDO::getUserId, userId)
 | 
			
		||||
                .orderByDesc(MemberSignInRecordDO::getDay)
 | 
			
		||||
                .last("limit 1"));
 | 
			
		||||
        //判断是否重复签到
 | 
			
		||||
        validSignDay(maxSignDay);
 | 
			
		||||
 | 
			
		||||
        /**1.查询出当前签到的天数**/
 | 
			
		||||
        MemberSignInRecordDO sign = new MemberSignInRecordDO();
 | 
			
		||||
        sign.setUserId(userId);
 | 
			
		||||
        //设置签到初始化天数
 | 
			
		||||
        sign.setDay(1);
 | 
			
		||||
        //设置签到分数默认为0
 | 
			
		||||
        sign.setPoint(0);
 | 
			
		||||
        //如果不为空则修改当前签到对应的天数
 | 
			
		||||
        if (maxSignDay != null) {
 | 
			
		||||
            sign.setDay(maxSignDay.getDay() + 1);
 | 
			
		||||
        }
 | 
			
		||||
        /**2.获取签到对应的分数**/
 | 
			
		||||
        //获取所有的签到规则,按照天数排序,只获取启用的
 | 
			
		||||
        List <MemberSignInConfigDO> configDOList = signInConfigMapper.selectList(new LambdaQueryWrapperX <MemberSignInConfigDO>()
 | 
			
		||||
                .eq(MemberSignInConfigDO::getEnable, 1)
 | 
			
		||||
                .orderByAsc(MemberSignInConfigDO::getDay));
 | 
			
		||||
        //如果签到的天数大于最大启用的规则天数,直接给最大签到的分数
 | 
			
		||||
        MemberSignInConfigDO lastConfig = configDOList.get(configDOList.size() - 1);
 | 
			
		||||
        if (sign.getDay() > lastConfig.getDay()) {
 | 
			
		||||
            sign.setPoint(lastConfig.getPoint());
 | 
			
		||||
        } else {
 | 
			
		||||
            configDOList.forEach(el -> {
 | 
			
		||||
                //循环匹配对应天数,设置对应分数
 | 
			
		||||
                if (el.getDay() == sign.getDay()) {
 | 
			
		||||
                    sign.setPoint(el.getPoint());
 | 
			
		||||
                }
 | 
			
		||||
 | 
			
		||||
            });
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        //3.插入当前签到获取的分数
 | 
			
		||||
        signInRecordMapper.insert(sign);
 | 
			
		||||
        //4.返回给用户
 | 
			
		||||
        return sign;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    void validSignDay(MemberSignInRecordDO signInRecordDO) {
 | 
			
		||||
        if (signInRecordDO == null)
 | 
			
		||||
            return;
 | 
			
		||||
        LocalDate today = LocalDate.now();
 | 
			
		||||
        if (today.equals(signInRecordDO.getCreateTime().toLocalDate())) {
 | 
			
		||||
            throw exception(ErrorCodeConstants.SIGN_IN_RECORD_EXISTS);
 | 
			
		||||
        }
 | 
			
		||||
    }
 | 
			
		||||
}
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user