h*~"      !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~3.4.2" Safe-Inferred warp"The type of the Date header value.warp Creating  DateCache and executing the action. Safe-Inferred\warp is used for cache of file information. Hash values of file pathes are used as outer keys. Because negative entries are also contained, a bad guy can intentionally cause the hash collison. So, < is used internally to prevent the hash collision attack. Safe-Inferred Safe-Inferred%&warpFile information. warpModification time warp#Modification time in the GMT formatwarp7Getting the file information corresponding to the file.warpCreating a file information cache and executing the action in the second argument. The first argument is a cache duration in second.  Safe-Inferred 0  Safe-Inferred warp is used as a cache of file descriptors. Since multiple threads could open file descriptors for the same file simultaneously, there could be multiple entries for one file. Since hash values of file paths are used as outer keys, collison would happen for multiple file paths. Because only positive entries are stored, Malicious attack cannot cause the inner list to blow up. So, lists are good enough.warpO(1)warpO(1)warpO(1)warp.O(M) where M is the number of entries per filewarpO(log n)warpO(n)warpO(n)   Safe-Inferred warpMutable Fd cacher.warp'An action to activate a Fd cache entry.warp Creating  and executing the action in the second argument. The first argument is a cache duration in second.warpGetting  and  from the mutable Fd cacher.  Safe-Inferred" warppackStatus H.status200"200""packStatus H.preconditionFailed412"412"  Safe-Inferred" warp/Will 'takeWhile isDigit' and return the parsed .  Safe-Inferred"> Safe-Inferred"7gwarp3What kind of transport is used for this connection?warpPlain channel: TCPwarpThe result of Application Layer Protocol Negociation in RFC 7301warpEncrypted channel: TLS or SSL!warpType for input streaming.(warpData type to manipulate IO actions for connections. This is used to abstract IO actions for plain HTTP and HTTP over TLS.*warp This is not used at this moment.+warpThe sending function.,warp+The sending function for files in HTTP/1.1.-warpThe connection closing function. Warp guarantees it will only be called once. Other functions (like .) may be called after - is called..warpThe connection receiving function. This returns "" for EOF or exceptions./warp Obsoleted.0warp6Reference to a write buffer. When during sending of a Builder% response it's detected the current 4 is too small it will be freed and a new bigger buffer will be created and written to this reference.1warpIs this connection HTTP/2?4warpA write buffer of a specified size containing bytes and a way to free the buffer.7warpThe size of the write buffer.8warpFree the allocated buffer. Warp guarantees it will only be called once, and no other functions will be called after it.9warp1fileid, offset, length, hook action, HTTP headers Since: 3.1.0:warpData type to abstract file identifiers. On Unix, a file descriptor would be specified to make use of the file descriptor cache. Since: 3.1.0warpException thrown if something goes wrong while in the midst of sending a response, since the status code can't be altered at that point.Used to determine whether keeping the HTTP1.1 connection / HTTP2 stream alive is safe or irrecoverable.>warpError types for bad Request.Fwarp Since 3.3.22Gwarp Since 3.3.22Hwarp$The type for header value used with  HeaderName.IwarpTCP port number.warp+Read from a Source, ignoring any leftovers. !"%$&'#(210/.-,+*)3486759:=<;>GFEDCBA@?HI Safe-Inferredwarp!parseRequestLine "GET / HTTP/1.1"("GET","/","",HTTP/1.1)8parseRequestLine "POST /cgi/search.cgi?key=foo HTTP/1.0".("POST","/cgi/search.cgi","?key=foo",HTTP/1.0)parseRequestLine "GET ":*** Exception: Warp: Invalid first line of request: "GET "+parseRequestLine "GET /NotHTTP UNKNOWN/1.1">*** Exception: Warp: Request line specified a non-HTTP request!parseRequestLine "PRI * HTTP/2.0"("PRI","*","",HTTP/2.0)warpparseHeader "Content-Length:47"("Content-Length","47")"parseHeader "Accept-Ranges: bytes"("Accept-Ranges","bytes")%parseHeader "Host: example.com:8080"("Host","example.com:8080")parseHeader "NoSemiColon"("NoSemiColon","") Safe-Inferred"/Jwarp Array for a set of HTTP headers.Kwarp The size for J4 for HTTP Request. From 0 to this corresponds to: "Content-Length""Transfer-Encoding""Expect" "Connection""Range""Host""If-Modified-Since""If-Unmodified-Since" "If-Range" "Referer" "User-Agent" "If-Match""If-None-Match"warp The size for J for HTTP Response.JK Safe-Inferred"'warp contentRangeHeader beg end total constructs a Content-Range  for the range specified.warp2addContentHeadersForFilePart [] (FilePart 2 10 16)[("Content-Range","bytes 2-11/16"),("Content-Length","10"),("Accept-Ranges","bytes")]2addContentHeadersForFilePart [] (FilePart 0 16 16)3[("Content-Length","16"),("Accept-Ranges","bytes")]warpResponsewarpRequest Safe-Inferred" LwarpHTTP/2 push promise or sever push. This allows files only for backward-compatibility while the HTTP/2 library supports other types. Since: 3.2.7MwarpAccessor for a URL path in L. E.g. "/style/default.css". Since: 3.2.7Nwarp Accessor for  in L". E.g. "FILE_PATH/default.css". Since: 3.2.7Owarp Accessor for  in L; "content-type" must be specified. Default value: []. Since: 3.2.7Pwarp Accessor for  in L. Default value: 16. Since: 3.2.7QwarpHTTP/2 specific data. Since: 3.2.7Rwarp Accessor for L in Q. Since: 3.2.7Swarp Accessor for  in Q.*Since: 3.2.8 but the type changed in 3.3.0TwarpDefault HTTP/2 specific data. Since: 3.2.7UwarpDefault push promise. Since: 3.2.7 LPONMQSRTU Safe-Inferred"nwarp Contains a Source. and a byte count that is still to be read in.warp Given an IsolatedBSSource provide a Source that only allows up to the specified number of bytes to be passed downstream. All leftovers should be retained within the Source5. If there are not enough bytes available, throws a ConnectionClosedByPeer exception. Safe-Inferred#zVwarp5Allocate a buffer of the given size and wrap it in a 4' containing that size and a finalizer.Wwarp"Allocating a buffer with malloc().XwarpReleasing a buffer with free().VWX Safe-Inferred%$YwarpFunction to send a file based on sendfile() for Linux/Mac/FreeBSD. This makes use of the file descriptor cache. For other OSes, this is identical to Z. Since: 3.1.0ZwarpFunction to send a file based on pread()/send() for Unix. This makes use of the file descriptor cache. For Windows, this is emulated by Handle. Since: 3.1.0YZ Safe-Inferred%[warp based on file descriptor cache. Since 3.3.13[ Safe-Inferred% Safe-Inferred%\ Safe-Inferred& Safe-Inferred "(;(]warp$Specify usage of the PROXY protocol.^warpSee setProxyProtocolNone._warpSee setProxyProtocolRequired.`warpSee setProxyProtocolOptional.awarpVarious Warp server settings. This is purposely kept as an abstract data type so that new settings can be added without breaking backwards compatibility. In order to create a a value, use  and the various 'set' functions to modify individual fields. For example: setTimeout 20 defaultSettingscwarp&Port to listen on. Default value: 3000dwarpDefault value: HostIPv4ewarpWhat to do with exceptions thrown by either the application or server. Default: ignore server-generated exceptions (see >9) and print application-generated applications to stderr.fwarpA function to create  when an exception occurs.0Default: 500, text/plain, "Something went wrong" Since 2.0.3gwarp+What to do when a connection is open. When  is returned, the connection is closed immediately. Otherwise, the connection is going on. Default: always returns .hwarp;What to do when a connection is close. Default: do nothing.iwarp+Timeout value in seconds. Default value: 30jwarpUse an existing timeout manager instead of spawning a new one. If used, i is ignored. Default is kwarpCache duration time of file descriptors in seconds. 0 means that the cache mechanism is not used. Default value: 0lwarpCache duration time of file information in seconds. 0 means that the cache mechanism is not used. Default value: 0mwarpCode to run after the listening socket is ready but before entering the main event loop. Useful for signaling to tests that they can start running, or to drop permissions after binding to a restricted port.Default: do nothing. Since 1.3.6nwarp1Code to fork a new thread to accept a connection.This may be useful if you need OS bound threads, or if you wish to develop an alternative threading model. Default:  Since 3.0.4owarp Code to accept a new connection.Useful if you need to provide connected sockets from something other than a standard accept call. Default:  Since 3.3.24pwarp&Perform no parsing on the rawPathInfo.(This is useful for writing HTTP proxies.Default: False Since 2.0.3qwarpAn action to install a handler (e.g. Unix signal handler) to close a listen socket. The first argument is an action to close the listen socket.Default: no action Since 3.0.1rwarp4Default server name if application does not set one. Since 3.0.2swarpSee setMaximumBodyFlush. Since 3.0.3twarp$Specify usage of the PROXY protocol. Since 3.0.5uwarpSize of bytes read to prevent Slowloris protection. Default value: 2048 Since 3.1.2vwarp4Whether to enable HTTP2 ALPN/upgrades. Default: True Since 3.1.7wwarp#A log function. Default: no action. Since 3.1.10xwarp6A HTTP/2 server push log function. Default: no action. Since 3.2.7ywarpAn optional timeout to limit the time (in seconds) waiting for a graceful shutdown of the web server. Since 3.2.8zwarpA timeout to limit the time (in milliseconds) waiting for FIN for HTTP/1.x. 0 means uses immediate close. Default: 0. Since 3.3.5{warpA timeout to limit the time (in milliseconds) waiting for FIN for HTTP/2. 0 means uses immediate close. Default: 2000. Since 3.3.5|warpDetermines the maximum header size that Warp will tolerate when using HTTP/1.x. Since 3.3.8}warp;Specify the header value of Alternative Services (AltSvc:).Default: Nothing Since 3.3.11~warp/Determines the maxium buffer size when sending Builder responses (See ).When sending a builder response warp uses a 16 KiB buffer to write the builder to. When that buffer is too small to fit the builder warp will free it and create a new one that will fit the builder.To protect against allocating too large a buffer warp will error if the builder requires more than this maximum.Default: 1049_000_000 = 1 MiB. Since 3.3.22warpThe default settings for the Warp server. See the individual settings for the default value.warpApply the logic provided by  to determine if an exception should be shown or not. The goal is to hide exceptions which occur under the normal course of the web server running. Since 2.1.3warp.Printing an exception to standard error if  returns . Since: 3.1.0warpSending 400 for bad requests. Sending 500 for internal server errors. Since: 3.1.0 Sending 413 for too large payload. Sending 431 for too large headers. Since 3.2.27warpException handler for the debugging purpose. 500, text/plain, a showed exception.Since: 2.0.3.2warp Similar to forkIOWithUnmask4, but does not set up the default exception handler.Since Warp will always install its own exception handler in forked threads, this provides a minor optimization.&For inspiration of this function, see  rawForkIO in the async package.warp.Standard "accept" call for a listening socket.)]`_^a~}{zyxwvutsrqonmlkjihgfedc|pb Safe-Inferred"7=2warp!first request on this connection?warpReceiving a HTTP request from (% and parsing its header to create .warp Assumes the  is never warpPeer's address.warpWhere HTTP request comes from.warp passed to 3, how many bytes remain to be consumed, if known J of HTTP request for internal use, Body producing action used for flushing the request bodywarp remaining  Safe-Inferred>warpGetting Q< through vault of the request. Warp uses this to receive Q from . Since: 3.2.7warpSetting Q" through vault of the request.  or  should use this. Since: 3.2.7warp Modifying Q" through vault of the request.  or  should use this. Since: 3.2.8 Safe-Inferred?  Safe-Inferred"IwarpSending a HTTP response to ( according to ./Applications/middlewares MUST provide a proper . so that inconsistency does not happen. No header is deleted by this function.Especially, Applications/middlewares MUST provide a proper Content-Type. They MUST NOT provide Content-Length, Content-Range, and Transfer-Encoding because they are inserted, when necessary, regardless they already exist. This function does not insert Content-Encoding. It's middleware's responsibility.The Date and Server header is added if not exist in HTTP response header.%There are three basic APIs to create :  ::  ->  ->  -> #HTTP response body is created from 6. Transfer-Encoding: chunked is used in HTTP/1.1. ::  ->  ->  -> #HTTP response body is created from 6. Transfer-Encoding: chunked is used in HTTP/1.1. :: (  -> ( ->  ()) ->  ()) ->  -> 8No header is added and no Transfer-Encoding: is applied. ::  ->  ->  ->   -> HTTP response body is sent (by sendfile(), if possible) for GET method. HTTP response body is not sent by HEAD method. Content-Length and Content-Range are automatically added into the HTTP response header if necessary. If Content-Length and Content-Range exist in the HTTP response header, they would cause inconsistency. "Accept-Ranges: bytes" is also inserted.Applications are categorized into simple and sophisticated. Sophisticated applications should specify  to  . They should treat the conditional request by themselves. A proper Status (200 or 206) must be provided.#Simple applications should specify  to  . The size of the specified file is obtained by disk access or from the file info cache. If-Modified-Since, If-Unmodified-Since, If-Range and Range are processed. Since a proper status is chosen, Status, is ignored. Last-Modified is inserted.warpUse +2 to send this data while respecting timeout rules.warpThe version of Warp.warp;replaceHeader "Content-Type" "new" [("content-type","old")][("Content-Type","new")]warp HTTP request.warpIndexed header of HTTP request.warp$source from client, for raw responsewarp8HTTP response including status code and response header.warp.Returing True if the connection is persistent. Safe-Inferred"I  Safe-Inferred "%&Jhwarp?Converting WAI application to the server type of http2 library. Since 3.3.11! Safe-Inferred"Kwarpget next chunkwarpmaximum to flushwarp3True == flushed the entire body, False == we didn't" Safe-Inferred"R warp Creating (( for plain HTTP based on a given socket.warpRun an  on the given port. This calls  with .warpRun an  on the port present in the PORT! environment variable. Uses the I/ given when the variable is unset. This calls  with . Since 3.0.9warpRun an  with the given a5. This opens a listen socket on the port defined in a and calls .warpThis installs a shutdown handler for the given socket and calls  with the default connection setup action which handles plain (non-cipher) HTTP. When the listen socket in the second argument is closed, all live connections are gracefully shut down.The supplied socket can be a Unix named socket, which can be used when reverse HTTP proxying into your application.Note that the c will still be passed to  s via the  serverPort record.warpThe connection setup action would be expensive. A good example is initialization of TLS. So, this converts the connection setup action to the connection maker which will be executed after forking a new worker thread. Then this calls  with the connection maker. This allows the expensive computations to be performed in a separate worker thread instead of the main server loop. Since 1.3.5warp6This modifies the connection maker so that it returns  for  (i.e. plain HTTP) then calls .warp"The core run function which takes a, a connection maker and . The connection maker can return a connection of either plain HTTP or HTTP over TLS. Since 2.1.4warp%Running an action with internal info. Since 3.3.11warp3Set flag FileCloseOnExec flag on a socket (on Unix) Copied from: https://github.com/mzero/plush/blob/master/src/Plush/Server/Warp.hs# Safe-Inferred"WwarpRuns the given  on a free port. Passes the port to the given operation and executes it, while the 5 is running. Shuts down the server before returning.warp with given a*. This will ignore the port value set by setPort in a.warpSame as 6 but with different exception handling: If the given  throws an exception,  will re-throw the exception to the calling thread, possibly interrupting the execution of the given operation.+This is handy for running tests against an  over a real network port. When running tests, it's useful to let exceptions thrown by your 0 propagate to the main thread of the test-suite.The exception handling makes this function unsuitable for use in production. Use  instead.warp with given a.warp?Opens a socket on a free port and returns both port and socket.warpLike & but closes the socket before exiting. Safe-InferredWEabp|cdefghijklmnoqrstuvwxyz{}~]^_` ()*+,-./012345768VWX:;<=9YZ"#'&$%HJK !\[abp|cdefghijklmnoqrstuvwxyz{}~]^_` ()*+,-./012345768VWX:;<=9YZ"#'&$%HJK !\[ Safe-Inferred|)warp&Port to listen on. Default value: 3000 Since 2.1.0warp-Interface to bind to. Default value: HostIPv4 Since 2.1.0warpWhat to do with exceptions thrown by either the application or server. Default:  Since 2.1.0warpA function to create a % when an exception occurs. Default: Note that an application can handle its own exceptions without interfering with Warp: myApp :: Application myApp request respond = innerApp `catch` onError where onError = respond . response500 request response500 :: Request -> SomeException -> Response response500 req someEx = responseLBS status500 -- ... Since 2.1.0warp-What to do when a connection is opened. When  is returned, the connection is closed immediately. Otherwise, the connection is going on. Default: always returns . Since 2.1.0warp a settings shutdownAction =  shutdownHandler  where0 shutdownHandler closeSocket = void $ $% $& ($'" $ shutdownAction >> closeSocket)  Note that by default, the graceful shutdown mode lasts indefinitely (see ). If you install a signal handler as above, upon receiving that signal, the custom shutdown action will run and+ all outstanding requests will be handled.:You may instead prefer to do one or both of the following:Only wait a finite amount of time for outstanding requests to complete, using .Only catch one signal, so the second hard-kills the Warp server, using $(.#Default: does not install any code. Since 3.0.1warpDefault server name to be sent as the "Server:" header if an application does not set one. If an empty string is set, the "Server:" header is not sent. This is true even if an application set one. Since 3.0.2warpThe maximum number of bytes to flush from an unconsumed request body.By default, Warp does not flush the request body so that, if a large body is present, the connection is simply terminated instead of wasting time and bandwidth on transmitting it. However, some clients do not deal with that situation well. You can either change this setting to Nothing to flush the entire body in all cases, or in your application ensure that you always consume the entire request body.Default: 8192 bytes. Since 3.0.3warp1Code to fork a new thread to accept a connection.This may be useful if you need OS bound threads, or if you wish to develop an alternative threading model. Default: void . forkIOWithUnmask Since 3.0.4warp Code to accept a new connection.Useful if you need to provide connected sockets from something other than a standard accept call. Default:  Since 3.3.24warpDo not use the PROXY protocol. Since 3.0.5warpRequire PROXY header.This is for cases where a "dumb" TCP/SSL proxy is being used, which cannot add an X-Forwarded-For HTTP header field but has enabled support for the PROXY protocol.See  :http://www.haproxy.org/download/1.5/doc/proxy-protocol.txt and  http://docs.aws.amazon.com/ElasticLoadBalancing/latest/DeveloperGuide/TerminologyandKeyConcepts.html#proxy-protocol.Only the human-readable header format (version 1) is supported. The binary header format (version 2) is not supported. Since 3.0.5warpUse the PROXY header if it exists, but also accept connections without the header. See .WARNING: This is contrary to the PROXY protocol specification and using it can indicate a security problem with your architecture if the web server is directly accessible to the public, since it would allow easy IP address spoofing. However, it can be useful in some cases, such as if a load balancer health check uses regular HTTP without the PROXY header, but proxied connections do include the PROXY header. Since 3.0.5warpSize in bytes read to prevent Slowloris attacks. Default value: 2048 Since 3.1.2warpDisable HTTP2. Since 3.1.7warpSetting a log function. Since 3.X.Xwarp.Setting a log function for HTTP/2 server push. Since: 3.2.7warp0Set the graceful shutdown timeout. A timeout of  will wait indefinitely, and a number, if provided, will be treated as seconds to wait for requests to finish, before shutting down the server entirely.Graceful shutdown mode is entered when the server socket is closed; see  for an example of how this could be done in response to a UNIX signal. Since 3.2.8warpSet the maximum header size that Warp will tolerate when using HTTP/1.x. Since 3.3.8warp;Setting the header value of Alternative Services (AltSvc:). Since 3.3.11warp(Set the maximum buffer size for sending Builder responses. Since 3.3.22warp'Explicitly pause the slowloris timeout.This is useful for cases where you partially consume a request body. For more information, see *https://github.com/yesodweb/wai/issues/351 Since 3.0.10warp,Getting file information of the target file.This function first uses a stat(2) or similar system call to obtain information of the target file, then registers it into the internal cache. From the next time, the information is obtained from the cache. This reduces the overhead to call the system call. The internal cache is refreshed every duration specified by .This function throws an  exception if the information is not available. For instance, the target file does not exist. If this function is used an a Request generated by a WAI backend besides Warp, it also throws an  exception. Since 3.1.10warpA timeout to limit the time (in milliseconds) waiting for FIN for HTTP/1.x. 0 means uses immediate close. Default: 0. Since 3.3.5warpA timeout to limit the time (in milliseconds) waiting for FIN for HTTP/1.x. 0 means uses immediate close. Since 3.3.5warpA timeout to limit the time (in milliseconds) waiting for FIN for HTTP/2. 0 means uses immediate close. Default: 2000. Since 3.3.5warpA timeout to limit the time (in milliseconds) waiting for FIN for HTTP/2. 0 means uses immediate close. Since 3.3.5warp*Getting information of client certificate. Since 3.3.5warp request, status, maybe file-sizewarprequest, path, file-sizeaI>?@ABCDEFG QRSTLMNOPUaI>?@ABCDEFG QRSTLMNOPU)*+,-.,-/,-0,1234567889:;<=> ? @ A B CDEFGHIJKLMNOPQQRSTUVVWXYZ[\]^_`aabcdeffghijklmnopqrstuvwxyz{|}~ """""""""""#####U)))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))           T   )  P)w| !!"""# warp-3.4.2-XBZaujUBYZBr8JefiYOV6!Network.Wai.Handler.Warp.InternalNetwork.Wai.Handler.WarpwarpNetwork.Wai.Handler.Warp.Date Network.Wai.Handler.Warp.HashMap Network.Wai.Handler.Warp.Imports&Network.Wai.Handler.Warp.FileInfoCache Network.Wai.Handler.Warp.Counter!Network.Wai.Handler.Warp.MultiMap Network.Wai.Handler.Warp.FdCache Network.Wai.Handler.Warp.PackInt Network.Wai.Handler.Warp.ReadInt'Network.Wai.Handler.Warp.ResponseHeaderNetwork.Wai.Handler.Warp.Types&Network.Wai.Handler.Warp.RequestHeaderNetwork.Wai.Handler.Warp.HeaderNetwork.Wai.Handler.Warp.File$Network.Wai.Handler.Warp.HTTP2.Types Network.Wai.Handler.Warp.ConduitNetwork.Wai.Handler.Warp.Buffer!Network.Wai.Handler.Warp.SendFile#Network.Wai.Handler.Warp.HTTP2.FileNetwork.Wai.Handler.Warp.IO Network.Wai.Handler.Warp.Windows Paths_warp!Network.Wai.Handler.Warp.Settings Network.Wai.Handler.Warp.Request&Network.Wai.Handler.Warp.HTTP2.Request*Network.Wai.Handler.Warp.HTTP2.PushPromise!Network.Wai.Handler.Warp.Response'Network.Wai.Handler.Warp.HTTP2.ResponseNetwork.Wai.Handler.Warp.HTTP2Network.Wai.Handler.Warp.HTTP1Network.Wai.Handler.Warp.Run(Network.Wai.Handler.Warp.WithApplicationSystem.Posix.SignalsinstallHandlersigTERMCatch CatchOncebaseSystem.Posix.TypesFd!recv-0.1.0-89Z5IYbyoz02cQ0pLClpJgNetwork.Socket.BufferPool.TypesRecvBufSizeBuffer Network.Socket.BufferPool.Buffercopy0streaming-commons-0.2.2.6-IOF2f0mxn9JIwXoKFj0vr2Data.Streaming.Network.InternalHostPreferenceGMTDate withDateCacheFileInfo fileInfoName fileInfoSize fileInfoTime fileInfoDategetInfowithFileInfoCacheRefresh withFdCacheopenFile closeFilesetFileCloseOnExec TransportTCPTLSQUICtlsMajorVersiontlsMinorVersiontlsNegotiatedProtocol tlsChiperIDtlsClientCertificatequicNegotiatedProtocol quicChiperIDquicClientCertificateSource InternalInfotimeoutManagergetDategetFd getFileInfo Connection connSendMany connSendAll connSendFile connCloseconnRecv connRecvBufconnWriteBuffer connHTTP2connMySockAddrRecvBuf WriteBuffer bufBufferbufSizebufFreeSendFileFileId fileIdPathfileIdFdInvalidRequestNotEnoughLines BadFirstLineNonHttpIncompleteHeadersConnectionClosedByPeerOverLargeHeaderBadProxyHeaderPayloadTooLargeRequestHeaderFieldsTooLarge HeaderValuePort IndexedHeaderrequestMaxIndex PushPromise promisedPath promisedFilepromisedResponseHeaderspromisedWeight HTTP2Datahttp2dataPushPromisehttp2dataTrailersdefaultHTTP2DatadefaultPushPromisecreateWriteBufferallocateBuffer freeBuffersendFile readSendFile pReadMakerwindowsThreadBlockHack ProxyProtocolProxyProtocolNoneProxyProtocolRequiredProxyProtocolOptionalSettings settingsPort settingsHostsettingsOnExceptionsettingsOnExceptionResponsesettingsOnOpensettingsOnClosesettingsTimeoutsettingsManagersettingsFdCacheDurationsettingsFileInfoCacheDurationsettingsBeforeMainLoop settingsForksettingsAcceptsettingsNoParsePathsettingsInstallShutdownHandlersettingsServerNamesettingsMaximumBodyFlushsettingsProxyProtocolsettingsSlowlorisSizesettingsHTTP2EnabledsettingsLoggersettingsServerPushLoggersettingsGracefulShutdownTimeoutsettingsGracefulCloseTimeout1settingsGracefulCloseTimeout2settingsMaxTotalHeaderLengthsettingsAltSvc$settingsMaxBuilderResponseBufferSizedefaultSettingsdefaultShouldDisplayExceptiondefaultOnExceptiondefaultOnExceptionResponseexceptionResponseForDebug FirstRequestSubsequentRequest recvRequest getHTTP2Data setHTTP2DatamodifyHTTP2Data sendResponse warpVersion http2serversocketConnectionrunrunEnv runSettingsrunSettingsSocketrunSettingsConnectionrunSettingsConnectionMaker runSettingsConnectionMakerSecurewithIIserveConnectionsetSocketCloseOnExecwithApplicationwithApplicationSettingstestWithApplicationtestWithApplicationSettings openFreePortsetPortsetHostsetOnExceptionsetOnExceptionResponse setOnOpen setOnClose setTimeout setManagersetFdCacheDurationsetFileInfoCacheDurationsetBeforeMainLoopsetNoParsePathgetPortgetHost getOnOpen getOnClosegetOnExceptiongetGracefulShutdownTimeoutsetInstallShutdownHandler setServerNamesetMaximumBodyFlushsetFork setAcceptsetProxyProtocolNonesetProxyProtocolRequiredsetProxyProtocolOptionalsetSlowlorisSizesetHTTP2Disabled setLoggersetServerPushLoggersetGracefulShutdownTimeoutsetMaxTotalHeaderLength setAltSvcsetMaxBuilderResponseBufferSize pauseTimeoutsetGracefulCloseTimeout1getGracefulCloseTimeout1setGracefulCloseTimeout2getGracefulCloseTimeout2clientCertificateHashMapcontainers-0.6.7Data.Map.InternalMapemptyisEmptyinsertlookupbytestring-0.11.5.2Data.ByteString.Internal.Type ByteStringBSPSGHC.BaseNonEmpty:| Applicative<*>pure*><*liftA2 Alternative<|>somemanyData.Functor.ConstConstgetConstControl.ApplicativeZipList getZipList WrappedArrow WrapArrow unwrapArrow WrappedMonad WrapMonad unwrapMonadFunctor<$fmap<**> Data.Functor<$>liftAliftA3optional Data.FoldableasumMonadreturn>>>>= MonadPlusmzeromplusControl.Monad.Fail MonadFailfailjoinmapM_forM_Data.TraversablemapMsequenceforM Control.MonadforeverliftMguard=<<whenliftM2liftM3liftM4liftM5apvoid sequence_msumfilterM>=><=< mapAndUnzipMzipWithM zipWithM_foldMfoldM_ replicateM replicateM_unless<$!>mfilterGHC.Bits FiniteBits finiteBitSizecountLeadingZeroscountTrailingZerosBits.&..|.xor complementshiftrotatezeroBitsbitsetBitclearBit complementBittestBit bitSizeMaybebitSizeisSignedshiftL unsafeShiftLshiftR unsafeShiftRrotateLrotateRpopCount Data.BitsIffgetIffXorgetXorIorgetIorAndgetAnd bitDefaulttestBitDefaultpopCountDefaulttoIntegralSizedoneBits.^..>>..<<.!>>.!<<.ghc-prim GHC.TypesIntGHC.IntInt8Int16Int32Int64MonoidmconcatmappendmemptyData.Semigroup.InternalAnygetAnySumgetSumProduct getProduct Data.MonoidLastgetLastFirstgetFirstAltgetAltAllgetAllEndoappEndoDualgetDualApgetAp<>OrderingLTEQGT GHC.ClassesOrd>=compare<<=>maxminData.OrdDowngetDownclamp comparingWordGHC.WordWord8Word64Word32Word16 byteSwap16 byteSwap32 byteSwap64 bitReverse8 bitReverse16 bitReverse32 bitReverse64 GHC.MaybeMaybeNothingJust Data.MaybemaybeisJust isNothingfromJust fromMaybe maybeToList listToMaybe catMaybesmapMaybe GHC.FloatFloatingpiexplogsqrt**logBasesincostanasinacosatansinhcoshtanhasinhacoshatanhlog1pexpm1log1pexplog1mexpGHC.Real showSigned showFloat floatToDigitsfromRatGHC.Read lexDigitsNumericreadIntreadBinreadOctreadDecreadHex readFloat readSignedshowInt showEFloat showFFloat showGFloat showFFloatAlt showGFloatAlt showHFloat showIntAtBaseshowHexshowOctshowBinCounter newCounter waitForZeroincreasedecreaseMultiMap singletontoList pruneWithmergeMutableFdCache packStatus packIntegralIntegral readInt64 composeHeaderExceptionInsideResponseBody readSource' getConnHTTP2 setConnHTTP2mkSource readSourceleftoverSourcereadLeftoverSourceisTransportSecureisTransportQUICgetTransportClientCertificateparseRequestLine parseHeaderparseHeaderLinesresponseMaxIndexResponseHeaderIndexResLastModifiedResDate ResServerResContentLengthRequestHeaderIndexReqIfNoneMatch ReqIfMatch ReqUserAgent ReqReferer ReqIfRangeReqIfUnmodifiedSinceReqIfModifiedSinceReqHostReqRange ReqConnection ReqExpectReqTransferEncodingReqContentLengthindexRequestHeaderrequestKeyIndexdefaultIndexRequestHeaderindexResponseHeaderresponseKeyIndextraverseHeadercontentRangeHeader(http-types-0.12.4-9gtavp8KoLGJbmEnFA2HrGNetwork.HTTP.Types.HeaderHeaderaddContentHeadersForFilePartconditionalRequest RspFileInfo WithoutBodyWithBodyparseByteRangesGHC.IOFilePathResponseHeaders"http2-5.3.4-8Kj8hhM7GIuDjzURPvpO1ANetwork.HTTP2.Frame.TypesWeight+http-semantics-0.2.1-7v9kQsunQWBJfAqBU9jD3tNetwork.HTTP.Semantics.Trailer TrailersMakerisHTTP2ISource readISource ChunkState DoneChunkingHaveLenNeedLenNewlineNeedLenCSource mkISource mkCSource readCSource isHexDigittoBuilderBufferbufferIO packHeader positionReadNetwork.HTTP.Semantics.FilePositionReadMaker toBufIOWithversion getBinDir getLibDir getDynLibDir getDataDir getLibexecDirgetDataFileName getSysconfDir wai-3.2.4-2sX8dxxRns55BFVeQtw3cmNetwork.Wai.InternalResponseFalseTrue defaultFork defaultAccept Network.WairesponseBuilderRequestpushData.ByteStringnull Application timeoutBody headerLinespauseTimeoutKeygetFileInfoKeygetClientCertificateKeyNoKeepAliveRequest Middleware toRequestfromPushPromisesfromPushPromiseNetwork.HTTP.Types.StatusStatus Data.ByteString.Builder.InternalBuilderresponseStream StreamingBody responseRawIO responseFileFilePart sendFragment replaceHeadersanitizeHeaderValuehasBody addServer addAltSvc fromResponsehttp2 flushBodyhttp1acceptConnectionforkgracefulShutdown withFreePort)time-manager-0.1.0-HyvXGCGT85QKmlUl8XbpFLSystem.TimeManagerHandleManager TimeoutThread TimeoutActioncancel initialize stopManager killManagerregisterregisterKillThreadticklepauseresume withManager withManager'