{-# 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 #-}
module Network.AWS.AppSync.GetDataSource
(
getDataSource
, GetDataSource
, gdsApiId
, gdsName
, getDataSourceResponse
, GetDataSourceResponse
, gdsrsDataSource
, gdsrsResponseStatus
) where
import Network.AWS.AppSync.Types
import Network.AWS.AppSync.Types.Product
import Network.AWS.Lens
import Network.AWS.Prelude
import Network.AWS.Request
import Network.AWS.Response
data GetDataSource = GetDataSource'
{ _gdsApiId :: !Text
, _gdsName :: !Text
} deriving (Eq, Read, Show, Data, Typeable, Generic)
getDataSource
:: Text
-> Text
-> GetDataSource
getDataSource pApiId_ pName_ =
GetDataSource' {_gdsApiId = pApiId_, _gdsName = pName_}
gdsApiId :: Lens' GetDataSource Text
gdsApiId = lens _gdsApiId (\ s a -> s{_gdsApiId = a})
gdsName :: Lens' GetDataSource Text
gdsName = lens _gdsName (\ s a -> s{_gdsName = a})
instance AWSRequest GetDataSource where
type Rs GetDataSource = GetDataSourceResponse
request = get appSync
response
= receiveJSON
(\ s h x ->
GetDataSourceResponse' <$>
(x .?> "dataSource") <*> (pure (fromEnum s)))
instance Hashable GetDataSource where
instance NFData GetDataSource where
instance ToHeaders GetDataSource where
toHeaders
= const
(mconcat
["Content-Type" =#
("application/x-amz-json-1.1" :: ByteString)])
instance ToPath GetDataSource where
toPath GetDataSource'{..}
= mconcat
["/v1/apis/", toBS _gdsApiId, "/datasources/",
toBS _gdsName]
instance ToQuery GetDataSource where
toQuery = const mempty
data GetDataSourceResponse = GetDataSourceResponse'
{ _gdsrsDataSource :: !(Maybe DataSource)
, _gdsrsResponseStatus :: !Int
} deriving (Eq, Read, Show, Data, Typeable, Generic)
getDataSourceResponse
:: Int
-> GetDataSourceResponse
getDataSourceResponse pResponseStatus_ =
GetDataSourceResponse'
{_gdsrsDataSource = Nothing, _gdsrsResponseStatus = pResponseStatus_}
gdsrsDataSource :: Lens' GetDataSourceResponse (Maybe DataSource)
gdsrsDataSource = lens _gdsrsDataSource (\ s a -> s{_gdsrsDataSource = a})
gdsrsResponseStatus :: Lens' GetDataSourceResponse Int
gdsrsResponseStatus = lens _gdsrsResponseStatus (\ s a -> s{_gdsrsResponseStatus = a})
instance NFData GetDataSourceResponse where