module Network.AWS.ServiceCatalog.DescribePortfolio
    (
    
      describePortfolio
    , DescribePortfolio
    
    , desAcceptLanguage
    , desId
    
    , describePortfolioResponse
    , DescribePortfolioResponse
    
    , dprsPortfolioDetail
    , dprsTagOptions
    , dprsTags
    , dprsResponseStatus
    ) where
import Network.AWS.Lens
import Network.AWS.Prelude
import Network.AWS.Request
import Network.AWS.Response
import Network.AWS.ServiceCatalog.Types
import Network.AWS.ServiceCatalog.Types.Product
data DescribePortfolio = DescribePortfolio'
  { _desAcceptLanguage :: !(Maybe Text)
  , _desId             :: !Text
  } deriving (Eq, Read, Show, Data, Typeable, Generic)
describePortfolio
    :: Text 
    -> DescribePortfolio
describePortfolio pId_ =
  DescribePortfolio' {_desAcceptLanguage = Nothing, _desId = pId_}
desAcceptLanguage :: Lens' DescribePortfolio (Maybe Text)
desAcceptLanguage = lens _desAcceptLanguage (\ s a -> s{_desAcceptLanguage = a});
desId :: Lens' DescribePortfolio Text
desId = lens _desId (\ s a -> s{_desId = a});
instance AWSRequest DescribePortfolio where
        type Rs DescribePortfolio = DescribePortfolioResponse
        request = postJSON serviceCatalog
        response
          = receiveJSON
              (\ s h x ->
                 DescribePortfolioResponse' <$>
                   (x .?> "PortfolioDetail") <*>
                     (x .?> "TagOptions" .!@ mempty)
                     <*> (x .?> "Tags" .!@ mempty)
                     <*> (pure (fromEnum s)))
instance Hashable DescribePortfolio where
instance NFData DescribePortfolio where
instance ToHeaders DescribePortfolio where
        toHeaders
          = const
              (mconcat
                 ["X-Amz-Target" =#
                    ("AWS242ServiceCatalogService.DescribePortfolio" ::
                       ByteString),
                  "Content-Type" =#
                    ("application/x-amz-json-1.1" :: ByteString)])
instance ToJSON DescribePortfolio where
        toJSON DescribePortfolio'{..}
          = object
              (catMaybes
                 [("AcceptLanguage" .=) <$> _desAcceptLanguage,
                  Just ("Id" .= _desId)])
instance ToPath DescribePortfolio where
        toPath = const "/"
instance ToQuery DescribePortfolio where
        toQuery = const mempty
data DescribePortfolioResponse = DescribePortfolioResponse'
  { _dprsPortfolioDetail :: !(Maybe PortfolioDetail)
  , _dprsTagOptions      :: !(Maybe [TagOptionDetail])
  , _dprsTags            :: !(Maybe [Tag])
  , _dprsResponseStatus  :: !Int
  } deriving (Eq, Read, Show, Data, Typeable, Generic)
describePortfolioResponse
    :: Int 
    -> DescribePortfolioResponse
describePortfolioResponse pResponseStatus_ =
  DescribePortfolioResponse'
  { _dprsPortfolioDetail = Nothing
  , _dprsTagOptions = Nothing
  , _dprsTags = Nothing
  , _dprsResponseStatus = pResponseStatus_
  }
dprsPortfolioDetail :: Lens' DescribePortfolioResponse (Maybe PortfolioDetail)
dprsPortfolioDetail = lens _dprsPortfolioDetail (\ s a -> s{_dprsPortfolioDetail = a});
dprsTagOptions :: Lens' DescribePortfolioResponse [TagOptionDetail]
dprsTagOptions = lens _dprsTagOptions (\ s a -> s{_dprsTagOptions = a}) . _Default . _Coerce;
dprsTags :: Lens' DescribePortfolioResponse [Tag]
dprsTags = lens _dprsTags (\ s a -> s{_dprsTags = a}) . _Default . _Coerce;
dprsResponseStatus :: Lens' DescribePortfolioResponse Int
dprsResponseStatus = lens _dprsResponseStatus (\ s a -> s{_dprsResponseStatus = a});
instance NFData DescribePortfolioResponse where