| | |
| | | import java.util.ArrayList; |
| | | import java.util.List; |
| | | import java.util.Map; |
| | | import java.util.concurrent.atomic.AtomicInteger; |
| | | import java.util.stream.Collectors; |
| | | |
| | | @Slf4j |
| | |
| | | if (loginUser != null) { |
| | | process.creator = loginUser.id; |
| | | } |
| | | AtomicInteger startCount = new AtomicInteger(); |
| | | AtomicInteger endCount = new AtomicInteger(); |
| | | process.nodes.forEach(node -> { |
| | | node.processId = process.id; |
| | | node.deleted = false; |
| | | if(node.isStart){ |
| | | startCount.getAndIncrement(); |
| | | } |
| | | if(node.isEnd){ |
| | | endCount.getAndIncrement(); |
| | | } |
| | | }); |
| | | if (startCount.get() != 1 || endCount.get() != 1) { |
| | | throw new RuntimeException("节点开始和结束节点有且只能有一个"); |
| | | } |
| | | } |
| | | |
| | | // 将节点和工作指示的保存逻辑封装到一个方法中 |