/*
* Copyright (c) MuleSoft, Inc. All rights reserved. http://www.mulesoft.com
* The software in this package is published under the terms of the CPAL v1.0
* license, a copy of which has been included with this distribution in the
* LICENSE.txt file.
*/
package org.mule.runtime.core.api.context.notification;
import org.mule.runtime.core.api.MuleContext;
import org.mule.runtime.core.api.context.MuleContextAware;
import org.mule.runtime.core.util.ClassUtils;
import java.util.EventObject;
import java.util.Map;
import java.util.concurrent.ConcurrentHashMap;
/**
* <code>ServerNotification</code> is an event triggered by something happening in the Server itself such as the server starting
* or a service being registered.
*/
public abstract class ServerNotification extends EventObject implements MuleContextAware {
public static final int NO_ACTION_ID = Integer.MIN_VALUE;
public static final String NO_ACTION_NAME = "none";
public static final String TYPE_TRACE = "trace";
public static final String TYPE_INFO = "info";
public static final String TYPE_WARNING = "warn";
public static final String TYPE_ERROR = "error";
public static final String TYPE_FATAL = "fatal";
protected static final int CONTEXT_EVENT_ACTION_START_RANGE = 100;
protected static final int SECURITY_EVENT_ACTION_START_RANGE = 400;
protected static final int MANAGEMENT_EVENT_ACTION_START_RANGE = 500;
protected static final int ADMIN_EVENT_ACTION_START_RANGE = 600;
protected static final int CONNECTION_EVENT_ACTION_START_RANGE = 700;
protected static final int MESSAGE_EVENT_ACTION_START_RANGE = 800;
protected static final int MESSAGE_EVENT_END_ACTION_START_RANGE = 850;
protected static final int SPACE_EVENT_ACTION_START_RANGE = 900;
protected static final int REGISTRY_EVENT_ACTION_START_RANGE = 1000;
protected static final int EXCEPTION_EVENT_ACTION_START_RANGE = 1100;
protected static final int TRANSACTION_EVENT_ACTION_START_RANGE = 1200;
protected static final int ROUTING_EVENT_ACTION_START_RANGE = 1300;
protected static final int COMPONENT_EVENT_ACTION_START_RANGE = 1400;
protected static final int FLOW_CONSTRUCT_EVENT_ACTION_START_RANGE = 1500;
protected static final int MESSAGE_PROCESSOR_EVENT_ACTION_START_RANGE = 1600;
protected static final int CLUSTER_NODE_EVENT_ACTION_START_RANGE = 1700;
protected static final int PIPELINE_MESSAGE_EVENT_ACTION_START_RANGE = 1800;
protected static final int ASYNC_MESSAGE_EVENT_ACTION_START_RANGE = 1900;
protected static final int EXCEPTION_STRATEGY_MESSAGE_EVENT_ACTION_START_RANGE = 2000;
public static final int CUSTOM_EVENT_ACTION_START_RANGE = 100000;
public static final int NULL_ACTION = 0;
public static final Object NULL_MESSAGE = "";
public final String EVENT_NAME = ClassUtils.getClassName(getClass());
protected String serverId;
protected long timestamp;
protected int action = NULL_ACTION;
private static Map<Integer, String> actionIdToName = new ConcurrentHashMap<>();
private static Map<String, Integer> actionNameToId = new ConcurrentHashMap<>();
/**
* The resourceIdentifier is used when firing inbound server notifications such as Admin notifications or other action
* notifications triggered by an external source Used to associate the event with a particular resource. For example, if the
* event was a ServiceNotification the resourceIdentifier could be the name of a particular service
*/
protected String resourceIdentifier = null;
protected transient MuleContext muleContext;
public ServerNotification(Object message, int action) {
this(message, action, null);
}
public ServerNotification(Object message, int action, String resourceIdentifier) {
super((message == null ? NULL_MESSAGE : message));
this.action = action;
this.resourceIdentifier = resourceIdentifier;
timestamp = System.currentTimeMillis();
}
@Override
public void setMuleContext(MuleContext context) {
muleContext = context;
serverId = context.getId();
}
public int getAction() {
return action;
}
public String getServerId() {
return serverId;
}
public String getResourceIdentifier() {
return resourceIdentifier;
}
public long getTimestamp() {
return timestamp;
}
@Override
public String toString() {
return EVENT_NAME + "{" + "action=" + getActionName(action) + ", resourceId=" + resourceIdentifier + ", serverId=" + serverId
+ ", timestamp=" + timestamp + "}";
}
public String getType() {
return TYPE_INFO;
}
public String getActionName() {
return getActionName(action);
}
protected static synchronized void registerAction(String name, int i) {
String lowerCaseName = name.toLowerCase();
Integer id = new Integer(i);
if (actionNameToId.containsKey(lowerCaseName)) {
throw new IllegalStateException("Action " + name + " already registered");
}
if (actionIdToName.containsKey(id)) {
throw new IllegalStateException("Action id " + i + " already registered");
}
actionIdToName.put(id, lowerCaseName);
actionNameToId.put(lowerCaseName, id);
}
public static String getActionName(int action) {
if (action == NO_ACTION_ID) {
return NO_ACTION_NAME;
}
Integer key = new Integer(action);
if (actionIdToName.containsKey(key)) {
return actionIdToName.get(key);
} else {
throw new IllegalArgumentException("No action with id: " + action);
}
}
public static int getActionId(String action) {
String lowerCaseName = action.toLowerCase();
if (actionNameToId.containsKey(lowerCaseName)) {
return actionNameToId.get(lowerCaseName).intValue();
} else {
throw new IllegalArgumentException("No action called: " + action);
}
}
}