dev-haskell/http-media (gentoo)

Search

Package Information

Description:
This library is intended to be a comprehensive solution to parsing and selecting quality-indexed values in HTTP headers. It is capable of parsing both media types and language parameters from the Accept and Content header families, and can be extended to match against other accept headers as well. Selecting the appropriate header value is achieved by comparing a list of server options against the quality-indexed values supplied by the client. In the following example, the Accept header is parsed and then matched against a list of server options to serve the appropriate media using 'mapAcceptMedia': > getHeader >>= maybe send406Error sendResourceWith . mapAcceptMedia > [ ("text/html", asHtml) > , ("application/json", asJson) > ] Similarly, the Content-Type header can be used to produce a parser for request bodies based on the given content type with 'mapContentMedia': > getContentType >>= maybe send415Error readRequestBodyWith . mapContentMedia > [ ("application/json", parseJson) > , ("text/plain", parseText) > ] The API is agnostic to your choice of server.
Homepage:
https://github.com/zmthy/http-media
License:
MIT

Versions

Version EAPI Keywords Slot
0.8.0.0 8 ~amd64 ~arm64 ~ppc64 ~riscv ~x86 0/0.8.0.0

Metadata

Description

Maintainers

Upstream

Raw Metadata XML
<pkgmetadata>
	<maintainer type="project">
		<email>haskell@gentoo.org</email>
		<name>Gentoo Haskell</name>
	</maintainer>
	<longdescription>
		This library is intended to be a comprehensive solution to parsing and
		selecting quality-indexed values in HTTP headers. It is capable of parsing
		both media types and language parameters from the Accept and Content header
		families, and can be extended to match against other accept headers as well.
		Selecting the appropriate header value is achieved by comparing a list of
		server options against the quality-indexed values supplied by the client.
		
		In the following example, the Accept header is parsed and then matched against
		a list of server options to serve the appropriate media using
		'mapAcceptMedia':
		
		&gt; getHeader &gt;&gt;= maybe send406Error sendResourceWith . mapAcceptMedia
		&gt;     [ ("text/html",        asHtml)
		&gt;     , ("application/json", asJson)
		&gt;     ]
		
		Similarly, the Content-Type header can be used to produce a parser for request
		bodies based on the given content type with 'mapContentMedia':
		
		&gt; getContentType &gt;&gt;= maybe send415Error readRequestBodyWith . mapContentMedia
		&gt;     [ ("application/json", parseJson)
		&gt;     , ("text/plain",       parseText)
		&gt;     ]
		
		The API is agnostic to your choice of server.
	</longdescription>
	<upstream>
		<remote-id type="github">zmthy/http-media</remote-id>
	</upstream>
</pkgmetadata>

Lint Warnings

Manifest

Type File Size Versions
DIST http-media-0.8.0.0.tar.gz 18895 bytes 0.8.0.0
Unmatched Entries
Type File Size