{-# 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.GetReadSetExportJob
-- Copyright   : (c) 2013-2023 Brendan Hay
-- License     : Mozilla Public License, v. 2.0.
-- Maintainer  : Brendan Hay
-- Stability   : auto-generated
-- Portability : non-portable (GHC extensions)
--
-- Gets information about a read set export job.
module Amazonka.Omics.GetReadSetExportJob
  ( -- * Creating a Request
    GetReadSetExportJob (..),
    newGetReadSetExportJob,

    -- * Request Lenses
    getReadSetExportJob_id,
    getReadSetExportJob_sequenceStoreId,

    -- * Destructuring the Response
    GetReadSetExportJobResponse (..),
    newGetReadSetExportJobResponse,

    -- * Response Lenses
    getReadSetExportJobResponse_completionTime,
    getReadSetExportJobResponse_readSets,
    getReadSetExportJobResponse_statusMessage,
    getReadSetExportJobResponse_httpStatus,
    getReadSetExportJobResponse_creationTime,
    getReadSetExportJobResponse_destination,
    getReadSetExportJobResponse_id,
    getReadSetExportJobResponse_sequenceStoreId,
    getReadSetExportJobResponse_status,
  )
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:/ 'newGetReadSetExportJob' smart constructor.
data GetReadSetExportJob = GetReadSetExportJob'
  { -- | The job\'s ID.
    GetReadSetExportJob -> Text
id :: Prelude.Text,
    -- | The job\'s sequence store ID.
    GetReadSetExportJob -> Text
sequenceStoreId :: Prelude.Text
  }
  deriving (GetReadSetExportJob -> GetReadSetExportJob -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: GetReadSetExportJob -> GetReadSetExportJob -> Bool
$c/= :: GetReadSetExportJob -> GetReadSetExportJob -> Bool
== :: GetReadSetExportJob -> GetReadSetExportJob -> Bool
$c== :: GetReadSetExportJob -> GetReadSetExportJob -> Bool
Prelude.Eq, ReadPrec [GetReadSetExportJob]
ReadPrec GetReadSetExportJob
Int -> ReadS GetReadSetExportJob
ReadS [GetReadSetExportJob]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [GetReadSetExportJob]
$creadListPrec :: ReadPrec [GetReadSetExportJob]
readPrec :: ReadPrec GetReadSetExportJob
$creadPrec :: ReadPrec GetReadSetExportJob
readList :: ReadS [GetReadSetExportJob]
$creadList :: ReadS [GetReadSetExportJob]
readsPrec :: Int -> ReadS GetReadSetExportJob
$creadsPrec :: Int -> ReadS GetReadSetExportJob
Prelude.Read, Int -> GetReadSetExportJob -> ShowS
[GetReadSetExportJob] -> ShowS
GetReadSetExportJob -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [GetReadSetExportJob] -> ShowS
$cshowList :: [GetReadSetExportJob] -> ShowS
show :: GetReadSetExportJob -> String
$cshow :: GetReadSetExportJob -> String
showsPrec :: Int -> GetReadSetExportJob -> ShowS
$cshowsPrec :: Int -> GetReadSetExportJob -> ShowS
Prelude.Show, forall x. Rep GetReadSetExportJob x -> GetReadSetExportJob
forall x. GetReadSetExportJob -> Rep GetReadSetExportJob x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep GetReadSetExportJob x -> GetReadSetExportJob
$cfrom :: forall x. GetReadSetExportJob -> Rep GetReadSetExportJob x
Prelude.Generic)

-- |
-- Create a value of 'GetReadSetExportJob' 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:
--
-- 'id', 'getReadSetExportJob_id' - The job\'s ID.
--
-- 'sequenceStoreId', 'getReadSetExportJob_sequenceStoreId' - The job\'s sequence store ID.
newGetReadSetExportJob ::
  -- | 'id'
  Prelude.Text ->
  -- | 'sequenceStoreId'
  Prelude.Text ->
  GetReadSetExportJob
newGetReadSetExportJob :: Text -> Text -> GetReadSetExportJob
newGetReadSetExportJob Text
pId_ Text
pSequenceStoreId_ =
  GetReadSetExportJob'
    { $sel:id:GetReadSetExportJob' :: Text
id = Text
pId_,
      $sel:sequenceStoreId:GetReadSetExportJob' :: Text
sequenceStoreId = Text
pSequenceStoreId_
    }

-- | The job\'s ID.
getReadSetExportJob_id :: Lens.Lens' GetReadSetExportJob Prelude.Text
getReadSetExportJob_id :: Lens' GetReadSetExportJob Text
getReadSetExportJob_id = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\GetReadSetExportJob' {Text
id :: Text
$sel:id:GetReadSetExportJob' :: GetReadSetExportJob -> Text
id} -> Text
id) (\s :: GetReadSetExportJob
s@GetReadSetExportJob' {} Text
a -> GetReadSetExportJob
s {$sel:id:GetReadSetExportJob' :: Text
id = Text
a} :: GetReadSetExportJob)

-- | The job\'s sequence store ID.
getReadSetExportJob_sequenceStoreId :: Lens.Lens' GetReadSetExportJob Prelude.Text
getReadSetExportJob_sequenceStoreId :: Lens' GetReadSetExportJob Text
getReadSetExportJob_sequenceStoreId = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\GetReadSetExportJob' {Text
sequenceStoreId :: Text
$sel:sequenceStoreId:GetReadSetExportJob' :: GetReadSetExportJob -> Text
sequenceStoreId} -> Text
sequenceStoreId) (\s :: GetReadSetExportJob
s@GetReadSetExportJob' {} Text
a -> GetReadSetExportJob
s {$sel:sequenceStoreId:GetReadSetExportJob' :: Text
sequenceStoreId = Text
a} :: GetReadSetExportJob)

instance Core.AWSRequest GetReadSetExportJob where
  type
    AWSResponse GetReadSetExportJob =
      GetReadSetExportJobResponse
  request :: (Service -> Service)
-> GetReadSetExportJob -> Request GetReadSetExportJob
request Service -> Service
overrides =
    forall a. ToRequest a => Service -> a -> Request a
Request.get (Service -> Service
overrides Service
defaultService)
  response :: forall (m :: * -> *).
MonadResource m =>
(ByteStringLazy -> IO ByteStringLazy)
-> Service
-> Proxy GetReadSetExportJob
-> ClientResponse ClientBody
-> m (Either
        Error (ClientResponse (AWSResponse GetReadSetExportJob)))
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 ISO8601
-> Maybe [ExportReadSetDetail]
-> Maybe Text
-> Int
-> ISO8601
-> Text
-> Text
-> Text
-> ReadSetExportJobStatus
-> GetReadSetExportJobResponse
GetReadSetExportJobResponse'
            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
"completionTime")
            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
"readSets" 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
"statusMessage")
            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))
            forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
Prelude.<*> (Object
x forall a. FromJSON a => Object -> Key -> Either String a
Data..:> Key
"creationTime")
            forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
Prelude.<*> (Object
x forall a. FromJSON a => Object -> Key -> Either String a
Data..:> Key
"destination")
            forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
Prelude.<*> (Object
x forall a. FromJSON a => Object -> Key -> Either String a
Data..:> Key
"id")
            forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
Prelude.<*> (Object
x forall a. FromJSON a => Object -> Key -> Either String a
Data..:> Key
"sequenceStoreId")
            forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
Prelude.<*> (Object
x forall a. FromJSON a => Object -> Key -> Either String a
Data..:> Key
"status")
      )

instance Prelude.Hashable GetReadSetExportJob where
  hashWithSalt :: Int -> GetReadSetExportJob -> Int
hashWithSalt Int
_salt GetReadSetExportJob' {Text
sequenceStoreId :: Text
id :: Text
$sel:sequenceStoreId:GetReadSetExportJob' :: GetReadSetExportJob -> Text
$sel:id:GetReadSetExportJob' :: GetReadSetExportJob -> Text
..} =
    Int
_salt
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Text
id
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Text
sequenceStoreId

instance Prelude.NFData GetReadSetExportJob where
  rnf :: GetReadSetExportJob -> ()
rnf GetReadSetExportJob' {Text
sequenceStoreId :: Text
id :: Text
$sel:sequenceStoreId:GetReadSetExportJob' :: GetReadSetExportJob -> Text
$sel:id:GetReadSetExportJob' :: GetReadSetExportJob -> Text
..} =
    forall a. NFData a => a -> ()
Prelude.rnf Text
id
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Text
sequenceStoreId

instance Data.ToHeaders GetReadSetExportJob where
  toHeaders :: GetReadSetExportJob -> 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.ToPath GetReadSetExportJob where
  toPath :: GetReadSetExportJob -> ByteString
toPath GetReadSetExportJob' {Text
sequenceStoreId :: Text
id :: Text
$sel:sequenceStoreId:GetReadSetExportJob' :: GetReadSetExportJob -> Text
$sel:id:GetReadSetExportJob' :: GetReadSetExportJob -> Text
..} =
    forall a. Monoid a => [a] -> a
Prelude.mconcat
      [ ByteString
"/sequencestore/",
        forall a. ToByteString a => a -> ByteString
Data.toBS Text
sequenceStoreId,
        ByteString
"/exportjob/",
        forall a. ToByteString a => a -> ByteString
Data.toBS Text
id
      ]

instance Data.ToQuery GetReadSetExportJob where
  toQuery :: GetReadSetExportJob -> QueryString
toQuery = forall a b. a -> b -> a
Prelude.const forall a. Monoid a => a
Prelude.mempty

-- | /See:/ 'newGetReadSetExportJobResponse' smart constructor.
data GetReadSetExportJobResponse = GetReadSetExportJobResponse'
  { -- | When the job completed.
    GetReadSetExportJobResponse -> Maybe ISO8601
completionTime :: Prelude.Maybe Data.ISO8601,
    -- | The job\'s read sets.
    GetReadSetExportJobResponse -> Maybe [ExportReadSetDetail]
readSets :: Prelude.Maybe [ExportReadSetDetail],
    -- | The job\'s status message.
    GetReadSetExportJobResponse -> Maybe Text
statusMessage :: Prelude.Maybe Prelude.Text,
    -- | The response's http status code.
    GetReadSetExportJobResponse -> Int
httpStatus :: Prelude.Int,
    -- | When the job was created.
    GetReadSetExportJobResponse -> ISO8601
creationTime :: Data.ISO8601,
    -- | The job\'s destination in Amazon S3.
    GetReadSetExportJobResponse -> Text
destination :: Prelude.Text,
    -- | The job\'s ID.
    GetReadSetExportJobResponse -> Text
id :: Prelude.Text,
    -- | The job\'s sequence store ID.
    GetReadSetExportJobResponse -> Text
sequenceStoreId :: Prelude.Text,
    -- | The job\'s status.
    GetReadSetExportJobResponse -> ReadSetExportJobStatus
status :: ReadSetExportJobStatus
  }
  deriving (GetReadSetExportJobResponse -> GetReadSetExportJobResponse -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: GetReadSetExportJobResponse -> GetReadSetExportJobResponse -> Bool
$c/= :: GetReadSetExportJobResponse -> GetReadSetExportJobResponse -> Bool
== :: GetReadSetExportJobResponse -> GetReadSetExportJobResponse -> Bool
$c== :: GetReadSetExportJobResponse -> GetReadSetExportJobResponse -> Bool
Prelude.Eq, ReadPrec [GetReadSetExportJobResponse]
ReadPrec GetReadSetExportJobResponse
Int -> ReadS GetReadSetExportJobResponse
ReadS [GetReadSetExportJobResponse]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [GetReadSetExportJobResponse]
$creadListPrec :: ReadPrec [GetReadSetExportJobResponse]
readPrec :: ReadPrec GetReadSetExportJobResponse
$creadPrec :: ReadPrec GetReadSetExportJobResponse
readList :: ReadS [GetReadSetExportJobResponse]
$creadList :: ReadS [GetReadSetExportJobResponse]
readsPrec :: Int -> ReadS GetReadSetExportJobResponse
$creadsPrec :: Int -> ReadS GetReadSetExportJobResponse
Prelude.Read, Int -> GetReadSetExportJobResponse -> ShowS
[GetReadSetExportJobResponse] -> ShowS
GetReadSetExportJobResponse -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [GetReadSetExportJobResponse] -> ShowS
$cshowList :: [GetReadSetExportJobResponse] -> ShowS
show :: GetReadSetExportJobResponse -> String
$cshow :: GetReadSetExportJobResponse -> String
showsPrec :: Int -> GetReadSetExportJobResponse -> ShowS
$cshowsPrec :: Int -> GetReadSetExportJobResponse -> ShowS
Prelude.Show, forall x.
Rep GetReadSetExportJobResponse x -> GetReadSetExportJobResponse
forall x.
GetReadSetExportJobResponse -> Rep GetReadSetExportJobResponse x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x.
Rep GetReadSetExportJobResponse x -> GetReadSetExportJobResponse
$cfrom :: forall x.
GetReadSetExportJobResponse -> Rep GetReadSetExportJobResponse x
Prelude.Generic)

-- |
-- Create a value of 'GetReadSetExportJobResponse' 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:
--
-- 'completionTime', 'getReadSetExportJobResponse_completionTime' - When the job completed.
--
-- 'readSets', 'getReadSetExportJobResponse_readSets' - The job\'s read sets.
--
-- 'statusMessage', 'getReadSetExportJobResponse_statusMessage' - The job\'s status message.
--
-- 'httpStatus', 'getReadSetExportJobResponse_httpStatus' - The response's http status code.
--
-- 'creationTime', 'getReadSetExportJobResponse_creationTime' - When the job was created.
--
-- 'destination', 'getReadSetExportJobResponse_destination' - The job\'s destination in Amazon S3.
--
-- 'id', 'getReadSetExportJobResponse_id' - The job\'s ID.
--
-- 'sequenceStoreId', 'getReadSetExportJobResponse_sequenceStoreId' - The job\'s sequence store ID.
--
-- 'status', 'getReadSetExportJobResponse_status' - The job\'s status.
newGetReadSetExportJobResponse ::
  -- | 'httpStatus'
  Prelude.Int ->
  -- | 'creationTime'
  Prelude.UTCTime ->
  -- | 'destination'
  Prelude.Text ->
  -- | 'id'
  Prelude.Text ->
  -- | 'sequenceStoreId'
  Prelude.Text ->
  -- | 'status'
  ReadSetExportJobStatus ->
  GetReadSetExportJobResponse
newGetReadSetExportJobResponse :: Int
-> UTCTime
-> Text
-> Text
-> Text
-> ReadSetExportJobStatus
-> GetReadSetExportJobResponse
newGetReadSetExportJobResponse
  Int
pHttpStatus_
  UTCTime
pCreationTime_
  Text
pDestination_
  Text
pId_
  Text
pSequenceStoreId_
  ReadSetExportJobStatus
pStatus_ =
    GetReadSetExportJobResponse'
      { $sel:completionTime:GetReadSetExportJobResponse' :: Maybe ISO8601
completionTime =
          forall a. Maybe a
Prelude.Nothing,
        $sel:readSets:GetReadSetExportJobResponse' :: Maybe [ExportReadSetDetail]
readSets = forall a. Maybe a
Prelude.Nothing,
        $sel:statusMessage:GetReadSetExportJobResponse' :: Maybe Text
statusMessage = forall a. Maybe a
Prelude.Nothing,
        $sel:httpStatus:GetReadSetExportJobResponse' :: Int
httpStatus = Int
pHttpStatus_,
        $sel:creationTime:GetReadSetExportJobResponse' :: ISO8601
creationTime =
          forall (a :: Format). Iso' (Time a) UTCTime
Data._Time forall t b. AReview t b -> b -> t
Lens.# UTCTime
pCreationTime_,
        $sel:destination:GetReadSetExportJobResponse' :: Text
destination = Text
pDestination_,
        $sel:id:GetReadSetExportJobResponse' :: Text
id = Text
pId_,
        $sel:sequenceStoreId:GetReadSetExportJobResponse' :: Text
sequenceStoreId = Text
pSequenceStoreId_,
        $sel:status:GetReadSetExportJobResponse' :: ReadSetExportJobStatus
status = ReadSetExportJobStatus
pStatus_
      }

-- | When the job completed.
getReadSetExportJobResponse_completionTime :: Lens.Lens' GetReadSetExportJobResponse (Prelude.Maybe Prelude.UTCTime)
getReadSetExportJobResponse_completionTime :: Lens' GetReadSetExportJobResponse (Maybe UTCTime)
getReadSetExportJobResponse_completionTime = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\GetReadSetExportJobResponse' {Maybe ISO8601
completionTime :: Maybe ISO8601
$sel:completionTime:GetReadSetExportJobResponse' :: GetReadSetExportJobResponse -> Maybe ISO8601
completionTime} -> Maybe ISO8601
completionTime) (\s :: GetReadSetExportJobResponse
s@GetReadSetExportJobResponse' {} Maybe ISO8601
a -> GetReadSetExportJobResponse
s {$sel:completionTime:GetReadSetExportJobResponse' :: Maybe ISO8601
completionTime = Maybe ISO8601
a} :: GetReadSetExportJobResponse) 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 (a :: Format). Iso' (Time a) UTCTime
Data._Time

-- | The job\'s read sets.
getReadSetExportJobResponse_readSets :: Lens.Lens' GetReadSetExportJobResponse (Prelude.Maybe [ExportReadSetDetail])
getReadSetExportJobResponse_readSets :: Lens' GetReadSetExportJobResponse (Maybe [ExportReadSetDetail])
getReadSetExportJobResponse_readSets = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\GetReadSetExportJobResponse' {Maybe [ExportReadSetDetail]
readSets :: Maybe [ExportReadSetDetail]
$sel:readSets:GetReadSetExportJobResponse' :: GetReadSetExportJobResponse -> Maybe [ExportReadSetDetail]
readSets} -> Maybe [ExportReadSetDetail]
readSets) (\s :: GetReadSetExportJobResponse
s@GetReadSetExportJobResponse' {} Maybe [ExportReadSetDetail]
a -> GetReadSetExportJobResponse
s {$sel:readSets:GetReadSetExportJobResponse' :: Maybe [ExportReadSetDetail]
readSets = Maybe [ExportReadSetDetail]
a} :: GetReadSetExportJobResponse) 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

-- | The job\'s status message.
getReadSetExportJobResponse_statusMessage :: Lens.Lens' GetReadSetExportJobResponse (Prelude.Maybe Prelude.Text)
getReadSetExportJobResponse_statusMessage :: Lens' GetReadSetExportJobResponse (Maybe Text)
getReadSetExportJobResponse_statusMessage = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\GetReadSetExportJobResponse' {Maybe Text
statusMessage :: Maybe Text
$sel:statusMessage:GetReadSetExportJobResponse' :: GetReadSetExportJobResponse -> Maybe Text
statusMessage} -> Maybe Text
statusMessage) (\s :: GetReadSetExportJobResponse
s@GetReadSetExportJobResponse' {} Maybe Text
a -> GetReadSetExportJobResponse
s {$sel:statusMessage:GetReadSetExportJobResponse' :: Maybe Text
statusMessage = Maybe Text
a} :: GetReadSetExportJobResponse)

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

-- | When the job was created.
getReadSetExportJobResponse_creationTime :: Lens.Lens' GetReadSetExportJobResponse Prelude.UTCTime
getReadSetExportJobResponse_creationTime :: Lens' GetReadSetExportJobResponse UTCTime
getReadSetExportJobResponse_creationTime = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\GetReadSetExportJobResponse' {ISO8601
creationTime :: ISO8601
$sel:creationTime:GetReadSetExportJobResponse' :: GetReadSetExportJobResponse -> ISO8601
creationTime} -> ISO8601
creationTime) (\s :: GetReadSetExportJobResponse
s@GetReadSetExportJobResponse' {} ISO8601
a -> GetReadSetExportJobResponse
s {$sel:creationTime:GetReadSetExportJobResponse' :: ISO8601
creationTime = ISO8601
a} :: GetReadSetExportJobResponse) forall b c a. (b -> c) -> (a -> b) -> a -> c
Prelude.. forall (a :: Format). Iso' (Time a) UTCTime
Data._Time

-- | The job\'s destination in Amazon S3.
getReadSetExportJobResponse_destination :: Lens.Lens' GetReadSetExportJobResponse Prelude.Text
getReadSetExportJobResponse_destination :: Lens' GetReadSetExportJobResponse Text
getReadSetExportJobResponse_destination = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\GetReadSetExportJobResponse' {Text
destination :: Text
$sel:destination:GetReadSetExportJobResponse' :: GetReadSetExportJobResponse -> Text
destination} -> Text
destination) (\s :: GetReadSetExportJobResponse
s@GetReadSetExportJobResponse' {} Text
a -> GetReadSetExportJobResponse
s {$sel:destination:GetReadSetExportJobResponse' :: Text
destination = Text
a} :: GetReadSetExportJobResponse)

-- | The job\'s ID.
getReadSetExportJobResponse_id :: Lens.Lens' GetReadSetExportJobResponse Prelude.Text
getReadSetExportJobResponse_id :: Lens' GetReadSetExportJobResponse Text
getReadSetExportJobResponse_id = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\GetReadSetExportJobResponse' {Text
id :: Text
$sel:id:GetReadSetExportJobResponse' :: GetReadSetExportJobResponse -> Text
id} -> Text
id) (\s :: GetReadSetExportJobResponse
s@GetReadSetExportJobResponse' {} Text
a -> GetReadSetExportJobResponse
s {$sel:id:GetReadSetExportJobResponse' :: Text
id = Text
a} :: GetReadSetExportJobResponse)

-- | The job\'s sequence store ID.
getReadSetExportJobResponse_sequenceStoreId :: Lens.Lens' GetReadSetExportJobResponse Prelude.Text
getReadSetExportJobResponse_sequenceStoreId :: Lens' GetReadSetExportJobResponse Text
getReadSetExportJobResponse_sequenceStoreId = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\GetReadSetExportJobResponse' {Text
sequenceStoreId :: Text
$sel:sequenceStoreId:GetReadSetExportJobResponse' :: GetReadSetExportJobResponse -> Text
sequenceStoreId} -> Text
sequenceStoreId) (\s :: GetReadSetExportJobResponse
s@GetReadSetExportJobResponse' {} Text
a -> GetReadSetExportJobResponse
s {$sel:sequenceStoreId:GetReadSetExportJobResponse' :: Text
sequenceStoreId = Text
a} :: GetReadSetExportJobResponse)

-- | The job\'s status.
getReadSetExportJobResponse_status :: Lens.Lens' GetReadSetExportJobResponse ReadSetExportJobStatus
getReadSetExportJobResponse_status :: Lens' GetReadSetExportJobResponse ReadSetExportJobStatus
getReadSetExportJobResponse_status = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\GetReadSetExportJobResponse' {ReadSetExportJobStatus
status :: ReadSetExportJobStatus
$sel:status:GetReadSetExportJobResponse' :: GetReadSetExportJobResponse -> ReadSetExportJobStatus
status} -> ReadSetExportJobStatus
status) (\s :: GetReadSetExportJobResponse
s@GetReadSetExportJobResponse' {} ReadSetExportJobStatus
a -> GetReadSetExportJobResponse
s {$sel:status:GetReadSetExportJobResponse' :: ReadSetExportJobStatus
status = ReadSetExportJobStatus
a} :: GetReadSetExportJobResponse)

instance Prelude.NFData GetReadSetExportJobResponse where
  rnf :: GetReadSetExportJobResponse -> ()
rnf GetReadSetExportJobResponse' {Int
Maybe [ExportReadSetDetail]
Maybe Text
Maybe ISO8601
Text
ISO8601
ReadSetExportJobStatus
status :: ReadSetExportJobStatus
sequenceStoreId :: Text
id :: Text
destination :: Text
creationTime :: ISO8601
httpStatus :: Int
statusMessage :: Maybe Text
readSets :: Maybe [ExportReadSetDetail]
completionTime :: Maybe ISO8601
$sel:status:GetReadSetExportJobResponse' :: GetReadSetExportJobResponse -> ReadSetExportJobStatus
$sel:sequenceStoreId:GetReadSetExportJobResponse' :: GetReadSetExportJobResponse -> Text
$sel:id:GetReadSetExportJobResponse' :: GetReadSetExportJobResponse -> Text
$sel:destination:GetReadSetExportJobResponse' :: GetReadSetExportJobResponse -> Text
$sel:creationTime:GetReadSetExportJobResponse' :: GetReadSetExportJobResponse -> ISO8601
$sel:httpStatus:GetReadSetExportJobResponse' :: GetReadSetExportJobResponse -> Int
$sel:statusMessage:GetReadSetExportJobResponse' :: GetReadSetExportJobResponse -> Maybe Text
$sel:readSets:GetReadSetExportJobResponse' :: GetReadSetExportJobResponse -> Maybe [ExportReadSetDetail]
$sel:completionTime:GetReadSetExportJobResponse' :: GetReadSetExportJobResponse -> Maybe ISO8601
..} =
    forall a. NFData a => a -> ()
Prelude.rnf Maybe ISO8601
completionTime
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe [ExportReadSetDetail]
readSets
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe Text
statusMessage
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Int
httpStatus
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf ISO8601
creationTime
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Text
destination
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Text
id
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Text
sequenceStoreId
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf ReadSetExportJobStatus
status