[web-devel] RFC: A standardized interface between web servers and
applications or frameworks (ala WSGI)
Sterling Clover
s.clover at gmail.com
Sun Apr 13 22:43:33 EDT 2008
In a sense, the CGIT interface provided by Network.CGI already is a
sort of halfway implementation of what we're discussing, no?
I'd be interested in approaching this from the other way --
specifying exactly what CGIT doesn't provide and therefore what folks
want to see. As far as I can tell, the main issue with CGIT is that
it doesn't handle streaming/resource issues very well.
The main innovation I see provided here is the enumerator interface,
which is a very nice and flexible approach to I/O and provides a way
to handle comet cleanly to boot. Since the application type as
proposed is Env -> IO (Code, Headers, ResponseEnumerator), what we're
really getting is almost an equiv. (modulo enumerators) of unwrapping
CGIT IO CGIResponse with a run function. So what we lose is the
ability for all our nicely named record accessors and functions to be
shared across frameworks -- i.e. the flexibility a monad transformer
*does* provide. So my question is if we can somehow preserve that
with an appropriate typeclass. I'd ideally like to see this
engineered in two parts -- a "cgit-like" typeclass interface that
allows access to the environment but is agnostic as to response type,
so that comet-style and other apps that take special advantage of
enumerators can be built on top of it as well as apps that simply
perform lazy writes; and the lower-level enumerator interface. This
ideally would let the higher-level interface be built over any stack
at all (i.e. STM-based as well, or even a pure stack), while the
lower level interface that calls it is some glue of the given
constant type in the IO monad. This would be of great help to hvac.
There's also the fact that this could be designed ground-up with
greater bytestring use, but that doesn't seem immense to me.
Outside of this, I'm not quite sure what else CGIT lacks. I'm with
Chris Smith's arguments as to the headers question, and it seems to
me that dicts are best done using MVar-style primitives.
I'm a bit at sea as to why the queryString is here just represented
as a bytestring -- is it seriously an issue that some apps may want
to use it other than in the standard parsed way? Is the idea here
that lib functions would fill in and be shared among frameworks? On
the other hand, seperating GET and POST vars is a good idea, and its
a shame that CGIT doesn't allow this. The openness here seems in part
based on the desire to keep different forms of file upload handling
available. However, the work that oleg did with regards to CGI also
seems promising -- i.e., rather than using an enumerator, simply
taking advantage of laziness to unpack the input stream into a lazy
dictionary.
Regards,
S.
On Apr 13, 2008, at 7:59 AM, Johan Tibell wrote:
> Good day hackers,
>
> The Python community have been successful in standardizing an
> interface between web server and applications or frameworks resulting
> in users having more control over their web stack by being able to
> pick frameworks independently from web servers, and vice versa. I
> propose we try to do the same for Haskell. I've written half a draft
> for a Haskell version of Python's PEP 333 [1]. If you're interested in
> taking part in this effort please read through the Python spec first
> (as it is way more complete and you can understand this proposal
> better by reading it, I've skipped some important issues in my first
> draft) and then go read the Haskell spec [2]. I'm particularly
> interesting in feedback regarding:
>
> * Doing in this way won't work as it violates HTTP/CGI spec part X, Y
> and Z (the Python spec takes lots of things from the CGI spec
> including naming and semantics).
> * My server/framework could never provide/be run under this interface.
> * This interface has bad performance by design.
> * Using a different set of data types would work better.
>
> The spec needs to be extended to cover all the corners of HTTP. Some
> parts need to be motivated better. It is easier for me to motivate
> things if people would tell me what parts are badly motivated.
>
> Note: I'm open to a complete rewrite if needed. I'm not wedded to the
> current design and/or wording. In fact parts of the wording is
> borrowed from the Python spec. The parts with bad grammar are all
> mine.
>
> 1. http://www.python.org/dev/peps/pep-0333/
> 2. http://www.haskell.org/haskellwiki/WebApplicationInterface
>
> -- Johan
> _______________________________________________
> web-devel mailing list
> web-devel at haskell.org
> http://www.haskell.org/mailman/listinfo/web-devel
More information about the web-devel
mailing list