module Kubernetes.Model.Json.WatchEvent
( WatchEvent (..)
, type_
, object
, mkWatchEvent
) where
import Control.Lens.TH (makeLenses)
import Data.Aeson.TH (defaultOptions, deriveJSON,
fieldLabelModifier)
import Data.Text (Text)
import GHC.Generics (Generic)
import Prelude hiding (drop, error, max, min)
import qualified Prelude as P
import Test.QuickCheck (Arbitrary, arbitrary)
import Test.QuickCheck.Instances ()
data WatchEvent = WatchEvent
{ _type_ :: !(Maybe Text)
, _object :: !(Maybe Text)
} deriving (Show, Eq, Generic)
makeLenses ''WatchEvent
$(deriveJSON defaultOptions{fieldLabelModifier = (\n -> if n == "_type_" then "type" else P.drop 1 n)} ''WatchEvent)
instance Arbitrary WatchEvent where
arbitrary = WatchEvent <$> arbitrary <*> arbitrary
mkWatchEvent :: WatchEvent
mkWatchEvent = WatchEvent Nothing Nothing