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