feat:客户同步同步下单平台接口增加业务主体

This commit is contained in:
zzs 2025-01-20 10:48:49 +08:00
parent b8f95ad456
commit 02539fc493
3 changed files with 82 additions and 33 deletions

View File

@ -1,8 +1,8 @@
package com.yem.or.task;
import com.yem.or.utils.OrderApiUtils;
import com.yem.wm.bd.customer.from.Validator.CustomerValidator;
import com.yem.wm.task.YunZhiJaGetOpenidTask;
import com.yem.wm.utils.YEM;
import kd.bos.context.RequestContext;
import kd.bos.dataentity.entity.DynamicObject;
import kd.bos.exception.KDException;
@ -24,9 +24,8 @@ public class CustomerTask extends AbstractTask {
@Override
public void execute(RequestContext requestContext, Map<String, Object> map) throws KDException {
Log log = LogFactory.getLog(YunZhiJaGetOpenidTask.class);
QFilter qFilter = new QFilter("yem_checkboxfield", QCP.equals, false);
qFilter.and("status", QCP.equals, "C");
DynamicObject[] dynamicObjects = BusinessDataServiceHelper.load("bd_customer", "id,number,name,yem_checkboxfield,yem_torderid,group"
QFilter qFilter = new QFilter("status", QCP.equals, "C");
DynamicObject[] dynamicObjects = BusinessDataServiceHelper.load("bd_customer", "id,number,name,yem_checkboxfield,yem_torderid,group,yem_groupcustomers"
, new QFilter[]{qFilter});
for (DynamicObject dynamicObject : dynamicObjects) {
DynamicObject group = dynamicObject.getDynamicObject("group");
@ -37,13 +36,33 @@ public class CustomerTask extends AbstractTask {
if (bd_customergroup.length > 0) {
for (int i = 0; i < bd_customergroup.length; i++) {
String number = dynamicObject.getString("number");
String replace = number.replace("-", "");
String name = dynamicObject.getString("name");
Map<String, String> demands = OrderApiUtils.demands(name, replace);
DynamicObject groupcustomers = dynamicObject.getDynamicObject("yem_groupcustomers");
if (YEM.isEmpty(groupcustomers)) {
continue;
}
if (!groupcustomers.containsProperty("yem_torderid")) {
groupcustomers = BusinessDataServiceHelper.loadSingleFromCache(groupcustomers.getDataEntityType().getName(), new QFilter[]{new QFilter("id", "=", groupcustomers.getPkValue())});
String group_torderid = groupcustomers.getString("yem_torderid");
if (YEM.isEmpty(group_torderid)) {
continue;
}
}
Map<String, String> demands;
if (dynamicObject.getBoolean("yem_checkboxfield")) {
String torderid = dynamicObject.getString("yem_torderid");
if(YEM.isEmpty(torderid)) {
continue;
}
Long id = Long.valueOf(torderid);
demands = OrderApiUtils.demands(name, number, groupcustomers, false, id);
} else {
demands = OrderApiUtils.demands(name, number, groupcustomers, true, null);
}
String msg = demands.get("msg");
if (msg == null) {
String id = demands.get("id");
if (!"".equals(id)) {
if (YEM.isNotEmpty(id)) {
dynamicObject.set("yem_torderid", id);
dynamicObject.set("yem_checkboxfield", true);
SaveServiceHelper.update(dynamicObject);

View File

@ -4,7 +4,6 @@ import com.alibaba.fastjson.JSON;
import com.alibaba.fastjson.JSONArray;
import com.alibaba.fastjson.JSONObject;
import com.yem.wm.utils.YEM;
import kd.bos.bill.BillShowParameter;
import kd.bos.data.BusinessDataReader;
import kd.bos.dataentity.OperateOption;
import kd.bos.dataentity.entity.DynamicObject;
@ -15,18 +14,13 @@ import kd.bos.entity.MainEntityType;
import kd.bos.entity.botp.runtime.ConvertOperationResult;
import kd.bos.entity.botp.runtime.PushArgs;
import kd.bos.entity.botp.runtime.SourceBillReport;
import kd.bos.entity.datamodel.IBillModel;
import kd.bos.entity.datamodel.IRefrencedataProvider;
import kd.bos.entity.datamodel.ListSelectedRow;
import kd.bos.entity.operate.OperateOptionConst;
import kd.bos.entity.operate.result.IOperateInfo;
import kd.bos.entity.operate.result.OperationResult;
import kd.bos.exception.KDBizException;
import kd.bos.form.IFormView;
import kd.bos.logging.Log;
import kd.bos.logging.LogFactory;
import kd.bos.mvc.FormConfigFactory;
import kd.bos.mvc.SessionManager;
import kd.bos.orm.ORM;
import kd.bos.orm.query.QCP;
import kd.bos.orm.query.QFilter;
@ -54,7 +48,9 @@ public class OrderApiUtils {
public static Log log = LogFactory.getLog(OrderApiUtils.class);
public static String ENDPOINTS = "http://10.64.113.156";
// public static String ENDPOINT = "http://122.4.221.133:30080";
// public static final String LOCAL_DEBUG_ENDPOINT = "http://127.0.0.1:48080";
// 本地测试环境
// public static final String ENDPOINTS = "http://127.0.0.1:48080";
/**
* 获取token
@ -424,8 +420,13 @@ public class OrderApiUtils {
/**
* 新增用户
*/
public static Map<String, String> demands(String data, String string) {
final String requestUrl = ENDPOINTS + "/admin-api/system/user/create";
public static Map<String, String> demands(String username, String userNumber, DynamicObject groupcustomers, boolean isCreate, Long existId) {
String requestUrl;
if (isCreate) {
requestUrl = ENDPOINTS + "/admin-api/system/user/create";
} else {
requestUrl = ENDPOINTS + "/admin-api/system/user/update";
}
Map<String, String> headers = null;
try {
@ -439,10 +440,22 @@ public class OrderApiUtils {
String accessToken = headers.get("token");
headers.put("Authorization", "Bearer " + (accessToken));
Map<String, Object> requestBody = new HashMap<>();
requestBody.put("nickname", data);
if (!groupcustomers.containsProperty("yem_torderid") || !groupcustomers.containsProperty("number") || !groupcustomers.containsProperty("name")) {
groupcustomers = BusinessDataServiceHelper.loadSingleFromCache(groupcustomers.getDataEntityType().getName(), new QFilter[]{new QFilter("id", "=", groupcustomers.getPkValue())});
}
String groupUserId = groupcustomers.getString("yem_torderid");
String groupName = groupcustomers.getString("number");
String name = groupcustomers.getString("name");
requestBody.put("nickname", username);
requestBody.put("password", "ensign@123");
requestBody.put("username", string);
requestBody.put("username", userNumber);
requestBody.put("deptId", "100");
requestBody.put("groupCustomerId", groupUserId);
requestBody.put("groupCustomerNumber", groupName);
requestBody.put("groupCustomerName", name);
if (!isCreate) {
requestBody.put("id", existId);
}
String res = "";
@ -457,13 +470,14 @@ public class OrderApiUtils {
}
JSONObject jsonObject = JSONObject.parseObject(res);
Long id = 0L;
int code = jsonObject.getIntValue("code");
if (code == 0) {
id = jsonObject.getLong("data");
String ids = id.toString();
Object data = jsonObject.get("data");
if (data instanceof Long) {
String ids = data.toString();
resStatus.put("id", ids);
}
}
return resStatus;
} else {
log.error(headers.get("msg"));

View File

@ -1,6 +1,7 @@
package com.yem.wm.bd.customer.from.Validator;
import com.yem.or.utils.OrderApiUtils;
import com.yem.wm.utils.YEM;
import kd.bos.dataentity.entity.DynamicObject;
import kd.bos.entity.ExtendedDataEntity;
import kd.bos.entity.plugin.args.EndOperationTransactionArgs;
@ -23,9 +24,9 @@ public class CustomerValidator extends AbstractValidator {
ExtendedDataEntity[] dataEntities = this.getDataEntities();
for (ExtendedDataEntity dataEntitie : dataEntities) {
DynamicObject mechanical = dataEntitie.getDataEntity();
boolean yemCheckboxfield = mechanical.getBoolean("yem_checkboxfield");
boolean isSynced = mechanical.getBoolean("yem_checkboxfield");
DynamicObject group = mechanical.getDynamicObject("group");
if (!yemCheckboxfield && group != null) {
if (group != null) {
long groupid = group.getLong("id");
QFilter qFilter = new QFilter("parent.number", QCP.equals, "11602");
QFilter qFilter1 = new QFilter("id", QCP.equals, groupid);
@ -34,13 +35,33 @@ public class CustomerValidator extends AbstractValidator {
, new QFilter[]{qFilter, qFilter1});
if (dynamicObjects.length > 0) {
String number = mechanical.getString("number");
String replace = number.replace("-", "");
String name = mechanical.getString("name");
Map<String, String> demands = OrderApiUtils.demands(name, replace);
DynamicObject groupcustomers = mechanical.getDynamicObject("yem_groupcustomers");
if (YEM.isEmpty(groupcustomers)) {
this.addErrorMessage(dataEntitie, String.format("请维护客户 [%s] 的业务主体", name));
continue;
}
Map<String, String> demands;
if (!groupcustomers.containsProperty("yem_torderid")) {
groupcustomers = BusinessDataServiceHelper.loadSingleFromCache(groupcustomers.getDataEntityType().getName(), new QFilter[]{new QFilter("id", "=", groupcustomers.getPkValue())});
String group_torderid = groupcustomers.getString("yem_torderid");
if (YEM.isEmpty(group_torderid)) {
this.addErrorMessage(dataEntitie, String.format("客户 [%s] 的业务主体 [%s] 未同步,请先同步业务主体至下单平台", name, groupcustomers.getString("name")));
continue;
}
}
String torderid = mechanical.getString("yem_torderid");
Long existId = Long.valueOf(torderid);
if (isSynced) {
demands = OrderApiUtils.demands(name, number, groupcustomers, false, existId);
} else {
demands = OrderApiUtils.demands(name, number, groupcustomers, true, null);
}
String msg = demands.get("msg");
if (msg == null) {
String id = demands.get("id");
if (!"".equals(id)) {
if (YEM.isNotEmpty(id)) {
mechanical.set("yem_torderid", id);
mechanical.set("yem_checkboxfield", true);
SaveServiceHelper.update(mechanical);
@ -53,13 +74,8 @@ public class CustomerValidator extends AbstractValidator {
this.addErrorMessage(dataEntitie, "当前客户不满足同步条件,禁止同步至下单平台!!!");
}
} else {
if (yemCheckboxfield) {
this.addErrorMessage(dataEntitie, "当前客户已同步下单平台!!");
} else if (group == null) {
this.addErrorMessage(dataEntitie, "当前客户分组为空!!");
}
}
}
}
}