module Opaleye.SqlTypes (module Opaleye.SqlTypes,
                         P.IsSqlType,
                         P.IsRangeType) where
import qualified Opaleye.Field   as F
import qualified Opaleye.PGTypes as P
import           Opaleye.PGTypes (IsSqlType, IsRangeType)
import qualified Data.Aeson as Ae
import qualified Data.ByteString as SByteString
import qualified Data.ByteString.Lazy as LByteString
import qualified Data.CaseInsensitive as CI
import           Data.Int (Int64)
import           Data.Scientific as Sci
import qualified Data.Text as SText
import qualified Data.Text.Lazy as LText
import qualified Data.Time as Time
import qualified Data.UUID as UUID
import qualified Database.PostgreSQL.Simple.Range as R
sqlString :: String -> F.Field SqlText
sqlString = P.pgString
sqlLazyByteString :: LByteString.ByteString -> F.Field SqlBytea
sqlLazyByteString = P.pgLazyByteString
sqlStrictByteString :: SByteString.ByteString -> F.Field SqlBytea
sqlStrictByteString = P.pgStrictByteString
sqlStrictText :: SText.Text -> F.Field SqlText
sqlStrictText = P.pgStrictText
sqlLazyText :: LText.Text -> F.Field SqlText
sqlLazyText = P.pgLazyText
sqlNumeric :: Sci.Scientific -> F.Field SqlNumeric
sqlNumeric = P.pgNumeric
sqlInt4 :: Int -> F.Field SqlInt4
sqlInt4 = P.pgInt4
sqlInt8 :: Int64 -> F.Field SqlInt8
sqlInt8 = P.pgInt8
sqlDouble :: Double -> F.Field SqlFloat8
sqlDouble = P.pgDouble
sqlBool :: Bool -> F.Field SqlBool
sqlBool = P.pgBool
sqlUUID :: UUID.UUID -> F.Field SqlUuid
sqlUUID = P.pgUUID
sqlDay :: Time.Day -> F.Field SqlDate
sqlDay = P.pgDay
sqlUTCTime :: Time.UTCTime -> F.Field SqlTimestamptz
sqlUTCTime = P.pgUTCTime
sqlLocalTime :: Time.LocalTime -> F.Field SqlTimestamp
sqlLocalTime = P.pgLocalTime
sqlZonedTime :: Time.ZonedTime -> F.Field SqlTimestamptz
sqlZonedTime = P.pgZonedTime
sqlTimeOfDay :: Time.TimeOfDay -> F.Field SqlTime
sqlTimeOfDay = P.pgTimeOfDay
sqlCiStrictText :: CI.CI SText.Text -> F.Field SqlCitext
sqlCiStrictText = P.pgCiStrictText
sqlCiLazyText :: CI.CI LText.Text -> F.Field SqlCitext
sqlCiLazyText = P.pgCiLazyText
sqlJSON :: String -> F.Field SqlJson
sqlJSON = P.pgJSON
sqlStrictJSON :: SByteString.ByteString -> F.Field SqlJson
sqlStrictJSON = P.pgStrictJSON
sqlLazyJSON :: LByteString.ByteString -> F.Field SqlJson
sqlLazyJSON = P.pgLazyJSON
sqlValueJSON :: Ae.ToJSON a => a -> F.Field SqlJson
sqlValueJSON = P.pgValueJSON
sqlJSONB :: String -> F.Field SqlJsonb
sqlJSONB = P.pgJSONB
sqlStrictJSONB :: SByteString.ByteString -> F.Field SqlJsonb
sqlStrictJSONB = P.pgStrictJSONB
sqlLazyJSONB :: LByteString.ByteString -> F.Field SqlJsonb
sqlLazyJSONB = P.pgLazyJSONB
sqlValueJSONB :: Ae.ToJSON a => a -> F.Field SqlJsonb
sqlValueJSONB = P.pgValueJSONB
sqlArray :: IsSqlType b => (a -> F.Field b) -> [a] -> F.Field (SqlArray b)
sqlArray = P.pgArray
sqlRange :: IsRangeType b
         => (a -> F.Field b)
         -> R.RangeBound a
         -> R.RangeBound a
         -> F.Field (SqlRange b)
sqlRange = P.pgRange
type SqlBool = P.PGBool
type SqlDate = P.PGDate
type SqlFloat4 = P.PGFloat4
type SqlFloat8 = P.PGFloat8
type SqlInt8 = P.PGInt8
type SqlInt4 = P.PGInt4
type SqlInt2 = P.PGInt2
type SqlNumeric = P.PGNumeric
type SqlText = P.PGText
type SqlTime = P.PGTime
type SqlTimestamp = P.PGTimestamp
type SqlTimestamptz = P.PGTimestamptz
type SqlUuid = P.PGUuid
type SqlCitext = P.PGCitext
type SqlArray = P.PGArray
type SqlBytea = P.PGBytea
type SqlJson = P.PGJson
type SqlJsonb = P.PGJsonb
type SqlRange = P.PGRange