module Kubernetes.Model.Unversioned.StatusDetails
( StatusDetails (..)
, name
, group
, kind
, causes
, retryAfterSeconds
, mkStatusDetails
) 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.StatusCause (StatusCause)
import Prelude hiding (drop, error,
max, min)
import qualified Prelude as P
import Test.QuickCheck (Arbitrary, arbitrary)
import Test.QuickCheck.Instances ()
data StatusDetails = StatusDetails
{ _name :: !(Maybe Text)
, _group :: !(Maybe Text)
, _kind :: !(Maybe Text)
, _causes :: !(Maybe [StatusCause])
, _retryAfterSeconds :: !(Maybe Integer)
} deriving (Show, Eq, Generic)
makeLenses ''StatusDetails
$(deriveJSON defaultOptions{fieldLabelModifier = (\n -> if n == "_type_" then "type" else P.drop 1 n)} ''StatusDetails)
instance Arbitrary StatusDetails where
arbitrary = StatusDetails <$> arbitrary <*> arbitrary <*> arbitrary <*> arbitrary <*> arbitrary
mkStatusDetails :: StatusDetails
mkStatusDetails = StatusDetails Nothing Nothing Nothing Nothing Nothing