-- 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.ServiceStatus
    ( ServiceStatus (..)
    , loadBalancer
    , mkServiceStatus
    ) where

import           Control.Lens.TH                        (makeLenses)
import           Data.Aeson.TH                          (defaultOptions,
                                                         deriveJSON,
                                                         fieldLabelModifier)
import           GHC.Generics                           (Generic)
import           Kubernetes.Model.V1.LoadBalancerStatus (LoadBalancerStatus)
import           Prelude                                hiding (drop, error,
                                                         max, min)
import qualified Prelude                                as P
import           Test.QuickCheck                        (Arbitrary, arbitrary)
import           Test.QuickCheck.Instances              ()

-- | ServiceStatus represents the current status of a service.
data ServiceStatus = ServiceStatus
    { _loadBalancer :: !(Maybe LoadBalancerStatus)
    } deriving (Show, Eq, Generic)

makeLenses ''ServiceStatus

$(deriveJSON defaultOptions{fieldLabelModifier = (\n -> if n == "_type_" then "type" else P.drop 1 n)} ''ServiceStatus)

instance Arbitrary ServiceStatus where
    arbitrary = ServiceStatus <$> arbitrary

-- | Use this method to build a ServiceStatus
mkServiceStatus :: ServiceStatus
mkServiceStatus = ServiceStatus Nothing