{-# 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.Glacier.Types.PartListElement where
import qualified Amazonka.Core as Core
import qualified Amazonka.Lens as Lens
import qualified Amazonka.Prelude as Prelude
data PartListElement = PartListElement'
{
PartListElement -> Maybe Text
sHA256TreeHash :: Prelude.Maybe Prelude.Text,
PartListElement -> Maybe Text
rangeInBytes :: Prelude.Maybe Prelude.Text
}
deriving (PartListElement -> PartListElement -> Bool
(PartListElement -> PartListElement -> Bool)
-> (PartListElement -> PartListElement -> Bool)
-> Eq PartListElement
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: PartListElement -> PartListElement -> Bool
$c/= :: PartListElement -> PartListElement -> Bool
== :: PartListElement -> PartListElement -> Bool
$c== :: PartListElement -> PartListElement -> Bool
Prelude.Eq, ReadPrec [PartListElement]
ReadPrec PartListElement
Int -> ReadS PartListElement
ReadS [PartListElement]
(Int -> ReadS PartListElement)
-> ReadS [PartListElement]
-> ReadPrec PartListElement
-> ReadPrec [PartListElement]
-> Read PartListElement
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [PartListElement]
$creadListPrec :: ReadPrec [PartListElement]
readPrec :: ReadPrec PartListElement
$creadPrec :: ReadPrec PartListElement
readList :: ReadS [PartListElement]
$creadList :: ReadS [PartListElement]
readsPrec :: Int -> ReadS PartListElement
$creadsPrec :: Int -> ReadS PartListElement
Prelude.Read, Int -> PartListElement -> ShowS
[PartListElement] -> ShowS
PartListElement -> String
(Int -> PartListElement -> ShowS)
-> (PartListElement -> String)
-> ([PartListElement] -> ShowS)
-> Show PartListElement
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [PartListElement] -> ShowS
$cshowList :: [PartListElement] -> ShowS
show :: PartListElement -> String
$cshow :: PartListElement -> String
showsPrec :: Int -> PartListElement -> ShowS
$cshowsPrec :: Int -> PartListElement -> ShowS
Prelude.Show, (forall x. PartListElement -> Rep PartListElement x)
-> (forall x. Rep PartListElement x -> PartListElement)
-> Generic PartListElement
forall x. Rep PartListElement x -> PartListElement
forall x. PartListElement -> Rep PartListElement x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep PartListElement x -> PartListElement
$cfrom :: forall x. PartListElement -> Rep PartListElement x
Prelude.Generic)
newPartListElement ::
PartListElement
newPartListElement :: PartListElement
newPartListElement =
PartListElement' :: Maybe Text -> Maybe Text -> PartListElement
PartListElement'
{ $sel:sHA256TreeHash:PartListElement' :: Maybe Text
sHA256TreeHash = Maybe Text
forall a. Maybe a
Prelude.Nothing,
$sel:rangeInBytes:PartListElement' :: Maybe Text
rangeInBytes = Maybe Text
forall a. Maybe a
Prelude.Nothing
}
partListElement_sHA256TreeHash :: Lens.Lens' PartListElement (Prelude.Maybe Prelude.Text)
partListElement_sHA256TreeHash :: (Maybe Text -> f (Maybe Text))
-> PartListElement -> f PartListElement
partListElement_sHA256TreeHash = (PartListElement -> Maybe Text)
-> (PartListElement -> Maybe Text -> PartListElement)
-> Lens PartListElement PartListElement (Maybe Text) (Maybe Text)
forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\PartListElement' {Maybe Text
sHA256TreeHash :: Maybe Text
$sel:sHA256TreeHash:PartListElement' :: PartListElement -> Maybe Text
sHA256TreeHash} -> Maybe Text
sHA256TreeHash) (\s :: PartListElement
s@PartListElement' {} Maybe Text
a -> PartListElement
s {$sel:sHA256TreeHash:PartListElement' :: Maybe Text
sHA256TreeHash = Maybe Text
a} :: PartListElement)
partListElement_rangeInBytes :: Lens.Lens' PartListElement (Prelude.Maybe Prelude.Text)
partListElement_rangeInBytes :: (Maybe Text -> f (Maybe Text))
-> PartListElement -> f PartListElement
partListElement_rangeInBytes = (PartListElement -> Maybe Text)
-> (PartListElement -> Maybe Text -> PartListElement)
-> Lens PartListElement PartListElement (Maybe Text) (Maybe Text)
forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\PartListElement' {Maybe Text
rangeInBytes :: Maybe Text
$sel:rangeInBytes:PartListElement' :: PartListElement -> Maybe Text
rangeInBytes} -> Maybe Text
rangeInBytes) (\s :: PartListElement
s@PartListElement' {} Maybe Text
a -> PartListElement
s {$sel:rangeInBytes:PartListElement' :: Maybe Text
rangeInBytes = Maybe Text
a} :: PartListElement)
instance Core.FromJSON PartListElement where
parseJSON :: Value -> Parser PartListElement
parseJSON =
String
-> (Object -> Parser PartListElement)
-> Value
-> Parser PartListElement
forall a. String -> (Object -> Parser a) -> Value -> Parser a
Core.withObject
String
"PartListElement"
( \Object
x ->
Maybe Text -> Maybe Text -> PartListElement
PartListElement'
(Maybe Text -> Maybe Text -> PartListElement)
-> Parser (Maybe Text) -> Parser (Maybe Text -> PartListElement)
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
Prelude.<$> (Object
x Object -> Text -> Parser (Maybe Text)
forall a. FromJSON a => Object -> Text -> Parser (Maybe a)
Core..:? Text
"SHA256TreeHash")
Parser (Maybe Text -> PartListElement)
-> Parser (Maybe Text) -> Parser PartListElement
forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
Prelude.<*> (Object
x Object -> Text -> Parser (Maybe Text)
forall a. FromJSON a => Object -> Text -> Parser (Maybe a)
Core..:? Text
"RangeInBytes")
)
instance Prelude.Hashable PartListElement
instance Prelude.NFData PartListElement