签字意见
parent
abf48d1d7d
commit
a691c6def9
|
@ -0,0 +1,114 @@
|
||||||
|
/* ******************* 德尔格 明细物料历史数据折扣带出提示 by youhong.ai ******************* */
|
||||||
|
$(() => {
|
||||||
|
let type = {
|
||||||
|
// 等于
|
||||||
|
equalTo: (value, target) => value == target,
|
||||||
|
// 不等于
|
||||||
|
notEqual: (value, target) => value != target,
|
||||||
|
// 大于
|
||||||
|
greaterThan: (value, target) => +value > +target,
|
||||||
|
// 小于
|
||||||
|
lessThan: (value, target) => +value < +target
|
||||||
|
}
|
||||||
|
// 值类型
|
||||||
|
let valueType = {
|
||||||
|
// 固定值
|
||||||
|
fixValue: 0,
|
||||||
|
// 流程字段
|
||||||
|
field: 1
|
||||||
|
}
|
||||||
|
let config = {
|
||||||
|
// 主表,填main
|
||||||
|
table: 'main',
|
||||||
|
// 明细表,明细1为detail_1,明细2为detail_2
|
||||||
|
detail: 'detail_1',
|
||||||
|
redField: 'zk',
|
||||||
|
// 条件集合
|
||||||
|
conditions: [{
|
||||||
|
// 所属表
|
||||||
|
table: 'detail_1',
|
||||||
|
// 字段
|
||||||
|
field: 'wllx',
|
||||||
|
// 对比值
|
||||||
|
value: 0,
|
||||||
|
// 值的类型
|
||||||
|
valueType: valueType.fixValue,
|
||||||
|
// 值字段所在表
|
||||||
|
valueTable: '',
|
||||||
|
// 条件类型
|
||||||
|
type: type.equalTo
|
||||||
|
}, {
|
||||||
|
// 所属表
|
||||||
|
table: 'detail_1',
|
||||||
|
// 字段
|
||||||
|
field: 'zkdc',
|
||||||
|
// 对比值
|
||||||
|
value: 'zk',
|
||||||
|
// 值的类型
|
||||||
|
valueType: valueType.field,
|
||||||
|
// 值字段所在表
|
||||||
|
valueTable: 'detail_1',
|
||||||
|
// 条件类型
|
||||||
|
type: type.notEqual
|
||||||
|
}]
|
||||||
|
}
|
||||||
|
|
||||||
|
runJs()
|
||||||
|
|
||||||
|
function runJs() {
|
||||||
|
let detailAllRowIndexStr = WfForm.getDetailAllRowIndexStr(config.detail);
|
||||||
|
let rowIndexArr = detailAllRowIndexStr.split(",");
|
||||||
|
let flag = true
|
||||||
|
rowIndexArr.forEach(rowIndex => {
|
||||||
|
if (flag) {
|
||||||
|
flag = isTrue(rowIndex)
|
||||||
|
} else {
|
||||||
|
isTrue(rowIndex)
|
||||||
|
}
|
||||||
|
})
|
||||||
|
if (!flag) {
|
||||||
|
WfForm.showConfirm("当前订单折扣不等于默认折扣");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
function isTrue(rowIndex) {
|
||||||
|
let flag = true
|
||||||
|
for (let i = 0; i < config.conditions.length; i++) {
|
||||||
|
let item = config.conditions[i]
|
||||||
|
let fieldId = WfForm.convertFieldNameToId(config, item.table)
|
||||||
|
let fieldMark = `${fieldId}_${rowIndex}`
|
||||||
|
let fieldValue = WfForm.getFieldValue(fieldMark)
|
||||||
|
if (item.valueType == valueType.fixValue) {
|
||||||
|
if (item.type(fieldValue, item.value)) {
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
renderRed(`${WfForm.convertFieldNameToId(config.redField, config.detail)}_${rowIndex}`)
|
||||||
|
flag = false
|
||||||
|
}
|
||||||
|
if (item.valueType == valueType.field) {
|
||||||
|
if (item.type(fieldValue, WfForm.getFieldValue(item.value, item.valueTable))) {
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
renderRed(`${WfForm.convertFieldNameToId(config.redField, config.detail)}_${rowIndex}`)
|
||||||
|
flag = false
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return flag
|
||||||
|
}
|
||||||
|
|
||||||
|
function renderRed(fieldMark) {
|
||||||
|
$(`#oTable0 .detail_odd_row.detail_data_row div[data-fieldmark='${fieldMark}'] .wf-form-input`).css({
|
||||||
|
color: '#FFF',
|
||||||
|
background: 'red',
|
||||||
|
})
|
||||||
|
$(`#oTable0 .detail_odd_row.detail_data_row div[data-fieldmark='${fieldMark}'] .wf-form-input input`).css({
|
||||||
|
'border-color': 'red',
|
||||||
|
background: 'red',
|
||||||
|
color: '#FFF'
|
||||||
|
})
|
||||||
|
}
|
||||||
|
})
|
||||||
|
|
||||||
|
/* ******************* 德尔格 明细物料历史数据折扣带出提示 end ******************* */
|
||||||
|
|
|
@ -1,6 +1,7 @@
|
||||||
package aiyh.utils.action;
|
package aiyh.utils.action;
|
||||||
|
|
||||||
import aiyh.utils.Util;
|
import aiyh.utils.Util;
|
||||||
|
import aiyh.utils.action.mapper.SafeActionMapper;
|
||||||
import aiyh.utils.excention.CustomerException;
|
import aiyh.utils.excention.CustomerException;
|
||||||
import com.google.common.base.Strings;
|
import com.google.common.base.Strings;
|
||||||
import org.apache.log4j.Logger;
|
import org.apache.log4j.Logger;
|
||||||
|
@ -29,6 +30,8 @@ public abstract class SafeCusBaseAction implements Action {
|
||||||
protected final Logger log = Util.getLogger();
|
protected final Logger log = Util.getLogger();
|
||||||
private final Map<String, SafeCusBaseActionHandleFunction> actionHandleMethod = new HashMap<>();
|
private final Map<String, SafeCusBaseActionHandleFunction> actionHandleMethod = new HashMap<>();
|
||||||
|
|
||||||
|
private final SafeActionMapper mapper = Util.getMapper(SafeActionMapper.class);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* <h2>初始化流程默认的处理方法</h2>
|
* <h2>初始化流程默认的处理方法</h2>
|
||||||
*/
|
*/
|
||||||
|
@ -191,7 +194,12 @@ public abstract class SafeCusBaseAction implements Action {
|
||||||
protected Map<String, String> getMainTableValue(RequestInfo requestInfo) {
|
protected Map<String, String> getMainTableValue(RequestInfo requestInfo) {
|
||||||
// 获取主表数据
|
// 获取主表数据
|
||||||
Property[] propertyArr = requestInfo.getMainTableInfo().getProperty();
|
Property[] propertyArr = requestInfo.getMainTableInfo().getProperty();
|
||||||
return getStringMap(propertyArr);
|
Map<String, String> result = getStringMap(propertyArr);
|
||||||
|
RequestManager requestManager = requestInfo.getRequestManager();
|
||||||
|
String billTable = requestManager.getBillTableName();
|
||||||
|
String id = mapper.selectIdByRequest(billTable, requestInfo.getRequestid());
|
||||||
|
result.put("id", id);
|
||||||
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
@NotNull
|
@NotNull
|
||||||
|
|
|
@ -0,0 +1,20 @@
|
||||||
|
package aiyh.utils.action.mapper;
|
||||||
|
|
||||||
|
import aiyh.utils.annotation.recordset.ParamMapper;
|
||||||
|
import aiyh.utils.annotation.recordset.Select;
|
||||||
|
import aiyh.utils.annotation.recordset.SqlMapper;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* <h1></h1>
|
||||||
|
*
|
||||||
|
* <p>create: 2023/4/17 17:47</p>
|
||||||
|
*
|
||||||
|
* @author youHong.ai
|
||||||
|
*/
|
||||||
|
@SqlMapper
|
||||||
|
public interface SafeActionMapper {
|
||||||
|
|
||||||
|
@Select("select id from $t{billTable} where requestid = #{requestId}")
|
||||||
|
String selectIdByRequest(@ParamMapper("billTable") String billTable,
|
||||||
|
@ParamMapper("requestId") String requestId);
|
||||||
|
}
|
|
@ -38,7 +38,6 @@ public class RequestLogShowOrHiddenImpl extends AbstractServiceProxy implements
|
||||||
Logger log = Util.getLogger();
|
Logger log = Util.getLogger();
|
||||||
try {
|
try {
|
||||||
privacyRequestLogUtil.requestLogList(result, params, request);
|
privacyRequestLogUtil.requestLogList(result, params, request);
|
||||||
log.info("最终的返回结果: " + JSON.toJSONString(result));
|
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
log.error("filter request log list error!" + Util.getErrString(e));
|
log.error("filter request log list error!" + Util.getErrString(e));
|
||||||
}
|
}
|
||||||
|
|
|
@ -4,6 +4,7 @@ import aiyh.utils.annotation.recordset.*;
|
||||||
import com.customization.youhong.deerge.requestlog.pojo.RequestLogPrivacyEntity;
|
import com.customization.youhong.deerge.requestlog.pojo.RequestLogPrivacyEntity;
|
||||||
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
import java.util.Map;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* <h1>拦截签字意见隐私处理</h1>
|
* <h1>拦截签字意见隐私处理</h1>
|
||||||
|
@ -24,9 +25,9 @@ public interface InterceptRequestLogMapper {
|
||||||
* @param operator 操作者
|
* @param operator 操作者
|
||||||
* @return 签字意见id
|
* @return 签字意见id
|
||||||
*/
|
*/
|
||||||
@Select("select logid from workflow_requestlog where REQUESTID = #{requestId} " +
|
@Select("select logid,operatetime from workflow_requestlog where REQUESTID = #{requestId} " +
|
||||||
"and NODEID = #{nodeId} and OPERATOR = #{operator} order by LOGID desc ")
|
"and NODEID = #{nodeId} and OPERATOR = #{operator} order by LOGID desc ")
|
||||||
Integer selectRequestLogId(@ParamMapper("requestId") String requestId,
|
List<Map<String, Object>> selectRequestLogId(@ParamMapper("requestId") String requestId,
|
||||||
@ParamMapper("nodeId") String nodeId,
|
@ParamMapper("nodeId") String nodeId,
|
||||||
@ParamMapper("operator") String operator);
|
@ParamMapper("operator") String operator);
|
||||||
|
|
||||||
|
|
|
@ -12,10 +12,7 @@ import weaver.hrm.HrmUserVarify;
|
||||||
import weaver.hrm.User;
|
import weaver.hrm.User;
|
||||||
|
|
||||||
import javax.servlet.http.HttpServletRequest;
|
import javax.servlet.http.HttpServletRequest;
|
||||||
import java.util.Arrays;
|
import java.util.*;
|
||||||
import java.util.List;
|
|
||||||
import java.util.Map;
|
|
||||||
import java.util.Objects;
|
|
||||||
import java.util.stream.Collectors;
|
import java.util.stream.Collectors;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -58,12 +55,31 @@ public class PrivacyRequestLogUtil {
|
||||||
}
|
}
|
||||||
logger.info("添加隐私按钮!未开启隐私");
|
logger.info("添加隐私按钮!未开启隐私");
|
||||||
// 未开启隐私,更新签字意见隐私信息为不隐私
|
// 未开启隐私,更新签字意见隐私信息为不隐私
|
||||||
Integer logId = mapper.selectRequestLogId(requestId, nodeId, userId);
|
List<Map<String, Object>> nodeIdMapList = mapper.selectRequestLogId(requestId, nodeId, userId);
|
||||||
|
logger.info("查询的log日志列表:" + nodeIdMapList);
|
||||||
|
if (CollectionUtil.isEmpty(nodeIdMapList)) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
Map<String, Object> firstLog = nodeIdMapList.get(0);
|
||||||
|
String operateTime = Util.null2String(firstLog.get("operatetime"));
|
||||||
|
List<Integer> logList = new ArrayList<>();
|
||||||
|
for (Map<String, Object> item : nodeIdMapList) {
|
||||||
|
String itemOperateTime = Util.null2String(item.get("operatetime"));
|
||||||
|
int logId = Integer.parseInt(Util.null2String(item.get("logid")));
|
||||||
|
if (operateTime.equals(itemOperateTime)) {
|
||||||
|
logList.add(logId);
|
||||||
|
} else {
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
for (Integer logId : logList) {
|
||||||
if (logId > 0) {
|
if (logId > 0) {
|
||||||
mapper.updateRequestLogStatus(logId, userId, nodeId, requestId, "0");
|
mapper.updateRequestLogStatus(logId, userId, nodeId, requestId, "0");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* <h2>插入更新隐私信息</h2>
|
* <h2>插入更新隐私信息</h2>
|
||||||
*
|
*
|
||||||
|
@ -74,8 +90,26 @@ public class PrivacyRequestLogUtil {
|
||||||
* @param enablePrivacy 是否开启隐私
|
* @param enablePrivacy 是否开启隐私
|
||||||
*/
|
*/
|
||||||
private void insertRequestPrivacyLog(String userId, String nodeId, String requestId, String field5, String enablePrivacy) {
|
private void insertRequestPrivacyLog(String userId, String nodeId, String requestId, String field5, String enablePrivacy) {
|
||||||
Integer logId = mapper.selectRequestLogId(requestId, nodeId, userId);
|
|
||||||
Logger logger = Util.getLogger();
|
Logger logger = Util.getLogger();
|
||||||
|
|
||||||
|
List<Map<String, Object>> nodeIdMapList = mapper.selectRequestLogId(requestId, nodeId, userId);
|
||||||
|
logger.info("查询的log日志列表:" + nodeIdMapList);
|
||||||
|
if (CollectionUtil.isEmpty(nodeIdMapList)) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
Map<String, Object> firstLog = nodeIdMapList.get(0);
|
||||||
|
String operateTime = Util.null2String(firstLog.get("operatetime"));
|
||||||
|
List<Integer> logList = new ArrayList<>();
|
||||||
|
for (Map<String, Object> item : nodeIdMapList) {
|
||||||
|
String itemOperateTime = Util.null2String(item.get("operatetime"));
|
||||||
|
int logId = Integer.parseInt(Util.null2String(item.get("logid")));
|
||||||
|
if (operateTime.equals(itemOperateTime)) {
|
||||||
|
logList.add(logId);
|
||||||
|
} else {
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
for (Integer logId : logList) {
|
||||||
logger.info("查询到的logId是:" + logId);
|
logger.info("查询到的logId是:" + logId);
|
||||||
if (logId <= 0) {
|
if (logId <= 0) {
|
||||||
throw new CustomerException("request log id query error!\n");
|
throw new CustomerException("request log id query error!\n");
|
||||||
|
@ -96,6 +130,7 @@ public class PrivacyRequestLogUtil {
|
||||||
dataId);
|
dataId);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* <h2>没有添加隐私按钮开关的逻辑处理</h2>
|
* <h2>没有添加隐私按钮开关的逻辑处理</h2>
|
||||||
|
@ -120,8 +155,6 @@ public class PrivacyRequestLogUtil {
|
||||||
}
|
}
|
||||||
String[] split = targetHrm.split(",");
|
String[] split = targetHrm.split(",");
|
||||||
List<String> hrmIds = Arrays.asList(split);
|
List<String> hrmIds = Arrays.asList(split);
|
||||||
logger.info("查询到hrmIds数据:" + JSON.toJSONString(hrmIds));
|
|
||||||
logger.info("当前用户Id:" + userId);
|
|
||||||
if (hrmIds.contains(userId)) {
|
if (hrmIds.contains(userId)) {
|
||||||
// 默认签字意见隐私
|
// 默认签字意见隐私
|
||||||
insertRequestPrivacyLog(userId, nodeId, requestId, field5, "1");
|
insertRequestPrivacyLog(userId, nodeId, requestId, field5, "1");
|
||||||
|
@ -139,21 +172,17 @@ public class PrivacyRequestLogUtil {
|
||||||
*/
|
*/
|
||||||
|
|
||||||
public void requestLogList(Map<String, Object> result, Map<String, Object> params, HttpServletRequest request) {
|
public void requestLogList(Map<String, Object> result, Map<String, Object> params, HttpServletRequest request) {
|
||||||
Logger logger = Util.getLogger();
|
|
||||||
String isMonitor = request.getParameter("ismonitor");
|
String isMonitor = request.getParameter("ismonitor");
|
||||||
boolean isPrint = "1".equals(Util.null2String(request.getParameter("isprint")));
|
boolean isPrint = "1".equals(Util.null2String(request.getParameter("isprint")));
|
||||||
String requestId = Util.null2String(params.get("requestid"));
|
String requestId = Util.null2String(params.get("requestid"));
|
||||||
User user = HrmUserVarify.getUser(request, null);
|
User user = HrmUserVarify.getUser(request, null);
|
||||||
logger.info("结果: " + JSON.toJSONString(result));
|
|
||||||
if (isPrint) {
|
if (isPrint) {
|
||||||
// 打印
|
// 打印
|
||||||
hiddenAll(result, requestId);
|
hiddenAll(result, requestId);
|
||||||
logger.info("最终的结果: " + JSON.toJSONString(result));
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
// 是流程监控
|
// 是流程监控
|
||||||
if (!StrUtil.isBlank(isMonitor)) {
|
if (!StrUtil.isBlank(isMonitor)) {
|
||||||
logger.info("流程监控最终的结果: " + JSON.toJSONString(result));
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -163,7 +192,6 @@ public class PrivacyRequestLogUtil {
|
||||||
if (CollectionUtil.isEmpty(privacyUserList)) {
|
if (CollectionUtil.isEmpty(privacyUserList)) {
|
||||||
// 不存在签字意见组中,所有隐私信息不可查看
|
// 不存在签字意见组中,所有隐私信息不可查看
|
||||||
hiddenAll(result, requestId);
|
hiddenAll(result, requestId);
|
||||||
logger.info("不在隐私组最终的结果: " + JSON.toJSONString(result));
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
// 查询非本组隐私的隐私信息
|
// 查询非本组隐私的隐私信息
|
||||||
|
@ -197,6 +225,7 @@ public class PrivacyRequestLogUtil {
|
||||||
*/
|
*/
|
||||||
private static void hiddenContentOrHiddenLog(Map<String, Object> result, List<Map<String, Object>> logList, List<String> privacyLogIdList) {
|
private static void hiddenContentOrHiddenLog(Map<String, Object> result, List<Map<String, Object>> logList, List<String> privacyLogIdList) {
|
||||||
String showContent = Util.getCusConfigValueNullOrEmpty("REQUEST_LOG_SHOW_CONTENT", "false");
|
String showContent = Util.getCusConfigValueNullOrEmpty("REQUEST_LOG_SHOW_CONTENT", "false");
|
||||||
|
String requestLogShowContentDefault = Util.getCusConfigValueNullOrEmpty("requestLogShowContentDefault", "");
|
||||||
if (!Boolean.parseBoolean(showContent)) {
|
if (!Boolean.parseBoolean(showContent)) {
|
||||||
List<Map<String, Object>> newLogList = logList.stream()
|
List<Map<String, Object>> newLogList = logList.stream()
|
||||||
.filter(item -> !privacyLogIdList.contains(Util.null2String(item.get("logid"))))
|
.filter(item -> !privacyLogIdList.contains(Util.null2String(item.get("logid"))))
|
||||||
|
@ -207,7 +236,7 @@ public class PrivacyRequestLogUtil {
|
||||||
List<Map<String, Object>> newLogList = logList.stream()
|
List<Map<String, Object>> newLogList = logList.stream()
|
||||||
.peek(item -> {
|
.peek(item -> {
|
||||||
if (privacyLogIdList.contains(Util.null2String(item.get("logid")))) {
|
if (privacyLogIdList.contains(Util.null2String(item.get("logid")))) {
|
||||||
item.put("log_remarkHtml", "");
|
item.put("log_remarkHtml", requestLogShowContentDefault);
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
.collect(Collectors.toList());
|
.collect(Collectors.toList());
|
||||||
|
|
File diff suppressed because it is too large
Load Diff
|
@ -0,0 +1,21 @@
|
||||||
|
package com.engine.youhong.ai.taibao.email;
|
||||||
|
|
||||||
|
import java.util.Set;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* <h1>黑名单扩展接口</h1>
|
||||||
|
*
|
||||||
|
* <p>create: 2023/4/14 17:07</p>
|
||||||
|
*
|
||||||
|
* @author youHong.ai
|
||||||
|
*/
|
||||||
|
public interface BlackListExpansion {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* <h2>发送邮件</h2>
|
||||||
|
*
|
||||||
|
* @param mailAddress 邮箱地址
|
||||||
|
* @return 邮箱地址
|
||||||
|
*/
|
||||||
|
Set<String> sendEmailHandler(Set<String> mailAddress);
|
||||||
|
}
|
|
@ -0,0 +1,38 @@
|
||||||
|
package com.engine.youhong.ai.taibao.email;
|
||||||
|
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Objects;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* <h1>注册信息</h1>
|
||||||
|
*
|
||||||
|
* <p>create: 2023/4/14 17:09</p>
|
||||||
|
*
|
||||||
|
* @author youHong.ai
|
||||||
|
*/
|
||||||
|
public class BlackListRegister {
|
||||||
|
|
||||||
|
private static final List<BlackListExpansion> EXPANSION_LIST = new ArrayList<>();
|
||||||
|
private static final List<BlackListExpansion> EXPANSION_APPROVE_LIST = new ArrayList<>();
|
||||||
|
|
||||||
|
public static void registerExpansion(BlackListExpansion blackListExpansion) {
|
||||||
|
if (Objects.nonNull(blackListExpansion)) {
|
||||||
|
EXPANSION_LIST.add(blackListExpansion);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void registerAPPROVEExpansion(BlackListExpansion blackListExpansion) {
|
||||||
|
if (Objects.nonNull(blackListExpansion)) {
|
||||||
|
EXPANSION_APPROVE_LIST.add(blackListExpansion);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static List<BlackListExpansion> getExpansionList() {
|
||||||
|
return EXPANSION_LIST;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static List<BlackListExpansion> getExpansionApproveList() {
|
||||||
|
return EXPANSION_APPROVE_LIST;
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,64 @@
|
||||||
|
package com.engine.youhong.ai.taibao.email.impl;
|
||||||
|
|
||||||
|
import aiyh.utils.Util;
|
||||||
|
import aiyh.utils.tool.cn.hutool.core.collection.CollectionUtil;
|
||||||
|
import com.engine.youhong.ai.taibao.email.BlackListRegister;
|
||||||
|
import com.engine.youhong.ai.taibao.email.mapper.InitBlackEmailListMapper;
|
||||||
|
import com.weaverboot.frame.ioc.anno.classAnno.WeaSysInitComponent;
|
||||||
|
import com.weaverboot.frame.ioc.anno.methodAnno.WeaSysInit;
|
||||||
|
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Objects;
|
||||||
|
import java.util.stream.Collectors;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* <h1>初始化扩展信息</h1>
|
||||||
|
*
|
||||||
|
* <p>create: 2023/4/14 17:15</p>
|
||||||
|
*
|
||||||
|
* @author youHong.ai
|
||||||
|
*/
|
||||||
|
|
||||||
|
@WeaSysInitComponent("注册email黑名单拦截器")
|
||||||
|
public class InitBlackListServiceImpl {
|
||||||
|
|
||||||
|
private final InitBlackEmailListMapper mapper = Util.getMapper(InitBlackEmailListMapper.class);
|
||||||
|
|
||||||
|
@WeaSysInit(order = 1, description = "注册拦截邮箱黑名单")
|
||||||
|
public void init() {
|
||||||
|
Util.getLogger().info("注册拦截邮箱黑名单,init");
|
||||||
|
BlackListRegister.registerExpansion(set -> {
|
||||||
|
if (Objects.isNull(set)) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
List<String> hrmList = mapper.selectWorkflowBlackEmailList();
|
||||||
|
String ids = Util.join(hrmList, ",");
|
||||||
|
List<String> blackEmailList = mapper.selectEmailListByHrmIds(ids);
|
||||||
|
if (CollectionUtil.isEmpty(blackEmailList)) {
|
||||||
|
return set;
|
||||||
|
}
|
||||||
|
return set.stream()
|
||||||
|
.filter(item -> !blackEmailList.contains(item))
|
||||||
|
.collect(Collectors.toSet());
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
@WeaSysInit(order = 2, description = "注册拦截邮箱黑名单")
|
||||||
|
public void initApprove() {
|
||||||
|
Util.getLogger().info("注册拦截邮箱黑名单,initApprove");
|
||||||
|
BlackListRegister.registerAPPROVEExpansion(set -> {
|
||||||
|
if (Objects.isNull(set)) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
String ids = mapper.selectWorkflowApproveBlackEmailList();
|
||||||
|
List<String> blackEmailList = mapper.selectEmailListByHrmIds(ids);
|
||||||
|
if (CollectionUtil.isEmpty(blackEmailList)) {
|
||||||
|
return set;
|
||||||
|
}
|
||||||
|
return set.stream()
|
||||||
|
.filter(item -> !blackEmailList.contains(item))
|
||||||
|
.collect(Collectors.toSet());
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -0,0 +1,44 @@
|
||||||
|
package com.engine.youhong.ai.taibao.email.mapper;
|
||||||
|
|
||||||
|
import aiyh.utils.annotation.recordset.Select;
|
||||||
|
import aiyh.utils.annotation.recordset.SqlMapper;
|
||||||
|
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* <h1></h1>
|
||||||
|
*
|
||||||
|
* <p>create: 2023/4/14 17:20</p>
|
||||||
|
*
|
||||||
|
* @author youHong.ai
|
||||||
|
*/
|
||||||
|
@SqlMapper
|
||||||
|
public interface InitBlackEmailListMapper {
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* <h2>查询流程黑名单</h2>
|
||||||
|
*
|
||||||
|
* @return email黑名单
|
||||||
|
*/
|
||||||
|
@Select("select black_hrm from uf_black_email_conf where type = 0")
|
||||||
|
List<String> selectWorkflowBlackEmailList();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* <h2>查询流程黑名单</h2>
|
||||||
|
*
|
||||||
|
* @return email黑名单
|
||||||
|
*/
|
||||||
|
@Select("select email from uf_black_email_conf where type = 1")
|
||||||
|
String selectWorkflowApproveBlackEmailList();
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* <h2>根据人员id查询邮件id</h2>
|
||||||
|
*
|
||||||
|
* @param ids 人员ids
|
||||||
|
* @return 邮件列表
|
||||||
|
*/
|
||||||
|
@Select("select email from hrmresource where id in ($t{ids})")
|
||||||
|
List<String> selectEmailListByHrmIds(String ids);
|
||||||
|
}
|
|
@ -10,19 +10,31 @@ import java.util.Map;
|
||||||
*/
|
*/
|
||||||
|
|
||||||
public enum GetValueTypeEnum {
|
public enum GetValueTypeEnum {
|
||||||
|
/** 流程字段 */
|
||||||
WORKFLOW_FIELD("0"),
|
WORKFLOW_FIELD("0"),
|
||||||
|
/** 默认值 */
|
||||||
DEFAULT_VALUE("1"),
|
DEFAULT_VALUE("1"),
|
||||||
|
/** 当前时间 */
|
||||||
CURRENT_TIME("3"),
|
CURRENT_TIME("3"),
|
||||||
|
/** 自定义sql */
|
||||||
CUS_SQL("4"),
|
CUS_SQL("4"),
|
||||||
|
/** 流程请求id */
|
||||||
REQUEST_ID("5"),
|
REQUEST_ID("5"),
|
||||||
|
/** 主表数据id */
|
||||||
MAIN_DATA_ID("6"),
|
MAIN_DATA_ID("6"),
|
||||||
|
/** 随机值 */
|
||||||
RANDOM("7"),
|
RANDOM("7"),
|
||||||
|
/** 附件 */
|
||||||
ATTACHMENT("8"),
|
ATTACHMENT("8"),
|
||||||
|
/** 自定义接口 */
|
||||||
|
|
||||||
CUS_INTERFACE("9"),
|
CUS_INTERFACE("9"),
|
||||||
|
|
||||||
CUS_FIELD("10");
|
/** 自定义字段 */
|
||||||
|
CUS_FIELD("10"),
|
||||||
|
|
||||||
|
/** 自定义mapper sql */
|
||||||
|
CUS_MAPPER_SQL("11");
|
||||||
|
|
||||||
private static final Map<String, GetValueTypeEnum> LOOK_UP = new HashMap<>(8);
|
private static final Map<String, GetValueTypeEnum> LOOK_UP = new HashMap<>(8);
|
||||||
|
|
||||||
|
|
|
@ -0,0 +1,21 @@
|
||||||
|
package weaver.xiao.commons.config.mapper;
|
||||||
|
|
||||||
|
import aiyh.utils.annotation.recordset.Select;
|
||||||
|
import aiyh.utils.annotation.recordset.SqlMapper;
|
||||||
|
import aiyh.utils.annotation.recordset.SqlString;
|
||||||
|
|
||||||
|
import java.util.Map;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* <h1></h1>
|
||||||
|
*
|
||||||
|
* <p>create: 2023/4/17 22:21</p>
|
||||||
|
*
|
||||||
|
* @author youHong.ai
|
||||||
|
*/
|
||||||
|
@SqlMapper
|
||||||
|
public interface DealWithMapper {
|
||||||
|
|
||||||
|
@Select(custom = true)
|
||||||
|
String selectCustomSql(@SqlString String sql, Map<String, Object> params);
|
||||||
|
}
|
|
@ -15,6 +15,7 @@ import weaver.xiao.commons.config.enumtype.GetValueTypeEnum;
|
||||||
import weaver.xiao.commons.config.enumtype.ParamTypeEnum;
|
import weaver.xiao.commons.config.enumtype.ParamTypeEnum;
|
||||||
import weaver.xiao.commons.config.interfacies.CusInterfaceGetValue;
|
import weaver.xiao.commons.config.interfacies.CusInterfaceGetValue;
|
||||||
import weaver.xiao.commons.config.interfacies.CusInterfaceListValue;
|
import weaver.xiao.commons.config.interfacies.CusInterfaceListValue;
|
||||||
|
import weaver.xiao.commons.config.mapper.DealWithMapper;
|
||||||
import weaver.xiao.commons.exception.ValueDealException;
|
import weaver.xiao.commons.exception.ValueDealException;
|
||||||
import weaver.zwl.common.ToolUtil;
|
import weaver.zwl.common.ToolUtil;
|
||||||
|
|
||||||
|
@ -57,6 +58,16 @@ public class DealWithMapping extends ToolUtil {
|
||||||
|
|
||||||
private RecordSet tempRs;
|
private RecordSet tempRs;
|
||||||
|
|
||||||
|
private DealWithMapper mapper = null;
|
||||||
|
|
||||||
|
{
|
||||||
|
try {
|
||||||
|
mapper = aiyh.utils.Util.getMapper(DealWithMapper.class);
|
||||||
|
} catch (Exception e) {
|
||||||
|
this.writeErrorLog("缺少 aiyh_utils.jar依赖,初始化失败!");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* <h1>将日期字符串转换为Date对象</h1>
|
* <h1>将日期字符串转换为Date对象</h1>
|
||||||
*
|
*
|
||||||
|
@ -748,6 +759,16 @@ public class DealWithMapping extends ToolUtil {
|
||||||
value = detailMap.get(valueContext.trim());
|
value = detailMap.get(valueContext.trim());
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
case CUS_MAPPER_SQL: {
|
||||||
|
Map<String, Object> param = new HashMap<>();
|
||||||
|
param.put("main", mainMap);
|
||||||
|
param.put("dt", detailMap);
|
||||||
|
if (mapper == null) {
|
||||||
|
throw new RuntimeException("缺少 aiyh_utils.jar依赖,无法使用mapper!");
|
||||||
|
}
|
||||||
|
value = mapper.selectCustomSql(valueContext, param);
|
||||||
|
}
|
||||||
|
break;
|
||||||
default:
|
default:
|
||||||
throw new ValueDealException("不支持的取值方式");
|
throw new ValueDealException("不支持的取值方式");
|
||||||
}
|
}
|
||||||
|
@ -1088,6 +1109,16 @@ public class DealWithMapping extends ToolUtil {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
case CUS_MAPPER_SQL: {
|
||||||
|
Map<String, Object> param = new HashMap<>();
|
||||||
|
param.put("main", mainMap);
|
||||||
|
param.put("dt", detailMap);
|
||||||
|
if (mapper == null) {
|
||||||
|
throw new RuntimeException("缺少 aiyh_utils.jar依赖,无法使用mapper!");
|
||||||
|
}
|
||||||
|
value = mapper.selectCustomSql(valueContext, param);
|
||||||
|
}
|
||||||
|
break;
|
||||||
default:
|
default:
|
||||||
throw new ValueDealException("不支持的取值方式");
|
throw new ValueDealException("不支持的取值方式");
|
||||||
}
|
}
|
||||||
|
|
|
@ -72,6 +72,16 @@ public class VoucherPayableAction extends SafeCusBaseAction {
|
||||||
@RequiredMark("ip")
|
@RequiredMark("ip")
|
||||||
private String ip;
|
private String ip;
|
||||||
|
|
||||||
|
|
||||||
|
@PrintParamMark
|
||||||
|
@RequiredMark("应付凭证远程文件名称前缀")
|
||||||
|
private String pavFileName;
|
||||||
|
|
||||||
|
|
||||||
|
@PrintParamMark
|
||||||
|
@RequiredMark("付款凭证远程文件名称前缀")
|
||||||
|
private String pmvFileName;
|
||||||
|
|
||||||
@PrintParamMark
|
@PrintParamMark
|
||||||
@ActionOptionalParam(desc = "是否删除生成的临时本地文件,true - 删除 false - 不删除", value = "false")
|
@ActionOptionalParam(desc = "是否删除生成的临时本地文件,true - 删除 false - 不删除", value = "false")
|
||||||
private String deleteTemp = "false";
|
private String deleteTemp = "false";
|
||||||
|
@ -86,10 +96,10 @@ public class VoucherPayableAction extends SafeCusBaseAction {
|
||||||
String fileName = "";
|
String fileName = "";
|
||||||
String remotePath = "";
|
String remotePath = "";
|
||||||
if (Integer.parseInt(voucherType) == 1) {
|
if (Integer.parseInt(voucherType) == 1) {
|
||||||
fileName = "Pav" + Util.getTime("yyyyMMddHHmmss") + ".txt";
|
fileName = pavFileName + Util.getTime("yyyyMMddHHmmssSSSS") + ".txt";
|
||||||
remotePath = pavRemotePath;
|
remotePath = pavRemotePath;
|
||||||
} else if (Integer.parseInt(voucherType) == 2) {
|
} else if (Integer.parseInt(voucherType) == 2) {
|
||||||
fileName = "Pmv" + Util.getTime("yyyyMMddHHmmss") + ".txt";
|
fileName = pmvFileName + Util.getTime("yyyyMMddHHmmssSSSS") + ".txt";
|
||||||
remotePath = pmvRemotePath;
|
remotePath = pmvRemotePath;
|
||||||
}
|
}
|
||||||
log.info("远程连接地址:" + "smb://" + ip + remotePath);
|
log.info("远程连接地址:" + "smb://" + ip + remotePath);
|
||||||
|
|
|
@ -0,0 +1,246 @@
|
||||||
|
package weaver.youhong.ai.haripijiu.action.sapdocking;
|
||||||
|
|
||||||
|
import aiyh.utils.Util;
|
||||||
|
import aiyh.utils.action.SafeCusBaseAction;
|
||||||
|
import aiyh.utils.annotation.*;
|
||||||
|
import aiyh.utils.excention.CustomerException;
|
||||||
|
import aiyh.utils.tool.cn.hutool.core.lang.Assert;
|
||||||
|
import lombok.Setter;
|
||||||
|
import org.jetbrains.annotations.NotNull;
|
||||||
|
import weaver.general.GCONST;
|
||||||
|
import weaver.hrm.User;
|
||||||
|
import weaver.soa.workflow.request.RequestInfo;
|
||||||
|
import weaver.xiao.commons.config.entity.RequestMappingConfig;
|
||||||
|
import weaver.xiao.commons.config.service.DealWithMapping;
|
||||||
|
import weaver.youhong.ai.haripijiu.action.sapdocking.util.SmbjUtil;
|
||||||
|
|
||||||
|
import java.io.File;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.io.OutputStreamWriter;
|
||||||
|
import java.nio.charset.StandardCharsets;
|
||||||
|
import java.nio.file.Files;
|
||||||
|
import java.nio.file.Path;
|
||||||
|
import java.nio.file.Paths;
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Map;
|
||||||
|
import java.util.UUID;
|
||||||
|
import java.util.stream.Collectors;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* <h1>对私凭证action</h1>
|
||||||
|
*
|
||||||
|
* <p>create: 2023/4/17 14:57</p>
|
||||||
|
*
|
||||||
|
* @author youHong.ai
|
||||||
|
*/
|
||||||
|
@ActionDesc(author = "youhong.ai", value = "对私凭证action")
|
||||||
|
@Setter
|
||||||
|
public class VoucherPayableNewAction extends SafeCusBaseAction {
|
||||||
|
|
||||||
|
|
||||||
|
private final DealWithMapping dealWithMapping = new DealWithMapping();
|
||||||
|
|
||||||
|
@PrintParamMark
|
||||||
|
@RequiredMark("请求参数配置表配置唯一标识字段!")
|
||||||
|
@ActionDefaultTestValue("duisi")
|
||||||
|
private String onlyMark;
|
||||||
|
|
||||||
|
@PrintParamMark
|
||||||
|
@ActionOptionalParam(value = "false", desc = "是否自动提交流程 false : 不提交; true : 提交")
|
||||||
|
private String submitAction = "false";
|
||||||
|
|
||||||
|
@PrintParamMark
|
||||||
|
@ActionOptionalParam(value = "true", desc = "是否失败后阻断流程, false : 不阻断; true: 阻断")
|
||||||
|
private String block = "true";
|
||||||
|
|
||||||
|
@PrintParamMark
|
||||||
|
@RequiredMark("凭证类型,1- 应付凭证; 2- 付款凭证")
|
||||||
|
private String voucherType;
|
||||||
|
|
||||||
|
|
||||||
|
@PrintParamMark
|
||||||
|
@RequiredMark("应付凭证远程路径")
|
||||||
|
private String pavRemotePath;
|
||||||
|
|
||||||
|
|
||||||
|
@PrintParamMark
|
||||||
|
@RequiredMark("付款凭证远程路径")
|
||||||
|
private String pmvRemotePath;
|
||||||
|
|
||||||
|
@PrintParamMark
|
||||||
|
@RequiredMark("用户名")
|
||||||
|
private String userName;
|
||||||
|
|
||||||
|
@PrintParamMark
|
||||||
|
@RequiredMark("密码")
|
||||||
|
private String password;
|
||||||
|
|
||||||
|
|
||||||
|
@PrintParamMark
|
||||||
|
@RequiredMark("ip")
|
||||||
|
private String ip;
|
||||||
|
|
||||||
|
|
||||||
|
@PrintParamMark
|
||||||
|
@RequiredMark("应付凭证远程文件名称前缀")
|
||||||
|
private String pavFileName;
|
||||||
|
|
||||||
|
|
||||||
|
@PrintParamMark
|
||||||
|
@RequiredMark("付款凭证远程文件名称前缀")
|
||||||
|
private String pmvFileName;
|
||||||
|
|
||||||
|
@PrintParamMark
|
||||||
|
@ActionOptionalParam(desc = "是否删除生成的临时本地文件,true - 删除 false - 不删除", value = "false")
|
||||||
|
private String deleteTemp = "false";
|
||||||
|
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void doSubmit(String requestId, String billTable, int workflowId, User user, RequestInfo requestInfo) {
|
||||||
|
|
||||||
|
try {
|
||||||
|
SmbjUtil smbjUtil = new SmbjUtil();
|
||||||
|
String tempFilePath = getFile(billTable, requestInfo);
|
||||||
|
String fileName = "";
|
||||||
|
String remotePath = "";
|
||||||
|
if (Integer.parseInt(voucherType) == 1) {
|
||||||
|
fileName = pavFileName + Util.getTime("yyyyMMddHHmmssSSSS") + ".txt";
|
||||||
|
remotePath = pavRemotePath;
|
||||||
|
} else if (Integer.parseInt(voucherType) == 2) {
|
||||||
|
fileName = pmvFileName + Util.getTime("yyyyMMddHHmmssSSSS") + ".txt";
|
||||||
|
remotePath = pmvRemotePath;
|
||||||
|
}
|
||||||
|
log.info("远程连接地址:" + "smb://" + ip + remotePath);
|
||||||
|
log.info("本地文件地址: " + tempFilePath);
|
||||||
|
smbjUtil.smbPut("smb://" + ip + remotePath, tempFilePath, userName, password, fileName);
|
||||||
|
if (Boolean.parseBoolean(deleteTemp)) {
|
||||||
|
Files.delete(Paths.get(tempFilePath));
|
||||||
|
}
|
||||||
|
/* ******************* 是否提交流程 ******************* */
|
||||||
|
if (Boolean.parseBoolean(submitAction)) {
|
||||||
|
this.submitWorkflow(requestId, user.getUID());
|
||||||
|
}
|
||||||
|
} catch (Exception e) {
|
||||||
|
log.error("推送应付款凭证失败!" + e.getMessage());
|
||||||
|
if (Boolean.parseBoolean(block)) {
|
||||||
|
throw new CustomerException(e.getMessage(), e);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public void submitWorkflow(String requestId, Integer userId) {
|
||||||
|
Util.submitWorkflowThread(Integer.parseInt(requestId), userId, "sap对接自动提交流程!");
|
||||||
|
}
|
||||||
|
|
||||||
|
private String getFile(String billTable, RequestInfo requestInfo) {
|
||||||
|
dealWithMapping.setMainTable(billTable);
|
||||||
|
RequestMappingConfig requestMappingConfig = dealWithMapping.treeDealWithUniqueCode(onlyMark);
|
||||||
|
Map<String, Object> requestParam = dealWithMapping.getRequestParam(getObjMainTableValue(requestInfo), requestMappingConfig);
|
||||||
|
Assert.notEmpty(requestParam, "query config error, can not query result by onlyMark:[{}],Please check the configuration table", onlyMark);
|
||||||
|
// 借方
|
||||||
|
List<Object> debit = (List<Object>) requestParam.get("debit");
|
||||||
|
// 贷方
|
||||||
|
List<Object> creditSide = (List<Object>) requestParam.get("creditSide");
|
||||||
|
// 凭证头
|
||||||
|
Map<String, Object> heads = (Map<String, Object>) requestParam.get("heads");
|
||||||
|
Assert.notEmpty(heads, "No relevant voucher header data was found. Please check the configuration table and process table data.");
|
||||||
|
Assert.notEmpty(debit, "No relevant voucher details have been queried. Please check whether there is data in the process schedule.");
|
||||||
|
Assert.notEmpty(creditSide, "No credit data was found. Please check whether the configuration table is configured correctly and whether the process data exists.");
|
||||||
|
return createFile(debit, creditSide, heads);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
private String createFile(List<Object> debit, List<Object> creditSide, Map<String, Object> heads) {
|
||||||
|
StringBuilder sb = new StringBuilder();
|
||||||
|
// 写入凭证头
|
||||||
|
List<String> headKeys = new ArrayList<>();
|
||||||
|
for (Map.Entry<String, Object> entry : heads.entrySet()) {
|
||||||
|
headKeys.add(entry.getKey());
|
||||||
|
}
|
||||||
|
headKeys = sortKey(headKeys);
|
||||||
|
for (String headKey : headKeys) {
|
||||||
|
sb.append(heads.get(headKey)).append("\t");
|
||||||
|
}
|
||||||
|
sb.deleteCharAt(sb.lastIndexOf("\t"));
|
||||||
|
sb.append("\r\n");
|
||||||
|
// 写入借方信息
|
||||||
|
writeList(debit, sb);
|
||||||
|
// 写入贷方信息
|
||||||
|
writeList(creditSide, sb);
|
||||||
|
String filePath = getFilePath();
|
||||||
|
try {
|
||||||
|
OutputStreamWriter out = new OutputStreamWriter(
|
||||||
|
Files.newOutputStream(Paths.get(filePath)), StandardCharsets.UTF_8);
|
||||||
|
out.write(sb.toString());
|
||||||
|
out.close();
|
||||||
|
|
||||||
|
} catch (IOException e) {
|
||||||
|
throw new CustomerException(Util.logStr("can not writer file [{}]", filePath));
|
||||||
|
}
|
||||||
|
|
||||||
|
return filePath;
|
||||||
|
}
|
||||||
|
|
||||||
|
private void writeList(List<Object> list, StringBuilder sb) {
|
||||||
|
Map<String, Object> firstMap = (Map<String, Object>) list.get(0);
|
||||||
|
List<String> keys = new ArrayList<>();
|
||||||
|
for (Map.Entry<String, Object> entry : firstMap.entrySet()) {
|
||||||
|
keys.add(entry.getKey());
|
||||||
|
}
|
||||||
|
if (list.size() > 1) {
|
||||||
|
Map<String, Object> secondMap = (Map<String, Object>) list.get(1);
|
||||||
|
for (Map.Entry<String, Object> entry : secondMap.entrySet()) {
|
||||||
|
if (keys.contains(entry.getKey())) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
keys.add(entry.getKey());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
keys = sortKey(keys);
|
||||||
|
for (Object o : list) {
|
||||||
|
Map<String, Object> map = (Map<String, Object>) o;
|
||||||
|
for (String key : keys) {
|
||||||
|
if (map.containsKey(key)) {
|
||||||
|
sb.append(map.get(key))
|
||||||
|
.append("\t");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
sb.deleteCharAt(sb.lastIndexOf("\t"));
|
||||||
|
sb.append("\r\n");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private List<String> sortKey(List<String> list) {
|
||||||
|
return list.stream()
|
||||||
|
.map(Integer::parseInt)
|
||||||
|
.sorted()
|
||||||
|
.map(Util::null2String)
|
||||||
|
.collect(Collectors.toList());
|
||||||
|
}
|
||||||
|
|
||||||
|
@NotNull
|
||||||
|
private String getFilePath() {
|
||||||
|
String sysFilePath = GCONST.getSysFilePath();
|
||||||
|
String filePath;
|
||||||
|
if (sysFilePath.endsWith(File.separator)) {
|
||||||
|
filePath = sysFilePath + "cus_temp" + File.separator + "voucher-new" + File.separator +
|
||||||
|
System.currentTimeMillis() + "-voucher-new-" + UUID.randomUUID() + ".txt";
|
||||||
|
} else {
|
||||||
|
filePath = sysFilePath + File.separator + "cus_temp" + File.separator + "voucher" + File.separator +
|
||||||
|
System.currentTimeMillis() + "-voucher-new-" + UUID.randomUUID() + ".txt";
|
||||||
|
}
|
||||||
|
Path path = Paths.get(filePath);
|
||||||
|
if (!Files.exists(path)) {
|
||||||
|
Path parent = path.getParent();
|
||||||
|
try {
|
||||||
|
Files.createDirectories(parent);
|
||||||
|
} catch (IOException e) {
|
||||||
|
throw new CustomerException(Util.logStr("can not create file [{}]", filePath));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return filePath;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
}
|
|
@ -1,10 +1,12 @@
|
||||||
package youhong.ai.haripijiu;
|
package youhong.ai.haripijiu;
|
||||||
|
|
||||||
import aiyh.utils.GenerateFileUtil;
|
import aiyh.utils.GenerateFileUtil;
|
||||||
|
import aiyh.utils.Util;
|
||||||
import basetest.BaseTest;
|
import basetest.BaseTest;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
import weaver.youhong.ai.haripijiu.action.sapdocking.ReceiptAndPaymentAction;
|
import weaver.youhong.ai.haripijiu.action.sapdocking.ReceiptAndPaymentAction;
|
||||||
import weaver.youhong.ai.haripijiu.action.sapdocking.VoucherPayableAction;
|
import weaver.youhong.ai.haripijiu.action.sapdocking.VoucherPayableAction;
|
||||||
|
import weaver.youhong.ai.haripijiu.action.sapdocking.VoucherPayableNewAction;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* <h1>测试</h1>
|
* <h1>测试</h1>
|
||||||
|
@ -25,5 +27,6 @@ public class TestHaRiPiJiu extends BaseTest {
|
||||||
@Test
|
@Test
|
||||||
public void test1() {
|
public void test1() {
|
||||||
|
|
||||||
|
Util.actionTest(VoucherPayableNewAction.class, 405407);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -296,4 +296,8 @@ public class UtilTest extends BaseTest {
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testSS() {
|
||||||
|
out.println(Util.getTime("yyyyMMddHHmmssSSSS"));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -7,6 +7,7 @@ import com.alibaba.fastjson.JSONArray;
|
||||||
import com.api.youhong.ai.taibao.fcuntionlist.service.FunctionListService;
|
import com.api.youhong.ai.taibao.fcuntionlist.service.FunctionListService;
|
||||||
import com.api.youhong.ai.taibao.qikan.service.PeriodicalService;
|
import com.api.youhong.ai.taibao.qikan.service.PeriodicalService;
|
||||||
import com.cloudstore.dev.api.util.Util_DataCache;
|
import com.cloudstore.dev.api.util.Util_DataCache;
|
||||||
|
import com.engine.youhong.ai.taibao.email.mapper.InitBlackEmailListMapper;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
import weaver.conn.RecordSet;
|
import weaver.conn.RecordSet;
|
||||||
import weaver.general.BaseBean;
|
import weaver.general.BaseBean;
|
||||||
|
@ -158,4 +159,14 @@ public class TestTaiBao extends BaseTest {
|
||||||
public void testTableModelId() {
|
public void testTableModelId() {
|
||||||
System.out.println(Util.getModeIdByTableName("uf_privacy_log_info"));
|
System.out.println(Util.getModeIdByTableName("uf_privacy_log_info"));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testEmailSelect() {
|
||||||
|
InitBlackEmailListMapper mapper = Util.getMapper(InitBlackEmailListMapper.class);
|
||||||
|
List<String> hrmList = mapper.selectWorkflowBlackEmailList();
|
||||||
|
String ids = Util.join(hrmList, ",");
|
||||||
|
List<String> strings = mapper.selectEmailListByHrmIds(ids);
|
||||||
|
System.out.println(JSON.toJSONString(strings));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,9 +1,11 @@
|
||||||
package youhong.ai.utiltest;
|
package youhong.ai.utiltest;
|
||||||
|
|
||||||
|
import aiyh.utils.GenerateFileUtil;
|
||||||
import aiyh.utils.Util;
|
import aiyh.utils.Util;
|
||||||
import aiyh.utils.tool.cn.hutool.core.collection.CollectionUtil;
|
import aiyh.utils.tool.cn.hutool.core.collection.CollectionUtil;
|
||||||
import basetest.BaseTest;
|
import basetest.BaseTest;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
|
import weaver.youhong.ai.haripijiu.action.sapdocking.VoucherPayableNewAction;
|
||||||
|
|
||||||
import java.lang.reflect.Field;
|
import java.lang.reflect.Field;
|
||||||
import java.lang.reflect.ParameterizedType;
|
import java.lang.reflect.ParameterizedType;
|
||||||
|
@ -82,4 +84,10 @@ public class GenericTest extends BaseTest {
|
||||||
System.out.println(aClass);
|
System.out.println(aClass);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testGre() {
|
||||||
|
GenerateFileUtil.createActionDocument(VoucherPayableNewAction.class);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
Loading…
Reference in New Issue