module Patrol.Type.ClientSdkInfo where
import qualified Data.Aeson as Aeson
import qualified Data.Text as Text
import qualified Patrol.Extra.Aeson as Aeson
import qualified Patrol.Type.ClientSdkPackage as ClientSdkPackage
data ClientSdkInfo = ClientSdkInfo
{ ClientSdkInfo -> [Text]
integrations :: [Text.Text],
ClientSdkInfo -> Text
name :: Text.Text,
ClientSdkInfo -> [ClientSdkPackage]
packages :: [ClientSdkPackage.ClientSdkPackage],
ClientSdkInfo -> Text
version :: Text.Text
}
deriving (ClientSdkInfo -> ClientSdkInfo -> Bool
(ClientSdkInfo -> ClientSdkInfo -> Bool)
-> (ClientSdkInfo -> ClientSdkInfo -> Bool) -> Eq ClientSdkInfo
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
$c== :: ClientSdkInfo -> ClientSdkInfo -> Bool
== :: ClientSdkInfo -> ClientSdkInfo -> Bool
$c/= :: ClientSdkInfo -> ClientSdkInfo -> Bool
/= :: ClientSdkInfo -> ClientSdkInfo -> Bool
Eq, Int -> ClientSdkInfo -> ShowS
[ClientSdkInfo] -> ShowS
ClientSdkInfo -> String
(Int -> ClientSdkInfo -> ShowS)
-> (ClientSdkInfo -> String)
-> ([ClientSdkInfo] -> ShowS)
-> Show ClientSdkInfo
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
$cshowsPrec :: Int -> ClientSdkInfo -> ShowS
showsPrec :: Int -> ClientSdkInfo -> ShowS
$cshow :: ClientSdkInfo -> String
show :: ClientSdkInfo -> String
$cshowList :: [ClientSdkInfo] -> ShowS
showList :: [ClientSdkInfo] -> ShowS
Show)
instance Aeson.ToJSON ClientSdkInfo where
toJSON :: ClientSdkInfo -> Value
toJSON ClientSdkInfo
clientSdkInfo =
[Pair] -> Value
Aeson.intoObject
[ String -> [Text] -> Pair
forall a. ToJSON a => String -> a -> Pair
Aeson.pair String
"integrations" ([Text] -> Pair) -> [Text] -> Pair
forall a b. (a -> b) -> a -> b
$ ClientSdkInfo -> [Text]
integrations ClientSdkInfo
clientSdkInfo,
String -> Text -> Pair
forall a. ToJSON a => String -> a -> Pair
Aeson.pair String
"name" (Text -> Pair) -> Text -> Pair
forall a b. (a -> b) -> a -> b
$ ClientSdkInfo -> Text
name ClientSdkInfo
clientSdkInfo,
String -> [ClientSdkPackage] -> Pair
forall a. ToJSON a => String -> a -> Pair
Aeson.pair String
"packages" ([ClientSdkPackage] -> Pair) -> [ClientSdkPackage] -> Pair
forall a b. (a -> b) -> a -> b
$ ClientSdkInfo -> [ClientSdkPackage]
packages ClientSdkInfo
clientSdkInfo,
String -> Text -> Pair
forall a. ToJSON a => String -> a -> Pair
Aeson.pair String
"version" (Text -> Pair) -> Text -> Pair
forall a b. (a -> b) -> a -> b
$ ClientSdkInfo -> Text
version ClientSdkInfo
clientSdkInfo
]
empty :: ClientSdkInfo
empty :: ClientSdkInfo
empty =
ClientSdkInfo
{ integrations :: [Text]
integrations = [],
name :: Text
name = Text
Text.empty,
packages :: [ClientSdkPackage]
packages = [],
version :: Text
version = Text
Text.empty
}