{-# 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.DataBrew.UpdateDataset
(
UpdateDataset (..),
newUpdateDataset,
updateDataset_format,
updateDataset_formatOptions,
updateDataset_pathOptions,
updateDataset_name,
updateDataset_input,
UpdateDatasetResponse (..),
newUpdateDatasetResponse,
updateDatasetResponse_httpStatus,
updateDatasetResponse_name,
)
where
import qualified Amazonka.Core as Core
import qualified Amazonka.Core.Lens.Internal as Lens
import qualified Amazonka.Data as Data
import Amazonka.DataBrew.Types
import qualified Amazonka.Prelude as Prelude
import qualified Amazonka.Request as Request
import qualified Amazonka.Response as Response
data UpdateDataset = UpdateDataset'
{
UpdateDataset -> Maybe InputFormat
format :: Prelude.Maybe InputFormat,
UpdateDataset -> Maybe FormatOptions
formatOptions :: Prelude.Maybe FormatOptions,
UpdateDataset -> Maybe PathOptions
pathOptions :: Prelude.Maybe PathOptions,
UpdateDataset -> Text
name :: Prelude.Text,
UpdateDataset -> Input
input :: Input
}
deriving (UpdateDataset -> UpdateDataset -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: UpdateDataset -> UpdateDataset -> Bool
$c/= :: UpdateDataset -> UpdateDataset -> Bool
== :: UpdateDataset -> UpdateDataset -> Bool
$c== :: UpdateDataset -> UpdateDataset -> Bool
Prelude.Eq, ReadPrec [UpdateDataset]
ReadPrec UpdateDataset
Int -> ReadS UpdateDataset
ReadS [UpdateDataset]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [UpdateDataset]
$creadListPrec :: ReadPrec [UpdateDataset]
readPrec :: ReadPrec UpdateDataset
$creadPrec :: ReadPrec UpdateDataset
readList :: ReadS [UpdateDataset]
$creadList :: ReadS [UpdateDataset]
readsPrec :: Int -> ReadS UpdateDataset
$creadsPrec :: Int -> ReadS UpdateDataset
Prelude.Read, Int -> UpdateDataset -> ShowS
[UpdateDataset] -> ShowS
UpdateDataset -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [UpdateDataset] -> ShowS
$cshowList :: [UpdateDataset] -> ShowS
show :: UpdateDataset -> String
$cshow :: UpdateDataset -> String
showsPrec :: Int -> UpdateDataset -> ShowS
$cshowsPrec :: Int -> UpdateDataset -> ShowS
Prelude.Show, forall x. Rep UpdateDataset x -> UpdateDataset
forall x. UpdateDataset -> Rep UpdateDataset x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep UpdateDataset x -> UpdateDataset
$cfrom :: forall x. UpdateDataset -> Rep UpdateDataset x
Prelude.Generic)
newUpdateDataset ::
Prelude.Text ->
Input ->
UpdateDataset
newUpdateDataset :: Text -> Input -> UpdateDataset
newUpdateDataset Text
pName_ Input
pInput_ =
UpdateDataset'
{ $sel:format:UpdateDataset' :: Maybe InputFormat
format = forall a. Maybe a
Prelude.Nothing,
$sel:formatOptions:UpdateDataset' :: Maybe FormatOptions
formatOptions = forall a. Maybe a
Prelude.Nothing,
$sel:pathOptions:UpdateDataset' :: Maybe PathOptions
pathOptions = forall a. Maybe a
Prelude.Nothing,
$sel:name:UpdateDataset' :: Text
name = Text
pName_,
$sel:input:UpdateDataset' :: Input
input = Input
pInput_
}
updateDataset_format :: Lens.Lens' UpdateDataset (Prelude.Maybe InputFormat)
updateDataset_format :: Lens' UpdateDataset (Maybe InputFormat)
updateDataset_format = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\UpdateDataset' {Maybe InputFormat
format :: Maybe InputFormat
$sel:format:UpdateDataset' :: UpdateDataset -> Maybe InputFormat
format} -> Maybe InputFormat
format) (\s :: UpdateDataset
s@UpdateDataset' {} Maybe InputFormat
a -> UpdateDataset
s {$sel:format:UpdateDataset' :: Maybe InputFormat
format = Maybe InputFormat
a} :: UpdateDataset)
updateDataset_formatOptions :: Lens.Lens' UpdateDataset (Prelude.Maybe FormatOptions)
updateDataset_formatOptions :: Lens' UpdateDataset (Maybe FormatOptions)
updateDataset_formatOptions = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\UpdateDataset' {Maybe FormatOptions
formatOptions :: Maybe FormatOptions
$sel:formatOptions:UpdateDataset' :: UpdateDataset -> Maybe FormatOptions
formatOptions} -> Maybe FormatOptions
formatOptions) (\s :: UpdateDataset
s@UpdateDataset' {} Maybe FormatOptions
a -> UpdateDataset
s {$sel:formatOptions:UpdateDataset' :: Maybe FormatOptions
formatOptions = Maybe FormatOptions
a} :: UpdateDataset)
updateDataset_pathOptions :: Lens.Lens' UpdateDataset (Prelude.Maybe PathOptions)
updateDataset_pathOptions :: Lens' UpdateDataset (Maybe PathOptions)
updateDataset_pathOptions = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\UpdateDataset' {Maybe PathOptions
pathOptions :: Maybe PathOptions
$sel:pathOptions:UpdateDataset' :: UpdateDataset -> Maybe PathOptions
pathOptions} -> Maybe PathOptions
pathOptions) (\s :: UpdateDataset
s@UpdateDataset' {} Maybe PathOptions
a -> UpdateDataset
s {$sel:pathOptions:UpdateDataset' :: Maybe PathOptions
pathOptions = Maybe PathOptions
a} :: UpdateDataset)
updateDataset_name :: Lens.Lens' UpdateDataset Prelude.Text
updateDataset_name :: Lens' UpdateDataset Text
updateDataset_name = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\UpdateDataset' {Text
name :: Text
$sel:name:UpdateDataset' :: UpdateDataset -> Text
name} -> Text
name) (\s :: UpdateDataset
s@UpdateDataset' {} Text
a -> UpdateDataset
s {$sel:name:UpdateDataset' :: Text
name = Text
a} :: UpdateDataset)
updateDataset_input :: Lens.Lens' UpdateDataset Input
updateDataset_input :: Lens' UpdateDataset Input
updateDataset_input = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\UpdateDataset' {Input
input :: Input
$sel:input:UpdateDataset' :: UpdateDataset -> Input
input} -> Input
input) (\s :: UpdateDataset
s@UpdateDataset' {} Input
a -> UpdateDataset
s {$sel:input:UpdateDataset' :: Input
input = Input
a} :: UpdateDataset)
instance Core.AWSRequest UpdateDataset where
type
AWSResponse UpdateDataset =
UpdateDatasetResponse
request :: (Service -> Service) -> UpdateDataset -> Request UpdateDataset
request Service -> Service
overrides =
forall a. (ToRequest a, ToJSON a) => Service -> a -> Request a
Request.putJSON (Service -> Service
overrides Service
defaultService)
response :: forall (m :: * -> *).
MonadResource m =>
(ByteStringLazy -> IO ByteStringLazy)
-> Service
-> Proxy UpdateDataset
-> ClientResponse ClientBody
-> m (Either Error (ClientResponse (AWSResponse UpdateDataset)))
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 ->
Int -> Text -> UpdateDatasetResponse
UpdateDatasetResponse'
forall (f :: * -> *) a b. Functor 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
"Name")
)
instance Prelude.Hashable UpdateDataset where
hashWithSalt :: Int -> UpdateDataset -> Int
hashWithSalt Int
_salt UpdateDataset' {Maybe InputFormat
Maybe FormatOptions
Maybe PathOptions
Text
Input
input :: Input
name :: Text
pathOptions :: Maybe PathOptions
formatOptions :: Maybe FormatOptions
format :: Maybe InputFormat
$sel:input:UpdateDataset' :: UpdateDataset -> Input
$sel:name:UpdateDataset' :: UpdateDataset -> Text
$sel:pathOptions:UpdateDataset' :: UpdateDataset -> Maybe PathOptions
$sel:formatOptions:UpdateDataset' :: UpdateDataset -> Maybe FormatOptions
$sel:format:UpdateDataset' :: UpdateDataset -> Maybe InputFormat
..} =
Int
_salt
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe InputFormat
format
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe FormatOptions
formatOptions
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe PathOptions
pathOptions
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Text
name
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Input
input
instance Prelude.NFData UpdateDataset where
rnf :: UpdateDataset -> ()
rnf UpdateDataset' {Maybe InputFormat
Maybe FormatOptions
Maybe PathOptions
Text
Input
input :: Input
name :: Text
pathOptions :: Maybe PathOptions
formatOptions :: Maybe FormatOptions
format :: Maybe InputFormat
$sel:input:UpdateDataset' :: UpdateDataset -> Input
$sel:name:UpdateDataset' :: UpdateDataset -> Text
$sel:pathOptions:UpdateDataset' :: UpdateDataset -> Maybe PathOptions
$sel:formatOptions:UpdateDataset' :: UpdateDataset -> Maybe FormatOptions
$sel:format:UpdateDataset' :: UpdateDataset -> Maybe InputFormat
..} =
forall a. NFData a => a -> ()
Prelude.rnf Maybe InputFormat
format
seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe FormatOptions
formatOptions
seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe PathOptions
pathOptions
seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Text
name
seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Input
input
instance Data.ToHeaders UpdateDataset where
toHeaders :: UpdateDataset -> 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 UpdateDataset where
toJSON :: UpdateDataset -> Value
toJSON UpdateDataset' {Maybe InputFormat
Maybe FormatOptions
Maybe PathOptions
Text
Input
input :: Input
name :: Text
pathOptions :: Maybe PathOptions
formatOptions :: Maybe FormatOptions
format :: Maybe InputFormat
$sel:input:UpdateDataset' :: UpdateDataset -> Input
$sel:name:UpdateDataset' :: UpdateDataset -> Text
$sel:pathOptions:UpdateDataset' :: UpdateDataset -> Maybe PathOptions
$sel:formatOptions:UpdateDataset' :: UpdateDataset -> Maybe FormatOptions
$sel:format:UpdateDataset' :: UpdateDataset -> Maybe InputFormat
..} =
[Pair] -> Value
Data.object
( forall a. [Maybe a] -> [a]
Prelude.catMaybes
[ (Key
"Format" 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 InputFormat
format,
(Key
"FormatOptions" 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 FormatOptions
formatOptions,
(Key
"PathOptions" 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 PathOptions
pathOptions,
forall a. a -> Maybe a
Prelude.Just (Key
"Input" forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
Data..= Input
input)
]
)
instance Data.ToPath UpdateDataset where
toPath :: UpdateDataset -> ByteString
toPath UpdateDataset' {Maybe InputFormat
Maybe FormatOptions
Maybe PathOptions
Text
Input
input :: Input
name :: Text
pathOptions :: Maybe PathOptions
formatOptions :: Maybe FormatOptions
format :: Maybe InputFormat
$sel:input:UpdateDataset' :: UpdateDataset -> Input
$sel:name:UpdateDataset' :: UpdateDataset -> Text
$sel:pathOptions:UpdateDataset' :: UpdateDataset -> Maybe PathOptions
$sel:formatOptions:UpdateDataset' :: UpdateDataset -> Maybe FormatOptions
$sel:format:UpdateDataset' :: UpdateDataset -> Maybe InputFormat
..} =
forall a. Monoid a => [a] -> a
Prelude.mconcat [ByteString
"/datasets/", forall a. ToByteString a => a -> ByteString
Data.toBS Text
name]
instance Data.ToQuery UpdateDataset where
toQuery :: UpdateDataset -> QueryString
toQuery = forall a b. a -> b -> a
Prelude.const forall a. Monoid a => a
Prelude.mempty
data UpdateDatasetResponse = UpdateDatasetResponse'
{
UpdateDatasetResponse -> Int
httpStatus :: Prelude.Int,
UpdateDatasetResponse -> Text
name :: Prelude.Text
}
deriving (UpdateDatasetResponse -> UpdateDatasetResponse -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: UpdateDatasetResponse -> UpdateDatasetResponse -> Bool
$c/= :: UpdateDatasetResponse -> UpdateDatasetResponse -> Bool
== :: UpdateDatasetResponse -> UpdateDatasetResponse -> Bool
$c== :: UpdateDatasetResponse -> UpdateDatasetResponse -> Bool
Prelude.Eq, ReadPrec [UpdateDatasetResponse]
ReadPrec UpdateDatasetResponse
Int -> ReadS UpdateDatasetResponse
ReadS [UpdateDatasetResponse]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [UpdateDatasetResponse]
$creadListPrec :: ReadPrec [UpdateDatasetResponse]
readPrec :: ReadPrec UpdateDatasetResponse
$creadPrec :: ReadPrec UpdateDatasetResponse
readList :: ReadS [UpdateDatasetResponse]
$creadList :: ReadS [UpdateDatasetResponse]
readsPrec :: Int -> ReadS UpdateDatasetResponse
$creadsPrec :: Int -> ReadS UpdateDatasetResponse
Prelude.Read, Int -> UpdateDatasetResponse -> ShowS
[UpdateDatasetResponse] -> ShowS
UpdateDatasetResponse -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [UpdateDatasetResponse] -> ShowS
$cshowList :: [UpdateDatasetResponse] -> ShowS
show :: UpdateDatasetResponse -> String
$cshow :: UpdateDatasetResponse -> String
showsPrec :: Int -> UpdateDatasetResponse -> ShowS
$cshowsPrec :: Int -> UpdateDatasetResponse -> ShowS
Prelude.Show, forall x. Rep UpdateDatasetResponse x -> UpdateDatasetResponse
forall x. UpdateDatasetResponse -> Rep UpdateDatasetResponse x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep UpdateDatasetResponse x -> UpdateDatasetResponse
$cfrom :: forall x. UpdateDatasetResponse -> Rep UpdateDatasetResponse x
Prelude.Generic)
newUpdateDatasetResponse ::
Prelude.Int ->
Prelude.Text ->
UpdateDatasetResponse
newUpdateDatasetResponse :: Int -> Text -> UpdateDatasetResponse
newUpdateDatasetResponse Int
pHttpStatus_ Text
pName_ =
UpdateDatasetResponse'
{ $sel:httpStatus:UpdateDatasetResponse' :: Int
httpStatus = Int
pHttpStatus_,
$sel:name:UpdateDatasetResponse' :: Text
name = Text
pName_
}
updateDatasetResponse_httpStatus :: Lens.Lens' UpdateDatasetResponse Prelude.Int
updateDatasetResponse_httpStatus :: Lens' UpdateDatasetResponse Int
updateDatasetResponse_httpStatus = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\UpdateDatasetResponse' {Int
httpStatus :: Int
$sel:httpStatus:UpdateDatasetResponse' :: UpdateDatasetResponse -> Int
httpStatus} -> Int
httpStatus) (\s :: UpdateDatasetResponse
s@UpdateDatasetResponse' {} Int
a -> UpdateDatasetResponse
s {$sel:httpStatus:UpdateDatasetResponse' :: Int
httpStatus = Int
a} :: UpdateDatasetResponse)
updateDatasetResponse_name :: Lens.Lens' UpdateDatasetResponse Prelude.Text
updateDatasetResponse_name :: Lens' UpdateDatasetResponse Text
updateDatasetResponse_name = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\UpdateDatasetResponse' {Text
name :: Text
$sel:name:UpdateDatasetResponse' :: UpdateDatasetResponse -> Text
name} -> Text
name) (\s :: UpdateDatasetResponse
s@UpdateDatasetResponse' {} Text
a -> UpdateDatasetResponse
s {$sel:name:UpdateDatasetResponse' :: Text
name = Text
a} :: UpdateDatasetResponse)
instance Prelude.NFData UpdateDatasetResponse where
rnf :: UpdateDatasetResponse -> ()
rnf UpdateDatasetResponse' {Int
Text
name :: Text
httpStatus :: Int
$sel:name:UpdateDatasetResponse' :: UpdateDatasetResponse -> Text
$sel:httpStatus:UpdateDatasetResponse' :: UpdateDatasetResponse -> Int
..} =
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 Text
name