{-# 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.SDB.CreateDomain
(
createDomain
, CreateDomain
, cdDomainName
, createDomainResponse
, CreateDomainResponse
) where
import Network.AWS.Lens
import Network.AWS.Prelude
import Network.AWS.Request
import Network.AWS.Response
import Network.AWS.SDB.Types
import Network.AWS.SDB.Types.Product
newtype CreateDomain = CreateDomain'
{ _cdDomainName :: Text
} deriving (Eq,Read,Show,Data,Typeable,Generic)
createDomain
:: Text
-> CreateDomain
createDomain pDomainName_ =
CreateDomain'
{ _cdDomainName = pDomainName_
}
cdDomainName :: Lens' CreateDomain Text
cdDomainName = lens _cdDomainName (\ s a -> s{_cdDomainName = a});
instance AWSRequest CreateDomain where
type Rs CreateDomain = CreateDomainResponse
request = postQuery sdb
response = receiveNull CreateDomainResponse'
instance Hashable CreateDomain
instance NFData CreateDomain
instance ToHeaders CreateDomain where
toHeaders = const mempty
instance ToPath CreateDomain where
toPath = const "/"
instance ToQuery CreateDomain where
toQuery CreateDomain'{..}
= mconcat
["Action" =: ("CreateDomain" :: ByteString),
"Version" =: ("2009-04-15" :: ByteString),
"DomainName" =: _cdDomainName]
data CreateDomainResponse =
CreateDomainResponse'
deriving (Eq,Read,Show,Data,Typeable,Generic)
createDomainResponse
:: CreateDomainResponse
createDomainResponse = CreateDomainResponse'
instance NFData CreateDomainResponse