{-# LANGUAGE DeriveGeneric #-}
{-# LANGUAGE DuplicateRecordFields #-}
{-# LANGUAGE NamedFieldPuns #-}
{-# LANGUAGE OverloadedStrings #-}
{-# LANGUAGE RecordWildCards #-}
{-# LANGUAGE StrictData #-}
{-# LANGUAGE NoImplicitPrelude #-}
{-# OPTIONS_GHC -fno-warn-unused-imports #-}
{-# OPTIONS_GHC -fno-warn-unused-matches #-}
module Amazonka.Omics.Types.ImportReadSetJobItem 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.ReadSetImportJobStatus
import qualified Amazonka.Prelude as Prelude
data ImportReadSetJobItem = ImportReadSetJobItem'
{
ImportReadSetJobItem -> Maybe ISO8601
completionTime :: Prelude.Maybe Data.ISO8601,
ImportReadSetJobItem -> ISO8601
creationTime :: Data.ISO8601,
ImportReadSetJobItem -> Text
id :: Prelude.Text,
ImportReadSetJobItem -> Text
roleArn :: Prelude.Text,
ImportReadSetJobItem -> Text
sequenceStoreId :: Prelude.Text,
ImportReadSetJobItem -> ReadSetImportJobStatus
status :: ReadSetImportJobStatus
}
deriving (ImportReadSetJobItem -> ImportReadSetJobItem -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: ImportReadSetJobItem -> ImportReadSetJobItem -> Bool
$c/= :: ImportReadSetJobItem -> ImportReadSetJobItem -> Bool
== :: ImportReadSetJobItem -> ImportReadSetJobItem -> Bool
$c== :: ImportReadSetJobItem -> ImportReadSetJobItem -> Bool
Prelude.Eq, ReadPrec [ImportReadSetJobItem]
ReadPrec ImportReadSetJobItem
Int -> ReadS ImportReadSetJobItem
ReadS [ImportReadSetJobItem]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [ImportReadSetJobItem]
$creadListPrec :: ReadPrec [ImportReadSetJobItem]
readPrec :: ReadPrec ImportReadSetJobItem
$creadPrec :: ReadPrec ImportReadSetJobItem
readList :: ReadS [ImportReadSetJobItem]
$creadList :: ReadS [ImportReadSetJobItem]
readsPrec :: Int -> ReadS ImportReadSetJobItem
$creadsPrec :: Int -> ReadS ImportReadSetJobItem
Prelude.Read, Int -> ImportReadSetJobItem -> ShowS
[ImportReadSetJobItem] -> ShowS
ImportReadSetJobItem -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [ImportReadSetJobItem] -> ShowS
$cshowList :: [ImportReadSetJobItem] -> ShowS
show :: ImportReadSetJobItem -> String
$cshow :: ImportReadSetJobItem -> String
showsPrec :: Int -> ImportReadSetJobItem -> ShowS
$cshowsPrec :: Int -> ImportReadSetJobItem -> ShowS
Prelude.Show, forall x. Rep ImportReadSetJobItem x -> ImportReadSetJobItem
forall x. ImportReadSetJobItem -> Rep ImportReadSetJobItem x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep ImportReadSetJobItem x -> ImportReadSetJobItem
$cfrom :: forall x. ImportReadSetJobItem -> Rep ImportReadSetJobItem x
Prelude.Generic)
newImportReadSetJobItem ::
Prelude.UTCTime ->
Prelude.Text ->
Prelude.Text ->
Prelude.Text ->
ReadSetImportJobStatus ->
ImportReadSetJobItem
newImportReadSetJobItem :: UTCTime
-> Text
-> Text
-> Text
-> ReadSetImportJobStatus
-> ImportReadSetJobItem
newImportReadSetJobItem
UTCTime
pCreationTime_
Text
pId_
Text
pRoleArn_
Text
pSequenceStoreId_
ReadSetImportJobStatus
pStatus_ =
ImportReadSetJobItem'
{ $sel:completionTime:ImportReadSetJobItem' :: Maybe ISO8601
completionTime =
forall a. Maybe a
Prelude.Nothing,
$sel:creationTime:ImportReadSetJobItem' :: ISO8601
creationTime = forall (a :: Format). Iso' (Time a) UTCTime
Data._Time forall t b. AReview t b -> b -> t
Lens.# UTCTime
pCreationTime_,
$sel:id:ImportReadSetJobItem' :: Text
id = Text
pId_,
$sel:roleArn:ImportReadSetJobItem' :: Text
roleArn = Text
pRoleArn_,
$sel:sequenceStoreId:ImportReadSetJobItem' :: Text
sequenceStoreId = Text
pSequenceStoreId_,
$sel:status:ImportReadSetJobItem' :: ReadSetImportJobStatus
status = ReadSetImportJobStatus
pStatus_
}
importReadSetJobItem_completionTime :: Lens.Lens' ImportReadSetJobItem (Prelude.Maybe Prelude.UTCTime)
importReadSetJobItem_completionTime :: Lens' ImportReadSetJobItem (Maybe UTCTime)
importReadSetJobItem_completionTime = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\ImportReadSetJobItem' {Maybe ISO8601
completionTime :: Maybe ISO8601
$sel:completionTime:ImportReadSetJobItem' :: ImportReadSetJobItem -> Maybe ISO8601
completionTime} -> Maybe ISO8601
completionTime) (\s :: ImportReadSetJobItem
s@ImportReadSetJobItem' {} Maybe ISO8601
a -> ImportReadSetJobItem
s {$sel:completionTime:ImportReadSetJobItem' :: Maybe ISO8601
completionTime = Maybe ISO8601
a} :: ImportReadSetJobItem) 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
importReadSetJobItem_creationTime :: Lens.Lens' ImportReadSetJobItem Prelude.UTCTime
importReadSetJobItem_creationTime :: Lens' ImportReadSetJobItem UTCTime
importReadSetJobItem_creationTime = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\ImportReadSetJobItem' {ISO8601
creationTime :: ISO8601
$sel:creationTime:ImportReadSetJobItem' :: ImportReadSetJobItem -> ISO8601
creationTime} -> ISO8601
creationTime) (\s :: ImportReadSetJobItem
s@ImportReadSetJobItem' {} ISO8601
a -> ImportReadSetJobItem
s {$sel:creationTime:ImportReadSetJobItem' :: ISO8601
creationTime = ISO8601
a} :: ImportReadSetJobItem) forall b c a. (b -> c) -> (a -> b) -> a -> c
Prelude.. forall (a :: Format). Iso' (Time a) UTCTime
Data._Time
importReadSetJobItem_id :: Lens.Lens' ImportReadSetJobItem Prelude.Text
importReadSetJobItem_id :: Lens' ImportReadSetJobItem Text
importReadSetJobItem_id = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\ImportReadSetJobItem' {Text
id :: Text
$sel:id:ImportReadSetJobItem' :: ImportReadSetJobItem -> Text
id} -> Text
id) (\s :: ImportReadSetJobItem
s@ImportReadSetJobItem' {} Text
a -> ImportReadSetJobItem
s {$sel:id:ImportReadSetJobItem' :: Text
id = Text
a} :: ImportReadSetJobItem)
importReadSetJobItem_roleArn :: Lens.Lens' ImportReadSetJobItem Prelude.Text
importReadSetJobItem_roleArn :: Lens' ImportReadSetJobItem Text
importReadSetJobItem_roleArn = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\ImportReadSetJobItem' {Text
roleArn :: Text
$sel:roleArn:ImportReadSetJobItem' :: ImportReadSetJobItem -> Text
roleArn} -> Text
roleArn) (\s :: ImportReadSetJobItem
s@ImportReadSetJobItem' {} Text
a -> ImportReadSetJobItem
s {$sel:roleArn:ImportReadSetJobItem' :: Text
roleArn = Text
a} :: ImportReadSetJobItem)
importReadSetJobItem_sequenceStoreId :: Lens.Lens' ImportReadSetJobItem Prelude.Text
importReadSetJobItem_sequenceStoreId :: Lens' ImportReadSetJobItem Text
importReadSetJobItem_sequenceStoreId = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\ImportReadSetJobItem' {Text
sequenceStoreId :: Text
$sel:sequenceStoreId:ImportReadSetJobItem' :: ImportReadSetJobItem -> Text
sequenceStoreId} -> Text
sequenceStoreId) (\s :: ImportReadSetJobItem
s@ImportReadSetJobItem' {} Text
a -> ImportReadSetJobItem
s {$sel:sequenceStoreId:ImportReadSetJobItem' :: Text
sequenceStoreId = Text
a} :: ImportReadSetJobItem)
importReadSetJobItem_status :: Lens.Lens' ImportReadSetJobItem ReadSetImportJobStatus
importReadSetJobItem_status :: Lens' ImportReadSetJobItem ReadSetImportJobStatus
importReadSetJobItem_status = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\ImportReadSetJobItem' {ReadSetImportJobStatus
status :: ReadSetImportJobStatus
$sel:status:ImportReadSetJobItem' :: ImportReadSetJobItem -> ReadSetImportJobStatus
status} -> ReadSetImportJobStatus
status) (\s :: ImportReadSetJobItem
s@ImportReadSetJobItem' {} ReadSetImportJobStatus
a -> ImportReadSetJobItem
s {$sel:status:ImportReadSetJobItem' :: ReadSetImportJobStatus
status = ReadSetImportJobStatus
a} :: ImportReadSetJobItem)
instance Data.FromJSON ImportReadSetJobItem where
parseJSON :: Value -> Parser ImportReadSetJobItem
parseJSON =
forall a. String -> (Object -> Parser a) -> Value -> Parser a
Data.withObject
String
"ImportReadSetJobItem"
( \Object
x ->
Maybe ISO8601
-> ISO8601
-> Text
-> Text
-> Text
-> ReadSetImportJobStatus
-> ImportReadSetJobItem
ImportReadSetJobItem'
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
Prelude.<$> (Object
x forall a. FromJSON a => Object -> Key -> Parser (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 -> Parser 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 -> Parser 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 -> Parser a
Data..: Key
"roleArn")
forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
Prelude.<*> (Object
x forall a. FromJSON a => Object -> Key -> Parser 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 -> Parser a
Data..: Key
"status")
)
instance Prelude.Hashable ImportReadSetJobItem where
hashWithSalt :: Int -> ImportReadSetJobItem -> Int
hashWithSalt Int
_salt ImportReadSetJobItem' {Maybe ISO8601
Text
ISO8601
ReadSetImportJobStatus
status :: ReadSetImportJobStatus
sequenceStoreId :: Text
roleArn :: Text
id :: Text
creationTime :: ISO8601
completionTime :: Maybe ISO8601
$sel:status:ImportReadSetJobItem' :: ImportReadSetJobItem -> ReadSetImportJobStatus
$sel:sequenceStoreId:ImportReadSetJobItem' :: ImportReadSetJobItem -> Text
$sel:roleArn:ImportReadSetJobItem' :: ImportReadSetJobItem -> Text
$sel:id:ImportReadSetJobItem' :: ImportReadSetJobItem -> Text
$sel:creationTime:ImportReadSetJobItem' :: ImportReadSetJobItem -> ISO8601
$sel:completionTime:ImportReadSetJobItem' :: ImportReadSetJobItem -> Maybe ISO8601
..} =
Int
_salt
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe ISO8601
completionTime
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` ISO8601
creationTime
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Text
id
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Text
roleArn
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Text
sequenceStoreId
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` ReadSetImportJobStatus
status
instance Prelude.NFData ImportReadSetJobItem where
rnf :: ImportReadSetJobItem -> ()
rnf ImportReadSetJobItem' {Maybe ISO8601
Text
ISO8601
ReadSetImportJobStatus
status :: ReadSetImportJobStatus
sequenceStoreId :: Text
roleArn :: Text
id :: Text
creationTime :: ISO8601
completionTime :: Maybe ISO8601
$sel:status:ImportReadSetJobItem' :: ImportReadSetJobItem -> ReadSetImportJobStatus
$sel:sequenceStoreId:ImportReadSetJobItem' :: ImportReadSetJobItem -> Text
$sel:roleArn:ImportReadSetJobItem' :: ImportReadSetJobItem -> Text
$sel:id:ImportReadSetJobItem' :: ImportReadSetJobItem -> Text
$sel:creationTime:ImportReadSetJobItem' :: ImportReadSetJobItem -> ISO8601
$sel:completionTime:ImportReadSetJobItem' :: ImportReadSetJobItem -> 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 ISO8601
creationTime
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
roleArn
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 ReadSetImportJobStatus
status