{-# LANGUAGE CPP #-}
{-# LANGUAGE OverloadedStrings #-}
module Database.Persist.IP ( (<:<.)
, (>:>.)
, (<:<=)
, (>:>=)
, (<.<.)
, (>.>.)
, IP
, IPRange
) where
import Data.IP
import Database.Persist
import Database.Persist.Instances.IP ()
import Unsafe.Coerce (unsafeCoerce)
#if MIN_VERSION_persistent(2,10,0)
#define VALUE_CONSTRUCTOR FilterValue
#else
#define VALUE_CONSTRUCTOR Left
#endif
(<:<.) :: EntityField record IPRange -> IPRange -> Filter record
field <:<. range = Filter field (VALUE_CONSTRUCTOR range) (BackendSpecificFilter "<<")
(>:>.) :: EntityField record IPRange -> IPRange -> Filter record
field >:>. range = Filter field (VALUE_CONSTRUCTOR range) (BackendSpecificFilter ">>")
(<:<=) :: EntityField record IPRange -> IPRange -> Filter record
field <:<= range = Filter field (VALUE_CONSTRUCTOR range) (BackendSpecificFilter "<<=")
(>:>=) :: EntityField record IPRange -> IPRange -> Filter record
field >:>= range = Filter field (VALUE_CONSTRUCTOR range) (BackendSpecificFilter ">>=")
(<.<.) :: EntityField record IP -> IPRange -> Filter record
field <.<. range = Filter (unsafeCoerce field :: EntityField record IPRange) (VALUE_CONSTRUCTOR range) (BackendSpecificFilter "<<")
(>.>.) :: EntityField record IPRange -> IP -> Filter record
field >.>. ip = Filter (unsafeCoerce field :: EntityField record IP) (VALUE_CONSTRUCTOR ip) (BackendSpecificFilter ">>")
#undef VALUE_CONSTRUCTOR