{-# 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.KMS.UntagResource -- Copyright : (c) 2013-2018 Brendan Hay -- License : Mozilla Public License, v. 2.0. -- Maintainer : Brendan Hay -- Stability : auto-generated -- Portability : non-portable (GHC extensions) -- -- Removes the specified tag or tags from the specified customer master key (CMK). You cannot perform this operation on a CMK in a different AWS account. -- -- -- To remove a tag, you specify the tag key for each tag to remove. You do not specify the tag value. To overwrite the tag value for an existing tag, use 'TagResource' . -- module Network.AWS.KMS.UntagResource ( -- * Creating a Request untagResource , UntagResource -- * Request Lenses , urKeyId , urTagKeys -- * Destructuring the Response , untagResourceResponse , UntagResourceResponse ) where import Network.AWS.KMS.Types import Network.AWS.KMS.Types.Product import Network.AWS.Lens import Network.AWS.Prelude import Network.AWS.Request import Network.AWS.Response -- | /See:/ 'untagResource' smart constructor. data UntagResource = UntagResource' { _urKeyId :: !Text , _urTagKeys :: ![Text] } deriving (Eq, Read, Show, Data, Typeable, Generic) -- | Creates a value of 'UntagResource' with the minimum fields required to make a request. -- -- Use one of the following lenses to modify other fields as desired: -- -- * 'urKeyId' - A unique identifier for the CMK from which you are removing tags. Specify the key ID or the Amazon Resource Name (ARN) of the CMK. For example: * Key ID: @1234abcd-12ab-34cd-56ef-1234567890ab@ * Key ARN: @arn:aws:kms:us-east-2:111122223333:key/1234abcd-12ab-34cd-56ef-1234567890ab@ To get the key ID and key ARN for a CMK, use 'ListKeys' or 'DescribeKey' . -- -- * 'urTagKeys' - One or more tag keys. Specify only the tag keys, not the tag values. untagResource :: Text -- ^ 'urKeyId' -> UntagResource untagResource pKeyId_ = UntagResource' {_urKeyId = pKeyId_, _urTagKeys = mempty} -- | A unique identifier for the CMK from which you are removing tags. Specify the key ID or the Amazon Resource Name (ARN) of the CMK. For example: * Key ID: @1234abcd-12ab-34cd-56ef-1234567890ab@ * Key ARN: @arn:aws:kms:us-east-2:111122223333:key/1234abcd-12ab-34cd-56ef-1234567890ab@ To get the key ID and key ARN for a CMK, use 'ListKeys' or 'DescribeKey' . urKeyId :: Lens' UntagResource Text urKeyId = lens _urKeyId (\ s a -> s{_urKeyId = a}) -- | One or more tag keys. Specify only the tag keys, not the tag values. urTagKeys :: Lens' UntagResource [Text] urTagKeys = lens _urTagKeys (\ s a -> s{_urTagKeys = a}) . _Coerce instance AWSRequest UntagResource where type Rs UntagResource = UntagResourceResponse request = postJSON kms response = receiveNull UntagResourceResponse' instance Hashable UntagResource where instance NFData UntagResource where instance ToHeaders UntagResource where toHeaders = const (mconcat ["X-Amz-Target" =# ("TrentService.UntagResource" :: ByteString), "Content-Type" =# ("application/x-amz-json-1.1" :: ByteString)]) instance ToJSON UntagResource where toJSON UntagResource'{..} = object (catMaybes [Just ("KeyId" .= _urKeyId), Just ("TagKeys" .= _urTagKeys)]) instance ToPath UntagResource where toPath = const "/" instance ToQuery UntagResource where toQuery = const mempty -- | /See:/ 'untagResourceResponse' smart constructor. data UntagResourceResponse = UntagResourceResponse' deriving (Eq, Read, Show, Data, Typeable, Generic) -- | Creates a value of 'UntagResourceResponse' with the minimum fields required to make a request. -- untagResourceResponse :: UntagResourceResponse untagResourceResponse = UntagResourceResponse' instance NFData UntagResourceResponse where