Class TransactionIdInboundFilter

  • All Implemented Interfaces:
    Filter

    public class TransactionIdInboundFilter
    extends Object
    implements Filter
    This filter is responsible to create the TransactionIdContext in the context's chain. If the incoming request contains the header "X-ForgeRock-TransactionId" then it uses that value as the transaction id otherwise a new one is generated.
    • Field Detail

      • SYSPROP_TRUST_TRANSACTION_HEADER

        public static final String SYSPROP_TRUST_TRANSACTION_HEADER
        The system property to allow to trust the HTTP header X-ForgeRock-TransactionId.
        See Also:
        Constant Field Values
    • Constructor Detail

      • TransactionIdInboundFilter

        public TransactionIdInboundFilter​(boolean trustTransactionIdHeader)
        Constructor that defines whether or not HTTP request transaction ID headers should be trusted.
        Parameters:
        trustTransactionIdHeader - true to trust HTTP request transaction ID headers and false otherwise
      • TransactionIdInboundFilter

        public TransactionIdInboundFilter​(BooleanSupplier trustTransactionIdHeader)
        Constructor that defines whether or not HTTP request transaction ID headers should be trusted.
        Parameters:
        trustTransactionIdHeader - returns true to trust HTTP request transaction ID headers and false otherwise
    • Method Detail

      • filter

        public Promise<Response,​NeverThrowsException> filter​(Context context,
                                                                   Request request,
                                                                   Handler next)
        Description copied from interface: Filter
        Filters the request and/or response of an exchange. To pass the request to the next filter or handler in the chain, the filter calls next.handle(context, request).

        This method may elect not to pass the request to the next filter or handler, and instead handle the request itself. It can achieve this by merely avoiding a call to next.handle(context, request) and creating its own response object. The filter is also at liberty to replace a response with another of its own by intercepting the response returned by the next handler.

        Specified by:
        filter in interface Filter
        Parameters:
        context - The request context.
        request - The request.
        next - The next filter or handler in the chain to handle the request.
        Returns:
        A Promise representing the response to be returned to the client.