{-# 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 #-}

-- Derived from AWS service descriptions, licensed under Apache 2.0.

-- |
-- Module      : Amazonka.EMR.AddInstanceFleet
-- Copyright   : (c) 2013-2023 Brendan Hay
-- License     : Mozilla Public License, v. 2.0.
-- Maintainer  : Brendan Hay
-- Stability   : auto-generated
-- Portability : non-portable (GHC extensions)
--
-- Adds an instance fleet to a running cluster.
--
-- The instance fleet configuration is available only in Amazon EMR
-- versions 4.8.0 and later, excluding 5.0.x.
module Amazonka.EMR.AddInstanceFleet
  ( -- * Creating a Request
    AddInstanceFleet (..),
    newAddInstanceFleet,

    -- * Request Lenses
    addInstanceFleet_clusterId,
    addInstanceFleet_instanceFleet,

    -- * Destructuring the Response
    AddInstanceFleetResponse (..),
    newAddInstanceFleetResponse,

    -- * Response Lenses
    addInstanceFleetResponse_clusterArn,
    addInstanceFleetResponse_clusterId,
    addInstanceFleetResponse_instanceFleetId,
    addInstanceFleetResponse_httpStatus,
  )
where

import qualified Amazonka.Core as Core
import qualified Amazonka.Core.Lens.Internal as Lens
import qualified Amazonka.Data as Data
import Amazonka.EMR.Types
import qualified Amazonka.Prelude as Prelude
import qualified Amazonka.Request as Request
import qualified Amazonka.Response as Response

-- | /See:/ 'newAddInstanceFleet' smart constructor.
data AddInstanceFleet = AddInstanceFleet'
  { -- | The unique identifier of the cluster.
    AddInstanceFleet -> Text
clusterId :: Prelude.Text,
    -- | Specifies the configuration of the instance fleet.
    AddInstanceFleet -> InstanceFleetConfig
instanceFleet :: InstanceFleetConfig
  }
  deriving (AddInstanceFleet -> AddInstanceFleet -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: AddInstanceFleet -> AddInstanceFleet -> Bool
$c/= :: AddInstanceFleet -> AddInstanceFleet -> Bool
== :: AddInstanceFleet -> AddInstanceFleet -> Bool
$c== :: AddInstanceFleet -> AddInstanceFleet -> Bool
Prelude.Eq, ReadPrec [AddInstanceFleet]
ReadPrec AddInstanceFleet
Int -> ReadS AddInstanceFleet
ReadS [AddInstanceFleet]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [AddInstanceFleet]
$creadListPrec :: ReadPrec [AddInstanceFleet]
readPrec :: ReadPrec AddInstanceFleet
$creadPrec :: ReadPrec AddInstanceFleet
readList :: ReadS [AddInstanceFleet]
$creadList :: ReadS [AddInstanceFleet]
readsPrec :: Int -> ReadS AddInstanceFleet
$creadsPrec :: Int -> ReadS AddInstanceFleet
Prelude.Read, Int -> AddInstanceFleet -> ShowS
[AddInstanceFleet] -> ShowS
AddInstanceFleet -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [AddInstanceFleet] -> ShowS
$cshowList :: [AddInstanceFleet] -> ShowS
show :: AddInstanceFleet -> String
$cshow :: AddInstanceFleet -> String
showsPrec :: Int -> AddInstanceFleet -> ShowS
$cshowsPrec :: Int -> AddInstanceFleet -> ShowS
Prelude.Show, forall x. Rep AddInstanceFleet x -> AddInstanceFleet
forall x. AddInstanceFleet -> Rep AddInstanceFleet x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep AddInstanceFleet x -> AddInstanceFleet
$cfrom :: forall x. AddInstanceFleet -> Rep AddInstanceFleet x
Prelude.Generic)

-- |
-- Create a value of 'AddInstanceFleet' with all optional fields omitted.
--
-- Use <https://hackage.haskell.org/package/generic-lens generic-lens> or <https://hackage.haskell.org/package/optics optics> to modify other optional fields.
--
-- The following record fields are available, with the corresponding lenses provided
-- for backwards compatibility:
--
-- 'clusterId', 'addInstanceFleet_clusterId' - The unique identifier of the cluster.
--
-- 'instanceFleet', 'addInstanceFleet_instanceFleet' - Specifies the configuration of the instance fleet.
newAddInstanceFleet ::
  -- | 'clusterId'
  Prelude.Text ->
  -- | 'instanceFleet'
  InstanceFleetConfig ->
  AddInstanceFleet
newAddInstanceFleet :: Text -> InstanceFleetConfig -> AddInstanceFleet
newAddInstanceFleet Text
pClusterId_ InstanceFleetConfig
pInstanceFleet_ =
  AddInstanceFleet'
    { $sel:clusterId:AddInstanceFleet' :: Text
clusterId = Text
pClusterId_,
      $sel:instanceFleet:AddInstanceFleet' :: InstanceFleetConfig
instanceFleet = InstanceFleetConfig
pInstanceFleet_
    }

-- | The unique identifier of the cluster.
addInstanceFleet_clusterId :: Lens.Lens' AddInstanceFleet Prelude.Text
addInstanceFleet_clusterId :: Lens' AddInstanceFleet Text
addInstanceFleet_clusterId = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\AddInstanceFleet' {Text
clusterId :: Text
$sel:clusterId:AddInstanceFleet' :: AddInstanceFleet -> Text
clusterId} -> Text
clusterId) (\s :: AddInstanceFleet
s@AddInstanceFleet' {} Text
a -> AddInstanceFleet
s {$sel:clusterId:AddInstanceFleet' :: Text
clusterId = Text
a} :: AddInstanceFleet)

-- | Specifies the configuration of the instance fleet.
addInstanceFleet_instanceFleet :: Lens.Lens' AddInstanceFleet InstanceFleetConfig
addInstanceFleet_instanceFleet :: Lens' AddInstanceFleet InstanceFleetConfig
addInstanceFleet_instanceFleet = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\AddInstanceFleet' {InstanceFleetConfig
instanceFleet :: InstanceFleetConfig
$sel:instanceFleet:AddInstanceFleet' :: AddInstanceFleet -> InstanceFleetConfig
instanceFleet} -> InstanceFleetConfig
instanceFleet) (\s :: AddInstanceFleet
s@AddInstanceFleet' {} InstanceFleetConfig
a -> AddInstanceFleet
s {$sel:instanceFleet:AddInstanceFleet' :: InstanceFleetConfig
instanceFleet = InstanceFleetConfig
a} :: AddInstanceFleet)

instance Core.AWSRequest AddInstanceFleet where
  type
    AWSResponse AddInstanceFleet =
      AddInstanceFleetResponse
  request :: (Service -> Service)
-> AddInstanceFleet -> Request AddInstanceFleet
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 AddInstanceFleet
-> ClientResponse ClientBody
-> m (Either Error (ClientResponse (AWSResponse AddInstanceFleet)))
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 ->
          Maybe Text
-> Maybe Text -> Maybe Text -> Int -> AddInstanceFleetResponse
AddInstanceFleetResponse'
            forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
Prelude.<$> (Object
x forall a. FromJSON a => Object -> Key -> Either String (Maybe a)
Data..?> Key
"ClusterArn")
            forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
Prelude.<*> (Object
x forall a. FromJSON a => Object -> Key -> Either String (Maybe a)
Data..?> Key
"ClusterId")
            forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
Prelude.<*> (Object
x forall a. FromJSON a => Object -> Key -> Either String (Maybe a)
Data..?> Key
"InstanceFleetId")
            forall (f :: * -> *) a b. Applicative f => 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))
      )

instance Prelude.Hashable AddInstanceFleet where
  hashWithSalt :: Int -> AddInstanceFleet -> Int
hashWithSalt Int
_salt AddInstanceFleet' {Text
InstanceFleetConfig
instanceFleet :: InstanceFleetConfig
clusterId :: Text
$sel:instanceFleet:AddInstanceFleet' :: AddInstanceFleet -> InstanceFleetConfig
$sel:clusterId:AddInstanceFleet' :: AddInstanceFleet -> Text
..} =
    Int
_salt
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Text
clusterId
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` InstanceFleetConfig
instanceFleet

instance Prelude.NFData AddInstanceFleet where
  rnf :: AddInstanceFleet -> ()
rnf AddInstanceFleet' {Text
InstanceFleetConfig
instanceFleet :: InstanceFleetConfig
clusterId :: Text
$sel:instanceFleet:AddInstanceFleet' :: AddInstanceFleet -> InstanceFleetConfig
$sel:clusterId:AddInstanceFleet' :: AddInstanceFleet -> Text
..} =
    forall a. NFData a => a -> ()
Prelude.rnf Text
clusterId
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf InstanceFleetConfig
instanceFleet

instance Data.ToHeaders AddInstanceFleet where
  toHeaders :: AddInstanceFleet -> ResponseHeaders
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 -> ResponseHeaders
Data.=# ( ByteString
"ElasticMapReduce.AddInstanceFleet" ::
                          Prelude.ByteString
                      ),
            HeaderName
"Content-Type"
              forall a. ToHeader a => HeaderName -> a -> ResponseHeaders
Data.=# ( ByteString
"application/x-amz-json-1.1" ::
                          Prelude.ByteString
                      )
          ]
      )

instance Data.ToJSON AddInstanceFleet where
  toJSON :: AddInstanceFleet -> Value
toJSON AddInstanceFleet' {Text
InstanceFleetConfig
instanceFleet :: InstanceFleetConfig
clusterId :: Text
$sel:instanceFleet:AddInstanceFleet' :: AddInstanceFleet -> InstanceFleetConfig
$sel:clusterId:AddInstanceFleet' :: AddInstanceFleet -> Text
..} =
    [Pair] -> Value
Data.object
      ( forall a. [Maybe a] -> [a]
Prelude.catMaybes
          [ forall a. a -> Maybe a
Prelude.Just (Key
"ClusterId" forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
Data..= Text
clusterId),
            forall a. a -> Maybe a
Prelude.Just
              (Key
"InstanceFleet" forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
Data..= InstanceFleetConfig
instanceFleet)
          ]
      )

instance Data.ToPath AddInstanceFleet where
  toPath :: AddInstanceFleet -> ByteString
toPath = forall a b. a -> b -> a
Prelude.const ByteString
"/"

instance Data.ToQuery AddInstanceFleet where
  toQuery :: AddInstanceFleet -> QueryString
toQuery = forall a b. a -> b -> a
Prelude.const forall a. Monoid a => a
Prelude.mempty

-- | /See:/ 'newAddInstanceFleetResponse' smart constructor.
data AddInstanceFleetResponse = AddInstanceFleetResponse'
  { -- | The Amazon Resource Name of the cluster.
    AddInstanceFleetResponse -> Maybe Text
clusterArn :: Prelude.Maybe Prelude.Text,
    -- | The unique identifier of the cluster.
    AddInstanceFleetResponse -> Maybe Text
clusterId :: Prelude.Maybe Prelude.Text,
    -- | The unique identifier of the instance fleet.
    AddInstanceFleetResponse -> Maybe Text
instanceFleetId :: Prelude.Maybe Prelude.Text,
    -- | The response's http status code.
    AddInstanceFleetResponse -> Int
httpStatus :: Prelude.Int
  }
  deriving (AddInstanceFleetResponse -> AddInstanceFleetResponse -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: AddInstanceFleetResponse -> AddInstanceFleetResponse -> Bool
$c/= :: AddInstanceFleetResponse -> AddInstanceFleetResponse -> Bool
== :: AddInstanceFleetResponse -> AddInstanceFleetResponse -> Bool
$c== :: AddInstanceFleetResponse -> AddInstanceFleetResponse -> Bool
Prelude.Eq, ReadPrec [AddInstanceFleetResponse]
ReadPrec AddInstanceFleetResponse
Int -> ReadS AddInstanceFleetResponse
ReadS [AddInstanceFleetResponse]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [AddInstanceFleetResponse]
$creadListPrec :: ReadPrec [AddInstanceFleetResponse]
readPrec :: ReadPrec AddInstanceFleetResponse
$creadPrec :: ReadPrec AddInstanceFleetResponse
readList :: ReadS [AddInstanceFleetResponse]
$creadList :: ReadS [AddInstanceFleetResponse]
readsPrec :: Int -> ReadS AddInstanceFleetResponse
$creadsPrec :: Int -> ReadS AddInstanceFleetResponse
Prelude.Read, Int -> AddInstanceFleetResponse -> ShowS
[AddInstanceFleetResponse] -> ShowS
AddInstanceFleetResponse -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [AddInstanceFleetResponse] -> ShowS
$cshowList :: [AddInstanceFleetResponse] -> ShowS
show :: AddInstanceFleetResponse -> String
$cshow :: AddInstanceFleetResponse -> String
showsPrec :: Int -> AddInstanceFleetResponse -> ShowS
$cshowsPrec :: Int -> AddInstanceFleetResponse -> ShowS
Prelude.Show, forall x.
Rep AddInstanceFleetResponse x -> AddInstanceFleetResponse
forall x.
AddInstanceFleetResponse -> Rep AddInstanceFleetResponse x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x.
Rep AddInstanceFleetResponse x -> AddInstanceFleetResponse
$cfrom :: forall x.
AddInstanceFleetResponse -> Rep AddInstanceFleetResponse x
Prelude.Generic)

-- |
-- Create a value of 'AddInstanceFleetResponse' with all optional fields omitted.
--
-- Use <https://hackage.haskell.org/package/generic-lens generic-lens> or <https://hackage.haskell.org/package/optics optics> to modify other optional fields.
--
-- The following record fields are available, with the corresponding lenses provided
-- for backwards compatibility:
--
-- 'clusterArn', 'addInstanceFleetResponse_clusterArn' - The Amazon Resource Name of the cluster.
--
-- 'clusterId', 'addInstanceFleetResponse_clusterId' - The unique identifier of the cluster.
--
-- 'instanceFleetId', 'addInstanceFleetResponse_instanceFleetId' - The unique identifier of the instance fleet.
--
-- 'httpStatus', 'addInstanceFleetResponse_httpStatus' - The response's http status code.
newAddInstanceFleetResponse ::
  -- | 'httpStatus'
  Prelude.Int ->
  AddInstanceFleetResponse
newAddInstanceFleetResponse :: Int -> AddInstanceFleetResponse
newAddInstanceFleetResponse Int
pHttpStatus_ =
  AddInstanceFleetResponse'
    { $sel:clusterArn:AddInstanceFleetResponse' :: Maybe Text
clusterArn =
        forall a. Maybe a
Prelude.Nothing,
      $sel:clusterId:AddInstanceFleetResponse' :: Maybe Text
clusterId = forall a. Maybe a
Prelude.Nothing,
      $sel:instanceFleetId:AddInstanceFleetResponse' :: Maybe Text
instanceFleetId = forall a. Maybe a
Prelude.Nothing,
      $sel:httpStatus:AddInstanceFleetResponse' :: Int
httpStatus = Int
pHttpStatus_
    }

-- | The Amazon Resource Name of the cluster.
addInstanceFleetResponse_clusterArn :: Lens.Lens' AddInstanceFleetResponse (Prelude.Maybe Prelude.Text)
addInstanceFleetResponse_clusterArn :: Lens' AddInstanceFleetResponse (Maybe Text)
addInstanceFleetResponse_clusterArn = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\AddInstanceFleetResponse' {Maybe Text
clusterArn :: Maybe Text
$sel:clusterArn:AddInstanceFleetResponse' :: AddInstanceFleetResponse -> Maybe Text
clusterArn} -> Maybe Text
clusterArn) (\s :: AddInstanceFleetResponse
s@AddInstanceFleetResponse' {} Maybe Text
a -> AddInstanceFleetResponse
s {$sel:clusterArn:AddInstanceFleetResponse' :: Maybe Text
clusterArn = Maybe Text
a} :: AddInstanceFleetResponse)

-- | The unique identifier of the cluster.
addInstanceFleetResponse_clusterId :: Lens.Lens' AddInstanceFleetResponse (Prelude.Maybe Prelude.Text)
addInstanceFleetResponse_clusterId :: Lens' AddInstanceFleetResponse (Maybe Text)
addInstanceFleetResponse_clusterId = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\AddInstanceFleetResponse' {Maybe Text
clusterId :: Maybe Text
$sel:clusterId:AddInstanceFleetResponse' :: AddInstanceFleetResponse -> Maybe Text
clusterId} -> Maybe Text
clusterId) (\s :: AddInstanceFleetResponse
s@AddInstanceFleetResponse' {} Maybe Text
a -> AddInstanceFleetResponse
s {$sel:clusterId:AddInstanceFleetResponse' :: Maybe Text
clusterId = Maybe Text
a} :: AddInstanceFleetResponse)

-- | The unique identifier of the instance fleet.
addInstanceFleetResponse_instanceFleetId :: Lens.Lens' AddInstanceFleetResponse (Prelude.Maybe Prelude.Text)
addInstanceFleetResponse_instanceFleetId :: Lens' AddInstanceFleetResponse (Maybe Text)
addInstanceFleetResponse_instanceFleetId = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\AddInstanceFleetResponse' {Maybe Text
instanceFleetId :: Maybe Text
$sel:instanceFleetId:AddInstanceFleetResponse' :: AddInstanceFleetResponse -> Maybe Text
instanceFleetId} -> Maybe Text
instanceFleetId) (\s :: AddInstanceFleetResponse
s@AddInstanceFleetResponse' {} Maybe Text
a -> AddInstanceFleetResponse
s {$sel:instanceFleetId:AddInstanceFleetResponse' :: Maybe Text
instanceFleetId = Maybe Text
a} :: AddInstanceFleetResponse)

-- | The response's http status code.
addInstanceFleetResponse_httpStatus :: Lens.Lens' AddInstanceFleetResponse Prelude.Int
addInstanceFleetResponse_httpStatus :: Lens' AddInstanceFleetResponse Int
addInstanceFleetResponse_httpStatus = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\AddInstanceFleetResponse' {Int
httpStatus :: Int
$sel:httpStatus:AddInstanceFleetResponse' :: AddInstanceFleetResponse -> Int
httpStatus} -> Int
httpStatus) (\s :: AddInstanceFleetResponse
s@AddInstanceFleetResponse' {} Int
a -> AddInstanceFleetResponse
s {$sel:httpStatus:AddInstanceFleetResponse' :: Int
httpStatus = Int
a} :: AddInstanceFleetResponse)

instance Prelude.NFData AddInstanceFleetResponse where
  rnf :: AddInstanceFleetResponse -> ()
rnf AddInstanceFleetResponse' {Int
Maybe Text
httpStatus :: Int
instanceFleetId :: Maybe Text
clusterId :: Maybe Text
clusterArn :: Maybe Text
$sel:httpStatus:AddInstanceFleetResponse' :: AddInstanceFleetResponse -> Int
$sel:instanceFleetId:AddInstanceFleetResponse' :: AddInstanceFleetResponse -> Maybe Text
$sel:clusterId:AddInstanceFleetResponse' :: AddInstanceFleetResponse -> Maybe Text
$sel:clusterArn:AddInstanceFleetResponse' :: AddInstanceFleetResponse -> Maybe Text
..} =
    forall a. NFData a => a -> ()
Prelude.rnf Maybe Text
clusterArn
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe Text
clusterId
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe Text
instanceFleetId
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Int
httpStatus