{-# 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.DeviceFarm.ListJobs -- Copyright : (c) 2013-2015 Brendan Hay -- License : Mozilla Public License, v. 2.0. -- Maintainer : Brendan Hay -- Stability : auto-generated -- Portability : non-portable (GHC extensions) -- -- Gets information about jobs. -- -- /See:/ for ListJobs. module Network.AWS.DeviceFarm.ListJobs ( -- * Creating a Request listJobs , ListJobs -- * Request Lenses , ljNextToken , ljArn -- * Destructuring the Response , listJobsResponse , ListJobsResponse -- * Response Lenses , ljrsJobs , ljrsNextToken , ljrsResponseStatus ) where import Network.AWS.DeviceFarm.Types import Network.AWS.DeviceFarm.Types.Product import Network.AWS.Prelude import Network.AWS.Request import Network.AWS.Response -- | Represents a request to the list jobs operation. -- -- /See:/ 'listJobs' smart constructor. data ListJobs = ListJobs' { _ljNextToken :: !(Maybe Text) , _ljArn :: !Text } deriving (Eq,Read,Show,Data,Typeable,Generic) -- | Creates a value of 'ListJobs' with the minimum fields required to make a request. -- -- Use one of the following lenses to modify other fields as desired: -- -- * 'ljNextToken' -- -- * 'ljArn' listJobs :: Text -- ^ 'ljArn' -> ListJobs listJobs pArn_ = ListJobs' { _ljNextToken = Nothing , _ljArn = pArn_ } -- | An identifier that was returned from the previous call to this -- operation, which can be used to return the next set of items in the -- list. ljNextToken :: Lens' ListJobs (Maybe Text) ljNextToken = lens _ljNextToken (\ s a -> s{_ljNextToken = a}); -- | The jobs\' ARNs. ljArn :: Lens' ListJobs Text ljArn = lens _ljArn (\ s a -> s{_ljArn = a}); instance AWSRequest ListJobs where type Rs ListJobs = ListJobsResponse request = postJSON deviceFarm response = receiveJSON (\ s h x -> ListJobsResponse' <$> (x .?> "jobs" .!@ mempty) <*> (x .?> "nextToken") <*> (pure (fromEnum s))) instance ToHeaders ListJobs where toHeaders = const (mconcat ["X-Amz-Target" =# ("DeviceFarm_20150623.ListJobs" :: ByteString), "Content-Type" =# ("application/x-amz-json-1.1" :: ByteString)]) instance ToJSON ListJobs where toJSON ListJobs'{..} = object (catMaybes [("nextToken" .=) <$> _ljNextToken, Just ("arn" .= _ljArn)]) instance ToPath ListJobs where toPath = const "/" instance ToQuery ListJobs where toQuery = const mempty -- | Represents the result of a list jobs request. -- -- /See:/ 'listJobsResponse' smart constructor. data ListJobsResponse = ListJobsResponse' { _ljrsJobs :: !(Maybe [Job]) , _ljrsNextToken :: !(Maybe Text) , _ljrsResponseStatus :: !Int } deriving (Eq,Read,Show,Data,Typeable,Generic) -- | Creates a value of 'ListJobsResponse' with the minimum fields required to make a request. -- -- Use one of the following lenses to modify other fields as desired: -- -- * 'ljrsJobs' -- -- * 'ljrsNextToken' -- -- * 'ljrsResponseStatus' listJobsResponse :: Int -- ^ 'ljrsResponseStatus' -> ListJobsResponse listJobsResponse pResponseStatus_ = ListJobsResponse' { _ljrsJobs = Nothing , _ljrsNextToken = Nothing , _ljrsResponseStatus = pResponseStatus_ } -- | Information about the jobs. ljrsJobs :: Lens' ListJobsResponse [Job] ljrsJobs = lens _ljrsJobs (\ s a -> s{_ljrsJobs = a}) . _Default . _Coerce; -- | If the number of items that are returned is significantly large, this is -- an identifier that is also returned, which can be used in a subsequent -- call to this operation to return the next set of items in the list. ljrsNextToken :: Lens' ListJobsResponse (Maybe Text) ljrsNextToken = lens _ljrsNextToken (\ s a -> s{_ljrsNextToken = a}); -- | The response status code. ljrsResponseStatus :: Lens' ListJobsResponse Int ljrsResponseStatus = lens _ljrsResponseStatus (\ s a -> s{_ljrsResponseStatus = a});