module Patrol.Type.TransactionInfo where

import qualified Data.Aeson as Aeson
import qualified Data.Text as Text
import qualified Patrol.Extra.Aeson as Aeson
import qualified Patrol.Type.TransactionSource as TransactionSource

-- | <https://develop.sentry.dev/sdk/event-payloads/types/#transactioninfo>
data TransactionInfo = TransactionInfo
  { TransactionInfo -> Text
original :: Text.Text,
    TransactionInfo -> Maybe TransactionSource
source :: Maybe TransactionSource.TransactionSource
  }
  deriving (TransactionInfo -> TransactionInfo -> Bool
(TransactionInfo -> TransactionInfo -> Bool)
-> (TransactionInfo -> TransactionInfo -> Bool)
-> Eq TransactionInfo
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
$c== :: TransactionInfo -> TransactionInfo -> Bool
== :: TransactionInfo -> TransactionInfo -> Bool
$c/= :: TransactionInfo -> TransactionInfo -> Bool
/= :: TransactionInfo -> TransactionInfo -> Bool
Eq, Int -> TransactionInfo -> ShowS
[TransactionInfo] -> ShowS
TransactionInfo -> String
(Int -> TransactionInfo -> ShowS)
-> (TransactionInfo -> String)
-> ([TransactionInfo] -> ShowS)
-> Show TransactionInfo
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
$cshowsPrec :: Int -> TransactionInfo -> ShowS
showsPrec :: Int -> TransactionInfo -> ShowS
$cshow :: TransactionInfo -> String
show :: TransactionInfo -> String
$cshowList :: [TransactionInfo] -> ShowS
showList :: [TransactionInfo] -> ShowS
Show)

instance Aeson.ToJSON TransactionInfo where
  toJSON :: TransactionInfo -> Value
toJSON TransactionInfo
transactionInfo =
    [Pair] -> Value
Aeson.intoObject
      [ String -> Text -> Pair
forall a. ToJSON a => String -> a -> Pair
Aeson.pair String
"original" (Text -> Pair) -> Text -> Pair
forall a b. (a -> b) -> a -> b
$ TransactionInfo -> Text
original TransactionInfo
transactionInfo,
        String -> Maybe TransactionSource -> Pair
forall a. ToJSON a => String -> a -> Pair
Aeson.pair String
"source" (Maybe TransactionSource -> Pair)
-> Maybe TransactionSource -> Pair
forall a b. (a -> b) -> a -> b
$ TransactionInfo -> Maybe TransactionSource
source TransactionInfo
transactionInfo
      ]

empty :: TransactionInfo
empty :: TransactionInfo
empty =
  TransactionInfo
    { original :: Text
original = Text
Text.empty,
      source :: Maybe TransactionSource
source = Maybe TransactionSource
forall a. Maybe a
Nothing
    }