You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
IESExtension/src/main/java/cn/teammodel/test/AsyncTeacherService.java

173 lines
7.3 KiB

package cn.teammodel.test;
import cn.teammodel.model.dto.admin.teacher.IdCodePair;
import cn.teammodel.model.entity.teacher.PtTeacherInfo;
import cn.teammodel.model.vo.admin.GpTeacherVo;
import cn.teammodel.repository.PtTeacherRepository;
import com.azure.cosmos.implementation.guava25.collect.Lists;
import org.apache.commons.lang3.tuple.Pair;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.BeanUtils;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.core.env.Environment;
import org.springframework.scheduling.annotation.Async;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional;
import java.util.Collections;
import java.util.List;
import java.util.Map;
import java.util.Objects;
import java.util.function.Function;
import java.util.stream.Collectors;
import static cn.teammodel.controller.admin.service.impl.TeacherServiceImpl.PT_TEACHER_CACHE;
@Service
public class AsyncTeacherService {
private static final Logger log = LoggerFactory.getLogger(AsyncTeacherService.class);
@Autowired
private PtTeacherRepository ptTeacherRepository;
public void testLog() {
log.info("【TEST】This is a test log entry.");
}
@Transactional(rollbackFor = Exception.class)
public void asyncSavePtTeacherInfos(List<GpTeacherVo> teachersList) {
try {
Map<String, PtTeacherInfo> existingTeachers = loadExistingTeachers(teachersList);
List<PtTeacherInfo> updates = teachersList.stream()
.filter(t -> t.getId() != null)
.map(t -> convertToPtTeacherInfo(t, existingTeachers))
.filter(Objects::nonNull) // 过滤掉未变更的记录
.collect(Collectors.toList());
if (!updates.isEmpty()) {
ptTeacherRepository.saveAll(updates);
updates.forEach(pt -> PT_TEACHER_CACHE.put(pt.getCode(), pt));
}
} catch (Exception e) {
log.error("Failed to save teacher info asynchronously", e);
}
}
private Map<String, PtTeacherInfo> loadExistingTeachers(List<GpTeacherVo> teachersList) {
List<IdCodePair> idAndCode = teachersList.stream()
.filter(t -> t.getId() != null)
.map(t -> new IdCodePair(t.getId(), "PtTeacher-" + t.getCode()))
.collect(Collectors.toList());
List<PtTeacherInfo> existingList = ptTeacherRepository.findByIdCodePairs(idAndCode);
return existingList.stream()
.collect(Collectors.toMap(
PtTeacherInfo::getCode,
Function.identity()
));
}
private PtTeacherInfo convertToPtTeacherInfo(GpTeacherVo teacher, Map<String, PtTeacherInfo> existingTeachers) {
String code = "PtTeacher-" + teacher.getCode();
PtTeacherInfo existing = existingTeachers.get(code);
// 如果数据库无记录,直接创建新对象
if (existing == null) {
return createNewPtTeacherInfo(teacher, code);
}
// 检查字段是否有变化
boolean isChanged = !Objects.equals(existing.getName(), teacher.getName())
|| !Objects.equals(existing.getPicture(), teacher.getPicture()) ||
!Objects.equals(existing.getEmail(), teacher.getEmail()) ||
!Objects.equals(existing.getPhone(), teacher.getPhone()) ||
!Objects.equals(existing.getSubjectIds(), teacher.getSubjectIds()) ||
!Objects.equals(existing.getRoles(), teacher.getRoles()) ||
!Objects.equals(existing.getStatus(), teacher.getStatus()) ||
!Objects.equals(existing.getJob(), teacher.getJob()) ||
!Objects.equals(existing.getPeriodId(), teacher.getPeriodId())
;
// 无变化则返回null表示无需更新
if (!isChanged) {
return null;
}
PtTeacherInfo updated = new PtTeacherInfo();
BeanUtils.copyProperties(existing, updated);
updated.setName(teacher.getName());
updated.setPhone(teacher.getPhone());
updated.setPicture(teacher.getPicture());
updated.setEmail(teacher.getEmail());
updated.setPeriodId(teacher.getPeriodId());
updated.setSubjectIds(teacher.getSubjectIds());
updated.setRoles(teacher.getRoles());
updated.setStatus(teacher.getStatus());
updated.setJob(teacher.getJob());
updated.setVersion(getNextVersion(updated.getId(), updated.getCode()));
return updated;
}
private Integer getNextVersion(String id,String code) {
PtTeacherInfo existingPtTeacherInfo = ptTeacherRepository.findByIdAndCode(id,code);
if (existingPtTeacherInfo != null) {
return existingPtTeacherInfo.getVersion() + 1;
}
return 1;
}
private PtTeacherInfo createNewPtTeacherInfo(GpTeacherVo teacher, String code) {
PtTeacherInfo ptTeacherInfo = new PtTeacherInfo();
// 固定值
ptTeacherInfo.setPk("PtTeacher");
ptTeacherInfo.setTtl(-1);
// 基础信息映射
ptTeacherInfo.setId(teacher.getId());
ptTeacherInfo.setCode(code);
ptTeacherInfo.setName(teacher.getName());
ptTeacherInfo.setPhone(teacher.getPhone() != null ? teacher.getPhone() : ""); // 空值处理
ptTeacherInfo.setEmail(teacher.getEmail() != null ? teacher.getEmail() : "");
ptTeacherInfo.setPicture(teacher.getPicture());
ptTeacherInfo.setJob(teacher.getJob());
ptTeacherInfo.setSchool(teacher.getCode());
ptTeacherInfo.setJoinTime(0L);
ptTeacherInfo.setState(1);
ptTeacherInfo.setVersion(1);
ptTeacherInfo.setAge(teacher.getAge() != null ? teacher.getAge() : 0);
ptTeacherInfo.setTeachingAge(teacher.getTeachingAge() != null ? teacher.getTeachingAge() : 0);
ptTeacherInfo.setStatus(teacher.getStatus() != null ? teacher.getStatus() : "");
// 学科与角色信息
ptTeacherInfo.setSubjectIds(teacher.getSubjectIds() != null ? teacher.getSubjectIds() : Collections.emptyList());
ptTeacherInfo.setSubjectNames(teacher.getSubjectNames() != null ? teacher.getSubjectNames() : Collections.emptyList());
ptTeacherInfo.setRoles(teacher.getRoles() != null ? teacher.getRoles() : Collections.emptyList());
//只是针对管理员权限的内容
if (teacher.getRoles() != null && teacher.getRoles().contains("admin")) {
ptTeacherInfo.setIdentity(Collections.singletonList("admin"));
} else {
ptTeacherInfo.setIdentity(Collections.singletonList("teacher"));
}
// 其他业务字段
ptTeacherInfo.setDegree(teacher.getDegree() != null ? teacher.getDegree() : "");
ptTeacherInfo.setGender(teacher.getGender() != null ? teacher.getGender() : "U"); // 未知性别默认值
ptTeacherInfo.setGrade(teacher.getGrade() != null ? teacher.getGrade() : Collections.emptyList());
ptTeacherInfo.setPeriodId(teacher.getPeriodId() != null ? teacher.getPeriodId() : "");
ptTeacherInfo.setTitle(teacher.getTitle() != null ? teacher.getTitle() : "");
// 版本号初始化
ptTeacherInfo.setVersion(1);
return ptTeacherInfo;
}
}