úÎ4Œ2.      Safe-Inferred  !"#$ !"#$  !"#$None3M(How to set the X-Real-IP request header. Since 0.2.0;Set it from either X-Real-IP or X-Forwarded-For, if present!Set it from the socket's address.Do not set the header>Set the X-Real-IP request header with the client's IP address.Default: SIHFromSocket Since 0.2.0 6Post-process the response body returned from the host. Since 0.2.1 ÂDetermine if the request should be upgraded to a raw proxy connection, as is needed for WebSockets. Requires WAI 2.1 or higher and a WAI handler with raw response support (e.g., Warp) to work.2Default: check if the upgrade header is websocket. Since 0.3.1 5The different responses that could be generated by a  waiProxyTo lookup function. Since 0.2.0 'Respond with the given WAI Application. Since 0.4.0 ÑSend to the given destination, but use the given modified Request for computing the reverse-proxied request. This can be useful for reverse proxying to a different path than the one specified. By the user. Since 0.2.0Send to the given destination. Since 0.2.0$Respond with the given WAI Response. Since 0.2.00Host/port combination to which we want to proxy.BSet up a reverse proxy server, which will have a minimal overhead._This function uses raw sockets, parsing as little of the request as possible. The workflow is:  Parse the first request headers.:Ask the supplied function to specify how to reverse proxy.,Open up a connection to the given host/port.)Pass all bytes across the wire unchanged.IIf you need more control, such as modifying the request or response, use .QSends a simple 502 bad gateway error message with the contents of the exception.Creates a WAI %# which will handle reverse proxies.ÿ"Connections to the proxied server will be provided via http-conduit. As such, all requests and responses will be fully processed in your reverse proxy. This allows you much more control over the data sent over the wire, but also incurs overhead. For a lower-overhead approach, consider .sMost likely, the given application should be run with Warp, though in theory other WAI handlers will work as well.ìNote: This function will use chunked request bodies for communicating with the proxied server. Not all servers necessarily support chunked request bodies, so please confirm that yours does (Warp, Snap, and Happstack, for example, do).&ëGet the HTTP headers for the first request on the stream, returning on consumed bytes as leftovers. Has built-in limits on how many bytes it will consume (specifically, will not ask for another chunked after it receives 1000 bytes).' How to reverse proxy. A Left result will run the given  , whereas a Right, will reverse proxy to the given host/port.How to reverse proxy. A Left8 result will be sent verbatim as the response, whereas Right will cause a reverse proxy.WHow to handle exceptions when calling remote server. For a simple 502 error page, use .connection manager to utilize()*+&,-     '  ()*+&,-.      !"#$%&'()*+,- ./01234http-reverse-proxy-0.4.1.2Network.HTTP.ReverseProxyPaths_http_reverse_proxyDCN Applicationdata-default-class-0.0.1Data.Default.Classdef SetIpHeader SIHFromHeader SIHFromSocketSIHNoneWaiProxySettingswpsOnExc wpsTimeoutwpsSetIpHeaderwpsProcessBodywpsUpgradeToRawWaiProxyResponseWPRApplicationWPRModifiedRequest WPRProxyDest WPRResponse ProxyDestpdHostpdPort rawProxyTo defaultOnExc waiProxyTowaiProxyToSettingscatchIOversionbindirlibdirdatadir libexecdir sysconfdir getBinDir getLibDir getDataDir getLibexecDir getSysconfDirgetDataFileName wai-3.0.2 Network.Wai getHeaders renderHeaders tryWebSocketsstrippedHeaders fixReqHeadersbodyReaderSource$fDefaultWaiProxySettings