From fe70ca5db711b458714bfbe4a6eda6cf7d8a0421 Mon Sep 17 00:00:00 2001
From: Administrator <15274802129@163.com>
Date: Tue, 16 Sep 2025 13:58:46 +0800
Subject: [PATCH] feat(member): 添加会员公司ID并更新相关服务
---
src/main/java/cc/mrbird/febs/ai/service/AiMemberTalkItemService.java | 2
src/main/java/cc/mrbird/febs/ai/service/AiMemberTalkService.java | 2
src/main/java/cc/mrbird/febs/ai/service/impl/AiTalkItemServiceImpl.java | 3 +
src/main/java/cc/mrbird/febs/ai/service/impl/AiMemberTalkServiceImpl.java | 19 ++++++---
src/main/java/cc/mrbird/febs/ai/service/impl/ApiMemberTalkStreamServiceImpl.java | 12 ++++--
src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallMemberServiceImpl.java | 7 +++
src/main/java/cc/mrbird/febs/ai/service/impl/AiMemberTalkItemServiceImpl.java | 3 +
src/main/java/cc/mrbird/febs/ai/service/impl/AiMemberAnswerServiceImpl.java | 6 +++
src/main/java/cc/mrbird/febs/mall/vo/MallMemberVo.java | 3 +
src/main/java/cc/mrbird/febs/mall/entity/MallMember.java | 2 +
src/main/java/cc/mrbird/febs/ai/service/impl/AiTalkServiceImpl.java | 8 ++-
src/main/java/cc/mrbird/febs/ai/service/AiTalkItemService.java | 2
src/main/java/cc/mrbird/febs/ai/service/AiTalkService.java | 2
13 files changed, 51 insertions(+), 20 deletions(-)
diff --git a/src/main/java/cc/mrbird/febs/ai/service/AiMemberTalkItemService.java b/src/main/java/cc/mrbird/febs/ai/service/AiMemberTalkItemService.java
index 21dea9b..fe3dce3 100644
--- a/src/main/java/cc/mrbird/febs/ai/service/AiMemberTalkItemService.java
+++ b/src/main/java/cc/mrbird/febs/ai/service/AiMemberTalkItemService.java
@@ -22,7 +22,7 @@
public interface AiMemberTalkItemService extends IService<AiMemberTalkItem> {
- AiMemberTalkItem add(String memberUuid, String id, int type, String resContext, Date createdTime);
+ AiMemberTalkItem add(String memberUuid, String id, String companyId, int type, String resContext, Date createdTime);
AiMemberTalkItem getByQuery(LambdaQueryWrapper<AiMemberTalkItem> memberTalkItemQuery);
diff --git a/src/main/java/cc/mrbird/febs/ai/service/AiMemberTalkService.java b/src/main/java/cc/mrbird/febs/ai/service/AiMemberTalkService.java
index 4b51641..e1ae7d0 100644
--- a/src/main/java/cc/mrbird/febs/ai/service/AiMemberTalkService.java
+++ b/src/main/java/cc/mrbird/febs/ai/service/AiMemberTalkService.java
@@ -34,7 +34,7 @@
FebsResponse answer(ApiMemberTalkAnswerDto dto);
- AiMemberTalk add(String memberUuid, String productId, Date nowTime);
+ AiMemberTalk add(String memberUuid,String companyId, String productId, Date nowTime);
FebsResponse historyPage(ApiMemberTalkItemPageDto dto);
diff --git a/src/main/java/cc/mrbird/febs/ai/service/AiTalkItemService.java b/src/main/java/cc/mrbird/febs/ai/service/AiTalkItemService.java
index d62b11b..e3f81c7 100644
--- a/src/main/java/cc/mrbird/febs/ai/service/AiTalkItemService.java
+++ b/src/main/java/cc/mrbird/febs/ai/service/AiTalkItemService.java
@@ -10,7 +10,7 @@
public interface AiTalkItemService extends IService<AiTalkItem> {
- void add(String id, int code, String context, String memberUuid, DateTime date);
+ void add(String id,String companyId, int code, String context, String memberUuid, DateTime date);
FebsResponse historyPage(ApiTalkItemPageDto dto);
diff --git a/src/main/java/cc/mrbird/febs/ai/service/AiTalkService.java b/src/main/java/cc/mrbird/febs/ai/service/AiTalkService.java
index 7f45d29..f8fb02b 100644
--- a/src/main/java/cc/mrbird/febs/ai/service/AiTalkService.java
+++ b/src/main/java/cc/mrbird/febs/ai/service/AiTalkService.java
@@ -17,7 +17,7 @@
FebsResponse talkOpen(ApiTalkDto dto);
- AiTalk add(String memberUuid, String question, Date date);
+ AiTalk add(String memberUuid,String companyId, String question, Date date);
Flux<FebsResponse> answerStream(String question);
diff --git a/src/main/java/cc/mrbird/febs/ai/service/impl/AiMemberAnswerServiceImpl.java b/src/main/java/cc/mrbird/febs/ai/service/impl/AiMemberAnswerServiceImpl.java
index 5ba0dd9..56576c6 100644
--- a/src/main/java/cc/mrbird/febs/ai/service/impl/AiMemberAnswerServiceImpl.java
+++ b/src/main/java/cc/mrbird/febs/ai/service/impl/AiMemberAnswerServiceImpl.java
@@ -64,6 +64,7 @@
if(ObjectUtil.isNull(aiProduct)){
throw new FebsException("产品不存在");
}
+ String companyId = aiProduct.getCompanyId();
//验证产品分类下是否有题目
String productCategoryId = aiProduct.getProductCategoryId();
LambdaQueryWrapper<AiProductQuestion> questionLambdaQueryWrapper = Wrappers.lambdaQuery(AiProductQuestion.class);
@@ -86,6 +87,7 @@
Integer questionCount = aiProduct.getQuestionCount();
aiMemberAnswer = new AiMemberAnswer();
aiMemberAnswer.setId(UUID.getSimpleUUIDString());
+ aiMemberAnswer.setCompanyId(companyId);
aiMemberAnswer.setCreatedTime(createdTime);
aiMemberAnswer.setUpdatedTime(createdTime);
aiMemberAnswer.setProductId(aiProduct.getId());
@@ -102,6 +104,7 @@
AiProductQuestion aiProductQuestion = aiProductQuestionService.createQuestion(aiProduct.getId());
AiMemberAnswerItem aiMemberAnswerItem = new AiMemberAnswerItem();
aiMemberAnswerItem.setId(UUID.getSimpleUUIDString());
+ aiMemberAnswerItem.setCompanyId(companyId);
aiMemberAnswerItem.setCreatedTime(createdTime);
aiMemberAnswerItem.setAnswerId(aiMemberAnswer.getId());
aiMemberAnswerItem.setProductId(aiMemberAnswer.getProductId());
@@ -250,6 +253,8 @@
throw new FebsException("答题记录不存在");
}
+ String companyId = aiMemberAnswer.getCompanyId();
+
Date createdTime = new Date();
AiMemberAnswerItem aiMemberAnswerItem = aiMemberAnswerItemService.getById(memberAnswerItemId);
aiMemberAnswerItem.setUpdatedTime(createdTime);
@@ -283,6 +288,7 @@
if (aiMemberAnswerItem.getMemberAnswerState() == 1){
aiMemberAnswer.setCorrectCnt(aiMemberAnswer.getCorrectCnt() + 1);
}
+ aiMemberAnswerItem.setCompanyId(companyId);
aiMemberAnswer.setUpdatedTime(createdTime);
aiMemberAnswerMapper.updateById(aiMemberAnswer);
diff --git a/src/main/java/cc/mrbird/febs/ai/service/impl/AiMemberTalkItemServiceImpl.java b/src/main/java/cc/mrbird/febs/ai/service/impl/AiMemberTalkItemServiceImpl.java
index 2b93ccc..552f8ef 100644
--- a/src/main/java/cc/mrbird/febs/ai/service/impl/AiMemberTalkItemServiceImpl.java
+++ b/src/main/java/cc/mrbird/febs/ai/service/impl/AiMemberTalkItemServiceImpl.java
@@ -38,9 +38,10 @@
private final AiMemberTalkItemMapper aiMemberTalkItemMapper;
@Override
- public AiMemberTalkItem add(String memberUuid, String id, int type, String resContext,Date createdTime) {
+ public AiMemberTalkItem add(String memberUuid, String id, String companyId, int type, String resContext,Date createdTime) {
AiMemberTalkItem aiMemberTalkItem = new AiMemberTalkItem();
aiMemberTalkItem.setId(UUID.getSimpleUUIDString());
+ aiMemberTalkItem.setCompanyId(companyId);
aiMemberTalkItem.setCreatedTime(createdTime);
aiMemberTalkItem.setMemberId(memberUuid);
aiMemberTalkItem.setMemberTalkId(id);
diff --git a/src/main/java/cc/mrbird/febs/ai/service/impl/AiMemberTalkServiceImpl.java b/src/main/java/cc/mrbird/febs/ai/service/impl/AiMemberTalkServiceImpl.java
index 4885a94..61c9102 100644
--- a/src/main/java/cc/mrbird/febs/ai/service/impl/AiMemberTalkServiceImpl.java
+++ b/src/main/java/cc/mrbird/febs/ai/service/impl/AiMemberTalkServiceImpl.java
@@ -71,6 +71,7 @@
if(ObjectUtil.isNull(aiProductRoleLink)){
throw new FebsException("产品AI陪练不存在");
}
+ String companyId = aiProductRoleLink.getCompanyId();
Date nowTime = new Date();
LambdaQueryWrapper<AiMemberTalk> query = Wrappers.lambdaQuery(AiMemberTalk.class);
@@ -79,7 +80,7 @@
query.last("limit 1");
AiMemberTalk aiMemberTalk = this.getByQuery(query);
if (ObjectUtil.isNull(aiMemberTalk)){
- aiMemberTalk = this.add(memberUuid,productId,nowTime);
+ aiMemberTalk = this.add(memberUuid,companyId,productId,nowTime);
}
List<AiMessage> aiMessageDtoList = aiMemberTalkItemService.getQuestionUpDownContext(aiMemberTalk.getId(),AiTypeEnum.QUESTION.getCode());
@@ -91,7 +92,7 @@
apiMemberTalkVo.setType(1);
apiMemberTalkVo.setContext(aiResponse.getResContext());
if(aiResponse.getCode().equals("200")){
- AiMemberTalkItem aiMemberTalkItem = aiMemberTalkItemService.add(memberUuid, aiMemberTalk.getId(), 1, aiResponse.getResContext(), nowTime);
+ AiMemberTalkItem aiMemberTalkItem = aiMemberTalkItemService.add(memberUuid, aiMemberTalk.getId(),companyId, 1, aiResponse.getResContext(), nowTime);
apiMemberTalkVo.setMemberTalkItemId(aiMemberTalkItem.getId());
this.updateTimeUpdate(nowTime,aiMemberTalk.getId());
}else{
@@ -137,6 +138,7 @@
callback.accept(aiResponse);
return;
}
+ String companyId = aiProductRoleLink.getCompanyId();
// 构造AI请求
AiRequest aiRequest = new AiRequest();
@@ -153,14 +155,14 @@
query.last("limit 1");
AiMemberTalk aiMemberTalk = this.getByQuery(query);
if (ObjectUtil.isNull(aiMemberTalk)) {
- aiMemberTalk = this.add(memberUuid, productId, nowTime);
+ aiMemberTalk = this.add(memberUuid,companyId, productId, nowTime);
}
try {
if (aiResponse.getCode().equals("200")) {
// 如果是最终结果(包含报告)
if (aiResponse.getReport() != null) {
// 保存完整响应到数据库
- aiMemberTalkItemService.add(memberUuid, aiMemberTalk.getId(), 1, aiResponse.getResContext(), nowTime);
+ aiMemberTalkItemService.add(memberUuid, aiMemberTalk.getId(),companyId, 1, aiResponse.getResContext(), nowTime);
this.updateTimeUpdate(nowTime, aiMemberTalk.getId());
callback.accept(aiResponse);
@@ -216,6 +218,8 @@
throw new FebsException("产品AI陪练对话不存在");
}
+ String companyId = aiMemberTalk.getCompanyId();
+
LambdaQueryWrapper<AiProductRoleLink> productLinkQuery = Wrappers.lambdaQuery(AiProductRoleLink.class);
productLinkQuery.eq(AiProductRoleLink::getProductId,aiMemberTalk.getProductId());
productLinkQuery.last("limit 1");
@@ -233,7 +237,7 @@
memberTalkItemQuery.orderByDesc(AiMemberTalkItem::getCreatedTime);
memberTalkItemQuery.last("limit 1");
AiMemberTalkItem aiMemberTalkItem = aiMemberTalkItemService.getByQuery(memberTalkItemQuery);
- aiMemberTalkItemService.add(memberUuid,aiMemberTalk.getId(),2,reqContext,new Date());
+ aiMemberTalkItemService.add(memberUuid,aiMemberTalk.getId(),companyId,2,reqContext,new Date());
String format = StrUtil.format(ANSWER_FORMAT, aiMemberTalkItem.getContext(), reqContext);
log.info("format:{}",format);
@@ -252,7 +256,7 @@
if ("null".equals( context)){
context = aiResponse.getResContext();
}
- AiMemberTalkItem talkItem = aiMemberTalkItemService.add(memberUuid, aiMemberTalk.getId(), 3, context, nowTime);
+ AiMemberTalkItem talkItem = aiMemberTalkItemService.add(memberUuid, aiMemberTalk.getId(),companyId, 3, context, nowTime);
this.updateTimeUpdate(nowTime,aiMemberTalk.getId());
@@ -264,9 +268,10 @@
return new FebsResponse().success().data(apiMemberTalkVo);
}
@Override
- public AiMemberTalk add(String memberUuid, String productId, Date nowTime) {
+ public AiMemberTalk add(String memberUuid,String companyId, String productId, Date nowTime) {
AiMemberTalk aiMemberTalk = new AiMemberTalk();
aiMemberTalk.setId(UUID.getSimpleUUIDString());
+ aiMemberTalk.setCompanyId(companyId);
aiMemberTalk.setCreatedTime(nowTime);
aiMemberTalk.setMemberId(memberUuid);
aiMemberTalk.setProductId(productId);
diff --git a/src/main/java/cc/mrbird/febs/ai/service/impl/AiTalkItemServiceImpl.java b/src/main/java/cc/mrbird/febs/ai/service/impl/AiTalkItemServiceImpl.java
index e4a6b73..a7c7531 100644
--- a/src/main/java/cc/mrbird/febs/ai/service/impl/AiTalkItemServiceImpl.java
+++ b/src/main/java/cc/mrbird/febs/ai/service/impl/AiTalkItemServiceImpl.java
@@ -26,9 +26,10 @@
private final AiTalkItemMapper aiTalkItemMapper;
@Override
- public void add(String id, int code, String context, String memberUuid, DateTime date) {
+ public void add(String id,String companyId, int code, String context, String memberUuid, DateTime date) {
AiTalkItem aiTalkItem = new AiTalkItem();
aiTalkItem.setId(UUID.getSimpleUUIDString());
+ aiTalkItem.setCompanyId(companyId);
aiTalkItem.setMemberId(memberUuid);
aiTalkItem.setType(code);
aiTalkItem.setTalkId(id);
diff --git a/src/main/java/cc/mrbird/febs/ai/service/impl/AiTalkServiceImpl.java b/src/main/java/cc/mrbird/febs/ai/service/impl/AiTalkServiceImpl.java
index cef8503..299d64c 100644
--- a/src/main/java/cc/mrbird/febs/ai/service/impl/AiTalkServiceImpl.java
+++ b/src/main/java/cc/mrbird/febs/ai/service/impl/AiTalkServiceImpl.java
@@ -76,16 +76,17 @@
Integer type = dto.getType();
String reasoningContent = dto.getReasoningContent();
String memberUuid = LoginUserUtil.getLoginUser().getMemberUuid();
+ String companyId = LoginUserUtil.getLoginUser().getCompanyId();
AiTalk aiTalk = this.getById(talkId);
DateTime date = DateUtil.date();
if (StrUtil.isEmpty(talkId)){
- aiTalk = this.add(memberUuid,context, date);
+ aiTalk = this.add(memberUuid,companyId,context, date);
}
HashMap<String, String> stringStringHashMap = new HashMap<>();
stringStringHashMap.put(LlmStrategyContextEnum.THINK.getName(),reasoningContent);
stringStringHashMap.put(LlmStrategyContextEnum.CONTENT.getName(),context);
- aiTalkItemService.add(aiTalk.getId(), type, JSONUtil.toJsonStr(stringStringHashMap), memberUuid, date);
+ aiTalkItemService.add(aiTalk.getId(), companyId,type, JSONUtil.toJsonStr(stringStringHashMap), memberUuid, date);
ApiTalkVo apiTalkVo = new ApiTalkVo();
apiTalkVo.setTalkId(aiTalk.getId());
@@ -93,9 +94,10 @@
}
@Override
- public AiTalk add(String memberUuid, String question, Date date) {
+ public AiTalk add(String memberUuid,String companyId, String question, Date date) {
AiTalk aiTalk = new AiTalk();
aiTalk.setId(UUID.getSimpleUUIDString());
+ aiTalk.setCompanyId(companyId);
aiTalk.setQuestion(question);
aiTalk.setCreatedTime(date);
aiTalk.setMemberId(memberUuid);
diff --git a/src/main/java/cc/mrbird/febs/ai/service/impl/ApiMemberTalkStreamServiceImpl.java b/src/main/java/cc/mrbird/febs/ai/service/impl/ApiMemberTalkStreamServiceImpl.java
index ff0df55..3c1e6f8 100644
--- a/src/main/java/cc/mrbird/febs/ai/service/impl/ApiMemberTalkStreamServiceImpl.java
+++ b/src/main/java/cc/mrbird/febs/ai/service/impl/ApiMemberTalkStreamServiceImpl.java
@@ -66,6 +66,8 @@
throw new FebsException("产品AI陪练不存在");
}
+ String companyId = aiProductRoleLink.getCompanyId();
+
Date nowTime = new Date();
LambdaQueryWrapper<AiMemberTalk> query = Wrappers.lambdaQuery(AiMemberTalk.class);
query.eq(AiMemberTalk::getMemberId,memberUuid);
@@ -73,7 +75,7 @@
query.last("limit 1");
AiMemberTalk aiMemberTalk = aiMemberTalkService.getByQuery(query);
if (ObjectUtil.isNull(aiMemberTalk)){
- aiMemberTalk = aiMemberTalkService.add(memberUuid,productId,nowTime);
+ aiMemberTalk = aiMemberTalkService.add(memberUuid,companyId,productId,nowTime);
}
ApiMemberTalkStreamVo apiMemberTalkVo = new ApiMemberTalkStreamVo();
@@ -81,7 +83,7 @@
AiProductQuestion question = aiProductQuestionService.createQuestion(productId);
if (ObjectUtil.isNotNull(question)){
title = question.getTitle();
- AiMemberTalkItem aiMemberTalkItem = aiMemberTalkItemService.add(memberUuid, aiMemberTalk.getId(), 1, title, nowTime);
+ AiMemberTalkItem aiMemberTalkItem = aiMemberTalkItemService.add(memberUuid, aiMemberTalk.getId(),companyId, 1, title, nowTime);
apiMemberTalkVo.setMemberTalkItemId(aiMemberTalkItem.getId());
aiMemberTalkService.updateTimeUpdate(nowTime,aiMemberTalk.getId());
}
@@ -128,7 +130,8 @@
if (ObjectUtil.isNull(aiMemberTalk)){
throw new FebsException("对话不存在");
}
- aiMemberTalkItemService.add(memberUuid,aiMemberTalk.getId(),2,content,new Date());
+ String companyId = aiMemberTalk.getCompanyId();
+ aiMemberTalkItemService.add(memberUuid,aiMemberTalk.getId(),companyId,2,content,new Date());
return new FebsResponse().success();
}
@@ -274,13 +277,14 @@
if (ObjectUtil.isNull(aiMemberTalk)){
throw new FebsException("对话不存在");
}
+ String companyId = aiMemberTalk.getCompanyId();
Integer type = dto.getType();
String memberTalkItemId;
String contentByCode = AiTalkOutputEnum.HIGH_LIGHT.getCodeByType(type);
if(StrUtil.isEmpty(dto.getMemberTalkItemId())){
HashMap<String, String> stringStringHashMap = new HashMap<>();
stringStringHashMap.put(contentByCode,content);
- AiMemberTalkItem add = aiMemberTalkItemService.add(memberUuid, memberTalkId, 3, JSONUtil.toJsonStr(stringStringHashMap), new Date());
+ AiMemberTalkItem add = aiMemberTalkItemService.add(memberUuid, memberTalkId,companyId, 3, JSONUtil.toJsonStr(stringStringHashMap), new Date());
memberTalkItemId = add.getId();
}else{
memberTalkItemId = dto.getMemberTalkItemId();
diff --git a/src/main/java/cc/mrbird/febs/mall/entity/MallMember.java b/src/main/java/cc/mrbird/febs/mall/entity/MallMember.java
index 5ece26c..44bb0a7 100644
--- a/src/main/java/cc/mrbird/febs/mall/entity/MallMember.java
+++ b/src/main/java/cc/mrbird/febs/mall/entity/MallMember.java
@@ -24,6 +24,8 @@
*/
private String name;
+ private String companyId;
+
/**
* 手机号
*/
diff --git a/src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallMemberServiceImpl.java b/src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallMemberServiceImpl.java
index e67b607..d5c99c4 100644
--- a/src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallMemberServiceImpl.java
+++ b/src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallMemberServiceImpl.java
@@ -745,6 +745,9 @@
mallMember = this.baseMapper.selectMemberByOpenId(openId);
String inviteId = ShareCodeUtil.toSerialCode(mallMember.getId());
mallMember.setMemberUuid(aiMember.getId());
+ if (StrUtil.isNotEmpty(aiMember.getCompanyId())){
+ mallMember.setCompanyId(aiMember.getCompanyId());
+ }
mallMember.setInviteId(inviteId);
this.baseMapper.updateById(mallMember);
MallMemberWallet wallet = new MallMemberWallet();
@@ -846,6 +849,10 @@
if(ObjectUtil.isNotEmpty(apiXcxSaveInfoDto.getGender())){
mallMember.setSex(1 == apiXcxSaveInfoDto.getGender() ? "女" : "男");
}
+
+ if(ObjectUtil.isNotEmpty(apiXcxSaveInfoDto.getCompanyId())){
+ mallMember.setCompanyId(apiXcxSaveInfoDto.getCompanyId());
+ }
this.baseMapper.updateById(mallMember);
String memberUuid = mallMember.getMemberUuid();
diff --git a/src/main/java/cc/mrbird/febs/mall/vo/MallMemberVo.java b/src/main/java/cc/mrbird/febs/mall/vo/MallMemberVo.java
index ea4f405..54dd6af 100644
--- a/src/main/java/cc/mrbird/febs/mall/vo/MallMemberVo.java
+++ b/src/main/java/cc/mrbird/febs/mall/vo/MallMemberVo.java
@@ -22,6 +22,9 @@
@ApiModelProperty(value = "昵称")
private String name;
+ @ApiModelProperty(value = "公司ID")
+ private String companyId;
+
@ApiModelProperty(value = "手机号")
private String phone;
--
Gitblit v1.9.1