Compare commits

..

No commits in common. "09ea2f1bdb2edaf81630b39c73290c76233ac2da" and "28464f4c8d9e1dcf9aa13c6f020900c4063d7f9d" have entirely different histories.

15 changed files with 1289 additions and 1622 deletions

12
pom.xml
View File

@ -64,18 +64,7 @@
<artifactId>junit</artifactId>
<version>4.12</version>
</dependency>
<!-- -->
<!-- <dependency>-->
<!-- <groupId>eu.agno3.jcifs</groupId>-->
<!-- <artifactId>jcifs-ng</artifactId>-->
<!-- <version>2.1.9</version>-->
<!-- </dependency>-->
<dependency>
<groupId>com.hierynomus</groupId>
<artifactId>smbj</artifactId>
<version>0.10.0</version>
</dependency>
<!-- easy excel -->
<dependency>
@ -98,6 +87,7 @@
</dependency>
</dependencies>
<repositories>

View File

@ -17,5 +17,5 @@ public class DocImageInfo {
private Integer id;
private Integer detailId;
private Integer fileSize;
private Integer docFileType;
}

View File

@ -4,7 +4,6 @@ package aiyh.utils.httpUtil;
import aiyh.utils.Util;
import com.alibaba.fastjson.JSON;
import com.alibaba.fastjson.JSONArray;
import com.alibaba.fastjson.JSONException;
import com.fasterxml.jackson.core.JsonProcessingException;
import com.fasterxml.jackson.core.type.TypeReference;
import com.fasterxml.jackson.databind.ObjectMapper;
@ -134,11 +133,7 @@ public class ResponeVo implements HttpResponse {
ObjectMapper mapper = new ObjectMapper();
this.entityMap = mapper.readValue(this.getEntityString(), Map.class);
} catch (JsonProcessingException ignored) {
try {
this.resultList = (List<Map>) JSONArray.parseArray(this.getEntityString(), Map.class);
} catch (JSONException e) {
Util.getLogger().error("Unable to convert the response result to array" + Util.getErrString(e));
}
} catch (Exception e) {
Util.getLogger().error("Unable to convert the response result to map or array" + Util.getErrString(e));
}

View File

@ -4,15 +4,13 @@ import aiyh.utils.Util;
import aiyh.utils.httpUtil.*;
import aiyh.utils.httpUtil.httpAsync.HttpAsyncThread;
import aiyh.utils.httpUtil.httpAsync.HttpAsyncThreadCallBack;
import aiyh.utils.zwl.common.ToolUtil;
import com.alibaba.fastjson.JSON;
import com.alibaba.fastjson.JSONObject;
import com.alibaba.fastjson.serializer.SerializerFeature;
import com.alibaba.fastjson.support.spring.PropertyPreFilters;
import com.google.common.base.Strings;
import com.google.common.util.concurrent.ThreadFactoryBuilder;
import lombok.Getter;
import lombok.Setter;
import lombok.ToString;
import org.apache.http.HttpEntity;
import org.apache.http.NameValuePair;
import org.apache.http.client.CredentialsProvider;
@ -43,26 +41,32 @@ import java.util.function.Function;
* @author EBU7-dev1-ayh
* @date 2021/8/31 0031 17:16 http HttpStaticUtils使HttpStaticUtils
*/
@ToString
public class HttpUtils {
public static final String JSON_PARAM_KEY = "JSON_PARAM_KEY";
public static final ThreadLocal<HttpUtilParamInfo> HTTP_UTIL_PARAM_INFO_THREAD_LOCAL = new ThreadLocal<>();
private static final Logger log = Util.getLogger("http_util");
@Getter
private final ToolUtil toolUtil = new ToolUtil();
private final GlobalCache globalCache = new GlobalCache();
// 线程池
private final ThreadPoolExecutor executorService;
private final PropertyPreFilters filters = new PropertyPreFilters();
private final PropertyPreFilters.MySimplePropertyPreFilter excludefilter = filters.addFilter();
// 默认编码
@Setter
private String DEFAULT_ENCODING = "UTF-8";
@Setter
private String sslKeyPath = "";
@Setter
private String password = "";
public void setSslKeyPath(String sslKeyPath) {
this.sslKeyPath = sslKeyPath;
}
public void setPassword(String password) {
this.password = password;
}
/**
* basic
@ -144,6 +148,17 @@ public class HttpUtils {
return str;
}
public void setCredentialsProvider(CredentialsProvider credentialsProvider) {
this.credentialsProvider = credentialsProvider;
}
public GlobalCache getGlobalCache() {
return globalCache;
}
public void setDEFAULT_ENCODING() {
this.DEFAULT_ENCODING = DEFAULT_ENCODING;
}
public HttpPost getHttpPost(String url) {
HttpPost httpPost = new HttpPost(url);
@ -636,15 +651,9 @@ public class HttpUtils {
CloseableHttpResponse response = null;
try {
response = httpClient.execute(request);
} catch (Exception e) {
log.error(" http调用失败:" + Util.getErrString(e));
HTTP_UTIL_PARAM_INFO_THREAD_LOCAL.remove();
ExtendedIOUtils.closeQuietly(httpClient);
throw e;
}
try {
consumer.accept(response);
} catch (Exception e) {
toolUtil.writeErrorLog(" http调用失败:" + e);
throw e;
} finally {
HTTP_UTIL_PARAM_INFO_THREAD_LOCAL.remove();
@ -658,15 +667,9 @@ public class HttpUtils {
ResponeVo apply = null;
try {
response = httpClient.execute(request);
} catch (Exception e) {
log.error(" http调用失败:" + Util.getErrString(e));
HTTP_UTIL_PARAM_INFO_THREAD_LOCAL.remove();
ExtendedIOUtils.closeQuietly(httpClient);
throw e;
}
try {
apply = consumer.apply(response);
} catch (Exception e) {
toolUtil.writeErrorLog(" http调用失败:" + e);
throw e;
} finally {
HttpUtilParamInfo httpUtilParamInfo = HTTP_UTIL_PARAM_INFO_THREAD_LOCAL.get();
@ -674,13 +677,11 @@ public class HttpUtils {
httpUtilParamInfo = new HttpUtilParamInfo();
}
httpUtilParamInfo.setResponse(apply);
if (apply != null) {
if (apply.getResponseMap() == null) {
httpUtilParamInfo.setResponseString(apply.getEntityString());
} else {
httpUtilParamInfo.setResponseMap(apply.getResponseMap());
}
}
httpUtilParamInfo.setResponseDate(new Date());
try {
log.info(Util.logStr("url [{}] request info : [\n{}\n];", httpUtilParamInfo.getUrl(),
@ -703,16 +704,9 @@ public class HttpUtils {
ResponeVo apply = null;
try {
response = httpClient.execute(request);
} catch (Exception e) {
HTTP_UTIL_PARAM_INFO_THREAD_LOCAL.remove();
log.error(" http调用失败:" + Util.getErrString(e));
ExtendedIOUtils.closeQuietly(httpClient);
throw e;
}
try {
apply = consumer.apply(requestParam, response);
} catch (Exception e) {
toolUtil.writeErrorLog(" http调用失败:" + e);
throw e;
} finally {
HttpUtilParamInfo httpUtilParamInfo = HTTP_UTIL_PARAM_INFO_THREAD_LOCAL.get();
@ -720,13 +714,11 @@ public class HttpUtils {
httpUtilParamInfo = new HttpUtilParamInfo();
}
httpUtilParamInfo.setResponse(apply);
if (apply != null) {
if (apply.getResponseMap() == null) {
httpUtilParamInfo.setResponseString(apply.getEntityString());
} else {
httpUtilParamInfo.setResponseMap(apply.getResponseMap());
}
}
httpUtilParamInfo.setResponseDate(new Date());
HTTP_UTIL_PARAM_INFO_THREAD_LOCAL.remove();
try {
@ -777,7 +769,7 @@ public class HttpUtils {
}
} catch (Exception e) {
log.error(" http调用失败:" + Util.getErrString(e));
toolUtil.writeErrorLog(" http调用失败:" + Util.getErrString(e));
try {
httpUtilParamInfo.setResponseDate(new Date());
log.info(Util.logStr("url [{}] request info : [\n{}\n];", httpUtilParamInfo.getUrl(),
@ -1271,7 +1263,7 @@ public class HttpUtils {
total.append(line);
}
} catch (IOException e) {
log.error(e.getLocalizedMessage() + "\n" + e);
toolUtil.writeErrorLog(e.getLocalizedMessage() + "\n" + e);
}
return total.toString();
}

View File

@ -61,14 +61,10 @@ public interface UtilMapper {
@Select("select id,docid doc_id,imagefileid image_file_id,imagefilename image_file_name from docimagefile where docid = #{docId}")
DocImageInfo selectDocImageInfo(@ParamMapper("docId") String docId);
@Select("select id,docid doc_id," +
"imagefileid image_file_id, docfiletype doc_file_type," +
"imagefilename image_file_name from docimagefile where docid in ($t{docIds})")
@Select("select id,docid doc_id,imagefileid image_file_id,imagefilename image_file_name from docimagefile where docid in ($t{docIds})")
List<DocImageInfo> selectDocImageInfos(@ParamMapper("docIds") String docIds);
@Select("select id,docid doc_id,imagefileid image_file_id," +
"docfiletype doc_file_type," +
"imagefilename image_file_name from docimagefile where docid in (${docIds})")
@Select("select id,docid doc_id,imagefileid image_file_id,imagefilename image_file_name from docimagefile where docid in (${docIds})")
List<DocImageInfo> selectDocImageInfos(@ParamMapper("docIds") String[] docIds);

View File

@ -4,7 +4,6 @@ import aiyh.utils.Util;
import aiyh.utils.action.SafeCusBaseAction;
import aiyh.utils.annotation.*;
import aiyh.utils.excention.CustomerException;
import com.alibaba.fastjson.JSON;
import com.google.common.base.Strings;
import ebu7common.youhong.ai.bean.Builder;
import lombok.Getter;
@ -13,7 +12,6 @@ import lombok.ToString;
import weaver.hrm.User;
import weaver.soa.workflow.request.RequestInfo;
import weaver.youhong.ai.pcn.actioin.conditionssetvalue.dto.UpdateDetailRowDto;
import weaver.youhong.ai.pcn.actioin.conditionssetvalue.entity.ConditionsSetValueConfigMain;
import weaver.youhong.ai.pcn.actioin.conditionssetvalue.service.WorkflowConditionsSetValueService;
import java.util.*;
@ -33,7 +31,7 @@ public class WorkflowConditionsSetValueAction extends SafeCusBaseAction {
@RequiredMark("流程条件赋值配置表唯一标识字段值")
@PrintParamMark
@ActionDefaultTestValue("getdata")
@ActionDefaultTestValue("test")
private String onlyMark;
@ActionOptionalParam(desc = "条件修改所在明细表,1-明细12-明细2", value = "")
@ -56,15 +54,14 @@ public class WorkflowConditionsSetValueAction extends SafeCusBaseAction {
try {
Map<String, Object> workflowData = new HashMap<>(16);
Map<String, Object> workflowMainData = super.getObjMainTableValue(requestInfo);
ConditionsSetValueConfigMain conditionsSetValueConfigMain = service.getConditionConfigMain(onlyMark);
if (Strings.isNullOrEmpty(detailNo)) {
/* ******************* 数据修改主表 ******************* */
Map<String, Object> conditionsValue = service.getConditionsValue(conditionsSetValueConfigMain, workflowData).get(billTable);
Map<String, Object> conditionsValue = service.getConditionsValue(onlyMark, workflowData).get(billTable);
service.updateWorkflowData(conditionsValue, billTable, requestId);
return;
}
/* ******************* 明细表 ******************* */
List<Map<String, Object>> detailData = super.getDetailTableObjValueByDetailNo(Integer.parseInt(detailNo) - 1, requestInfo);
List<Map<String, Object>> detailData = super.getDetailTableObjValueByDetailNo(Integer.parseInt(detailNo), requestInfo);
workflowData.put("main", workflowMainData);
workflowData.put("_user_", user);
workflowData.put("_workflowId_", workflowId);
@ -74,7 +71,7 @@ public class WorkflowConditionsSetValueAction extends SafeCusBaseAction {
List<UpdateDetailRowDto> detail = new ArrayList<>();
for (Map<String, Object> detailDatum : detailData) {
workflowData.put("detail_" + detailNo, detailDatum);
Map<String, Map<String, Object>> conditionsValues = service.getConditionsValue(conditionsSetValueConfigMain, workflowData);
Map<String, Map<String, Object>> conditionsValues = service.getConditionsValue(onlyMark, workflowData);
Map<String, Object> mainConditions = conditionsValues.get(billTable);
if (!Objects.isNull(mainConditions) && !mainConditions.isEmpty()) {
main.add(Builder.builder(UpdateDetailRowDto::new)
@ -92,8 +89,6 @@ public class WorkflowConditionsSetValueAction extends SafeCusBaseAction {
.build());
}
}
log.info("条件值: " + JSON.toJSONString(main));
log.info("条件值: " + JSON.toJSONString(detail));
service.updateWorkflowDetailData(main, billTable, null);
service.updateWorkflowDetailData(detail, billTable + "_dt" + detailNo, detailNo);
} catch (Exception e) {
@ -106,8 +101,6 @@ public class WorkflowConditionsSetValueAction extends SafeCusBaseAction {
}
public void submitWorkflow(String requestId, Integer userId) {
if (Boolean.parseBoolean(submitAction)) {
Util.submitWorkflowThread(Integer.parseInt(requestId), userId, "流程条件赋值提交流程!");
}
Util.submitWorkflowThread(Integer.parseInt(requestId), userId, "邮件发送附件提交流程!");
}
}

View File

@ -2,7 +2,6 @@ package weaver.youhong.ai.pcn.actioin.conditionssetvalue.service;
import aiyh.utils.Util;
import aiyh.utils.tool.Assert;
import org.jetbrains.annotations.NotNull;
import weaver.youhong.ai.pcn.actioin.conditionssetvalue.dto.ConditionValueDto;
import weaver.youhong.ai.pcn.actioin.conditionssetvalue.dto.UpdateDetailRowDto;
import weaver.youhong.ai.pcn.actioin.conditionssetvalue.entity.ConditionItem;
@ -29,13 +28,17 @@ public class WorkflowConditionsSetValueService {
/**
* <h2></h2>
*
* @param conditionsSetValueConfigMain
* @param onlyMark
* @param workflowData
* @return
*/
public Map<String, Map<String, Object>> getConditionsValue(ConditionsSetValueConfigMain conditionsSetValueConfigMain, Map<String, Object> workflowData) {
List<ConditionItem> conditionItemList = conditionsSetValueConfigMain.getConditionItemList();
public Map<String, Map<String, Object>> getConditionsValue(String onlyMark, Map<String, Object> workflowData) {
/* ******************* 查询配置表 ******************* */
ConditionsSetValueConfigMain conditionsSetValueConfigMain = mapper.selectConfigByOnlyMark(onlyMark);
Assert.notNull(conditionsSetValueConfigMain, "can not query configuration by onlyMark [{}]", onlyMark);
List<ConditionItem> conditionItemList = conditionsSetValueConfigMain.getConditionItemList();
Assert.notEmpty(conditionItemList, "can not query conditionItemList by onlyMark [{}]", onlyMark);
/* ******************* 映射规则处理 ,责任链初始化 ******************* */
ConditionsTypeTreatment conditionsTypeTreatment = new ConditionsTypeTreatment(
new ConditionsTreatment(
@ -65,16 +68,6 @@ public class WorkflowConditionsSetValueService {
return result;
}
@NotNull
public ConditionsSetValueConfigMain getConditionConfigMain(String onlyMark) {
/* ******************* 查询配置表 ******************* */
ConditionsSetValueConfigMain conditionsSetValueConfigMain = mapper.selectConfigByOnlyMark(onlyMark);
Assert.notNull(conditionsSetValueConfigMain, "can not query configuration by onlyMark [{}]", onlyMark);
List<ConditionItem> conditionItemList = conditionsSetValueConfigMain.getConditionItemList();
Assert.notEmpty(conditionItemList, "can not query conditionItemList by onlyMark [{}]", onlyMark);
return conditionsSetValueConfigMain;
}
/**
* <h2></h2>
*
@ -101,9 +94,6 @@ public class WorkflowConditionsSetValueService {
StringBuilder sb = new StringBuilder("update ");
sb.append(billTable).append(" set ");
for (Map.Entry<String, Object> entry : updateBatchData.get(0).entrySet()) {
if (entry.getKey().equals("_id_")) {
continue;
}
sb.append(entry.getKey())
.append(" = #{item.")
.append(entry.getKey())

View File

@ -51,7 +51,6 @@ public class ValueSetRulesTreatment {
return Builder.builder(ConditionValueDto::new)
.with(ConditionValueDto::setFieldName, conditionItem.getTargetField().getFieldName())
.with(ConditionValueDto::setValue, value)
.with(ConditionValueDto::setTableName, conditionItem.getTargetField().getTableName())
.build();
}

View File

@ -1,100 +0,0 @@
package weaver.youhong.ai.pcn.actioin.docfieltoattachment;
import aiyh.utils.Util;
import aiyh.utils.action.SafeCusBaseAction;
import aiyh.utils.annotation.ActionDesc;
import aiyh.utils.annotation.ActionOptionalParam;
import aiyh.utils.annotation.PrintParamMark;
import aiyh.utils.annotation.RequiredMark;
import aiyh.utils.entity.DocImageInfo;
import aiyh.utils.excention.CustomerException;
import lombok.Getter;
import lombok.Setter;
import lombok.ToString;
import weaver.file.ImageFileManager;
import weaver.hrm.User;
import weaver.soa.workflow.request.RequestInfo;
import weaver.youhong.ai.pcn.actioin.docfieltoattachment.mapper.CopyDocFileToAttachmentMapper;
import java.io.InputStream;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
/**
* <h1></h1>
*
* <p>create: 2023/2/21 18:40</p>
*
* @author youHong.ai
*/
@Getter
@Setter
@ToString
@ActionDesc(value = "文档字段中附件复制到附件字段中", author = "youhong.ai")
public class CopyDocFileToAttachmentAction extends SafeCusBaseAction {
@PrintParamMark
@ActionOptionalParam(value = "true", desc = "是否失败后阻断流程")
private String block = "true";
@PrintParamMark
@RequiredMark("字段映射配置字段: 文档字段:附件字段;文档字段:附件字段")
private String fieldMappings;
private final CopyDocFileToAttachmentMapper mapper = Util.getMapper(CopyDocFileToAttachmentMapper.class);
@Override
public void doSubmit(String requestId, String billTable, int workflowId, User user, RequestInfo requestInfo) {
try {
String[] fieldMappingArr = fieldMappings.split(";");
Map<String, String> mainTableValue = super.getMainTableValue(requestInfo);
Map<String, Object> sqlValue = new HashMap<>();
for (String fieldMapping : fieldMappingArr) {
copyFile(fieldMapping, mainTableValue, sqlValue, String.valueOf(workflowId), billTable, user.getUID());
}
StringBuilder sb = new StringBuilder("update ");
sb.append(billTable).append(" set ");
for (Map.Entry<String, Object> entry : sqlValue.entrySet()) {
sb.append(entry.getKey()).append(" = ").append("#{").append(entry.getKey()).append("},");
}
sb.deleteCharAt(sb.length() - 1);
sb.append(" where requestid = ").append(requestId);
if (mapper.updateDocIds(sb.toString(), sqlValue)) {
Thread.sleep(500);
mapper.updateDocIds(sb.toString(), sqlValue);
}
} catch (Exception e) {
if (Boolean.parseBoolean(block)) {
throw new CustomerException(e.getMessage(), e);
}
}
}
private void copyFile(String fieldMapping, Map<String, String> mainTableValue,
Map<String, Object> sqlValue, String workflowId,
String billTable, int userId) {
List<Integer> docIds = new ArrayList<>();
String[] split = fieldMapping.split(":");
String docField = split[0];
String fileField = split[1];
String docId = mainTableValue.get(docField);
List<DocImageInfo> docImageInfos = Util.selectImageInfoByDocIds(docId);
for (DocImageInfo docImageInfo : docImageInfos) {
if (docImageInfo.getDocFileType() != 2) {
continue;
}
InputStream inputStreamById = ImageFileManager.getInputStreamById(docImageInfo.getImageFileId());
String docCategorysByTable = Util.getDocCategorysByTable(workflowId, fileField, billTable);
String[] categoryArr = docCategorysByTable.split(",");
String category = categoryArr[categoryArr.length - 1];
try {
int doc = Util.createDoc(docImageInfo.getImageFileName(), Integer.parseInt(category), inputStreamById, userId);
docIds.add(doc);
} catch (Exception e) {
throw new RuntimeException(e);
}
}
sqlValue.put(fileField, Util.intJoin(docIds, ","));
}
}

View File

@ -1,22 +0,0 @@
package weaver.youhong.ai.pcn.actioin.docfieltoattachment.mapper;
import aiyh.utils.annotation.recordset.SqlMapper;
import aiyh.utils.annotation.recordset.SqlString;
import aiyh.utils.annotation.recordset.Update;
import java.util.Map;
/**
* <h1></h1>
*
* <p>create: 2023/2/21 19:13</p>
*
* @author youHong.ai
*/
@SqlMapper
public interface CopyDocFileToAttachmentMapper {
@Update(custom = true)
boolean updateDocIds(@SqlString String sql,
Map<String, Object> map);
}

View File

@ -1,94 +0,0 @@
package weaver.youhong.ai.pcn.actioin.generateloginid;
import aiyh.utils.Util;
import aiyh.utils.action.SafeCusBaseAction;
import aiyh.utils.annotation.ActionDesc;
import aiyh.utils.annotation.ActionOptionalParam;
import aiyh.utils.annotation.PrintParamMark;
import aiyh.utils.annotation.RequiredMark;
import lombok.Getter;
import lombok.Setter;
import lombok.ToString;
import weaver.hrm.User;
import weaver.soa.workflow.request.RequestInfo;
import weaver.youhong.ai.pcn.actioin.generateloginid.mapper.GenerateLoginIdMapper;
import java.text.NumberFormat;
import java.util.Map;
/**
* <h1>loginid</h1>
*
* <p>create: 2023/2/21 19:46</p>
*
* @author youHong.ai
*/
@Getter
@Setter
@ToString
@ActionDesc(value = "根据分部生成对应的登录名", author = "youhong.ai")
public class GenerateLoginIdAction extends SafeCusBaseAction {
@PrintParamMark
@RequiredMark("流程回写登录名字段名")
private String loginIdField;
@PrintParamMark
@RequiredMark("分部简称流程字段名")
private String subCompanyTextField;
@PrintParamMark
@ActionOptionalParam(value = "4", desc = "登录名序列数字位长度序列不足时前缀补0如0001默认长度4位")
private String numberFillQuantity = "4";
@PrintParamMark
@ActionOptionalParam(value = "true", desc = "是否失败后阻断流程")
private String block = "true";
private final GenerateLoginIdMapper mapper = Util.getMapper(GenerateLoginIdMapper.class);
@Override
public void doSubmit(String requestId, String billTable, int workflowId, User user, RequestInfo requestInfo) {
try {
Map<String, String> mainTableValue = super.getMainTableValue(requestInfo);
String subCompanyName = mainTableValue.get(subCompanyTextField);
String subCompanyId = mapper.selectSubCompanyIdBySubCompanyName(subCompanyName);
Map<String, String> lastLoginIdInfo = mapper.selectLastLoginId(subCompanyName, subCompanyId, subCompanyName + "%");
String loginIdNo = lastLoginIdInfo.get("loginIdNo");
String loginId = prefixFill(loginIdNo, subCompanyName);
if (mapper.updateLoginId(billTable, requestId, loginId, loginIdField)) {
try {
Thread.sleep(500);
} catch (Exception ignore) {
}
mapper.updateLoginId(billTable, requestId, loginId, loginIdField);
}
} catch (Exception e) {
if (Boolean.parseBoolean(block)) {
throw e;
}
}
}
/**
* <h2></h2>
*
* @param lastLoginIdNo
* @param prefix
* @return
*/
private String prefixFill(String lastLoginIdNo, String prefix) {
NumberFormat numberFormat = NumberFormat.getInstance();
// 禁用数字格式化分组。
numberFormat.setGroupingUsed(false);
// 保留最小位数
numberFormat.setMinimumIntegerDigits(Integer.parseInt(numberFillQuantity));
// 保留最大位数
numberFormat.setMaximumIntegerDigits(Integer.parseInt(numberFillQuantity));
int newLoginId = Integer.parseInt(lastLoginIdNo) + 1;
return prefix + numberFormat.format(newLoginId);
}
}

View File

@ -1,64 +0,0 @@
package weaver.youhong.ai.pcn.actioin.generateloginid.mapper;
import aiyh.utils.annotation.recordset.ParamMapper;
import aiyh.utils.annotation.recordset.Select;
import aiyh.utils.annotation.recordset.SqlMapper;
import aiyh.utils.annotation.recordset.Update;
import java.util.Map;
/**
* <h1></h1>
*
* <p>create: 2023/2/21 20:31</p>
*
* @author youHong.ai
*/
@SqlMapper
public interface GenerateLoginIdMapper {
/**
* <h2>id</h2>
*
* @param subCompanyName
* @return id
*/
@Select("select id from hrmsubcompany where SUBCOMPANYNAME = #{subCompanyName}")
String selectSubCompanyIdBySubCompanyName(String subCompanyName);
/**
* <h2></h2>
*
* @param loginIdPrefix
* @param subCompanyId id
* @param loginLike +%
* @return id
*/
@Select("select id,substring(LOGINID,length(#{loginIdPrefix}) + 1) login_id_no \n" +
"from hrmresource \n" +
"where SUBCOMPANYID1 = #{subCompanyId} and LOGINID like #{loginLike} \n" +
" order by cast(substring(LOGINID,length(#{loginIdPrefix}) + 1) as decimal) \n" +
" desc limit 1")
Map<String, String> selectLastLoginId(
@ParamMapper("loginIdPrefix") String loginIdPrefix,
@ParamMapper("subCompanyId") String subCompanyId,
@ParamMapper("loginLike") String loginLike
);
/**
* <h2>loginId</h2>
*
* @param billTable
* @param requestId id
* @param loginId id
* @param loginIdField id
* @return
*/
@Update("update $t{billTable} set $t{loginIdField} where requestid = #{requestId}")
boolean updateLoginId(@ParamMapper("billTable") String billTable,
@ParamMapper("requestId") String requestId,
@ParamMapper("loginId") String loginId,
@ParamMapper("loginIdField") String loginIdField);
}

View File

@ -20,10 +20,4 @@ public class TestHaRiPiJiu extends BaseTest {
GenerateFileUtil.createActionDocument(VoucherPayableAction.class);
GenerateFileUtil.createActionDocument(ReceiptAndPaymentAction.class);
}
@Test
public void test1() {
}
}

View File

@ -8,7 +8,6 @@ import com.engine.hrm.service.impl.RolesMembersServiceImpl;
import org.junit.Test;
import weaver.hrm.User;
import weaver.youhong.ai.pcn.actioin.conditionssetvalue.WorkflowConditionsSetValueAction;
import weaver.youhong.ai.pcn.actioin.generateloginid.GenerateLoginIdAction;
import weaver.youhong.ai.pcn.schedule.addrolebyhasundering.RegisterRoleMemberByHasUnderingCronJob;
import weaver.youhong.ai.pcn.schedule.addrolemember.RegisterRoleMemberCronJob;
@ -76,6 +75,6 @@ public class RolesTest extends BaseTest {
@Test
public void generateFile() {
GenerateFileUtil.createActionDocument(GenerateLoginIdAction.class);
GenerateFileUtil.createActionDocument(WorkflowConditionsSetValueAction.class);
}
}

View File

@ -59,8 +59,7 @@ select wb.id,
when wb.FIELDHTMLTYPE = '3' then '流览框'
when wb.FIELDHTMLTYPE = '4' then 'check框'
when wb.FIELDHTMLTYPE = '5' then '选择框'
else '附件上传' end) fieldhtmltype,
wb.FIELDHTMLTYPE fieldtype
else '附件上传' end) fieldhtmltype
from workflow_billfield wb
left join htmllabelindex ht on wb.fieldlabel = ht.id;