module Kubernetes.Model.V1.EventList
( EventList (..)
, kind
, apiVersion
, metadata
, items
, mkEventList
) where
import Control.Lens.TH (makeLenses)
import Data.Aeson.TH (defaultOptions,
deriveJSON,
fieldLabelModifier)
import Data.Text (Text)
import GHC.Generics (Generic)
import Kubernetes.Model.Unversioned.ListMeta (ListMeta)
import Kubernetes.Model.V1.Event (Event)
import Prelude hiding (drop, error, max,
min)
import qualified Prelude as P
import Test.QuickCheck (Arbitrary, arbitrary)
import Test.QuickCheck.Instances ()
data EventList = EventList
{ _kind :: !(Maybe Text)
, _apiVersion :: !(Maybe Text)
, _metadata :: !(Maybe ListMeta)
, _items :: !([Event])
} deriving (Show, Eq, Generic)
makeLenses ''EventList
$(deriveJSON defaultOptions{fieldLabelModifier = (\n -> if n == "_type_" then "type" else P.drop 1 n)} ''EventList)
instance Arbitrary EventList where
arbitrary = EventList <$> arbitrary <*> arbitrary <*> arbitrary <*> arbitrary
mkEventList :: [Event] -> EventList
mkEventList xitemsx = EventList Nothing Nothing Nothing xitemsx