/*
* Zed Attack Proxy (ZAP) and its related class files.
*
* ZAP is an HTTP/HTTPS proxy for assessing web application security.
*
* Copyright The ZAP development team
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.zaproxy.zap.extension.alert;
import org.zaproxy.zap.ZAP;
import org.zaproxy.zap.eventBus.EventPublisher;
public class AlertEventPublisher implements EventPublisher {
private static AlertEventPublisher publisher = null;
public static final String ALERT_ADDED_EVENT = "alert.added";
public static final String ALERT_CHANGED_EVENT = "alert.changed";
public static final String ALERT_REMOVED_EVENT = "alert.removed";
public static final String ALL_ALERTS_REMOVED_EVENT = "alert.all.removed";
public static final String ALERT_ID = "alertId";
/**
* Indicates the {@code HistoryReference} ID of the alert.
* <p>
* The field is available in the events {@link #ALERT_ADDED_EVENT}, {@link #ALERT_CHANGED_EVENT} and
* {@link #ALERT_REMOVED_EVENT}.
*
* @since 2.5.0
*/
public static final String HISTORY_REFERENCE_ID = "historyId";
@Override
public String getPublisherName() {
return AlertEventPublisher.class.getCanonicalName();
}
public static synchronized AlertEventPublisher getPublisher() {
if (publisher == null) {
publisher = new AlertEventPublisher();
ZAP.getEventBus().registerPublisher(publisher,
new String[] {ALERT_ADDED_EVENT, ALERT_CHANGED_EVENT, ALERT_REMOVED_EVENT, ALL_ALERTS_REMOVED_EVENT});
}
return publisher;
}
}