private void filterOutNotCriticalTasks( ProjectInformation projectInformation, BatchIntervalInfo bi) { List<TaskInformation> tasks = projectInformation.getTasks(); for (int i = tasks.size() - 1; i >= 0; i--) { if (!tasks.get(i).IsCritical()) { tasks.remove(i); } } }
private void filterOutSendedWarnings(ProjectInformation pi, BatchIntervalInfo bi) { List<TaskInformation> tasks = pi.getTasks(); for (int i = tasks.size() - 1; i >= 0; i--) { Date d = batchPersisterService.getLastSendedFor(tasks.get(i).getId()); if (d != null) { if (new Date().getTime() - bi.getMailSendingInterval() * 60 * 24 * 60 * 1000 - d.getTime() <= 0) { System.out.println("MAILSENDEDFILTER TASK: " + tasks.get(i)); tasks.remove(i); } } } }
@Asynchronous public void checkImmediately(BatchIntervalInfo info) { try { List<ProjectInformation> pi = projectInformationService.getProjectInformation(info.getUsername(), info.getPassword()); for (ProjectInformation projectInformation : pi) { markCritialTasks(projectInformation, info); if (!info.isReportFull()) { filterOutNotCriticalTasks(projectInformation, info); } if (projectInformation.getTasks().size() > 0) { send(projectInformation); } } } catch (Exception ex) { Logger.getLogger(BatchTimerBean.class.getName()).log(Level.SEVERE, null, ex); } }
private void markCritialTasks(ProjectInformation projectInformation, BatchIntervalInfo bi) { List<TaskInformation> tasks = projectInformation.getTasks(); for (int i = tasks.size() - 1; i >= 0; i--) { List<Criteria> criterias = bi.getCriterias(); boolean critic = false; for (Criteria criteria : criterias) { critic = critic || !(criteria.checkTask(tasks.get(i))); tasks.get(i).setIsCritical(critic); System.out.println( "TASKKFILTER " + criteria.getCriteriaType() + " :" + tasks.get(i) + "is " + criteria.checkTask(tasks.get(i))); } System.out.println("Task " + tasks.get(i) + " is critic " + tasks.get(i).IsCritical()); } }
@Timeout public void check(Timer timer) { BatchIntervalInfo bi = (BatchIntervalInfo) timer.getInfo(); try { List<ProjectInformation> pi = projectInformationService.getProjectInformation(bi.getUsername(), bi.getPassword()); for (ProjectInformation projectInformation : pi) { markCritialTasks(projectInformation, bi); if (!bi.isReportFull()) { filterOutSendedWarnings(projectInformation, bi); filterOutNotCriticalTasks(projectInformation, bi); } if (projectInformation.getTasks().size() > 0) { send(projectInformation); markTasksAsSended(projectInformation); } } } catch (Exception ex) { Logger.getLogger(BatchTimerBean.class.getName()).log(Level.SEVERE, null, ex); } }
private void markTasksAsSended(ProjectInformation pi) { List<TaskInformation> tasks = pi.getTasks(); for (TaskInformation taskInformation : tasks) { batchPersisterService.markAsSended(taskInformation.getId(), new Date()); } }