{-# LANGUAGE DeriveGeneric #-}
{-# LANGUAGE DuplicateRecordFields #-}
{-# LANGUAGE NamedFieldPuns #-}
{-# LANGUAGE OverloadedStrings #-}
{-# LANGUAGE RecordWildCards #-}
{-# LANGUAGE StrictData #-}
{-# LANGUAGE TypeFamilies #-}
{-# LANGUAGE NoImplicitPrelude #-}
{-# OPTIONS_GHC -fno-warn-unused-binds #-}
{-# OPTIONS_GHC -fno-warn-unused-imports #-}
{-# OPTIONS_GHC -fno-warn-unused-matches #-}

-- Derived from AWS service descriptions, licensed under Apache 2.0.

-- |
-- Module      : Amazonka.Omics.ListReferenceImportJobs
-- Copyright   : (c) 2013-2023 Brendan Hay
-- License     : Mozilla Public License, v. 2.0.
-- Maintainer  : Brendan Hay
-- Stability   : auto-generated
-- Portability : non-portable (GHC extensions)
--
-- Retrieves a list of reference import jobs.
--
-- This operation returns paginated results.
module Amazonka.Omics.ListReferenceImportJobs
  ( -- * Creating a Request
    ListReferenceImportJobs (..),
    newListReferenceImportJobs,

    -- * Request Lenses
    listReferenceImportJobs_filter,
    listReferenceImportJobs_maxResults,
    listReferenceImportJobs_nextToken,
    listReferenceImportJobs_referenceStoreId,

    -- * Destructuring the Response
    ListReferenceImportJobsResponse (..),
    newListReferenceImportJobsResponse,

    -- * Response Lenses
    listReferenceImportJobsResponse_importJobs,
    listReferenceImportJobsResponse_nextToken,
    listReferenceImportJobsResponse_httpStatus,
  )
where

import qualified Amazonka.Core as Core
import qualified Amazonka.Core.Lens.Internal as Lens
import qualified Amazonka.Data as Data
import Amazonka.Omics.Types
import qualified Amazonka.Prelude as Prelude
import qualified Amazonka.Request as Request
import qualified Amazonka.Response as Response

-- | /See:/ 'newListReferenceImportJobs' smart constructor.
data ListReferenceImportJobs = ListReferenceImportJobs'
  { -- | A filter to apply to the list.
    ListReferenceImportJobs -> Maybe ImportReferenceFilter
filter' :: Prelude.Maybe ImportReferenceFilter,
    -- | The maximum number of jobs to return in one page of results.
    ListReferenceImportJobs -> Maybe Natural
maxResults :: Prelude.Maybe Prelude.Natural,
    -- | Specify the pagination token from a previous request to retrieve the
    -- next page of results.
    ListReferenceImportJobs -> Maybe Text
nextToken :: Prelude.Maybe Prelude.Text,
    -- | The job\'s reference store ID.
    ListReferenceImportJobs -> Text
referenceStoreId :: Prelude.Text
  }
  deriving (ListReferenceImportJobs -> ListReferenceImportJobs -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: ListReferenceImportJobs -> ListReferenceImportJobs -> Bool
$c/= :: ListReferenceImportJobs -> ListReferenceImportJobs -> Bool
== :: ListReferenceImportJobs -> ListReferenceImportJobs -> Bool
$c== :: ListReferenceImportJobs -> ListReferenceImportJobs -> Bool
Prelude.Eq, ReadPrec [ListReferenceImportJobs]
ReadPrec ListReferenceImportJobs
Int -> ReadS ListReferenceImportJobs
ReadS [ListReferenceImportJobs]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [ListReferenceImportJobs]
$creadListPrec :: ReadPrec [ListReferenceImportJobs]
readPrec :: ReadPrec ListReferenceImportJobs
$creadPrec :: ReadPrec ListReferenceImportJobs
readList :: ReadS [ListReferenceImportJobs]
$creadList :: ReadS [ListReferenceImportJobs]
readsPrec :: Int -> ReadS ListReferenceImportJobs
$creadsPrec :: Int -> ReadS ListReferenceImportJobs
Prelude.Read, Int -> ListReferenceImportJobs -> ShowS
[ListReferenceImportJobs] -> ShowS
ListReferenceImportJobs -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [ListReferenceImportJobs] -> ShowS
$cshowList :: [ListReferenceImportJobs] -> ShowS
show :: ListReferenceImportJobs -> String
$cshow :: ListReferenceImportJobs -> String
showsPrec :: Int -> ListReferenceImportJobs -> ShowS
$cshowsPrec :: Int -> ListReferenceImportJobs -> ShowS
Prelude.Show, forall x. Rep ListReferenceImportJobs x -> ListReferenceImportJobs
forall x. ListReferenceImportJobs -> Rep ListReferenceImportJobs x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep ListReferenceImportJobs x -> ListReferenceImportJobs
$cfrom :: forall x. ListReferenceImportJobs -> Rep ListReferenceImportJobs x
Prelude.Generic)

-- |
-- Create a value of 'ListReferenceImportJobs' with all optional fields omitted.
--
-- Use <https://hackage.haskell.org/package/generic-lens generic-lens> or <https://hackage.haskell.org/package/optics optics> to modify other optional fields.
--
-- The following record fields are available, with the corresponding lenses provided
-- for backwards compatibility:
--
-- 'filter'', 'listReferenceImportJobs_filter' - A filter to apply to the list.
--
-- 'maxResults', 'listReferenceImportJobs_maxResults' - The maximum number of jobs to return in one page of results.
--
-- 'nextToken', 'listReferenceImportJobs_nextToken' - Specify the pagination token from a previous request to retrieve the
-- next page of results.
--
-- 'referenceStoreId', 'listReferenceImportJobs_referenceStoreId' - The job\'s reference store ID.
newListReferenceImportJobs ::
  -- | 'referenceStoreId'
  Prelude.Text ->
  ListReferenceImportJobs
newListReferenceImportJobs :: Text -> ListReferenceImportJobs
newListReferenceImportJobs Text
pReferenceStoreId_ =
  ListReferenceImportJobs'
    { $sel:filter':ListReferenceImportJobs' :: Maybe ImportReferenceFilter
filter' = forall a. Maybe a
Prelude.Nothing,
      $sel:maxResults:ListReferenceImportJobs' :: Maybe Natural
maxResults = forall a. Maybe a
Prelude.Nothing,
      $sel:nextToken:ListReferenceImportJobs' :: Maybe Text
nextToken = forall a. Maybe a
Prelude.Nothing,
      $sel:referenceStoreId:ListReferenceImportJobs' :: Text
referenceStoreId = Text
pReferenceStoreId_
    }

-- | A filter to apply to the list.
listReferenceImportJobs_filter :: Lens.Lens' ListReferenceImportJobs (Prelude.Maybe ImportReferenceFilter)
listReferenceImportJobs_filter :: Lens' ListReferenceImportJobs (Maybe ImportReferenceFilter)
listReferenceImportJobs_filter = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\ListReferenceImportJobs' {Maybe ImportReferenceFilter
filter' :: Maybe ImportReferenceFilter
$sel:filter':ListReferenceImportJobs' :: ListReferenceImportJobs -> Maybe ImportReferenceFilter
filter'} -> Maybe ImportReferenceFilter
filter') (\s :: ListReferenceImportJobs
s@ListReferenceImportJobs' {} Maybe ImportReferenceFilter
a -> ListReferenceImportJobs
s {$sel:filter':ListReferenceImportJobs' :: Maybe ImportReferenceFilter
filter' = Maybe ImportReferenceFilter
a} :: ListReferenceImportJobs)

-- | The maximum number of jobs to return in one page of results.
listReferenceImportJobs_maxResults :: Lens.Lens' ListReferenceImportJobs (Prelude.Maybe Prelude.Natural)
listReferenceImportJobs_maxResults :: Lens' ListReferenceImportJobs (Maybe Natural)
listReferenceImportJobs_maxResults = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\ListReferenceImportJobs' {Maybe Natural
maxResults :: Maybe Natural
$sel:maxResults:ListReferenceImportJobs' :: ListReferenceImportJobs -> Maybe Natural
maxResults} -> Maybe Natural
maxResults) (\s :: ListReferenceImportJobs
s@ListReferenceImportJobs' {} Maybe Natural
a -> ListReferenceImportJobs
s {$sel:maxResults:ListReferenceImportJobs' :: Maybe Natural
maxResults = Maybe Natural
a} :: ListReferenceImportJobs)

-- | Specify the pagination token from a previous request to retrieve the
-- next page of results.
listReferenceImportJobs_nextToken :: Lens.Lens' ListReferenceImportJobs (Prelude.Maybe Prelude.Text)
listReferenceImportJobs_nextToken :: Lens' ListReferenceImportJobs (Maybe Text)
listReferenceImportJobs_nextToken = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\ListReferenceImportJobs' {Maybe Text
nextToken :: Maybe Text
$sel:nextToken:ListReferenceImportJobs' :: ListReferenceImportJobs -> Maybe Text
nextToken} -> Maybe Text
nextToken) (\s :: ListReferenceImportJobs
s@ListReferenceImportJobs' {} Maybe Text
a -> ListReferenceImportJobs
s {$sel:nextToken:ListReferenceImportJobs' :: Maybe Text
nextToken = Maybe Text
a} :: ListReferenceImportJobs)

-- | The job\'s reference store ID.
listReferenceImportJobs_referenceStoreId :: Lens.Lens' ListReferenceImportJobs Prelude.Text
listReferenceImportJobs_referenceStoreId :: Lens' ListReferenceImportJobs Text
listReferenceImportJobs_referenceStoreId = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\ListReferenceImportJobs' {Text
referenceStoreId :: Text
$sel:referenceStoreId:ListReferenceImportJobs' :: ListReferenceImportJobs -> Text
referenceStoreId} -> Text
referenceStoreId) (\s :: ListReferenceImportJobs
s@ListReferenceImportJobs' {} Text
a -> ListReferenceImportJobs
s {$sel:referenceStoreId:ListReferenceImportJobs' :: Text
referenceStoreId = Text
a} :: ListReferenceImportJobs)

instance Core.AWSPager ListReferenceImportJobs where
  page :: ListReferenceImportJobs
-> AWSResponse ListReferenceImportJobs
-> Maybe ListReferenceImportJobs
page ListReferenceImportJobs
rq AWSResponse ListReferenceImportJobs
rs
    | forall a. AWSTruncated a => a -> Bool
Core.stop
        ( AWSResponse ListReferenceImportJobs
rs
            forall s a. s -> Getting (First a) s a -> Maybe a
Lens.^? Lens' ListReferenceImportJobsResponse (Maybe Text)
listReferenceImportJobsResponse_nextToken
            forall b c a. (b -> c) -> (a -> b) -> a -> c
Prelude.. forall a b. Prism (Maybe a) (Maybe b) a b
Lens._Just
        ) =
        forall a. Maybe a
Prelude.Nothing
    | forall a. AWSTruncated a => a -> Bool
Core.stop
        ( AWSResponse ListReferenceImportJobs
rs
            forall s a. s -> Getting (First a) s a -> Maybe a
Lens.^? Lens'
  ListReferenceImportJobsResponse (Maybe [ImportReferenceJobItem])
listReferenceImportJobsResponse_importJobs
            forall b c a. (b -> c) -> (a -> b) -> a -> c
Prelude.. forall a b. Prism (Maybe a) (Maybe b) a b
Lens._Just
        ) =
        forall a. Maybe a
Prelude.Nothing
    | Bool
Prelude.otherwise =
        forall a. a -> Maybe a
Prelude.Just
          forall a b. (a -> b) -> a -> b
Prelude.$ ListReferenceImportJobs
rq
          forall a b. a -> (a -> b) -> b
Prelude.& Lens' ListReferenceImportJobs (Maybe Text)
listReferenceImportJobs_nextToken
          forall s t a b. ASetter s t a b -> b -> s -> t
Lens..~ AWSResponse ListReferenceImportJobs
rs
          forall s a. s -> Getting (First a) s a -> Maybe a
Lens.^? Lens' ListReferenceImportJobsResponse (Maybe Text)
listReferenceImportJobsResponse_nextToken
          forall b c a. (b -> c) -> (a -> b) -> a -> c
Prelude.. forall a b. Prism (Maybe a) (Maybe b) a b
Lens._Just

instance Core.AWSRequest ListReferenceImportJobs where
  type
    AWSResponse ListReferenceImportJobs =
      ListReferenceImportJobsResponse
  request :: (Service -> Service)
-> ListReferenceImportJobs -> Request ListReferenceImportJobs
request Service -> Service
overrides =
    forall a. (ToRequest a, ToJSON a) => Service -> a -> Request a
Request.postJSON (Service -> Service
overrides Service
defaultService)
  response :: forall (m :: * -> *).
MonadResource m =>
(ByteStringLazy -> IO ByteStringLazy)
-> Service
-> Proxy ListReferenceImportJobs
-> ClientResponse ClientBody
-> m (Either
        Error (ClientResponse (AWSResponse ListReferenceImportJobs)))
response =
    forall (m :: * -> *) a.
MonadResource m =>
(Int -> ResponseHeaders -> Object -> Either String (AWSResponse a))
-> (ByteStringLazy -> IO ByteStringLazy)
-> Service
-> Proxy a
-> ClientResponse ClientBody
-> m (Either Error (ClientResponse (AWSResponse a)))
Response.receiveJSON
      ( \Int
s ResponseHeaders
h Object
x ->
          Maybe [ImportReferenceJobItem]
-> Maybe Text -> Int -> ListReferenceImportJobsResponse
ListReferenceImportJobsResponse'
            forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
Prelude.<$> (Object
x forall a. FromJSON a => Object -> Key -> Either String (Maybe a)
Data..?> Key
"importJobs" forall (f :: * -> *) a. Functor f => f (Maybe a) -> a -> f a
Core..!@ forall a. Monoid a => a
Prelude.mempty)
            forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
Prelude.<*> (Object
x forall a. FromJSON a => Object -> Key -> Either String (Maybe a)
Data..?> Key
"nextToken")
            forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
Prelude.<*> (forall (f :: * -> *) a. Applicative f => a -> f a
Prelude.pure (forall a. Enum a => a -> Int
Prelude.fromEnum Int
s))
      )

instance Prelude.Hashable ListReferenceImportJobs where
  hashWithSalt :: Int -> ListReferenceImportJobs -> Int
hashWithSalt Int
_salt ListReferenceImportJobs' {Maybe Natural
Maybe Text
Maybe ImportReferenceFilter
Text
referenceStoreId :: Text
nextToken :: Maybe Text
maxResults :: Maybe Natural
filter' :: Maybe ImportReferenceFilter
$sel:referenceStoreId:ListReferenceImportJobs' :: ListReferenceImportJobs -> Text
$sel:nextToken:ListReferenceImportJobs' :: ListReferenceImportJobs -> Maybe Text
$sel:maxResults:ListReferenceImportJobs' :: ListReferenceImportJobs -> Maybe Natural
$sel:filter':ListReferenceImportJobs' :: ListReferenceImportJobs -> Maybe ImportReferenceFilter
..} =
    Int
_salt
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe ImportReferenceFilter
filter'
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe Natural
maxResults
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe Text
nextToken
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Text
referenceStoreId

instance Prelude.NFData ListReferenceImportJobs where
  rnf :: ListReferenceImportJobs -> ()
rnf ListReferenceImportJobs' {Maybe Natural
Maybe Text
Maybe ImportReferenceFilter
Text
referenceStoreId :: Text
nextToken :: Maybe Text
maxResults :: Maybe Natural
filter' :: Maybe ImportReferenceFilter
$sel:referenceStoreId:ListReferenceImportJobs' :: ListReferenceImportJobs -> Text
$sel:nextToken:ListReferenceImportJobs' :: ListReferenceImportJobs -> Maybe Text
$sel:maxResults:ListReferenceImportJobs' :: ListReferenceImportJobs -> Maybe Natural
$sel:filter':ListReferenceImportJobs' :: ListReferenceImportJobs -> Maybe ImportReferenceFilter
..} =
    forall a. NFData a => a -> ()
Prelude.rnf Maybe ImportReferenceFilter
filter'
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe Natural
maxResults
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe Text
nextToken
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Text
referenceStoreId

instance Data.ToHeaders ListReferenceImportJobs where
  toHeaders :: ListReferenceImportJobs -> ResponseHeaders
toHeaders =
    forall a b. a -> b -> a
Prelude.const
      ( forall a. Monoid a => [a] -> a
Prelude.mconcat
          [ HeaderName
"Content-Type"
              forall a. ToHeader a => HeaderName -> a -> ResponseHeaders
Data.=# ( ByteString
"application/x-amz-json-1.1" ::
                          Prelude.ByteString
                      )
          ]
      )

instance Data.ToJSON ListReferenceImportJobs where
  toJSON :: ListReferenceImportJobs -> Value
toJSON ListReferenceImportJobs' {Maybe Natural
Maybe Text
Maybe ImportReferenceFilter
Text
referenceStoreId :: Text
nextToken :: Maybe Text
maxResults :: Maybe Natural
filter' :: Maybe ImportReferenceFilter
$sel:referenceStoreId:ListReferenceImportJobs' :: ListReferenceImportJobs -> Text
$sel:nextToken:ListReferenceImportJobs' :: ListReferenceImportJobs -> Maybe Text
$sel:maxResults:ListReferenceImportJobs' :: ListReferenceImportJobs -> Maybe Natural
$sel:filter':ListReferenceImportJobs' :: ListReferenceImportJobs -> Maybe ImportReferenceFilter
..} =
    [Pair] -> Value
Data.object
      ( forall a. [Maybe a] -> [a]
Prelude.catMaybes
          [(Key
"filter" forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
Data..=) forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
Prelude.<$> Maybe ImportReferenceFilter
filter']
      )

instance Data.ToPath ListReferenceImportJobs where
  toPath :: ListReferenceImportJobs -> ByteString
toPath ListReferenceImportJobs' {Maybe Natural
Maybe Text
Maybe ImportReferenceFilter
Text
referenceStoreId :: Text
nextToken :: Maybe Text
maxResults :: Maybe Natural
filter' :: Maybe ImportReferenceFilter
$sel:referenceStoreId:ListReferenceImportJobs' :: ListReferenceImportJobs -> Text
$sel:nextToken:ListReferenceImportJobs' :: ListReferenceImportJobs -> Maybe Text
$sel:maxResults:ListReferenceImportJobs' :: ListReferenceImportJobs -> Maybe Natural
$sel:filter':ListReferenceImportJobs' :: ListReferenceImportJobs -> Maybe ImportReferenceFilter
..} =
    forall a. Monoid a => [a] -> a
Prelude.mconcat
      [ ByteString
"/referencestore/",
        forall a. ToByteString a => a -> ByteString
Data.toBS Text
referenceStoreId,
        ByteString
"/importjobs"
      ]

instance Data.ToQuery ListReferenceImportJobs where
  toQuery :: ListReferenceImportJobs -> QueryString
toQuery ListReferenceImportJobs' {Maybe Natural
Maybe Text
Maybe ImportReferenceFilter
Text
referenceStoreId :: Text
nextToken :: Maybe Text
maxResults :: Maybe Natural
filter' :: Maybe ImportReferenceFilter
$sel:referenceStoreId:ListReferenceImportJobs' :: ListReferenceImportJobs -> Text
$sel:nextToken:ListReferenceImportJobs' :: ListReferenceImportJobs -> Maybe Text
$sel:maxResults:ListReferenceImportJobs' :: ListReferenceImportJobs -> Maybe Natural
$sel:filter':ListReferenceImportJobs' :: ListReferenceImportJobs -> Maybe ImportReferenceFilter
..} =
    forall a. Monoid a => [a] -> a
Prelude.mconcat
      [ ByteString
"maxResults" forall a. ToQuery a => ByteString -> a -> QueryString
Data.=: Maybe Natural
maxResults,
        ByteString
"nextToken" forall a. ToQuery a => ByteString -> a -> QueryString
Data.=: Maybe Text
nextToken
      ]

-- | /See:/ 'newListReferenceImportJobsResponse' smart constructor.
data ListReferenceImportJobsResponse = ListReferenceImportJobsResponse'
  { -- | A lis of jobs.
    ListReferenceImportJobsResponse -> Maybe [ImportReferenceJobItem]
importJobs :: Prelude.Maybe [ImportReferenceJobItem],
    -- | A pagination token that\'s included if more results are available.
    ListReferenceImportJobsResponse -> Maybe Text
nextToken :: Prelude.Maybe Prelude.Text,
    -- | The response's http status code.
    ListReferenceImportJobsResponse -> Int
httpStatus :: Prelude.Int
  }
  deriving (ListReferenceImportJobsResponse
-> ListReferenceImportJobsResponse -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: ListReferenceImportJobsResponse
-> ListReferenceImportJobsResponse -> Bool
$c/= :: ListReferenceImportJobsResponse
-> ListReferenceImportJobsResponse -> Bool
== :: ListReferenceImportJobsResponse
-> ListReferenceImportJobsResponse -> Bool
$c== :: ListReferenceImportJobsResponse
-> ListReferenceImportJobsResponse -> Bool
Prelude.Eq, ReadPrec [ListReferenceImportJobsResponse]
ReadPrec ListReferenceImportJobsResponse
Int -> ReadS ListReferenceImportJobsResponse
ReadS [ListReferenceImportJobsResponse]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [ListReferenceImportJobsResponse]
$creadListPrec :: ReadPrec [ListReferenceImportJobsResponse]
readPrec :: ReadPrec ListReferenceImportJobsResponse
$creadPrec :: ReadPrec ListReferenceImportJobsResponse
readList :: ReadS [ListReferenceImportJobsResponse]
$creadList :: ReadS [ListReferenceImportJobsResponse]
readsPrec :: Int -> ReadS ListReferenceImportJobsResponse
$creadsPrec :: Int -> ReadS ListReferenceImportJobsResponse
Prelude.Read, Int -> ListReferenceImportJobsResponse -> ShowS
[ListReferenceImportJobsResponse] -> ShowS
ListReferenceImportJobsResponse -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [ListReferenceImportJobsResponse] -> ShowS
$cshowList :: [ListReferenceImportJobsResponse] -> ShowS
show :: ListReferenceImportJobsResponse -> String
$cshow :: ListReferenceImportJobsResponse -> String
showsPrec :: Int -> ListReferenceImportJobsResponse -> ShowS
$cshowsPrec :: Int -> ListReferenceImportJobsResponse -> ShowS
Prelude.Show, forall x.
Rep ListReferenceImportJobsResponse x
-> ListReferenceImportJobsResponse
forall x.
ListReferenceImportJobsResponse
-> Rep ListReferenceImportJobsResponse x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x.
Rep ListReferenceImportJobsResponse x
-> ListReferenceImportJobsResponse
$cfrom :: forall x.
ListReferenceImportJobsResponse
-> Rep ListReferenceImportJobsResponse x
Prelude.Generic)

-- |
-- Create a value of 'ListReferenceImportJobsResponse' with all optional fields omitted.
--
-- Use <https://hackage.haskell.org/package/generic-lens generic-lens> or <https://hackage.haskell.org/package/optics optics> to modify other optional fields.
--
-- The following record fields are available, with the corresponding lenses provided
-- for backwards compatibility:
--
-- 'importJobs', 'listReferenceImportJobsResponse_importJobs' - A lis of jobs.
--
-- 'nextToken', 'listReferenceImportJobsResponse_nextToken' - A pagination token that\'s included if more results are available.
--
-- 'httpStatus', 'listReferenceImportJobsResponse_httpStatus' - The response's http status code.
newListReferenceImportJobsResponse ::
  -- | 'httpStatus'
  Prelude.Int ->
  ListReferenceImportJobsResponse
newListReferenceImportJobsResponse :: Int -> ListReferenceImportJobsResponse
newListReferenceImportJobsResponse Int
pHttpStatus_ =
  ListReferenceImportJobsResponse'
    { $sel:importJobs:ListReferenceImportJobsResponse' :: Maybe [ImportReferenceJobItem]
importJobs =
        forall a. Maybe a
Prelude.Nothing,
      $sel:nextToken:ListReferenceImportJobsResponse' :: Maybe Text
nextToken = forall a. Maybe a
Prelude.Nothing,
      $sel:httpStatus:ListReferenceImportJobsResponse' :: Int
httpStatus = Int
pHttpStatus_
    }

-- | A lis of jobs.
listReferenceImportJobsResponse_importJobs :: Lens.Lens' ListReferenceImportJobsResponse (Prelude.Maybe [ImportReferenceJobItem])
listReferenceImportJobsResponse_importJobs :: Lens'
  ListReferenceImportJobsResponse (Maybe [ImportReferenceJobItem])
listReferenceImportJobsResponse_importJobs = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\ListReferenceImportJobsResponse' {Maybe [ImportReferenceJobItem]
importJobs :: Maybe [ImportReferenceJobItem]
$sel:importJobs:ListReferenceImportJobsResponse' :: ListReferenceImportJobsResponse -> Maybe [ImportReferenceJobItem]
importJobs} -> Maybe [ImportReferenceJobItem]
importJobs) (\s :: ListReferenceImportJobsResponse
s@ListReferenceImportJobsResponse' {} Maybe [ImportReferenceJobItem]
a -> ListReferenceImportJobsResponse
s {$sel:importJobs:ListReferenceImportJobsResponse' :: Maybe [ImportReferenceJobItem]
importJobs = Maybe [ImportReferenceJobItem]
a} :: ListReferenceImportJobsResponse) forall b c a. (b -> c) -> (a -> b) -> a -> c
Prelude.. forall (f :: * -> *) (g :: * -> *) s t a b.
(Functor f, Functor g) =>
AnIso s t a b -> Iso (f s) (g t) (f a) (g b)
Lens.mapping forall s t a b. (Coercible s a, Coercible t b) => Iso s t a b
Lens.coerced

-- | A pagination token that\'s included if more results are available.
listReferenceImportJobsResponse_nextToken :: Lens.Lens' ListReferenceImportJobsResponse (Prelude.Maybe Prelude.Text)
listReferenceImportJobsResponse_nextToken :: Lens' ListReferenceImportJobsResponse (Maybe Text)
listReferenceImportJobsResponse_nextToken = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\ListReferenceImportJobsResponse' {Maybe Text
nextToken :: Maybe Text
$sel:nextToken:ListReferenceImportJobsResponse' :: ListReferenceImportJobsResponse -> Maybe Text
nextToken} -> Maybe Text
nextToken) (\s :: ListReferenceImportJobsResponse
s@ListReferenceImportJobsResponse' {} Maybe Text
a -> ListReferenceImportJobsResponse
s {$sel:nextToken:ListReferenceImportJobsResponse' :: Maybe Text
nextToken = Maybe Text
a} :: ListReferenceImportJobsResponse)

-- | The response's http status code.
listReferenceImportJobsResponse_httpStatus :: Lens.Lens' ListReferenceImportJobsResponse Prelude.Int
listReferenceImportJobsResponse_httpStatus :: Lens' ListReferenceImportJobsResponse Int
listReferenceImportJobsResponse_httpStatus = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\ListReferenceImportJobsResponse' {Int
httpStatus :: Int
$sel:httpStatus:ListReferenceImportJobsResponse' :: ListReferenceImportJobsResponse -> Int
httpStatus} -> Int
httpStatus) (\s :: ListReferenceImportJobsResponse
s@ListReferenceImportJobsResponse' {} Int
a -> ListReferenceImportJobsResponse
s {$sel:httpStatus:ListReferenceImportJobsResponse' :: Int
httpStatus = Int
a} :: ListReferenceImportJobsResponse)

instance
  Prelude.NFData
    ListReferenceImportJobsResponse
  where
  rnf :: ListReferenceImportJobsResponse -> ()
rnf ListReferenceImportJobsResponse' {Int
Maybe [ImportReferenceJobItem]
Maybe Text
httpStatus :: Int
nextToken :: Maybe Text
importJobs :: Maybe [ImportReferenceJobItem]
$sel:httpStatus:ListReferenceImportJobsResponse' :: ListReferenceImportJobsResponse -> Int
$sel:nextToken:ListReferenceImportJobsResponse' :: ListReferenceImportJobsResponse -> Maybe Text
$sel:importJobs:ListReferenceImportJobsResponse' :: ListReferenceImportJobsResponse -> Maybe [ImportReferenceJobItem]
..} =
    forall a. NFData a => a -> ()
Prelude.rnf Maybe [ImportReferenceJobItem]
importJobs
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe Text
nextToken
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Int
httpStatus