[Haskell-cafe] Re: RFC: A standardized interface between web
servers and applications or frameworks (ala WSGI)
Michaeljohn Clement
mj at mjclement.com
Sun Apr 13 23:50:48 EDT 2008
Adam Langley wrote:
> On Sun, Apr 13, 2008 at 4:59 AM, Johan Tibell <johan.tibell at gmail.com> wrote:
>> * Using a different set of data types would work better.
>
> Give that this is Haskell, I'd suggest more types ;)
>
> HTTP headers aren't just strings and, at the risk of tooting my own
> horn, I'll point to the Headers structure in [1].
That is one of the things I don't like about Network.HTTP, which also
enumerates header fields. It is inconvenient to have to look up the
names in the data type, when the standard field names are already known,
and it makes using non-RFC2616 headers less convenient.
Automatic parsing of header fields also makes unusual usage inconvenient,
(for example the Range header support in [1] is a profile of RFC2616.)
I think those kinds of features belong in frameworks; they will be more
of an annoyance than a help to anyone that is writing to the WSGI layer.
> Likewise, URLs have
> lots of structure that should just be handled in one place [2]
Yes, I think should be parsed to the level of granularity specified by
RFC 2616 (i.e. scheme, host, port, path, query string) and anything
more (like parsing query strings) should be handled by frameworks.
>
> [1] http://darcs.imperialviolet.org/darcsweb.cgi?r=network-minihttp;a=headblob;f=/Network/MiniHTTP/Marshal.hs
> [2] http://darcs.imperialviolet.org/darcsweb.cgi?r=network-minihttp;a=headblob;f=/Network/MiniHTTP/URL.hs
>
>
> AGL
>
--
Michaeljohn Clement
More information about the Haskell-Cafe
mailing list