-- 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.CinderVolumeSource ( CinderVolumeSource (..) , volumeID , fsType , readOnly , mkCinderVolumeSource ) 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 () -- | Represents a cinder volume resource in Openstack. A Cinder volume must exist before mounting to a container. The volume must also be in the same region as the kubelet. Cinder volumes support ownership management and SELinux relabeling. data CinderVolumeSource = CinderVolumeSource { _volumeID :: !(Text) , _fsType :: !(Maybe Text) , _readOnly :: !(Maybe Bool) } deriving (Show, Eq, Generic) makeLenses ''CinderVolumeSource $(deriveJSON defaultOptions{fieldLabelModifier = (\n -> if n == "_type_" then "type" else P.drop 1 n)} ''CinderVolumeSource) instance Arbitrary CinderVolumeSource where arbitrary = CinderVolumeSource <$> arbitrary <*> arbitrary <*> arbitrary -- | Use this method to build a CinderVolumeSource mkCinderVolumeSource :: Text -> CinderVolumeSource mkCinderVolumeSource xvolumeIDx = CinderVolumeSource xvolumeIDx Nothing Nothing