{-# 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.RDS.CreateDBClusterParameterGroup -- Copyright : (c) 2013-2015 Brendan Hay -- License : Mozilla Public License, v. 2.0. -- Maintainer : Brendan Hay -- Stability : auto-generated -- Portability : non-portable (GHC extensions) -- -- Creates a new DB cluster parameter group. -- -- Parameters in a DB cluster parameter group apply to all of the instances -- in a DB cluster. -- -- A DB cluster parameter group is initially created with the default -- parameters for the database engine used by instances in the DB cluster. -- To provide custom values for any of the parameters, you must modify the -- group after creating it using ModifyDBClusterParameterGroup. Once -- you\'ve created a DB cluster parameter group, you need to associate it -- with your DB cluster using ModifyDBCluster. When you associate a new DB -- cluster parameter group with a running DB cluster, you need to reboot -- the DB instances in the DB cluster without failover for the new DB -- cluster parameter group and associated settings to take effect. -- -- After you create a DB cluster parameter group, you should wait at least -- 5 minutes before creating your first DB cluster that uses that DB -- cluster parameter group as the default parameter group. This allows -- Amazon RDS to fully complete the create action before the DB cluster -- parameter group is used as the default for a new DB cluster. This is -- especially important for parameters that are critical when creating the -- default database for a DB cluster, such as the character set for the -- default database defined by the 'character_set_database' parameter. You -- can use the /Parameter Groups/ option of the -- or the -- DescribeDBClusterParameters command to verify that your DB cluster -- parameter group has been created or modified. -- -- For more information on Amazon Aurora, see -- -- in the /Amazon RDS User Guide./ -- -- /See:/ for CreateDBClusterParameterGroup. module Network.AWS.RDS.CreateDBClusterParameterGroup ( -- * Creating a Request createDBClusterParameterGroup , CreateDBClusterParameterGroup -- * Request Lenses , cdcpgTags , cdcpgDBClusterParameterGroupName , cdcpgDBParameterGroupFamily , cdcpgDescription -- * Destructuring the Response , createDBClusterParameterGroupResponse , CreateDBClusterParameterGroupResponse -- * Response Lenses , cdcpgrsDBClusterParameterGroup , cdcpgrsStatus ) where import Network.AWS.Prelude import Network.AWS.RDS.Types import Network.AWS.RDS.Types.Product import Network.AWS.Request import Network.AWS.Response -- | -- -- /See:/ 'createDBClusterParameterGroup' smart constructor. data CreateDBClusterParameterGroup = CreateDBClusterParameterGroup' { _cdcpgTags :: !(Maybe [Tag]) , _cdcpgDBClusterParameterGroupName :: !Text , _cdcpgDBParameterGroupFamily :: !Text , _cdcpgDescription :: !Text } deriving (Eq,Read,Show,Data,Typeable,Generic) -- | Creates a value of 'CreateDBClusterParameterGroup' with the minimum fields required to make a request. -- -- Use one of the following lenses to modify other fields as desired: -- -- * 'cdcpgTags' -- -- * 'cdcpgDBClusterParameterGroupName' -- -- * 'cdcpgDBParameterGroupFamily' -- -- * 'cdcpgDescription' createDBClusterParameterGroup :: Text -- ^ 'cdcpgDBClusterParameterGroupName' -> Text -- ^ 'cdcpgDBParameterGroupFamily' -> Text -- ^ 'cdcpgDescription' -> CreateDBClusterParameterGroup createDBClusterParameterGroup pDBClusterParameterGroupName_ pDBParameterGroupFamily_ pDescription_ = CreateDBClusterParameterGroup' { _cdcpgTags = Nothing , _cdcpgDBClusterParameterGroupName = pDBClusterParameterGroupName_ , _cdcpgDBParameterGroupFamily = pDBParameterGroupFamily_ , _cdcpgDescription = pDescription_ } -- | Undocumented member. cdcpgTags :: Lens' CreateDBClusterParameterGroup [Tag] cdcpgTags = lens _cdcpgTags (\ s a -> s{_cdcpgTags = a}) . _Default . _Coerce; -- | The name of the DB cluster parameter group. -- -- Constraints: -- -- - Must be 1 to 255 alphanumeric characters -- - First character must be a letter -- - Cannot end with a hyphen or contain two consecutive hyphens -- -- This value is stored as a lowercase string. cdcpgDBClusterParameterGroupName :: Lens' CreateDBClusterParameterGroup Text cdcpgDBClusterParameterGroupName = lens _cdcpgDBClusterParameterGroupName (\ s a -> s{_cdcpgDBClusterParameterGroupName = a}); -- | The DB cluster parameter group family name. A DB cluster parameter group -- can be associated with one and only one DB cluster parameter group -- family, and can be applied only to a DB cluster running a database -- engine and engine version compatible with that DB cluster parameter -- group family. cdcpgDBParameterGroupFamily :: Lens' CreateDBClusterParameterGroup Text cdcpgDBParameterGroupFamily = lens _cdcpgDBParameterGroupFamily (\ s a -> s{_cdcpgDBParameterGroupFamily = a}); -- | The description for the DB cluster parameter group. cdcpgDescription :: Lens' CreateDBClusterParameterGroup Text cdcpgDescription = lens _cdcpgDescription (\ s a -> s{_cdcpgDescription = a}); instance AWSRequest CreateDBClusterParameterGroup where type Rs CreateDBClusterParameterGroup = CreateDBClusterParameterGroupResponse request = postQuery rDS response = receiveXMLWrapper "CreateDBClusterParameterGroupResult" (\ s h x -> CreateDBClusterParameterGroupResponse' <$> (x .@? "DBClusterParameterGroup") <*> (pure (fromEnum s))) instance ToHeaders CreateDBClusterParameterGroup where toHeaders = const mempty instance ToPath CreateDBClusterParameterGroup where toPath = const "/" instance ToQuery CreateDBClusterParameterGroup where toQuery CreateDBClusterParameterGroup'{..} = mconcat ["Action" =: ("CreateDBClusterParameterGroup" :: ByteString), "Version" =: ("2014-10-31" :: ByteString), "Tags" =: toQuery (toQueryList "Tag" <$> _cdcpgTags), "DBClusterParameterGroupName" =: _cdcpgDBClusterParameterGroupName, "DBParameterGroupFamily" =: _cdcpgDBParameterGroupFamily, "Description" =: _cdcpgDescription] -- | /See:/ 'createDBClusterParameterGroupResponse' smart constructor. data CreateDBClusterParameterGroupResponse = CreateDBClusterParameterGroupResponse' { _cdcpgrsDBClusterParameterGroup :: !(Maybe DBClusterParameterGroup) , _cdcpgrsStatus :: !Int } deriving (Eq,Read,Show,Data,Typeable,Generic) -- | Creates a value of 'CreateDBClusterParameterGroupResponse' with the minimum fields required to make a request. -- -- Use one of the following lenses to modify other fields as desired: -- -- * 'cdcpgrsDBClusterParameterGroup' -- -- * 'cdcpgrsStatus' createDBClusterParameterGroupResponse :: Int -- ^ 'cdcpgrsStatus' -> CreateDBClusterParameterGroupResponse createDBClusterParameterGroupResponse pStatus_ = CreateDBClusterParameterGroupResponse' { _cdcpgrsDBClusterParameterGroup = Nothing , _cdcpgrsStatus = pStatus_ } -- | Undocumented member. cdcpgrsDBClusterParameterGroup :: Lens' CreateDBClusterParameterGroupResponse (Maybe DBClusterParameterGroup) cdcpgrsDBClusterParameterGroup = lens _cdcpgrsDBClusterParameterGroup (\ s a -> s{_cdcpgrsDBClusterParameterGroup = a}); -- | The response status code. cdcpgrsStatus :: Lens' CreateDBClusterParameterGroupResponse Int cdcpgrsStatus = lens _cdcpgrsStatus (\ s a -> s{_cdcpgrsStatus = a});