Interface SnapshotEventGenerator

    • Method Detail

      • generateSnapshots

        List<Snapshot> generateSnapshots​(Object withIdGreaterThan,
                                         String filter)

        Returns a batch of snapshots of given type (event type is an event channel topic name). The implementation may return an arbitrary amount of results, but it must return at least one element if there are entities matching the parameters.

        Calling this method must have no side effects.

        The library will call your implementation like this:
        • Request: generateSnapshots(null, filter), Response: 1,2,3
        • Request: generateSnapshots(3, filter), Response: 4,5
        • Request: generateSnapshots(5, filter), Response: emptyList

        It is your responsibility to make sure that the returned events are ordered by their ID ascending and that, given you return a list of events for entities with IDs {id1, ..., idN}, there exists no entity with an ID between id1 and idN, that is not part of the result.

        Parameters:
        withIdGreaterThan - if not null, only events for entities with an ID greater than the given one must be returned
        filter - a filter for the snapshot generation mechanism. This value is simply passed through from the request body of the REST endpoint (or from any other triggering mechanism). If there was no request body, this will be null. Implementors can interpret it in whatever way they want (even ignore it). All calls for one snapshot generation will receive the same string.
        Returns:
        list of elements (wrapped in Snapshot objects) ordered by their ID.
      • getSupportedEventType

        String getSupportedEventType()
        The name of the event type supported by this snapshot generator.