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);
    /**
     * @param userAuditFilter UserAuditFilter
     * 
     * @since 4.2
     */
    public void setUserAuditFilter(UserAuditFilter userAuditFilter);
    
    /**
     * 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();
    
    /**
     * Determines if audit values are required based on whether there are any audit applications
     * registered to record data for the given path. This helper method gives data producers a 
     * shortcut in the event that nothing would be recorded in any event.
     * 
     * @param path              the audit path
     * @return                  Returns true if there is at least one audit application
     *                          registered to handle the given path.
     * 
     * @since 3.4                         
     */
    public boolean areAuditValuesRequired(String path);
    
    /**
     * 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 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