{-# 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.Inspector.DescribeAssessmentTemplates
-- Copyright   : (c) 2013-2016 Brendan Hay
-- License     : Mozilla Public License, v. 2.0.
-- Maintainer  : Brendan Hay <brendan.g.hay@gmail.com>
-- Stability   : auto-generated
-- Portability : non-portable (GHC extensions)
--
-- Describes the assessment templates that are specified by the ARNs of the
-- assessment templates.
module Network.AWS.Inspector.DescribeAssessmentTemplates
    (
    -- * Creating a Request
      describeAssessmentTemplates
    , DescribeAssessmentTemplates
    -- * Request Lenses
    , datAssessmentTemplateARNs

    -- * Destructuring the Response
    , describeAssessmentTemplatesResponse
    , DescribeAssessmentTemplatesResponse
    -- * Response Lenses
    , datrsResponseStatus
    , datrsAssessmentTemplates
    , datrsFailedItems
    ) where

import           Network.AWS.Inspector.Types
import           Network.AWS.Inspector.Types.Product
import           Network.AWS.Lens
import           Network.AWS.Prelude
import           Network.AWS.Request
import           Network.AWS.Response

-- | /See:/ 'describeAssessmentTemplates' smart constructor.
newtype DescribeAssessmentTemplates = DescribeAssessmentTemplates'
    { _datAssessmentTemplateARNs :: List1 Text
    } deriving (Eq,Read,Show,Data,Typeable,Generic)

-- | Creates a value of 'DescribeAssessmentTemplates' with the minimum fields required to make a request.
--
-- Use one of the following lenses to modify other fields as desired:
--
-- * 'datAssessmentTemplateARNs'
describeAssessmentTemplates
    :: NonEmpty Text -- ^ 'datAssessmentTemplateARNs'
    -> DescribeAssessmentTemplates
describeAssessmentTemplates pAssessmentTemplateARNs_ =
    DescribeAssessmentTemplates'
    { _datAssessmentTemplateARNs = _List1 # pAssessmentTemplateARNs_
    }

-- | The ARN that specifiesthe assessment templates that you want to
-- describe.
datAssessmentTemplateARNs :: Lens' DescribeAssessmentTemplates (NonEmpty Text)
datAssessmentTemplateARNs = lens _datAssessmentTemplateARNs (\ s a -> s{_datAssessmentTemplateARNs = a}) . _List1;

instance AWSRequest DescribeAssessmentTemplates where
        type Rs DescribeAssessmentTemplates =
             DescribeAssessmentTemplatesResponse
        request = postJSON inspector
        response
          = receiveJSON
              (\ s h x ->
                 DescribeAssessmentTemplatesResponse' <$>
                   (pure (fromEnum s)) <*>
                     (x .?> "assessmentTemplates" .!@ mempty)
                     <*> (x .?> "failedItems" .!@ mempty))

instance Hashable DescribeAssessmentTemplates

instance NFData DescribeAssessmentTemplates

instance ToHeaders DescribeAssessmentTemplates where
        toHeaders
          = const
              (mconcat
                 ["X-Amz-Target" =#
                    ("InspectorService.DescribeAssessmentTemplates" ::
                       ByteString),
                  "Content-Type" =#
                    ("application/x-amz-json-1.1" :: ByteString)])

instance ToJSON DescribeAssessmentTemplates where
        toJSON DescribeAssessmentTemplates'{..}
          = object
              (catMaybes
                 [Just
                    ("assessmentTemplateArns" .=
                       _datAssessmentTemplateARNs)])

instance ToPath DescribeAssessmentTemplates where
        toPath = const "/"

instance ToQuery DescribeAssessmentTemplates where
        toQuery = const mempty

-- | /See:/ 'describeAssessmentTemplatesResponse' smart constructor.
data DescribeAssessmentTemplatesResponse = DescribeAssessmentTemplatesResponse'
    { _datrsResponseStatus      :: !Int
    , _datrsAssessmentTemplates :: ![AssessmentTemplate]
    , _datrsFailedItems         :: !(Map Text FailedItemDetails)
    } deriving (Eq,Read,Show,Data,Typeable,Generic)

-- | Creates a value of 'DescribeAssessmentTemplatesResponse' with the minimum fields required to make a request.
--
-- Use one of the following lenses to modify other fields as desired:
--
-- * 'datrsResponseStatus'
--
-- * 'datrsAssessmentTemplates'
--
-- * 'datrsFailedItems'
describeAssessmentTemplatesResponse
    :: Int -- ^ 'datrsResponseStatus'
    -> DescribeAssessmentTemplatesResponse
describeAssessmentTemplatesResponse pResponseStatus_ =
    DescribeAssessmentTemplatesResponse'
    { _datrsResponseStatus = pResponseStatus_
    , _datrsAssessmentTemplates = mempty
    , _datrsFailedItems = mempty
    }

-- | The response status code.
datrsResponseStatus :: Lens' DescribeAssessmentTemplatesResponse Int
datrsResponseStatus = lens _datrsResponseStatus (\ s a -> s{_datrsResponseStatus = a});

-- | Information about the assessment templates.
datrsAssessmentTemplates :: Lens' DescribeAssessmentTemplatesResponse [AssessmentTemplate]
datrsAssessmentTemplates = lens _datrsAssessmentTemplates (\ s a -> s{_datrsAssessmentTemplates = a}) . _Coerce;

-- | Assessment template details that cannot be described. An error code is
-- provided for each failed item.
datrsFailedItems :: Lens' DescribeAssessmentTemplatesResponse (HashMap Text FailedItemDetails)
datrsFailedItems = lens _datrsFailedItems (\ s a -> s{_datrsFailedItems = a}) . _Map;

instance NFData DescribeAssessmentTemplatesResponse