/* * (non-Javadoc) * * @see org.talend.gwtadministrator.server.remoterepositorymgt.view.AbstractViewAdapter#gwt2Hib(java.lang.Object, * org.talend.administrator.common.persistence.hibernate.ITransactionHolder) */ @Override public ExecutionPlanPart gwt2Hib(ExecutionPlanPartBean gwtBean, ITransactionHolder transaction) { Action action = (gwtBean.getId() == null ? Constants.Action.ADD : Constants.Action.UPDATE); ExecutionPlanPart hibBean = null; switch (action) { case ADD: hibBean = ConductorFactory.eINSTANCE.createExecutionPlanPart(); break; case UPDATE: hibBean = ExecutionPlanPartHelper.getInstance().findById(gwtBean.getId(), transaction); if (hibBean != null) { hibBean.setId(gwtBean.getId()); } else { log.warn( "Can't find the plan part with the id=" + gwtBean.getId() + ", the plan part might have already been deleted"); return null; } break; } if (gwtBean.getPlanBean() != null) { ExecutionPlan executionPlan = ExecutionPlanHelper.getInstance().findById(gwtBean.getPlanBean().getId(), transaction); hibBean.setExecutionPlan(executionPlan); } if (gwtBean.getTaskBean() != null) { ExecutionTask executionTask = ExecutionTaskHelper.getInstance().findById(gwtBean.getTaskBean().getId(), transaction); hibBean.setTask(executionTask); } ExecutionPlanPartBean parent = gwtBean.getParent(); if (parent != null) { hibBean.setParent(gwt2Hib(parent, transaction)); } if (gwtBean.getType() != null) { hibBean.setType(gwtBean.getType().toString()); PlanPartStatus partStatus = PlanPartStatus.get(gwtBean.getType().toString()); hibBean.setStatus(partStatus.name()); } if (gwtBean.getStatus() != null) { hibBean.setStatus(gwtBean.getStatus()); } hibBean.setStartDate(gwtBean.getStartDate()); hibBean.setEndDate(gwtBean.getEndDate()); hibBean.setUseParallel(gwtBean.isUseParallel()); hibBean.setMaxThreads(gwtBean.getMaxThreads()); return hibBean; }
private void saveOrUpdateParallelParts( ExecutionPlanPartBean parentPlanPartBean, ExecutionPlanPart parentPlanPart, User user, ITransactionHolder transaction) throws BusinessException, ClientBusinessException { List<ExecutionPlanPartBean> parallelNodes = parentPlanPartBean.getParallelParts(); if (parallelNodes == null) { parallelNodes = new ArrayList<ExecutionPlanPartBean>(); } int parallelTasksListSize = parallelNodes.size(); removeObsoleteNodes(parentPlanPart, transaction, parallelNodes, parallelTasksListSize); if (parentPlanPart.isUseParallel()) { for (int i = 0; i < parallelTasksListSize; i++) { ExecutionPlanPartBean parallelPartBean = parallelNodes.get(i); parallelPartBean.setParent(parentPlanPartBean); ExecutionTaskBean taskBean = parallelPartBean.getTaskBean(); ActionType type = parallelPartBean.getType(); if (ActionType.PARALLEL.equals(type) && taskBean != null) { saveExecutionPlanPartBean(parallelPartBean, user, transaction); } else { throw new RuntimeException( "Can't save a parallel node: type=" + type + ", taskId=" + taskBean.getId()); } } } }