{-# 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.GuardDuty.DeclineInvitations -- Copyright : (c) 2013-2018 Brendan Hay -- License : Mozilla Public License, v. 2.0. -- Maintainer : Brendan Hay -- Stability : auto-generated -- Portability : non-portable (GHC extensions) -- -- Declines invitations sent to the current member account by AWS account specified by their account IDs. module Network.AWS.GuardDuty.DeclineInvitations ( -- * Creating a Request declineInvitations , DeclineInvitations -- * Request Lenses , dAccountIds -- * Destructuring the Response , declineInvitationsResponse , DeclineInvitationsResponse -- * Response Lenses , disrsUnprocessedAccounts , disrsResponseStatus ) where import Network.AWS.GuardDuty.Types import Network.AWS.GuardDuty.Types.Product import Network.AWS.Lens import Network.AWS.Prelude import Network.AWS.Request import Network.AWS.Response -- | DeclineInvitations request body. -- -- /See:/ 'declineInvitations' smart constructor. newtype DeclineInvitations = DeclineInvitations' { _dAccountIds :: Maybe [Text] } deriving (Eq, Read, Show, Data, Typeable, Generic) -- | Creates a value of 'DeclineInvitations' with the minimum fields required to make a request. -- -- Use one of the following lenses to modify other fields as desired: -- -- * 'dAccountIds' - A list of account IDs of the AWS accounts that sent invitations to the current member account that you want to decline invitations from. declineInvitations :: DeclineInvitations declineInvitations = DeclineInvitations' {_dAccountIds = Nothing} -- | A list of account IDs of the AWS accounts that sent invitations to the current member account that you want to decline invitations from. dAccountIds :: Lens' DeclineInvitations [Text] dAccountIds = lens _dAccountIds (\ s a -> s{_dAccountIds = a}) . _Default . _Coerce instance AWSRequest DeclineInvitations where type Rs DeclineInvitations = DeclineInvitationsResponse request = postJSON guardDuty response = receiveJSON (\ s h x -> DeclineInvitationsResponse' <$> (x .?> "unprocessedAccounts" .!@ mempty) <*> (pure (fromEnum s))) instance Hashable DeclineInvitations where instance NFData DeclineInvitations where instance ToHeaders DeclineInvitations where toHeaders = const (mconcat ["Content-Type" =# ("application/x-amz-json-1.1" :: ByteString)]) instance ToJSON DeclineInvitations where toJSON DeclineInvitations'{..} = object (catMaybes [("accountIds" .=) <$> _dAccountIds]) instance ToPath DeclineInvitations where toPath = const "/invitation/decline" instance ToQuery DeclineInvitations where toQuery = const mempty -- | /See:/ 'declineInvitationsResponse' smart constructor. data DeclineInvitationsResponse = DeclineInvitationsResponse' { _disrsUnprocessedAccounts :: !(Maybe [UnprocessedAccount]) , _disrsResponseStatus :: !Int } deriving (Eq, Read, Show, Data, Typeable, Generic) -- | Creates a value of 'DeclineInvitationsResponse' with the minimum fields required to make a request. -- -- Use one of the following lenses to modify other fields as desired: -- -- * 'disrsUnprocessedAccounts' - A list of objects containing the unprocessed account and a result string explaining why it was unprocessed. -- -- * 'disrsResponseStatus' - -- | The response status code. declineInvitationsResponse :: Int -- ^ 'disrsResponseStatus' -> DeclineInvitationsResponse declineInvitationsResponse pResponseStatus_ = DeclineInvitationsResponse' { _disrsUnprocessedAccounts = Nothing , _disrsResponseStatus = pResponseStatus_ } -- | A list of objects containing the unprocessed account and a result string explaining why it was unprocessed. disrsUnprocessedAccounts :: Lens' DeclineInvitationsResponse [UnprocessedAccount] disrsUnprocessedAccounts = lens _disrsUnprocessedAccounts (\ s a -> s{_disrsUnprocessedAccounts = a}) . _Default . _Coerce -- | -- | The response status code. disrsResponseStatus :: Lens' DeclineInvitationsResponse Int disrsResponseStatus = lens _disrsResponseStatus (\ s a -> s{_disrsResponseStatus = a}) instance NFData DeclineInvitationsResponse where