HAppS tutorial2: Difference between revisions
Mightybyte (talk | contribs) No edit summary |
Mightybyte (talk | contribs) No edit summary |
||
Line 27: | Line 27: | ||
Need better explanations here. | Need better explanations here. | ||
Author's Note: Due to my inexperience with Monads, these explanations are probably lacking. Feel free to improve them. | |||
These data types provide the framework for converting a Request into a Result in a structured way. | These data types provide the framework for converting a Request into a Result in a structured way. | ||
Line 33: | Line 35: | ||
<haskell> | <haskell> | ||
newtype WebT m a = WebT { unWebT :: m (Result a) } | newtype WebT m a = WebT { unWebT :: m (Result a) } | ||
</haskell> | |||
A WebT is a computation that generates a result. | |||
====ServerPartT==== | ====ServerPartT==== | ||
Line 40: | Line 43: | ||
<haskell> | <haskell> | ||
newtype ServerPartT m a = ServerPartT { unServerPartT :: Request -> WebT m a } | newtype ServerPartT m a = ServerPartT { unServerPartT :: Request -> WebT m a } | ||
</haskell> | </haskell> | ||
A ServerPartT is a computation that converts a Request into a WebT. | |||
===Basic ServerPart Functions=== | ===Basic ServerPart Functions=== | ||
Line 54: | Line 57: | ||
* multi - run a list of server parts | * multi - run a list of server parts | ||
* method - runs a server part if the request has the specified method | * method - runs a server part if the request has the specified method | ||
* anyRequest - runs a | * withRequest - builds a ServerPartT from a WebT | ||
* anyRequest - runs a ServerPartT no matter what the request was | |||
* withData - | * withData - retrieve data from the input query or the cookies | ||
* withDataFn - | * withDataFn - retrieve data from the input query or the cookies | ||
* applyRequest | * applyRequest | ||
* ok | * ok | ||
Line 92: | Line 95: | ||
====method==== | ====method==== | ||
==== | ====withRequest==== | ||
<haskell> | <haskell> | ||
withRequest :: (Request -> WebT m a) -> ServerPartT m a | |||
</haskell> | </haskell> | ||
Since a ServerPartT is an encapsulation for a function (Request -> WebT), the withRequest function acts as a ServerPartT constructor. | |||
==== | ====anyRequest==== | ||
<haskell> | <haskell> | ||
anyRequest :: Monad m => WebT m a -> ServerPartT m a | |||
anyRequest x = withRequest $ \_ -> x | |||
</haskell> | </haskell> | ||
anyRequest uses withRequest to construct a ServerPartT from the supplied WebT. | |||
===Error Codes=== | ===Error Codes=== |
Revision as of 04:10, 4 February 2008
Most of the stuff on this page refers to HAppS 0.9.1.2 or greater.
This is the most recent development version at the time of this
writing. There is another tutorial for HAppS 0.8.8. Start there to get a background. This page is dedicated to the things that have changed in the newer versions.
Author's Note: This page will be in various states of disrepair for awhile. I'm creating this document as I am learning HAppS, so it may reflect my inaccurate perceptions. Some of the information on this page MAY EVEN BE WRONG. If you know it's wrong, I would be grateful for your help in improving it.
HAppS is a framework for developing Internet services quickly, deploying them easily, scaling them massively, and managing them effortlessly. Web, persistence, mail, DNS and database servers are all built-in so you can focus on app development rather than integrating and babysitting lots of different servers/services (the Haskell type system keeps everything consistent).
Introduction
The basic web server framework in HAppS consists of a call to simpleHTTP that is passed a list of ServerParts that define the available pages. simpleHTTP searches through the ServerParts and returns the response generated by the first matching ServerPart. Typically ServerParts will match based on some part of the request URL.
The ServerPart is the workhorse of defining HAppS actions. The biggest goal of this document is to provide a useful guide to the ServerPart primitives that are available.
Fundamental Data Types
Need better explanations here.
Author's Note: Due to my inexperience with Monads, these explanations are probably lacking. Feel free to improve them.
These data types provide the framework for converting a Request into a Result in a structured way.
WebT
newtype WebT m a = WebT { unWebT :: m (Result a) }
A WebT is a computation that generates a result.
ServerPartT
newtype ServerPartT m a = ServerPartT { unServerPartT :: Request -> WebT m a }
A ServerPartT is a computation that converts a Request into a WebT.
Basic ServerPart Functions
High-level description
Currently, many of these ServerPart primitives are defined in SimpleHTTP.hs and AlternativeHTTP.hs. AlternativeHTTP is being phased in to replace SimpleHTTP, so this section will focus on the definitions from AlternativeHTTP.
* dir - match a directory at the front of the URL * path - another way to match a URL directory * multi - run a list of server parts * method - runs a server part if the request has the specified method * withRequest - builds a ServerPartT from a WebT * anyRequest - runs a ServerPartT no matter what the request was * withData - retrieve data from the input query or the cookies * withDataFn - retrieve data from the input query or the cookies * applyRequest * ok * toResponse * fileServe - a generic file server that returns files from the local file system as responses
dir
dir :: Monad m => String -> [ServerPartT m a] -> ServerPartT m a
The first argument is matched to the first directory element in the path URL. If it matches, then the ServerParts in the second argument are run.
path
path :: (FromReqURI a, Monad m) => (a -> [ServerPartT m r]) -> ServerPartT m r
Similar to dir except instead of passing a String and a list of ServerParts, you pass a function that returns a list of ServerParts.
FromReqURI is a type class that facilitates the conversion of data in the URI to Haskell types. The basic types are are already members of the class.
multi
multi :: Monad m => [ServerPartT m a] -> ServerPartT m a
Returns a ServerPart that runs the list of ServerParts supplied in the first argument.
method
withRequest
withRequest :: (Request -> WebT m a) -> ServerPartT m a
Since a ServerPartT is an encapsulation for a function (Request -> WebT), the withRequest function acts as a ServerPartT constructor.
anyRequest
anyRequest :: Monad m => WebT m a -> ServerPartT m a
anyRequest x = withRequest $ \_ -> x
anyRequest uses withRequest to construct a ServerPartT from the supplied WebT.
Error Codes
* badRequest * unauthorizied * notFound * seeOther * found * movedPermanently * tempRedirect