Interface WebRequestGateway
- All Superinterfaces:
HasLocalHandlers, Namespaced<WebRequestGateway>
- All Known Implementing Classes:
DefaultWebRequestGateway
This gateway does not directly execute the request. Instead, it logs the request as a WebRequest message,
which is then picked up by the Fluxzero Runtime's proxy. The proxy only executes the request if the request URL is
absolute (e.g., starts with http:// or https://).
Benefits of this approach include:
- Traceability: All outbound web traffic is traceable through Fluxzero message logs.
- Centralization: Outgoing requests are routed via a centralized proxy, simplifying firewalling and monitoring.
- Proxy-level enhancements: The proxy can apply retries, circuit breakers, filtering, and other behaviors.
This gateway also supports local request handlers, meaning that annotated methods (e.g., @HandleWebRequest) can respond to requests directly
within the application if desired.
- See Also:
-
Field Summary
FieldsModifier and TypeFieldDescriptionstatic final WebRequestSettingsDefault request settings used when none are specified explicitly. -
Method Summary
Modifier and TypeMethodDescriptionvoidclose()Gracefully shuts down the gateway and releases any associated resources.default CompletableFuture<WebResponse> send(WebRequest request) Sends the given web request using default request settings and returns a future that completes with the response.send(WebRequest request, WebRequestSettings settings) Sends the given web request using given request settings and returns a future that completes with the response.sendAndForget(Guarantee guarantee, WebRequest... requests) Sends one or more web requests without waiting for a response.default WebResponsesendAndWait(WebRequest request) Sends the given web request using default request settings and waits for the response synchronously.sendAndWait(WebRequest request, WebRequestSettings settings) Sends the given web request using the specified request settings and waits for the response synchronously.Methods inherited from interface HasLocalHandlers
hasLocalHandlers, registerHandler, registerHandler, setSelfHandlerFilterMethods inherited from interface Namespaced
forDefaultNamespace, forNamespace
-
Field Details
-
defaultSettings
Default request settings used when none are specified explicitly.
-
-
Method Details
-
sendAndForget
Sends one or more web requests without waiting for a response.Use this for fire-and-forget scenarios (e.g., async webhook posts).
- Parameters:
guarantee- indicates whether to wait until the request is sent or storedrequests- the web requests to send- Returns:
- a future that completes once the requests have been sent or stored
-
send
Sends the given web request using default request settings and returns a future that completes with the response.The request must have an absolute URL to be forwarded by the Fluxzero proxy.
- Parameters:
request- the web request to send- Returns:
- a future completed with the
WebResponse
-
send
Sends the given web request using given request settings and returns a future that completes with the response.The request must have an absolute URL to be forwarded by the Fluxzero proxy.
- Parameters:
request- the web request to send- Returns:
- a future completed with the
WebResponse
-
sendAndWait
Sends the given web request using default request settings and waits for the response synchronously.This method blocks the calling thread until the request is completed or times out.
The request must have an absolute URL to be forwarded by the Fluxzero proxy.
- Parameters:
request- the web request to send- Returns:
- the received
WebResponse
-
sendAndWait
Sends the given web request using the specified request settings and waits for the response synchronously.This method blocks the calling thread until the request is completed or times out.
The request must have an absolute URL to be forwarded by the Fluxzero proxy.
- Parameters:
request- the web request to sendsettings- configuration settings for this request (e.g., timeouts, accepted encodings)- Returns:
- the received
WebResponse
-
close
void close()Gracefully shuts down the gateway and releases any associated resources.
-