{-# 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.Route53Domains.UpdateTagsForDomain -- Copyright : (c) 2013-2015 Brendan Hay -- License : Mozilla Public License, v. 2.0. -- Maintainer : Brendan Hay -- Stability : auto-generated -- Portability : non-portable (GHC extensions) -- -- This operation adds or updates tags for a specified domain. -- -- All tag operations are eventually consistent; subsequent operations may -- not immediately represent all issued operations. -- -- /See:/ for UpdateTagsForDomain. module Network.AWS.Route53Domains.UpdateTagsForDomain ( -- * Creating a Request updateTagsForDomain , UpdateTagsForDomain -- * Request Lenses , utfdTagsToUpdate , utfdDomainName -- * Destructuring the Response , updateTagsForDomainResponse , UpdateTagsForDomainResponse -- * Response Lenses , utfdrsResponseStatus ) where import Network.AWS.Prelude import Network.AWS.Request import Network.AWS.Response import Network.AWS.Route53Domains.Types import Network.AWS.Route53Domains.Types.Product -- | The UpdateTagsForDomainRequest includes the following elements. -- -- /See:/ 'updateTagsForDomain' smart constructor. data UpdateTagsForDomain = UpdateTagsForDomain' { _utfdTagsToUpdate :: !(Maybe [Tag]) , _utfdDomainName :: !Text } deriving (Eq,Read,Show,Data,Typeable,Generic) -- | Creates a value of 'UpdateTagsForDomain' with the minimum fields required to make a request. -- -- Use one of the following lenses to modify other fields as desired: -- -- * 'utfdTagsToUpdate' -- -- * 'utfdDomainName' updateTagsForDomain :: Text -- ^ 'utfdDomainName' -> UpdateTagsForDomain updateTagsForDomain pDomainName_ = UpdateTagsForDomain' { _utfdTagsToUpdate = Nothing , _utfdDomainName = pDomainName_ } -- | A list of the tag keys and values that you want to add or update. If you -- specify a key that already exists, the corresponding value will be -- replaced. -- -- Type: A complex type containing a list of tags -- -- Default: None -- -- Required: No -- -- \'> -- -- Each tag includes the following elements: -- -- - Key -- -- The key (name) of a tag. -- -- Type: String -- -- Default: None -- -- Valid values: Unicode characters including alphanumeric, space, and -- \".:\/=+\\-\'\" -- -- Constraints: Each key can be 1-128 characters long. -- -- Required: Yes -- -- - Value -- -- The value of a tag. -- -- Type: String -- -- Default: None -- -- Valid values: Unicode characters including alphanumeric, space, and -- \".:\/=+\\-\'\" -- -- Constraints: Each value can be 0-256 characters long. -- -- Required: Yes -- utfdTagsToUpdate :: Lens' UpdateTagsForDomain [Tag] utfdTagsToUpdate = lens _utfdTagsToUpdate (\ s a -> s{_utfdTagsToUpdate = a}) . _Default . _Coerce; -- | The domain for which you want to add or update tags. -- -- The name of a domain. -- -- Type: String -- -- Default: None -- -- Constraints: The domain name can contain only the letters a through z, -- the numbers 0 through 9, and hyphen (-). Hyphens are allowed only when -- theyaposre surrounded by letters, numbers, or other hyphens. You -- canapost specify a hyphen at the beginning or end of a label. To specify -- an Internationalized Domain Name, you must convert the name to Punycode. -- -- Required: Yes utfdDomainName :: Lens' UpdateTagsForDomain Text utfdDomainName = lens _utfdDomainName (\ s a -> s{_utfdDomainName = a}); instance AWSRequest UpdateTagsForDomain where type Rs UpdateTagsForDomain = UpdateTagsForDomainResponse request = postJSON route53Domains response = receiveEmpty (\ s h x -> UpdateTagsForDomainResponse' <$> (pure (fromEnum s))) instance ToHeaders UpdateTagsForDomain where toHeaders = const (mconcat ["X-Amz-Target" =# ("Route53Domains_v20140515.UpdateTagsForDomain" :: ByteString), "Content-Type" =# ("application/x-amz-json-1.1" :: ByteString)]) instance ToJSON UpdateTagsForDomain where toJSON UpdateTagsForDomain'{..} = object (catMaybes [("TagsToUpdate" .=) <$> _utfdTagsToUpdate, Just ("DomainName" .= _utfdDomainName)]) instance ToPath UpdateTagsForDomain where toPath = const "/" instance ToQuery UpdateTagsForDomain where toQuery = const mempty -- | /See:/ 'updateTagsForDomainResponse' smart constructor. newtype UpdateTagsForDomainResponse = UpdateTagsForDomainResponse' { _utfdrsResponseStatus :: Int } deriving (Eq,Read,Show,Data,Typeable,Generic) -- | Creates a value of 'UpdateTagsForDomainResponse' with the minimum fields required to make a request. -- -- Use one of the following lenses to modify other fields as desired: -- -- * 'utfdrsResponseStatus' updateTagsForDomainResponse :: Int -- ^ 'utfdrsResponseStatus' -> UpdateTagsForDomainResponse updateTagsForDomainResponse pResponseStatus_ = UpdateTagsForDomainResponse' { _utfdrsResponseStatus = pResponseStatus_ } -- | The response status code. utfdrsResponseStatus :: Lens' UpdateTagsForDomainResponse Int utfdrsResponseStatus = lens _utfdrsResponseStatus (\ s a -> s{_utfdrsResponseStatus = a});