{-# 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 #-} -- Derived from AWS service descriptions, licensed under Apache 2.0. -- | -- Module : Network.AWS.Redshift.CreateClusterSecurityGroup -- Copyright : (c) 2013-2016 Brendan Hay -- License : Mozilla Public License, v. 2.0. -- Maintainer : Brendan Hay -- Stability : auto-generated -- Portability : non-portable (GHC extensions) -- -- Creates a new Amazon Redshift security group. You use security groups to control access to non-VPC clusters. -- -- For information about managing security groups, go to in the /Amazon Redshift Cluster Management Guide/. module Network.AWS.Redshift.CreateClusterSecurityGroup ( -- * Creating a Request createClusterSecurityGroup , CreateClusterSecurityGroup -- * Request Lenses , creTags , creClusterSecurityGroupName , creDescription -- * Destructuring the Response , createClusterSecurityGroupResponse , CreateClusterSecurityGroupResponse -- * Response Lenses , crsClusterSecurityGroup , crsResponseStatus ) where import Network.AWS.Lens import Network.AWS.Prelude import Network.AWS.Redshift.Types import Network.AWS.Redshift.Types.Product import Network.AWS.Request import Network.AWS.Response -- | -- -- /See:/ 'createClusterSecurityGroup' smart constructor. data CreateClusterSecurityGroup = CreateClusterSecurityGroup' { _creTags :: !(Maybe [Tag]) , _creClusterSecurityGroupName :: !Text , _creDescription :: !Text } deriving (Eq,Read,Show,Data,Typeable,Generic) -- | Creates a value of 'CreateClusterSecurityGroup' with the minimum fields required to make a request. -- -- Use one of the following lenses to modify other fields as desired: -- -- * 'creTags' -- -- * 'creClusterSecurityGroupName' -- -- * 'creDescription' createClusterSecurityGroup :: Text -- ^ 'creClusterSecurityGroupName' -> Text -- ^ 'creDescription' -> CreateClusterSecurityGroup createClusterSecurityGroup pClusterSecurityGroupName_ pDescription_ = CreateClusterSecurityGroup' { _creTags = Nothing , _creClusterSecurityGroupName = pClusterSecurityGroupName_ , _creDescription = pDescription_ } -- | A list of tag instances. creTags :: Lens' CreateClusterSecurityGroup [Tag] creTags = lens _creTags (\ s a -> s{_creTags = a}) . _Default . _Coerce; -- | The name for the security group. Amazon Redshift stores the value as a lowercase string. -- -- Constraints: -- -- - Must contain no more than 255 alphanumeric characters or hyphens. -- - Must not be \"Default\". -- - Must be unique for all security groups that are created by your AWS account. -- -- Example: 'examplesecuritygroup' creClusterSecurityGroupName :: Lens' CreateClusterSecurityGroup Text creClusterSecurityGroupName = lens _creClusterSecurityGroupName (\ s a -> s{_creClusterSecurityGroupName = a}); -- | A description for the security group. creDescription :: Lens' CreateClusterSecurityGroup Text creDescription = lens _creDescription (\ s a -> s{_creDescription = a}); instance AWSRequest CreateClusterSecurityGroup where type Rs CreateClusterSecurityGroup = CreateClusterSecurityGroupResponse request = postQuery redshift response = receiveXMLWrapper "CreateClusterSecurityGroupResult" (\ s h x -> CreateClusterSecurityGroupResponse' <$> (x .@? "ClusterSecurityGroup") <*> (pure (fromEnum s))) instance Hashable CreateClusterSecurityGroup instance NFData CreateClusterSecurityGroup instance ToHeaders CreateClusterSecurityGroup where toHeaders = const mempty instance ToPath CreateClusterSecurityGroup where toPath = const "/" instance ToQuery CreateClusterSecurityGroup where toQuery CreateClusterSecurityGroup'{..} = mconcat ["Action" =: ("CreateClusterSecurityGroup" :: ByteString), "Version" =: ("2012-12-01" :: ByteString), "Tags" =: toQuery (toQueryList "Tag" <$> _creTags), "ClusterSecurityGroupName" =: _creClusterSecurityGroupName, "Description" =: _creDescription] -- | /See:/ 'createClusterSecurityGroupResponse' smart constructor. data CreateClusterSecurityGroupResponse = CreateClusterSecurityGroupResponse' { _crsClusterSecurityGroup :: !(Maybe ClusterSecurityGroup) , _crsResponseStatus :: !Int } deriving (Eq,Read,Show,Data,Typeable,Generic) -- | Creates a value of 'CreateClusterSecurityGroupResponse' with the minimum fields required to make a request. -- -- Use one of the following lenses to modify other fields as desired: -- -- * 'crsClusterSecurityGroup' -- -- * 'crsResponseStatus' createClusterSecurityGroupResponse :: Int -- ^ 'crsResponseStatus' -> CreateClusterSecurityGroupResponse createClusterSecurityGroupResponse pResponseStatus_ = CreateClusterSecurityGroupResponse' { _crsClusterSecurityGroup = Nothing , _crsResponseStatus = pResponseStatus_ } -- | Undocumented member. crsClusterSecurityGroup :: Lens' CreateClusterSecurityGroupResponse (Maybe ClusterSecurityGroup) crsClusterSecurityGroup = lens _crsClusterSecurityGroup (\ s a -> s{_crsClusterSecurityGroup = a}); -- | The response status code. crsResponseStatus :: Lens' CreateClusterSecurityGroupResponse Int crsResponseStatus = lens _crsResponseStatus (\ s a -> s{_crsResponseStatus = a}); instance NFData CreateClusterSecurityGroupResponse