{-# 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.CreateDataset
(
CreateDataset (..),
newCreateDataset,
createDataset_format,
createDataset_formatOptions,
createDataset_pathOptions,
createDataset_tags,
createDataset_name,
createDataset_input,
CreateDatasetResponse (..),
newCreateDatasetResponse,
createDatasetResponse_httpStatus,
createDatasetResponse_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 CreateDataset = CreateDataset'
{
CreateDataset -> Maybe InputFormat
format :: Prelude.Maybe InputFormat,
CreateDataset -> Maybe FormatOptions
formatOptions :: Prelude.Maybe FormatOptions,
CreateDataset -> Maybe PathOptions
pathOptions :: Prelude.Maybe PathOptions,
CreateDataset -> Maybe (HashMap Text Text)
tags :: Prelude.Maybe (Prelude.HashMap Prelude.Text Prelude.Text),
CreateDataset -> Text
name :: Prelude.Text,
CreateDataset -> Input
input :: Input
}
deriving (CreateDataset -> CreateDataset -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: CreateDataset -> CreateDataset -> Bool
$c/= :: CreateDataset -> CreateDataset -> Bool
== :: CreateDataset -> CreateDataset -> Bool
$c== :: CreateDataset -> CreateDataset -> Bool
Prelude.Eq, ReadPrec [CreateDataset]
ReadPrec CreateDataset
Int -> ReadS CreateDataset
ReadS [CreateDataset]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [CreateDataset]
$creadListPrec :: ReadPrec [CreateDataset]
readPrec :: ReadPrec CreateDataset
$creadPrec :: ReadPrec CreateDataset
readList :: ReadS [CreateDataset]
$creadList :: ReadS [CreateDataset]
readsPrec :: Int -> ReadS CreateDataset
$creadsPrec :: Int -> ReadS CreateDataset
Prelude.Read, Int -> CreateDataset -> ShowS
[CreateDataset] -> ShowS
CreateDataset -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [CreateDataset] -> ShowS
$cshowList :: [CreateDataset] -> ShowS
show :: CreateDataset -> String
$cshow :: CreateDataset -> String
showsPrec :: Int -> CreateDataset -> ShowS
$cshowsPrec :: Int -> CreateDataset -> ShowS
Prelude.Show, forall x. Rep CreateDataset x -> CreateDataset
forall x. CreateDataset -> Rep CreateDataset x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep CreateDataset x -> CreateDataset
$cfrom :: forall x. CreateDataset -> Rep CreateDataset x
Prelude.Generic)
newCreateDataset ::
Prelude.Text ->
Input ->
CreateDataset
newCreateDataset :: Text -> Input -> CreateDataset
newCreateDataset Text
pName_ Input
pInput_ =
CreateDataset'
{ $sel:format:CreateDataset' :: Maybe InputFormat
format = forall a. Maybe a
Prelude.Nothing,
$sel:formatOptions:CreateDataset' :: Maybe FormatOptions
formatOptions = forall a. Maybe a
Prelude.Nothing,
$sel:pathOptions:CreateDataset' :: Maybe PathOptions
pathOptions = forall a. Maybe a
Prelude.Nothing,
$sel:tags:CreateDataset' :: Maybe (HashMap Text Text)
tags = forall a. Maybe a
Prelude.Nothing,
$sel:name:CreateDataset' :: Text
name = Text
pName_,
$sel:input:CreateDataset' :: Input
input = Input
pInput_
}
createDataset_format :: Lens.Lens' CreateDataset (Prelude.Maybe InputFormat)
createDataset_format :: Lens' CreateDataset (Maybe InputFormat)
createDataset_format = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\CreateDataset' {Maybe InputFormat
format :: Maybe InputFormat
$sel:format:CreateDataset' :: CreateDataset -> Maybe InputFormat
format} -> Maybe InputFormat
format) (\s :: CreateDataset
s@CreateDataset' {} Maybe InputFormat
a -> CreateDataset
s {$sel:format:CreateDataset' :: Maybe InputFormat
format = Maybe InputFormat
a} :: CreateDataset)
createDataset_formatOptions :: Lens.Lens' CreateDataset (Prelude.Maybe FormatOptions)
createDataset_formatOptions :: Lens' CreateDataset (Maybe FormatOptions)
createDataset_formatOptions = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\CreateDataset' {Maybe FormatOptions
formatOptions :: Maybe FormatOptions
$sel:formatOptions:CreateDataset' :: CreateDataset -> Maybe FormatOptions
formatOptions} -> Maybe FormatOptions
formatOptions) (\s :: CreateDataset
s@CreateDataset' {} Maybe FormatOptions
a -> CreateDataset
s {$sel:formatOptions:CreateDataset' :: Maybe FormatOptions
formatOptions = Maybe FormatOptions
a} :: CreateDataset)
createDataset_pathOptions :: Lens.Lens' CreateDataset (Prelude.Maybe PathOptions)
createDataset_pathOptions :: Lens' CreateDataset (Maybe PathOptions)
createDataset_pathOptions = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\CreateDataset' {Maybe PathOptions
pathOptions :: Maybe PathOptions
$sel:pathOptions:CreateDataset' :: CreateDataset -> Maybe PathOptions
pathOptions} -> Maybe PathOptions
pathOptions) (\s :: CreateDataset
s@CreateDataset' {} Maybe PathOptions
a -> CreateDataset
s {$sel:pathOptions:CreateDataset' :: Maybe PathOptions
pathOptions = Maybe PathOptions
a} :: CreateDataset)
createDataset_tags :: Lens.Lens' CreateDataset (Prelude.Maybe (Prelude.HashMap Prelude.Text Prelude.Text))
createDataset_tags :: Lens' CreateDataset (Maybe (HashMap Text Text))
createDataset_tags = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\CreateDataset' {Maybe (HashMap Text Text)
tags :: Maybe (HashMap Text Text)
$sel:tags:CreateDataset' :: CreateDataset -> Maybe (HashMap Text Text)
tags} -> Maybe (HashMap Text Text)
tags) (\s :: CreateDataset
s@CreateDataset' {} Maybe (HashMap Text Text)
a -> CreateDataset
s {$sel:tags:CreateDataset' :: Maybe (HashMap Text Text)
tags = Maybe (HashMap Text Text)
a} :: CreateDataset) 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
createDataset_name :: Lens.Lens' CreateDataset Prelude.Text
createDataset_name :: Lens' CreateDataset Text
createDataset_name = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\CreateDataset' {Text
name :: Text
$sel:name:CreateDataset' :: CreateDataset -> Text
name} -> Text
name) (\s :: CreateDataset
s@CreateDataset' {} Text
a -> CreateDataset
s {$sel:name:CreateDataset' :: Text
name = Text
a} :: CreateDataset)
createDataset_input :: Lens.Lens' CreateDataset Input
createDataset_input :: Lens' CreateDataset Input
createDataset_input = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\CreateDataset' {Input
input :: Input
$sel:input:CreateDataset' :: CreateDataset -> Input
input} -> Input
input) (\s :: CreateDataset
s@CreateDataset' {} Input
a -> CreateDataset
s {$sel:input:CreateDataset' :: Input
input = Input
a} :: CreateDataset)
instance Core.AWSRequest CreateDataset where
type
AWSResponse CreateDataset =
CreateDatasetResponse
request :: (Service -> Service) -> CreateDataset -> Request CreateDataset
request Service -> Service
overrides =
forall a. (ToRequest a, ToJSON a) => Service -> a -> Request a
Request.postJSON (Service -> Service
overrides Service
defaultService)
response :: forall (m :: * -> *).
MonadResource m =>
(ByteStringLazy -> IO ByteStringLazy)
-> Service
-> Proxy CreateDataset
-> ClientResponse ClientBody
-> m (Either Error (ClientResponse (AWSResponse CreateDataset)))
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 -> CreateDatasetResponse
CreateDatasetResponse'
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 CreateDataset where
hashWithSalt :: Int -> CreateDataset -> Int
hashWithSalt Int
_salt CreateDataset' {Maybe (HashMap Text Text)
Maybe InputFormat
Maybe FormatOptions
Maybe PathOptions
Text
Input
input :: Input
name :: Text
tags :: Maybe (HashMap Text Text)
pathOptions :: Maybe PathOptions
formatOptions :: Maybe FormatOptions
format :: Maybe InputFormat
$sel:input:CreateDataset' :: CreateDataset -> Input
$sel:name:CreateDataset' :: CreateDataset -> Text
$sel:tags:CreateDataset' :: CreateDataset -> Maybe (HashMap Text Text)
$sel:pathOptions:CreateDataset' :: CreateDataset -> Maybe PathOptions
$sel:formatOptions:CreateDataset' :: CreateDataset -> Maybe FormatOptions
$sel:format:CreateDataset' :: CreateDataset -> 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` Maybe (HashMap Text Text)
tags
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 CreateDataset where
rnf :: CreateDataset -> ()
rnf CreateDataset' {Maybe (HashMap Text Text)
Maybe InputFormat
Maybe FormatOptions
Maybe PathOptions
Text
Input
input :: Input
name :: Text
tags :: Maybe (HashMap Text Text)
pathOptions :: Maybe PathOptions
formatOptions :: Maybe FormatOptions
format :: Maybe InputFormat
$sel:input:CreateDataset' :: CreateDataset -> Input
$sel:name:CreateDataset' :: CreateDataset -> Text
$sel:tags:CreateDataset' :: CreateDataset -> Maybe (HashMap Text Text)
$sel:pathOptions:CreateDataset' :: CreateDataset -> Maybe PathOptions
$sel:formatOptions:CreateDataset' :: CreateDataset -> Maybe FormatOptions
$sel:format:CreateDataset' :: CreateDataset -> 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 Maybe (HashMap Text Text)
tags
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 CreateDataset where
toHeaders :: CreateDataset -> 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 CreateDataset where
toJSON :: CreateDataset -> Value
toJSON CreateDataset' {Maybe (HashMap Text Text)
Maybe InputFormat
Maybe FormatOptions
Maybe PathOptions
Text
Input
input :: Input
name :: Text
tags :: Maybe (HashMap Text Text)
pathOptions :: Maybe PathOptions
formatOptions :: Maybe FormatOptions
format :: Maybe InputFormat
$sel:input:CreateDataset' :: CreateDataset -> Input
$sel:name:CreateDataset' :: CreateDataset -> Text
$sel:tags:CreateDataset' :: CreateDataset -> Maybe (HashMap Text Text)
$sel:pathOptions:CreateDataset' :: CreateDataset -> Maybe PathOptions
$sel:formatOptions:CreateDataset' :: CreateDataset -> Maybe FormatOptions
$sel:format:CreateDataset' :: CreateDataset -> 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,
(Key
"Tags" 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 (HashMap Text Text)
tags,
forall a. a -> Maybe a
Prelude.Just (Key
"Name" forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
Data..= Text
name),
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 CreateDataset where
toPath :: CreateDataset -> ByteString
toPath = forall a b. a -> b -> a
Prelude.const ByteString
"/datasets"
instance Data.ToQuery CreateDataset where
toQuery :: CreateDataset -> QueryString
toQuery = forall a b. a -> b -> a
Prelude.const forall a. Monoid a => a
Prelude.mempty
data CreateDatasetResponse = CreateDatasetResponse'
{
CreateDatasetResponse -> Int
httpStatus :: Prelude.Int,
CreateDatasetResponse -> Text
name :: Prelude.Text
}
deriving (CreateDatasetResponse -> CreateDatasetResponse -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: CreateDatasetResponse -> CreateDatasetResponse -> Bool
$c/= :: CreateDatasetResponse -> CreateDatasetResponse -> Bool
== :: CreateDatasetResponse -> CreateDatasetResponse -> Bool
$c== :: CreateDatasetResponse -> CreateDatasetResponse -> Bool
Prelude.Eq, ReadPrec [CreateDatasetResponse]
ReadPrec CreateDatasetResponse
Int -> ReadS CreateDatasetResponse
ReadS [CreateDatasetResponse]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [CreateDatasetResponse]
$creadListPrec :: ReadPrec [CreateDatasetResponse]
readPrec :: ReadPrec CreateDatasetResponse
$creadPrec :: ReadPrec CreateDatasetResponse
readList :: ReadS [CreateDatasetResponse]
$creadList :: ReadS [CreateDatasetResponse]
readsPrec :: Int -> ReadS CreateDatasetResponse
$creadsPrec :: Int -> ReadS CreateDatasetResponse
Prelude.Read, Int -> CreateDatasetResponse -> ShowS
[CreateDatasetResponse] -> ShowS
CreateDatasetResponse -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [CreateDatasetResponse] -> ShowS
$cshowList :: [CreateDatasetResponse] -> ShowS
show :: CreateDatasetResponse -> String
$cshow :: CreateDatasetResponse -> String
showsPrec :: Int -> CreateDatasetResponse -> ShowS
$cshowsPrec :: Int -> CreateDatasetResponse -> ShowS
Prelude.Show, forall x. Rep CreateDatasetResponse x -> CreateDatasetResponse
forall x. CreateDatasetResponse -> Rep CreateDatasetResponse x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep CreateDatasetResponse x -> CreateDatasetResponse
$cfrom :: forall x. CreateDatasetResponse -> Rep CreateDatasetResponse x
Prelude.Generic)
newCreateDatasetResponse ::
Prelude.Int ->
Prelude.Text ->
CreateDatasetResponse
newCreateDatasetResponse :: Int -> Text -> CreateDatasetResponse
newCreateDatasetResponse Int
pHttpStatus_ Text
pName_ =
CreateDatasetResponse'
{ $sel:httpStatus:CreateDatasetResponse' :: Int
httpStatus = Int
pHttpStatus_,
$sel:name:CreateDatasetResponse' :: Text
name = Text
pName_
}
createDatasetResponse_httpStatus :: Lens.Lens' CreateDatasetResponse Prelude.Int
createDatasetResponse_httpStatus :: Lens' CreateDatasetResponse Int
createDatasetResponse_httpStatus = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\CreateDatasetResponse' {Int
httpStatus :: Int
$sel:httpStatus:CreateDatasetResponse' :: CreateDatasetResponse -> Int
httpStatus} -> Int
httpStatus) (\s :: CreateDatasetResponse
s@CreateDatasetResponse' {} Int
a -> CreateDatasetResponse
s {$sel:httpStatus:CreateDatasetResponse' :: Int
httpStatus = Int
a} :: CreateDatasetResponse)
createDatasetResponse_name :: Lens.Lens' CreateDatasetResponse Prelude.Text
createDatasetResponse_name :: Lens' CreateDatasetResponse Text
createDatasetResponse_name = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\CreateDatasetResponse' {Text
name :: Text
$sel:name:CreateDatasetResponse' :: CreateDatasetResponse -> Text
name} -> Text
name) (\s :: CreateDatasetResponse
s@CreateDatasetResponse' {} Text
a -> CreateDatasetResponse
s {$sel:name:CreateDatasetResponse' :: Text
name = Text
a} :: CreateDatasetResponse)
instance Prelude.NFData CreateDatasetResponse where
rnf :: CreateDatasetResponse -> ()
rnf CreateDatasetResponse' {Int
Text
name :: Text
httpStatus :: Int
$sel:name:CreateDatasetResponse' :: CreateDatasetResponse -> Text
$sel:httpStatus:CreateDatasetResponse' :: CreateDatasetResponse -> 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