{-# 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.OpsWorks.AssignInstance
(
AssignInstance (..),
newAssignInstance,
assignInstance_instanceId,
assignInstance_layerIds,
AssignInstanceResponse (..),
newAssignInstanceResponse,
)
where
import qualified Amazonka.Core as Core
import qualified Amazonka.Core.Lens.Internal as Lens
import qualified Amazonka.Data as Data
import Amazonka.OpsWorks.Types
import qualified Amazonka.Prelude as Prelude
import qualified Amazonka.Request as Request
import qualified Amazonka.Response as Response
data AssignInstance = AssignInstance'
{
AssignInstance -> Text
instanceId :: Prelude.Text,
AssignInstance -> [Text]
layerIds :: [Prelude.Text]
}
deriving (AssignInstance -> AssignInstance -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: AssignInstance -> AssignInstance -> Bool
$c/= :: AssignInstance -> AssignInstance -> Bool
== :: AssignInstance -> AssignInstance -> Bool
$c== :: AssignInstance -> AssignInstance -> Bool
Prelude.Eq, ReadPrec [AssignInstance]
ReadPrec AssignInstance
Int -> ReadS AssignInstance
ReadS [AssignInstance]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [AssignInstance]
$creadListPrec :: ReadPrec [AssignInstance]
readPrec :: ReadPrec AssignInstance
$creadPrec :: ReadPrec AssignInstance
readList :: ReadS [AssignInstance]
$creadList :: ReadS [AssignInstance]
readsPrec :: Int -> ReadS AssignInstance
$creadsPrec :: Int -> ReadS AssignInstance
Prelude.Read, Int -> AssignInstance -> ShowS
[AssignInstance] -> ShowS
AssignInstance -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [AssignInstance] -> ShowS
$cshowList :: [AssignInstance] -> ShowS
show :: AssignInstance -> String
$cshow :: AssignInstance -> String
showsPrec :: Int -> AssignInstance -> ShowS
$cshowsPrec :: Int -> AssignInstance -> ShowS
Prelude.Show, forall x. Rep AssignInstance x -> AssignInstance
forall x. AssignInstance -> Rep AssignInstance x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep AssignInstance x -> AssignInstance
$cfrom :: forall x. AssignInstance -> Rep AssignInstance x
Prelude.Generic)
newAssignInstance ::
Prelude.Text ->
AssignInstance
newAssignInstance :: Text -> AssignInstance
newAssignInstance Text
pInstanceId_ =
AssignInstance'
{ $sel:instanceId:AssignInstance' :: Text
instanceId = Text
pInstanceId_,
$sel:layerIds:AssignInstance' :: [Text]
layerIds = forall a. Monoid a => a
Prelude.mempty
}
assignInstance_instanceId :: Lens.Lens' AssignInstance Prelude.Text
assignInstance_instanceId :: Lens' AssignInstance Text
assignInstance_instanceId = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\AssignInstance' {Text
instanceId :: Text
$sel:instanceId:AssignInstance' :: AssignInstance -> Text
instanceId} -> Text
instanceId) (\s :: AssignInstance
s@AssignInstance' {} Text
a -> AssignInstance
s {$sel:instanceId:AssignInstance' :: Text
instanceId = Text
a} :: AssignInstance)
assignInstance_layerIds :: Lens.Lens' AssignInstance [Prelude.Text]
assignInstance_layerIds :: Lens' AssignInstance [Text]
assignInstance_layerIds = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\AssignInstance' {[Text]
layerIds :: [Text]
$sel:layerIds:AssignInstance' :: AssignInstance -> [Text]
layerIds} -> [Text]
layerIds) (\s :: AssignInstance
s@AssignInstance' {} [Text]
a -> AssignInstance
s {$sel:layerIds:AssignInstance' :: [Text]
layerIds = [Text]
a} :: AssignInstance) forall b c a. (b -> c) -> (a -> b) -> a -> c
Prelude.. forall s t a b. (Coercible s a, Coercible t b) => Iso s t a b
Lens.coerced
instance Core.AWSRequest AssignInstance where
type
AWSResponse AssignInstance =
AssignInstanceResponse
request :: (Service -> Service) -> AssignInstance -> Request AssignInstance
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 AssignInstance
-> ClientResponse ClientBody
-> m (Either Error (ClientResponse (AWSResponse AssignInstance)))
response =
forall (m :: * -> *) a.
MonadResource m =>
AWSResponse a
-> (ByteStringLazy -> IO ByteStringLazy)
-> Service
-> Proxy a
-> ClientResponse ClientBody
-> m (Either Error (ClientResponse (AWSResponse a)))
Response.receiveNull AssignInstanceResponse
AssignInstanceResponse'
instance Prelude.Hashable AssignInstance where
hashWithSalt :: Int -> AssignInstance -> Int
hashWithSalt Int
_salt AssignInstance' {[Text]
Text
layerIds :: [Text]
instanceId :: Text
$sel:layerIds:AssignInstance' :: AssignInstance -> [Text]
$sel:instanceId:AssignInstance' :: AssignInstance -> Text
..} =
Int
_salt
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Text
instanceId
forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` [Text]
layerIds
instance Prelude.NFData AssignInstance where
rnf :: AssignInstance -> ()
rnf AssignInstance' {[Text]
Text
layerIds :: [Text]
instanceId :: Text
$sel:layerIds:AssignInstance' :: AssignInstance -> [Text]
$sel:instanceId:AssignInstance' :: AssignInstance -> Text
..} =
forall a. NFData a => a -> ()
Prelude.rnf Text
instanceId
seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf [Text]
layerIds
instance Data.ToHeaders AssignInstance where
toHeaders :: AssignInstance -> [Header]
toHeaders =
forall a b. a -> b -> a
Prelude.const
( forall a. Monoid a => [a] -> a
Prelude.mconcat
[ HeaderName
"X-Amz-Target"
forall a. ToHeader a => HeaderName -> a -> [Header]
Data.=# ( ByteString
"OpsWorks_20130218.AssignInstance" ::
Prelude.ByteString
),
HeaderName
"Content-Type"
forall a. ToHeader a => HeaderName -> a -> [Header]
Data.=# ( ByteString
"application/x-amz-json-1.1" ::
Prelude.ByteString
)
]
)
instance Data.ToJSON AssignInstance where
toJSON :: AssignInstance -> Value
toJSON AssignInstance' {[Text]
Text
layerIds :: [Text]
instanceId :: Text
$sel:layerIds:AssignInstance' :: AssignInstance -> [Text]
$sel:instanceId:AssignInstance' :: AssignInstance -> Text
..} =
[Pair] -> Value
Data.object
( forall a. [Maybe a] -> [a]
Prelude.catMaybes
[ forall a. a -> Maybe a
Prelude.Just (Key
"InstanceId" forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
Data..= Text
instanceId),
forall a. a -> Maybe a
Prelude.Just (Key
"LayerIds" forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
Data..= [Text]
layerIds)
]
)
instance Data.ToPath AssignInstance where
toPath :: AssignInstance -> ByteString
toPath = forall a b. a -> b -> a
Prelude.const ByteString
"/"
instance Data.ToQuery AssignInstance where
toQuery :: AssignInstance -> QueryString
toQuery = forall a b. a -> b -> a
Prelude.const forall a. Monoid a => a
Prelude.mempty
data AssignInstanceResponse = AssignInstanceResponse'
{
}
deriving (AssignInstanceResponse -> AssignInstanceResponse -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: AssignInstanceResponse -> AssignInstanceResponse -> Bool
$c/= :: AssignInstanceResponse -> AssignInstanceResponse -> Bool
== :: AssignInstanceResponse -> AssignInstanceResponse -> Bool
$c== :: AssignInstanceResponse -> AssignInstanceResponse -> Bool
Prelude.Eq, ReadPrec [AssignInstanceResponse]
ReadPrec AssignInstanceResponse
Int -> ReadS AssignInstanceResponse
ReadS [AssignInstanceResponse]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [AssignInstanceResponse]
$creadListPrec :: ReadPrec [AssignInstanceResponse]
readPrec :: ReadPrec AssignInstanceResponse
$creadPrec :: ReadPrec AssignInstanceResponse
readList :: ReadS [AssignInstanceResponse]
$creadList :: ReadS [AssignInstanceResponse]
readsPrec :: Int -> ReadS AssignInstanceResponse
$creadsPrec :: Int -> ReadS AssignInstanceResponse
Prelude.Read, Int -> AssignInstanceResponse -> ShowS
[AssignInstanceResponse] -> ShowS
AssignInstanceResponse -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [AssignInstanceResponse] -> ShowS
$cshowList :: [AssignInstanceResponse] -> ShowS
show :: AssignInstanceResponse -> String
$cshow :: AssignInstanceResponse -> String
showsPrec :: Int -> AssignInstanceResponse -> ShowS
$cshowsPrec :: Int -> AssignInstanceResponse -> ShowS
Prelude.Show, forall x. Rep AssignInstanceResponse x -> AssignInstanceResponse
forall x. AssignInstanceResponse -> Rep AssignInstanceResponse x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep AssignInstanceResponse x -> AssignInstanceResponse
$cfrom :: forall x. AssignInstanceResponse -> Rep AssignInstanceResponse x
Prelude.Generic)
newAssignInstanceResponse ::
AssignInstanceResponse
newAssignInstanceResponse :: AssignInstanceResponse
newAssignInstanceResponse = AssignInstanceResponse
AssignInstanceResponse'
instance Prelude.NFData AssignInstanceResponse where
rnf :: AssignInstanceResponse -> ()
rnf AssignInstanceResponse
_ = ()