Spock ===== [![Build Status](https://travis-ci.org/agrafix/Spock.svg)](https://travis-ci.org/agrafix/Spock) [![Hackage](https://img.shields.io/hackage/v/Spock.svg)](http://hackage.haskell.org/package/Spock) ## Intro Hackage: [Spock](http://hackage.haskell.org/package/Spock) Stackage: [Spock](https://www.stackage.org/package/Spock) Another Haskell web framework for rapid development ## Library Usage Example ```haskell {-# LANGUAGE OverloadedStrings #-} import Web.Spock import qualified Data.Text as T main = runSpock 3000 $ spockT id $ do get ("echo" var) $ \something -> text $ T.concat ["Echo: ", something] ``` For more examples check the examples/ directory. ## Install * Using cabal: `cabal install Spock` * Using Stack: `stack install Spock` * From Source (cabal): `git clone https://github.com/agrafix/Spock.git && cd Spock && cabal install` * From Source (stack): `git clone https://github.com/agrafix/Spock.git && cd Spock && stack build` ## Features Another Haskell web framework for rapid development: This toolbox provides everything you need to get a quick start into web hacking with haskell: * fast routing (both typesafe and "untyped") * middleware * json * sessions * cookies * database helper * csrf-protection * typesafe contexts Benchmarks: * https://github.com/philopon/apiary-benchmark * https://github.com/agrafix/Spock-scotty-benchmark ## Important Links * [Tutorial](https://www.spock.li/tutorial/) * [Type-safe routing in Spock](https://www.spock.li/2015/04/19/type-safe_routing.html) ### Talks * German: [Moderne typsichere Web-Entwicklung mit Haskell](https://dl.dropboxusercontent.com/u/15078797/talks/typesafe-webdev-2015.pdf) (by Alexander Thiemann) * German: [reroute-talk](https://github.com/timjb/reroute-talk) (by Tim Baumann) ## Candy ### Extensions The following Spock extensions exist: * Background workers for Spock: [Spock-worker](http://hackage.haskell.org/package/Spock-worker) * Digestive functors for Spock: [Spock-digestive](http://hackage.haskell.org/package/Spock-digestive) ### Works well with Spock * User management [users](http://hackage.haskell.org/package/users) * Data validation [validate-input](http://hackage.haskell.org/package/validate-input) * Blaze bootstrap helpers [blaze-bootstrap](http://hackage.haskell.org/package/blaze-bootstrap) * digestive-forms bootstrap helpers [digestive-bootstrap](http://hackage.haskell.org/package/digestive-bootstrap) ## Example Projects * [funblog](https://github.com/agrafix/funblog) * [makeci](https://github.com/openbrainsrc/makeci) * [curry-recipes](https://github.com/timjb/reroute-talk/tree/06574561918b50c1809f1e24ec7faeff731fddcf/curry-recipes) ## Companies / Projects using Spock * http://cp-med.com * http://openbrain.co.uk * http://findmelike.com * https://www.tramcloud.net * http://thitp.de ## Notes Since version 0.7.0.0 Spock supports typesafe routing. If you wish to continue using the untyped version of Spock you can Use `Web.Spock.Simple`. The implementation of the routing is implemented in a separate haskell package called `reroute`. Since version 0.5.0.0 Spock is no longer built on top of scotty. The design and interface is still influenced by scotty, but the internal implementation differs from scotty's. ## Thanks to * Tim Baumann [Github](https://github.com/timjb) (lot's of help with typesafe routing) * Tom Nielsen [Github](https://github.com/glutamate) (much feedback and small improvements) ## Misc ### Supported GHC Versions * 7.6.3 * 7.8.4 * 7.10.2 ### License Released under the BSD3 license. (c) 2013 - 2015 Alexander Thiemann