Interface QueryBus

All Superinterfaces:
DescribableComponent, QueryHandlerRegistry<QueryBus>
All Known Implementing Classes:
DistributedQueryBus, InterceptingQueryBus, SimpleQueryBus

public interface QueryBus extends QueryHandlerRegistry<QueryBus>, DescribableComponent
The mechanism that dispatches queries to their appropriate query handler.

Query handlers can subscribe to the query bus to handle queries matching the QualifiedName.

Hence, queries dispatched (through either query(QueryMessage, ProcessingContext), query(QueryMessage, ProcessingContext), and subscriptionQuery(QueryMessage, ProcessingContext, int)) match a subscribed query handler based on "query name".

There may be multiple handlers for each query.

Since:
3.1
Author:
Marc Gathier, Allard Buijze
  • Method Details

    • query

      @Nonnull MessageStream<QueryResponseMessage> query(@Nonnull QueryMessage query, @Nullable ProcessingContext context)
      Dispatch the given query to a QueryHandler subscribed to the given query's query name, returning a MessageStream of responses to the given query.

      The resulting MessageStream will contain 0, 1, or N QueryResponseMessages, depending on the QueryHandler that handled the given query.

      As several QueryHandlers can be registered for the same query name, this method will loop through them (in insert order) until one has a suitable return value. A suitable response is any value or user exception returned from a QueryHandler. When no handlers are available that can answer the given query, the returned MessageStream will have failed with a NoHandlerForQueryException.

      Parameters:
      query - The query to dispatch.
      context - The processing context under which the query is being published (can be null).
      Returns:
      A MessageStream containing either 0, 1, or N QueryResponseMessages.
      Throws:
      NoHandlerForQueryException - When no QueryHandler is registered for the given query's query name.
    • subscriptionQuery

      @Nonnull MessageStream<QueryResponseMessage> subscriptionQuery(@Nonnull QueryMessage query, @Nullable ProcessingContext context, int updateBufferSize)
      Dispatch the given query to a single QueryHandler subscribed to the given query's queryName/initialResponseType/updateResponseType. The result is lazily created and there will be no execution of the query handler before there is a subscription to the initial result. In order not to miss update, the query bus will queue all update which happen after the subscription query is done and once the subscription to the flux is made, these update will be emitted.

      If there is an error during retrieving or consuming initial result, stream for incremental update is NOT interrupted.

      If there is an error during emitting an update, subscription is cancelled causing further emits not reaching the destination.

      If a subscription query with the same query identifier is already registered, the returned MessageStream will be failed with a SubscriptionQueryAlreadyRegisteredException instead of throwing the exception. This allows callers to handle double subscription scenarios gracefully through the stream API.

      Parameters:
      query - The subscription query to dispatch.
      context - The processing context under which the query is being published (can be null).
      updateBufferSize - The size of the buffer which accumulates update.
      Returns:
      query result containing initial result and incremental update, or a failed MessageStream with SubscriptionQueryAlreadyRegisteredException if a subscription with the same query identifier already exists.
    • subscribeToUpdates

      @Nonnull MessageStream<SubscriptionQueryUpdateMessage> subscribeToUpdates(@Nonnull QueryMessage query, int updateBufferSize)
      Subscribes the given query with the given updateBufferSize, and returns the MessageStream that provides the update of the subscription query.

      Can be used directly instead when fine-grained control of update handlers is required. If using the update directly is not mandatory for your use case, we strongly recommend using subscriptionQuery(QueryMessage, ProcessingContext, int) instead.

      Note that the returned MessageStream must be consumed from before the buffer fills up. Once the buffer is full, any attempt to add an update will complete the stream with an exception.

      If a subscription query with the same query identifier is already registered, the returned MessageStream will be failed with a SubscriptionQueryAlreadyRegisteredException instead of throwing the exception.

      Parameters:
      query - The subscription query for which we register an update handler.
      updateBufferSize - The size of the buffer that accumulates update.
      Returns:
      a MessageStream of update for the given subscription query, or a failed MessageStream with SubscriptionQueryAlreadyRegisteredException if a subscription with the same query identifier already exists.
    • emitUpdate

      @Nonnull CompletableFuture<Void> emitUpdate(@Nonnull Predicate<QueryMessage> filter, @Nonnull Supplier<SubscriptionQueryUpdateMessage> updateSupplier, @Nullable ProcessingContext context)
      Emits the outcome of the updateSupplier to subscription queries matching the given queryName and given filter.
      Parameters:
      filter - A predicate filtering on QueryMessages. The updateSupplier will only be sent to subscription queries matching this filter.
      updateSupplier - The update supplier to emit for subscription queries matching the given filter.
      context - The processing context under which the updateSupplier is being emitted (can be null).
      Returns:
      A future completing whenever the updateSupplier has been emitted.
    • completeSubscriptions

      @Nonnull CompletableFuture<Void> completeSubscriptions(@Nonnull Predicate<QueryMessage> filter, @Nullable ProcessingContext context)
      Completes subscription queries matching the given filter.

      To be used whenever there are no subsequent update to emit left.

      Parameters:
      filter - A predicate filtering on QueryMessages. Subscription queries matching this filter will be completed.
      context - The processing context within which to complete subscription queries (can be null).
      Returns:
      A future completing whenever all matching subscription queries have been completed.
    • completeSubscriptionsExceptionally

      @Nonnull CompletableFuture<Void> completeSubscriptionsExceptionally(@Nonnull Predicate<QueryMessage> filter, @Nonnull Throwable cause, @Nullable ProcessingContext context)
      Completes subscription queries matching the given filter exceptionally with the given cause.

      To be used whenever emitting update should be stopped due to some exception.

      Parameters:
      filter - A predicate filtering on QueryMessages. Subscription queries matching this filter will be completed exceptionally.
      cause - the cause of an error
      context - The processing context within which to complete subscription queries exceptionally (can be null).
      Returns:
      A future completing whenever all matching subscription queries have been completed exceptionally.