in progess
This commit is contained in:
parent
a2c3f44dcd
commit
a0c77b4e68
|
@ -3,6 +3,7 @@ package org.gcube.application.cms.notifications;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
import org.gcube.application.cms.notifications.config.SubscribeNotificationEvent;
|
import org.gcube.application.cms.notifications.config.SubscribeNotificationEvent;
|
||||||
|
import org.gcube.application.geoportal.common.model.useCaseDescriptor.UseCaseDescriptor;
|
||||||
import org.gcube.com.fasterxml.jackson.annotation.JsonIgnoreProperties;
|
import org.gcube.com.fasterxml.jackson.annotation.JsonIgnoreProperties;
|
||||||
|
|
||||||
import lombok.Data;
|
import lombok.Data;
|
||||||
|
@ -10,6 +11,7 @@ import lombok.Data;
|
||||||
@Data
|
@Data
|
||||||
@JsonIgnoreProperties(ignoreUnknown = true)
|
@JsonIgnoreProperties(ignoreUnknown = true)
|
||||||
public class NotificationEventsSubscribedConfig {
|
public class NotificationEventsSubscribedConfig {
|
||||||
String context;
|
UseCaseDescriptor ucd;
|
||||||
List<SubscribeNotificationEvent> listNotificationEventSubscribed;
|
List<SubscribeNotificationEvent> listNotificationEventSubscribed;
|
||||||
|
String linkToMessages;
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,12 +1,16 @@
|
||||||
package org.gcube.application.cms.notifications;
|
package org.gcube.application.cms.notifications;
|
||||||
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
|
import java.util.Arrays;
|
||||||
|
import java.util.HashMap;
|
||||||
import java.util.LinkedHashMap;
|
import java.util.LinkedHashMap;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
import java.util.stream.Collectors;
|
||||||
|
|
||||||
import org.bson.Document;
|
import org.bson.Document;
|
||||||
import org.gcube.application.cms.implementations.utils.UserUtils;
|
import org.gcube.application.cms.implementations.utils.UserUtils;
|
||||||
|
import org.gcube.application.cms.notifications.config.NotificationFor;
|
||||||
import org.gcube.application.cms.notifications.config.SubscribeNotificationEvent;
|
import org.gcube.application.cms.notifications.config.SubscribeNotificationEvent;
|
||||||
import org.gcube.application.cms.plugins.EventListenerPluginInterface;
|
import org.gcube.application.cms.plugins.EventListenerPluginInterface;
|
||||||
import org.gcube.application.cms.plugins.events.EventListener;
|
import org.gcube.application.cms.plugins.events.EventListener;
|
||||||
|
@ -51,6 +55,9 @@ public class NotificationsPlugin extends AbstractPlugin implements EventListener
|
||||||
DESCRIPTOR.setDescription("Manage the notification from Geoportal engine");
|
DESCRIPTOR.setDescription("Manage the notification from Geoportal engine");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// This is a map "<Context,<UCD_ID,NotificationEventsSubscribedConfig>"
|
||||||
|
protected Map<String, Map<String, NotificationEventsSubscribedConfig>> notificationEventsBindingMap = null;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Inits the.
|
* Inits the.
|
||||||
*
|
*
|
||||||
|
@ -160,7 +167,7 @@ public class NotificationsPlugin extends AbstractPlugin implements EventListener
|
||||||
String context = UserUtils.getCurrent().getContext();
|
String context = UserUtils.getCurrent().getContext();
|
||||||
if (getNotificationBindingMapPerContext() == null) {
|
if (getNotificationBindingMapPerContext() == null) {
|
||||||
log.info("Initializing in " + context);
|
log.info("Initializing in " + context);
|
||||||
notificationEventsBindingMap.put(context, new NotificationEventsSubscribedConfig());
|
notificationEventsBindingMap.put(context, new HashMap<String, NotificationEventsSubscribedConfig>());
|
||||||
}
|
}
|
||||||
report.setStatus(Report.Status.OK);
|
report.setStatus(Report.Status.OK);
|
||||||
report.putMessage("Initialized " + DESCRIPTOR.getId() + " in the " + context);
|
report.putMessage("Initialized " + DESCRIPTOR.getId() + " in the " + context);
|
||||||
|
@ -184,11 +191,17 @@ public class NotificationsPlugin extends AbstractPlugin implements EventListener
|
||||||
NotificationEventsSubscribedConfig eventsSub = readNotificationsSubscribedFromConfigurationInTheUCD(
|
NotificationEventsSubscribedConfig eventsSub = readNotificationsSubscribedFromConfigurationInTheUCD(
|
||||||
observerd.getUseCaseDescriptor());
|
observerd.getUseCaseDescriptor());
|
||||||
|
|
||||||
List<SubscribeNotificationEvent> listEvents = eventsSub.getListNotificationEventSubscribed();
|
if (eventsSub != null) {
|
||||||
log.info("List events is {}", listEvents);
|
|
||||||
if (listEvents.contains(observerd.getEvent())) {
|
List<SubscribeNotificationEvent> listEvents = eventsSub.getListNotificationEventSubscribed();
|
||||||
log.info("the event {} is subscribed from config ", observerd.getEvent());
|
log.info("List events is {}", listEvents);
|
||||||
return true;
|
if (listEvents != null
|
||||||
|
&& listEvents.stream().anyMatch(sne -> sne.getEvent().equals(observerd.getEvent()))) {
|
||||||
|
log.info("the event {} is subscribed from config ", observerd.getEvent());
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
log.info("the event {} is not subscribed from config ", observerd.getEvent());
|
||||||
|
return false;
|
||||||
}
|
}
|
||||||
log.info("the event {} is not subscribed from config ", observerd.getEvent());
|
log.info("the event {} is not subscribed from config ", observerd.getEvent());
|
||||||
return false;
|
return false;
|
||||||
|
@ -200,20 +213,40 @@ public class NotificationsPlugin extends AbstractPlugin implements EventListener
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
protected Map<String, NotificationEventsSubscribedConfig> notificationEventsBindingMap = null;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Gets the notification binding map per context.
|
* Gets the notification binding map per context.
|
||||||
*
|
*
|
||||||
* @return the notification binding map per context
|
* @return the notification binding map per context
|
||||||
*/
|
*/
|
||||||
protected NotificationEventsSubscribedConfig getNotificationBindingMapPerContext() {
|
protected Map<String, NotificationEventsSubscribedConfig> getNotificationBindingMapPerContext() {
|
||||||
String context = UserUtils.getCurrent().getContext();
|
String context = UserUtils.getCurrent().getContext();
|
||||||
log.debug("Getting {} from cache map for context {}", NotificationsPlugin.PLUGIN_ID, context);
|
log.debug("Getting {} from cache map for context {}", NotificationsPlugin.PLUGIN_ID, context);
|
||||||
if (notificationEventsBindingMap == null)
|
if (notificationEventsBindingMap == null) {
|
||||||
notificationEventsBindingMap = new LinkedHashMap<String, NotificationEventsSubscribedConfig>();
|
notificationEventsBindingMap = new LinkedHashMap<String, Map<String, NotificationEventsSubscribedConfig>>();
|
||||||
|
}
|
||||||
|
|
||||||
return notificationEventsBindingMap.get(context);
|
// read notification events binding subscribed in the context
|
||||||
|
Map<String, NotificationEventsSubscribedConfig> map = notificationEventsBindingMap.get(context);
|
||||||
|
return map == null ? new LinkedHashMap<String, NotificationEventsSubscribedConfig>() : map;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Sets the notification binding map per context.
|
||||||
|
*
|
||||||
|
* @param context the context
|
||||||
|
* @param ucd the ucd
|
||||||
|
* @param notification the notification
|
||||||
|
*/
|
||||||
|
private void setNotificationBindingMapPerContext(String context, UseCaseDescriptor ucd,
|
||||||
|
NotificationEventsSubscribedConfig notification) {
|
||||||
|
Map<String, NotificationEventsSubscribedConfig> mapNotificationConfig = notificationEventsBindingMap
|
||||||
|
.get(context);
|
||||||
|
if (mapNotificationConfig == null) {
|
||||||
|
mapNotificationConfig = new LinkedHashMap<String, NotificationEventsSubscribedConfig>();
|
||||||
|
}
|
||||||
|
|
||||||
|
mapNotificationConfig.put(ucd.getId(), notification);
|
||||||
|
notificationEventsBindingMap.put(context, mapNotificationConfig);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -228,7 +261,7 @@ public class NotificationsPlugin extends AbstractPlugin implements EventListener
|
||||||
|
|
||||||
log.debug("Reading subscribed events from UCD");
|
log.debug("Reading subscribed events from UCD");
|
||||||
|
|
||||||
NotificationEventsSubscribedConfig notificationMapPerContext = new NotificationEventsSubscribedConfig();
|
NotificationEventsSubscribedConfig notificationMapPerContext = null;
|
||||||
|
|
||||||
if (useCaseDescriptor == null)
|
if (useCaseDescriptor == null)
|
||||||
throw new Exception("Error reading UCD null found");
|
throw new Exception("Error reading UCD null found");
|
||||||
|
@ -237,49 +270,61 @@ public class NotificationsPlugin extends AbstractPlugin implements EventListener
|
||||||
|
|
||||||
String context = UserUtils.getCurrent().getContext();
|
String context = UserUtils.getCurrent().getContext();
|
||||||
|
|
||||||
notificationMapPerContext = getNotificationBindingMapPerContext();
|
Map<String, NotificationEventsSubscribedConfig> mapPerContext = getNotificationBindingMapPerContext();
|
||||||
|
|
||||||
List<SubscribeNotificationEvent> listNotificationEventsSubscribedPerUCD = notificationMapPerContext.getListNotificationEventSubscribed();
|
notificationMapPerContext = mapPerContext.get(useCaseDescriptor.getId());
|
||||||
|
|
||||||
if (listNotificationEventsSubscribedPerUCD==null) {
|
if (notificationMapPerContext == null) {
|
||||||
|
notificationMapPerContext = new NotificationEventsSubscribedConfig();
|
||||||
|
setNotificationBindingMapPerContext(context, useCaseDescriptor, notificationMapPerContext);
|
||||||
|
}
|
||||||
|
|
||||||
|
List<SubscribeNotificationEvent> listNotificationEventsSubscribedPerUCD = notificationMapPerContext
|
||||||
|
.getListNotificationEventSubscribed();
|
||||||
|
|
||||||
|
if (listNotificationEventsSubscribedPerUCD == null) {
|
||||||
listNotificationEventsSubscribedPerUCD = new ArrayList<SubscribeNotificationEvent>();
|
listNotificationEventsSubscribedPerUCD = new ArrayList<SubscribeNotificationEvent>();
|
||||||
Document profileConfiguration = getConfigurationFromProfile(useCaseDescriptor).getConfiguration();
|
Document profileConfiguration = getConfigurationFromProfile(useCaseDescriptor).getConfiguration();
|
||||||
log.debug("UseCaseDescriptor Configuration is {} ", profileConfiguration);
|
log.debug("UseCaseDescriptor Configuration is {} ", profileConfiguration);
|
||||||
// JSONPathWrapper schemaNavigator = new
|
// JSONPathWrapper schemaNavigator = new
|
||||||
// JSONPathWrapper(useCaseDescriptor.getSchema().toJson());
|
// JSONPathWrapper(useCaseDescriptor.getSchema().toJson());
|
||||||
|
|
||||||
for (Object fsConfigObj : profileConfiguration.get(SUBSCRIBE_NOTIFICATIONS_CONFIG, List.class)) {
|
if (profileConfiguration != null) {
|
||||||
log.debug("Managing {} ", fsConfigObj);
|
for (Object fsConfigObj : profileConfiguration.get(SUBSCRIBE_NOTIFICATIONS_CONFIG, List.class)) {
|
||||||
SubscribeNotificationEvent fsConfig = Serialization.convert(fsConfigObj,
|
log.debug("Managing {} ", fsConfigObj);
|
||||||
SubscribeNotificationEvent.class);
|
SubscribeNotificationEvent fsConfig = Serialization.convert(fsConfigObj,
|
||||||
log.debug("Converted config {}", fsConfig);
|
SubscribeNotificationEvent.class);
|
||||||
String theEventSubsribed = fsConfig.getEvent();
|
log.debug("Converted config {}", fsConfig);
|
||||||
if (theEventSubsribed == null || theEventSubsribed.isEmpty())
|
try {
|
||||||
throw new MaterializationException(
|
Event theEventSubsribed = Serialization.convert(fsConfig.getEvent(), Event.class);
|
||||||
"Invalid Field Definition path in configuration null or empty event : " + theEventSubsribed);
|
if (theEventSubsribed == null)
|
||||||
|
throw new MaterializationException(
|
||||||
|
"Invalid Field Definition path in configuration [NO MATCH] : "
|
||||||
|
+ theEventSubsribed);
|
||||||
|
} catch (Exception e) {
|
||||||
|
log.error("MaterializationException: ", e);
|
||||||
|
throw new MaterializationException(
|
||||||
|
"Invalid Event Definition path in configuration [NO MATCH Event] : "
|
||||||
|
+ Event.values());
|
||||||
|
}
|
||||||
|
|
||||||
try {
|
|
||||||
Event event = Serialization.convert(theEventSubsribed, Event.class);
|
|
||||||
log.debug("Added event {} to list ", event);
|
|
||||||
listNotificationEventsSubscribedPerUCD.add(fsConfig);
|
listNotificationEventsSubscribedPerUCD.add(fsConfig);
|
||||||
}catch (Exception e) {
|
|
||||||
log.error("MaterializationException: ", e);
|
|
||||||
throw new MaterializationException(
|
|
||||||
"Invalid Event Definition path in configuration [NO MATCH] : " + fsConfig.getEvent());
|
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
notificationMapPerContext = new NotificationEventsSubscribedConfig();
|
notificationMapPerContext.setUcd(useCaseDescriptor);
|
||||||
notificationMapPerContext.setContext(context);
|
notificationMapPerContext
|
||||||
notificationMapPerContext.setListNotificationEventSubscribed(listNotificationEventsSubscribedPerUCD);
|
.setListNotificationEventSubscribed(listNotificationEventsSubscribedPerUCD);
|
||||||
notificationEventsBindingMap.put(context, notificationMapPerContext);
|
String linkToMessages = profileConfiguration.get("link_to_messages", String.class);
|
||||||
|
notificationMapPerContext.setLinkToMessages(linkToMessages);
|
||||||
|
}
|
||||||
|
setNotificationBindingMapPerContext(context, useCaseDescriptor, notificationMapPerContext);
|
||||||
|
|
||||||
log.info("Events subscribed read from config {} ", notificationMapPerContext);
|
log.info("Events subscribed read from config {} ", notificationMapPerContext);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
log.error("Unable to read configuration for "+NotificationsPlugin.PLUGIN_ID, e);
|
log.error("Unable to read configuration for " + NotificationsPlugin.PLUGIN_ID, e);
|
||||||
} catch (Throwable t) {
|
} catch (Throwable t) {
|
||||||
log.error("Exception, Unable to read configuration ", t);
|
log.error("Exception, Unable to read configuration ", t);
|
||||||
}
|
}
|
||||||
|
@ -305,7 +350,32 @@ public class NotificationsPlugin extends AbstractPlugin implements EventListener
|
||||||
*/
|
*/
|
||||||
@Override
|
@Override
|
||||||
public void doAction(ItemObserved<Project> itemObserved) {
|
public void doAction(ItemObserved<Project> itemObserved) {
|
||||||
// TODO Auto-generated method stub
|
|
||||||
|
if (checkIfSubscribedEvent(itemObserved)) {
|
||||||
|
|
||||||
|
//Map (UCD_ID, Notification)
|
||||||
|
Map<String, NotificationEventsSubscribedConfig> notificationMapPerContext = getNotificationBindingMapPerContext();
|
||||||
|
|
||||||
|
NotificationEventsSubscribedConfig subscribedConfig = notificationMapPerContext
|
||||||
|
.get(itemObserved.getUCD_Id());
|
||||||
|
|
||||||
|
String linkToFileWithMessages = subscribedConfig.getLinkToMessages();
|
||||||
|
List<SubscribeNotificationEvent> list = subscribedConfig.getListNotificationEventSubscribed();
|
||||||
|
|
||||||
|
List<SubscribeNotificationEvent> filterList = list.stream()
|
||||||
|
.filter(sne -> sne.getEvent().equals(itemObserved.getEvent())).collect(Collectors.toList());
|
||||||
|
|
||||||
|
for (SubscribeNotificationEvent subscribeNotificationEvent : filterList) {
|
||||||
|
List<NotificationFor> listNotificationFor = subscribeNotificationEvent.getNotificationFor();
|
||||||
|
|
||||||
|
UserUtils.getCurrent().getRoles();
|
||||||
|
|
||||||
|
for (NotificationFor notificationFor : listNotificationFor) {
|
||||||
|
notificationFor.getRoles();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -2,6 +2,7 @@ package org.gcube.application.cms.notifications.config;
|
||||||
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
|
import org.gcube.application.cms.plugins.events.EventManager.Event;
|
||||||
import org.gcube.com.fasterxml.jackson.annotation.JsonIgnoreProperties;
|
import org.gcube.com.fasterxml.jackson.annotation.JsonIgnoreProperties;
|
||||||
|
|
||||||
import lombok.Data;
|
import lombok.Data;
|
||||||
|
@ -66,6 +67,6 @@ import lombok.Data;
|
||||||
@JsonIgnoreProperties(ignoreUnknown = true)
|
@JsonIgnoreProperties(ignoreUnknown = true)
|
||||||
public class SubscribeNotificationEvent {
|
public class SubscribeNotificationEvent {
|
||||||
|
|
||||||
String event;
|
Event event;
|
||||||
List<NotificationFor> notificationFor;
|
List<NotificationFor> notificationFor;
|
||||||
}
|
}
|
||||||
|
|
|
@ -11,6 +11,7 @@ import org.gcube.application.cms.notifications.config.NotificationWhen;
|
||||||
import org.gcube.application.cms.notifications.config.Notify;
|
import org.gcube.application.cms.notifications.config.Notify;
|
||||||
import org.gcube.application.cms.notifications.config.Notify.NOTIFICATION_TYPE;
|
import org.gcube.application.cms.notifications.config.Notify.NOTIFICATION_TYPE;
|
||||||
import org.gcube.application.cms.notifications.config.SubscribeNotificationEvent;
|
import org.gcube.application.cms.notifications.config.SubscribeNotificationEvent;
|
||||||
|
import org.gcube.application.cms.plugins.events.EventManager.Event;
|
||||||
import org.gcube.application.cms.plugins.faults.InitializationException;
|
import org.gcube.application.cms.plugins.faults.InitializationException;
|
||||||
import org.gcube.application.cms.serialization.Serialization;
|
import org.gcube.application.cms.serialization.Serialization;
|
||||||
import org.gcube.application.cms.tests.TestProfiles;
|
import org.gcube.application.cms.tests.TestProfiles;
|
||||||
|
@ -76,7 +77,7 @@ public class CatalogueBindingPluginTest extends BasicPluginTest {
|
||||||
org.junit.Assume.assumeTrue(GCubeTest.isTestInfrastructureEnabled());
|
org.junit.Assume.assumeTrue(GCubeTest.isTestInfrastructureEnabled());
|
||||||
|
|
||||||
SubscribeNotificationEvent sne = new SubscribeNotificationEvent();
|
SubscribeNotificationEvent sne = new SubscribeNotificationEvent();
|
||||||
sne.setEvent("LIFECYCLE_STEP_PERFORMED");
|
sne.setEvent(Event.LIFECYCLE_STEP_PERFORMED);
|
||||||
|
|
||||||
List<NotificationFor> listNotificationFor = new ArrayList<NotificationFor>();
|
List<NotificationFor> listNotificationFor = new ArrayList<NotificationFor>();
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue