!_ŷ      !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~'None warp"The type of the Date header value.warp Creating  DateCache and executing the action.None GV      !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~    None None1None"#.warpFile information.warpModification time warp#Modification time in the GMT format warp7Getting 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.  None None\warpO(1) warpO(1)!warpO(1)"warpO(log n)#warpO(log n)$warpO(log n)%warpO(n)&warpO(n) ' !"#$%&( None)warpMutable Fd cacher. warp'An action to activate a Fd cache entry.warp Creating )f and executing the action in the second argument. The first argument is a cache duration in second.*warpGetting  and   from the mutable Fd cacher.  None T+warp.packIntegral (abs n) == C8.pack (show (abs n))Z\(Large n) -> let n' = fromIntegral (abs n :: Int) in packIntegral n' == C8.pack (show n'),warppackStatus H.status200"200""packStatus H.preconditionFailed412"412"+, None+u-warp contentRangeHeader beg end total constructs a Content-Range . for the range specified./warp2addContentHeadersForFilePart [] (FilePart 2 10 16)'[(Token {ix = 20, shouldBeIndexed = True, isPseudo = False, tokenKey = "Content-Range"},"bytes 2-11/16"),(Token {ix = 18, shouldBeIndexed = False, isPseudo = False, tokenKey = "Content-Length"},"10"),(Token {ix = 8, shouldBeIndexed = True, isPseudo = False, tokenKey = "Accept-Ranges"},"bytes")]2addContentHeadersForFilePart [] (FilePart 0 16 16)[(Token {ix = 18, shouldBeIndexed = False, isPseudo = False, tokenKey = "Content-Length"},"16"),(Token {ix = 8, shouldBeIndexed = True, isPseudo = False, tokenKey = "Accept-Ranges"},"bytes")]01234/ NoneF+56Safe28 warpA handle used by warp%An action to be performed on timeout.warpA timeout managerwarp\Creating timeout manager which works every N micro seconds where N is the first argument.warp.Stopping timeout manager with onTimeout fired.warp=Killing timeout manager immediately without firing onTimeout.warpRegistering a timeout action.warp4Registering a timeout action of killing this thread.warp Setting the state to active. % turns active to inactive repeatedly.warp"Setting the state to canceled. 0 eventually removes this without timeout action.warp Setting the state to paused.  does not change the value.warp;Setting the paused state to active. This is an alias to . warp/Call the inner function with a timeout manager. warptimeout in microseconds None2R!warp3What kind of transport is used for this connection?"warpPlain channel: TCP#warpEncrypted channel: TLS or SSL&warp@The result of Application Layer Protocol Negociation in RFC 7301(warpType for input streaming.0warp|Data type to manipulate IO actions for connections. This is used to abstract IO actions for plain HTTP and HTTP over TLS.2warp This is not used at this moment.3warpThe sending function.4warp+The sending function for files in HTTP/1.1.5warpeThe connection closing function. Warp guarantees it will only be called once. Other functions (like 7) may be called after 5 is called.6warpyFree any buffers allocated. Warp guarantees it will only be called once, and no other functions will be called after it.7warp;The connection receiving function. This returns "" for EOF.8warp{The connection receiving function. This tries to fill the buffer. This returns when the buffer is filled or reaches EOF.9warpThe write buffer.:warpThe size of the write buffer.;warpType for the action to receive input data with a buffer. The result boolean indicates whether or not the buffer is fully filled.<warp)Type for the action to receive input data=warpType for buffer size>warpType for buffer7warpType for read buffer pool?warp1fileid, 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.0DwarpError types for bad Request.Lwarp$The type for header value used with  HeaderName.MwarpTCP port number.8warp+Read from a Source, ignoring any leftovers.>!#"'&%$(9)*-,+./:;<=>01:98765432;<=>7?@ACBDKJIHGFELM?@ABCD8EFGNone]Hwarp!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)IwarpparseHeader "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","")JNone>bNwarp Array for a set of HTTP headers.Owarp The size for N for HTTP Request. From 0 to this corresponds to "Content-Length", "Transfer-Encoding", "Expect", "Connection", "Range", "Host", "If-Modified-Since", "If-Unmodified-Since" and "If-Range".Kwarp The size for N for HTTP Response.LMNOPQRSTUVWXYZ[N\O]^_K`aNonehbwarp contentRangeHeader beg end total constructs a Content-Range . for the range specified.cwarp2addContentHeadersForFilePart [] (FilePart 2 10 16)U[("Content-Range","bytes 2-11/16"),("Content-Length","10"),("Accept-Ranges","bytes")]2addContentHeadersForFilePart [] (FilePart 0 16 16)3[("Content-Length","16"),("Accept-Ranges","bytes")]0defgcNonenhwarp Contains a Source. and a byte count that is still to be read in.iwarp 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.jklmnophqristuNoneu.PwarpThe default size of the write buffer: 16384 (2^14 = 1024 * 16). This is the maximum size of TLS record. This is also the maximum size of HTTP/2 frame payload (excluding frame header).Qwarp"Allocating a buffer with malloc().RwarpReleasing a buffer with free().SwarpjCopying the bytestring to the buffer. This function returns the point where the next copy should start. PQRvwxySzNone { TwarpFunction 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 U. Since: 3.1.0UwarpFunction 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.0T{U|None{`}None VwarpThis function returns a receiving function based on two receiving functions. The returned function efficiently manages received data which is initialized by the first argument. The returned function may allocate a byte string with malloc().~VNoneSafe[WSafeNone%QSTXXwarp$Specify usage of the PROXY protocol.YwarpSee setProxyProtocolNone.ZwarpSee setProxyProtocolRequired.[warpSee setProxyProtocolOptional.\warpVarious 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 \ value, use tK and the various 'set' functions to modify individual fields. For example: setTimeout 20 defaultSettings^warp&Port to listen on. Default value: 3000_warpDefault value: HostIPv4`warpxWhat to do with exceptions thrown by either the application or server. Default: ignore server-generated exceptions (see D9) and print application-generated applications to stderr.awarpA function to create  when an exception occurs.0Default: 500, text/plain, "Something went wrong" Since 2.0.3bwarp+What to do when a connection is open. When s is returned, the connection is closed immediately. Otherwise, the connection is going on. Default: always returns .cwarp;What to do when a connection is close. Default: do nothing.dwarp+Timeout value in seconds. Default value: 30ewarpHUse an existing timeout manager instead of spawning a new one. If used, d is ignored. Default is fwarprCache duration time of file descriptors in seconds. 0 means that the cache mechanism is not used. Default value: 0gwarprCache duration time of file information in seconds. 0 means that the cache mechanism is not used. Default value: 0hwarpCode 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.6iwarp1Code to fork a new thread to accept a connection.kThis 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.4jwarp&Perform no parsing on the rawPathInfo.(This is useful for writing HTTP proxies.Default: False Since 2.0.3lwarp4Default server name if application does not set one. Since 3.0.2mwarpSee setMaximumBodyFlush. Since 3.0.3nwarp$Specify usage of the PROXY protocol. Since 3.0.5.owarpGSize of bytes read to prevent Slowloris protection. Default value: 2048 Since 3.1.2.pwarp4Whether to enable HTTP2 ALPN/upgrades. Default: True Since 3.1.7.qwarp#A log function. Default: no action. Since 3.X.X.rwarp6A HTTP/2 server push log function. Default: no action. Since 3.X.X.swarpfAn optional timeout to limit the time (in seconds) waiting for a graceful shutdown of the web server. Since 3.2.8twarp]The default settings for the Warp server. See the individual settings for the default value.uwarpApply the logic provided by v 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.3vwarp.Printing an exception to standard error if u returns . Since: 3.1.0wwarpESending 400 for bad requests. Sending 500 for internal server errors. Since: 3.1.0xwarpTException handler for the debugging purpose. 500, text/plain, a showed exception.Since: 2.0.3.2!X[ZY\]srqponmlkihgfedcba`_^jtuvwxNone2GywarpReceiving a HTTP request from 0% and parsing its header to create .ywarp!first request on this connection?warpPeer's address.warpWhere HTTP request comes from.warp passed to 3, how many bytes remain to be consumed, if known N\ of HTTP request for internal use, Body producing action used for flushing the request bodywarpcontent lengthwarptransfer-encodingwarp remainingyNoneawarpfStarting a thread pool manager. Its action is initially set to 'return ()' and should be set by @. This allows that the action can include the manager itself.None"#$' zwarp"HTTP/2 push promise or sever push. Since: 3.2.7{warpAccessor for a URL path in z. E.g. "/style/default.css". Since: 3.2.7|warp Accessor for  in z". E.g. "FILE_PATH/default.css". Since: 3.2.7}warp Accessor for  in z; "content-type" must be specified. Default value: []. Since: 3.2.7~warp Accessor for  in z. Default value: 16. Since: 3.2.7warpHTTP/2 specific data. Since: 3.2.7warp Accessor for z in . Since: 3.2.7warp"The context for HTTP/2 connection.warpRFC 7540 says "Other frames (from any stream) MUST NOT occur between the HEADERS frame and any CONTINUATION frames that might follow". This field is used to implement this requirement.warpDefault HTTP/2 specific data. Since: 3.2.7warpDefault push promise. Since: 3.2.7nz~}|{NoneЍwarpGetting < through vault of the request. Warp uses this to receive  from . Since: 3.2.7warpSetting " through vault of the request.  or  should use this. Since: 3.2.7warp Modifying " through vault of the request.  or  should use this. Since: 3.2.8 None"#$     !None$s"None$Q#NoneSXwarpSending a HTTP response to 0 according to ./Applications/middlewares MUST provide a proper U. so that inconsistency does not happen. No header is deleted by this function.AEspecially, 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.LThe 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.kApplications are categorized into simple and sophisticated. Sophisticated applications should specify  to  I. 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 infor 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 32 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.$None$QX?warp)The type to store enough information for settingsOnException. warpNIt would nice if responders could return values to workers. Unfortunately, ! is already defined in WAI 2.0. It is not wise to change this type. So, a reference is shared by a responder and its worker. The reference refers a value of this type as a return value. If O, the worker continue to serve requests. Otherwise, the worker get finished."warpThe wai definition is 'type Application = Request -> (Response -> IO ResponseReceived) -> IO ResponseReceived'. This type implements the second argument (Response -> IO ResponseReceived) with extra arguments.#warp6This function is passed to workers. They also pass s from Ms to this function. This function enqueues commands for the HTTP/2 sender."#$%None"#%&NonePQWX warp Creating 0( for plain HTTP based on a given socket.warpRun an  on the given port. This calls  with t.warpRun an  on the port present in the PORT! environment variable. Uses the M/ given when the variable is unset. This calls  with t. Since 3.0.9warpRun an  with the given \5. This opens a listen socket on the port defined in \ and calls .warpAThis 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.tThe supplied socket can be a Unix named socket, which can be used when reverse HTTP proxying into your application.Note that the ^ 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 connection maker and W. The connection maker can return a connection of either plain HTTP or HTTP over TLS. Since 2.1.4warp3Set flag FileCloseOnExec flag on a socket (on Unix) Copied from: Chttps://github.com/mzero/plush/blob/master/src/Plush/Server/Warp.hs&warpget next chunkwarpmaximum to flushwarp3True == flushed the entire body, False == we didn't'()*&+,-'None/]warpRuns the given T 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 \*. This will ignore the port value set by setPort in \.warpSame as 6 but with different exception handling: If the given  throws an exception, q 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.LThe exception handling makes this function unsuitable for use in production. Use  instead.warp with given \.warp?Opens a socket on a free port and returns both port and socket..warpLike & but closes the socket before exiting..None/r  !"#$%&'()*/.+,-0123456789:;<=>?@ABCLNOPQRSTUVWXYZ[\]j^_`abcdefghiklmnopqrsyr\]j^_`abcdefghiklmnopqrsXYZ[!"#$%&'0123456789:<;V>=PQRS@ABC?TU)*/.+,-LNO   (yWNoneQSXY warp&Port to listen on. Default value: 3000 Since 2.1.0warp-Interface to bind to. Default value: HostIPv4 Since 2.1.0warpQWhat to do with exceptions thrown by either the application or server. Default: v Since 2.1.0warpA function to create a % when an exception occurs. Default: wUNote 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 u is returned, the connection is closed immediately. Otherwise, the connection is going on. Default: always returns . Since 2.1.0warp<What to do when a connection is closed. Default: do nothing. Since 2.1.0warp+Timeout value in seconds. Default value: 30 Since 2.1.0warpIUse an existing timeout manager instead of spawning a new one. If used, d is ignored. Since 2.1.0warpaCache duration time of file descriptors in seconds. 0 means that the cache mechanism is not used.The FD cache is an optimization that is useful for servers dealing with static files. However, if files are being modified, it can cause incorrect results in some cases. Therefore, we disable it by default. If you know that your files will be static or you prefer performance to file consistency, it's recommended to turn this on; a reasonable value for those cases is 10. Enabling this cache results in drastic performance improvement for file transfers.#Default value: 0, was previously 10 Since 3.0.13warpaCache duration time of file information in seconds. 0 means that the cache mechanism is not used.The file information cache is an optimization that is useful for servers dealing with static files. However, if files are being modified, it can cause incorrect results in some cases. Therefore, we disable it by default. If you know that your files will be static or you prefer performance to file consistency, it's recommended to turn this on; a reasonable value for those cases is 10. Enabling this cache results in drastic performance improvement for file transfers.Default value: 0warpCode 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 2.1.0warp&Perform no parsing on the rawPathInfo.(This is useful for writing HTTP proxies.Default: False Since 2.1.0warpGet the listening port. Since 2.1.1warpGet the interface to bind to. Since 2.1.1warp%Get the action on opening connection.warp&Get the action on closeing connection.warpGet the exception handler.warp!Get the graceful shutdown timeout Since 3.2.8warp#A code to install shutdown handler.For instance, this code should set up a UNIX signal handler. The handler should call the first argument, which closes the listen socket, at shutdown.Example usage: settings :: IO () -> \ settings shutdownAction =  shutdownHandler t where0 shutdownHandler closeSocket = void $ () (* ((+" $ shutdownAction >> closeSocket)  JNote that by default, the graceful shutdown mode lasts indefinitely (see n). If you install a signal handler as above, upon receiving that signal, the custon shutdown action will run and+ all outstanding requests will be handled.:You may instead prefer to do one or both of the following:QOnly wait a finite amount of time for outstanding requests to complete, using .JOnly 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.2warpEThe 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 Nothingx 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.kThis 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.4warpDo not use the PROXY protocol. Since 3.0.5warpRequire PROXY header.SThis is for cases where a "dumb" TCP/SSL proxy is being used, which cannot add an X-Forwarded-ForC HTTP header field but has enabled support for the PROXY protocol.See  :http://www.haproxy.org/download/1.5/doc/proxy-protocol.txt and  shttp://docs.aws.amazon.com/ElasticLoadBalancing/latest/DeveloperGuide/TerminologyandKeyConcepts.html#proxy-protocol.iOnly the human-readable header format (version 1) is supported. The binary header format (version 2) is not supported. Since 3.0.5warpYUse 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 accessable 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.5warpDSize 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.IGraceful shutdown mode is entered when the server socket is closed; see H for an example of how this could be done in response to a UNIX signal. Since 3.2.8warp'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.PThis 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.10warp request, status, maybe file-sizewarprequest, path, file-sizeM DEFGHIJKM\tuvwxz~}|{M\tvuwxMDEFGHIJK z{|}~/-./01234556789:;< = > ? @ ABBCDEFGHIJKLMNOPQRSTUVWXXYZ[\]^^_`abcdefghijklmmnopqrstuvwxyz{|}~##&&&&&&&&&''''']-------------------------------------                   ------------ -!-"-#-$-%-&-'(-')-*-+-,---. /0-12-13-14-15-67-68-69 /: /; /< /= />-?@-?A-?B-?CDEFDEG-H-IJ-K-L-M-N-O-P-Q-R-S-T-U-V-W-X-Y-Z-[-\-]-^-_-`-ab-'c-'d-'e-fg-fh-fi-fj-fk-fl-fm-fn-fn-fo-pq-pq-pr-s-t-u-v-w-x-y-z-{-|-}-~-----------------------------------------------------------------------------------------------------------------?-?-?---------------------------- - - - -I ------------------ -!-"-#-$-%-&-'-(-)-*-+-,---.-/0-/1-/2-/3-/4-/5-/6-/7-/8-9-:-;-<-=->-?-@-A-B-C-DEE:FOGHIJKLMNOP Q O R S T  U V W X Y \ Z [ \]^_ `]^a b c d e  fghWiijj:klmnopqrstuvwxyz{|}~\`bcde / /E-]^       S !"#$% & ' ( ) * + ,!-"./]01D23456 /789#:#;#<#=#>$?$@A$B$C$D%E&F&G&H&I&J&K&L&M'NO"warp-3.2.26-K1hIolNasPiFe7B01IPUzL!Network.Wai.Handler.Warp.InternalNetwork.Wai.Handler.WarpNetwork.Wai.Handler.Warp.Date Network.Wai.Handler.Warp.Imports Network.Wai.Handler.Warp.HashMap*Network.Wai.Handler.Warp.HTTP2.EncodeFrame&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.HTTP2.File Network.Wai.Handler.Warp.ReadInt Network.Wai.Handler.Warp.TimeoutNetwork.Wai.Handler.Warp.Types&Network.Wai.Handler.Warp.RequestHeaderNetwork.Wai.Handler.Warp.HeaderNetwork.Wai.Handler.Warp.File Network.Wai.Handler.Warp.ConduitNetwork.Wai.Handler.Warp.Buffer!Network.Wai.Handler.Warp.SendFile'Network.Wai.Handler.Warp.ResponseHeaderNetwork.Wai.Handler.Warp.RecvNetwork.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.Manager$Network.Wai.Handler.Warp.HTTP2.Types&Network.Wai.Handler.Warp.HTTP2.Request$Network.Wai.Handler.Warp.HTTP2.HPACK%Network.Wai.Handler.Warp.HTTP2.Sender'Network.Wai.Handler.Warp.HTTP2.Receiver!Network.Wai.Handler.Warp.Response%Network.Wai.Handler.Warp.HTTP2.WorkerNetwork.Wai.Handler.Warp.HTTP2Network.Wai.Handler.Warp.Run(Network.Wai.Handler.Warp.WithApplicationSystem.Posix.SignalsinstallHandlersigTERMCatch CatchOncebaseSystem.Posix.TypesFd0streaming-commons-0.2.1.0-Hj7adYN3taFIGGqYOgmlgUData.Streaming.Network.InternalHostPreferenceGMTDate withDateCacheFileInfo fileInfoName fileInfoSize fileInfoTime fileInfoDateHashgetInfowithFileInfoCacheRefresh withFdCacheopenFile closeFilesetFileCloseOnExec TimeoutThreadHandle TimeoutActionManager initialize stopManager killManagerregisterregisterKillThreadticklecancelpauseresume withManager TransportTCPTLStlsMajorVersiontlsMinorVersiontlsNegotiatedProtocol tlsChiperIDSource InternalInfo threadHandletimeoutManagergetDategetFd getFileInfo Connection connSendMany connSendAll connSendFile connCloseconnFreeconnRecv connRecvBufconnWriteBufferconnBufferSizeRecvBufRecvBufSizeBufferSendFileFileId fileIdPathfileIdFdInvalidRequestNotEnoughLines BadFirstLineNonHttpIncompleteHeadersConnectionClosedByPeerOverLargeHeaderBadProxyHeader HeaderValuePort IndexedHeaderrequestMaxIndex bufferSizeallocateBuffer freeBuffercopysendFile readSendFilemakePlainReceiveNwindowsThreadBlockHack ProxyProtocolProxyProtocolNoneProxyProtocolRequiredProxyProtocolOptionalSettings settingsPort settingsHostsettingsOnExceptionsettingsOnExceptionResponsesettingsOnOpensettingsOnClosesettingsTimeoutsettingsManagersettingsFdCacheDurationsettingsFileInfoCacheDurationsettingsBeforeMainLoop settingsForksettingsNoParsePathsettingsInstallShutdownHandlersettingsServerNamesettingsMaximumBodyFlushsettingsProxyProtocolsettingsSlowlorisSizesettingsHTTP2EnabledsettingsLoggersettingsServerPushLoggersettingsGracefulShutdownTimeoutdefaultSettingsdefaultShouldDisplayExceptiondefaultOnExceptiondefaultOnExceptionResponseexceptionResponseForDebug recvRequest PushPromise promisedPath promisedFilepromisedResponseHeaderspromisedWeight HTTP2Datahttp2dataPushPromisehttp2dataTrailersdefaultHTTP2DatadefaultPushPromise getHTTP2Data setHTTP2DatamodifyHTTP2Data sendResponse warpVersionsocketConnectionrunrunEnv runSettingsrunSettingsSocketrunSettingsConnectionrunSettingsConnectionMaker runSettingsConnectionMakerSecuresetSocketCloseOnExecwithApplicationwithApplicationSettingstestWithApplicationtestWithApplicationSettings openFreePortsetPortsetHostsetOnExceptionsetOnExceptionResponse setOnOpen setOnClose setTimeout setManagersetFdCacheDurationsetFileInfoCacheDurationsetBeforeMainLoopsetNoParsePathgetPortgetHost getOnOpen getOnClosegetOnExceptiongetGracefulShutdownTimeoutsetInstallShutdownHandler setServerNamesetMaximumBodyFlushsetForksetProxyProtocolNonesetProxyProtocolRequiredsetProxyProtocolOptionalsetSlowlorisSizesetHTTP2Disabled setLoggersetServerPushLoggersetGracefulShutdownTimeout pauseTimeoutGHC.Base++GHC.Listfilterzipmap Control.Monadguardjoin GHC.FloatFloatingpiexplogsqrt**logBasesincostanasinacosatansinhcoshtanhasinhacoshatanhlog1pexpm1log1pexplog1mexpMonad>>=>>returnfailFunctorfmap<$ghc-prim GHC.ClassesOrd>=minmax><compare<= Applicative<*>pure*><*liftA2 Data.Foldablefoldrlengthnullfoldlfoldl'foldl1sumproductfoldr1maximumminimumelemData.TraversablemapMsequence<>Monoidmemptymappendmconcat GHC.TypesIntGHC.IntInt8Int16Int32Int64 GHC.MaybeMaybeNothingJustOrderingLTEQGTWordGHC.WordWord8Word16Word32Word64bytestring-0.10.8.2Data.ByteString.Internal ByteStringPS<**> Data.Functor<$> Alternativemanysome<|>empty MonadPlusmzeromplusmfilter<$!>unless replicateM_ replicateMfoldM_foldM zipWithM_zipWithM mapAndUnzipMforever<=<>=>filterM Data.ListisSubsequenceOf mapAccumR mapAccumLforMControl.Applicativeoptional WrappedMonad WrapMonad unwrapMonad WrappedArrow WrapArrow unwrapArrowZipList getZipListData.Functor.ConstConstgetConstfindnotElem minimumBy maximumByallanyorand concatMapconcatmsum sequence_forM_mapM_ Data.MonoidFirstgetFirstLastgetLastApgetApData.Semigroup.InternalDualgetDualEndoappEndoAllgetAllAnygetAnySumgetSumProduct getProductAltgetAlt Data.OldListunwordswordsunlineslinesunfoldrsortOnsortBysort permutations subsequencestailsinitsgroupBygroupdeleteFirstsByunzip7unzip6unzip5unzip4zipWith7zipWith6zipWith5zipWith4zip7zip6zip5zip4genericReplicate genericIndexgenericSplitAt genericDrop genericTake genericLengthinsertByinsert partition transpose intercalate intersperse intersectBy intersectunionByunion\\deleteBydeletenubBynub isInfixOf isSuffixOf isPrefixOf findIndices findIndex elemIndices elemIndex stripPrefix dropWhileEndData.Ord comparingDownNumericshowOctshowHex showIntAtBase showHFloat showGFloatAlt showFFloatAlt showGFloat showFFloat showEFloatshowInt readSigned readFloatreadHexreadDecreadOctreadIntGHC.Read lexDigitsfromRat floatToDigits showFloat byteSwap64 byteSwap32 byteSwap16 Data.BitstoIntegralSizedpopCountDefaulttestBitDefault bitDefaultBits.&..|.xor complementshiftrotatezeroBitsbitsetBitclearBit complementBittestBit bitSizeMaybebitSizeisSignedshiftL unsafeShiftLshiftR unsafeShiftRrotateLrotateRpopCount FiniteBits finiteBitSizecountLeadingZeroscountTrailingZerosvoidGHC.Real showSignedunzip3unzipzipWith3zipWithzip3!!lookupreversebreakspansplitAtdroptake dropWhile takeWhilecycle replicaterepeatiterate'iteratescanr1scanrscanl'scanl1scanlfoldl1'initlasttailunconshead Data.MaybemapMaybe catMaybes listToMaybe maybeToList fromMaybefromJust isNothingisJustmaybeapliftM5liftM4liftM3liftM2liftMwhen=<<liftA3liftANonEmpty:|HashMaphashByteString goawayFrame resetFrame settingsFrame pingFramewindowUpdateFrameCounter newCounter waitForZeroincreasedecreaseisEmpty singletonsearch searchWithtoList pruneWithMMapmergeMutableFdCache packIntegral packStatuscontentRangeHeader(http-types-0.12.2-JKkfxO2E01jGz1Dpb9VxuiNetwork.HTTP.Types.HeaderHeaderaddContentHeadersForFilePartparseByteRanges RspFileInfo WithoutBodyWithBodyconditionalRequest readInt64 BufferPool readSource' InternalInfo1 InternalInfo0timeoutManager0toInternalInfo1 threadHandle1toInternalInfomkSource readSourceleftoverSourcereadLeftoverSourceisTransportSecureparseRequestLine parseHeaderparseHeaderLinesresponseMaxIndexResponseHeaderIndexResDate ResServerResContentLengthRequestHeaderIndex ReqUserAgent ReqReferer ReqIfRangeReqIfUnmodifiedSinceReqIfModifiedSinceReqHostReqRange ReqConnection ReqExpectReqTransferEncodingReqContentLengthindexRequestHeaderrequestKeyIndexdefaultIndexRequestHeaderindexResponseHeaderresponseKeyIndextraverseHeaderISource readISource ChunkState DoneChunkingHaveLenNeedLenNewlineNeedLenCSource mkISource mkCSource readCSource isHexDigit newBufferPoolmallocBSwithBufferPooltoBuilderBufferbufferIO packHeader positionRead composeHeader makeReceiveNspellreceive receiveBuf toBufIOWithversion getBinDir getLibDir getDynLibDir getDataDir getLibexecDir getSysconfDirgetDataFileName"wai-3.2.1.2-Eqkx83L8VUB7gu665gKQzkNetwork.Wai.InternalResponseFalseTrueRequest Network.Wai Application bodyAndSource timeoutBodyNoKeepAliveRequest headerLinespauseTimeoutKeygetFileInfoKeystart setActionstop spawnActionaddMyId deleteMyIdGHC.IOFilePathResponseHeaders"http2-1.6.4-AtVBx4COQTpHd6tzdDze9tNetwork.HTTP2.TypesWeightContext continued StreamTableStreamstreamPrecedence streamWindow streamState streamNumber StreamStateReservedClosed HalfClosedOpenIdle ClosedCode ResetByMeResetKilledFinished OpenStateBodyHasBodyNoBody Continued JustOpenedconnectionWindowdecodeDynamicTableencodeDynamicTablecontrolQoutputQinputQserverStreamIdclientStreamIdpriorityTreeSize concurrency streamTable firstSettings http2settingsSequenceSBuilderSFlushSFinishControl CSettings0 CSettingsCFrameCGoawayCFinish OutputTypeONextOPushOWaitORspnOutput outputType outputH2Data outputHookoutputII outputRspn outputStreamRspnRspnFile RspnBuilder RspnStreaming RspnNobodyNext BytesFilledDynaNextInputhttp2verisHTTP2 rspnStatus rspnHeadersoutputMaybeTBQueue newContext clearContextisIdleisOpen isHalfClosedisClosed newStream newPushStreamopenedclosednewStreamTableremoveupdateAllStreamWindowforkAndEnqueueWhenReady enqueueOutputenqueueControl MiddlewareMkReq mkRequest addHeader fixHeadersdeleteUnnecessaryHeadershpackEncodeHeaderhpackEncodeHeaderLoophpackDecodeHeaderjust frameSender frameReceiverresponseBuilderNetwork.HTTP.Types.StatusStatus Data.ByteString.Builder.InternalBuilderresponseStream StreamingBody responseRawIO responseFileFilePart sendFragment replaceHeadersanitizeHeaderValuehasBody addServer StreamInfoThreadContinueResponseReceived Responderresponseworkerhttp2 flushBodyacceptConnectionforkserveConnectionflushEntireBody wrappedRecv wrappedRecvNgracefulShutdown withFreePort