module Kubernetes.Model.Unversioned.StatusCause
( StatusCause (..)
, reason
, message
, field
, mkStatusCause
) 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 StatusCause = StatusCause
{ _reason :: !(Maybe Text)
, _message :: !(Maybe Text)
, _field :: !(Maybe Text)
} deriving (Show, Eq, Generic)
makeLenses ''StatusCause
$(deriveJSON defaultOptions{fieldLabelModifier = (\n -> if n == "_type_" then "type" else P.drop 1 n)} ''StatusCause)
instance Arbitrary StatusCause where
arbitrary = StatusCause <$> arbitrary <*> arbitrary <*> arbitrary
mkStatusCause :: StatusCause
mkStatusCause = StatusCause Nothing Nothing Nothing