{-# 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.AlexaBusiness.UpdateSkillGroup
(
updateSkillGroup
, UpdateSkillGroup
, usgSkillGroupARN
, usgDescription
, usgSkillGroupName
, updateSkillGroupResponse
, UpdateSkillGroupResponse
, usgrsResponseStatus
) where
import Network.AWS.AlexaBusiness.Types
import Network.AWS.AlexaBusiness.Types.Product
import Network.AWS.Lens
import Network.AWS.Prelude
import Network.AWS.Request
import Network.AWS.Response
data UpdateSkillGroup = UpdateSkillGroup'
{ _usgSkillGroupARN :: !(Maybe Text)
, _usgDescription :: !(Maybe Text)
, _usgSkillGroupName :: !(Maybe Text)
} deriving (Eq, Read, Show, Data, Typeable, Generic)
updateSkillGroup
:: UpdateSkillGroup
updateSkillGroup =
UpdateSkillGroup'
{ _usgSkillGroupARN = Nothing
, _usgDescription = Nothing
, _usgSkillGroupName = Nothing
}
usgSkillGroupARN :: Lens' UpdateSkillGroup (Maybe Text)
usgSkillGroupARN = lens _usgSkillGroupARN (\ s a -> s{_usgSkillGroupARN = a})
usgDescription :: Lens' UpdateSkillGroup (Maybe Text)
usgDescription = lens _usgDescription (\ s a -> s{_usgDescription = a})
usgSkillGroupName :: Lens' UpdateSkillGroup (Maybe Text)
usgSkillGroupName = lens _usgSkillGroupName (\ s a -> s{_usgSkillGroupName = a})
instance AWSRequest UpdateSkillGroup where
type Rs UpdateSkillGroup = UpdateSkillGroupResponse
request = postJSON alexaBusiness
response
= receiveEmpty
(\ s h x ->
UpdateSkillGroupResponse' <$> (pure (fromEnum s)))
instance Hashable UpdateSkillGroup where
instance NFData UpdateSkillGroup where
instance ToHeaders UpdateSkillGroup where
toHeaders
= const
(mconcat
["X-Amz-Target" =#
("AlexaForBusiness.UpdateSkillGroup" :: ByteString),
"Content-Type" =#
("application/x-amz-json-1.1" :: ByteString)])
instance ToJSON UpdateSkillGroup where
toJSON UpdateSkillGroup'{..}
= object
(catMaybes
[("SkillGroupArn" .=) <$> _usgSkillGroupARN,
("Description" .=) <$> _usgDescription,
("SkillGroupName" .=) <$> _usgSkillGroupName])
instance ToPath UpdateSkillGroup where
toPath = const "/"
instance ToQuery UpdateSkillGroup where
toQuery = const mempty
newtype UpdateSkillGroupResponse = UpdateSkillGroupResponse'
{ _usgrsResponseStatus :: Int
} deriving (Eq, Read, Show, Data, Typeable, Generic)
updateSkillGroupResponse
:: Int
-> UpdateSkillGroupResponse
updateSkillGroupResponse pResponseStatus_ =
UpdateSkillGroupResponse' {_usgrsResponseStatus = pResponseStatus_}
usgrsResponseStatus :: Lens' UpdateSkillGroupResponse Int
usgrsResponseStatus = lens _usgrsResponseStatus (\ s a -> s{_usgrsResponseStatus = a})
instance NFData UpdateSkillGroupResponse where