servant-jquery: Automatically derive (jquery) javascript functions to query servant webservices

[ bsd3, deprecated, library, web ] [ Propose Tags ] [ Report a vulnerability ]
Deprecated in favor of servant-js

Automatically derive jquery-based javascript functions to query servant webservices.

You can find an example here which serves the generated javascript to a webpage that allows you to trigger webservice calls.

CHANGELOG


[Skip to Readme]

Modules

[Index]

Flags

Manual Flags

NameDescriptionDefault
example

Build the example too

Disabled

Use -f <flag> to enable a flag, or -f -<flag> to disable that flag. More info

Downloads

Maintainer's Corner

Package maintainers

For package maintainers and hackage trustees

Candidates

  • No Candidates
Versions [RSS] 0.2, 0.2.1, 0.2.2, 0.2.2.1, 0.4.0, 0.4.1, 0.4.2, 0.4.3, 0.4.3.1, 0.4.4, 0.4.4.2, 0.4.4.3, 0.4.4.4, 0.4.4.5, 0.4.4.6, 0.4.4.7
Change log CHANGELOG.md
Dependencies aeson, base (>=4.5 && <5), charset, filepath, lens (>=4), servant (>=0.4 && <0.5), servant-jquery (>=0.4 && <0.5), servant-server (>=0.4 && <0.5), stm, text, transformers, warp [details]
License BSD-3-Clause
Copyright 2014 Alp Mestanogullari
Author Alp Mestanogullari
Maintainer alpmestan@gmail.com
Category Web
Home page http://haskell-servant.github.io/
Bug tracker http://github.com/haskell-servant/servant/issues
Source repo head: git clone http://github.com/haskell-servant/servant.git
Uploaded by jkarni at 2015-05-29T14:33:41Z
Distributions
Reverse Dependencies 1 direct, 0 indirect [details]
Executables counter
Downloads 9932 total (42 in the last 30 days)
Rating 2.0 (votes: 1) [estimated by Bayesian average]
Your Rating
  • λ
  • λ
  • λ
Status Docs available [build log]
Last success reported on 2015-05-29 [all 1 reports]

Readme for servant-jquery-0.4.1

[back to package description]

servant-jquery

servant

This library lets you derive automatically (JQuery based) Javascript functions that let you query each endpoint of a servant webservice.

Example

Read more about the following example here.

{-# LANGUAGE DataKinds #-} {-# LANGUAGE TypeOperators #-} {-# LANGUAGE DeriveGeneric #-} {-# LANGUAGE GeneralizedNewtypeDeriving #-} import Control.Concurrent.STM import Control.Monad.IO.Class import Data.Aeson import Data.Proxy import GHC.Generics import Network.Wai.Handler.Warp (run) import Servant import Servant.JQuery import System.FilePath -- * A simple Counter data type newtype Counter = Counter { value :: Int } deriving (Generic, Show, Num) instance ToJSON Counter -- * Shared counter operations -- Creating a counter that starts from 0 newCounter :: IO (TVar Counter) newCounter = newTVarIO 0 -- Increasing the counter by 1 counterPlusOne :: MonadIO m => TVar Counter -> m Counter counterPlusOne counter = liftIO . atomically $ do oldValue <- readTVar counter let newValue = oldValue + 1 writeTVar counter newValue return newValue currentValue :: MonadIO m => TVar Counter -> m Counter currentValue counter = liftIO $ readTVarIO counter -- * Our API type type TestApi = "counter" :> Post Counter -- endpoint for increasing the counter :<|> "counter" :> Get Counter -- endpoint to get the current value :<|> Raw -- used for serving static files testApi :: Proxy TestApi testApi = Proxy -- * Server-side handler -- where our static files reside www :: FilePath www = "examples/www" -- defining handlers server :: TVar Counter -> Server TestApi server counter = counterPlusOne counter -- (+1) on the TVar :<|> currentValue counter -- read the TVar :<|> serveDirectory www -- serve static files runServer :: TVar Counter -- ^ shared variable for the counter -> Int -- ^ port the server should listen on -> IO () runServer var port = run port (serve testApi $ server var) -- * Generating the JQuery code incCounterJS :<|> currentValueJS :<|> _ = jquery testApi writeJS :: FilePath -> [AjaxReq] -> IO () writeJS fp functions = writeFile fp $ concatMap generateJS functions main :: IO () main = do -- write the JS code to www/api.js at startup writeJS (www </> "api.js") [ incCounterJS, currentValueJS ] -- setup a shared counter cnt <- newCounter -- listen to requests on port 8080 runServer cnt 8080