{-# 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 #-}
module Amazonka.RDS.StartExportTask
(
StartExportTask (..),
newStartExportTask,
startExportTask_exportOnly,
startExportTask_s3Prefix,
startExportTask_exportTaskIdentifier,
startExportTask_sourceArn,
startExportTask_s3BucketName,
startExportTask_iamRoleArn,
startExportTask_kmsKeyId,
ExportTask (..),
newExportTask,
exportTask_exportOnly,
exportTask_exportTaskIdentifier,
exportTask_failureCause,
exportTask_iamRoleArn,
exportTask_kmsKeyId,
exportTask_percentProgress,
exportTask_s3Bucket,
exportTask_s3Prefix,
exportTask_snapshotTime,
exportTask_sourceArn,
exportTask_sourceType,
exportTask_status,
exportTask_taskEndTime,
exportTask_taskStartTime,
exportTask_totalExtractedDataInGB,
exportTask_warningMessage,
)
where
import qualified Amazonka.Core as Core
import qualified Amazonka.Core.Lens.Internal as Lens
import qualified Amazonka.Data as Data
import qualified Amazonka.Prelude as Prelude
import Amazonka.RDS.Types
import qualified Amazonka.Request as Request
import qualified Amazonka.Response as Response
data StartExportTask = StartExportTask'
{
StartExportTask -> Maybe [Text]
exportOnly :: Prelude.Maybe [Prelude.Text],
StartExportTask -> Maybe Text
s3Prefix :: Prelude.Maybe Prelude.Text,
StartExportTask -> Text
exportTaskIdentifier :: Prelude.Text,
StartExportTask -> Text
sourceArn :: Prelude.Text,
StartExportTask -> Text
s3BucketName :: Prelude.Text,
StartExportTask -> Text
iamRoleArn :: Prelude.Text,
StartExportTask -> Text
kmsKeyId :: Prelude.Text
}
deriving (StartExportTask -> StartExportTask -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: StartExportTask -> StartExportTask -> Bool
$c/= :: StartExportTask -> StartExportTask -> Bool
== :: StartExportTask -> StartExportTask -> Bool
$c== :: StartExportTask -> StartExportTask -> Bool
Prelude.Eq, ReadPrec [StartExportTask]
ReadPrec StartExportTask
Int -> ReadS StartExportTask
ReadS [StartExportTask]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [StartExportTask]
$creadListPrec :: ReadPrec [StartExportTask]
readPrec :: ReadPrec StartExportTask
$creadPrec :: ReadPrec StartExportTask
readList :: ReadS [StartExportTask]
$creadList :: ReadS [StartExportTask]
readsPrec :: Int -> ReadS StartExportTask
$creadsPrec :: Int -> ReadS StartExportTask
Prelude.Read, Int -> StartExportTask -> ShowS
[StartExportTask] -> ShowS
StartExportTask -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [StartExportTask] -> ShowS
$cshowList :: [StartExportTask] -> ShowS
show :: StartExportTask -> String
$cshow :: StartExportTask -> String
showsPrec :: Int -> StartExportTask -> ShowS
$cshowsPrec :: Int -> StartExportTask -> ShowS
Prelude.Show, forall x. Rep StartExportTask x -> StartExportTask
forall x. StartExportTask -> Rep StartExportTask x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep StartExportTask x -> StartExportTask
$cfrom :: forall x. StartExportTask -> Rep StartExportTask x
Prelude.Generic)
newStartExportTask ::
Prelude.Text ->
Prelude.Text ->
Prelude.Text ->
Prelude.Text ->
Prelude.Text ->
StartExportTask
newStartExportTask :: Text -> Text -> Text -> Text -> Text -> StartExportTask
newStartExportTask
Text
pExportTaskIdentifier_
Text
pSourceArn_
Text
pS3BucketName_
Text
pIamRoleArn_
Text
pKmsKeyId_ =
StartExportTask'
{ $sel:exportOnly:StartExportTask' :: Maybe [Text]
exportOnly = forall a. Maybe a
Prelude.Nothing,
$sel:s3Prefix:StartExportTask' :: Maybe Text
s3Prefix = forall a. Maybe a
Prelude.Nothing,
$sel:exportTaskIdentifier:StartExportTask' :: Text
exportTaskIdentifier = Text
pExportTaskIdentifier_,
$sel:sourceArn:StartExportTask' :: Text
sourceArn = Text
pSourceArn_,
$sel:s3BucketName:StartExportTask' :: Text
s3BucketName = Text
pS3BucketName_,
$sel:iamRoleArn:StartExportTask' :: Text
iamRoleArn = Text
pIamRoleArn_,
$sel:kmsKeyId:StartExportTask' :: Text
kmsKeyId = Text
pKmsKeyId_
}
startExportTask_exportOnly :: Lens.Lens' StartExportTask (Prelude.Maybe [Prelude.Text])
startExportTask_exportOnly :: Lens' StartExportTask (Maybe [Text])
startExportTask_exportOnly = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\StartExportTask' {Maybe [Text]
exportOnly :: Maybe [Text]
$sel:exportOnly:StartExportTask' :: StartExportTask -> Maybe [Text]
exportOnly} -> Maybe [Text]
exportOnly) (\s :: StartExportTask
s@StartExportTask' {} Maybe [Text]
a -> StartExportTask
s {$sel:exportOnly:StartExportTask' :: Maybe [Text]
exportOnly = Maybe [Text]
a} :: StartExportTask) 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
startExportTask_s3Prefix :: Lens.Lens' StartExportTask (Prelude.Maybe Prelude.Text)
startExportTask_s3Prefix :: Lens' StartExportTask (Maybe Text)
startExportTask_s3Prefix = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\StartExportTask' {Maybe Text
s3Prefix :: Maybe Text
$sel:s3Prefix:StartExportTask' :: StartExportTask -> Maybe Text
s3Prefix} -> Maybe Text
s3Prefix) (\s :: StartExportTask
s@StartExportTask' {} Maybe Text
a -> StartExportTask
s {$sel:s3Prefix:StartExportTask' :: Maybe Text
s3Prefix = Maybe Text
a} :: StartExportTask)
startExportTask_exportTaskIdentifier :: Lens.Lens' StartExportTask Prelude.Text
startExportTask_exportTaskIdentifier :: Lens' StartExportTask Text
startExportTask_exportTaskIdentifier = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\StartExportTask' {Text
exportTaskIdentifier :: Text
$sel:exportTaskIdentifier:StartExportTask' :: StartExportTask -> Text
exportTaskIdentifier} -> Text
exportTaskIdentifier) (\s :: StartExportTask
s@StartExportTask' {} Text
a -> StartExportTask
s {$sel:exportTaskIdentifier:StartExportTask' :: Text
exportTaskIdentifier = Text
a} :: StartExportTask)
startExportTask_sourceArn :: Lens.Lens' StartExportTask Prelude.Text
startExportTask_sourceArn :: Lens' StartExportTask Text
startExportTask_sourceArn = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\StartExportTask' {Text
sourceArn :: Text
$sel:sourceArn:StartExportTask' :: StartExportTask -> Text
sourceArn} -> Text
sourceArn) (\s :: StartExportTask
s@StartExportTask' {} Text
a -> StartExportTask
s {$sel:sourceArn:StartExportTask' :: Text
sourceArn = Text
a} :: StartExportTask)
startExportTask_s3BucketName :: Lens.Lens' StartExportTask Prelude.Text
startExportTask_s3BucketName :: Lens' StartExportTask Text
startExportTask_s3BucketName = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\StartExportTask' {Text
s3BucketName :: Text
$sel:s3BucketName:StartExportTask' :: StartExportTask -> Text
s3BucketName} -> Text
s3BucketName) (\s :: StartExportTask
s@StartExportTask' {} Text
a -> StartExportTask
s {$sel:s3BucketName:StartExportTask' :: Text
s3BucketName = Text
a} :: StartExportTask)
startExportTask_iamRoleArn :: Lens.Lens' StartExportTask Prelude.Text
startExportTask_iamRoleArn :: Lens' StartExportTask Text
startExportTask_iamRoleArn = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\StartExportTask' {Text
iamRoleArn :: Text
$sel:iamRoleArn:StartExportTask' :: StartExportTask -> Text
iamRoleArn} -> Text
iamRoleArn) (\s :: StartExportTask
s@StartExportTask' {} Text
a -> StartExportTask
s {$sel:iamRoleArn:StartExportTask' :: Text
iamRoleArn = Text
a} :: StartExportTask)
startExportTask_kmsKeyId :: Lens.Lens' StartExportTask Prelude.Text
startExportTask_kmsKeyId :: Lens' StartExportTask Text
startExportTask_kmsKeyId = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\StartExportTask' {Text
kmsKeyId :: Text
$sel:kmsKeyId:StartExportTask' :: StartExportTask -> Text
kmsKeyId} -> Text
kmsKeyId) (\s :: StartExportTask
s@StartExportTask' {} Text
a -> StartExportTask
s {$sel:kmsKeyId:StartExportTask' :: Text
kmsKeyId = Text
a} :: StartExportTask)
instance Core.AWSRequest StartExportTask where
type AWSResponse StartExportTask = ExportTask
request :: (Service -> Service) -> StartExportTask -> Request StartExportTask
request Service -> Service
overrides =
forall a. ToRequest a => Service -> a -> Request a
Request.postQuery (Service -> Service
overrides Service
defaultService)
response :: forall (m :: * -> *).
MonadResource m =>
(ByteStringLazy -> IO ByteStringLazy)
-> Service
-> Proxy StartExportTask
-> ClientResponse ClientBody
-> m (Either Error (ClientResponse (AWSResponse StartExportTask)))
response =
forall (m :: * -> *) a.
MonadResource m =>
Text
-> (Int
-> ResponseHeaders -> [Node] -> Either String (AWSResponse a))
-> (ByteStringLazy -> IO ByteStringLazy)
-> Service
-> Proxy a
-> ClientResponse ClientBody
-> m (Either Error (ClientResponse (AWSResponse a)))
Response.receiveXMLWrapper
Text
"StartExportTaskResult"
(\Int
s ResponseHeaders
h [Node]
x -> forall a. FromXML a => [Node] -> Either String a
Data.parseXML [Node]
x)
instance Prelude.Hashable StartExportTask where
hashWithSalt :: Int -> StartExportTask -> Int
hashWithSalt Int
_salt StartExportTask' {Maybe [Text]
Maybe Text
Text
kmsKeyId :: Text
iamRoleArn :: Text
s3BucketName :: Text
sourceArn :: Text
exportTaskIdentifier :: Text
s3Prefix :: Maybe Text
exportOnly :: Maybe [Text]
$sel:kmsKeyId:StartExportTask' :: StartExportTask -> Text
$sel:iamRoleArn:StartExportTask' :: StartExportTask -> Text
$sel:s3BucketName:StartExportTask' :: StartExportTask -> Text
$sel:sourceArn:StartExportTask' :: StartExportTask -> Text
$sel:exportTaskIdentifier:StartExportTask' :: StartExportTask -> Text
$sel:s3Prefix:StartExportTask' :: StartExportTask -> Maybe Text
$sel:exportOnly:StartExportTask' :: StartExportTask -> Maybe [Text]
..} =
Int
_salt
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe [Text]
exportOnly
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe Text
s3Prefix
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Text
exportTaskIdentifier
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Text
sourceArn
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Text
s3BucketName
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Text
iamRoleArn
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Text
kmsKeyId
instance Prelude.NFData StartExportTask where
rnf :: StartExportTask -> ()
rnf StartExportTask' {Maybe [Text]
Maybe Text
Text
kmsKeyId :: Text
iamRoleArn :: Text
s3BucketName :: Text
sourceArn :: Text
exportTaskIdentifier :: Text
s3Prefix :: Maybe Text
exportOnly :: Maybe [Text]
$sel:kmsKeyId:StartExportTask' :: StartExportTask -> Text
$sel:iamRoleArn:StartExportTask' :: StartExportTask -> Text
$sel:s3BucketName:StartExportTask' :: StartExportTask -> Text
$sel:sourceArn:StartExportTask' :: StartExportTask -> Text
$sel:exportTaskIdentifier:StartExportTask' :: StartExportTask -> Text
$sel:s3Prefix:StartExportTask' :: StartExportTask -> Maybe Text
$sel:exportOnly:StartExportTask' :: StartExportTask -> Maybe [Text]
..} =
forall a. NFData a => a -> ()
Prelude.rnf Maybe [Text]
exportOnly
seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe Text
s3Prefix
seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Text
exportTaskIdentifier
seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Text
sourceArn
seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Text
s3BucketName
seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Text
iamRoleArn
seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Text
kmsKeyId
instance Data.ToHeaders StartExportTask where
toHeaders :: StartExportTask -> ResponseHeaders
toHeaders = forall a b. a -> b -> a
Prelude.const forall a. Monoid a => a
Prelude.mempty
instance Data.ToPath StartExportTask where
toPath :: StartExportTask -> ByteString
toPath = forall a b. a -> b -> a
Prelude.const ByteString
"/"
instance Data.ToQuery StartExportTask where
toQuery :: StartExportTask -> QueryString
toQuery StartExportTask' {Maybe [Text]
Maybe Text
Text
kmsKeyId :: Text
iamRoleArn :: Text
s3BucketName :: Text
sourceArn :: Text
exportTaskIdentifier :: Text
s3Prefix :: Maybe Text
exportOnly :: Maybe [Text]
$sel:kmsKeyId:StartExportTask' :: StartExportTask -> Text
$sel:iamRoleArn:StartExportTask' :: StartExportTask -> Text
$sel:s3BucketName:StartExportTask' :: StartExportTask -> Text
$sel:sourceArn:StartExportTask' :: StartExportTask -> Text
$sel:exportTaskIdentifier:StartExportTask' :: StartExportTask -> Text
$sel:s3Prefix:StartExportTask' :: StartExportTask -> Maybe Text
$sel:exportOnly:StartExportTask' :: StartExportTask -> Maybe [Text]
..} =
forall a. Monoid a => [a] -> a
Prelude.mconcat
[ ByteString
"Action"
forall a. ToQuery a => ByteString -> a -> QueryString
Data.=: (ByteString
"StartExportTask" :: Prelude.ByteString),
ByteString
"Version"
forall a. ToQuery a => ByteString -> a -> QueryString
Data.=: (ByteString
"2014-10-31" :: Prelude.ByteString),
ByteString
"ExportOnly"
forall a. ToQuery a => ByteString -> a -> QueryString
Data.=: forall a. ToQuery a => a -> QueryString
Data.toQuery
(forall a.
(IsList a, ToQuery (Item a)) =>
ByteString -> a -> QueryString
Data.toQueryList ByteString
"member" forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
Prelude.<$> Maybe [Text]
exportOnly),
ByteString
"S3Prefix" forall a. ToQuery a => ByteString -> a -> QueryString
Data.=: Maybe Text
s3Prefix,
ByteString
"ExportTaskIdentifier" forall a. ToQuery a => ByteString -> a -> QueryString
Data.=: Text
exportTaskIdentifier,
ByteString
"SourceArn" forall a. ToQuery a => ByteString -> a -> QueryString
Data.=: Text
sourceArn,
ByteString
"S3BucketName" forall a. ToQuery a => ByteString -> a -> QueryString
Data.=: Text
s3BucketName,
ByteString
"IamRoleArn" forall a. ToQuery a => ByteString -> a -> QueryString
Data.=: Text
iamRoleArn,
ByteString
"KmsKeyId" forall a. ToQuery a => ByteString -> a -> QueryString
Data.=: Text
kmsKeyId
]