{-# LANGUAGE DataKinds #-}
{-# LANGUAGE FlexibleContexts #-}
{-# LANGUAGE FlexibleInstances #-}
{-# LANGUAGE MultiParamTypeClasses #-}
{-# LANGUAGE ScopedTypeVariables #-}
{-# LANGUAGE TypeFamilies #-}
{-# LANGUAGE UndecidableInstances #-}
module Keuringsdienst.Helpers
( filterFailedValidations,
isEqualTo,
isLesserThan,
isNegative,
isNegativeOrZero,
isNonEmptyText,
isPositive,
isPositiveOrZero,
isTextOfLength,
isTextSmallerThan,
isTextSmallerThanOrEqual,
isNotEqualTo,
)
where
import Data.Map as Map
import Data.Text as T
import Keuringsdienst as K
isEqualTo :: (Show a, Eq a) => a -> ValidationRule a
isEqualTo :: forall a. (Show a, Eq a) => a -> ValidationRule a
isEqualTo a
value = forall a. (a -> ValidationResult) -> ValidationRule a
ValidationRule forall a b. (a -> b) -> a -> b
$ \a
actual ->
if a
actual forall a. Eq a => a -> a -> Bool
== a
value
then forall err. Validation err
Success
else
forall err. err -> Validation err
Failure
[String -> ErrMsg
pack forall a b. (a -> b) -> a -> b
$ String
"Expected " forall a. Semigroup a => a -> a -> a
<> forall a. Show a => a -> String
show a
actual forall a. Semigroup a => a -> a -> a
<> String
" to equal " forall a. Semigroup a => a -> a -> a
<> forall a. Show a => a -> String
show a
value]
isNotEqualTo :: (Show a, Eq a) => a -> ValidationRule a
isNotEqualTo :: forall a. (Show a, Eq a) => a -> ValidationRule a
isNotEqualTo a
value = forall a. (a -> ValidationResult) -> ValidationRule a
ValidationRule forall a b. (a -> b) -> a -> b
$ \a
actual ->
if a
actual forall a. Eq a => a -> a -> Bool
/= a
value
then forall err. Validation err
Success
else
forall err. err -> Validation err
Failure
[String -> ErrMsg
pack forall a b. (a -> b) -> a -> b
$ String
"Expected " forall a. Semigroup a => a -> a -> a
<> forall a. Show a => a -> String
show a
actual forall a. Semigroup a => a -> a -> a
<> String
" to not equal " forall a. Semigroup a => a -> a -> a
<> forall a. Show a => a -> String
show a
value]
isGreaterThan :: (Show a, Ord a) => a -> ValidationRule a
isGreaterThan :: forall a. (Show a, Ord a) => a -> ValidationRule a
isGreaterThan a
ruleValue = forall a. (a -> ValidationResult) -> ValidationRule a
ValidationRule forall a b. (a -> b) -> a -> b
$ \a
actual ->
if a
actual forall a. Ord a => a -> a -> Bool
> a
ruleValue
then forall err. Validation err
Success
else
forall err. err -> Validation err
Failure
[ String -> ErrMsg
pack (forall a. Show a => a -> String
show a
actual forall a. Semigroup a => a -> a -> a
<> String
" was expected to be greater than " forall a. Semigroup a => a -> a -> a
<> forall a. Show a => a -> String
show a
ruleValue)
]
isLesserThan :: (Show a, Ord a) => a -> ValidationRule a
isLesserThan :: forall a. (Show a, Ord a) => a -> ValidationRule a
isLesserThan a
ruleValue = forall a. (a -> ValidationResult) -> ValidationRule a
ValidationRule forall a b. (a -> b) -> a -> b
$ \a
actual ->
if a
actual forall a. Ord a => a -> a -> Bool
< a
ruleValue
then forall err. Validation err
Success
else
forall err. err -> Validation err
Failure
[ String -> ErrMsg
pack (forall a. Show a => a -> String
show a
actual forall a. Semigroup a => a -> a -> a
<> String
" was expected to be lesser than " forall a. Semigroup a => a -> a -> a
<> forall a. Show a => a -> String
show a
ruleValue)
]
isNonEmptyText :: ValidationRule Text
isNonEmptyText :: ValidationRule ErrMsg
isNonEmptyText = forall a. (a -> ValidationResult) -> ValidationRule a
ValidationRule forall a b. (a -> b) -> a -> b
$ \ErrMsg
actual ->
if ErrMsg -> Bool
T.null ErrMsg
actual
then forall err. err -> Validation err
Failure [String -> ErrMsg
T.pack String
"Text was expected to be non-empty"]
else forall err. Validation err
Success
isTextOfLength :: Int -> ValidationRule Text
isTextOfLength :: Int -> ValidationRule ErrMsg
isTextOfLength Int
ruleValue = forall a. (a -> ValidationResult) -> ValidationRule a
ValidationRule forall a b. (a -> b) -> a -> b
$ \ErrMsg
actual -> do
let actualTextLength :: Int
actualTextLength = ErrMsg -> Int
T.length ErrMsg
actual
if Int
actualTextLength forall a. Eq a => a -> a -> Bool
/= Int
ruleValue
then
forall err. err -> Validation err
Failure
[ String -> ErrMsg
T.pack
( String
"Text was expected to be of size "
forall a. Semigroup a => a -> a -> a
<> forall a. Show a => a -> String
show Int
ruleValue
forall a. Semigroup a => a -> a -> a
<> String
" but was "
forall a. Semigroup a => a -> a -> a
<> forall a. Show a => a -> String
show Int
actualTextLength
)
]
else forall err. Validation err
Success
isTextSmallerThan :: Int -> ValidationRule Text
isTextSmallerThan :: Int -> ValidationRule ErrMsg
isTextSmallerThan Int
ruleValue = forall a. (a -> ValidationResult) -> ValidationRule a
ValidationRule forall a b. (a -> b) -> a -> b
$ \ErrMsg
actual -> do
let actualTextLength :: Int
actualTextLength = ErrMsg -> Int
T.length ErrMsg
actual
if Int
actualTextLength forall a. Ord a => a -> a -> Bool
>= Int
ruleValue
then
forall err. err -> Validation err
Failure
[ String -> ErrMsg
T.pack
( String
"Text was expected to be smaller than "
forall a. Semigroup a => a -> a -> a
<> forall a. Show a => a -> String
show Int
ruleValue
forall a. Semigroup a => a -> a -> a
<> String
" but was "
forall a. Semigroup a => a -> a -> a
<> forall a. Show a => a -> String
show Int
actualTextLength
)
]
else forall err. Validation err
Success
isTextSmallerThanOrEqual :: Int -> ValidationRule Text
isTextSmallerThanOrEqual :: Int -> ValidationRule ErrMsg
isTextSmallerThanOrEqual Int
ruleValue = forall a. (a -> ValidationResult) -> ValidationRule a
ValidationRule forall a b. (a -> b) -> a -> b
$ \ErrMsg
actual -> do
let actualTextLength :: Int
actualTextLength = ErrMsg -> Int
T.length ErrMsg
actual
if Int
actualTextLength forall a. Ord a => a -> a -> Bool
> Int
ruleValue
then
forall err. err -> Validation err
Failure
[ String -> ErrMsg
T.pack
( String
"Text was expected to be smaller than "
forall a. Semigroup a => a -> a -> a
<> forall a. Show a => a -> String
show Int
ruleValue
forall a. Semigroup a => a -> a -> a
<> String
" but was "
forall a. Semigroup a => a -> a -> a
<> forall a. Show a => a -> String
show Int
actualTextLength
)
]
else forall err. Validation err
Success
isNegative :: ValidationRule Int
isNegative :: ValidationRule Int
isNegative = forall a. (Show a, Ord a) => a -> ValidationRule a
isLesserThan Int
0
isPositive :: ValidationRule Int
isPositive :: ValidationRule Int
isPositive = forall a. (Show a, Ord a) => a -> ValidationRule a
isGreaterThan Int
0
isPositiveOrZero :: ValidationRule Int
isPositiveOrZero :: ValidationRule Int
isPositiveOrZero = ValidationRule Int
isPositive forall a. ValidationRule a -> ValidationRule a -> ValidationRule a
*||* forall a. (Show a, Eq a) => a -> ValidationRule a
isEqualTo Int
0
isNegativeOrZero :: ValidationRule Int
isNegativeOrZero :: ValidationRule Int
isNegativeOrZero = ValidationRule Int
isNegative forall a. ValidationRule a -> ValidationRule a -> ValidationRule a
*||* forall a. (Show a, Eq a) => a -> ValidationRule a
isEqualTo Int
0
filterFailedValidations :: Map Text (Validation err) -> Map Text (Validation err)
filterFailedValidations :: forall err.
Map ErrMsg (Validation err) -> Map ErrMsg (Validation err)
filterFailedValidations =
forall a k. (a -> Bool) -> Map k a -> Map k a
Map.filter
( \Validation err
x -> do
case Validation err
x of
Failure err
_ -> Bool
True
Validation err
Success -> Bool
False
)