-- 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.NodeStatus ( NodeStatus (..) , capacity , allocatable , phase , conditions , addresses , daemonEndpoints , nodeInfo , images , mkNodeStatus ) 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.Any (Any) import Kubernetes.Model.V1.ContainerImage (ContainerImage) import Kubernetes.Model.V1.NodeAddress (NodeAddress) import Kubernetes.Model.V1.NodeCondition (NodeCondition) import Kubernetes.Model.V1.NodeDaemonEndpoints (NodeDaemonEndpoints) import Kubernetes.Model.V1.NodeSystemInfo (NodeSystemInfo) import Prelude hiding (drop, error, max, min) import qualified Prelude as P import Test.QuickCheck (Arbitrary, arbitrary) import Test.QuickCheck.Instances () -- | NodeStatus is information about the current status of a node. data NodeStatus = NodeStatus { _capacity :: !(Maybe Any) , _allocatable :: !(Maybe Any) , _phase :: !(Maybe Text) , _conditions :: !(Maybe [NodeCondition]) , _addresses :: !(Maybe [NodeAddress]) , _daemonEndpoints :: !(Maybe NodeDaemonEndpoints) , _nodeInfo :: !(Maybe NodeSystemInfo) , _images :: !([ContainerImage]) } deriving (Show, Eq, Generic) makeLenses ''NodeStatus $(deriveJSON defaultOptions{fieldLabelModifier = (\n -> if n == "_type_" then "type" else P.drop 1 n)} ''NodeStatus) instance Arbitrary NodeStatus where arbitrary = NodeStatus <$> arbitrary <*> arbitrary <*> arbitrary <*> arbitrary <*> arbitrary <*> arbitrary <*> arbitrary <*> arbitrary -- | Use this method to build a NodeStatus mkNodeStatus :: [ContainerImage] -> NodeStatus mkNodeStatus ximagesx = NodeStatus Nothing Nothing Nothing Nothing Nothing Nothing Nothing ximagesx