dobe_comic8/main/java/shkd/bamp/base/task/DobeDWorgTask.java

231 lines
12 KiB
Java
Raw Normal View History

2024-11-04 15:32:41 +00:00
package shkd.bamp.base.task;
import com.alibaba.fastjson.JSON;
import com.alibaba.fastjson.JSONArray;
import com.alibaba.fastjson.JSONObject;
import kd.bos.context.RequestContext;
import kd.bos.dataentity.entity.DynamicObject;
import kd.bos.db.DB;
import kd.bos.db.DBRoute;
2024-11-04 15:32:41 +00:00
import kd.bos.exception.KDException;
import kd.bos.logging.Log;
import kd.bos.logging.LogFactory;
import kd.bos.org.model.OrgDutyView;
2024-11-04 15:32:41 +00:00
import kd.bos.org.model.OrgParam;
import kd.bos.orm.query.QFilter;
import kd.bos.schedule.executor.AbstractTask;
import kd.bos.servicehelper.QueryServiceHelper;
import kd.bos.servicehelper.org.OrgUnitServiceHelper;
import kd.bos.servicehelper.org.OrgViewType;
import kd.sdk.plugin.Plugin;
import okhttp3.OkHttpClient;
import okhttp3.Request;
import okhttp3.Response;
import shkd.utils.DobeDWUtils;
import java.io.IOException;
import java.util.*;
/**
* 后台任务插件 yxl 20240830
* 组织和人员的相关操作参考 https://dev.kingdee.com/open/detail/sdk/2077750769712378880
2024-11-04 15:32:41 +00:00
*/
public class DobeDWorgTask extends AbstractTask implements Plugin {
private static final String entityName = "bos_org";//系统库 表名 t_org_org
private static Log log = LogFactory.getLog(DobeDWorgTask.class);
private static final String dw_menthod = "mdm_arog";
@Override
public void execute(RequestContext requestContext, Map<String, Object> map) throws KDException {
//定时任务具体执行逻辑 从数仓获取当天更新的行政组织数据,并与系统中的组织数据比较,是新增还是更新
//组装请求数仓查询接口入参
//调用数仓查询接口
OkHttpClient client = new OkHttpClient();
Request request = new Request.Builder().url(DobeDWUtils.dwUrl+dw_menthod)
.post(DobeDWUtils.createRequestBody("",1))
.header("Content-Type", "application/json")
.header("Authorization", DobeDWUtils.appCode)
.build();
String resultData = null;
Response response = null;
try {
response = client.newCall(request).execute();
resultData = response.body().string();
log.info("组织接口返回结果:\n{}", resultData);
} catch (IOException e) {
log.info(String.format("组织接口异常:%s", e.getMessage()));
throw new RuntimeException(e);
}
JSONObject json_body = JSON.parseObject(resultData);
//接口返回的数据进行了分页
int totalNum = json_body.getIntValue("totalNum");//分页-SQL查询总数据量
//解析接口返回值,与系统数据比较
handleOrg(json_body);
int queryCount = DobeDWUtils.getQueryCount(totalNum);
if(queryCount > 1){
//查询次数不止一次,需要分页查询
for (int i = 2; i <= queryCount; i++) {
request = new Request.Builder().url(DobeDWUtils.dwUrl+dw_menthod)
.post(DobeDWUtils.createRequestBody("",i))
.header("Content-Type", "application/json")
.header("Authorization", DobeDWUtils.appCode)
.build();
try {
response = client.newCall(request).execute();
resultData = response.body().string();
// log.info("组织接口返回结果:\n{}", resultData);
} catch (IOException e) {
log.info(String.format("组织接口异常:%s", e.getMessage()));
throw new RuntimeException(e);
}
json_body = JSON.parseObject(resultData);
handleOrg(json_body);
}
}
}
private boolean isNeedUpdate(DynamicObject currentOrg,String orgNumber,String orgName,Long parentId){
if(!orgNumber.equals(currentOrg.getString("number")) || !orgName.equals(currentOrg.getString("name"))){
return true;
}
List<Long> idlist = new ArrayList<>();
idlist.add(currentOrg.getLong("id"));
//获取直接上级组织 返回值说明 <组织ID - 上级组织ID>
Map<Long,Long> maprs = OrgUnitServiceHelper.getDirectSuperiorOrg(OrgViewType.Admin,idlist);
if(maprs != null && !parentId.equals(maprs.get(idlist.get(0)))){
return true;
}
return false;
}
2024-11-04 15:32:41 +00:00
private void handleOrg(JSONObject json_body) {
JSONArray detailsJson = json_body.getJSONArray("data");
// List<OrgParam> paramList = new ArrayList<>();
OrgParam param = null;
DynamicObject parentOrg = null;
DynamicObject currentOrg = null;
String orgNumber = null;
String orgName = null;
String orgID = null;
String parentId = null;
String person_charge = null;//部门下的负责人的工号
2024-11-29 08:48:06 +00:00
String updateNocgeSql = "UPDATE t_SEC_UserPosition SET fisincharge=? WHERE fdptid in (select fid from t_org_org where fyzjorgid=?);";
String updatecgeSql = "UPDATE t_SEC_UserPosition SET fisincharge=? WHERE fdptid in (select fid from t_org_org where fyzjorgid=?) and fid in (select fid from t_sec_user where fnumber=?);";
TreeMap<String, OrgDutyView> multiViewMap = new TreeMap<>();
OrgDutyView dutyView = null;
2024-11-04 15:32:41 +00:00
for (int i = 0; i < detailsJson.size(); i++) {
json_body = detailsJson.getJSONObject(i);
orgNumber = json_body.getString("org_code");
orgName = json_body.getString("org_name");
orgID = json_body.getString("org_id");
// String orgLevel = json_body.getString("org_level");//组织层级
parentId = json_body.getString("org_parentid");
person_charge = json_body.getString("person_chargecode");
2024-11-04 15:32:41 +00:00
if(DobeDWUtils.isEmpty(orgID) || DobeDWUtils.isEmpty(orgNumber) || DobeDWUtils.isEmpty(orgName)
|| DobeDWUtils.isEmpty(parentId)){
//如果组织ID和组织编码 名称是空的,则跳过此记录
log.info(String.format("组织入参为空异常:%s", json_body.toJSONString()));
continue;
}
//根据父级ID获取父级组织对象,组织的主数据id存在于星瀚组织的fyzjorgid字段中
parentOrg = QueryServiceHelper.queryOne(entityName,"id,number,name",new QFilter[]{new QFilter("fyzjorgid","=",parentId)});
if(parentOrg == null){
log.info(String.format("根据数仓组织父级ID未在金蝶中找到对应组织%s", parentId));
continue;
}
2024-11-04 15:32:41 +00:00
//根据组织ID查找系统现有数据是否存在这种写法会抛异常需要关注原因
currentOrg = QueryServiceHelper.queryOne(entityName,"id,number,name",new QFilter[]{new QFilter("fyzjorgid","=",orgID)});
if(currentOrg != null){
//根据组织下的负责人id去人员分录表中更新负责人标记先去除这个部门下人员的负责人标记再更新
if(!DobeDWUtils.isEmpty(person_charge)){
2024-11-29 08:48:06 +00:00
DB.update(DBRoute.of("sys"), updateNocgeSql, new Object[]{0,orgID});
DB.update(DBRoute.of("sys"), updatecgeSql, new Object[]{1,orgID,person_charge});
}
2024-11-04 15:32:41 +00:00
//已存在,做更新
if(!isNeedUpdate(currentOrg,orgNumber,orgName,parentOrg.getLong("id"))){
//编号和名称、上级单位都没有变化,无需更新;现在判断不出来上级单位,直接更新
2024-11-04 15:32:41 +00:00
continue;
}
param = new OrgParam();
param.setId(currentOrg.getLong("id"));
param.setName(orgName);
param.setNumber(orgNumber);
// param.setParentId(parentOrg.getLong("id"));//上级组织的金蝶ID
//设置多视图参数
multiViewMap.clear();
dutyView = new OrgDutyView();
//组织移动时设置新的上级ID
dutyView.setParentId(parentOrg.getLong("id"));
//行政组织
multiViewMap.put(OrgViewType.Admin, dutyView);
//每种视图方案的参数对象不能用同一个,需要单独实例化
dutyView = new OrgDutyView();
dutyView.setParentId(parentOrg.getLong("id"));
//业务单元
multiViewMap.put(OrgViewType.OrgUnit, dutyView);
//采购组织
// dutyView = new OrgDutyView();
// dutyView.setParentId(parentOrg.getLong("id"));
// multiViewMap.put(OrgViewType.Asset, dutyView);
param.setMultiViewMap(multiViewMap);
2024-11-04 15:32:41 +00:00
OrgUnitServiceHelper.update(param);
if (!param.isSuccess()) {
log.info(String.format("组织修改异常:%s", param.getMsg()));
}
}else{
2024-11-04 15:32:41 +00:00
/* 新增单个视图方案的组织 */
param = new OrgParam();
// param.setParentId(parentOrg.getLong("id"));//上级组织的金蝶ID
2024-11-04 15:32:41 +00:00
param.setName(orgName);
param.setYzjOrgId(orgID);//云之家组织内码字段用于保存组织的外部ID
param.setNumber(orgNumber);
param.setOrgPatternId(4);//组织形态ID默认ID为4L部门1为公司当前组织是公司还是部门需要有字段可以体现
// param.setCustomOrgId(Long.parseLong(orgID));//组织自定义ID用于保存第三方系统的ID并非额外字段保存而是直接更新id字段
param.setDuty(OrgViewType.Admin);//组织属性-行政组织
//设置组织属性-单个视图
// Map<String, Object> proMap = new HashMap<>();
// proMap.put("uniformsocialcreditcode", "add0001");//统一社会信用代码
// param.setPropertyMap(proMap);//组织关联属性map
// paramList.add(param);
// 设置多视图参数
// TreeMap<String, OrgDutyView> multiViewMap = new TreeMap<>();
multiViewMap.clear();
dutyView = new OrgDutyView();
dutyView.setParentId(parentOrg.getLong("id"));//上级组织的金蝶ID
multiViewMap.put(OrgViewType.Admin, dutyView);//行政组织
dutyView = new OrgDutyView();
dutyView.setParentId(parentOrg.getLong("id"));//上级组织的金蝶ID
multiViewMap.put(OrgViewType.OrgUnit, dutyView);//业务单元
dutyView = new OrgDutyView();
dutyView.setParentId(parentOrg.getLong("id"));//上级组织的金蝶ID
multiViewMap.put(OrgViewType.Accounting, dutyView);//核算组织
dutyView = new OrgDutyView();
dutyView.setParentId(parentOrg.getLong("id"));//上级组织的金蝶ID
multiViewMap.put(OrgViewType.Purchase, dutyView);//采购组织
2024-11-04 15:32:41 +00:00
param.setMultiViewMap(multiViewMap);//多职能参数 支持一次更新多种业务视图方案键为视图方案编码参照本页参数说明的OrgViewType值为OrgDutyView对象
// paramList.add(param);
2024-11-04 15:32:41 +00:00
// 执行并判断结果,如下是微服务模式调用,会提示服务找不到
// IOrgService orgService = ServiceFactory.getService(OrgService.class);
// orgService.add(paramList);
OrgUnitServiceHelper.add(param);
if (!param.isSuccess()) {
log.info(String.format("组织新增异常:%s", param.getMsg()));
}
//部门新增时,不用去更新部门下的负责人
2024-11-04 15:32:41 +00:00
}
}
}
// for (OrgParam result : paramList) {
// // 根据操作结果提示用户或执行其他处理
// if (!result.isSuccess()) {
// log.info(String.format("组织保存异常:%s", result.getMsg()));
// }
// }
}