{-# 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.IAM.UploadSigningCertificate -- Copyright : (c) 2013-2016 Brendan Hay -- License : Mozilla Public License, v. 2.0. -- Maintainer : Brendan Hay -- Stability : auto-generated -- Portability : non-portable (GHC extensions) -- -- Uploads an X.509 signing certificate and associates it with the specified IAM user. Some AWS services use X.509 signing certificates to validate requests that are signed with a corresponding private key. When you upload the certificate, its default status is 'Active'. -- -- If the 'UserName' field is not specified, the IAM user name is determined implicitly based on the AWS access key ID used to sign the request. Because this action works for access keys under the AWS account, you can use this action to manage root credentials even if the AWS account has no associated users. -- -- Because the body of a X.509 certificate can be large, you should use POST rather than GET when calling 'UploadSigningCertificate'. For information about setting up signatures and authorization through the API, go to in the /AWS General Reference/. For general information about using the Query API with IAM, go to in the /IAM User Guide/. module Network.AWS.IAM.UploadSigningCertificate ( -- * Creating a Request uploadSigningCertificate , UploadSigningCertificate -- * Request Lenses , uplUserName , uplCertificateBody -- * Destructuring the Response , uploadSigningCertificateResponse , UploadSigningCertificateResponse -- * Response Lenses , uscrsResponseStatus , uscrsCertificate ) where import Network.AWS.IAM.Types import Network.AWS.IAM.Types.Product import Network.AWS.Lens import Network.AWS.Prelude import Network.AWS.Request import Network.AWS.Response -- | /See:/ 'uploadSigningCertificate' smart constructor. data UploadSigningCertificate = UploadSigningCertificate' { _uplUserName :: !(Maybe Text) , _uplCertificateBody :: !Text } deriving (Eq,Read,Show,Data,Typeable,Generic) -- | Creates a value of 'UploadSigningCertificate' with the minimum fields required to make a request. -- -- Use one of the following lenses to modify other fields as desired: -- -- * 'uplUserName' -- -- * 'uplCertificateBody' uploadSigningCertificate :: Text -- ^ 'uplCertificateBody' -> UploadSigningCertificate uploadSigningCertificate pCertificateBody_ = UploadSigningCertificate' { _uplUserName = Nothing , _uplCertificateBody = pCertificateBody_ } -- | The name of the user the signing certificate is for. -- -- The for this parameter is a string of characters consisting of upper and lowercase alphanumeric characters with no spaces. You can also include any of the following characters: =,.\'- uplUserName :: Lens' UploadSigningCertificate (Maybe Text) uplUserName = lens _uplUserName (\ s a -> s{_uplUserName = a}); -- | The contents of the signing certificate. -- -- The for this parameter is a string of characters consisting of any printable ASCII character ranging from the space character (\\u0020) through end of the ASCII character range (\\u00FF). It also includes the special characters tab (\\u0009), line feed (\\u000A), and carriage return (\\u000D). uplCertificateBody :: Lens' UploadSigningCertificate Text uplCertificateBody = lens _uplCertificateBody (\ s a -> s{_uplCertificateBody = a}); instance AWSRequest UploadSigningCertificate where type Rs UploadSigningCertificate = UploadSigningCertificateResponse request = postQuery iam response = receiveXMLWrapper "UploadSigningCertificateResult" (\ s h x -> UploadSigningCertificateResponse' <$> (pure (fromEnum s)) <*> (x .@ "Certificate")) instance Hashable UploadSigningCertificate instance NFData UploadSigningCertificate instance ToHeaders UploadSigningCertificate where toHeaders = const mempty instance ToPath UploadSigningCertificate where toPath = const "/" instance ToQuery UploadSigningCertificate where toQuery UploadSigningCertificate'{..} = mconcat ["Action" =: ("UploadSigningCertificate" :: ByteString), "Version" =: ("2010-05-08" :: ByteString), "UserName" =: _uplUserName, "CertificateBody" =: _uplCertificateBody] -- | Contains the response to a successful < UploadSigningCertificate> request. -- -- /See:/ 'uploadSigningCertificateResponse' smart constructor. data UploadSigningCertificateResponse = UploadSigningCertificateResponse' { _uscrsResponseStatus :: !Int , _uscrsCertificate :: !SigningCertificate } deriving (Eq,Read,Show,Data,Typeable,Generic) -- | Creates a value of 'UploadSigningCertificateResponse' with the minimum fields required to make a request. -- -- Use one of the following lenses to modify other fields as desired: -- -- * 'uscrsResponseStatus' -- -- * 'uscrsCertificate' uploadSigningCertificateResponse :: Int -- ^ 'uscrsResponseStatus' -> SigningCertificate -- ^ 'uscrsCertificate' -> UploadSigningCertificateResponse uploadSigningCertificateResponse pResponseStatus_ pCertificate_ = UploadSigningCertificateResponse' { _uscrsResponseStatus = pResponseStatus_ , _uscrsCertificate = pCertificate_ } -- | The response status code. uscrsResponseStatus :: Lens' UploadSigningCertificateResponse Int uscrsResponseStatus = lens _uscrsResponseStatus (\ s a -> s{_uscrsResponseStatus = a}); -- | Information about the certificate. uscrsCertificate :: Lens' UploadSigningCertificateResponse SigningCertificate uscrsCertificate = lens _uscrsCertificate (\ s a -> s{_uscrsCertificate = a}); instance NFData UploadSigningCertificateResponse