package com.whyc.service;
|
|
import com.baomidou.mybatisplus.core.conditions.update.UpdateWrapper;
|
import com.baomidou.mybatisplus.core.toolkit.Wrappers;
|
import com.github.pagehelper.PageHelper;
|
import com.github.pagehelper.PageInfo;
|
import com.whyc.constant.UserOperation;
|
import com.whyc.mapper.UserLogMapper;
|
import com.whyc.pojo.UserLog;
|
import com.whyc.util.ActionUtil;
|
import com.whyc.util.DateUtil;
|
import com.whyc.util.ExcelUtil;
|
import org.apache.poi.hssf.usermodel.HSSFWorkbook;
|
import org.springframework.stereotype.Service;
|
|
import javax.annotation.Resource;
|
import javax.servlet.http.HttpServletRequest;
|
import javax.servlet.http.HttpServletResponse;
|
import java.util.Date;
|
import java.util.List;
|
|
@Service
|
public class UserLogService {
|
|
@Resource
|
private UserLogMapper mapper;
|
|
public PageInfo<UserLog>getPage(int pageNum, int pageSize, UserLog userLog) {
|
PageHelper.startPage(pageNum, pageSize, true);
|
//这个接口要兼容新老审计日志记录的查询
|
List<UserLog> userLogList = mapper.getList(userLog);
|
//根据当前的语言环境设置不同的日志记录
|
String lang = ActionUtil.getLang();
|
userLogList.stream().forEach(userLog1 -> {
|
switch (userLog1.getOperationType()) {
|
case 1:
|
if (lang.contains("zh")) {
|
userLog1.setOperationTypeStr(UserOperation.TYPE_LOGIN.getTypeName());
|
} else {
|
userLog1.setOperationTypeStr(UserOperation.TYPE_LOGIN.getTypeNameEn());
|
}
|
break;
|
case 2:
|
if (lang.contains("zh")) {
|
userLog1.setOperationTypeStr(UserOperation.TYPE_LOGOUT.getTypeName());
|
} else {
|
userLog1.setOperationTypeStr(UserOperation.TYPE_LOGOUT.getTypeNameEn());
|
}
|
break;
|
case 3:
|
if (lang.contains("zh")) {
|
userLog1.setOperationTypeStr(UserOperation.TYPE_ADD.getTypeName());
|
} else {
|
userLog1.setOperationTypeStr(UserOperation.TYPE_ADD.getTypeNameEn());
|
}
|
break;
|
case 4:
|
if (lang.contains("zh")) {
|
userLog1.setOperationTypeStr(UserOperation.TYPE_UPDATE.getTypeName());
|
} else {
|
userLog1.setOperationTypeStr(UserOperation.TYPE_UPDATE.getTypeNameEn());
|
}
|
break;
|
case 5:
|
if (lang.contains("zh")) {
|
userLog1.setOperationTypeStr(UserOperation.TYPE_DELETE.getTypeName());
|
} else {
|
userLog1.setOperationTypeStr(UserOperation.TYPE_DELETE.getTypeNameEn());
|
}
|
break;
|
case 20:
|
if (lang.contains("zh")) {
|
userLog1.setOperationTypeStr(UserOperation.TYPE_UNAUTHORIZED_ACCESS.getTypeName());
|
} else {
|
userLog1.setOperationTypeStr(UserOperation.TYPE_UNAUTHORIZED_ACCESS.getTypeNameEn());
|
}
|
break;
|
case 21:
|
if (lang.contains("zh")) {
|
userLog1.setOperationTypeStr(UserOperation.TYPE_EXCEPTION.getTypeName());
|
} else {
|
userLog1.setOperationTypeStr(UserOperation.TYPE_EXCEPTION.getTypeNameEn());
|
}
|
break;
|
case 31:
|
if (lang.contains("zh")) {
|
userLog1.setOperationTypeStr(UserOperation.TYPE_LOGIN_FAIL.getTypeName());
|
} else {
|
userLog1.setOperationTypeStr(UserOperation.TYPE_LOGIN_FAIL.getTypeNameEn());
|
}
|
break;
|
case 32:
|
if (lang.contains("zh")) {
|
userLog1.setOperationTypeStr(UserOperation.TYPE_PARAM_CHANGE.getTypeName());
|
} else {
|
userLog1.setOperationTypeStr(UserOperation.TYPE_PARAM_CHANGE.getTypeNameEn());
|
}
|
break;
|
case 33:
|
if (lang.contains("zh")) {
|
userLog1.setOperationTypeStr(UserOperation.TYPE_PASSWORD_CHANGE.getTypeName());
|
} else {
|
userLog1.setOperationTypeStr(UserOperation.TYPE_PASSWORD_CHANGE.getTypeNameEn());
|
}
|
break;
|
case 34:
|
if (lang.contains("zh")) {
|
userLog1.setOperationTypeStr(UserOperation.TYPE_LOGIN_TIMEOUT.getTypeName());
|
} else {
|
userLog1.setOperationTypeStr(UserOperation.TYPE_LOGIN_TIMEOUT.getTypeNameEn());
|
}
|
break;
|
default:
|
if (lang.contains("zh")) {
|
userLog1.setOperationTypeStr(UserOperation.TYPE_UNRECOGNIZED.getTypeName());
|
} else {
|
userLog1.setOperationTypeStr(UserOperation.TYPE_UNRECOGNIZED.getTypeNameEn());
|
}
|
}
|
});
|
PageInfo<UserLog> pageInfo = new PageInfo<>(userLogList);
|
return pageInfo;
|
|
}
|
|
public void exportExcel(HttpServletResponse response, String[][] value) {
|
//根据当前的语言环境设置不同的日志记录
|
String lang = ActionUtil.getLang();
|
String[] columnTitleArr = null;
|
if (lang.contains("zh")) {
|
columnTitleArr = new String[]{"操作人姓名", "操作类型", "操作时间", "终端IP", "操作事件", "具体参数"};
|
} else {
|
columnTitleArr = new String[]{"Operator Name", "Operator Type", "Operator Time", "Operator IP", "Operator EVENT", "Specific parameters"};
|
}
|
String now = DateUtil.YYYY_MM_DD_HH_MM_SS_UNION.format(new Date());
|
ExcelUtil.exportExcel("UserLog-" + now, "sheet1", columnTitleArr, value, new HSSFWorkbook(), response);
|
}
|
|
public void record(long uId, int operationType, String msg) {
|
UserLog userLog = new UserLog();
|
userLog.setTerminalIp(ActionUtil.getRequest().getRemoteAddr());
|
//userLog.setTerminalIp(request.getRemoteAddr());
|
userLog.setOperationTime(new Date());
|
userLog.setUId((int)(uId));
|
userLog.setOperationType(operationType);
|
userLog.setOperationMsg(msg);
|
mapper.insert(userLog);
|
}
|
|
public void record(long uId, int operationType, String msg,String msgDetail) {
|
UserLog userLog = new UserLog();
|
userLog.setTerminalIp(ActionUtil.getRequest().getRemoteAddr());
|
//userLog.setTerminalIp(request.getRemoteAddr());
|
userLog.setOperationTime(new Date());
|
userLog.setUId((int)(uId));
|
userLog.setOperationType(operationType);
|
userLog.setOperationMsg(msg);
|
userLog.setOperationDetail(msgDetail);
|
mapper.insert(userLog);
|
}
|
|
public void record2(HttpServletRequest request,long uId, int operationType, String msg,String msgDetail) {
|
UserLog userLog = new UserLog();
|
userLog.setTerminalIp(request.getRemoteAddr());
|
//userLog.setTerminalIp(request.getRemoteAddr());
|
userLog.setOperationTime(new Date());
|
userLog.setUId((int)(uId));
|
userLog.setOperationType(operationType);
|
userLog.setOperationMsg(msg);
|
userLog.setOperationDetail(msgDetail);
|
mapper.insert(userLog);
|
}
|
|
public List<UserLog> getDataBeforeRetentionMonth(Date retentionTime) {
|
return mapper.getDataBeforeRetentionMonth(retentionTime);
|
}
|
|
public void insertBatch(List<UserLog> userLogs) {
|
mapper.insertBatchSomeColumn(userLogs);
|
}
|
|
public void deleteBeforeRetentionMonth(Date retentionTime) {
|
UpdateWrapper<UserLog> update = Wrappers.update();
|
|
update.lt("uOprateDay",retentionTime);
|
mapper.delete(update);
|
}
|
}
|