public class JsonAuditEventHandler extends AuditEventHandlerBase
AuditEventHandler
for persisting raw JSON events to a file.
The file format is a UTF-8 text-file, with one JSON event per line, and each line terminated by a newline character.
Modifier and Type | Field and Description |
---|---|
static String |
FLUSH_FILE_ACTION_NAME
Name of action to force flushing of file-buffer, which is not the same as flushing buffered audit events,
and is primarily used for testing purposes.
|
static String |
ROTATE_FILE_ACTION_NAME
Name of action to force file rotation.
|
eventTopicsMetaData
Constructor and Description |
---|
JsonAuditEventHandler(JsonAuditEventHandlerConfiguration configuration,
EventTopicsMetaData eventTopicsMetaData)
Creates a
JsonAuditEventHandler instances. |
Modifier and Type | Method and Description |
---|---|
Promise<ActionResponse,ResourceException> |
handleAction(Context context,
String topic,
ActionRequest request)
Performs an action.
|
Promise<ResourceResponse,ResourceException> |
publishEvent(Context context,
String topic,
JsonValue event)
Publishes an event to the provided topic.
|
Promise<QueryResponse,ResourceException> |
queryEvents(Context context,
String topic,
QueryRequest query,
QueryResourceHandler handler)
Query some events from the provided topic.
|
Promise<ResourceResponse,ResourceException> |
readEvent(Context context,
String topic,
String resourceId)
Reads an event with the provided resource id from the provided topic.
|
void |
shutdown()
Instruct this object to flush any buffers and close any open file handles or network connections.
|
void |
startup()
Instruct this object that it is safe to initialize file handles and network connections.
|
getHandledTopics, getName, isEnabled
public static final String ROTATE_FILE_ACTION_NAME
public static final String FLUSH_FILE_ACTION_NAME
public JsonAuditEventHandler(JsonAuditEventHandlerConfiguration configuration, EventTopicsMetaData eventTopicsMetaData)
JsonAuditEventHandler
instances.configuration
- ConfigurationeventTopicsMetaData
- Provides meta-data describing the audit event topics this handler may have to handle.public void startup() throws ResourceException
AuditEventHandler
Reconfiguration of the AuditService
and its handlers is achieved by replacing
rather than modifying the existing objects. Therefore, it's essential that the replacements do not perform
any I/O that would interfere with the operation of the objects they are replacing until the old objects are
shutdown. For example, when shutting down an old instance of a file-based AuditEventHandler, the old instance
may need to flush buffers, apply file rotation or retention policies, or even add line or block signatures
as part of tamper evident logging. Any of these operations could be broken if two handler instances are
operating on the same set of files simultaneously.
ResourceException
- if starting the AuditEventHandler failspublic void shutdown() throws ResourceException
AuditEventHandler
ResourceException
- if closing the AuditEventHandler failspublic Promise<ResourceResponse,ResourceException> publishEvent(Context context, String topic, JsonValue event)
AuditEventHandler
context
- The context chain that initiated the event.topic
- The topic where to publish the event.event
- The event to publish.public Promise<ResourceResponse,ResourceException> readEvent(Context context, String topic, String resourceId)
AuditEventHandler
context
- The context chain that initiated the event.topic
- The topic where event is read.resourceId
- The identifier of the event.public Promise<QueryResponse,ResourceException> queryEvents(Context context, String topic, QueryRequest query, QueryResourceHandler handler)
AuditEventHandler
context
- The context chain that initiated the event.topic
- The topic on which query is performed.query
- The request with the query.handler
- The handler to process responses for the query.public Promise<ActionResponse,ResourceException> handleAction(Context context, String topic, ActionRequest request)
AuditEventHandler
handleAction
in interface AuditEventHandler
handleAction
in class AuditEventHandlerBase
context
- The context chain that initiated the event.topic
- The topic on which action is performed.request
- The request with the action.Copyright 2011-2017 ForgeRock AS.