-- Copyright (c) 2016-present, SoundCloud Ltd. -- All rights reserved. -- -- This source code is distributed under the terms of a MIT license, -- found in the LICENSE file. {-# LANGUAGE DeriveGeneric #-} {-# LANGUAGE GeneralizedNewtypeDeriving #-} {-# LANGUAGE TemplateHaskell #-} module Kubernetes.Model.V1.ComponentStatus ( ComponentStatus (..) , kind , apiVersion , metadata , conditions , mkComponentStatus ) where import Control.Lens.TH (makeLenses) import Data.Aeson.TH (defaultOptions, deriveJSON, fieldLabelModifier) import Data.Text (Text) import GHC.Generics (Generic) import Kubernetes.Model.V1.ComponentCondition (ComponentCondition) import Kubernetes.Model.V1.ObjectMeta (ObjectMeta) import Prelude hiding (drop, error, max, min) import qualified Prelude as P import Test.QuickCheck (Arbitrary, arbitrary) import Test.QuickCheck.Instances () -- | ComponentStatus (and ComponentStatusList) holds the cluster validation info. data ComponentStatus = ComponentStatus { _kind :: !(Maybe Text) , _apiVersion :: !(Maybe Text) , _metadata :: !(Maybe ObjectMeta) , _conditions :: !(Maybe [ComponentCondition]) } deriving (Show, Eq, Generic) makeLenses ''ComponentStatus $(deriveJSON defaultOptions{fieldLabelModifier = (\n -> if n == "_type_" then "type" else P.drop 1 n)} ''ComponentStatus) instance Arbitrary ComponentStatus where arbitrary = ComponentStatus <$> arbitrary <*> arbitrary <*> arbitrary <*> arbitrary -- | Use this method to build a ComponentStatus mkComponentStatus :: ComponentStatus mkComponentStatus = ComponentStatus Nothing Nothing Nothing Nothing