module Quantum.Random.Codec (
QRResponse (..),
QRSettings (..),
defaults,
parseResponse,
parseSettings,
updateTarSize,
updateMinSize,
updateDefaultStyle
) where
import Quantum.Random.Exceptions
import Quantum.Random.Display
import GHC.Generics (Generic)
import Data.Aeson
import Data.Aeson.Types (Options (..))
import Data.Text (Text)
import Data.ByteString.Lazy (ByteString)
import Data.Bifunctor (first)
data QRResponse = QRResponse { qtype :: !Text
, qlength :: !Int
, qdata :: ![Int]
, success :: !Bool } deriving (Show, Generic)
data QRSettings = QRSettings { minStoreSize :: Int
, targetStoreSize :: Int
, defaultDisplayStyle :: DisplayStyle } deriving (Show, Generic)
instance FromJSON QRResponse where
parseJSON = genericParseJSON $
defaultOptions { fieldLabelModifier = qrFieldRenamer }
where qrFieldRenamer :: String -> String
qrFieldRenamer ('q':str) = str
qrFieldRenamer str = str
instance FromJSON QRSettings
instance ToJSON QRSettings
defaults :: QRSettings
defaults = QRSettings 400 800 ColorHex
updateMinSize :: Int -> QRSettings -> QRSettings
updateMinSize n qs = qs { minStoreSize = n }
updateTarSize :: Int -> QRSettings -> QRSettings
updateTarSize n qs = qs { targetStoreSize = n }
updateDefaultStyle :: DisplayStyle -> QRSettings -> QRSettings
updateDefaultStyle sty qs = qs { defaultDisplayStyle = sty }
parseResponse :: ByteString -> Either QRException QRResponse
parseResponse = first ParseResponseError . eitherDecode
parseSettings :: ByteString -> Either QRException QRSettings
parseSettings = first ParseSettingsError . eitherDecode