添加服务消息通知的消息记录和操作统计记录

This commit is contained in:
longbinbin 2024-12-13 14:02:38 +08:00
parent b544639b11
commit f73d950599
7 changed files with 114 additions and 24 deletions

View File

@ -10,7 +10,7 @@ public enum StatisticEnum {
ON_SITE_PAYMENT(3,"现场支付"),
POST_PAYMENT(4,"事后支付"),
REFUND(5,"退款"),
AGREE_TO_PUSH(6,"同意推送"),
MESSAGE_PUSH(6,"消息推送"),
DOWNLOAD(8,"下载"),
CLICK_ON_PAYMENT(9,"点击支付、购买"),

View File

@ -34,7 +34,7 @@ public interface MemberMapper {
* 查询用户当前景区服务通知状态
* @param scenicId 景区id
* @param memberId 用户id
* @return
* @return 0关闭 1开启
*/
Integer getScenicServiceNoticeStatus(@Param("scenicId") Long scenicId,@Param("memberId") Long memberId);

View File

@ -1,5 +1,6 @@
package com.ycwl.basic.mapper;
import com.ycwl.basic.model.mobile.messageRecord.MessageRecordEntity;
import org.apache.ibatis.annotations.Mapper;
/**
@ -8,4 +9,6 @@ import org.apache.ibatis.annotations.Mapper;
*/
@Mapper
public interface MessageRecordMapper {
int insertMessageRecord(MessageRecordEntity messageRecordEntity);
}

View File

@ -0,0 +1,34 @@
package com.ycwl.basic.model.mobile.messageRecord;
import com.baomidou.mybatisplus.annotation.TableId;
import com.baomidou.mybatisplus.annotation.TableName;
import lombok.Data;
/**
* @Authorlongbinbin
* @Date2024/12/13 11:37
* 景区服务消息记录表
*/
@Data
@TableName("message_record")
public class MessageRecordEntity {
@TableId
private Long id;
/**
* 用户id
*/
private Long memberId;
/**
* 景区id
*/
private Long scenicId;
/**
* 消息模板
*/
private String templateId;
/**
* 消息内容
*/
private String content;
private String createTime;
}

View File

@ -41,7 +41,14 @@ public class WechatMessageSubscribeForm {
* 进入小程序查看的语言类型支持zh_CNen_USzh_HKzh_TW默认为zh_CN
*/
private String lang;
/**
* 景区id
*/
private Long scenicId;
/**
* 用户id
*/
private Long memberId;
}

View File

@ -6,11 +6,19 @@ import com.ycwl.basic.config.WechatConfig;
import com.ycwl.basic.constant.NumberConstant;
import com.ycwl.basic.constant.WeiXinConstant;
import com.ycwl.basic.enums.BizCodeEnum;
import com.ycwl.basic.enums.StatisticEnum;
import com.ycwl.basic.exception.AppException;
import com.ycwl.basic.mapper.MemberMapper;
import com.ycwl.basic.mapper.MessageRecordMapper;
import com.ycwl.basic.mapper.ScenicMapper;
import com.ycwl.basic.mapper.StatisticsMapper;
import com.ycwl.basic.model.mobile.messageRecord.MessageRecordEntity;
import com.ycwl.basic.model.mobile.statistic.req.StatisticsRecordAddReq;
import com.ycwl.basic.model.wx.WechatAccessTokenVO;
import com.ycwl.basic.model.wx.WechatMessageSubscribeForm;
import com.ycwl.basic.model.wx.WechatMssVO;
import com.ycwl.basic.service.mobile.WxNotifyService;
import com.ycwl.basic.utils.SnowFlakeUtil;
import lombok.extern.slf4j.Slf4j;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.http.HttpStatus;
@ -39,6 +47,12 @@ public class WxNotifyServiceImpl implements WxNotifyService {
@Autowired
private WechatConfig wechatConfig;
@Autowired
private MessageRecordMapper messageRecordMapper;
@Autowired
private StatisticsMapper statisticsMapper;
@Autowired
private MemberMapper memberMapper;
/**
* 缓存accessToken
@ -81,31 +95,58 @@ public class WxNotifyServiceImpl implements WxNotifyService {
@Override
public JSONObject pushMessage(WechatMessageSubscribeForm info) {
RestTemplate restTemplate = new RestTemplate();
String url = MESSAGE_SEND_URL + getAccessToken();
// 拼接推送的模板
WechatMssVO wxMssVO = new WechatMssVO();
wxMssVO.setTouser(info.getOpenId()); // 用户的openId
wxMssVO.setTemplate_id(info.getTemplateId()); // 订阅消息模板id
wxMssVO.setLang(info.getLang()); // 语言类型
wxMssVO.setMiniprogram_state(info.getMiniprogram_state()); // 跳转小程序类型
wxMssVO.setPage(info.getPage());
Integer scenicServiceNoticeStatus = memberMapper.getScenicServiceNoticeStatus(info.getScenicId(), info.getMemberId());
if (scenicServiceNoticeStatus == NumberConstant.ZERO) {
log.info("用户已关闭通知");
return null;
}else {
// 发送通知
RestTemplate restTemplate = new RestTemplate();
String url = MESSAGE_SEND_URL + getAccessToken();
// // TODO: 推送的内容
// Map<String, WechatTemplateData> map = new HashMap<>();
// map.put("msg", new WechatTemplateData("发消息了"));
wxMssVO.setData(info.getData());
// 拼接推送的模板
WechatMssVO wxMssVO = new WechatMssVO();
wxMssVO.setTouser(info.getOpenId()); // 用户的openId
wxMssVO.setTemplate_id(info.getTemplateId()); // 订阅消息模板id
wxMssVO.setLang(info.getLang()); // 语言类型
wxMssVO.setMiniprogram_state(info.getMiniprogram_state()); // 跳转小程序类型
wxMssVO.setPage(info.getPage());
// 发送
ResponseEntity<String> responseEntity = restTemplate.postForEntity(url, wxMssVO, String.class);
JSONObject jsonObject = JSONObject.parseObject(JSONObject.toJSONString(responseEntity.getBody()));
Integer errcode = jsonObject.getInteger(WECHAT_ERRCODE);
String errmsg = jsonObject.getString(WECHAT_ERRMSG);
if (errcode != NumberConstant.ZERO) {
throw new AppException(errcode, errmsg);
// // TODO: 推送的内容
// Map<String, WechatTemplateData> map = new HashMap<>();
// map.put("msg", new WechatTemplateData("发消息了"));
wxMssVO.setData(info.getData());
// 发送
ResponseEntity<String> responseEntity = restTemplate.postForEntity(url, wxMssVO, String.class);
JSONObject jsonObject = JSONObject.parseObject(JSONObject.toJSONString(responseEntity.getBody()));
Integer errcode = jsonObject.getInteger(WECHAT_ERRCODE);
String errmsg = jsonObject.getString(WECHAT_ERRMSG);
if (errcode != NumberConstant.ZERO) {
throw new AppException(errcode, errmsg);
}
// 记录消息记录
MessageRecordEntity messageRecord = new MessageRecordEntity();
messageRecord.setId(SnowFlakeUtil.getLongId());
messageRecord.setMemberId(info.getMemberId());
messageRecord.setScenicId(info.getScenicId());
messageRecord.setTemplateId(info.getTemplateId());
messageRecord.setContent(info.getData().toString());
messageRecordMapper.insertMessageRecord(messageRecord);
// 统计消息记录
StatisticsRecordAddReq statisticsRecordAddReq = new StatisticsRecordAddReq();
statisticsRecordAddReq.setScenicId(info.getScenicId());
statisticsRecordAddReq.setMemberId(info.getMemberId());
statisticsRecordAddReq.setType(StatisticEnum.MESSAGE_PUSH.code);
statisticsRecordAddReq.setMorphId(messageRecord.getId());
statisticsMapper.addStatisticsRecord(statisticsRecordAddReq);
return JSONObject.parseObject(JSONObject.toJSONString(responseEntity.getBody()));
}
return JSONObject.parseObject(JSONObject.toJSONString(responseEntity.getBody()));
}

View File

@ -1,4 +1,9 @@
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.ycwl.basic.mapper.MessageRecordMapper">
<insert id="insertMessageRecord">
insert into message_record (id,member_id,scenic_id,template_id,context)
value (#{id},#{memberId},#{scenicId},#{templateId},#{content})
</insert>
</mapper>