{-# LANGUAGE DeriveDataTypeable #-}
{-# LANGUAGE DeriveGeneric #-}
{-# LANGUAGE OverloadedStrings #-}
{-# LANGUAGE RecordWildCards #-}
{-# LANGUAGE TypeFamilies #-}
{-# OPTIONS_GHC -fno-warn-unused-imports #-}
{-# OPTIONS_GHC -fno-warn-unused-binds #-}
{-# OPTIONS_GHC -fno-warn-unused-matches #-}
module Network.AWS.SageMaker.UpdateEndpointWeightsAndCapacities
(
updateEndpointWeightsAndCapacities
, UpdateEndpointWeightsAndCapacities
, uewacEndpointName
, uewacDesiredWeightsAndCapacities
, updateEndpointWeightsAndCapacitiesResponse
, UpdateEndpointWeightsAndCapacitiesResponse
, uewacrsResponseStatus
, uewacrsEndpointARN
) where
import Network.AWS.Lens
import Network.AWS.Prelude
import Network.AWS.Request
import Network.AWS.Response
import Network.AWS.SageMaker.Types
import Network.AWS.SageMaker.Types.Product
data UpdateEndpointWeightsAndCapacities = UpdateEndpointWeightsAndCapacities'
{ _uewacEndpointName :: !Text
, _uewacDesiredWeightsAndCapacities :: !(List1 DesiredWeightAndCapacity)
} deriving (Eq, Read, Show, Data, Typeable, Generic)
updateEndpointWeightsAndCapacities
:: Text
-> NonEmpty DesiredWeightAndCapacity
-> UpdateEndpointWeightsAndCapacities
updateEndpointWeightsAndCapacities pEndpointName_ pDesiredWeightsAndCapacities_ =
UpdateEndpointWeightsAndCapacities'
{ _uewacEndpointName = pEndpointName_
, _uewacDesiredWeightsAndCapacities = _List1 # pDesiredWeightsAndCapacities_
}
uewacEndpointName :: Lens' UpdateEndpointWeightsAndCapacities Text
uewacEndpointName = lens _uewacEndpointName (\ s a -> s{_uewacEndpointName = a})
uewacDesiredWeightsAndCapacities :: Lens' UpdateEndpointWeightsAndCapacities (NonEmpty DesiredWeightAndCapacity)
uewacDesiredWeightsAndCapacities = lens _uewacDesiredWeightsAndCapacities (\ s a -> s{_uewacDesiredWeightsAndCapacities = a}) . _List1
instance AWSRequest
UpdateEndpointWeightsAndCapacities
where
type Rs UpdateEndpointWeightsAndCapacities =
UpdateEndpointWeightsAndCapacitiesResponse
request = postJSON sageMaker
response
= receiveJSON
(\ s h x ->
UpdateEndpointWeightsAndCapacitiesResponse' <$>
(pure (fromEnum s)) <*> (x .:> "EndpointArn"))
instance Hashable UpdateEndpointWeightsAndCapacities
where
instance NFData UpdateEndpointWeightsAndCapacities
where
instance ToHeaders UpdateEndpointWeightsAndCapacities
where
toHeaders
= const
(mconcat
["X-Amz-Target" =#
("SageMaker.UpdateEndpointWeightsAndCapacities" ::
ByteString),
"Content-Type" =#
("application/x-amz-json-1.1" :: ByteString)])
instance ToJSON UpdateEndpointWeightsAndCapacities
where
toJSON UpdateEndpointWeightsAndCapacities'{..}
= object
(catMaybes
[Just ("EndpointName" .= _uewacEndpointName),
Just
("DesiredWeightsAndCapacities" .=
_uewacDesiredWeightsAndCapacities)])
instance ToPath UpdateEndpointWeightsAndCapacities
where
toPath = const "/"
instance ToQuery UpdateEndpointWeightsAndCapacities
where
toQuery = const mempty
data UpdateEndpointWeightsAndCapacitiesResponse = UpdateEndpointWeightsAndCapacitiesResponse'
{ _uewacrsResponseStatus :: !Int
, _uewacrsEndpointARN :: !Text
} deriving (Eq, Read, Show, Data, Typeable, Generic)
updateEndpointWeightsAndCapacitiesResponse
:: Int
-> Text
-> UpdateEndpointWeightsAndCapacitiesResponse
updateEndpointWeightsAndCapacitiesResponse pResponseStatus_ pEndpointARN_ =
UpdateEndpointWeightsAndCapacitiesResponse'
{ _uewacrsResponseStatus = pResponseStatus_
, _uewacrsEndpointARN = pEndpointARN_
}
uewacrsResponseStatus :: Lens' UpdateEndpointWeightsAndCapacitiesResponse Int
uewacrsResponseStatus = lens _uewacrsResponseStatus (\ s a -> s{_uewacrsResponseStatus = a})
uewacrsEndpointARN :: Lens' UpdateEndpointWeightsAndCapacitiesResponse Text
uewacrsEndpointARN = lens _uewacrsEndpointARN (\ s a -> s{_uewacrsEndpointARN = a})
instance NFData
UpdateEndpointWeightsAndCapacitiesResponse
where