private void createNotification( Profile profile, UGCAudit currentAudit, Map<String, Profile> actionOwnersCache) { if (currentAudit.getProfileId() != null && !currentAudit.getProfileId().equalsIgnoreCase("anonymous")) { Notification notification = new Notification(); // ACTION of the current JOB notification.setAction(profile.getSubscriptions().getAction()); notification.setCreatedDate(new Date()); notification.setRow(currentAudit.getRow()); // FORMAT of the current JOB notification.setFormat(profile.getSubscriptions().getFormat()); // FORMAT of the current JOB notification.setFrequency(profile.getSubscriptions().getFrequency()); notification.setSubscriberUsername(profile.getUserName()); notification.setSubscriberEmail(profile.getEmail()); notification.setSubscriberId(profile.getId()); notification.setTransmitedStatus(TransmittedStatus.PENDING); notification.setEvent( createEvent(currentAudit, getActionAuditOwner(actionOwnersCache, currentAudit))); this.notificationRepository.save(notification); } }
/** * Persist notifications * * @param pl Susbcriptors for each event * @param audits The events */ private void createNotifications( List<Profile> pl, List<UGCAudit> audits, Map<String, Profile> actionOwnersCache) { if (pl == null || pl.size() == 0) { return; } for (UGCAudit currentAudit : audits) { UGC ugc = ugcRepository.findOne(currentAudit.getUgcId()); if (ugc != null) { UGC.ModerationStatus modStatus = ugc.getModerationStatus(); if (modStatus != UGC.ModerationStatus.SPAM && modStatus != UGC.ModerationStatus.TRASH) { for (Profile profile : pl) { if (log.isDebugEnabled()) { log.debug( "Audit harvester creating notification event ROW " + currentAudit.getRow() + " for the subscriber: " + profile.getUserName()); } createNotification(profile, currentAudit, actionOwnersCache); } } } } }