true
if audit is enabled
*
* @since 3.3
*/
public boolean isAuditEnabled();
/**
* Switch auditing on or off
*
* @param enable true to enable auditing or false to disable
*
* @since 3.4
*/
public void setAuditEnabled(boolean enable);
/**
* Get all registered audit applications, whether active or not.
*
* @return Returns a map of registered audit applications keyed by name
*
* @since 3.4
*/
public Maptrue
if the calling code (data producers)
* should go ahead and generate the data for
* {@link #recordAuditValues(String, Map) recording}.
*
* @since 3.3
*/
public boolean areAuditValuesRequired();
/**
* Delete audit entries for the given application and time range
*
* @param applicationName the name of the application being logged to
* @param fromTime the start time of entries to remove (inclusive and optional)
* @param toTime the end time of entries to remove (exclusive and optional)
* @return Returns the number of entries deleted
*
* @since 3.2
*/
int deleteAuditEntries(String applicationName, Long fromTime, Long toTime);
/**
* Delete a discrete list of audit entries based on ID
*
* @param auditEntryIds the audit entry IDs to delete
* @return Returns the number of entries deleted
*/
int deleteAuditEntries(List* If the enabled * * @param applicationName the name of the application being logged to * @param path the audit path to check or null to assume the * application's root path * * @since 3.2 */ void enableAudit(String applicationName, String path); /** * Disable auditing (if it is not already disabled) for all paths that contain the given path. * The path is the path as originally logged (see {@link #audit(String, String, Map)}) and * not the path that the generated data may contain - although this would be similarly * disabled. *
* If the path is /x/y then any data paths that start with /x/y will be stripped * out before data generators and data recorders are applied. If the path represents * the root path of the application, then auditing for that application is effectively disabled. * * @param applicationName the name of the application being logged to * @param path the audit path to check or null to assume the * application's root path * * @since 3.2 */ void disableAudit(String applicationName, String path); /** * Remove all disabled paths i.e. enable all per-path based auditing. Auditing may still be * disabled globally. This is primarily for test purposes; applications should know which * paths need {@link #enableAudit(String, String) enabling} or * {@link #disableAudit(String, String) disabled}. * * @param applicationName the name of the application * * @since 3.2 */ void resetDisabledPaths(String applicationName); /** * Create an audit entry for the given map of values. The map key is a path - starting with '/' * ({@link AuditApplication#AUDIT_PATH_SEPARATOR}) - relative to the root path provided. *
* The root path and value keys are combined to produce a map of data keyed by full path. This * fully-pathed map is then passed through the * {@link AuditModelRegistry#getAuditPathMapper() audit path mapper}. The result may yield data * destined for several different * {@link AuditModelRegistry#getAuditApplicationByKey(String) audit applications}. depending on * the data extraction and generation defined in the applications, values (or derived values) may * be recorded against several audit entries (one per application represented). * * The return values reflect what was actually persisted and is controlled by the data extractors * defined in the audit configuration. * * A new read-write transaction is started if there are values to write that there is not a viable * transaction present. * * @param rootPath a base path of {@link AuditPath} key entries concatenated with the path separator * '/' ({@link AuditApplication#AUDIT_PATH_SEPARATOR}) * @param values the values to audit mapped by {@link AuditPath} key relative to root path * (may be null) * @return Returns the values that were actually persisted, keyed by their full path. * @throws IllegalStateException if the transaction state could not be determined * * @since 3.2 */ Map