Skip to content

Commit

Permalink
Merge pull request #45 from phadej/lenient-param
Browse files Browse the repository at this point in the history
Add LenientData
  • Loading branch information
fizruk authored Jan 19, 2017
2 parents 916442d + a5f4e27 commit 883b997
Show file tree
Hide file tree
Showing 2 changed files with 21 additions and 0 deletions.
3 changes: 3 additions & 0 deletions src/Web/HttpApiData.hs
Original file line number Diff line number Diff line change
Expand Up @@ -35,6 +35,9 @@ module Web.HttpApiData (
parseBoundedEnumOfI,
parseBoundedTextData,

-- * Lenient data
LenientData (..),

-- * Other helpers
showTextData,
readTextData,
Expand Down
18 changes: 18 additions & 0 deletions src/Web/Internal/HttpApiData.hs
Original file line number Diff line number Diff line change
@@ -1,5 +1,9 @@
{-# LANGUAGE CPP #-}
{-# LANGUAGE DefaultSignatures #-}
{-# LANGUAGE DeriveDataTypeable #-}
{-# LANGUAGE DeriveFunctor #-}
{-# LANGUAGE DeriveFoldable #-}
{-# LANGUAGE DeriveTraversable #-}
{-# LANGUAGE FlexibleInstances #-}
{-# LANGUAGE OverloadedStrings #-}
{-# LANGUAGE ScopedTypeVariables #-}
Expand All @@ -11,6 +15,7 @@ module Web.Internal.HttpApiData where

#if __GLASGOW_HASKELL__ < 710
import Control.Applicative
import Data.Foldable (Foldable)
import Data.Traversable (Traversable(traverse))
#endif

Expand Down Expand Up @@ -48,6 +53,9 @@ import TextShow (TextShow, showt)

import qualified Data.UUID.Types as UUID

import Data.Typeable (Typeable)
import Data.Data (Data)

-- $setup
-- >>> data BasicAuthToken = BasicAuthToken Text deriving (Show)
-- >>> instance FromHttpApiData BasicAuthToken where parseHeader h = BasicAuthToken <$> parseHeaderWithPrefix "Basic " h; parseQueryParam p = BasicAuthToken <$> parseQueryParam p
Expand Down Expand Up @@ -586,3 +594,13 @@ instance ToHttpApiData UUID.UUID where
instance FromHttpApiData UUID.UUID where
parseUrlPiece = maybe (Left "invalid UUID") Right . UUID.fromText
parseHeader = maybe (Left "invalid UUID") Right . UUID.fromASCIIBytes


-- | Lenient parameters. 'FromHttpApiData' combinators always return `Right`.
newtype LenientData a = LenientData { getLenientData :: Either Text a }
deriving (Eq, Ord, Show, Read, Typeable, Data, Functor, Foldable, Traversable)

instance FromHttpApiData a => FromHttpApiData (LenientData a) where
parseUrlPiece = Right . LenientData . parseUrlPiece
parseHeader = Right . LenientData . parseHeader
parseQueryParam = Right . LenientData . parseQueryParam

0 comments on commit 883b997

Please sign in to comment.