/// <summary> /// 保存实例 /// </summary> /// <param name="keyValue"></param> /// <param name="entity"></param> /// <returns></returns> public int SaveEntity(string keyValue, WFProcessTransitionHistoryEntity entity) { try { int num; if (string.IsNullOrEmpty(keyValue)) { entity.Create(); num = this.BaseRepository().Insert(entity); } else { entity.Modify(keyValue); num = this.BaseRepository().Update(entity); } return(num); } catch { throw; } }
/// <summary> /// 更新流程实例 审核节点用 /// </summary> /// <param name="sql"></param> /// <param name="dbbaseId"></param> /// <param name="processInstanceEntity"></param> /// <param name="processSchemeEntity"></param> /// <param name="processOperationHistoryEntity"></param> /// <param name="delegateRecordEntityList"></param> /// <param name="processTransitionHistoryEntity"></param> /// <returns></returns> public int SaveProcess(string sql, string dbbaseId, WFProcessInstanceEntity processInstanceEntity, WFProcessSchemeEntity processSchemeEntity, WFProcessOperationHistoryEntity processOperationHistoryEntity, List <WFDelegateRecordEntity> delegateRecordEntityList, WFProcessTransitionHistoryEntity processTransitionHistoryEntity = null) { IRepository db = this.BaseRepository().BeginTrans(); try { processInstanceEntity.Modify(processInstanceEntity.Id); db.Update(processSchemeEntity); db.Update(processInstanceEntity); processOperationHistoryEntity.Create(); processOperationHistoryEntity.ProcessId = processInstanceEntity.Id; db.Insert(processOperationHistoryEntity); if (processTransitionHistoryEntity != null) { processTransitionHistoryEntity.Create(); processTransitionHistoryEntity.ProcessId = processInstanceEntity.Id; db.Insert(processTransitionHistoryEntity); } if (delegateRecordEntityList != null) { foreach (var item in delegateRecordEntityList) { item.Create(); item.ProcessId = processInstanceEntity.Id; db.Insert(item); } } //if (!string.IsNullOrEmpty(dbbaseId) && !string.IsNullOrEmpty(sql))//测试环境不允许执行sql语句 //{ // DataBaseLinkEntity dataBaseLinkEntity = dataBaseLinkService.GetEntity(dbbaseId);//获取 // this.BaseRepository(dataBaseLinkEntity.DbConnection).ExecuteBySql(sql.Replace("{0}", processInstanceEntity.Id)); //} db.Commit(); return(1); } catch { db.Rollback(); throw; } }
/// <summary> /// 存储工作流实例进程(审核驳回重新提交) /// </summary> /// <param name="processInstanceEntity"></param> /// <param name="processSchemeEntity"></param> /// <param name="processOperationHistoryEntity"></param> /// <param name="processTransitionHistoryEntity"></param> /// <returns></returns> public int SaveProcess(WFProcessInstanceEntity processInstanceEntity, WFProcessSchemeEntity processSchemeEntity, WFProcessOperationHistoryEntity processOperationHistoryEntity, List <WFDelegateRecordEntity> delegateRecordEntityList, WFProcessTransitionHistoryEntity processTransitionHistoryEntity = null) { IRepository db = this.BaseRepository().BeginTrans(); try { processInstanceEntity.Modify(processInstanceEntity.Id); db.Update(processSchemeEntity); db.Update(processInstanceEntity); processOperationHistoryEntity.Create(); processOperationHistoryEntity.ProcessId = processInstanceEntity.Id; db.Insert(processOperationHistoryEntity); if (processTransitionHistoryEntity != null) { processTransitionHistoryEntity.Create(); processTransitionHistoryEntity.ProcessId = processInstanceEntity.Id; db.Insert(processTransitionHistoryEntity); } if (delegateRecordEntityList != null) { foreach (var item in delegateRecordEntityList) { item.Create(); item.ProcessId = processInstanceEntity.Id; db.Insert(item); } } db.Commit(); return(1); } catch { db.Rollback(); throw; } }
/// <summary> /// 存储工作流实例进程(创建实例进程) /// </summary> /// <param name="wfRuntimeModel"></param> /// <param name="processInstanceEntity"></param> /// <param name="processSchemeEntity"></param> /// <param name="processOperationHistoryEntity"></param> /// <param name="delegateRecordEntity"></param> /// <returns></returns> public int SaveProcess(WF_RuntimeModel wfRuntimeModel, WFProcessInstanceEntity processInstanceEntity, WFProcessSchemeEntity processSchemeEntity, WFProcessOperationHistoryEntity processOperationHistoryEntity, WFProcessTransitionHistoryEntity processTransitionHistoryEntity, List <WFDelegateRecordEntity> delegateRecordEntityList) { IRepository db = this.BaseRepository().BeginTrans(); try { if (string.IsNullOrEmpty(processInstanceEntity.Id)) { processSchemeEntity.Create(); db.Insert(processSchemeEntity); processInstanceEntity.Create(); processInstanceEntity.Id = wfRuntimeModel.processId; processInstanceEntity.ProcessSchemeId = processSchemeEntity.Id; db.Insert(processInstanceEntity); } else { processInstanceEntity.Modify(processInstanceEntity.Id); db.Update(processSchemeEntity); db.Update(processInstanceEntity); } processOperationHistoryEntity.Create(); processOperationHistoryEntity.ProcessId = processInstanceEntity.Id; db.Insert(processOperationHistoryEntity); if (processTransitionHistoryEntity != null) { processTransitionHistoryEntity.Create(); processTransitionHistoryEntity.ProcessId = processInstanceEntity.Id; db.Insert(processTransitionHistoryEntity); } foreach (var item in delegateRecordEntityList) { item.Create(); item.ProcessId = processInstanceEntity.Id; db.Insert(item); } //if (processInstanceEntity.FrmType == 0) //{ // DataBaseLinkEntity dataBaseLinkEntity = dataBaseLinkService.GetEntity(wfRuntimeModel.schemeContentJson.Frm.FrmDbId.Value);//获取 // if (wfRuntimeModel.schemeContentJson.Frm.isSystemTable.Value != 0) // { // this.BaseRepository(dataBaseLinkEntity.DbConnection).ExecuteBySql(wfRuntimeModel.sqlFrm); // } //} db.Commit(); return(1); } catch { db.Rollback(); throw; } }
/// <summary> /// 存储工作流实例进程(创建实例进程) /// </summary> /// <param name="wfRuntimeModel"></param> /// <param name="processInstanceEntity"></param> /// <param name="processSchemeEntity"></param> /// <param name="processOperationHistoryEntity"></param> /// <param name="delegateRecordEntity"></param> /// <returns></returns> public int SaveProcess(WF_RuntimeModel wfRuntimeModel, WFProcessInstanceEntity processInstanceEntity, WFProcessSchemeEntity processSchemeEntity, WFProcessOperationHistoryEntity processOperationHistoryEntity, WFProcessTransitionHistoryEntity processTransitionHistoryEntity, List <WFDelegateRecordEntity> delegateRecordEntityList) { IRepository db = this.BaseRepository().BeginTrans(); try { //占用单据号 coderuleService.UseRuleSeed(OperatorProvider.Provider.Current().LoginInfo.UserId, "", "10007", db); if (string.IsNullOrEmpty(processInstanceEntity.Id)) { processSchemeEntity.Create(); db.Insert(processSchemeEntity); processInstanceEntity.Create(); processInstanceEntity.Id = wfRuntimeModel.processId; processInstanceEntity.ProcessSchemeId = processSchemeEntity.Id; db.Insert(processInstanceEntity); } else { processInstanceEntity.Modify(processInstanceEntity.Id); db.Update(processSchemeEntity); db.Update(processInstanceEntity); } processOperationHistoryEntity.Create(); processOperationHistoryEntity.ProcessId = processInstanceEntity.Id; db.Insert(processOperationHistoryEntity); if (processTransitionHistoryEntity != null) { processTransitionHistoryEntity.Create(); processTransitionHistoryEntity.ProcessId = processInstanceEntity.Id; db.Insert(processTransitionHistoryEntity); } foreach (var item in delegateRecordEntityList) { item.Create(); item.ProcessId = processInstanceEntity.Id; db.Insert(item); } if (processInstanceEntity.FrmType == 0) { DataBaseLinkEntity dataBaseLinkEntity = dataBaseLinkService.GetEntity(wfRuntimeModel.schemeContentJson.Frm.FrmDbId.Value);//获取 if (wfRuntimeModel.schemeContentJson.Frm.isSystemTable.Value != 0) { //是否执行插入数据 外包员工薪资申请流程处理 create by chand 2016-11-29 if (processSchemeEntity.WFSchemeInfoId != "3416863b-d5c1-4b31-b59f-e5fd8cd2d5f1") { this.BaseRepository(dataBaseLinkEntity.DbConnection).ExecuteBySql(wfRuntimeModel.sqlFrm); } } } db.Commit(); return(1); } catch { db.Rollback(); throw; } }