dobe_comic8/main/java/shkd/repc/task/YongyouBIPTask.java

188 lines
10 KiB
Java
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

package shkd.repc.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.OperateOption;
import kd.bos.dataentity.entity.DynamicObject;
import kd.bos.exception.KDException;
import kd.bos.logging.Log;
import kd.bos.logging.LogFactory;
import kd.bos.orm.query.QFilter;
import kd.bos.schedule.executor.AbstractTask;
import kd.bos.servicehelper.BusinessDataServiceHelper;
import kd.bos.servicehelper.operation.OperationServiceHelper;
import kd.bos.servicehelper.operation.SaveServiceHelper;
import kd.sdk.plugin.Plugin;
import nccloud.open.api.auto.token.cur.utils.APICurUtils;
import okhttp3.OkHttpClient;
import okhttp3.Request;
import okhttp3.RequestBody;
import okhttp3.Response;
import shkd.utils.DobeDWUtils;
import java.util.HashMap;
import java.util.Map;
/**
* 后台任务插件
*/
public class YongyouBIPTask extends AbstractTask implements Plugin {
private static Log log = LogFactory.getLog(YongyouBIPTask.class);
//合同付款申请单的实体名称
// private static final String payrequestEntity = "recon_payreqbill";
//费用登记的实体名称
// private static final String notextEntity = "recon_connotextbill";
private static final String payregisterEntity = "recon_payregister";//付款登记标识 供应链库 t_recon_payregister
@Override
public void execute(RequestContext requestContext, Map<String, Object> map) throws KDException {
//查找合同付款申请单已审核未付款的单子
// DynamicObjectCollection docs = QueryServiceHelper.query(payrequestEntity,"id,number,name",new QFilter[]{new QFilter("billstatus","=","C")});
// DynamicObject currentinfo = null;
// for (int i = 0; i < docs.size(); i++) {
// currentinfo = docs.get(i);
// }
//定时任务获取的参数是配置调度程序的时候设置如果是测试接口联通性则将token放入日志中
if(map != null && "yes".equals(map.get("testjiekou"))){
APICurUtils apiutil1 = new APICurUtils();//处理认证接口的工具类用友提供的第三方工具得到accesstoken
apiutil1.init(DobeDWUtils.yyip,DobeDWUtils.yyport,DobeDWUtils.bizcenter,DobeDWUtils.clientid,DobeDWUtils.clientsecret,DobeDWUtils.pubKey,DobeDWUtils.clientid,null);
try {
String tokenresult1 = apiutil1.getTokenByClient();
DobeDWUtils.saveLog("testjiekou","测试用友token接口",null,tokenresult1,true,"定时任务");
} catch (Exception e) {
throw new RuntimeException(e);
}
}
//查找未审核的付款登记单,考虑费用登记和付款申请单如果是事后补单的话,此处是否需要过滤
QFilter statusFilter = new QFilter("billstatus","=","A");
QFilter statusB = new QFilter("billstatus","=","B");
// String selectStr = "id,billno,bizdate,billstatus,connotextbill.id,connotextbill.billno,connotextbill.qeug_yynum,payreqbill.id,payreqbill.billno,payreqbill.qeug_yynum";
DynamicObject[] prs = BusinessDataServiceHelper.load(payregisterEntity,"id",new QFilter[]{statusFilter.or(statusB)});
if(prs.length == 0){
return;
}
//将满足本次查询条件的单子存入map中
DynamicObject prinfo = null;
DynamicObject requestinfo = null;
String yyid = null;
JSONObject idjson = null;
JSONArray idarray = new JSONArray();
Map<String,DynamicObject> billMap = new HashMap();
Map<String,String> billNumberMap = new HashMap();
for (int i = 0; i < prs.length; i++) {
prinfo = BusinessDataServiceHelper.loadSingle(prs[i].getPkValue(),payregisterEntity);
//费用登记
requestinfo = prinfo.getDynamicObject("connotextbill");
if(requestinfo == null){
//付款申请
requestinfo = prinfo.getDynamicObject("payreqbill");
}
requestinfo = BusinessDataServiceHelper.loadSingle(requestinfo.getPkValue(),requestinfo.getDataEntityType().getName().replace("_f7",""));
//看用友的实付款查询接口是一个个查询,还是集中查询;这个字段直接从F7实体对象中获取不到需要扩展F7实体
yyid = requestinfo.getString("qeug_yyid");
//获取到的yyid为空则不进行实付查询
if(DobeDWUtils.isEmpty(yyid)){
continue;
}
billMap.put(yyid,prinfo);
billNumberMap.put(yyid,requestinfo.getString("qeug_yynum"));
idjson = new JSONObject();
idjson.put("id",yyid);
idarray.add(idjson);
}
if(billMap.isEmpty()){
return;
}
//bip接口认证
String accesstoken = null;
APICurUtils apiutil = new APICurUtils();//处理认证接口的工具类用友提供的第三方工具得到accesstoken
apiutil.init(DobeDWUtils.yyip,DobeDWUtils.yyport,DobeDWUtils.bizcenter,DobeDWUtils.clientid,DobeDWUtils.clientsecret,DobeDWUtils.pubKey,DobeDWUtils.clientid,null);
try {
String tokenresult = apiutil.getTokenByClient();
if(DobeDWUtils.isEmpty(tokenresult)){
log.error("用友认证接口返回的accessToken为空");
return;
}
JSONObject json_reuslt = JSON.parseObject(tokenresult);
if(json_reuslt.getJSONObject("data") == null){
log.error("用友认证接口返回的data为空");
return;
}
accesstoken = json_reuslt.getJSONObject("data").getString("access_token");
} catch (Exception e) {
log.error(String.format("用友认证接口异常:%s", e.getMessage()));
throw new RuntimeException(e);
}
if(DobeDWUtils.isEmpty(accesstoken)){
log.error("用友认证接口返回的accessToken为空");
return;
}
JSONObject queryParams = new JSONObject();
queryParams.put("bipData",idarray);
Request request = new Request.Builder().url(DobeDWUtils.payQueryUrl)
.post(createFormRequestBody(queryParams))
.header("Content-Type", "application/json;charset=utf-8")
.header("access_token", accesstoken)
.header("repeat_check", "Y")
.header("ucg_flag", "Y")
.header("client_id", DobeDWUtils.clientid)
.build();
try {
OkHttpClient client = new OkHttpClient();
Response response = client.newCall(request).execute();
JSONObject resultData = JSON.parseObject(response.body().string());
if(!"200".equals(resultData.getString("code"))){
//增加日志记录
DobeDWUtils.saveLog("noQueryResult","用友实付查询",queryParams.toString(),resultData.toString(),false,"定时任务");
return;
}
JSONArray dataArray = resultData.getJSONArray("data");
for (int i = 0; i < dataArray.size(); i++) {
idjson = dataArray.getJSONObject(i);
yyid = idjson.getJSONObject("parentVO").getString("pk_busi");
prinfo = billMap.get(yyid);
if(prinfo != null){
prinfo.set("bizdate",idjson.getJSONObject("parentVO").getDate("settleDate"));
prinfo.set("billno",billNumberMap.get(yyid));
prinfo.set("billstatus","B"); //单据状态改为已提交
SaveServiceHelper.update(prinfo);//保存上述设置内容
//调用付款登记单的审核方法,在此之前设置一下当前操作人为付款登记的经办人
// requestContext.setUserOpenId(prinfo.getDynamicObject("handler").getString("id"));
OperationServiceHelper.executeOperate("audit",payregisterEntity,new DynamicObject[]{prinfo}, OperateOption.create());
}
}
DobeDWUtils.saveLog("querySuccess","用友实付查询",queryParams.toString(),resultData.toString(),true,"定时任务");
} catch (Exception e) {
DobeDWUtils.saveLog("queryException","用友实付查询",queryParams.toString(),e.getMessage(),false,"定时任务");
}
// String[] companyDept = null;
// for (int i = 0; i < prs.length; i++) {
// //根据付款申请单的用款部门找到对应财务组织编号
// companyDept = DobeDWUtils.getCompanyDeptNumber(requestinfo.getDynamicObject("usedepart").getString("number"));
// if(companyDept[0] == null){
// DobeDWUtils.saveLog(requestinfo.getString("number"),"用友实付查询",requestinfo.getDynamicObject("usedepart").getString("number"),"根据用款部门编号转换财务编号失败",false,"定时任务");
// continue;
// }
// queryParams.put("pk_org",companyDept[0]);
// //根据查询结果设置付款登记对象
// prinfo.set("bizdate",resultData.getJSONObject("data").getDate("billdate"));
// prinfo.set("billno",yynum);
// prinfo.set("billstatus","B"); //单据状态改为已提交
// SaveServiceHelper.update(prinfo);//保存上述设置内容
// //调用提交方法
//// OperationServiceHelper.executeOperate("submit",payregisterEntity,new DynamicObject[]{prinfo}, OperateOption.create());
// //调用付款登记单的审核方法
// OperationServiceHelper.executeOperate("audit",payregisterEntity,new DynamicObject[]{prinfo}, OperateOption.create());
// DobeDWUtils.saveLog(requestinfo.getString("number"),"用友实付查询",queryParams.toString(),resultData.toString(),true,"定时任务");
// }
}
private RequestBody createFormRequestBody(JSONObject json_body) {
// return RequestBody.create(ByteString.encodeUtf8(json_body.toJSONString()), DobeDWUtils.MTJSON);
return RequestBody.create(json_body.toJSONString(), DobeDWUtils.MTJSON);
}
}