1 -- | Lucu is an HTTP daemonic library. It can be embedded in any
2 -- Haskell program and runs in an independent thread.
6 -- [/Full support of HTTP\/1.1/] Lucu supports request pipelining,
7 -- chunked I\/O, ETag comparison and \"100 Continue\".
9 -- [/Performance/] Lucu is carefully designed to gain a good
12 -- [/Affinity for RESTafarians/] Lucu is specifically designed to be
13 -- suitable for RESTful applications.
15 -- [/SSL connections/] Lucu can handle HTTP connections over SSL
18 -- Lucu is not a replacement for Apache or lighttpd. It is intended to
19 -- be used to build an efficient web-based RESTful application. It is
20 -- also intended to be run behind a reverse-proxy so it doesn't have
21 -- the following (otherwise essential) facilities:
23 -- [/Logging/] Lucu doesn't write logs of any requests from any
26 -- [/Client Filtering/] Lucu always accepts any clients. No IP
27 -- filter is implemented.
29 -- [/Bandwidth Limitting/] Lucu doesn't limit bandwidth it consumes.
31 -- [/Protection Against Wicked Clients/] Lucu is somewhat fragile
32 -- against wicked clients. No attacker should be able to cause a
33 -- buffer-overflow but can possibly DoS it.
35 module Network.HTTP.Lucu
40 , module Network.HTTP.Lucu.Config
47 , module Network.HTTP.Lucu.Resource
49 -- ** Things to be used in the Resource monad
74 -- ** Static file handling
75 , module Network.HTTP.Lucu.StaticFile
78 import Network.HTTP.Lucu.Abortion
79 import Network.HTTP.Lucu.Authentication
80 import Network.HTTP.Lucu.Config
81 import Network.HTTP.Lucu.ETag
82 import Network.HTTP.Lucu.Httpd
83 import Network.HTTP.Lucu.MIMEType
84 import Network.HTTP.Lucu.Resource
85 import Network.HTTP.Lucu.Resource.Tree
86 import Network.HTTP.Lucu.Response
87 import Network.HTTP.Lucu.StaticFile