Package org.nuxeo.drive.service.impl
Class AuditChangeFinder
java.lang.Object
org.nuxeo.drive.service.impl.AuditChangeFinder
- All Implemented Interfaces:
FileSystemChangeFinder
- Direct Known Subclasses:
SQLAuditChangeFinder
Implementation of
FileSystemChangeFinder using the AuditBackend.- Since:
- 2025.0
- Author:
- Antoine Taillefer
- Implementation Note:
- before 2025.0 this finder only handles SQL audit, now it can work with any implementation
-
Field Summary
Fields -
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptiongetFileSystemChanges(CoreSession session, Set<IdRef> lastActiveRootRefs, SynchronizationRoots activeRoots, Set<String> collectionSyncRootMemberIds, long lowerBound, long upperBound, int limit) Gets the changes in the repository against which the given session is bound for the given synchronization root paths, between the given lower and upper integer bounds and without exceeding the given limit.protected FileSystemItemChangegetFileSystemItemChange(CoreSession session, DocumentRef docRef, LogEntry entry, String expectedFileSystemItemId) longReturns the last available log id in the audit log table (primary key) to be used as the upper bound of the event log id range clause in the change query.voidhandleParameters(Map<String, String> parameters) Handles the parameters contributed through thechangeFindercontribution.queryAuditEntries(CoreSession session, SynchronizationRoots activeRoots, Set<String> collectionSyncRootMemberIds, long lowerBound, long upperBound, int limit) Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, waitMethods inherited from interface org.nuxeo.drive.service.FileSystemChangeFinder
getUpperBound
-
Field Details
-
parameters
-
-
Constructor Details
-
AuditChangeFinder
public AuditChangeFinder()
-
-
Method Details
-
handleParameters
Description copied from interface:FileSystemChangeFinderHandles the parameters contributed through thechangeFindercontribution.- Specified by:
handleParametersin interfaceFileSystemChangeFinder
-
getFileSystemChanges
public List<FileSystemItemChange> getFileSystemChanges(CoreSession session, Set<IdRef> lastActiveRootRefs, SynchronizationRoots activeRoots, Set<String> collectionSyncRootMemberIds, long lowerBound, long upperBound, int limit) Description copied from interface:FileSystemChangeFinderGets the changes in the repository against which the given session is bound for the given synchronization root paths, between the given lower and upper integer bounds and without exceeding the given limit. The change summaries are mapped back to the file system view: the file system items might not always have the same tree layout as the backing documents in the repositories but this is a back-end detail that the client does not have to deal with.- Specified by:
getFileSystemChangesin interfaceFileSystemChangeFinder- Parameters:
session- the session bound to a specific repositorylastActiveRootRefs- docrefs of the roots as reported by the last successful synchronization (can be empty or null)activeRoots- the currently active synchronization rootscollectionSyncRootMemberIds- the collection sync root member idslowerBound- the lower integer bound of the range clause in the change queryupperBound- the upper integer bound of the range clause in the change query. This id is typically obtained by callingFileSystemChangeFinder.getUpperBound()limit- the maximum number of changes to fetch- Returns:
- the list of document changes
-
getUpperBound
public long getUpperBound()Returns the last available log id in the audit log table (primary key) to be used as the upper bound of the event log id range clause in the change query.- Specified by:
getUpperBoundin interfaceFileSystemChangeFinder
-
queryAuditEntries
protected List<LogEntry> queryAuditEntries(CoreSession session, SynchronizationRoots activeRoots, Set<String> collectionSyncRootMemberIds, long lowerBound, long upperBound, int limit) -
getFileSystemItemChange
protected FileSystemItemChange getFileSystemItemChange(CoreSession session, DocumentRef docRef, LogEntry entry, String expectedFileSystemItemId)
-