module Kubernetes.Model.V1.ComponentCondition
( ComponentCondition (..)
, type_
, status
, message
, error
, mkComponentCondition
) 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 ComponentCondition = ComponentCondition
{ _type_ :: !(Text)
, _status :: !(Text)
, _message :: !(Maybe Text)
, _error :: !(Maybe Text)
} deriving (Show, Eq, Generic)
makeLenses ''ComponentCondition
$(deriveJSON defaultOptions{fieldLabelModifier = (\n -> if n == "_type_" then "type" else P.drop 1 n)} ''ComponentCondition)
instance Arbitrary ComponentCondition where
arbitrary = ComponentCondition <$> arbitrary <*> arbitrary <*> arbitrary <*> arbitrary
mkComponentCondition :: Text -> Text -> ComponentCondition
mkComponentCondition xtype_x xstatusx = ComponentCondition xtype_x xstatusx Nothing Nothing