Package org.apache.solr.security
Class MultiDestinationAuditLogger
- java.lang.Object
-
- org.apache.solr.security.AuditLoggerPlugin
-
- org.apache.solr.security.MultiDestinationAuditLogger
-
- All Implemented Interfaces:
Closeable,AutoCloseable,Runnable,org.apache.lucene.analysis.util.ResourceLoaderAware,SolrInfoBean,SolrMetricProducer
public class MultiDestinationAuditLogger extends AuditLoggerPlugin implements org.apache.lucene.analysis.util.ResourceLoaderAware
Audit logger that chains other loggers. Lets you configure logging to multiple destinations. The config is simply a list of configs for the sub plugins:"class" : "solr.MultiDestinationAuditLogger", "plugins" : [ { "class" : "solr.SolrLogAuditLoggerPlugin" }, { "class" : "solr.MyOtherAuditPlugin"} ]This interface may change in next release and is marked experimental- Since:
- 8.1.0
- WARNING: This API is experimental and might change in incompatible ways in the next release.
-
-
Nested Class Summary
-
Nested classes/interfaces inherited from class org.apache.solr.security.AuditLoggerPlugin
AuditLoggerPlugin.AuditEventFormatter, AuditLoggerPlugin.JSONAuditEventFormatter, AuditLoggerPlugin.MuteRule
-
Nested classes/interfaces inherited from interface org.apache.solr.core.SolrInfoBean
SolrInfoBean.Category, SolrInfoBean.Group
-
-
Field Summary
-
Fields inherited from class org.apache.solr.security.AuditLoggerPlugin
eventTypes, formatter, metricManager, numErrors, numLogged, numLost, queuedTime, registryName, requestTimes, totalTime
-
-
Constructor Summary
Constructors Constructor Description MultiDestinationAuditLogger()
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description voidaudit(AuditEvent event)Passes the AuditEvent to all sub plugins in parallel.voidclose()Waits 30s for async queue to drain, then closes executor threads.voidinform(org.apache.lucene.analysis.util.ResourceLoader loader)voidinit(Map<String,Object> pluginConfig)Initialize the plugin from security.jsonvoidinitializeMetrics(SolrMetricManager manager, String registryName, String tag, String scope)Initializes metrics specific to this producerbooleanshouldLog(AuditEvent.EventType eventType)Checks whether this event type should be logged based on "eventTypes" config parameter.-
Methods inherited from class org.apache.solr.security.AuditLoggerPlugin
auditAsync, doAudit, getCategory, getDescription, getMetricNames, getMetricRegistry, getName, run, setFormatter, shouldMute, waitForQueueToDrain
-
Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
-
Methods inherited from interface org.apache.solr.core.SolrInfoBean
getMetricsSnapshot, registerMetricName
-
-
-
-
Method Detail
-
audit
public void audit(AuditEvent event)
Passes the AuditEvent to all sub plugins in parallel. The event should be aAuditEventto be able to pull context info.- Specified by:
auditin classAuditLoggerPlugin- Parameters:
event- the audit event
-
init
public void init(Map<String,Object> pluginConfig)
Initialize the plugin from security.json- Overrides:
initin classAuditLoggerPlugin- Parameters:
pluginConfig- the config for the plugin
-
shouldLog
public boolean shouldLog(AuditEvent.EventType eventType)
Description copied from class:AuditLoggerPluginChecks whether this event type should be logged based on "eventTypes" config parameter.- Overrides:
shouldLogin classAuditLoggerPlugin- Parameters:
eventType- the event type to consider- Returns:
- true if this event type should be logged
-
inform
public void inform(org.apache.lucene.analysis.util.ResourceLoader loader)
- Specified by:
informin interfaceorg.apache.lucene.analysis.util.ResourceLoaderAware
-
initializeMetrics
public void initializeMetrics(SolrMetricManager manager, String registryName, String tag, String scope)
Description copied from interface:SolrMetricProducerInitializes metrics specific to this producer- Specified by:
initializeMetricsin interfaceSolrMetricProducer- Overrides:
initializeMetricsin classAuditLoggerPlugin- Parameters:
manager- an instance ofSolrMetricManagerregistryName- registry name where metrics are registeredtag- a symbolic tag that represents this instance of the producer, or a group of related instances that have the same life-cycle. This tag is used when managing life-cycle of some metrics and is set whenSolrMetricProducer.initializeMetrics(SolrMetricManager, String, String, String)is called.scope- scope of the metrics (eg. handler name) to separate metrics of
-
close
public void close() throws IOExceptionDescription copied from class:AuditLoggerPluginWaits 30s for async queue to drain, then closes executor threads. Subclasses should either callsuper.close()orAuditLoggerPlugin.waitForQueueToDrain(int)before shutting itself down to make sure they can complete logging events in the queue.- Specified by:
closein interfaceAutoCloseable- Specified by:
closein interfaceCloseable- Overrides:
closein classAuditLoggerPlugin- Throws:
IOException
-
-