/// <summary> /// XTLibrary 入口函数 /// </summary> /// <param name="log"></param> /// <returns></returns> public void Run(Model.Synergismlog log) { System.Diagnostics.Trace.WriteLine("begin Run(Model.Synergismlog log) "); System.Diagnostics.Trace.WriteLine("before log.OPClass "); log.OPClass = log.OPClass; log.OP = ClassFactory.GetBaseOp(log); DealResult dr = new DealResult(); dr.ResultNum = Constant.ResultNum_NoError; System.Diagnostics.Trace.WriteLine("after log.OPClass "); System.Diagnostics.Trace.WriteLine("before ITaskLogDetail "); BLL.TaskLogFactory.ITaskLogDetail logdtbll = ClassFactory.GetITaskLogDetailBLL(log.TaskType); System.Diagnostics.Trace.WriteLine("after ITaskLogDetail "); System.Diagnostics.Trace.WriteLine("before ITaskLogMain "); BLL.TaskLogFactory.ITaskLogMain logbll = ClassFactory.GetITaskLogMainBLL(log.TaskType); System.Diagnostics.Trace.WriteLine("after ITaskLogMain "); System.Diagnostics.Trace.WriteLine("before logdtbll.GetFrist "); Model.Synergismlogdt fdt = logdtbll.GetFrist(log, log.OP); System.Diagnostics.Trace.WriteLine("after logdtbll.GetFrist "); //挂起主表(置于等待中) if (fdt.Cstatus == Constant.SynergisnLogDT_Cstatus_NoAudit) { log.Cstatus = Constant.SynerginsLog_Cstatus_Wait; log.Endtime = DateTime.Now; logbll.Update(log, log.OP); //return dr; } //把记录设为处理中 log.Cstatus = Constant.SynerginsLog_Cstatus_Dealing; log.Endtime = DateTime.Now; logbll.Update(log, log.OP); //预置为完成 log.Cstatus = Constant.SynerginsLog_Cstatus_Complete; //获取下一节点(节点数可能大于1) List <Model.Synergismlogdt> listnext = logdtbll.GetNext(fdt, log.OP); //协同操作 System.Diagnostics.Trace.WriteLine("before MakeLogDT "); dr = MakeLogDT(log, dr, logdtbll, logbll, fdt, listnext); System.Diagnostics.Trace.WriteLine("after MakeLogDT "); //发送消息 //更新最终状态 log.Endtime = DateTime.Now; logbll.Update(log, log.OP); // return dr; }
/// <summary> /// 生单\审核 主函数 /// </summary> /// <param name="log">任务主表信息</param> /// <param name="dr"></param> /// <param name="logdtbll">任务子表信息</param> /// <param name="logbll">任务主表BLL</param> /// <param name="fdt">首节点信息</param> /// <param name="listnext">当前任务节点信息,档案同步时有可能存在多个子结点</param> /// <returns></returns> private DealResult MakeLogDT(Synergismlog log, DealResult dr, BLL.TaskLogFactory.ITaskLogDetail logdtbll, BLL.TaskLogFactory.ITaskLogMain logbll, Model.Synergismlogdt fdt, List <Model.Synergismlogdt> listnext) { for (int i = 0; i < listnext.Count; i++) { System.Diagnostics.Trace.WriteLine("listnext.Count: " + listnext.Count); Synergismlogdt preDt; Model.Synergismlogdt nextdt = listnext[i]; ////处理数据开始 try { System.Diagnostics.Trace.WriteLine(" 处理数据开始 "); BaseData bd = ClassFactory.GetBaseData(nextdt); bd.Fristsynergismlogdt = fdt; bd.Synergismlogdt = nextdt; BaseOp op = ClassFactory.GetBaseOp(nextdt); nextdt.OP = op; preDt = logdtbll.GetPrevious(nextdt, nextdt.OP); if (op == null) { throw new Exception("插件安装错误"); } if (nextdt.Cdealmothed == 3) //删除 { TaskOperator t = new TaskOperator(); return(t.DeleteVouch(0, nextdt)); } else if (nextdt.Cdealmothed == 2) //修改 { } System.Diagnostics.Trace.WriteLine(" before MakeData "); dr = op.MakeData(nextdt, bd); System.Diagnostics.Trace.WriteLine(" after MakeData "); string ccode; if (nextdt.Cstatus != DAL.Constant.SynergisnLogDT_Cstatus_NoAudit) { if (nextdt.Cdealmothed == 2) { dr = op.MakeUpdate(bd); return(dr); } System.Diagnostics.Trace.WriteLine(" before MakeVouch "); dr = op.MakeVouch(bd); //生单、档案协同 System.Diagnostics.Trace.WriteLine(" after MakeVouch "); if (dr.ResultNum == DAL.Constant.ResultNum_NormalError) { throw new Exception("API错误:" + dr.ResultMsg); } ccode = op.GetCodeorID(dr.VouchIdRet, bd, "code"); nextdt.Cstatus = DAL.Constant.SynergisnLogDT_Cstatus_NoAudit; nextdt.Dmaketime = DateTime.Now; nextdt.Cvoucherno = ccode; logdtbll.Update(nextdt, nextdt.OP); } else { ccode = nextdt.Cvoucherno; } if (string.IsNullOrEmpty(ccode)) { //throw new Exception("获取上游单据失败"); if (nextdt.Cstatus != DAL.Constant.SynergisnLogDT_Cstatus_NoAudit) { nextdt.Cstatus = DAL.Constant.SynerginsLog_Cstatus_NoDeal; } nextdt.Dmaketime = DateTime.Now; nextdt.Cvoucherno = ccode; logdtbll.Update(nextdt, nextdt.OP); break; } if (nextdt.Isaudit == DAL.Constant.SynergisnLogDT_Isaudit_True) { nextdt.Cstatus = DAL.Constant.SynergisnLogDT_Cstatus_Complete; dr = op.MakeAudit(bd, nextdt); //审核单据 } else { nextdt.Cstatus = DAL.Constant.SynergisnLogDT_Cstatus_NoAudit; } //nextdt.Cstatus = Constant.SynergisnLogDT_Cstatus_Complete; nextdt.Dmaketime = DateTime.Now; nextdt.Cvoucherno = ccode; logdtbll.Update(nextdt, nextdt.OP); //log.Cstatus = DAL.Common.SetLogStatus(log.Cstatus, Constant.SynerginsLog_Cstatus_Complete); if (nextdt.Isaudit == DAL.Constant.SynergisnLogDT_Isaudit_True) { log.Cstatus = DAL.Common.SetLogStatus(log.Cstatus, DAL.Constant.SynerginsLog_Cstatus_Complete); } else { log.Cstatus = DAL.Common.SetLogStatus(log.Cstatus, DAL.Constant.SynerginsLog_Cstatus_Wait); break; } List <Model.Synergismlogdt> listnl = logdtbll.GetNext(nextdt, nextdt.OP); MakeLogDT(log, dr, logdtbll, logbll, fdt, listnl); } catch (Exception ex) { dr.ResultNum = DAL.Constant.ResultNum_NormalError; dr.ResultMsg = ex.Message; Log.WriteWinLog(ex.ToString()); nextdt.Cstatus = DAL.Constant.SynergisnLogDT_Cstatus_Error; nextdt.Cerrordesc = ex.Message; nextdt.Errortimes++; nextdt.Dmaketime = DateTime.Now; logdtbll.Update(nextdt, nextdt.OP); preDt = logdtbll.GetPrevious(nextdt, nextdt.OP); log.Cstatus = DAL.Common.SetLogStatus(log.Cstatus, DAL.Constant.SynerginsLog_Cstatus_Error); } } return(dr); }